Skip to content

Commit

Permalink
Add yaml support (#131)
Browse files Browse the repository at this point in the history
* Allow generate YAML copy

* Allow generate YAML copy

* Allow to use YAML for docs

* Apply fixes from StyleCI

[ci skip] [skip ci]

* Update readme

* composer update

* cleanup

---------

Co-authored-by: StyleCI Bot <bot@styleci.io>
  • Loading branch information
DarkaOnLine and StyleCIBot authored May 10, 2023
1 parent 7d93fac commit 5db6551
Show file tree
Hide file tree
Showing 9 changed files with 109 additions and 19 deletions.
4 changes: 2 additions & 2 deletions Dockerfile
Original file line number Diff line number Diff line change
@@ -1,7 +1,7 @@
#
# Base install
#
FROM amd64/php:8.0-apache as base
FROM amd64/php:8.1-apache as base

LABEL vendor="SwaggerLume"

Expand Down Expand Up @@ -60,7 +60,7 @@ WORKDIR /app/swaggerLume-app

RUN /usr/local/bin/php -dxdebug.mode=off /usr/local/bin/composer config repositories.swagger-lume path '../'

RUN /usr/local/bin/php -dxdebug.mode=off /usr/local/bin/composer require 'DarkaOnLine/swagger-lume:dev-master'
RUN /usr/local/bin/php -dxdebug.mode=off /usr/local/bin/composer require 'darkaonline/swagger-lume:dev-master'

RUN ln -s /app/tests/storage/annotations/ app/annotations

Expand Down
1 change: 1 addition & 0 deletions README.md
Original file line number Diff line number Diff line change
Expand Up @@ -25,6 +25,7 @@ Installation
7.0 | 3 | 2.0, 3.0 | ``` composer require "darkaonline/swagger-lume:7.*" ```
8.0 | 3 | 2.0, 3.0 | ``` composer require "darkaonline/swagger-lume:8.*" ```
9.0 | 3 | 2.0, 3.0 | ``` composer require "darkaonline/swagger-lume:9.*" ```
10.0 | 3 | 2.0, 3.0 | ``` composer require "darkaonline/swagger-lume:10.*" ```

- Open your `bootstrap/app.php` file and:

Expand Down
3 changes: 2 additions & 1 deletion composer.json
Original file line number Diff line number Diff line change
Expand Up @@ -23,7 +23,8 @@
"php": ">=7.2 || ^8.0",
"laravel/lumen-framework": "~6.0 || ~7.0 || ^8.0 || ^9.0 || ^10.0",
"zircote/swagger-php": "~2.0 || 3.*",
"swagger-api/swagger-ui": "^3.0 || ^4.0"
"swagger-api/swagger-ui": "^3.0 || ^4.0",
"symfony/yaml": "^4.0 || ^5.0 || ^6.2"
},
"require-dev": {
"phpunit/phpunit": "^10.0 || ^9.5",
Expand Down
21 changes: 21 additions & 0 deletions config/swagger-lume.php
Original file line number Diff line number Diff line change
Expand Up @@ -67,6 +67,19 @@
*/
'docs_json' => 'api-docs.json',

/*
|--------------------------------------------------------------------------
| File name of the generated YAML documentation file
|--------------------------------------------------------------------------
*/

'docs_yaml' => 'api-docs.yaml',

/*
* Set this to `json` or `yaml` to determine which documentation file to use in UI
*/
'format_to_use_for_docs' => env('SWAGGER_LUME__FORMAT_TO_USE_FOR_DOCS', 'json'),

/*
|--------------------------------------------------------------------------
| Absolute path to directory containing the swagger annotations are stored.
Expand Down Expand Up @@ -151,6 +164,14 @@
*/
'generate_always' => env('SWAGGER_GENERATE_ALWAYS', false),

/*
|--------------------------------------------------------------------------
| Turn this on to generate a copy of documentation in yaml format
|--------------------------------------------------------------------------
*/

'generate_yaml_copy' => env('SWAGGER_LUME_GENERATE_YAML_COPY', false),

/*
|--------------------------------------------------------------------------
| Edit to set the swagger version number
Expand Down
27 changes: 25 additions & 2 deletions src/Generator.php
Original file line number Diff line number Diff line change
Expand Up @@ -4,6 +4,10 @@

use Illuminate\Support\Facades\File;
use OpenApi\Annotations\Server;
use OpenApi\Generator as OpenApiGenerator;
use OpenApi\Util;
use Symfony\Component\Yaml\Dumper as YamlDumper;
use Symfony\Component\Yaml\Yaml;

class Generator
{
Expand All @@ -23,7 +27,9 @@ public static function generateDocs()
$excludeDirs = config('swagger-lume.paths.excludes');

if (version_compare(config('swagger-lume.swagger_version'), '3.0', '>=')) {
$swagger = \OpenApi\scan($appDir, ['exclude' => $excludeDirs]);
$generator = new OpenApiGenerator();
$finder = Util::finder($appDir, $excludeDirs);
$swagger = $generator->generate($finder);
} else {
$swagger = \Swagger\scan($appDir, ['exclude' => $excludeDirs]);
}
Expand All @@ -38,11 +44,13 @@ public static function generateDocs()
}
}

$filename = $docDir.'/'.config('swagger-lume.paths.docs_json');
$filename = sprintf('%s/%s', $docDir, config('swagger-lume.paths.docs_json'));
$swagger->saveAs($filename);

$security = new SecurityDefinitions();
$security->generate($filename);

self::makeYamlCopy($filename);
}
}

Expand All @@ -54,4 +62,19 @@ protected static function defineConstants(array $constants)
}
}
}

protected static function makeYamlCopy($filename)
{
if (config('swagger-lume.generate_yaml_copy')) {
$path = sprintf('%s/%s', config('swagger-lume.paths.docs'), config('swagger-lume.paths.docs_yaml'));
$yamlContent = (new YamlDumper(2))->dump(
json_decode(file_get_contents($filename), true),
20,
0,
Yaml::DUMP_OBJECT_AS_MAP ^ Yaml::DUMP_EMPTY_ARRAY_AS_SEQUENCE
);

file_put_contents($path, $yamlContent);
}
}
}
36 changes: 27 additions & 9 deletions src/Http/Controllers/SwaggerLumeController.php
Original file line number Diff line number Diff line change
Expand Up @@ -4,7 +4,8 @@

use Illuminate\Http\Response;
use Illuminate\Support\Facades\File;
use Illuminate\Support\Facades\Request;
use Illuminate\Support\Facades\Log;
use Illuminate\Support\Facades\Request as RequestFacade;
use Laravel\Lumen\Routing\Controller as BaseController;
use SwaggerLume\Generator;

Expand All @@ -13,13 +14,24 @@ class SwaggerLumeController extends BaseController
/**
* Dump api-docs.json content endpoint.
*
* @param null $jsonFile
* @param null $docsFile
* @return \Illuminate\Http\Response
*/
public function docs($jsonFile = null)
public function docs()
{
$filePath = config('swagger-lume.paths.docs').'/'.
(! is_null($jsonFile) ? $jsonFile : config('swagger-lume.paths.docs_json'));
$filePath = sprintf(
'%s/%s',
config('swagger-lume.paths.docs'),
config('swagger-lume.paths.format_to_use_for_docs') === 'json' ? config('swagger-lume.paths.docs_json') : config('swagger-lume.paths.docs_yaml')
);

$yaml = false;
$parts = explode('.', $filePath);

if (! empty($parts)) {
$extension = array_pop($parts);
$yaml = strtolower($extension) === 'yaml';
}

if (config('swagger-lume.generate_always') && ! File::exists($filePath)) {
try {
Expand All @@ -44,6 +56,14 @@ public function docs($jsonFile = null)

$content = File::get($filePath);

if ($yaml) {
return Response($content, 200, [
'Content-Type' => 'application/yaml',
'Content-Disposition' => 'inline',
'filename' => config('swagger-lume.paths.docs_yaml'),
]);
}

return new Response($content, 200, ['Content-Type' => 'application/json']);
}

Expand All @@ -59,9 +79,9 @@ public function api()
}

//need the / at the end to avoid CORS errors on Homestead systems.
$response = new Response(
return new Response(
view('swagger-lume::index', [
'secure' => Request::secure(),
'secure' => RequestFacade::secure(),
'urlToDocs' => route('swagger-lume.docs'),
'operationsSorter' => config('swagger-lume.operations_sort'),
'configUrl' => config('swagger-lume.additional_config_url'),
Expand All @@ -70,8 +90,6 @@ public function api()
200,
['Content-Type' => 'text/html']
);

return $response;
}

/**
Expand Down
6 changes: 4 additions & 2 deletions tests/GeneratorTest.php
Original file line number Diff line number Diff line change
Expand Up @@ -7,13 +7,14 @@
class GeneratorTest extends LumenTestCase
{
/** @test */
public function canGenerateApiJsonFile()
public function canGenerateApiJsonAndYamlFile()
{
$this->setPaths();

Generator::generateDocs();

$this->assertTrue(file_exists($this->jsonDocsFile()));
$this->assertTrue(file_exists($this->yamlDocsFile()));

$response = $this->get(config('swagger-lume.routes.docs'));

Expand All @@ -24,7 +25,7 @@ public function canGenerateApiJsonFile()
}

/** @test */
public function canGenerateApiJsonFileWithChangedBasePath()
public function canGenerateApiJsonAndYamlFileWithChangedBasePath()
{
if ($this->isOpenApi() == true) {
$this->markTestSkipped('only for openApi 2.0');
Expand All @@ -39,6 +40,7 @@ public function canGenerateApiJsonFileWithChangedBasePath()
Generator::generateDocs();

$this->assertTrue(file_exists($this->jsonDocsFile()));
$this->assertTrue(file_exists($this->yamlDocsFile()));

$response = $this->get(config('swagger-lume.routes.docs'));

Expand Down
28 changes: 26 additions & 2 deletions tests/LumenTestCase.php
Original file line number Diff line number Diff line change
Expand Up @@ -23,6 +23,10 @@ public function tearDown(): void
if (file_exists($this->jsonDocsFile())) {
unlink($this->jsonDocsFile());
}

if (file_exists($this->yamlDocsFile())) {
unlink($this->yamlDocsFile());
}
parent::tearDown();
}

Expand Down Expand Up @@ -106,6 +110,8 @@ protected function setPaths()
//For test we want to regenerate always
$cfg['generate_always'] = true;

$cfg['generate_yaml_copy'] = true;

//Adding constants which will be replaced in generated json file
$cfg['constants']['SWAGGER_LUME_CONST_HOST'] = 'http://my-default-host.com';

Expand All @@ -122,14 +128,32 @@ protected function setPaths()
return $this;
}

protected function crateJsonDocumentationFile()
protected function createJsonDocumentationFile()
{
file_put_contents($this->jsonDocsFile(), '');
}

protected function createYamlDocumentationFile()
{
file_put_contents($this->yamlDocsFile(), '');
}

protected function jsonDocsFile()
{
return config('swagger-lume.paths.docs').'/api-docs.json';
return sprintf(
'%s/%s',
config('swagger-lume.paths.docs'),
config('swagger-lume.paths.docs_json')
);
}

protected function yamlDocsFile()
{
return sprintf(
'%s/%s',
config('swagger-lume.paths.docs'),
config('swagger-lume.paths.docs_yaml')
);
}

protected function copyAssets()
Expand Down
2 changes: 1 addition & 1 deletion tests/RoutesTest.php
Original file line number Diff line number Diff line change
Expand Up @@ -19,7 +19,7 @@ public function canAccessJsonFile()
{
$jsonUrl = config('swagger-lume.routes.docs');

$this->setPaths()->crateJsonDocumentationFile();
$this->setPaths()->createJsonDocumentationFile();

$this->get($jsonUrl);

Expand Down

0 comments on commit 5db6551

Please sign in to comment.