kekos / prest-doc
Static Site Generator for OpenAPI documentation
Installs: 136
Dependents: 0
Suggesters: 0
Security: 0
Stars: 0
Watchers: 1
Forks: 0
Open Issues: 0
pkg:composer/kekos/prest-doc
Requires
- php: ~8.1.0 || ~8.2.0 || ~8.3.0
- ext-mbstring: *
- cebe/php-openapi: ^1.8
- league/commonmark: ^2.3
- spatie/commonmark-highlighter: ^3.0
- symfony/yaml: ^6.0 || ^7.0
Requires (Dev)
- phpstan/phpstan: ^1.8
README
Static Site Generator for OpenAPI documentation written in PHP.
Install
composer require kekos/prest-doc
Requires at least PHP 8.1.
Usage
./bin/prest-doc <in_directory> <out_directory> <layout_file> [<config_file>]
- <in_directory>points to a directory which Prest-doc should read and convert.
- <out_directory>points to a directory where converted files will be written. Please note that this directory will be deleted by Prest-doc on each run
- <layout_file>is a file path to layout file. See the- examples/directory.
- <config_file>is a file path to configuration. Optional.
Configuration
API templates
You can override the default OpenAPI Markdown templates by creating a configuration file and supply it with your own instances of template interfaces:
<?php use Kekos\PrestDoc\Configuration; use Kekos\PrestDoc\ApiTemplates\Contracts\SchemaTemplate; return new Configuration( api_templates_class_map: [ SchemaTemplate::class => new MyOwnImplementationOfSchemaTemplate(), ], );
Topics menu
Prest-doc can be configured with how it should create the main API navigation, the "topics menu". Two implementations
are included, but you can build your own by implementing the interface \Kekos\PrestDoc\ApiEntities\TopicsRepository.
Use the Configuration class´ api_templates_class_map property to configure this.
TaggedTopicsRepository (default)
All path operations must have a tag prefixed with topic-. That tag will be used to group operations together under the
name of tag, excluding topic-.
SingleTopicRepository
All paths are grouped to a single topic "Operations".
Features
- Converts OpenAPI specifications (JSON) to HTML.
- Allows for own HTML layout template, written in PHP.
- Allows for own CSS and JavaScript.
- Sort paths (topics) in an order logical for you and your app.
Bugs and improvements
Report bugs in GitHub issues or feel free to make a pull request :-)
License
MIT