From 40874d204b990f35f014674440df620194570459 Mon Sep 17 00:00:00 2001 From: Fabricio Ferreira Date: Wed, 24 Apr 2024 16:24:44 +1200 Subject: [PATCH 1/2] Added support to specify a single source file --- src/DocFxOpenApi/DocFxOpenApi.cs | 17 +++++-- src/DocFxOpenApi/Domain/CommandlineOptions.cs | 46 ++++++++++++++++--- 2 files changed, 51 insertions(+), 12 deletions(-) diff --git a/src/DocFxOpenApi/DocFxOpenApi.cs b/src/DocFxOpenApi/DocFxOpenApi.cs index 3b6ab6d..465a085 100644 --- a/src/DocFxOpenApi/DocFxOpenApi.cs +++ b/src/DocFxOpenApi/DocFxOpenApi.cs @@ -75,13 +75,13 @@ private void RunLogic() _options.OutputFolder = _options.SpecFolder; } - _message.Verbose($"Specification folder: {_options.SpecFolder}"); + _message.Verbose($"Specification file/folder: {_options.SpecFolder ?? _options.SpecFile}"); _message.Verbose($"Output folder : {_options.OutputFolder}"); _message.Verbose($"Verbose : {_options.Verbose}"); - if (!Directory.Exists(_options.SpecFolder)) + if ((_options.SpecFolder ?? _options.SpecFile) == null) { - _message.Error($"ERROR: Specification folder '{_options.SpecFolder}' doesn't exist."); + _message.Error($"ERROR: Specification folder/file '{_options.SpecSource}' doesn't exist."); _returnvalue = 1; return; } @@ -93,9 +93,16 @@ private void RunLogic() private void ConvertOpenApiFiles() { - foreach (var extension in _openApiFileExtensions) + if (_options.SpecFolder != null) { - this.ConvertOpenApiFiles(extension); + foreach (var extension in _openApiFileExtensions) + { + this.ConvertOpenApiFiles(extension); + } + } + else + { + this.ConvertOpenApiFile(_options.SpecFile!); } } diff --git a/src/DocFxOpenApi/Domain/CommandlineOptions.cs b/src/DocFxOpenApi/Domain/CommandlineOptions.cs index 068322d..9131ae8 100644 --- a/src/DocFxOpenApi/Domain/CommandlineOptions.cs +++ b/src/DocFxOpenApi/Domain/CommandlineOptions.cs @@ -3,29 +3,61 @@ namespace DocFxOpenApi.Domain { + using System.IO; using CommandLine; /// - /// Class for command line options. + /// Class for command line options. /// public class CommandlineOptions { /// - /// Gets or sets the folder with specifications. + /// Gets or sets the folder with specifications. /// - [Option('s', "specfolder", Required = true, HelpText = "Folder containing the OpenAPI specification.")] - public string? SpecFolder { get; set; } + [Option('s', "specsource", Required = true, HelpText = "Folder or File containing the OpenAPI specification.")] + public string? SpecSource + { + get => SpecFolder ?? SpecFile; + set => SetSource(value); + } /// - /// Gets or sets the output folder. + /// Gets or sets the output folder. /// [Option('o', "outputfolder", Required = false, HelpText = "Folder to write the resulting specifications in.")] public string? OutputFolder { get; set; } /// - /// Gets or sets a value indicating whether verbose information is shown in the output. + /// Gets or sets a value indicating whether verbose information is shown in the output. /// [Option('v', "verbose", Required = false, HelpText = "Show verbose messages.")] public bool Verbose { get; set; } + + /// + /// Gets the folder with specifications, if the source is a folder. + /// + public string? SpecFolder { get; private set; } + + /// + /// Gets the file with specifications, if the source is a file. + /// + public string? SpecFile { get; private set; } + + private void SetSource(string? value) + { + if (value == null) + { + return; + } + + if (Directory.Exists(value)) + { + SpecFolder = value; + } + else if (File.Exists(value)) + { + SpecFile = value; + } + } } -} +} \ No newline at end of file From 4671c6fcbd92b1bc87cd9b56f9d713bb8baa7e06 Mon Sep 17 00:00:00 2001 From: Fabricio Ferreira Date: Fri, 26 Apr 2024 08:38:56 +1200 Subject: [PATCH 2/2] Fixed comment's formatting and updated Readme.md --- src/DocFxOpenApi/Domain/CommandlineOptions.cs | 12 ++++++------ src/DocFxOpenApi/README.md | 11 ++++++----- 2 files changed, 12 insertions(+), 11 deletions(-) diff --git a/src/DocFxOpenApi/Domain/CommandlineOptions.cs b/src/DocFxOpenApi/Domain/CommandlineOptions.cs index 9131ae8..7d0c290 100644 --- a/src/DocFxOpenApi/Domain/CommandlineOptions.cs +++ b/src/DocFxOpenApi/Domain/CommandlineOptions.cs @@ -7,12 +7,12 @@ namespace DocFxOpenApi.Domain using CommandLine; /// - /// Class for command line options. + /// Class for command line options. /// public class CommandlineOptions { /// - /// Gets or sets the folder with specifications. + /// Gets or sets the folder with specifications. /// [Option('s', "specsource", Required = true, HelpText = "Folder or File containing the OpenAPI specification.")] public string? SpecSource @@ -22,24 +22,24 @@ public string? SpecSource } /// - /// Gets or sets the output folder. + /// Gets or sets the output folder. /// [Option('o', "outputfolder", Required = false, HelpText = "Folder to write the resulting specifications in.")] public string? OutputFolder { get; set; } /// - /// Gets or sets a value indicating whether verbose information is shown in the output. + /// Gets or sets a value indicating whether verbose information is shown in the output. /// [Option('v', "verbose", Required = false, HelpText = "Show verbose messages.")] public bool Verbose { get; set; } /// - /// Gets the folder with specifications, if the source is a folder. + /// Gets the folder with specifications, if the source is a folder. /// public string? SpecFolder { get; private set; } /// - /// Gets the file with specifications, if the source is a file. + /// Gets the file with specifications, if the source is a file. /// public string? SpecFile { get; private set; } diff --git a/src/DocFxOpenApi/README.md b/src/DocFxOpenApi/README.md index e180c1e..7ee3830 100644 --- a/src/DocFxOpenApi/README.md +++ b/src/DocFxOpenApi/README.md @@ -6,14 +6,15 @@ This tool converts existing [OpenAPI](https://www.openapis.org/) specification f ```text DocFxOpenApi -s [-o ] [-v] - -s, --specfolder Required. Folder containing the OpenAPI specification. + -s, --specsource Required. Folder or file containing the OpenAPI specification. -o, --outputfolder Folder to write the resulting specifications in. - -v, --verbose Show verbose messages. - --help Display this help screen. - --version Display version information. + -v, --verbose Show verbose messages. + --help Display this help screen. + --version Display version information. ``` -The tool converts any `*.json`, `*.yaml`, `*.yml` file from the provided specification folder into the output folder. It supports JSON or YAML-format, OpenAPI v2 or v3 (including 3.0.1) format files. +When a folder is provided to the `specsource` parameter, the tool converts all `*.json`, `*.yaml`, `*.yml` files in the folder and its subfolders. When a file is provided, the tool converts only that file. +It supports JSON or YAML-format, OpenAPI v2 or v3 (including 3.0.1) format files. If the `-o or --outputfolder` is not provided, the output folder is set to the input specs folder.