From 2efad5167812e5949292e32af7bfe1f3f3557410 Mon Sep 17 00:00:00 2001 From: StarProxima Date: Fri, 6 Oct 2023 19:42:40 +0300 Subject: [PATCH 01/10] Schema from url --- .../lib/src/config/yaml_config.dart | 61 ++++++++++------- .../lib/src/generator/generator.dart | 65 ++++++++++++++----- swagger_parser/lib/src/parser/parser.dart | 6 +- swagger_parser/lib/src/utils/file_utils.dart | 13 ++++ swagger_parser/lib/src/utils/utils.dart | 20 +++--- 5 files changed, 115 insertions(+), 50 deletions(-) diff --git a/swagger_parser/lib/src/config/yaml_config.dart b/swagger_parser/lib/src/config/yaml_config.dart index ceb189a2..942acf33 100644 --- a/swagger_parser/lib/src/config/yaml_config.dart +++ b/swagger_parser/lib/src/config/yaml_config.dart @@ -20,6 +20,7 @@ final class YamlConfig { required this.schemaPath, required this.outputDirectory, required this.name, + this.schemaUrl, this.language, this.freezed, this.rootClient, @@ -73,6 +74,31 @@ final class YamlConfig { outputDirectory = rootConfig.outputDirectory; } + final rawName = yamlConfig['name']; + if (rawName is! String?) { + throw const ConfigException( + "Config parameter 'name' must be String.", + ); + } + + final name = rawName == null || rawName.isEmpty + ? schemaPath.split('/').last.split('.').first + : rawName; + + final schemaUrl = yamlConfig['schema_url']; + if (schemaUrl is! String?) { + throw const ConfigException( + "Config parameter 'schema_url' must be String.", + ); + } else if (schemaUrl != null) { + final uri = Uri.tryParse(schemaUrl); + if (uri == null) { + throw const ConfigException( + "Config parameter 'schema_url' must be valid URL.", + ); + } + } + ProgrammingLanguage? language; final rawLanguage = yamlConfig['language']?.toString(); if (rawLanguage != null) { @@ -117,6 +143,13 @@ final class YamlConfig { ); } + final putInFolder = yamlConfig['put_in_folder']; + if (putInFolder is! bool?) { + throw const ConfigException( + "Config parameter 'put_in_folder' must be bool.", + ); + } + final squashClients = yamlConfig['squash_clients']; if (squashClients is! bool?) { throw const ConfigException( @@ -180,37 +213,20 @@ final class YamlConfig { } } - final putInFolder = yamlConfig['put_in_folder']; - if (putInFolder is! bool?) { - throw const ConfigException( - "Config parameter 'put_in_folder' must be bool.", - ); - } - - final rawName = yamlConfig['name']; - if (rawName is! String?) { - throw const ConfigException( - "Config parameter 'name' must be String.", - ); - } - - final name = rawName == null || rawName.isEmpty - ? schemaPath.split('/').last.split('.').first - : rawName; - return YamlConfig( + name: name, schemaPath: schemaPath, outputDirectory: outputDirectory, - name: name, + schemaUrl: schemaUrl, language: language ?? rootConfig?.language, freezed: freezed ?? rootConfig?.freezed, rootClient: rootClient ?? rootConfig?.rootClient, rootClientName: rootClientName ?? rootConfig?.rootClientName, clientPostfix: clientPostfix ?? rootConfig?.clientPostfix, + putInFolder: putInFolder ?? rootConfig?.putInFolder, putClientsInFolder: putClientsInFolder ?? rootConfig?.putClientsInFolder, squashClients: squashClients ?? rootConfig?.squashClients, pathMethodName: pathMethodName ?? rootConfig?.pathMethodName, - putInFolder: putInFolder ?? rootConfig?.putInFolder, enumsToJson: enumsToJson ?? rootConfig?.enumsToJson, enumsPrefix: enumsPrefix ?? rootConfig?.enumsPrefix, markFilesAsGenerated: @@ -289,17 +305,18 @@ final class YamlConfig { return configs; } - final String name; final String schemaPath; final String outputDirectory; + final String name; + final String? schemaUrl; final ProgrammingLanguage? language; final bool? freezed; final String? clientPostfix; final bool? rootClient; final String? rootClientName; - final bool? putClientsInFolder; final bool? squashClients; final bool? pathMethodName; + final bool? putClientsInFolder; final bool? putInFolder; final bool? enumsToJson; final bool? enumsPrefix; diff --git a/swagger_parser/lib/src/generator/generator.dart b/swagger_parser/lib/src/generator/generator.dart index cc9ac8dd..be589375 100644 --- a/swagger_parser/lib/src/generator/generator.dart +++ b/swagger_parser/lib/src/generator/generator.dart @@ -4,6 +4,7 @@ import '../config/yaml_config.dart'; import '../parser/parser.dart'; import '../utils/case_utils.dart'; import '../utils/file_utils.dart'; +import '../utils/utils.dart'; import 'fill_controller.dart'; import 'generator_exception.dart'; import 'models/generated_file.dart'; @@ -21,11 +22,11 @@ final class Generator { /// Applies parameters directly from constructor /// and sets them to default if not found Generator({ - required String schemaContent, required String outputDirectory, + required String schemaPath, + String? schemaUrl, ProgrammingLanguage? language, String? name, - bool? isYaml, bool? freezed, bool? rootClient, String? clientPostfix, @@ -38,11 +39,11 @@ final class Generator { bool? enumsPrefix, bool? markFilesAsGenerated, List? replacementRules, - }) : _schemaContent = schemaContent, + }) : _schemaPath = schemaPath, + _schemaUrl = schemaUrl, _outputDirectory = outputDirectory, _name = name, _programmingLanguage = language ?? ProgrammingLanguage.dart, - _isYaml = isYaml ?? false, _freezed = freezed ?? false, _rootClient = rootClient ?? true, _rootClientName = rootClientName ?? 'RestClient', @@ -58,21 +59,12 @@ final class Generator { /// Applies parameters set from yaml config file factory Generator.fromYamlConfig(YamlConfig yamlConfig) { - final schemaPath = yamlConfig.schemaPath; - final configFile = schemaFile(schemaPath); - if (configFile == null) { - throw GeneratorException("Can't find schema file at $schemaPath."); - } - - final isYaml = p.extension(schemaPath).toLowerCase() == '.yaml'; - final schemaContent = configFile.readAsStringSync(); - return Generator( - schemaContent: schemaContent, outputDirectory: yamlConfig.outputDirectory, + schemaPath: yamlConfig.schemaPath, + schemaUrl: yamlConfig.schemaUrl, language: yamlConfig.language, name: yamlConfig.name, - isYaml: isYaml, freezed: yamlConfig.freezed, rootClient: yamlConfig.rootClient, rootClientName: yamlConfig.rootClientName, @@ -89,10 +81,16 @@ final class Generator { } /// The contents of your schema file - final String _schemaContent; + late final String _schemaContent; /// Is the schema format YAML - final bool _isYaml; + late final bool _isYaml; + + /// The path to your schema file + final String _schemaPath; + + /// The url to your schema file + final String? _schemaUrl; /// Output directory final String _outputDirectory; @@ -155,6 +153,7 @@ final class Generator { Future<(OpenApiInfo, GenerationStatistics)> generateFiles() async { final stopwatch = Stopwatch()..start(); + await _fetchSchemaContent(); _parseOpenApiDefinitionFile(); await _generateFiles(); @@ -181,6 +180,38 @@ final class Generator { return _fillContent(); } + Future _fetchSchemaContent() async { + final url = _schemaUrl; + + if (url != null) { + final extension = p.extension(url).toLowerCase(); + _isYaml = switch (extension) { + '.yaml' => true, + '.json' => false, + _ => throw GeneratorException( + 'Unsupported $url extension: $extension', + ), + }; + extractingSchemaFromUrlMessage(url); + _schemaContent = await schemaUrl(url); + writeSchemaToFile(_schemaContent, _schemaPath); + } else { + final configFile = schemaFile(_schemaPath); + if (configFile == null) { + throw GeneratorException("Can't find schema file at $_schemaPath."); + } + final extension = p.extension(_schemaPath).toLowerCase(); + _isYaml = switch (extension) { + '.yaml' => true, + '.json' => false, + _ => throw GeneratorException( + 'Unsupported $_schemaPath extension: $extension', + ), + }; + _schemaContent = configFile.readAsStringSync(); + } + } + /// Parse definition file content and fill list of [UniversalRestClient] /// and list of [UniversalDataClass] void _parseOpenApiDefinitionFile() { diff --git a/swagger_parser/lib/src/parser/parser.dart b/swagger_parser/lib/src/parser/parser.dart index 3d76e825..3698fc05 100644 --- a/swagger_parser/lib/src/parser/parser.dart +++ b/swagger_parser/lib/src/parser/parser.dart @@ -25,15 +25,15 @@ class OpenApiParser { /// and [isYaml] schema format or not OpenApiParser( String fileContent, { + String? name, bool isYaml = false, bool enumsPrefix = false, bool pathMethodName = false, - String? name, bool squashClients = false, List replacementRules = const [], - }) : _pathMethodName = pathMethodName, + }) : _name = name, + _pathMethodName = pathMethodName, _enumsPrefix = enumsPrefix, - _name = name, _squashClients = squashClients, _replacementRules = replacementRules { _definitionFileContent = isYaml diff --git a/swagger_parser/lib/src/utils/file_utils.dart b/swagger_parser/lib/src/utils/file_utils.dart index 8819aa68..279a4702 100644 --- a/swagger_parser/lib/src/utils/file_utils.dart +++ b/swagger_parser/lib/src/utils/file_utils.dart @@ -1,3 +1,4 @@ +import 'dart:convert'; import 'dart:io'; import 'package:path/path.dart' as p; @@ -30,6 +31,18 @@ File? schemaFile(String filePath) { return file.existsSync() ? file : null; } +void writeSchemaToFile(String schemaContent, String filePath) { + File(p.join(_rootDirectoryPath, filePath)).writeAsStringSync(schemaContent); +} + +Future schemaUrl(String url) async { + final client = HttpClient(); + final request = await client.getUrl(Uri.parse(url)); + final response = await request.close(); + final data = await response.transform(utf8.decoder).join(); + return data; +} + /// Creates DTO file Future generateFile( String outputDirectory, diff --git a/swagger_parser/lib/src/utils/utils.dart b/swagger_parser/lib/src/utils/utils.dart index 8da46b6f..d4ff9e93 100644 --- a/swagger_parser/lib/src/utils/utils.dart +++ b/swagger_parser/lib/src/utils/utils.dart @@ -10,6 +10,9 @@ import '../utils/case_utils.dart'; const _green = '\x1B[32m'; // ignore: unused_element const _yellow = '\x1B[33m'; +// ignore: unused_element +const _blue = '\x1B[34m'; +const _lightBlue = '\x1B[36m'; const _red = '\x1B[31m'; const _reset = '\x1B[0m'; @@ -92,6 +95,10 @@ void generateMessage() { stdout.writeln('Generate...'); } +void extractingSchemaFromUrlMessage(String url) { + stdout.writeln('Extracting schema from $_lightBlue$url...$_reset'); +} + final _numbersRegExp = RegExp(r'(\d{1,3})(?=(\d{3})+(?!\d))'); String formatNumber(int number) => '$number'.replaceAllMapped( @@ -112,12 +119,12 @@ void schemaStatisticsMessage({ } stdout.writeln( - '\n> $title $version: \n' + '> $title $version: \n' ' ${formatNumber(statistics.totalRestClients)} rest clients, ' '${formatNumber(statistics.totalRequests)} requests, ' '${formatNumber(statistics.totalDataClasses)} data classes.\n' ' ${formatNumber(statistics.totalFiles)} files with ${formatNumber(statistics.totalLines)} lines of code.\n' - ' ${_green}Success (${statistics.timeElapsed.inMilliseconds / 1000} seconds)$_reset', + ' ${_green}Success (${statistics.timeElapsed.inMilliseconds / 1000} seconds)$_reset\n', ); } @@ -132,10 +139,10 @@ void schemaFailedMessage({ } stdout.writeln( - '\n> $title: \n' + '> $title: \n' ' ${_red}Failed to generate files.$_reset\n' ' $error\n' - ' ${stack.toString().replaceAll('\n', '\n ')}', + ' ${stack.toString().replaceAll('\n', '\n ')}\n', ); } @@ -145,7 +152,7 @@ void summaryStatisticsMessage({ required GenerationStatistics statistics, }) { stdout.writeln( - '\nSummary (${statistics.timeElapsed.inMilliseconds / 1000} seconds):\n' + 'Summary (${statistics.timeElapsed.inMilliseconds / 1000} seconds):\n' '${successCount != schemasCount ? '$successCount/$schemasCount' : '$schemasCount'} schemas, ' '${formatNumber(statistics.totalRestClients)} clients, ' '${formatNumber(statistics.totalRequests)} requests, ' @@ -160,19 +167,16 @@ void doneMessage({ }) { if (successSchemasCount == 0) { stdout.writeln( - '\n' '${_red}The generation was completed with errors.\n' 'No schemas were generated.$_reset', ); } else if (successSchemasCount != schemasCount) { stdout.writeln( - '\n' '${_red}The generation was completed with errors.\n' '${schemasCount - successSchemasCount} schemas were not generated.$_reset', ); } else { stdout.writeln( - '\n' '${schemasCount > 1 ? _green : ''}The generation was completed successfully. ' 'You can run the generation using build_runner.${schemasCount > 1 ? _reset : ''}', ); From da7b42a811da89047b02a77c4c8ce397185f4bb4 Mon Sep 17 00:00:00 2001 From: StarProxima Date: Fri, 6 Oct 2023 21:17:43 +0300 Subject: [PATCH 02/10] Add `schema_from_url_to_file` and `prefer_schema_from` --- .../lib/src/config/yaml_config.dart | 68 ++++++++++++++----- .../lib/src/generator/generator.dart | 51 ++++++++++---- swagger_parser/lib/src/utils/file_utils.dart | 2 +- swagger_parser/lib/src/utils/utils.dart | 12 ++-- 4 files changed, 97 insertions(+), 36 deletions(-) diff --git a/swagger_parser/lib/src/config/yaml_config.dart b/swagger_parser/lib/src/config/yaml_config.dart index 942acf33..c54dec84 100644 --- a/swagger_parser/lib/src/config/yaml_config.dart +++ b/swagger_parser/lib/src/config/yaml_config.dart @@ -1,4 +1,5 @@ import 'package:args/args.dart'; +import 'package:collection/collection.dart'; import 'package:yaml/yaml.dart'; import '../generator/models/programming_language.dart'; @@ -17,10 +18,12 @@ import 'config_exception.dart'; final class YamlConfig { /// Applies parameters directly from constructor const YamlConfig({ - required this.schemaPath, - required this.outputDirectory, required this.name, + required this.outputDirectory, + this.schemaPath, this.schemaUrl, + this.schemaFromUrlToFile, + this.preferSchemaFrom, this.language, this.freezed, this.rootClient, @@ -49,9 +52,19 @@ final class YamlConfig { schemaPath = ''; } - if (schemaPath == null) { + final schemaUrl = yamlConfig['schema_url']?.toString(); + if (schemaUrl != null) { + final uri = Uri.tryParse(schemaUrl); + if (uri == null) { + throw const ConfigException( + "Config parameter 'schema_url' must be valid URL.", + ); + } + } + + if (schemaPath == null && schemaUrl == null) { throw const ConfigException( - "Config parameter 'schema_path' is required.", + "Config parameters 'schema_path' or 'schema_url' are required.", ); } @@ -82,19 +95,28 @@ final class YamlConfig { } final name = rawName == null || rawName.isEmpty - ? schemaPath.split('/').last.split('.').first + ? (schemaPath ?? schemaUrl)! + .split('/') + .lastOrNull + ?.split('.') + .firstOrNull ?? + 'unknown' : rawName; - final schemaUrl = yamlConfig['schema_url']; - if (schemaUrl is! String?) { + final schemaFromUrlToFile = yamlConfig['schema_from_url_to_file']; + if (schemaFromUrlToFile is! bool?) { throw const ConfigException( - "Config parameter 'schema_url' must be String.", + "Config parameter 'schema_from_url_to_file' must be bool.", ); - } else if (schemaUrl != null) { - final uri = Uri.tryParse(schemaUrl); - if (uri == null) { - throw const ConfigException( - "Config parameter 'schema_url' must be valid URL.", + } + + PreferSchemaFrom? preferSchemaFrom; + final rawPreferSchemeFrom = yamlConfig['prefer_schema_from']?.toString(); + if (rawPreferSchemeFrom != null) { + preferSchemaFrom = PreferSchemaFrom.fromString(rawPreferSchemeFrom); + if (preferSchemaFrom == null) { + throw ConfigException( + "'prefer_schema_from' field must be contained in ${PreferSchemaFrom.values.map((e) => e.name)}.", ); } } @@ -105,7 +127,7 @@ final class YamlConfig { language = ProgrammingLanguage.fromString(rawLanguage); if (language == null) { throw ConfigException( - "'language' field must be contained in ${ProgrammingLanguage.values}.", + "'language' field must be contained in ${ProgrammingLanguage.values.map((e) => e.name)}.", ); } } @@ -218,6 +240,9 @@ final class YamlConfig { schemaPath: schemaPath, outputDirectory: outputDirectory, schemaUrl: schemaUrl, + schemaFromUrlToFile: + schemaFromUrlToFile ?? rootConfig?.schemaFromUrlToFile, + preferSchemaFrom: preferSchemaFrom ?? rootConfig?.preferSchemaFrom, language: language ?? rootConfig?.language, freezed: freezed ?? rootConfig?.freezed, rootClient: rootClient ?? rootConfig?.rootClient, @@ -305,10 +330,12 @@ final class YamlConfig { return configs; } - final String schemaPath; - final String outputDirectory; final String name; + final String outputDirectory; + final String? schemaPath; final String? schemaUrl; + final bool? schemaFromUrlToFile; + final PreferSchemaFrom? preferSchemaFrom; final ProgrammingLanguage? language; final bool? freezed; final String? clientPostfix; @@ -323,3 +350,12 @@ final class YamlConfig { final bool? markFilesAsGenerated; final List replacementRules; } + +enum PreferSchemaFrom { + url, + file; + + static PreferSchemaFrom? fromString(String string) => values.firstWhereOrNull( + (e) => e.name == string, + ); +} diff --git a/swagger_parser/lib/src/generator/generator.dart b/swagger_parser/lib/src/generator/generator.dart index be589375..cdc5a786 100644 --- a/swagger_parser/lib/src/generator/generator.dart +++ b/swagger_parser/lib/src/generator/generator.dart @@ -23,8 +23,12 @@ final class Generator { /// and sets them to default if not found Generator({ required String outputDirectory, - required String schemaPath, + String? schemaPath, String? schemaUrl, + String? schemaContent, + bool? isYaml, + bool? schemaFromUrlToFile, + PreferSchemaFrom? preferSchemeFrom, ProgrammingLanguage? language, String? name, bool? freezed, @@ -41,6 +45,10 @@ final class Generator { List? replacementRules, }) : _schemaPath = schemaPath, _schemaUrl = schemaUrl, + _schemaContent = schemaContent, + _isYaml = isYaml ?? false, + _schemaFromUrlToFile = schemaFromUrlToFile ?? true, + _preferSchemeFrom = preferSchemeFrom ?? PreferSchemaFrom.url, _outputDirectory = outputDirectory, _name = name, _programmingLanguage = language ?? ProgrammingLanguage.dart, @@ -63,6 +71,8 @@ final class Generator { outputDirectory: yamlConfig.outputDirectory, schemaPath: yamlConfig.schemaPath, schemaUrl: yamlConfig.schemaUrl, + schemaFromUrlToFile: yamlConfig.schemaFromUrlToFile, + preferSchemeFrom: yamlConfig.preferSchemaFrom, language: yamlConfig.language, name: yamlConfig.name, freezed: yamlConfig.freezed, @@ -81,17 +91,23 @@ final class Generator { } /// The contents of your schema file - late final String _schemaContent; + String? _schemaContent; /// Is the schema format YAML - late final bool _isYaml; + bool _isYaml; /// The path to your schema file - final String _schemaPath; + final String? _schemaPath; /// The url to your schema file final String? _schemaUrl; + /// If true, schema will be extracted from url and saved to file + final bool _schemaFromUrlToFile; + + /// Prefer schema from url or file + final PreferSchemaFrom _preferSchemeFrom; + /// Output directory final String _outputDirectory; @@ -176,14 +192,17 @@ final class Generator { /// Generates content of files based on OpenApi definition file /// and return list of [GeneratedFile] Future> generateContent() async { + await _fetchSchemaContent(); _parseOpenApiDefinitionFile(); return _fillContent(); } Future _fetchSchemaContent() async { final url = _schemaUrl; + final path = _schemaPath; - if (url != null) { + if ((_preferSchemeFrom == PreferSchemaFrom.url || path == null) && + url != null) { final extension = p.extension(url).toLowerCase(); _isYaml = switch (extension) { '.yaml' => true, @@ -193,22 +212,28 @@ final class Generator { ), }; extractingSchemaFromUrlMessage(url); - _schemaContent = await schemaUrl(url); - writeSchemaToFile(_schemaContent, _schemaPath); - } else { - final configFile = schemaFile(_schemaPath); + _schemaContent = await schemaFromUrl(url); + if (_schemaFromUrlToFile && path != null) { + writeSchemaToFile(_schemaContent!, path); + } + } else if (path != null) { + final configFile = schemaFile(path); if (configFile == null) { - throw GeneratorException("Can't find schema file at $_schemaPath."); + throw GeneratorException("Can't find schema file at $path."); } - final extension = p.extension(_schemaPath).toLowerCase(); + final extension = p.extension(path).toLowerCase(); _isYaml = switch (extension) { '.yaml' => true, '.json' => false, _ => throw GeneratorException( - 'Unsupported $_schemaPath extension: $extension', + 'Unsupported $path extension: $extension', ), }; _schemaContent = configFile.readAsStringSync(); + } else if (_schemaContent == null) { + throw GeneratorException( + "Parameters 'schemaPath' or 'schemaUrl' or 'schemaContent' are required", + ); } } @@ -216,7 +241,7 @@ final class Generator { /// and list of [UniversalDataClass] void _parseOpenApiDefinitionFile() { final parser = OpenApiParser( - _schemaContent, + _schemaContent!, isYaml: _isYaml, pathMethodName: _pathMethodName, enumsPrefix: _enumsPrefix, diff --git a/swagger_parser/lib/src/utils/file_utils.dart b/swagger_parser/lib/src/utils/file_utils.dart index 279a4702..1b40b65c 100644 --- a/swagger_parser/lib/src/utils/file_utils.dart +++ b/swagger_parser/lib/src/utils/file_utils.dart @@ -35,7 +35,7 @@ void writeSchemaToFile(String schemaContent, String filePath) { File(p.join(_rootDirectoryPath, filePath)).writeAsStringSync(schemaContent); } -Future schemaUrl(String url) async { +Future schemaFromUrl(String url) async { final client = HttpClient(); final request = await client.getUrl(Uri.parse(url)); final response = await request.close(); diff --git a/swagger_parser/lib/src/utils/utils.dart b/swagger_parser/lib/src/utils/utils.dart index d4ff9e93..46935fe8 100644 --- a/swagger_parser/lib/src/utils/utils.dart +++ b/swagger_parser/lib/src/utils/utils.dart @@ -81,12 +81,12 @@ const _ignoreLintsComment = ''' void introMessage() { stdout.writeln( - ''' - ┏━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━┓ - ┃ ┃ - ┃ Welcome to swagger_parser ┃ - ┃ ┃ - ┗━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━┛ + r''' + +┃ ____ _ _ _ ____ ____ ____ ____ ____ ___ ____ ____ ____ ____ ____ +┃ [__ | | | |__| | __ | __ |___ |__/ |__] |__| |__/ [__ |___ |__/ +┃ ___] |_|_| | | |__] |__] |___ | \ ___ | | | | \ ___] |___ | \ +┃ ''', ); } From eeced9ca9eb07db76902e8384030314874a7ae1d Mon Sep 17 00:00:00 2001 From: StarProxima Date: Fri, 6 Oct 2023 22:47:07 +0300 Subject: [PATCH 03/10] Update README --- swagger_parser/CHANGELOG.md | 2 +- swagger_parser/README.md | 27 +++++++++---- swagger_parser/example/README.md | 2 +- swagger_parser/example/swagger_parser.yaml | 23 ++++++++--- .../lib/src/config/yaml_config.dart | 38 +++++++++++-------- .../lib/src/generator/generator.dart | 10 ++--- 6 files changed, 66 insertions(+), 36 deletions(-) diff --git a/swagger_parser/CHANGELOG.md b/swagger_parser/CHANGELOG.md index 368bab0f..abe69f65 100644 --- a/swagger_parser/CHANGELOG.md +++ b/swagger_parser/CHANGELOG.md @@ -5,7 +5,7 @@ - Fix error with missing File import ([#101](https://github.com/Carapacik/swagger_parser/issues/101)) ## 1.8.0 -- Multiple schemas support(see ([example](https://github.com/Carapacik/swagger_parser/blob/main/swagger_parser/example/swagger_parser.yaml))) +- Multiple schemas support (see [example](https://github.com/Carapacik/swagger_parser/blob/main/swagger_parser/example/swagger_parser.yaml)) - Support for specifying nullable types via anyOf - Edit root client template - Add new config parameter `root_client_name` diff --git a/swagger_parser/README.md b/swagger_parser/README.md index 4cf3bcbd..8e31fee4 100644 --- a/swagger_parser/README.md +++ b/swagger_parser/README.md @@ -7,12 +7,14 @@ [![Tests](https://github.com/Carapacik/swagger_parser/actions/workflows/tests.yml/badge.svg?branch=main)](https://github.com/Carapacik/swagger_parser/actions/workflows/tests.yml) -## Dart package that generates REST clients and data classes from OpenApi definition file +## Dart package that generates REST clients and data classes from OpenApi definition files or links ## Features - Supports OpenApi v2, v3.0 and v3.1 - Support JSON and YAML format +- Support for generation by link +- Support for multiple schemes - Generate REST client files based on Retrofit - Generate data classes (also on [freezed](https://pub.dev/packages/freezed)) - Support for multiple languages (Dart, Kotlin) @@ -46,8 +48,12 @@ An example of YAML is shown below. A default value is specified for each of the ```yaml swagger_parser: - # Required. Sets the OpenApi schema path directory for api definition. - schema_path: schemas/openapi.json + # You must provide the file path and/or url to the OpenApi schema. + + # Sets the OpenApi schema path directory for api definition. + # schema_path: schemas/openapi.json + # Sets the url of the OpenApi schema + # schema_url: https://petstore.swagger.io/v2/swagger.json # Required. Sets output directory for generated files (Clients and DTOs). output_directory: lib/api @@ -56,6 +62,10 @@ swagger_parser: # Current available languages are: dart, kotlin language: dart + # Optional. If 'schema_path' and 'schema_url' are specified, what will be used. + # Current available options are: path, url. + prefer_schema_from: url + # Optional (dart only). Set 'true' to generate data classes using freezed package. freezed: false @@ -79,6 +89,9 @@ swagger_parser: # Optional. Set to 'true' to squash all clients in one client. squash_clients: false + # Optional. Set to 'false' to not write the schema from the url to the schema file. + schema_from_url_to_file: true + # Optional. Set postfix for Client class and file. client_postfix: Client @@ -123,14 +136,14 @@ swagger_parser: put_in_folder: true replacement_rules: [] - - schema_path: schemas/openapi.json + - schema_url: https://petstore.swagger.io/v2/swagger.json name: pet_service - client_postfix: DataSource + client_postfix: Service put_clients_in_folder: true - enums_to_json: true put_in_folder: true - - schema_path: schemas/openapi.json + - schema_path: schemas/pet_store.json + schema_url: https://petstore.swagger.io/v2/swagger.json output_directory: lib/api/kotlin language: kotlin ``` diff --git a/swagger_parser/example/README.md b/swagger_parser/example/README.md index 9b20362f..f397d5be 100644 --- a/swagger_parser/example/README.md +++ b/swagger_parser/example/README.md @@ -2,7 +2,7 @@ - ### Set the output directory in pubspec.yaml - ### Run command below to generate rest clients and data classes: ```shell -dart run swagger_parser:generate +dart run swagger_parser ``` - ### For `freezed` with `retrofit` use build.yaml file with this content: ```yaml diff --git a/swagger_parser/example/swagger_parser.yaml b/swagger_parser/example/swagger_parser.yaml index 759d476d..b168eb63 100644 --- a/swagger_parser/example/swagger_parser.yaml +++ b/swagger_parser/example/swagger_parser.yaml @@ -1,14 +1,22 @@ swagger_parser: - # Required. Sets the OpenApi schema path directory for api definition. + # You must provide the file path and/or url to the OpenApi schema. + + # Sets the OpenApi schema path directory for api definition. # schema_path: schemas/openapi.json + # Sets the url of the OpenApi schema + # schema_url: https://petstore.swagger.io/v2/swagger.json # Required. Sets output directory for generated files (Clients and DTOs). output_directory: lib/api # Optional. Sets the programming language. - # Current available languages are: dart, kotlin + # Current available languages are: dart, kotlin. language: dart + # Optional. If 'schema_path' and 'schema_url' are specified, what will be used. + # Current available options are: path, url. + prefer_schema_from: url + # Optional (dart only). Set 'true' to generate data classes using freezed package. freezed: false @@ -32,6 +40,9 @@ swagger_parser: # Optional. Set to 'true' to squash all clients in one client. squash_clients: false + # Optional. Set to 'false' to not write the schema from the url to the schema file. + schema_from_url_to_file: true + # Optional. Set postfix for Client class and file. client_postfix: Client @@ -67,13 +78,13 @@ swagger_parser: put_in_folder: true replacement_rules: [] - - schema_path: schemas/openapi.json + - schema_url: https://petstore.swagger.io/v2/swagger.json name: pet_service - client_postfix: DataSource + client_postfix: Service put_clients_in_folder: true - enums_to_json: true put_in_folder: true - - schema_path: schemas/openapi.json + - schema_path: schemas/pet_store.json + schema_url: https://petstore.swagger.io/v2/swagger.json output_directory: lib/api/kotlin language: kotlin diff --git a/swagger_parser/lib/src/config/yaml_config.dart b/swagger_parser/lib/src/config/yaml_config.dart index c54dec84..d56996e1 100644 --- a/swagger_parser/lib/src/config/yaml_config.dart +++ b/swagger_parser/lib/src/config/yaml_config.dart @@ -23,7 +23,7 @@ final class YamlConfig { this.schemaPath, this.schemaUrl, this.schemaFromUrlToFile, - this.preferSchemaFrom, + this.preferSchemaSource, this.language, this.freezed, this.rootClient, @@ -110,13 +110,14 @@ final class YamlConfig { ); } - PreferSchemaFrom? preferSchemaFrom; - final rawPreferSchemeFrom = yamlConfig['prefer_schema_from']?.toString(); - if (rawPreferSchemeFrom != null) { - preferSchemaFrom = PreferSchemaFrom.fromString(rawPreferSchemeFrom); - if (preferSchemaFrom == null) { + PreferSchemaSource? preferSchemaSource; + final rawPreferSchemeSource = + yamlConfig['prefer_schema_source']?.toString(); + if (rawPreferSchemeSource != null) { + preferSchemaSource = PreferSchemaSource.fromString(rawPreferSchemeSource); + if (preferSchemaSource == null) { throw ConfigException( - "'prefer_schema_from' field must be contained in ${PreferSchemaFrom.values.map((e) => e.name)}.", + "'prefer_schema_source' field must be contained in ${PreferSchemaSource.values.map((e) => e.name)}.", ); } } @@ -242,7 +243,7 @@ final class YamlConfig { schemaUrl: schemaUrl, schemaFromUrlToFile: schemaFromUrlToFile ?? rootConfig?.schemaFromUrlToFile, - preferSchemaFrom: preferSchemaFrom ?? rootConfig?.preferSchemaFrom, + preferSchemaSource: preferSchemaSource ?? rootConfig?.preferSchemaSource, language: language ?? rootConfig?.language, freezed: freezed ?? rootConfig?.freezed, rootClient: rootClient ?? rootConfig?.rootClient, @@ -290,17 +291,19 @@ final class YamlConfig { final configs = []; final schemaPath = yamlMap['schema_path'] as String?; + final schemaUrl = yamlMap['schema_url'] as String?; final schemas = yamlMap['schemas'] as YamlList?; - if (schemas == null && schemaPath == null) { + if (schemas == null && schemaUrl == null && schemaPath == null) { throw const ConfigException( - "Config parameter 'schema_path' or 'schemas' is required.", + "Config parameter 'schema_path', 'schema_url' or 'schemas' is required.", ); } - if (schemas != null && schemaPath != null) { + if (schemas != null && schemaPath != null || + schemas != null && schemaUrl != null) { throw const ConfigException( - "Config parameter 'schema_path' and 'schemas' can't be used together.", + "Config parameter 'schema_path' or 'schema_url' can't be used with 'schemas'.", ); } @@ -335,7 +338,7 @@ final class YamlConfig { final String? schemaPath; final String? schemaUrl; final bool? schemaFromUrlToFile; - final PreferSchemaFrom? preferSchemaFrom; + final PreferSchemaSource? preferSchemaSource; final ProgrammingLanguage? language; final bool? freezed; final String? clientPostfix; @@ -351,11 +354,14 @@ final class YamlConfig { final List replacementRules; } -enum PreferSchemaFrom { +/// Enum for choosing schema source +enum PreferSchemaSource { url, - file; + path; - static PreferSchemaFrom? fromString(String string) => values.firstWhereOrNull( + /// Returns [PreferSchemaSource] from string + static PreferSchemaSource? fromString(String string) => + values.firstWhereOrNull( (e) => e.name == string, ); } diff --git a/swagger_parser/lib/src/generator/generator.dart b/swagger_parser/lib/src/generator/generator.dart index cdc5a786..4c4ab01a 100644 --- a/swagger_parser/lib/src/generator/generator.dart +++ b/swagger_parser/lib/src/generator/generator.dart @@ -28,7 +28,7 @@ final class Generator { String? schemaContent, bool? isYaml, bool? schemaFromUrlToFile, - PreferSchemaFrom? preferSchemeFrom, + PreferSchemaSource? preferSchemeSource, ProgrammingLanguage? language, String? name, bool? freezed, @@ -48,7 +48,7 @@ final class Generator { _schemaContent = schemaContent, _isYaml = isYaml ?? false, _schemaFromUrlToFile = schemaFromUrlToFile ?? true, - _preferSchemeFrom = preferSchemeFrom ?? PreferSchemaFrom.url, + _preferSchemeSource = preferSchemeSource ?? PreferSchemaSource.url, _outputDirectory = outputDirectory, _name = name, _programmingLanguage = language ?? ProgrammingLanguage.dart, @@ -72,7 +72,7 @@ final class Generator { schemaPath: yamlConfig.schemaPath, schemaUrl: yamlConfig.schemaUrl, schemaFromUrlToFile: yamlConfig.schemaFromUrlToFile, - preferSchemeFrom: yamlConfig.preferSchemaFrom, + preferSchemeSource: yamlConfig.preferSchemaSource, language: yamlConfig.language, name: yamlConfig.name, freezed: yamlConfig.freezed, @@ -106,7 +106,7 @@ final class Generator { final bool _schemaFromUrlToFile; /// Prefer schema from url or file - final PreferSchemaFrom _preferSchemeFrom; + final PreferSchemaSource _preferSchemeSource; /// Output directory final String _outputDirectory; @@ -201,7 +201,7 @@ final class Generator { final url = _schemaUrl; final path = _schemaPath; - if ((_preferSchemeFrom == PreferSchemaFrom.url || path == null) && + if ((_preferSchemeSource == PreferSchemaSource.url || path == null) && url != null) { final extension = p.extension(url).toLowerCase(); _isYaml = switch (extension) { From 52cc81a0b8b36ade73671300a53ffdb51fd1a399 Mon Sep 17 00:00:00 2001 From: StarProxima Date: Fri, 6 Oct 2023 22:47:07 +0300 Subject: [PATCH 04/10] Update README --- swagger_parser/CHANGELOG.md | 2 +- swagger_parser/README.md | 27 +++++++++---- swagger_parser/example/README.md | 2 +- swagger_parser/example/swagger_parser.yaml | 23 ++++++++--- .../lib/src/config/yaml_config.dart | 38 +++++++++++-------- .../lib/src/generator/generator.dart | 10 ++--- 6 files changed, 66 insertions(+), 36 deletions(-) diff --git a/swagger_parser/CHANGELOG.md b/swagger_parser/CHANGELOG.md index 368bab0f..abe69f65 100644 --- a/swagger_parser/CHANGELOG.md +++ b/swagger_parser/CHANGELOG.md @@ -5,7 +5,7 @@ - Fix error with missing File import ([#101](https://github.com/Carapacik/swagger_parser/issues/101)) ## 1.8.0 -- Multiple schemas support(see ([example](https://github.com/Carapacik/swagger_parser/blob/main/swagger_parser/example/swagger_parser.yaml))) +- Multiple schemas support (see [example](https://github.com/Carapacik/swagger_parser/blob/main/swagger_parser/example/swagger_parser.yaml)) - Support for specifying nullable types via anyOf - Edit root client template - Add new config parameter `root_client_name` diff --git a/swagger_parser/README.md b/swagger_parser/README.md index 4cf3bcbd..e5e7f56e 100644 --- a/swagger_parser/README.md +++ b/swagger_parser/README.md @@ -7,7 +7,7 @@ [![Tests](https://github.com/Carapacik/swagger_parser/actions/workflows/tests.yml/badge.svg?branch=main)](https://github.com/Carapacik/swagger_parser/actions/workflows/tests.yml) -## Dart package that generates REST clients and data classes from OpenApi definition file +## Dart package that generates REST clients and data classes from OpenApi definition files or links ## Features @@ -15,6 +15,8 @@ - Support JSON and YAML format - Generate REST client files based on Retrofit - Generate data classes (also on [freezed](https://pub.dev/packages/freezed)) +- Support for generation by link +- Support for multiple schemes - Support for multiple languages (Dart, Kotlin) - Web interface at https://carapacik.github.io/swagger_parser @@ -46,8 +48,12 @@ An example of YAML is shown below. A default value is specified for each of the ```yaml swagger_parser: - # Required. Sets the OpenApi schema path directory for api definition. - schema_path: schemas/openapi.json + # You must provide the file path and/or url to the OpenApi schema. + + # Sets the OpenApi schema path directory for api definition. + # schema_path: schemas/openapi.json + # Sets the url of the OpenApi schema + # schema_url: https://petstore.swagger.io/v2/swagger.json # Required. Sets output directory for generated files (Clients and DTOs). output_directory: lib/api @@ -56,6 +62,10 @@ swagger_parser: # Current available languages are: dart, kotlin language: dart + # Optional. If 'schema_path' and 'schema_url' are specified, what will be used. + # Current available options are: path, url. + prefer_schema_from: url + # Optional (dart only). Set 'true' to generate data classes using freezed package. freezed: false @@ -79,6 +89,9 @@ swagger_parser: # Optional. Set to 'true' to squash all clients in one client. squash_clients: false + # Optional. Set to 'false' to not write the schema from the url to the schema file. + schema_from_url_to_file: true + # Optional. Set postfix for Client class and file. client_postfix: Client @@ -123,14 +136,14 @@ swagger_parser: put_in_folder: true replacement_rules: [] - - schema_path: schemas/openapi.json + - schema_url: https://petstore.swagger.io/v2/swagger.json name: pet_service - client_postfix: DataSource + client_postfix: Service put_clients_in_folder: true - enums_to_json: true put_in_folder: true - - schema_path: schemas/openapi.json + - schema_path: schemas/pet_store.json + schema_url: https://petstore.swagger.io/v2/swagger.json output_directory: lib/api/kotlin language: kotlin ``` diff --git a/swagger_parser/example/README.md b/swagger_parser/example/README.md index 9b20362f..f397d5be 100644 --- a/swagger_parser/example/README.md +++ b/swagger_parser/example/README.md @@ -2,7 +2,7 @@ - ### Set the output directory in pubspec.yaml - ### Run command below to generate rest clients and data classes: ```shell -dart run swagger_parser:generate +dart run swagger_parser ``` - ### For `freezed` with `retrofit` use build.yaml file with this content: ```yaml diff --git a/swagger_parser/example/swagger_parser.yaml b/swagger_parser/example/swagger_parser.yaml index 759d476d..b168eb63 100644 --- a/swagger_parser/example/swagger_parser.yaml +++ b/swagger_parser/example/swagger_parser.yaml @@ -1,14 +1,22 @@ swagger_parser: - # Required. Sets the OpenApi schema path directory for api definition. + # You must provide the file path and/or url to the OpenApi schema. + + # Sets the OpenApi schema path directory for api definition. # schema_path: schemas/openapi.json + # Sets the url of the OpenApi schema + # schema_url: https://petstore.swagger.io/v2/swagger.json # Required. Sets output directory for generated files (Clients and DTOs). output_directory: lib/api # Optional. Sets the programming language. - # Current available languages are: dart, kotlin + # Current available languages are: dart, kotlin. language: dart + # Optional. If 'schema_path' and 'schema_url' are specified, what will be used. + # Current available options are: path, url. + prefer_schema_from: url + # Optional (dart only). Set 'true' to generate data classes using freezed package. freezed: false @@ -32,6 +40,9 @@ swagger_parser: # Optional. Set to 'true' to squash all clients in one client. squash_clients: false + # Optional. Set to 'false' to not write the schema from the url to the schema file. + schema_from_url_to_file: true + # Optional. Set postfix for Client class and file. client_postfix: Client @@ -67,13 +78,13 @@ swagger_parser: put_in_folder: true replacement_rules: [] - - schema_path: schemas/openapi.json + - schema_url: https://petstore.swagger.io/v2/swagger.json name: pet_service - client_postfix: DataSource + client_postfix: Service put_clients_in_folder: true - enums_to_json: true put_in_folder: true - - schema_path: schemas/openapi.json + - schema_path: schemas/pet_store.json + schema_url: https://petstore.swagger.io/v2/swagger.json output_directory: lib/api/kotlin language: kotlin diff --git a/swagger_parser/lib/src/config/yaml_config.dart b/swagger_parser/lib/src/config/yaml_config.dart index c54dec84..d56996e1 100644 --- a/swagger_parser/lib/src/config/yaml_config.dart +++ b/swagger_parser/lib/src/config/yaml_config.dart @@ -23,7 +23,7 @@ final class YamlConfig { this.schemaPath, this.schemaUrl, this.schemaFromUrlToFile, - this.preferSchemaFrom, + this.preferSchemaSource, this.language, this.freezed, this.rootClient, @@ -110,13 +110,14 @@ final class YamlConfig { ); } - PreferSchemaFrom? preferSchemaFrom; - final rawPreferSchemeFrom = yamlConfig['prefer_schema_from']?.toString(); - if (rawPreferSchemeFrom != null) { - preferSchemaFrom = PreferSchemaFrom.fromString(rawPreferSchemeFrom); - if (preferSchemaFrom == null) { + PreferSchemaSource? preferSchemaSource; + final rawPreferSchemeSource = + yamlConfig['prefer_schema_source']?.toString(); + if (rawPreferSchemeSource != null) { + preferSchemaSource = PreferSchemaSource.fromString(rawPreferSchemeSource); + if (preferSchemaSource == null) { throw ConfigException( - "'prefer_schema_from' field must be contained in ${PreferSchemaFrom.values.map((e) => e.name)}.", + "'prefer_schema_source' field must be contained in ${PreferSchemaSource.values.map((e) => e.name)}.", ); } } @@ -242,7 +243,7 @@ final class YamlConfig { schemaUrl: schemaUrl, schemaFromUrlToFile: schemaFromUrlToFile ?? rootConfig?.schemaFromUrlToFile, - preferSchemaFrom: preferSchemaFrom ?? rootConfig?.preferSchemaFrom, + preferSchemaSource: preferSchemaSource ?? rootConfig?.preferSchemaSource, language: language ?? rootConfig?.language, freezed: freezed ?? rootConfig?.freezed, rootClient: rootClient ?? rootConfig?.rootClient, @@ -290,17 +291,19 @@ final class YamlConfig { final configs = []; final schemaPath = yamlMap['schema_path'] as String?; + final schemaUrl = yamlMap['schema_url'] as String?; final schemas = yamlMap['schemas'] as YamlList?; - if (schemas == null && schemaPath == null) { + if (schemas == null && schemaUrl == null && schemaPath == null) { throw const ConfigException( - "Config parameter 'schema_path' or 'schemas' is required.", + "Config parameter 'schema_path', 'schema_url' or 'schemas' is required.", ); } - if (schemas != null && schemaPath != null) { + if (schemas != null && schemaPath != null || + schemas != null && schemaUrl != null) { throw const ConfigException( - "Config parameter 'schema_path' and 'schemas' can't be used together.", + "Config parameter 'schema_path' or 'schema_url' can't be used with 'schemas'.", ); } @@ -335,7 +338,7 @@ final class YamlConfig { final String? schemaPath; final String? schemaUrl; final bool? schemaFromUrlToFile; - final PreferSchemaFrom? preferSchemaFrom; + final PreferSchemaSource? preferSchemaSource; final ProgrammingLanguage? language; final bool? freezed; final String? clientPostfix; @@ -351,11 +354,14 @@ final class YamlConfig { final List replacementRules; } -enum PreferSchemaFrom { +/// Enum for choosing schema source +enum PreferSchemaSource { url, - file; + path; - static PreferSchemaFrom? fromString(String string) => values.firstWhereOrNull( + /// Returns [PreferSchemaSource] from string + static PreferSchemaSource? fromString(String string) => + values.firstWhereOrNull( (e) => e.name == string, ); } diff --git a/swagger_parser/lib/src/generator/generator.dart b/swagger_parser/lib/src/generator/generator.dart index cdc5a786..4c4ab01a 100644 --- a/swagger_parser/lib/src/generator/generator.dart +++ b/swagger_parser/lib/src/generator/generator.dart @@ -28,7 +28,7 @@ final class Generator { String? schemaContent, bool? isYaml, bool? schemaFromUrlToFile, - PreferSchemaFrom? preferSchemeFrom, + PreferSchemaSource? preferSchemeSource, ProgrammingLanguage? language, String? name, bool? freezed, @@ -48,7 +48,7 @@ final class Generator { _schemaContent = schemaContent, _isYaml = isYaml ?? false, _schemaFromUrlToFile = schemaFromUrlToFile ?? true, - _preferSchemeFrom = preferSchemeFrom ?? PreferSchemaFrom.url, + _preferSchemeSource = preferSchemeSource ?? PreferSchemaSource.url, _outputDirectory = outputDirectory, _name = name, _programmingLanguage = language ?? ProgrammingLanguage.dart, @@ -72,7 +72,7 @@ final class Generator { schemaPath: yamlConfig.schemaPath, schemaUrl: yamlConfig.schemaUrl, schemaFromUrlToFile: yamlConfig.schemaFromUrlToFile, - preferSchemeFrom: yamlConfig.preferSchemaFrom, + preferSchemeSource: yamlConfig.preferSchemaSource, language: yamlConfig.language, name: yamlConfig.name, freezed: yamlConfig.freezed, @@ -106,7 +106,7 @@ final class Generator { final bool _schemaFromUrlToFile; /// Prefer schema from url or file - final PreferSchemaFrom _preferSchemeFrom; + final PreferSchemaSource _preferSchemeSource; /// Output directory final String _outputDirectory; @@ -201,7 +201,7 @@ final class Generator { final url = _schemaUrl; final path = _schemaPath; - if ((_preferSchemeFrom == PreferSchemaFrom.url || path == null) && + if ((_preferSchemeSource == PreferSchemaSource.url || path == null) && url != null) { final extension = p.extension(url).toLowerCase(); _isYaml = switch (extension) { From d35a1bf5e02ec1ee87005201312722d04d69a266 Mon Sep 17 00:00:00 2001 From: StarProxima Date: Sat, 7 Oct 2023 00:36:07 +0300 Subject: [PATCH 05/10] Fix README --- swagger_parser/README.md | 8 ++++---- 1 file changed, 4 insertions(+), 4 deletions(-) diff --git a/swagger_parser/README.md b/swagger_parser/README.md index e5e7f56e..19c370b9 100644 --- a/swagger_parser/README.md +++ b/swagger_parser/README.md @@ -13,10 +13,10 @@ - Supports OpenApi v2, v3.0 and v3.1 - Support JSON and YAML format -- Generate REST client files based on Retrofit -- Generate data classes (also on [freezed](https://pub.dev/packages/freezed)) - Support for generation by link - Support for multiple schemes +- Generate REST client files based on Retrofit +- Generate data classes (also on [freezed](https://pub.dev/packages/freezed)) - Support for multiple languages (Dart, Kotlin) - Web interface at https://carapacik.github.io/swagger_parser @@ -51,9 +51,9 @@ swagger_parser: # You must provide the file path and/or url to the OpenApi schema. # Sets the OpenApi schema path directory for api definition. - # schema_path: schemas/openapi.json + schema_path: schemas/openapi.json # Sets the url of the OpenApi schema - # schema_url: https://petstore.swagger.io/v2/swagger.json + schema_url: https://petstore.swagger.io/v2/swagger.json # Required. Sets output directory for generated files (Clients and DTOs). output_directory: lib/api From 0c77b5add8f59aaaae50146e6c22fea2cc51607b Mon Sep 17 00:00:00 2001 From: StarProxima Date: Sat, 7 Oct 2023 02:24:07 +0300 Subject: [PATCH 06/10] Format json in file --- swagger_parser/lib/src/generator/generator.dart | 10 +++++++++- 1 file changed, 9 insertions(+), 1 deletion(-) diff --git a/swagger_parser/lib/src/generator/generator.dart b/swagger_parser/lib/src/generator/generator.dart index 4c4ab01a..cf10c4fa 100644 --- a/swagger_parser/lib/src/generator/generator.dart +++ b/swagger_parser/lib/src/generator/generator.dart @@ -1,3 +1,5 @@ +import 'dart:convert'; + import 'package:path/path.dart' as p; import '../config/yaml_config.dart'; @@ -214,7 +216,13 @@ final class Generator { extractingSchemaFromUrlMessage(url); _schemaContent = await schemaFromUrl(url); if (_schemaFromUrlToFile && path != null) { - writeSchemaToFile(_schemaContent!, path); + if (!_isYaml) { + final formattedJson = const JsonEncoder.withIndent(' ') + .convert(jsonDecode(_schemaContent!)); + writeSchemaToFile(formattedJson, path); + } else { + writeSchemaToFile(_schemaContent!, path); + } } } else if (path != null) { final configFile = schemaFile(path); From 2fdd87a74f3958f559568ba8a19b767b648a5b07 Mon Sep 17 00:00:00 2001 From: StarProxima Date: Sat, 7 Oct 2023 02:50:14 +0300 Subject: [PATCH 07/10] Edit JsonEncoder indent --- swagger_parser/lib/src/generator/generator.dart | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/swagger_parser/lib/src/generator/generator.dart b/swagger_parser/lib/src/generator/generator.dart index cf10c4fa..d4b790e0 100644 --- a/swagger_parser/lib/src/generator/generator.dart +++ b/swagger_parser/lib/src/generator/generator.dart @@ -217,7 +217,7 @@ final class Generator { _schemaContent = await schemaFromUrl(url); if (_schemaFromUrlToFile && path != null) { if (!_isYaml) { - final formattedJson = const JsonEncoder.withIndent(' ') + final formattedJson = const JsonEncoder.withIndent(' ') .convert(jsonDecode(_schemaContent!)); writeSchemaToFile(formattedJson, path); } else { From b1522f2812821618afe197ae7d8ce6424d65850e Mon Sep 17 00:00:00 2001 From: StarProxima Date: Sat, 7 Oct 2023 03:10:38 +0300 Subject: [PATCH 08/10] `prefer_schema_from` -> `prefer_schema_source` --- swagger_parser/README.md | 2 +- swagger_parser/example/swagger_parser.yaml | 2 +- 2 files changed, 2 insertions(+), 2 deletions(-) diff --git a/swagger_parser/README.md b/swagger_parser/README.md index 19c370b9..2e0a4d16 100644 --- a/swagger_parser/README.md +++ b/swagger_parser/README.md @@ -64,7 +64,7 @@ swagger_parser: # Optional. If 'schema_path' and 'schema_url' are specified, what will be used. # Current available options are: path, url. - prefer_schema_from: url + prefer_schema_source: url # Optional (dart only). Set 'true' to generate data classes using freezed package. freezed: false diff --git a/swagger_parser/example/swagger_parser.yaml b/swagger_parser/example/swagger_parser.yaml index b168eb63..dba9b598 100644 --- a/swagger_parser/example/swagger_parser.yaml +++ b/swagger_parser/example/swagger_parser.yaml @@ -15,7 +15,7 @@ swagger_parser: # Optional. If 'schema_path' and 'schema_url' are specified, what will be used. # Current available options are: path, url. - prefer_schema_from: url + prefer_schema_source: url # Optional (dart only). Set 'true' to generate data classes using freezed package. freezed: false From b7e0164bdb45cc7192cb286e2ae9daa2fbd76729 Mon Sep 17 00:00:00 2001 From: StarProxima Date: Fri, 13 Oct 2023 19:00:57 +0300 Subject: [PATCH 09/10] Update CHANGELOG.md --- swagger_parser/CHANGELOG.md | 8 +++++++- 1 file changed, 7 insertions(+), 1 deletion(-) diff --git a/swagger_parser/CHANGELOG.md b/swagger_parser/CHANGELOG.md index 2f87bf3e..0954ecd2 100644 --- a/swagger_parser/CHANGELOG.md +++ b/swagger_parser/CHANGELOG.md @@ -1,9 +1,15 @@ +## 1.10.0 +- Support for generating schemas by url (see [example](https://github.com/Carapacik/swagger_parser/blob/main/swagger_parser/example/swagger_parser.yaml)) +- Add new config parameter `schema_url` +- Add new config parameter `schema_from_url_to_file` +- Add new config parameter `prefer_schema_source` + ## 1.9.2 - Fix error with `required` in clients ([#101](https://github.com/Carapacik/swagger_parser/issues/103)) ## 1.9.1 - Handling incorrect names for classes, enums and methods. -- Additional name for unnamed models [#98](https://github.com/Carapacik/swagger_parser/issues/98) +- Additional name for unnamed models ([#98](https://github.com/Carapacik/swagger_parser/issues/98)) - Support for `deprecated` annotations for methods ## 1.9.0 From 4dc186e8ce7f93b85edf964d017fc2a75e9f8acf Mon Sep 17 00:00:00 2001 From: StarProxima Date: Sat, 14 Oct 2023 17:40:07 +0300 Subject: [PATCH 10/10] Transfer PreferSchemaSource and docs --- swagger_parser/lib/src/config/yaml_config.dart | 13 +------------ swagger_parser/lib/src/generator/generator.dart | 1 + .../generator/models/prefer_schema_source.dart | 16 ++++++++++++++++ 3 files changed, 18 insertions(+), 12 deletions(-) create mode 100644 swagger_parser/lib/src/generator/models/prefer_schema_source.dart diff --git a/swagger_parser/lib/src/config/yaml_config.dart b/swagger_parser/lib/src/config/yaml_config.dart index d56996e1..94274c44 100644 --- a/swagger_parser/lib/src/config/yaml_config.dart +++ b/swagger_parser/lib/src/config/yaml_config.dart @@ -2,6 +2,7 @@ import 'package:args/args.dart'; import 'package:collection/collection.dart'; import 'package:yaml/yaml.dart'; +import '../generator/models/prefer_schema_source.dart'; import '../generator/models/programming_language.dart'; import '../generator/models/replacement_rule.dart'; import '../utils/file_utils.dart'; @@ -353,15 +354,3 @@ final class YamlConfig { final bool? markFilesAsGenerated; final List replacementRules; } - -/// Enum for choosing schema source -enum PreferSchemaSource { - url, - path; - - /// Returns [PreferSchemaSource] from string - static PreferSchemaSource? fromString(String string) => - values.firstWhereOrNull( - (e) => e.name == string, - ); -} diff --git a/swagger_parser/lib/src/generator/generator.dart b/swagger_parser/lib/src/generator/generator.dart index d4b790e0..ab13ef9d 100644 --- a/swagger_parser/lib/src/generator/generator.dart +++ b/swagger_parser/lib/src/generator/generator.dart @@ -12,6 +12,7 @@ import 'generator_exception.dart'; import 'models/generated_file.dart'; import 'models/generation_statistics.dart'; import 'models/open_api_info.dart'; +import 'models/prefer_schema_source.dart'; import 'models/programming_language.dart'; import 'models/replacement_rule.dart'; import 'models/universal_data_class.dart'; diff --git a/swagger_parser/lib/src/generator/models/prefer_schema_source.dart b/swagger_parser/lib/src/generator/models/prefer_schema_source.dart new file mode 100644 index 00000000..9a0b7801 --- /dev/null +++ b/swagger_parser/lib/src/generator/models/prefer_schema_source.dart @@ -0,0 +1,16 @@ +import 'package:collection/collection.dart'; + +/// Enum for choosing schema source +enum PreferSchemaSource { + /// Prefer remote schema from url + url, + + /// Prefer local schema from file + path; + + /// Returns [PreferSchemaSource] from string + static PreferSchemaSource? fromString(String string) => + values.firstWhereOrNull( + (e) => e.name == string, + ); +}