diff --git a/ApiGeneratorOptions.json b/ApiGeneratorOptions.json
index 6e5affbeb..cc26fb572 100644
--- a/ApiGeneratorOptions.json
+++ b/ApiGeneratorOptions.json
@@ -4,6 +4,13 @@
"swaggerThemeMode": "None",
"useRestExtended": true,
"includeDeprecated": false,
+ "projectSuffixName": "",
+ "contractsLocation": "Contracts.[[apiGroupName]]",
+ "endpointsLocation": "Endpoints.[[apiGroupName]]",
+ "handlersLocation": "Handlers.[[apiGroupName]]",
+ "usePartialClassForContracts": false,
+ "usePartialClassForEndpoints": false,
+ "removeNamespaceGroupSeparatorInGlobalUsings": false,
"request": {},
"response": {
"useProblemDetailsAsDefaultBody": false
@@ -16,5 +23,5 @@
"modelNameCasingStyle": "PascalCase",
"modelPropertyNameCasingStyle": "CamelCase"
},
- "includeDeprecated": false
+ "includeDeprecatedOperations": false
}
\ No newline at end of file
diff --git a/Atc.Rest.Api.Generator.sln.DotSettings b/Atc.Rest.Api.Generator.sln.DotSettings
index 14dd62e35..d3fa14478 100644
--- a/Atc.Rest.Api.Generator.sln.DotSettings
+++ b/Atc.Rest.Api.Generator.sln.DotSettings
@@ -7,4 +7,5 @@
True
True
True
+ True
True
\ No newline at end of file
diff --git a/README.md b/README.md
index 31a6796fe..1ac4aa093 100644
--- a/README.md
+++ b/README.md
@@ -18,6 +18,11 @@
- [Option **generate server all -h**](#option-generate-server-all--h)
- [Command **options-file**](#command-options-file)
- [Default options-file - ApiGeneratorOptions.json](#default-options-file---apigeneratoroptionsjson)
+ - [Custom options-file - ApiGeneratorOptions.json](#custom-options-file---apigeneratoroptionsjson)
+ - [Options for locations explained](#options-for-locations-explained)
+ - [Syntax](#syntax)
+ - [Examples](#examples)
+ - [Other options explained](#other-options-explained)
- [PetStore Example](#petstore-example)
- [Security - supporting role-based security and custom authentication-schemes](#security---supporting-role-based-security-and-custom-authentication-schemes)
- [Roles and authentication-scheme validation](#roles-and-authentication-scheme-validation)
@@ -79,12 +84,12 @@ flowchart TB;
CLI --> ApiGenerator;
CLI --> CodingRules;
-
+
ApiGenerator --> ClientCSharp;
ApiGenerator --> ServerMvc;
ApiGenerator --> ServerMinimal;
ApiGenerator .-> Contracts;
-
+
ClientCSharp --> Framework;
ClientCSharp .-> Contracts;
ClientCSharp .-> CSharpGenerator;
@@ -181,6 +186,9 @@ COMMANDS:
```powershell
atc-rest-api-generator generate server all -h
+DESCRIPTION:
+Creates API, domain and host projects.
+
USAGE:
atc-rest-api-generator.exe generate server all [OPTIONS]
@@ -195,16 +203,24 @@ OPTIONS:
-s, --specificationPath Path to Open API specification (directory, file or url)
--optionsPath [OPTIONSPATH] Path to options json-file
--validate-strictMode Use strictmode
+ --validate-operationIdValidation Use operationId validation
--validate-operationIdCasingStyle [OPERATIONIDCASINGSTYLE] Set casingStyle for operationId. Valid values are: CamelCase (default), KebabCase, PascalCase, SnakeCase
--validate-modelNameCasingStyle [MODELNAMECASINGSTYLE] Set casingStyle for model name. Valid values are: CamelCase, KebabCase, PascalCase (default), SnakeCase
--validate-modelPropertyNameCasingStyle [MODELPROPERTYNAMECASINGSTYLE] Set casingStyle for model property name. Valid values are: CamelCase (default), KebabCase, PascalCase, SnakeCase
- --useAuthorization Use authorization
-p, --projectPrefixName Project prefix name (e.g. 'PetStore' becomes 'PetStore.Api.Generated')
+ --disableCodingRules Disable ATC-Coding-Rules
+ --useProblemDetailsAsDefaultResponseBody Use ProblemDetails as default responsen body
+ --endpointsLocation [ENDPOINTSLOCATION] If endpoints-localtion is provided, generated files will be placed here instead of the Endpoints folder
+ --contractsLocation [CONTRACTSLOCATION] If contracts-localtion is provided, generated files will be placed here instead of the Contracts folder
+ --handlersLocation [HANDLERSLOCATION] If handlers-localtion is provided, generated files will be placed here instead of the Handlers folder
+ --usePartialClassForContracts Use Partial-Class for contracts
+ --usePartialClassForEndpoints Use Partial-Class for endpoints
+ --removeNamespaceGroupSeparatorInGlobalUsings Remove space between namespace groups in GlobalUsing.cs
+ --aspnet-output-type [ASPNETOUTPUTTYPE] Set AspNet output type for the generated api. Valid values are: Mvc (default), MinimalApi
+ --swagger-theme [SWAGGERTHEME] Set Swagger theme for the hosting api. Valid values are: None, Default (default), Light, Dark
--outputSlnPath Path to solution file (directory or file)
--outputSrcPath Path to generated src projects (directory)
--outputTestPath [OUTPUTTESTPATH] Path to generated test projects (directory)
- --disableCodingRules Disable ATC-Coding-Rules
- --removeNamespaceGroupSeparatorInGlobalUsings Remove space between namespace groups in GlobalUsing.cs
```
#### Command **options-file**
@@ -225,13 +241,26 @@ COMMANDS:
validate Validate the options file 'ApiGeneratorOptions.json'
```
+> **Note:** All values from the options-file will be overriden if pressent from the CLI options.
+>
+> **Example:** If the usePartialClassForContracts=false in the options-file and the CLI `--usePartialClassForContracts` options set, then the usePartialClassForContracts is true.
+
#### Default options-file - ApiGeneratorOptions.json
```json
{
"generator": {
- "useAuthorization": false,
+ "aspNetOutputType": "Mvc",
+ "swaggerThemeMode": "None",
"useRestExtended": true,
+ "projectName": "",
+ "projectSuffixName": "",
+ "contractsLocation": "Contracts.[[apiGroupName]]",
+ "endpointsLocation": "Endpoints.[[apiGroupName]]",
+ "handlersLocation": "Handlers.[[apiGroupName]]",
+ "usePartialClassForContracts": false,
+ "usePartialClassForEndpoints": false,
+ "removeNamespaceGroupSeparatorInGlobalUsings": false,
"request": {},
"response": {
"useProblemDetailsAsDefaultBody": false
@@ -239,13 +268,119 @@ COMMANDS:
},
"validation": {
"strictMode": false,
+ "operationIdValidation": false,
"operationIdCasingStyle": "CamelCase",
"modelNameCasingStyle": "PascalCase",
"modelPropertyNameCasingStyle": "CamelCase"
- }
+ },
+ "includeDeprecatedOperations": false
}
```
+#### Custom options-file - ApiGeneratorOptions.json
+
+```json
+{
+ "generator": {
+ "aspNetOutputType": "MinimalApi",
+ "swaggerThemeMode": "Dark",
+ "useRestExtended": true,
+ "projectName": "",
+ "projectSuffixName": "",
+ "contractsLocation": "Contracts.[[apiGroupName]]",
+ "endpointsLocation": "Endpoints.[[apiGroupName]]",
+ "handlersLocation": "Handlers.[[apiGroupName]]",
+ "usePartialClassForContracts": false,
+ "usePartialClassForEndpoints": false,
+ "removeNamespaceGroupSeparatorInGlobalUsings": false,
+ "request": {},
+ "response": {
+ "useProblemDetailsAsDefaultBody": false,
+ "customErrorResponseModel": {
+ "name": "ErrorResponse",
+ "description": "Represents an error response.",
+ "schema": {
+ "status": {
+ "dataType": "string?",
+ "description": "Gets or sets the status of the error."
+ },
+ "message": {
+ "dataType": "string?",
+ "description": "Gets or sets the error message."
+ },
+ "readableMessage": {
+ "dataType": "string?",
+ "description": "Gets or sets the readable message."
+ },
+ "errorCode": {
+ "dataType": "string?",
+ "description": "Gets or sets the error code."
+ },
+ "context": {
+ "dataType": "object?",
+ "description": "Gets or sets the context information."
+ }
+ }
+ }
+ },
+ "client": {
+ "excludeEndpointGeneration": false,
+ "httpClientName": "My-ApiClient"
+ }
+ },
+ "validation": {
+ "strictMode": false,
+ "operationIdValidation": false,
+ "operationIdCasingStyle": "CamelCase",
+ "modelNameCasingStyle": "PascalCase",
+ "modelPropertyNameCasingStyle": "CamelCase"
+ },
+ "includeDeprecatedOperations": false
+}
+```
+
+#### Options for locations explained
+
+The following options control the file locations for generated files such as contracts, endpoints, and handlers.
+You can use specific syntax to define and customize the output file structure.
+
+##### Syntax
+
+For options like `contractsLocation`, `endpointsLocation`, and `handlersLocation`,
+you can define paths using placeholders and custom directory names.
+
+The syntax is flexible and allows you to organize files based on grouping or specific requirements.
+
+##### Examples
+
+| Option-Name | Option-Value | Example-file | Generated-output |
+|-------------|--------------|--------------|------------------|
+| contractsLocation | Contracts | Account.cs | [Project-root]\Contracts\Accounts\Account.cs |
+| contractsLocation | Contracts.[[apiGroupName]] | Account.cs | [Project-root]\Contracts\Accounts\Account.cs |
+| contractsLocation | Contracts-[[apiGroupName]] | Account.cs | [Project-root]\Contracts\Accounts\Account.cs |
+| contractsLocation | [[apiGroupName]].MyContracts | Account.cs | [Project-root]\Accounts\MyContracts\Account.cs |
+| contractsLocation | [[apiGroupName]]-MyContracts | Account.cs | [Project-root]\Accounts\MyContracts\Account.cs |
+| contractsLocation | [[apiGroupName]] | Account.cs | [Project-root]\Accounts\Account.cs |
+| contractsLocation | . | Account.cs | [Project-root]\Account.cs |
+
+> Placeholder Explanation:
+>
+> - [[apiGroupName]]: A placeholder replaced by the API group name during code generation. This allows grouping files dynamically based on your API structure.
+> - [Project-root]: The root directory of your project where the generated files will be placed.
+
+By using these options, you can effectively organize generated files into meaningful folder structures, ensuring clarity and scalability in your project layout.
+
+#### Other options explained
+
+The `projectSuffixName` extend `projectName` like the example:
+
+| projectName | projectSuffixName | Generated project name | Reson |
+|-------------|-------------------|------------------------|-------|
+| PetStore | | PetStore.Api.Generated | default is `Api.Generated` |
+| PetStore | MyApi | PetStore.MyApi | |
+| PetStore | Foo.Api | PetStore.Foo.Api | |
+| PetStore | Bar-Api | PetStore.Bar.Api | |
+
## PetStore Example
The following command will generate an API that implements the offcial Pet Store example from Swagger.
diff --git a/src/Atc.CodeGeneration.CSharp/Content/AccessModifiers.cs b/src/Atc.CodeGeneration.CSharp/Content/AccessModifiers.cs
index 66075c684..270aa1b23 100644
--- a/src/Atc.CodeGeneration.CSharp/Content/AccessModifiers.cs
+++ b/src/Atc.CodeGeneration.CSharp/Content/AccessModifiers.cs
@@ -7,39 +7,18 @@ public enum AccessModifiers
[Description("public")]
Public,
- [Description("public async")]
- PublicAsync,
-
- [Description("public static")]
- PublicStatic,
-
- [Description("public static implicit operator")]
- PublicStaticImplicitOperator,
-
- [Description("public class")]
- PublicClass,
-
- [Description("public static class")]
- PublicStaticClass,
-
- [Description("public sealed class")]
- PublicSealedClass,
-
- [Description("public record")]
- PublicRecord,
-
- [Description("public record struct")]
- PublicRecordStruct,
-
[Description("private")]
Private,
- [Description("private async")]
- PrivateAsync,
-
[Description("protected")]
Protected,
[Description("internal")]
Internal,
+
+ [Description("protected internal")]
+ ProtectedInternal,
+
+ [Description("private protected")]
+ PrivateProtected,
}
\ No newline at end of file
diff --git a/src/Atc.CodeGeneration.CSharp/Content/DeclarationModifiers.cs b/src/Atc.CodeGeneration.CSharp/Content/DeclarationModifiers.cs
new file mode 100644
index 000000000..bb34dfd2f
--- /dev/null
+++ b/src/Atc.CodeGeneration.CSharp/Content/DeclarationModifiers.cs
@@ -0,0 +1,63 @@
+namespace Atc.CodeGeneration.CSharp.Content;
+
+public enum DeclarationModifiers
+{
+ None,
+
+ [Description("public")]
+ Public,
+
+ [Description("public async")]
+ PublicAsync,
+
+ [Description("public static")]
+ PublicStatic,
+
+ [Description("public static implicit operator")]
+ PublicStaticImplicitOperator,
+
+ [Description("public class")]
+ PublicClass,
+
+ [Description("public partial class")]
+ PublicPartialClass,
+
+ [Description("public static class")]
+ PublicStaticClass,
+
+ [Description("public sealed class")]
+ PublicSealedClass,
+
+ [Description("public interface")]
+ PublicInterface,
+
+ [Description("public partial interface")]
+ PublicPartialInterface,
+
+ [Description("public static interface")]
+ PublicStaticInterface,
+
+ [Description("public record")]
+ PublicRecord,
+
+ [Description("public record struct")]
+ PublicRecordStruct,
+
+ [Description("public partial record")]
+ PublicPartialRecord,
+
+ [Description("public partial record struct")]
+ PublicPartialRecordStruct,
+
+ [Description("private")]
+ Private,
+
+ [Description("private async")]
+ PrivateAsync,
+
+ [Description("protected")]
+ Protected,
+
+ [Description("internal")]
+ Internal,
+}
\ No newline at end of file
diff --git a/src/Atc.CodeGeneration.CSharp/Content/Factories/ClassParametersFactory.cs b/src/Atc.CodeGeneration.CSharp/Content/Factories/ClassParametersFactory.cs
index ed4ec74b4..15142c32e 100644
--- a/src/Atc.CodeGeneration.CSharp/Content/Factories/ClassParametersFactory.cs
+++ b/src/Atc.CodeGeneration.CSharp/Content/Factories/ClassParametersFactory.cs
@@ -6,13 +6,14 @@ public static ClassParameters Create(
string headerContent,
string @namespace,
AttributeParameters attribute,
- string classTypeName)
+ string classTypeName,
+ bool usePartialClass = false)
=> new(
HeaderContent: headerContent,
Namespace: @namespace,
DocumentationTags: null,
Attributes: new List { attribute },
- AccessModifiers.PublicClass,
+ usePartialClass ? DeclarationModifiers.PublicPartialClass : DeclarationModifiers.PublicClass,
ClassTypeName: classTypeName,
GenericTypeName: null,
InheritedClassTypeName: null,
diff --git a/src/Atc.CodeGeneration.CSharp/Content/Factories/EnumParametersFactory.cs b/src/Atc.CodeGeneration.CSharp/Content/Factories/EnumParametersFactory.cs
index 113698158..1b3e31ab6 100644
--- a/src/Atc.CodeGeneration.CSharp/Content/Factories/EnumParametersFactory.cs
+++ b/src/Atc.CodeGeneration.CSharp/Content/Factories/EnumParametersFactory.cs
@@ -14,7 +14,7 @@ public static EnumParameters Create(
Namespace: @namespace,
DocumentationTags: documentationTags,
Attributes: attributes,
- AccessModifier: AccessModifiers.Public,
+ DeclarationModifier: DeclarationModifiers.Public,
EnumTypeName: enumTypeName,
UseFlags: false,
EnumValuesParametersFactory.Create(enumNames));
@@ -31,7 +31,7 @@ public static EnumParameters Create(
Namespace: @namespace,
DocumentationTags: documentationTags,
Attributes: attributes,
- AccessModifier: AccessModifiers.Public,
+ DeclarationModifier: DeclarationModifiers.Public,
EnumTypeName: enumTypeName,
UseFlags: DetermineIfFlagsAttributeShouldBeUsed(enumNameValues),
EnumValuesParametersFactory.Create(enumNameValues));
diff --git a/src/Atc.CodeGeneration.CSharp/Content/Factories/InterfaceParametersFactory.cs b/src/Atc.CodeGeneration.CSharp/Content/Factories/InterfaceParametersFactory.cs
index a088294b9..50fea3999 100644
--- a/src/Atc.CodeGeneration.CSharp/Content/Factories/InterfaceParametersFactory.cs
+++ b/src/Atc.CodeGeneration.CSharp/Content/Factories/InterfaceParametersFactory.cs
@@ -12,7 +12,7 @@ public static InterfaceParameters Create(
Namespace: @namespace,
DocumentationTags: null,
Attributes: new List { attribute },
- AccessModifiers.Public,
+ DeclarationModifiers.Public,
InterfaceTypeName: interfaceTypeName,
InheritedInterfaceTypeName: null,
Properties: null,
@@ -28,7 +28,7 @@ public static InterfaceParameters Create(
Namespace: @namespace,
DocumentationTags: null,
Attributes: attributes,
- AccessModifiers.Public,
+ DeclarationModifiers.PublicInterface,
InterfaceTypeName: interfaceTypeName,
InheritedInterfaceTypeName: null,
Properties: null,
diff --git a/src/Atc.CodeGeneration.CSharp/Content/Generators/GenerateContentForClass.cs b/src/Atc.CodeGeneration.CSharp/Content/Generators/GenerateContentForClass.cs
index 4474a12fe..014036392 100644
--- a/src/Atc.CodeGeneration.CSharp/Content/Generators/GenerateContentForClass.cs
+++ b/src/Atc.CodeGeneration.CSharp/Content/Generators/GenerateContentForClass.cs
@@ -27,7 +27,7 @@ public string Generate()
parameters.DocumentationTags,
parameters.Attributes));
- sb.Append($"{parameters.AccessModifier.GetDescription()} {parameters.ClassTypeName}");
+ sb.Append($"{parameters.DeclarationModifier.GetDescription()} {parameters.ClassTypeName}");
if (!string.IsNullOrEmpty(parameters.GenericTypeName))
{
sb.Append($"<{parameters.GenericTypeName}>");
diff --git a/src/Atc.CodeGeneration.CSharp/Content/Generators/GenerateContentForEnum.cs b/src/Atc.CodeGeneration.CSharp/Content/Generators/GenerateContentForEnum.cs
index 447093510..b309c5768 100644
--- a/src/Atc.CodeGeneration.CSharp/Content/Generators/GenerateContentForEnum.cs
+++ b/src/Atc.CodeGeneration.CSharp/Content/Generators/GenerateContentForEnum.cs
@@ -34,7 +34,7 @@ public string Generate()
sb.AppendLine("[JsonConverter(typeof(JsonStringEnumConverter))]");
}
- sb.Append($"{parameters.AccessModifier.GetDescription()} enum ");
+ sb.Append($"{parameters.DeclarationModifier.GetDescription()} enum ");
sb.AppendLine($"{parameters.EnumTypeName}");
sb.AppendLine("{");
diff --git a/src/Atc.CodeGeneration.CSharp/Content/Generators/GenerateContentForInterface.cs b/src/Atc.CodeGeneration.CSharp/Content/Generators/GenerateContentForInterface.cs
index c1fffb53c..490e7720c 100644
--- a/src/Atc.CodeGeneration.CSharp/Content/Generators/GenerateContentForInterface.cs
+++ b/src/Atc.CodeGeneration.CSharp/Content/Generators/GenerateContentForInterface.cs
@@ -26,7 +26,7 @@ public string Generate()
parameters.DocumentationTags,
parameters.Attributes));
- sb.Append($"{parameters.AccessModifier.GetDescription()} interface ");
+ sb.Append($"{parameters.DeclarationModifier.GetDescription()} ");
if (string.IsNullOrEmpty(parameters.InheritedInterfaceTypeName))
{
sb.AppendLine($"{parameters.InterfaceTypeName}");
diff --git a/src/Atc.CodeGeneration.CSharp/Content/Generators/GenerateContentForRecords.cs b/src/Atc.CodeGeneration.CSharp/Content/Generators/GenerateContentForRecords.cs
index 4e576f446..7875d3544 100644
--- a/src/Atc.CodeGeneration.CSharp/Content/Generators/GenerateContentForRecords.cs
+++ b/src/Atc.CodeGeneration.CSharp/Content/Generators/GenerateContentForRecords.cs
@@ -34,11 +34,11 @@ public string Generate()
recordParameters.Parameters.Any(x => x.IsGenericListType &&
x.TypeName.Equals("T", StringComparison.Ordinal)))
{
- sb.Append($"{recordParameters.AccessModifier.GetDescription()} {recordParameters.Name}");
+ sb.Append($"{recordParameters.DeclarationModifier.GetDescription()} {recordParameters.Name}");
}
else
{
- sb.Append($"{recordParameters.AccessModifier.GetDescription()} {recordParameters.Name}");
+ sb.Append($"{recordParameters.DeclarationModifier.GetDescription()} {recordParameters.Name}");
}
if (recordParameters.Parameters is null ||
diff --git a/src/Atc.CodeGeneration.CSharp/Content/Generators/Internal/GenerateContentWriter.cs b/src/Atc.CodeGeneration.CSharp/Content/Generators/Internal/GenerateContentWriter.cs
index c0656c74b..84bc4c33e 100644
--- a/src/Atc.CodeGeneration.CSharp/Content/Generators/Internal/GenerateContentWriter.cs
+++ b/src/Atc.CodeGeneration.CSharp/Content/Generators/Internal/GenerateContentWriter.cs
@@ -53,7 +53,7 @@ public string GenerateConstructor(
var sb = new StringBuilder();
- sb.AppendAccessModifier(4, parameters.AccessModifier);
+ sb.AppendDeclarationModifier(4, parameters.DeclarationModifier);
if (string.IsNullOrEmpty(parameters.GenericTypeName))
{
@@ -181,9 +181,9 @@ public string GenerateProperty(
}
sb.Append(" ");
- if (parameters.AccessModifier != AccessModifiers.None)
+ if (parameters.DeclarationModifier != DeclarationModifiers.None)
{
- sb.AppendAccessModifier(parameters.AccessModifier);
+ sb.AppendDeclarationModifier(parameters.DeclarationModifier);
}
sb.AppendTypeAndName(parameters.GenericTypeName, parameters.TypeName, parameters.IsNullableType, parameters.Name);
@@ -261,9 +261,9 @@ public string GenerateMethod(
}
sb.Append(" ");
- if (parameters.AccessModifier != AccessModifiers.None)
+ if (parameters.DeclarationModifier != DeclarationModifiers.None)
{
- sb.AppendAccessModifier(parameters.AccessModifier);
+ sb.AppendDeclarationModifier(parameters.DeclarationModifier);
}
if (string.IsNullOrEmpty(parameters.ReturnTypeName))
@@ -306,7 +306,7 @@ public string GenerateMethod(
useCommaForEndChar);
}
- if (parameters.AccessModifier == AccessModifiers.None)
+ if (parameters.DeclarationModifier == DeclarationModifiers.None)
{
sb.Append(';');
}
diff --git a/src/Atc.CodeGeneration.CSharp/Content/ParameterRecords.cs b/src/Atc.CodeGeneration.CSharp/Content/ParameterRecords.cs
index f384eb90d..e340ff99e 100644
--- a/src/Atc.CodeGeneration.CSharp/Content/ParameterRecords.cs
+++ b/src/Atc.CodeGeneration.CSharp/Content/ParameterRecords.cs
@@ -36,7 +36,7 @@ public record BaseParameters(
string? HeaderContent,
string Namespace,
CodeDocumentationTags? DocumentationTags,
- AccessModifiers AccessModifier,
+ DeclarationModifiers DeclarationModifier,
string TypeName);
public record InterfaceParameters(
@@ -44,7 +44,7 @@ public record InterfaceParameters(
string Namespace,
CodeDocumentationTags? DocumentationTags,
IList? Attributes,
- AccessModifiers AccessModifier,
+ DeclarationModifiers DeclarationModifier,
string InterfaceTypeName,
string? InheritedInterfaceTypeName,
IList? Properties,
@@ -53,7 +53,7 @@ public record InterfaceParameters(
HeaderContent,
Namespace,
DocumentationTags,
- AccessModifier,
+ DeclarationModifier,
InterfaceTypeName);
public record ClassParameters(
@@ -61,7 +61,7 @@ public record ClassParameters(
string Namespace,
CodeDocumentationTags? DocumentationTags,
IList? Attributes,
- AccessModifiers AccessModifier,
+ DeclarationModifiers DeclarationModifier,
string ClassTypeName,
string? GenericTypeName,
string? InheritedClassTypeName,
@@ -75,7 +75,7 @@ public record ClassParameters(
HeaderContent,
Namespace,
DocumentationTags,
- AccessModifier,
+ DeclarationModifier,
ClassTypeName);
public record EnumParameters(
@@ -83,7 +83,7 @@ public record EnumParameters(
string Namespace,
CodeDocumentationTags? DocumentationTags,
IList? Attributes,
- AccessModifiers AccessModifier,
+ DeclarationModifiers DeclarationModifier,
string EnumTypeName,
bool UseFlags,
IList Values)
@@ -91,7 +91,7 @@ public record EnumParameters(
HeaderContent,
Namespace,
DocumentationTags,
- AccessModifier,
+ DeclarationModifier,
EnumTypeName);
public record AttributeParameters(
@@ -120,7 +120,7 @@ public record ConstructorParameterBaseParameters(
public record ConstructorParameters(
CodeDocumentationTags? DocumentationTags,
- AccessModifiers AccessModifier,
+ DeclarationModifiers DeclarationModifier,
string? GenericTypeName,
string TypeName,
string? InheritedClassTypeName,
@@ -129,7 +129,7 @@ public record ConstructorParameters(
public record PropertyParameters(
CodeDocumentationTags? DocumentationTags,
IList? Attributes,
- AccessModifiers AccessModifier,
+ DeclarationModifiers DeclarationModifier,
string? GenericTypeName,
string TypeName,
bool IsNullableType,
@@ -156,7 +156,7 @@ public record PropertyParameters(
public record MethodParameters(
CodeDocumentationTags? DocumentationTags,
IList? Attributes,
- AccessModifiers AccessModifier,
+ DeclarationModifiers DeclarationModifier,
string? ReturnGenericTypeName,
string? ReturnTypeName,
string Name,
@@ -176,10 +176,11 @@ public record RecordsParameters(
string Namespace,
CodeDocumentationTags? DocumentationTags,
IList? Attributes,
+ DeclarationModifiers DeclarationModifier,
IList Parameters);
public record RecordParameters(
CodeDocumentationTags? DocumentationTags,
- AccessModifiers AccessModifier,
+ DeclarationModifiers DeclarationModifier,
string Name,
IList? Parameters);
\ No newline at end of file
diff --git a/src/Atc.CodeGeneration.CSharp/Extensions/StringBuilderExtensions.cs b/src/Atc.CodeGeneration.CSharp/Extensions/StringBuilderExtensions.cs
index 8c46f3baa..766457c30 100644
--- a/src/Atc.CodeGeneration.CSharp/Extensions/StringBuilderExtensions.cs
+++ b/src/Atc.CodeGeneration.CSharp/Extensions/StringBuilderExtensions.cs
@@ -3,20 +3,23 @@ namespace Atc.CodeGeneration.CSharp.Extensions;
[SuppressMessage("Design", "CA1062:Validate arguments of public methods", Justification = "OK.")]
public static class StringBuilderExtensions
{
- public static void AppendAccessModifier(
+ public static void AppendDeclarationModifier(
this StringBuilder sb,
- AccessModifiers accessModifier)
- => sb.AppendAccessModifier(0, accessModifier);
+ DeclarationModifiers declarationModifier)
+ => sb.AppendDeclarationModifier(0, declarationModifier);
- public static void AppendAccessModifier(
+ public static void AppendDeclarationModifier(
this StringBuilder sb,
int indentSpaces,
- AccessModifiers accessModifier)
+ DeclarationModifiers declarationModifier)
{
- if (accessModifier != AccessModifiers.None)
+ if (declarationModifier == DeclarationModifiers.None)
{
- sb.Append(indentSpaces, $"{accessModifier.GetDescription()} ");
+ return;
}
+
+ sb.Append(indentSpaces, declarationModifier.GetDescription());
+ sb.Append(' ');
}
public static void AppendTypeAndName(
diff --git a/src/Atc.Rest.ApiGenerator.CLI/ApiOptionsHelper.cs b/src/Atc.Rest.ApiGenerator.CLI/ApiOptionsHelper.cs
index a013ec217..ca3e5346d 100644
--- a/src/Atc.Rest.ApiGenerator.CLI/ApiOptionsHelper.cs
+++ b/src/Atc.Rest.ApiGenerator.CLI/ApiOptionsHelper.cs
@@ -132,20 +132,21 @@ private static void ApplyGeneratorOverrides(
{
if (settings is BaseServerCommandSettings serverCommandSettings)
{
- if (serverCommandSettings.AspNetOutputType.IsSet)
+ if (serverCommandSettings.AspNetOutputType.IsSet ||
+ serverCommandSettings.AspNetOutputType.Value != apiOptions.Generator.AspNetOutputType)
{
apiOptions.Generator.AspNetOutputType = serverCommandSettings.AspNetOutputType.Value;
}
- if (serverCommandSettings.SwaggerThemeMode.IsSet)
+ if (serverCommandSettings.SwaggerThemeMode.IsSet ||
+ serverCommandSettings.SwaggerThemeMode.Value != apiOptions.Generator.SwaggerThemeMode)
{
apiOptions.Generator.SwaggerThemeMode = serverCommandSettings.SwaggerThemeMode.Value;
}
if (serverCommandSettings.UseProblemDetailsAsDefaultResponseBody)
{
- apiOptions.Generator.Response.UseProblemDetailsAsDefaultBody =
- serverCommandSettings.UseProblemDetailsAsDefaultResponseBody;
+ apiOptions.Generator.Response.UseProblemDetailsAsDefaultBody = serverCommandSettings.UseProblemDetailsAsDefaultResponseBody;
}
if (serverCommandSettings.ProjectPrefixName is not null)
@@ -153,6 +154,34 @@ private static void ApplyGeneratorOverrides(
apiOptions.Generator.ProjectName = serverCommandSettings.ProjectPrefixName;
}
+ if (serverCommandSettings.ContractsLocation is not null &&
+ serverCommandSettings.ContractsLocation.IsSet)
+ {
+ apiOptions.Generator.ContractsLocation = serverCommandSettings.ContractsLocation.Value;
+ }
+
+ if (serverCommandSettings.EndpointsLocation is not null &&
+ serverCommandSettings.EndpointsLocation.IsSet)
+ {
+ apiOptions.Generator.EndpointsLocation = serverCommandSettings.EndpointsLocation.Value;
+ }
+
+ if (serverCommandSettings.HandlersLocation is not null &&
+ serverCommandSettings.HandlersLocation.IsSet)
+ {
+ apiOptions.Generator.HandlersLocation = serverCommandSettings.HandlersLocation.Value;
+ }
+
+ if (serverCommandSettings.UsePartialClassForContracts)
+ {
+ apiOptions.Generator.UsePartialClassForContracts = serverCommandSettings.UsePartialClassForContracts;
+ }
+
+ if (serverCommandSettings.UsePartialClassForEndpoints)
+ {
+ apiOptions.Generator.UsePartialClassForEndpoints = serverCommandSettings.UsePartialClassForEndpoints;
+ }
+
if (serverCommandSettings.RemoveNamespaceGroupSeparatorInGlobalUsings)
{
apiOptions.Generator.RemoveNamespaceGroupSeparatorInGlobalUsings = serverCommandSettings.RemoveNamespaceGroupSeparatorInGlobalUsings;
@@ -165,8 +194,7 @@ private static void ApplyGeneratorOverrides(
{
if (clientApiCommandSettings.UseProblemDetailsAsDefaultResponseBody)
{
- apiOptions.Generator.Response.UseProblemDetailsAsDefaultBody =
- clientApiCommandSettings.UseProblemDetailsAsDefaultResponseBody;
+ apiOptions.Generator.Response.UseProblemDetailsAsDefaultBody = clientApiCommandSettings.UseProblemDetailsAsDefaultResponseBody;
}
if (clientApiCommandSettings.ProjectPrefixName is not null)
@@ -181,41 +209,54 @@ private static void ApplyGeneratorOverrides(
if (string.IsNullOrEmpty(apiOptions.Generator.ProjectSuffixName))
{
- apiOptions.Generator.ProjectSuffixName = "ApiClient.Generated";
+ apiOptions.Generator.ProjectSuffixName = $"{ContentGeneratorConstants.DefaultHttpClientName}.Generated";
}
- apiOptions.Generator.Client ??= new ApiOptionsGeneratorClient();
+ if (clientApiCommandSettings.ContractsLocation is not null &&
+ clientApiCommandSettings.ContractsLocation.IsSet)
+ {
+ apiOptions.Generator.ContractsLocation = clientApiCommandSettings.ContractsLocation.Value;
+ }
+
+ if (clientApiCommandSettings.EndpointsLocation is not null &&
+ clientApiCommandSettings.EndpointsLocation.IsSet)
+ {
+ apiOptions.Generator.EndpointsLocation = clientApiCommandSettings.EndpointsLocation.Value;
+ }
- if (clientApiCommandSettings.ClientFolderName is not null &&
- clientApiCommandSettings.ClientFolderName.IsSet)
+ if (clientApiCommandSettings.UsePartialClassForContracts)
{
- apiOptions.Generator.Client.FolderName = clientApiCommandSettings.ClientFolderName.Value;
+ apiOptions.Generator.UsePartialClassForContracts = clientApiCommandSettings.UsePartialClassForContracts;
}
+ if (clientApiCommandSettings.UsePartialClassForEndpoints)
+ {
+ apiOptions.Generator.UsePartialClassForEndpoints = clientApiCommandSettings.UsePartialClassForEndpoints;
+ }
+
+ apiOptions.Generator.Client ??= new ApiOptionsGeneratorClient();
+
if (clientApiCommandSettings.HttpClientName is not null &&
clientApiCommandSettings.HttpClientName.IsSet)
{
apiOptions.Generator.Client.HttpClientName = clientApiCommandSettings.HttpClientName.Value;
}
- else if ("ApiClient".Equals(apiOptions.Generator.Client.HttpClientName, StringComparison.Ordinal))
+ else if (ContentGeneratorConstants.DefaultHttpClientName.Equals(apiOptions.Generator.Client.HttpClientName, StringComparison.Ordinal))
{
var baseGenerateCommandSettings = (BaseGenerateCommandSettings)settings;
- apiOptions.Generator.Client.HttpClientName = $"{baseGenerateCommandSettings.ProjectPrefixName}-ApiClient";
+ apiOptions.Generator.Client.HttpClientName = $"{baseGenerateCommandSettings.ProjectPrefixName}-{ContentGeneratorConstants.DefaultHttpClientName}";
}
- apiOptions.Generator.Client.ExcludeEndpointGeneration = clientApiCommandSettings.ExcludeEndpointGeneration;
+ if (clientApiCommandSettings.ExcludeEndpointGeneration)
+ {
+ apiOptions.Generator.Client.ExcludeEndpointGeneration = clientApiCommandSettings.ExcludeEndpointGeneration;
+ }
break;
}
}
- if (apiOptions.Generator.ProjectSuffixName.Contains(' ', StringComparison.Ordinal) ||
- apiOptions.Generator.ProjectSuffixName.Contains('-', StringComparison.Ordinal))
- {
- apiOptions.Generator.ProjectSuffixName = apiOptions.Generator.ProjectSuffixName
- .Trim()
- .Replace(' ', '.')
- .Replace('-', '.');
- }
+ apiOptions.Generator.ProjectName = apiOptions.Generator.ProjectName.EnsureNamespaceFormat();
+ apiOptions.Generator.ProjectSuffixName = apiOptions.Generator.ProjectSuffixName.EnsureNamespaceFormat();
}
}
\ No newline at end of file
diff --git a/src/Atc.Rest.ApiGenerator.CLI/Commands/ArgumentCommandConstants.cs b/src/Atc.Rest.ApiGenerator.CLI/Commands/ArgumentCommandConstants.cs
index e4fd46bd1..cb385698f 100644
--- a/src/Atc.Rest.ApiGenerator.CLI/Commands/ArgumentCommandConstants.cs
+++ b/src/Atc.Rest.ApiGenerator.CLI/Commands/ArgumentCommandConstants.cs
@@ -20,9 +20,14 @@ public static class ArgumentCommandConstants
public const string LongConfigurationValidateModelNameCasingStyle = "--validate-modelNameCasingStyle";
public const string LongConfigurationValidateModelPropertyNameCasingStyle = "--validate-modelPropertyNameCasingStyle";
- public const string LongClientFolderName = "--clientFolderName";
+ public const string LongEndpointsLocation = "--endpointsLocation";
+ public const string LongContractsLocation = "--contractsLocation";
+ public const string LongHandlersLocation = "--handlersLocation";
+
public const string LongClientHttpClientName = "--httpClientName";
public const string LongExcludeEndpointGeneration = "--excludeEndpointGeneration";
+ public const string LongUsePartialClassForContracts = "--usePartialClassForContracts";
+ public const string LongUsePartialClassForEndpoints = "--usePartialClassForEndpoints";
public const string LongServerOutputSolutionPath = "--outputSlnPath";
public const string LongServerOutputSourcePath = "--outputSrcPath";
diff --git a/src/Atc.Rest.ApiGenerator.CLI/Commands/GenerateClientCSharpCommand.cs b/src/Atc.Rest.ApiGenerator.CLI/Commands/GenerateClientCSharpCommand.cs
index 7842ef9ef..459081065 100644
--- a/src/Atc.Rest.ApiGenerator.CLI/Commands/GenerateClientCSharpCommand.cs
+++ b/src/Atc.Rest.ApiGenerator.CLI/Commands/GenerateClientCSharpCommand.cs
@@ -60,7 +60,7 @@ private async Task ExecuteInternalAsync(
{
if (!openApiDocumentValidator.IsValid(
apiOptions.Validation,
- apiOptions.IncludeDeprecated,
+ apiOptions.IncludeDeprecatedOperations,
apiDocumentContainer))
{
return ConsoleExitStatusCodes.Failure;
diff --git a/src/Atc.Rest.ApiGenerator.CLI/Commands/GenerateServerAllCommand.cs b/src/Atc.Rest.ApiGenerator.CLI/Commands/GenerateServerAllCommand.cs
index e52ff3455..6780d9d26 100644
--- a/src/Atc.Rest.ApiGenerator.CLI/Commands/GenerateServerAllCommand.cs
+++ b/src/Atc.Rest.ApiGenerator.CLI/Commands/GenerateServerAllCommand.cs
@@ -75,7 +75,7 @@ private async Task ExecuteInternalAsync(
{
if (!openApiDocumentValidator.IsValid(
apiOptions.Validation,
- apiOptions.IncludeDeprecated,
+ apiOptions.IncludeDeprecatedOperations,
apiDocumentContainer))
{
return ConsoleExitStatusCodes.Failure;
diff --git a/src/Atc.Rest.ApiGenerator.CLI/Commands/GenerateServerApiCommand.cs b/src/Atc.Rest.ApiGenerator.CLI/Commands/GenerateServerApiCommand.cs
index f0d942a9e..26e32de42 100644
--- a/src/Atc.Rest.ApiGenerator.CLI/Commands/GenerateServerApiCommand.cs
+++ b/src/Atc.Rest.ApiGenerator.CLI/Commands/GenerateServerApiCommand.cs
@@ -68,7 +68,7 @@ private async Task ExecuteInternalAsync(
{
if (!openApiDocumentValidator.IsValid(
apiOptions.Validation,
- apiOptions.IncludeDeprecated,
+ apiOptions.IncludeDeprecatedOperations,
apiDocumentContainer))
{
return ConsoleExitStatusCodes.Failure;
diff --git a/src/Atc.Rest.ApiGenerator.CLI/Commands/GenerateServerDomainCommand.cs b/src/Atc.Rest.ApiGenerator.CLI/Commands/GenerateServerDomainCommand.cs
index 2460956fc..4271042d5 100644
--- a/src/Atc.Rest.ApiGenerator.CLI/Commands/GenerateServerDomainCommand.cs
+++ b/src/Atc.Rest.ApiGenerator.CLI/Commands/GenerateServerDomainCommand.cs
@@ -68,7 +68,7 @@ private async Task ExecuteInternalAsync(
{
if (!openApiDocumentValidator.IsValid(
apiOptions.Validation,
- apiOptions.IncludeDeprecated,
+ apiOptions.IncludeDeprecatedOperations,
apiDocumentContainer))
{
return ConsoleExitStatusCodes.Failure;
diff --git a/src/Atc.Rest.ApiGenerator.CLI/Commands/GenerateServerHostCommand.cs b/src/Atc.Rest.ApiGenerator.CLI/Commands/GenerateServerHostCommand.cs
index d5512227c..2e93f554c 100644
--- a/src/Atc.Rest.ApiGenerator.CLI/Commands/GenerateServerHostCommand.cs
+++ b/src/Atc.Rest.ApiGenerator.CLI/Commands/GenerateServerHostCommand.cs
@@ -68,7 +68,7 @@ private async Task ExecuteInternalAsync(
{
if (!openApiDocumentValidator.IsValid(
apiOptions.Validation,
- apiOptions.IncludeDeprecated,
+ apiOptions.IncludeDeprecatedOperations,
apiDocumentContainer))
{
return ConsoleExitStatusCodes.Failure;
diff --git a/src/Atc.Rest.ApiGenerator.CLI/Commands/Settings/BaseGenerateCommandSettings.cs b/src/Atc.Rest.ApiGenerator.CLI/Commands/Settings/BaseGenerateCommandSettings.cs
index c8ec7782a..1234d1990 100644
--- a/src/Atc.Rest.ApiGenerator.CLI/Commands/Settings/BaseGenerateCommandSettings.cs
+++ b/src/Atc.Rest.ApiGenerator.CLI/Commands/Settings/BaseGenerateCommandSettings.cs
@@ -14,6 +14,26 @@ public class BaseGenerateCommandSettings : BaseConfigurationCommandSettings
[Description("Use ProblemDetails as default responsen body")]
public bool UseProblemDetailsAsDefaultResponseBody { get; init; }
+ [CommandOption($"{ArgumentCommandConstants.LongEndpointsLocation} [ENDPOINTSLOCATION]")]
+ [Description($"If endpoints-localtion is provided, generated files will be placed here instead of the {ContentGeneratorConstants.Endpoints} folder.")]
+ public FlagValue? EndpointsLocation { get; init; }
+
+ [CommandOption($"{ArgumentCommandConstants.LongContractsLocation} [CONTRACTSLOCATION]")]
+ [Description($"If contracts-localtion is provided, generated files will be placed here instead of the {ContentGeneratorConstants.Contracts} folder.")]
+ public FlagValue? ContractsLocation { get; init; }
+
+ [CommandOption($"{ArgumentCommandConstants.LongHandlersLocation} [HANDLERSLOCATION]")]
+ [Description($"If handlers-localtion is provided, generated files will be placed here instead of the {ContentGeneratorConstants.Handlers} folder.")]
+ public FlagValue? HandlersLocation { get; init; }
+
+ [CommandOption(ArgumentCommandConstants.LongUsePartialClassForContracts)]
+ [Description("Use Partial-Class for contracts")]
+ public bool UsePartialClassForContracts { get; init; }
+
+ [CommandOption(ArgumentCommandConstants.LongUsePartialClassForEndpoints)]
+ [Description("Use Partial-Class for endpoints")]
+ public bool UsePartialClassForEndpoints { get; init; }
+
[CommandOption($"{ArgumentCommandConstants.LongRemoveNamespaceGroupSeparatorInGlobalUsings}")]
[Description("Remove space between namespace groups in GlobalUsing.cs")]
public bool RemoveNamespaceGroupSeparatorInGlobalUsings { get; init; }
diff --git a/src/Atc.Rest.ApiGenerator.CLI/Commands/Settings/ClientApiCommandSettings.cs b/src/Atc.Rest.ApiGenerator.CLI/Commands/Settings/ClientApiCommandSettings.cs
index 83e0879d6..11c06bd2f 100644
--- a/src/Atc.Rest.ApiGenerator.CLI/Commands/Settings/ClientApiCommandSettings.cs
+++ b/src/Atc.Rest.ApiGenerator.CLI/Commands/Settings/ClientApiCommandSettings.cs
@@ -6,10 +6,6 @@ public class ClientApiCommandSettings : BaseGenerateCommandSettings
[Description("Path to generated project (directory)")]
public string OutputPath { get; init; } = string.Empty;
- [CommandOption($"{ArgumentCommandConstants.LongClientFolderName} [CLIENTFOLDERNAME]")]
- [Description("If client folder is provided, generated files will be placed here instead of the project root.")]
- public FlagValue? ClientFolderName { get; init; }
-
[CommandOption(ArgumentCommandConstants.LongExcludeEndpointGeneration)]
[Description("Exclude endpoint generation")]
public bool ExcludeEndpointGeneration { get; init; }
diff --git a/src/Atc.Rest.ApiGenerator.CLI/Commands/ValidateSchemaCommand.cs b/src/Atc.Rest.ApiGenerator.CLI/Commands/ValidateSchemaCommand.cs
index f487d0418..e9bc87107 100644
--- a/src/Atc.Rest.ApiGenerator.CLI/Commands/ValidateSchemaCommand.cs
+++ b/src/Atc.Rest.ApiGenerator.CLI/Commands/ValidateSchemaCommand.cs
@@ -41,7 +41,7 @@ private async Task ExecuteInternalAsync(
{
if (!openApiDocumentValidator.IsValid(
apiOptions.Validation,
- apiOptions.IncludeDeprecated,
+ apiOptions.IncludeDeprecatedOperations,
apiDocumentContainer))
{
return ConsoleExitStatusCodes.Failure;
diff --git a/src/Atc.Rest.ApiGenerator.CLI/GlobalUsings.cs b/src/Atc.Rest.ApiGenerator.CLI/GlobalUsings.cs
index 49caf47dc..65b02b2aa 100644
--- a/src/Atc.Rest.ApiGenerator.CLI/GlobalUsings.cs
+++ b/src/Atc.Rest.ApiGenerator.CLI/GlobalUsings.cs
@@ -16,6 +16,7 @@
global using Atc.Rest.ApiGenerator.CLI.Extensions;
global using Atc.Rest.ApiGenerator.CodingRules;
global using Atc.Rest.ApiGenerator.Contracts;
+global using Atc.Rest.ApiGenerator.Framework.Extensions;
global using Atc.Rest.ApiGenerator.Framework.Providers;
global using Atc.Rest.ApiGenerator.Framework.Readers;
global using Atc.Rest.ApiGenerator.Helpers;
diff --git a/src/Atc.Rest.ApiGenerator.Client.CSharp/ContentGenerators/ContentGeneratorClientEndpoint.cs b/src/Atc.Rest.ApiGenerator.Client.CSharp/ContentGenerators/ContentGeneratorClientEndpoint.cs
index cf70e95f5..e21058dae 100644
--- a/src/Atc.Rest.ApiGenerator.Client.CSharp/ContentGenerators/ContentGeneratorClientEndpoint.cs
+++ b/src/Atc.Rest.ApiGenerator.Client.CSharp/ContentGenerators/ContentGeneratorClientEndpoint.cs
@@ -41,7 +41,7 @@ public string Generate()
}
sb.AppendLine(codeAttributeGenerator.Generate());
- sb.AppendLine($"public class {parameters.EndpointName} : {parameters.InterfaceName}");
+ sb.AppendLine($"{parameters.DeclarationModifier.GetDescription()} {parameters.EndpointName} : {parameters.InterfaceName}");
sb.AppendLine("{");
sb.AppendLine(4, "private readonly IHttpClientFactory factory;");
sb.AppendLine(4, "private readonly IHttpMessageFactory httpMessageFactory;");
diff --git a/src/Atc.Rest.ApiGenerator.Client.CSharp/ContentGenerators/ContentGeneratorClientEndpointResult.cs b/src/Atc.Rest.ApiGenerator.Client.CSharp/ContentGenerators/ContentGeneratorClientEndpointResult.cs
index cca7359d2..adde55417 100644
--- a/src/Atc.Rest.ApiGenerator.Client.CSharp/ContentGenerators/ContentGeneratorClientEndpointResult.cs
+++ b/src/Atc.Rest.ApiGenerator.Client.CSharp/ContentGenerators/ContentGeneratorClientEndpointResult.cs
@@ -36,7 +36,7 @@ public string Generate()
}
sb.AppendLine(codeAttributeGenerator.Generate());
- sb.AppendLine($"public class {parameters.EndpointResultName} : {parameters.InheritClassName}, {parameters.EndpointResultInterfaceName}");
+ sb.AppendLine($"{parameters.DeclarationModifier.GetDescription()} {parameters.EndpointResultName} : {parameters.InheritClassName}, {parameters.EndpointResultInterfaceName}");
sb.AppendLine("{");
sb.AppendLine(4, $"public {parameters.EndpointResultName}(EndpointResponse response)");
sb.AppendLine(8, ": base(response)");
diff --git a/src/Atc.Rest.ApiGenerator.Client.CSharp/ContentGenerators/ContentGeneratorClientEndpointResultInterface.cs b/src/Atc.Rest.ApiGenerator.Client.CSharp/ContentGenerators/ContentGeneratorClientEndpointResultInterface.cs
index dde620922..8fda829d5 100644
--- a/src/Atc.Rest.ApiGenerator.Client.CSharp/ContentGenerators/ContentGeneratorClientEndpointResultInterface.cs
+++ b/src/Atc.Rest.ApiGenerator.Client.CSharp/ContentGenerators/ContentGeneratorClientEndpointResultInterface.cs
@@ -37,7 +37,7 @@ public string Generate()
}
sb.AppendLine(codeAttributeGenerator.Generate());
- sb.AppendLine($"public interface {parameters.InterfaceName} : {parameters.InheritInterfaceName}");
+ sb.AppendLine($"{parameters.DeclarationModifier.GetDescription()} {parameters.InterfaceName} : {parameters.InheritInterfaceName}");
sb.AppendLine("{");
AppendContent(sb);
sb.Append('}');
diff --git a/src/Atc.Rest.ApiGenerator.Client.CSharp/ContentGenerators/ContentGeneratorClientParameter.cs b/src/Atc.Rest.ApiGenerator.Client.CSharp/ContentGenerators/ContentGeneratorClientParameter.cs
index ffe8c1269..05cdc8a3f 100644
--- a/src/Atc.Rest.ApiGenerator.Client.CSharp/ContentGenerators/ContentGeneratorClientParameter.cs
+++ b/src/Atc.Rest.ApiGenerator.Client.CSharp/ContentGenerators/ContentGeneratorClientParameter.cs
@@ -35,7 +35,7 @@ public string Generate()
}
sb.AppendLine(codeAttributeGenerator.Generate());
- sb.AppendLine($"public class {parameters.ParameterName}");
+ sb.AppendLine($"{parameters.DeclarationModifier.GetDescription()} {parameters.ParameterName}");
sb.AppendLine("{");
foreach (var parameter in parameters.PropertyParameters)
diff --git a/src/Atc.Rest.ApiGenerator.Client.CSharp/GlobalUsings.cs b/src/Atc.Rest.ApiGenerator.Client.CSharp/GlobalUsings.cs
index 3f90ae52b..c3d839ebf 100644
--- a/src/Atc.Rest.ApiGenerator.Client.CSharp/GlobalUsings.cs
+++ b/src/Atc.Rest.ApiGenerator.Client.CSharp/GlobalUsings.cs
@@ -14,10 +14,12 @@
global using Atc.Rest.ApiGenerator.Contracts.Extensions;
global using Atc.Rest.ApiGenerator.Contracts.Models;
global using Atc.Rest.ApiGenerator.Framework.ContentGenerators;
+global using Atc.Rest.ApiGenerator.Framework.Factories;
global using Atc.Rest.ApiGenerator.Framework.Factories.Parameters.Client;
global using Atc.Rest.ApiGenerator.Framework.Factories.Parameters.ServerClient;
global using Atc.Rest.ApiGenerator.Framework.Helpers;
global using Atc.Rest.ApiGenerator.Framework.Providers;
+global using Atc.Rest.ApiGenerator.Framework.Settings;
global using Atc.Rest.ApiGenerator.Framework.Writers;
global using Atc.Rest.ApiGenerator.OpenApi.Extensions;
diff --git a/src/Atc.Rest.ApiGenerator.Client.CSharp/ProjectGenerator/ClientCSharpApiGenerator.cs b/src/Atc.Rest.ApiGenerator.Client.CSharp/ProjectGenerator/ClientCSharpApiGenerator.cs
index 3b7a3ac26..91c45ca92 100644
--- a/src/Atc.Rest.ApiGenerator.Client.CSharp/ProjectGenerator/ClientCSharpApiGenerator.cs
+++ b/src/Atc.Rest.ApiGenerator.Client.CSharp/ProjectGenerator/ClientCSharpApiGenerator.cs
@@ -7,58 +7,42 @@ public class ClientCSharpApiGenerator : IClientCSharpApiGenerator
{
private readonly ILogger logger;
private readonly INugetPackageReferenceProvider nugetPackageReferenceProvider;
- private readonly Version apiGeneratorVersion;
- private readonly string projectName;
- private readonly DirectoryInfo projectPath;
private readonly OpenApiDocument openApiDocument;
private readonly IList operationSchemaMappings;
private readonly string codeGeneratorContentHeader;
private readonly AttributeParameters codeGeneratorAttribute;
- private readonly bool useProblemDetailsAsDefaultResponseBody;
- private readonly bool includeDeprecated;
+ private readonly GeneratorSettings settings;
private readonly CustomErrorResponseModel? customErrorResponseModel;
public ClientCSharpApiGenerator(
ILoggerFactory loggerFactory,
INugetPackageReferenceProvider nugetPackageReferenceProvider,
- Version apiGeneratorVersion,
- string projectName,
- DirectoryInfo projectPath,
OpenApiDocument openApiDocument,
IList operationSchemaMappings,
- bool useProblemDetailsAsDefaultResponseBody,
- bool includeDeprecated,
+ GeneratorSettings generatorSettings,
CustomErrorResponseModel? customErrorResponseModel)
{
ArgumentNullException.ThrowIfNull(loggerFactory);
ArgumentNullException.ThrowIfNull(nugetPackageReferenceProvider);
- ArgumentNullException.ThrowIfNull(apiGeneratorVersion);
- ArgumentNullException.ThrowIfNull(projectName);
- ArgumentNullException.ThrowIfNull(projectPath);
ArgumentNullException.ThrowIfNull(openApiDocument);
ArgumentNullException.ThrowIfNull(operationSchemaMappings);
+ ArgumentNullException.ThrowIfNull(generatorSettings);
logger = loggerFactory.CreateLogger();
this.nugetPackageReferenceProvider = nugetPackageReferenceProvider;
- this.apiGeneratorVersion = apiGeneratorVersion;
- this.projectName = projectName;
- this.projectPath = projectPath;
this.customErrorResponseModel = customErrorResponseModel;
this.openApiDocument = openApiDocument;
this.operationSchemaMappings = operationSchemaMappings;
- this.useProblemDetailsAsDefaultResponseBody = useProblemDetailsAsDefaultResponseBody;
- this.includeDeprecated = includeDeprecated;
+ settings = generatorSettings;
codeGeneratorContentHeader = GeneratedCodeHeaderGeneratorFactory
- .Create(apiGeneratorVersion)
+ .Create(settings.Version)
.Generate();
codeGeneratorAttribute = AttributeParametersFactory
- .CreateGeneratedCode(apiGeneratorVersion);
+ .CreateGeneratedCode(settings.Version);
}
- public string? ClientFolderName { get; set; }
-
- public string HttpClientName { get; set; } = "DefaultHttpClient";
+ public string HttpClientName { get; set; } = ContentGeneratorConstants.DefaultHttpClient;
public async Task ScaffoldProjectFile()
{
@@ -86,7 +70,7 @@ public async Task ScaffoldProjectFile()
new("GenerateDocumentationFile", Attributes: null, "true"),
],
[
- new("DocumentationFile", Attributes: null, @$"bin\Debug\net8.0\{projectName}.xml"),
+ new("DocumentationFile", Attributes: null, @$"bin\Debug\net8.0\{settings.ProjectName}.xml"),
new("NoWarn", Attributes: null, "$(NoWarn);1573;1591;1701;1702;1712;8618;"),
],
],
@@ -101,8 +85,8 @@ public async Task ScaffoldProjectFile()
var contentWriter = new ContentWriter(logger);
contentWriter.Write(
- projectPath,
- projectPath.CombineFileInfo($"{projectName}.csproj"),
+ settings.ProjectPath,
+ FileInfoFactory.Create(settings.ProjectPath, $"{settings.ProjectName}.csproj"),
ContentWriterArea.Src,
content,
overrideIfExist: false);
@@ -144,13 +128,13 @@ public void GenerateParameters()
{
var apiGroupName = openApiPath.GetApiGroupName();
- var fullNamespace = string.IsNullOrEmpty(ClientFolderName)
- ? $"{projectName}.{ContentGeneratorConstants.Contracts}.{apiGroupName}"
- : $"{projectName}.{ClientFolderName}.{ContentGeneratorConstants.Contracts}.{apiGroupName}";
+ var contractsLocation = LocationFactory.CreateWithApiGroupName(apiGroupName, settings.ContractsLocation);
+
+ var fullNamespace = NamespaceFactory.Create(settings.ProjectName, contractsLocation);
foreach (var openApiOperation in openApiPath.Value.Operations)
{
- if (openApiOperation.Value.Deprecated && !includeDeprecated)
+ if (openApiOperation.Value.Deprecated && !settings.IncludeDeprecatedOperations)
{
continue;
}
@@ -167,8 +151,8 @@ public void GenerateParameters()
openApiPath.Value.Parameters);
var contentGenerator = new ContentGeneratorClientParameter(
- new GeneratedCodeHeaderGenerator(new GeneratedCodeGeneratorParameters(apiGeneratorVersion)),
- new GeneratedCodeAttributeGenerator(new GeneratedCodeGeneratorParameters(apiGeneratorVersion)),
+ new GeneratedCodeHeaderGenerator(new GeneratedCodeGeneratorParameters(settings.Version)),
+ new GeneratedCodeAttributeGenerator(new GeneratedCodeGeneratorParameters(settings.Version)),
new CodeDocumentationTagsGenerator(),
parameterParameters);
@@ -176,8 +160,8 @@ public void GenerateParameters()
var contentWriter = new ContentWriter(logger);
contentWriter.Write(
- projectPath,
- projectPath.CombineFileInfo(ContentGeneratorConstants.Contracts, apiGroupName, ContentGeneratorConstants.RequestParameters, $"{parameterParameters.ParameterName}.cs"),
+ settings.ProjectPath,
+ FileInfoFactory.Create(settings.ProjectPath, contractsLocation, ContentGeneratorConstants.RequestParameters, $"{parameterParameters.ParameterName}.cs"),
ContentWriterArea.Src,
content);
}
@@ -190,13 +174,13 @@ public void GenerateEndpointInterfaces()
{
var apiGroupName = openApiPath.GetApiGroupName();
- var fullNamespace = string.IsNullOrEmpty(ClientFolderName)
- ? $"{projectName}.{ContentGeneratorConstants.Endpoints}.{apiGroupName}.{ContentGeneratorConstants.Interfaces}"
- : $"{projectName}.{ClientFolderName}.{ContentGeneratorConstants.Endpoints}.{apiGroupName}.{ContentGeneratorConstants.Interfaces}";
+ var endpointsLocation = LocationFactory.CreateWithApiGroupName(apiGroupName, settings.EndpointsLocation);
+
+ var fullNamespace = NamespaceFactory.Create(settings.ProjectName, endpointsLocation) + $".{ContentGeneratorConstants.Interfaces}";
foreach (var openApiOperation in openApiPath.Value.Operations)
{
- if (openApiOperation.Value.Deprecated && !includeDeprecated)
+ if (openApiOperation.Value.Deprecated && !settings.IncludeDeprecatedOperations)
{
continue;
}
@@ -207,7 +191,8 @@ public void GenerateEndpointInterfaces()
codeGeneratorAttribute,
openApiPath.Value,
openApiOperation.Value,
- HttpClientName);
+ HttpClientName,
+ settings.UsePartialClassForEndpoints);
var contentGenerator = new GenerateContentForInterface(
new CodeDocumentationTagsGenerator(),
@@ -217,8 +202,8 @@ public void GenerateEndpointInterfaces()
var contentWriter = new ContentWriter(logger);
contentWriter.Write(
- projectPath,
- projectPath.CombineFileInfo(ContentGeneratorConstants.Endpoints, apiGroupName, ContentGeneratorConstants.Interfaces, $"{interfaceParameters.TypeName}.cs"),
+ settings.ProjectPath,
+ FileInfoFactory.Create(settings.ProjectPath, endpointsLocation, ContentGeneratorConstants.Interfaces, $"{interfaceParameters.TypeName}.cs"),
ContentWriterArea.Src,
content);
}
@@ -231,41 +216,44 @@ public void GenerateEndpoints()
{
var apiGroupName = openApiPath.GetApiGroupName();
- var fullNamespace = string.IsNullOrEmpty(ClientFolderName)
- ? $"{projectName}.{ContentGeneratorConstants.Endpoints}.{apiGroupName}"
- : $"{projectName}.{ClientFolderName}.{ContentGeneratorConstants.Endpoints}.{apiGroupName}";
+ var endpointsLocation = LocationFactory.CreateWithApiGroupName(apiGroupName, settings.EndpointsLocation);
+ var contractsLocation = LocationFactory.CreateWithApiGroupName(apiGroupName, settings.ContractsLocation);
+
+ var fullNamespace = NamespaceFactory.Create(settings.ProjectName, endpointsLocation);
foreach (var openApiOperation in openApiPath.Value.Operations)
{
- if (openApiOperation.Value.Deprecated && !includeDeprecated)
+ if (openApiOperation.Value.Deprecated && !settings.IncludeDeprecatedOperations)
{
continue;
}
var endpointParameters = ContentGeneratorClientEndpointParametersFactory.Create(
- projectName,
+ settings.ProjectName,
apiGroupName,
fullNamespace,
+ contractsLocation,
openApiPath.Value,
openApiOperation.Key,
openApiOperation.Value,
HttpClientName,
- $"{openApiDocument.GetServerUrlBasePath()}{openApiPath.Key}");
+ $"{openApiDocument.GetServerUrlBasePath()}{openApiPath.Key}",
+ settings.UsePartialClassForEndpoints);
var contentGenerator = new ContentGeneratorClientEndpoint(
- new GeneratedCodeHeaderGenerator(new GeneratedCodeGeneratorParameters(apiGeneratorVersion)),
- new GeneratedCodeAttributeGenerator(new GeneratedCodeGeneratorParameters(apiGeneratorVersion)),
+ new GeneratedCodeHeaderGenerator(new GeneratedCodeGeneratorParameters(settings.Version)),
+ new GeneratedCodeAttributeGenerator(new GeneratedCodeGeneratorParameters(settings.Version)),
new CodeDocumentationTagsGenerator(),
endpointParameters,
- useProblemDetailsAsDefaultResponseBody,
+ settings.UseProblemDetailsAsDefaultResponseBody,
customErrorResponseModel?.Name);
var content = contentGenerator.Generate();
var contentWriter = new ContentWriter(logger);
contentWriter.Write(
- projectPath,
- projectPath.CombineFileInfo(ContentGeneratorConstants.Endpoints, apiGroupName, $"{endpointParameters.EndpointName}.cs"),
+ settings.ProjectPath,
+ FileInfoFactory.Create(settings.ProjectPath, endpointsLocation, $"{endpointParameters.EndpointName}.cs"),
ContentWriterArea.Src,
content);
}
@@ -278,37 +266,40 @@ public void GenerateEndpointResultInterfaces()
{
var apiGroupName = openApiPath.GetApiGroupName();
- var fullNamespace = string.IsNullOrEmpty(ClientFolderName)
- ? $"{projectName}.{ContentGeneratorConstants.Endpoints}.{apiGroupName}.{ContentGeneratorConstants.Interfaces}"
- : $"{projectName}.{ClientFolderName}.{ContentGeneratorConstants.Endpoints}.{apiGroupName}.{ContentGeneratorConstants.Interfaces}";
+ var endpointsLocation = LocationFactory.CreateWithApiGroupName(apiGroupName, settings.EndpointsLocation);
+ var contractsLocation = LocationFactory.CreateWithApiGroupName(apiGroupName, settings.ContractsLocation);
+
+ var fullNamespace = NamespaceFactory.Create(settings.ProjectName, endpointsLocation) + $".{ContentGeneratorConstants.Interfaces}";
foreach (var openApiOperation in openApiPath.Value.Operations)
{
- if (openApiOperation.Value.Deprecated && !includeDeprecated)
+ if (openApiOperation.Value.Deprecated && !settings.IncludeDeprecatedOperations)
{
continue;
}
var endpointResultInterfaceParameters = ContentGeneratorClientEndpointResultInterfaceParametersFactory.Create(
- projectName,
+ settings.ProjectName,
apiGroupName,
fullNamespace,
+ contractsLocation,
openApiPath.Value,
- openApiOperation.Value);
+ openApiOperation.Value,
+ settings.UsePartialClassForContracts);
var contentGenerator = new ContentGeneratorClientEndpointResultInterface(
- new GeneratedCodeHeaderGenerator(new GeneratedCodeGeneratorParameters(apiGeneratorVersion)),
- new GeneratedCodeAttributeGenerator(new GeneratedCodeGeneratorParameters(apiGeneratorVersion)),
+ new GeneratedCodeHeaderGenerator(new GeneratedCodeGeneratorParameters(settings.Version)),
+ new GeneratedCodeAttributeGenerator(new GeneratedCodeGeneratorParameters(settings.Version)),
new CodeDocumentationTagsGenerator(),
endpointResultInterfaceParameters,
- useProblemDetailsAsDefaultResponseBody);
+ settings.UseProblemDetailsAsDefaultResponseBody);
var content = contentGenerator.Generate();
var contentWriter = new ContentWriter(logger);
contentWriter.Write(
- projectPath,
- projectPath.CombineFileInfo(ContentGeneratorConstants.Endpoints, apiGroupName, ContentGeneratorConstants.Interfaces, $"{endpointResultInterfaceParameters.InterfaceName}.cs"),
+ settings.ProjectPath,
+ FileInfoFactory.Create(settings.ProjectPath, endpointsLocation, ContentGeneratorConstants.Interfaces, $"{endpointResultInterfaceParameters.InterfaceName}.cs"),
ContentWriterArea.Src,
content);
}
@@ -321,37 +312,40 @@ public void GenerateEndpointResults()
{
var apiGroupName = openApiPath.GetApiGroupName();
- var fullNamespace = string.IsNullOrEmpty(ClientFolderName)
- ? $"{projectName}.{ContentGeneratorConstants.Endpoints}.{apiGroupName}"
- : $"{projectName}.{ClientFolderName}.{ContentGeneratorConstants.Endpoints}.{apiGroupName}";
+ var endpointsLocation = LocationFactory.CreateWithApiGroupName(apiGroupName, settings.EndpointsLocation);
+ var contractsLocation = LocationFactory.CreateWithApiGroupName(apiGroupName, settings.ContractsLocation);
+
+ var fullNamespace = NamespaceFactory.Create(settings.ProjectName, endpointsLocation);
foreach (var openApiOperation in openApiPath.Value.Operations)
{
- if (openApiOperation.Value.Deprecated && !includeDeprecated)
+ if (openApiOperation.Value.Deprecated && !settings.IncludeDeprecatedOperations)
{
continue;
}
var endpointResultParameters = ContentGeneratorClientEndpointResultParametersFactory.Create(
- projectName,
+ settings.ProjectName,
apiGroupName,
fullNamespace,
+ contractsLocation,
openApiPath.Value,
- openApiOperation.Value);
+ openApiOperation.Value,
+ settings.UsePartialClassForContracts);
var contentGenerator = new ContentGeneratorClientEndpointResult(
- new GeneratedCodeHeaderGenerator(new GeneratedCodeGeneratorParameters(apiGeneratorVersion)),
- new GeneratedCodeAttributeGenerator(new GeneratedCodeGeneratorParameters(apiGeneratorVersion)),
+ new GeneratedCodeHeaderGenerator(new GeneratedCodeGeneratorParameters(settings.Version)),
+ new GeneratedCodeAttributeGenerator(new GeneratedCodeGeneratorParameters(settings.Version)),
new CodeDocumentationTagsGenerator(),
endpointResultParameters,
- useProblemDetailsAsDefaultResponseBody);
+ settings.UseProblemDetailsAsDefaultResponseBody);
var content = contentGenerator.Generate();
var contentWriter = new ContentWriter(logger);
contentWriter.Write(
- projectPath,
- projectPath.CombineFileInfo(ContentGeneratorConstants.Endpoints, apiGroupName, $"{endpointResultParameters.EndpointResultName}.cs"),
+ settings.ProjectPath,
+ FileInfoFactory.Create(settings.ProjectPath, endpointsLocation, $"{endpointResultParameters.EndpointResultName}.cs"),
ContentWriterArea.Src,
content);
}
@@ -375,17 +369,17 @@ public void MaintainGlobalUsings(
"Microsoft.AspNetCore.Mvc",
};
- if (openApiDocument.IsUsingRequiredForSystemLinq(includeDeprecated))
+ if (openApiDocument.IsUsingRequiredForSystemLinq(settings.IncludeDeprecatedOperations))
{
requiredUsings.Add("System.Linq");
}
- if (openApiDocument.IsUsingRequiredForSystemCollectionGeneric(includeDeprecated))
+ if (openApiDocument.IsUsingRequiredForSystemCollectionGeneric(settings.IncludeDeprecatedOperations))
{
requiredUsings.Add("System.Collections.Generic");
}
- if (openApiDocument.IsUsingRequiredForSystemTextJsonSerializationAndSystemRuntimeSerialization(includeDeprecated))
+ if (openApiDocument.IsUsingRequiredForSystemTextJsonSerializationAndSystemRuntimeSerialization(settings.IncludeDeprecatedOperations))
{
requiredUsings.Add("System.Runtime.Serialization");
requiredUsings.Add("System.Text.Json.Serialization");
@@ -403,16 +397,19 @@ public void MaintainGlobalUsings(
if (operationSchemaMappings.Any(apiOperation => apiOperation.Model.IsShared))
{
- requiredUsings.Add($"{projectName}.{ContentGeneratorConstants.Contracts}");
+ requiredUsings.Add(NamespaceFactory.Create(settings.ProjectName, LocationFactory.CreateWithoutTemplateForApiGroupName(settings.ContractsLocation)));
}
var apiGroupNames = openApiDocument.GetApiGroupNames();
foreach (var openApiPath in openApiDocument.Paths)
{
var apiGroupName = openApiPath.GetApiGroupName();
+
+ var contractsLocation = LocationFactory.CreateWithApiGroupName(apiGroupName, settings.ContractsLocation);
+
foreach (var openApiOperation in openApiPath.Value.Operations)
{
- if (openApiOperation.Value.Deprecated && !includeDeprecated)
+ if (openApiOperation.Value.Deprecated && !settings.IncludeDeprecatedOperations)
{
continue;
}
@@ -423,7 +420,7 @@ public void MaintainGlobalUsings(
continue;
}
- var requiredUsing = $"{projectName}.{ContentGeneratorConstants.Contracts}.{apiGroupName}";
+ var requiredUsing = NamespaceFactory.Create(settings.ProjectName, contractsLocation);
if (!requiredUsings.Contains(requiredUsing, StringComparer.CurrentCulture))
{
requiredUsings.Add(requiredUsing);
@@ -439,6 +436,8 @@ public void MaintainGlobalUsings(
var apiOperationModels = GetDistinctApiOperationModels(apiOperations);
+ var contractsLocation = LocationFactory.CreateWithApiGroupName(apiGroupName, settings.ContractsLocation);
+
foreach (var apiOperationModel in apiOperationModels)
{
if (apiOperationModel.IsEnum ||
@@ -447,7 +446,12 @@ public void MaintainGlobalUsings(
continue;
}
- var requiredUsing = $"{projectName}.{ContentGeneratorConstants.Contracts}.{apiGroupName}";
+ if (apiGroupName.IsWellKnownSystemTypeName())
+ {
+ continue;
+ }
+
+ var requiredUsing = NamespaceFactory.Create(settings.ProjectName, contractsLocation);
if (!requiredUsings.Contains(requiredUsing, StringComparer.CurrentCulture))
{
requiredUsings.Add(requiredUsing);
@@ -455,12 +459,12 @@ public void MaintainGlobalUsings(
}
}
- requiredUsings.AddRange(apiGroupNames.Select(x => $"{projectName}.{ContentGeneratorConstants.Endpoints}.{x}.{ContentGeneratorConstants.Interfaces}"));
+ requiredUsings.AddRange(apiGroupNames.Select(x => NamespaceFactory.Create(settings.ProjectName, LocationFactory.CreateWithApiGroupName(x, settings.EndpointsLocation), ContentGeneratorConstants.Interfaces)));
GlobalUsingsHelper.CreateOrUpdate(
logger,
ContentWriterArea.Src,
- projectPath,
+ settings.ProjectPath,
requiredUsings,
removeNamespaceGroupSeparatorInGlobalUsings);
}
@@ -469,7 +473,9 @@ private void GenerateEnumerationType(
string enumerationName,
OpenApiSchema openApiSchemaEnumeration)
{
- var fullNamespace = $"{projectName}.{ContentGeneratorConstants.Contracts}";
+ var contractsLocation = LocationFactory.CreateWithoutTemplateForApiGroupName(settings.ContractsLocation);
+
+ var fullNamespace = NamespaceFactory.Create(settings.ProjectName, contractsLocation);
var enumParameters = ContentGeneratorServerClientEnumParametersFactory.Create(
codeGeneratorContentHeader,
@@ -486,8 +492,8 @@ private void GenerateEnumerationType(
var contentWriter = new ContentWriter(logger);
contentWriter.Write(
- projectPath,
- projectPath.CombineFileInfo(ContentGeneratorConstants.Contracts, ContentGeneratorConstants.SpecialFolderEnumerationTypes, $"{enumerationName}.cs"),
+ settings.ProjectPath,
+ FileInfoFactory.Create(settings.ProjectPath, contractsLocation, ContentGeneratorConstants.SpecialFolderEnumerationTypes, $"{enumerationName}.cs"),
ContentWriterArea.Src,
content);
}
@@ -498,9 +504,11 @@ private void GenerateModel(
string apiGroupName,
bool isSharedContract)
{
- var fullNamespace = isSharedContract
- ? $"{projectName}.{ContentGeneratorConstants.Contracts}"
- : $"{projectName}.{ContentGeneratorConstants.Contracts}.{apiGroupName}";
+ var contractsLocation = isSharedContract
+ ? LocationFactory.CreateWithoutTemplateForApiGroupName(settings.ContractsLocation)
+ : LocationFactory.CreateWithApiGroupName(apiGroupName, settings.ContractsLocation);
+
+ var fullNamespace = NamespaceFactory.Create(settings.ProjectName, contractsLocation);
var parameters = ContentGeneratorServerClientModelParametersFactory.CreateForClass(
codeGeneratorContentHeader,
@@ -508,7 +516,8 @@ private void GenerateModel(
codeGeneratorAttribute,
modelName,
apiSchemaModel,
- includeDeprecated);
+ settings.UsePartialClassForContracts,
+ settings.IncludeDeprecatedOperations);
var contentGeneratorClass = new GenerateContentForClass(
new CodeDocumentationTagsGenerator(),
@@ -518,10 +527,10 @@ private void GenerateModel(
var contentWriter = new ContentWriter(logger);
contentWriter.Write(
- projectPath,
+ settings.ProjectPath,
isSharedContract
- ? projectPath.CombineFileInfo(ContentGeneratorConstants.Contracts, ContentGeneratorConstants.SpecialFolderSharedModels, $"{modelName}.cs")
- : projectPath.CombineFileInfo(ContentGeneratorConstants.Contracts, apiGroupName, $"{modelName}.cs"),
+ ? FileInfoFactory.Create(settings.ProjectPath, contractsLocation, ContentGeneratorConstants.SpecialFolderSharedModels, $"{modelName}.cs")
+ : FileInfoFactory.Create(settings.ProjectPath, contractsLocation, $"{modelName}.cs"),
ContentWriterArea.Src,
content);
}
@@ -534,13 +543,16 @@ private void GenerateCustomErrorResponseModel()
return;
}
- var fullNamespace = $"{projectName}.{ContentGeneratorConstants.Contracts}";
+ var contractsLocation = LocationFactory.CreateWithoutTemplateForApiGroupName(settings.ContractsLocation);
+
+ var fullNamespace = NamespaceFactory.Create(settings.ProjectName, contractsLocation);
var parameters = ContentGeneratorServerClientModelParametersFactory.CreateForCustomErrorResponseModel(
codeGeneratorContentHeader,
fullNamespace,
codeGeneratorAttribute,
- customErrorResponseModel);
+ customErrorResponseModel,
+ settings.UsePartialClassForContracts);
var contentGeneratorClass = new GenerateContentForClass(
new CodeDocumentationTagsGenerator(),
@@ -550,8 +562,8 @@ private void GenerateCustomErrorResponseModel()
var contentWriter = new ContentWriter(logger);
contentWriter.Write(
- projectPath,
- projectPath.CombineFileInfo(ContentGeneratorConstants.Contracts, ContentGeneratorConstants.SpecialFolderSharedModels, $"{customErrorResponseModel.Name.EnsureFirstCharacterToUpper()}.cs"),
+ settings.ProjectPath,
+ FileInfoFactory.Create(settings.ProjectPath, contractsLocation, ContentGeneratorConstants.SpecialFolderSharedModels, $"{customErrorResponseModel.Name.EnsureFirstCharacterToUpper()}.cs"),
ContentWriterArea.Src,
content);
}
diff --git a/src/Atc.Rest.ApiGenerator.Client.CSharp/ProjectGenerator/IClientCSharpApiGenerator.cs b/src/Atc.Rest.ApiGenerator.Client.CSharp/ProjectGenerator/IClientCSharpApiGenerator.cs
index c18a961c1..84ffac5a6 100644
--- a/src/Atc.Rest.ApiGenerator.Client.CSharp/ProjectGenerator/IClientCSharpApiGenerator.cs
+++ b/src/Atc.Rest.ApiGenerator.Client.CSharp/ProjectGenerator/IClientCSharpApiGenerator.cs
@@ -11,8 +11,6 @@ namespace Atc.Rest.ApiGenerator.Client.CSharp.ProjectGenerator;
///
public interface IClientCSharpApiGenerator
{
- string? ClientFolderName { get; set; }
-
string HttpClientName { get; set; }
Task ScaffoldProjectFile();
diff --git a/src/Atc.Rest.ApiGenerator.Contracts/Atc.Rest.ApiGenerator.Contracts.csproj b/src/Atc.Rest.ApiGenerator.Contracts/Atc.Rest.ApiGenerator.Contracts.csproj
index 92a0a1a34..1d1e14174 100644
--- a/src/Atc.Rest.ApiGenerator.Contracts/Atc.Rest.ApiGenerator.Contracts.csproj
+++ b/src/Atc.Rest.ApiGenerator.Contracts/Atc.Rest.ApiGenerator.Contracts.csproj
@@ -10,4 +10,8 @@
+
+
+
+
diff --git a/src/Atc.Rest.ApiGenerator.Contracts/ContentGeneratorConstants.cs b/src/Atc.Rest.ApiGenerator.Contracts/ContentGeneratorConstants.cs
index 4a1a4e04d..33e1006e8 100644
--- a/src/Atc.Rest.ApiGenerator.Contracts/ContentGeneratorConstants.cs
+++ b/src/Atc.Rest.ApiGenerator.Contracts/ContentGeneratorConstants.cs
@@ -25,4 +25,8 @@ public static class ContentGeneratorConstants
public const string SpecialFolderSharedModels = "_Shared";
public const string Tests = "Tests";
public const string UndefinedDescription = "Undefined description.";
+ public const string DefaultHttpClientName = "ApiClient";
+ public const string DefaultHttpClient = "DefaultHttpClient";
+ public const string TemplateKeyForApiGroupName = "apiGroupName";
+ public const string TemplateForApiGroupName = "[[apiGroupName]]";
}
\ No newline at end of file
diff --git a/src/Atc.Rest.ApiGenerator.Contracts/ContentGeneratorsParameters/Client/ContentGeneratorClientEndpointParameters.cs b/src/Atc.Rest.ApiGenerator.Contracts/ContentGeneratorsParameters/Client/ContentGeneratorClientEndpointParameters.cs
index 9dce80986..90eaa45ab 100644
--- a/src/Atc.Rest.ApiGenerator.Contracts/ContentGeneratorsParameters/Client/ContentGeneratorClientEndpointParameters.cs
+++ b/src/Atc.Rest.ApiGenerator.Contracts/ContentGeneratorsParameters/Client/ContentGeneratorClientEndpointParameters.cs
@@ -7,6 +7,7 @@ public record ContentGeneratorClientEndpointParameters(
CodeDocumentationTags DocumentationTags,
string HttpClientName,
string UrlPath,
+ DeclarationModifiers DeclarationModifier,
string EndpointName,
string InterfaceName,
string ResultName,
diff --git a/src/Atc.Rest.ApiGenerator.Contracts/ContentGeneratorsParameters/Client/ContentGeneratorClientEndpointResultInterfaceParameters.cs b/src/Atc.Rest.ApiGenerator.Contracts/ContentGeneratorsParameters/Client/ContentGeneratorClientEndpointResultInterfaceParameters.cs
index 20417901e..44449ae9b 100644
--- a/src/Atc.Rest.ApiGenerator.Contracts/ContentGeneratorsParameters/Client/ContentGeneratorClientEndpointResultInterfaceParameters.cs
+++ b/src/Atc.Rest.ApiGenerator.Contracts/ContentGeneratorsParameters/Client/ContentGeneratorClientEndpointResultInterfaceParameters.cs
@@ -4,6 +4,7 @@ public record ContentGeneratorClientEndpointResultInterfaceParameters(
string Namespace,
string OperationName,
CodeDocumentationTags DocumentationTags,
+ DeclarationModifiers DeclarationModifier,
string InterfaceName,
string InheritInterfaceName,
bool HasParameterType,
diff --git a/src/Atc.Rest.ApiGenerator.Contracts/ContentGeneratorsParameters/Client/ContentGeneratorClientEndpointResultParameters.cs b/src/Atc.Rest.ApiGenerator.Contracts/ContentGeneratorsParameters/Client/ContentGeneratorClientEndpointResultParameters.cs
index 420804b99..204c5f664 100644
--- a/src/Atc.Rest.ApiGenerator.Contracts/ContentGeneratorsParameters/Client/ContentGeneratorClientEndpointResultParameters.cs
+++ b/src/Atc.Rest.ApiGenerator.Contracts/ContentGeneratorsParameters/Client/ContentGeneratorClientEndpointResultParameters.cs
@@ -4,6 +4,7 @@ public record ContentGeneratorClientEndpointResultParameters(
string Namespace,
string OperationName,
CodeDocumentationTags DocumentationTags,
+ DeclarationModifiers DeclarationModifier,
string EndpointResultName,
string EndpointResultInterfaceName,
string InheritClassName,
diff --git a/src/Atc.Rest.ApiGenerator.Contracts/ContentGeneratorsParameters/Client/ContentGeneratorClientParameterParameters.cs b/src/Atc.Rest.ApiGenerator.Contracts/ContentGeneratorsParameters/Client/ContentGeneratorClientParameterParameters.cs
index 103de5ad5..4be295271 100644
--- a/src/Atc.Rest.ApiGenerator.Contracts/ContentGeneratorsParameters/Client/ContentGeneratorClientParameterParameters.cs
+++ b/src/Atc.Rest.ApiGenerator.Contracts/ContentGeneratorsParameters/Client/ContentGeneratorClientParameterParameters.cs
@@ -4,6 +4,7 @@ public record ContentGeneratorClientParameterParameters(
string Namespace,
string OperationName,
CodeDocumentationTags DocumentationTags,
+ DeclarationModifiers DeclarationModifier,
string ParameterName,
IList PropertyParameters);
diff --git a/src/Atc.Rest.ApiGenerator.Contracts/ContentGeneratorsParameters/Server/ContentGeneratorServerParameterParameters.cs b/src/Atc.Rest.ApiGenerator.Contracts/ContentGeneratorsParameters/Server/ContentGeneratorServerParameterParameters.cs
index d2d6f05b6..f89e2491f 100644
--- a/src/Atc.Rest.ApiGenerator.Contracts/ContentGeneratorsParameters/Server/ContentGeneratorServerParameterParameters.cs
+++ b/src/Atc.Rest.ApiGenerator.Contracts/ContentGeneratorsParameters/Server/ContentGeneratorServerParameterParameters.cs
@@ -4,6 +4,7 @@ public record ContentGeneratorServerParameterParameters(
string Namespace,
string OperationName,
CodeDocumentationTags DocumentationTags,
+ DeclarationModifiers DeclarationModifier,
string ParameterName,
IList PropertyParameters);
diff --git a/src/Atc.Rest.ApiGenerator.Contracts/ContentGeneratorsParameters/Server/ContentGeneratorServerResultParameters.cs b/src/Atc.Rest.ApiGenerator.Contracts/ContentGeneratorsParameters/Server/ContentGeneratorServerResultParameters.cs
index c6dac7060..fa91840b6 100644
--- a/src/Atc.Rest.ApiGenerator.Contracts/ContentGeneratorsParameters/Server/ContentGeneratorServerResultParameters.cs
+++ b/src/Atc.Rest.ApiGenerator.Contracts/ContentGeneratorsParameters/Server/ContentGeneratorServerResultParameters.cs
@@ -4,6 +4,7 @@ public record ContentGeneratorServerResultParameters(
string Namespace,
string OperationName,
CodeDocumentationTags DocumentationTags,
+ DeclarationModifiers DeclarationModifier,
string ResultName,
IList MethodParameters,
ContentGeneratorServerResultImplicitOperatorParameters? ImplicitOperatorParameters);
diff --git a/src/Atc.Rest.ApiGenerator.Contracts/Extensions/ApiOperationResponseModelExtensions.cs b/src/Atc.Rest.ApiGenerator.Contracts/Extensions/ApiOperationResponseModelExtensions.cs
index 53eb66dc2..d63dab547 100644
--- a/src/Atc.Rest.ApiGenerator.Contracts/Extensions/ApiOperationResponseModelExtensions.cs
+++ b/src/Atc.Rest.ApiGenerator.Contracts/Extensions/ApiOperationResponseModelExtensions.cs
@@ -167,7 +167,7 @@ public static IEnumerable AdjustNamespacesIfNeeded(
foreach (var model in responseModels)
{
if (model.DataType is not null &&
- IsWellKnownSystemTypeName(model.DataType))
+ model.DataType.IsWellKnownSystemTypeName())
{
var operationSchemaMapping = operationSchemaMappings.First(x => x.Model.Name == model.DataType);
if (operationSchemaMapping.Model.IsShared)
@@ -195,11 +195,4 @@ model with
return models;
}
-
- private static bool IsWellKnownSystemTypeName(
- string value)
- => value.EndsWith("Task", StringComparison.Ordinal) ||
- value.EndsWith("Tasks", StringComparison.Ordinal) ||
- value.EndsWith("Endpoint", StringComparison.Ordinal) ||
- value.EndsWith("EventArgs", StringComparison.Ordinal);
}
\ No newline at end of file
diff --git a/src/Atc.Rest.ApiGenerator.Contracts/Extensions/StringExtensions.cs b/src/Atc.Rest.ApiGenerator.Contracts/Extensions/StringExtensions.cs
new file mode 100644
index 000000000..762da1462
--- /dev/null
+++ b/src/Atc.Rest.ApiGenerator.Contracts/Extensions/StringExtensions.cs
@@ -0,0 +1,12 @@
+namespace Atc.Rest.ApiGenerator.Contracts.Extensions;
+
+public static class StringExtensions
+{
+ public static bool IsWellKnownSystemTypeName(
+ this string value)
+ => value is not null &&
+ (value.EndsWith("Task", StringComparison.Ordinal) ||
+ value.EndsWith("Tasks", StringComparison.Ordinal) ||
+ value.EndsWith("Endpoint", StringComparison.Ordinal) ||
+ value.EndsWith("EventArgs", StringComparison.Ordinal));
+}
\ No newline at end of file
diff --git a/src/Atc.Rest.ApiGenerator.Contracts/GlobalUsings.cs b/src/Atc.Rest.ApiGenerator.Contracts/GlobalUsings.cs
index d23fac09f..422c9a275 100644
--- a/src/Atc.Rest.ApiGenerator.Contracts/GlobalUsings.cs
+++ b/src/Atc.Rest.ApiGenerator.Contracts/GlobalUsings.cs
@@ -3,4 +3,5 @@
global using System.Net;
global using Atc.CodeDocumentation.CodeComment;
+global using Atc.CodeGeneration.CSharp.Content;
global using Atc.Rest.ApiGenerator.Contracts.Models;
\ No newline at end of file
diff --git a/src/Atc.Rest.ApiGenerator.Framework.Minimal/ContentGenerators/ContentGeneratorServerEndpoints.cs b/src/Atc.Rest.ApiGenerator.Framework.Minimal/ContentGenerators/ContentGeneratorServerEndpoints.cs
index efb74b77d..015615f9d 100644
--- a/src/Atc.Rest.ApiGenerator.Framework.Minimal/ContentGenerators/ContentGeneratorServerEndpoints.cs
+++ b/src/Atc.Rest.ApiGenerator.Framework.Minimal/ContentGenerators/ContentGeneratorServerEndpoints.cs
@@ -37,7 +37,7 @@ public string Generate()
sb.AppendLine(codeAttributeGenerator.Generate());
- sb.AppendLine($"public sealed class {parameters.ApiGroupName}EndpointDefinition : IEndpointDefinition");
+ sb.AppendLine($"{parameters.DeclarationModifier.GetDescription()} {parameters.ApiGroupName}EndpointDefinition : IEndpointDefinition");
sb.AppendLine("{");
AppendContent(sb);
sb.Append('}');
diff --git a/src/Atc.Rest.ApiGenerator.Framework.Minimal/ContentGenerators/ContentGeneratorServerResult.cs b/src/Atc.Rest.ApiGenerator.Framework.Minimal/ContentGenerators/ContentGeneratorServerResult.cs
index ee471dd42..99421df34 100644
--- a/src/Atc.Rest.ApiGenerator.Framework.Minimal/ContentGenerators/ContentGeneratorServerResult.cs
+++ b/src/Atc.Rest.ApiGenerator.Framework.Minimal/ContentGenerators/ContentGeneratorServerResult.cs
@@ -35,7 +35,7 @@ public string Generate()
}
sb.AppendLine(codeAttributeGenerator.Generate());
- sb.AppendLine($"public class {parameters.ResultName}");
+ sb.AppendLine($"{parameters.DeclarationModifier.GetDescription()} {parameters.ResultName}");
sb.AppendLine("{");
sb.AppendLine(4, $"private {parameters.ResultName}(IResult result)");
sb.AppendLine(4, "{");
diff --git a/src/Atc.Rest.ApiGenerator.Framework.Minimal/Factories/ContentGeneratorServerHandlerInterfaceParametersFactory.cs b/src/Atc.Rest.ApiGenerator.Framework.Minimal/Factories/ContentGeneratorServerHandlerInterfaceParametersFactory.cs
index 93316a3d6..96dcf3ae3 100644
--- a/src/Atc.Rest.ApiGenerator.Framework.Minimal/Factories/ContentGeneratorServerHandlerInterfaceParametersFactory.cs
+++ b/src/Atc.Rest.ApiGenerator.Framework.Minimal/Factories/ContentGeneratorServerHandlerInterfaceParametersFactory.cs
@@ -57,7 +57,7 @@ public static InterfaceParameters Create(
exceptions: null,
@return: null),
Attributes: null,
- AccessModifier: AccessModifiers.None,
+ DeclarationModifier: DeclarationModifiers.None,
ReturnTypeName: returnTypeName,
ReturnGenericTypeName: "Task",
Name: "ExecuteAsync",
@@ -72,7 +72,7 @@ public static InterfaceParameters Create(
@namespace,
DocumentationTags: openApiOperation.ExtractDocumentationTagsForHandlerInterface(),
new List { codeGeneratorAttribute },
- AccessModifiers.Public,
+ DeclarationModifiers.PublicInterface,
InterfaceTypeName: $"I{operationName}{ContentGeneratorConstants.Handler}",
InheritedInterfaceTypeName: null,
Properties: null,
diff --git a/src/Atc.Rest.ApiGenerator.Framework.Minimal/Factories/ContentGeneratorServerHandlerParametersFactory.cs b/src/Atc.Rest.ApiGenerator.Framework.Minimal/Factories/ContentGeneratorServerHandlerParametersFactory.cs
index 598db795f..85faf73a2 100644
--- a/src/Atc.Rest.ApiGenerator.Framework.Minimal/Factories/ContentGeneratorServerHandlerParametersFactory.cs
+++ b/src/Atc.Rest.ApiGenerator.Framework.Minimal/Factories/ContentGeneratorServerHandlerParametersFactory.cs
@@ -46,7 +46,7 @@ public static ClassParameters Create(
new(
DocumentationTags: null,
Attributes: null,
- AccessModifier: AccessModifiers.Public,
+ DeclarationModifier: DeclarationModifiers.Public,
ReturnTypeName: $"{operationName}{ContentGeneratorConstants.Result}",
ReturnGenericTypeName: "Task",
Name: "ExecuteAsync",
@@ -61,7 +61,7 @@ public static ClassParameters Create(
@namespace,
openApiOperation.ExtractDocumentationTagsForHandler(),
Attributes: null,
- AccessModifiers.PublicSealedClass,
+ DeclarationModifiers.PublicSealedClass,
ClassTypeName: $"{operationName}{ContentGeneratorConstants.Handler}",
GenericTypeName: null,
InheritedClassTypeName: $"I{operationName}{ContentGeneratorConstants.Handler}",
@@ -84,7 +84,7 @@ public static ClassParameters CreateForCustomTest(
new(
DocumentationTags: null,
Attributes: AttributesParametersFactory.Create("Fact", "Skip = \"Change this to a real test\""),
- AccessModifier: AccessModifiers.Public,
+ DeclarationModifier: DeclarationModifiers.Public,
ReturnTypeName: "void",
ReturnGenericTypeName: null,
Name: "Sample",
@@ -99,7 +99,7 @@ public static ClassParameters CreateForCustomTest(
@namespace,
DocumentationTags: null,
Attributes: null,
- AccessModifiers.PublicClass,
+ DeclarationModifiers.PublicClass,
ClassTypeName: $"{operationName}{ContentGeneratorConstants.HandlerTests}",
GenericTypeName: null,
InheritedClassTypeName: null,
diff --git a/src/Atc.Rest.ApiGenerator.Framework.Minimal/Factories/ContentGeneratorServerResultParametersFactory.cs b/src/Atc.Rest.ApiGenerator.Framework.Minimal/Factories/ContentGeneratorServerResultParametersFactory.cs
index 1c079f52c..f295b2cb2 100644
--- a/src/Atc.Rest.ApiGenerator.Framework.Minimal/Factories/ContentGeneratorServerResultParametersFactory.cs
+++ b/src/Atc.Rest.ApiGenerator.Framework.Minimal/Factories/ContentGeneratorServerResultParametersFactory.cs
@@ -53,6 +53,7 @@ public static ContentGeneratorServerResultParameters Create(
@namespace,
operationName,
openApiOperation.ExtractDocumentationTagsForResult(),
+ DeclarationModifiers.PublicClass,
$"{operationName}{ContentGeneratorConstants.Result}",
methodParameters,
implicitOperatorParameters);
diff --git a/src/Atc.Rest.ApiGenerator.Framework.Minimal/GlobalUsings.cs b/src/Atc.Rest.ApiGenerator.Framework.Minimal/GlobalUsings.cs
index e3bb7c36b..3fa87e833 100644
--- a/src/Atc.Rest.ApiGenerator.Framework.Minimal/GlobalUsings.cs
+++ b/src/Atc.Rest.ApiGenerator.Framework.Minimal/GlobalUsings.cs
@@ -14,6 +14,7 @@
global using Atc.Rest.ApiGenerator.Framework.ContentGenerators;
global using Atc.Rest.ApiGenerator.Framework.ContentGenerators.Server;
global using Atc.Rest.ApiGenerator.Framework.ContentGeneratorsParameters.Server;
+global using Atc.Rest.ApiGenerator.Framework.Factories;
global using Atc.Rest.ApiGenerator.Framework.Factories.Parameters.Server;
global using Atc.Rest.ApiGenerator.Framework.Factories.Parameters.ServerClient;
global using Atc.Rest.ApiGenerator.Framework.Factories.Server;
@@ -21,6 +22,7 @@
global using Atc.Rest.ApiGenerator.Framework.Minimal.Factories;
global using Atc.Rest.ApiGenerator.Framework.ProjectGenerator;
global using Atc.Rest.ApiGenerator.Framework.Providers;
+global using Atc.Rest.ApiGenerator.Framework.Settings;
global using Atc.Rest.ApiGenerator.Framework.Writers;
global using Atc.Rest.ApiGenerator.OpenApi.Extensions;
diff --git a/src/Atc.Rest.ApiGenerator.Framework.Minimal/ProjectGenerator/ServerApiGenerator.cs b/src/Atc.Rest.ApiGenerator.Framework.Minimal/ProjectGenerator/ServerApiGenerator.cs
index 67533c4d3..a5a3f94bf 100644
--- a/src/Atc.Rest.ApiGenerator.Framework.Minimal/ProjectGenerator/ServerApiGenerator.cs
+++ b/src/Atc.Rest.ApiGenerator.Framework.Minimal/ProjectGenerator/ServerApiGenerator.cs
@@ -5,54 +5,40 @@ public class ServerApiGenerator : IServerApiGenerator
{
private readonly ILogger logger;
private readonly INugetPackageReferenceProvider nugetPackageReferenceProvider;
- private readonly Version apiGeneratorVersion;
- private readonly string projectName;
- private readonly DirectoryInfo projectPath;
private readonly OpenApiDocument openApiDocument;
private readonly IList operationSchemaMappings;
private readonly string routeBase;
private readonly string codeGeneratorContentHeader;
private readonly AttributeParameters codeGeneratorAttribute;
- private readonly bool useProblemDetailsAsDefaultResponseBody;
- private readonly bool includeDeprecated;
+ private readonly GeneratorSettings settings;
public ServerApiGenerator(
ILoggerFactory loggerFactory,
INugetPackageReferenceProvider nugetPackageReferenceProvider,
- Version apiGeneratorVersion,
- string projectName,
- DirectoryInfo projectPath,
OpenApiDocument openApiDocument,
IList operationSchemaMappings,
string routeBase,
- bool useProblemDetailsAsDefaultResponseBody,
- bool includeDeprecated)
+ GeneratorSettings generatorSettings)
{
ArgumentNullException.ThrowIfNull(loggerFactory);
ArgumentNullException.ThrowIfNull(nugetPackageReferenceProvider);
- ArgumentNullException.ThrowIfNull(apiGeneratorVersion);
- ArgumentNullException.ThrowIfNull(projectName);
- ArgumentNullException.ThrowIfNull(projectPath);
ArgumentNullException.ThrowIfNull(openApiDocument);
ArgumentNullException.ThrowIfNull(routeBase);
+ ArgumentNullException.ThrowIfNull(generatorSettings);
logger = loggerFactory.CreateLogger();
this.nugetPackageReferenceProvider = nugetPackageReferenceProvider;
- this.apiGeneratorVersion = apiGeneratorVersion;
- this.projectName = projectName;
- this.projectPath = projectPath;
this.openApiDocument = openApiDocument;
this.operationSchemaMappings = operationSchemaMappings;
this.routeBase = routeBase;
- this.useProblemDetailsAsDefaultResponseBody = useProblemDetailsAsDefaultResponseBody;
- this.includeDeprecated = includeDeprecated;
+ settings = generatorSettings;
codeGeneratorContentHeader = GeneratedCodeHeaderGeneratorFactory
- .Create(apiGeneratorVersion)
+ .Create(settings.Version)
.Generate();
codeGeneratorAttribute = new AttributeParameters(
"GeneratedCode",
- $"\"{ContentWriterConstants.ApiGeneratorName}\", \"{apiGeneratorVersion}\"");
+ $"\"{ContentWriterConstants.ApiGeneratorName}\", \"{settings.Version}\"");
}
public async Task ScaffoldProjectFile()
@@ -80,7 +66,7 @@ public async Task ScaffoldProjectFile()
new("GenerateDocumentationFile", Attributes: null, "true"),
],
[
- new("DocumentationFile", Attributes: null, @$"bin\Debug\net8.0\{projectName}.xml"),
+ new("DocumentationFile", Attributes: null, @$"bin\Debug\net8.0\{settings.ProjectName}.xml"),
new("NoWarn", Attributes: null, "$(NoWarn);1573;1591;1701;1702;1712;8618;"),
],
],
@@ -95,8 +81,8 @@ public async Task ScaffoldProjectFile()
var contentWriter = new ContentWriter(logger);
contentWriter.Write(
- projectPath,
- projectPath.CombineFileInfo($"{projectName}.csproj"),
+ settings.ProjectPath,
+ FileInfoFactory.Create(settings.ProjectPath, $"{settings.ProjectName}.csproj"),
ContentWriterArea.Src,
content,
overrideIfExist: false);
@@ -104,7 +90,7 @@ public async Task ScaffoldProjectFile()
public void GenerateAssemblyMarker()
{
- ArgumentNullException.ThrowIfNull(apiGeneratorVersion);
+ ArgumentNullException.ThrowIfNull(settings.Version);
var suppressMessageAvoidEmptyInterfaceAttribute = new AttributeParameters(
"SuppressMessage",
@@ -112,7 +98,7 @@ public void GenerateAssemblyMarker()
var interfaceParameters = InterfaceParametersFactory.Create(
codeGeneratorContentHeader,
- projectName,
+ settings.ProjectName,
[suppressMessageAvoidEmptyInterfaceAttribute, codeGeneratorAttribute],
"IApiContractAssemblyMarker");
@@ -124,8 +110,8 @@ public void GenerateAssemblyMarker()
var contentWriter = new ContentWriter(logger);
contentWriter.Write(
- projectPath,
- projectPath.CombineFileInfo("IApiContractAssemblyMarker.cs"),
+ settings.ProjectPath,
+ FileInfoFactory.Create(settings.ProjectPath, "IApiContractAssemblyMarker.cs"),
ContentWriterArea.Src,
content);
}
@@ -164,11 +150,13 @@ public void GenerateParameters()
{
var apiGroupName = openApiPath.GetApiGroupName();
- var fullNamespace = $"{projectName}.{ContentGeneratorConstants.Contracts}.{apiGroupName}";
+ var contractsLocation = LocationFactory.CreateWithApiGroupName(apiGroupName, settings.ContractsLocation);
+
+ var fullNamespace = NamespaceFactory.Create(settings.ProjectName, contractsLocation);
foreach (var openApiOperation in openApiPath.Value.Operations)
{
- if (openApiOperation.Value.Deprecated && !includeDeprecated)
+ if (openApiOperation.Value.Deprecated && !settings.IncludeDeprecatedOperations)
{
continue;
}
@@ -185,8 +173,8 @@ public void GenerateParameters()
openApiPath.Value.Parameters);
var contentGenerator = new ContentGenerators.ContentGeneratorServerParameter(
- new GeneratedCodeHeaderGenerator(new GeneratedCodeGeneratorParameters(apiGeneratorVersion)),
- new GeneratedCodeAttributeGenerator(new GeneratedCodeGeneratorParameters(apiGeneratorVersion)),
+ new GeneratedCodeHeaderGenerator(new GeneratedCodeGeneratorParameters(settings.Version)),
+ new GeneratedCodeAttributeGenerator(new GeneratedCodeGeneratorParameters(settings.Version)),
new CodeDocumentationTagsGenerator(),
parameterParameters);
@@ -194,8 +182,8 @@ public void GenerateParameters()
var contentWriter = new ContentWriter(logger);
contentWriter.Write(
- projectPath,
- projectPath.CombineFileInfo(ContentGeneratorConstants.Contracts, apiGroupName, ContentGeneratorConstants.Parameters, $"{parameterParameters.ParameterName}.cs"),
+ settings.ProjectPath,
+ FileInfoFactory.Create(settings.ProjectPath, contractsLocation, ContentGeneratorConstants.Parameters, $"{parameterParameters.ParameterName}.cs"),
ContentWriterArea.Src,
content);
}
@@ -208,11 +196,13 @@ public void GenerateResults()
{
var apiGroupName = openApiPath.GetApiGroupName();
- var fullNamespace = $"{projectName}.{ContentGeneratorConstants.Contracts}.{apiGroupName}";
+ var contractsLocation = LocationFactory.CreateWithApiGroupName(apiGroupName, settings.ContractsLocation);
+
+ var fullNamespace = NamespaceFactory.Create(settings.ProjectName, contractsLocation);
foreach (var openApiOperation in openApiPath.Value.Operations)
{
- if (openApiOperation.Value.Deprecated && !includeDeprecated)
+ if (openApiOperation.Value.Deprecated && !settings.IncludeDeprecatedOperations)
{
continue;
}
@@ -222,18 +212,18 @@ public void GenerateResults()
openApiOperation.Value);
var contentGenerator = new ContentGenerators.ContentGeneratorServerResult(
- new GeneratedCodeHeaderGenerator(new GeneratedCodeGeneratorParameters(apiGeneratorVersion)),
- new GeneratedCodeAttributeGenerator(new GeneratedCodeGeneratorParameters(apiGeneratorVersion)),
+ new GeneratedCodeHeaderGenerator(new GeneratedCodeGeneratorParameters(settings.Version)),
+ new GeneratedCodeAttributeGenerator(new GeneratedCodeGeneratorParameters(settings.Version)),
new CodeDocumentationTagsGenerator(),
resultParameters,
- useProblemDetailsAsDefaultResponseBody);
+ settings.UseProblemDetailsAsDefaultResponseBody);
var content = contentGenerator.Generate();
var contentWriter = new ContentWriter(logger);
contentWriter.Write(
- projectPath,
- projectPath.CombineFileInfo(ContentGeneratorConstants.Contracts, apiGroupName, ContentGeneratorConstants.Results, $"{resultParameters.ResultName}.cs"),
+ settings.ProjectPath,
+ FileInfoFactory.Create(settings.ProjectPath, contractsLocation, ContentGeneratorConstants.Results, $"{resultParameters.ResultName}.cs"),
ContentWriterArea.Src,
content);
}
@@ -246,11 +236,13 @@ public void GenerateInterfaces()
{
var apiGroupName = openApiPath.GetApiGroupName();
- var fullNamespace = $"{projectName}.{ContentGeneratorConstants.Contracts}.{apiGroupName}";
+ var contractsLocation = LocationFactory.CreateWithApiGroupName(apiGroupName, settings.ContractsLocation);
+
+ var fullNamespace = NamespaceFactory.Create(settings.ProjectName, contractsLocation);
foreach (var openApiOperation in openApiPath.Value.Operations)
{
- if (openApiOperation.Value.Deprecated && !includeDeprecated)
+ if (openApiOperation.Value.Deprecated && !settings.IncludeDeprecatedOperations)
{
continue;
}
@@ -270,8 +262,8 @@ public void GenerateInterfaces()
var contentWriter = new ContentWriter(logger);
contentWriter.Write(
- projectPath,
- projectPath.CombineFileInfo(ContentGeneratorConstants.Contracts, apiGroupName, ContentGeneratorConstants.Interfaces, $"{interfaceParameters.InterfaceTypeName}.cs"),
+ settings.ProjectPath,
+ FileInfoFactory.Create(settings.ProjectPath, contractsLocation, ContentGeneratorConstants.Interfaces, $"{interfaceParameters.InterfaceTypeName}.cs"),
ContentWriterArea.Src,
content);
}
@@ -282,28 +274,33 @@ public void GenerateEndpoints()
{
foreach (var apiGroupName in openApiDocument.GetApiGroupNames())
{
+ var endpointsLocation = LocationFactory.CreateWithoutTemplateForApiGroupName(settings.EndpointsLocation);
+
+ var fullNamespace = NamespaceFactory.Create(settings.ProjectName, endpointsLocation);
+
var endpointParameters = ContentGeneratorServerEndpointParametersFactory.Create(
operationSchemaMappings,
- projectName,
- $"{projectName}.{ContentGeneratorConstants.Endpoints}",
+ settings.ProjectName,
+ fullNamespace,
apiGroupName,
GetRouteByApiGroupName(apiGroupName),
ContentGeneratorConstants.EndpointDefinition,
- openApiDocument);
+ openApiDocument,
+ settings.UsePartialClassForEndpoints);
var contentGenerator = new ContentGenerators.ContentGeneratorServerEndpoints(
- new GeneratedCodeHeaderGenerator(new GeneratedCodeGeneratorParameters(apiGeneratorVersion)),
- new GeneratedCodeAttributeGenerator(new GeneratedCodeGeneratorParameters(apiGeneratorVersion)),
+ new GeneratedCodeHeaderGenerator(new GeneratedCodeGeneratorParameters(settings.Version)),
+ new GeneratedCodeAttributeGenerator(new GeneratedCodeGeneratorParameters(settings.Version)),
new CodeDocumentationTagsGenerator(),
endpointParameters,
- useProblemDetailsAsDefaultResponseBody);
+ settings.UseProblemDetailsAsDefaultResponseBody);
var content = contentGenerator.Generate();
var contentWriter = new ContentWriter(logger);
contentWriter.Write(
- projectPath,
- projectPath.CombineFileInfo(ContentGeneratorConstants.Endpoints, $"{endpointParameters.EndpointName}.cs"),
+ settings.ProjectPath,
+ FileInfoFactory.Create(settings.ProjectPath, endpointsLocation, $"{endpointParameters.EndpointName}.cs"),
ContentWriterArea.Src,
content);
}
@@ -314,7 +311,7 @@ public void MaintainApiSpecification(
=> ResourcesHelper.CopyApiSpecification(
apiSpecificationFile,
openApiDocument,
- projectPath);
+ settings.ProjectPath);
public void MaintainGlobalUsings(
bool removeNamespaceGroupSeparatorInGlobalUsings)
@@ -330,7 +327,7 @@ public void MaintainGlobalUsings(
"Microsoft.AspNetCore.Mvc",
};
- if (openApiDocument.IsUsingRequiredForSystemTextJsonSerializationAndSystemRuntimeSerialization(includeDeprecated))
+ if (openApiDocument.IsUsingRequiredForSystemTextJsonSerializationAndSystemRuntimeSerialization(settings.IncludeDeprecatedOperations))
{
requiredUsings.Add("System.Runtime.Serialization");
requiredUsings.Add("System.Text.Json.Serialization");
@@ -341,7 +338,7 @@ public void MaintainGlobalUsings(
requiredUsings.Add("Atc.Rest.Results");
}
- if (openApiDocument.IsUsingRequiredForMicrosoftAspNetCoreAuthorization(includeDeprecated))
+ if (openApiDocument.IsUsingRequiredForMicrosoftAspNetCoreAuthorization(settings.IncludeDeprecatedOperations))
{
requiredUsings.Add("Microsoft.AspNetCore.Authorization");
}
@@ -353,16 +350,24 @@ public void MaintainGlobalUsings(
if (operationSchemaMappings.Any(apiOperation => apiOperation.Model.IsShared))
{
- requiredUsings.Add($"{projectName}.{ContentGeneratorConstants.Contracts}");
+ var requiredUsing = NamespaceFactory.Create(
+ settings.ProjectName,
+ LocationFactory.CreateWithoutTemplateForApiGroupName(settings.ContractsLocation));
+
+ if (!requiredUsings.Contains(requiredUsing, StringComparer.CurrentCulture))
+ {
+ requiredUsings.Add(requiredUsing);
+ }
}
var apiGroupNames = openApiDocument.GetApiGroupNames();
- requiredUsings.AddRange(apiGroupNames.Select(x => $"{projectName}.{ContentGeneratorConstants.Contracts}.{x}"));
+
+ requiredUsings.AddRange(apiGroupNames.Select(x => NamespaceFactory.Create(settings.ProjectName, LocationFactory.CreateWithApiGroupName(x, settings.ContractsLocation))));
GlobalUsingsHelper.CreateOrUpdate(
logger,
ContentWriterArea.Src,
- projectPath,
+ settings.ProjectPath,
requiredUsings,
removeNamespaceGroupSeparatorInGlobalUsings);
}
@@ -387,7 +392,9 @@ private void GenerateEnumerationType(
string enumerationName,
OpenApiSchema openApiSchemaEnumeration)
{
- var fullNamespace = $"{projectName}.{ContentGeneratorConstants.Contracts}";
+ var contractsLocation = LocationFactory.CreateWithoutTemplateForApiGroupName(settings.ContractsLocation);
+
+ var fullNamespace = NamespaceFactory.Create(settings.ProjectName, contractsLocation);
var enumParameters = ContentGeneratorServerClientEnumParametersFactory.Create(
codeGeneratorContentHeader,
@@ -404,8 +411,8 @@ private void GenerateEnumerationType(
var contentWriter = new ContentWriter(logger);
contentWriter.Write(
- projectPath,
- projectPath.CombineFileInfo(ContentGeneratorConstants.Contracts, ContentGeneratorConstants.SpecialFolderEnumerationTypes, $"{enumerationName}.cs"),
+ settings.ProjectPath,
+ FileInfoFactory.Create(settings.ProjectPath, contractsLocation, ContentGeneratorConstants.SpecialFolderEnumerationTypes, $"{enumerationName}.cs"),
ContentWriterArea.Src,
content);
}
@@ -416,9 +423,11 @@ private void GenerateModel(
string apiGroupName,
bool isSharedContract)
{
- var fullNamespace = isSharedContract
- ? $"{projectName}.{ContentGeneratorConstants.Contracts}"
- : $"{projectName}.{ContentGeneratorConstants.Contracts}.{apiGroupName}";
+ var contractsLocation = isSharedContract
+ ? LocationFactory.CreateWithoutTemplateForApiGroupName(settings.ContractsLocation)
+ : LocationFactory.CreateWithApiGroupName(apiGroupName, settings.ContractsLocation);
+
+ var fullNamespace = NamespaceFactory.Create(settings.ProjectName, contractsLocation);
var parameters = ContentGeneratorServerClientModelParametersFactory.CreateForRecord(
codeGeneratorContentHeader,
@@ -426,7 +435,8 @@ private void GenerateModel(
codeGeneratorAttribute,
modelName,
apiSchemaModel,
- includeDeprecated);
+ settings.UsePartialClassForContracts,
+ settings.IncludeDeprecatedOperations);
var contentGeneratorRecord = new GenerateContentForRecords(
new CodeDocumentationTagsGenerator(),
@@ -436,10 +446,10 @@ private void GenerateModel(
var contentWriter = new ContentWriter(logger);
contentWriter.Write(
- projectPath,
+ settings.ProjectPath,
isSharedContract
- ? projectPath.CombineFileInfo(ContentGeneratorConstants.Contracts, ContentGeneratorConstants.SpecialFolderSharedModels, $"{modelName}.cs")
- : projectPath.CombineFileInfo(ContentGeneratorConstants.Contracts, apiGroupName, ContentGeneratorConstants.Models, $"{modelName}.cs"),
+ ? FileInfoFactory.Create(settings.ProjectPath, contractsLocation, ContentGeneratorConstants.SpecialFolderSharedModels, $"{modelName}.cs")
+ : FileInfoFactory.Create(settings.ProjectPath, contractsLocation, ContentGeneratorConstants.Models, $"{modelName}.cs"),
ContentWriterArea.Src,
content);
}
diff --git a/src/Atc.Rest.ApiGenerator.Framework.Minimal/ProjectGenerator/ServerDomainGenerator.cs b/src/Atc.Rest.ApiGenerator.Framework.Minimal/ProjectGenerator/ServerDomainGenerator.cs
index 9b80ba590..12030a56d 100644
--- a/src/Atc.Rest.ApiGenerator.Framework.Minimal/ProjectGenerator/ServerDomainGenerator.cs
+++ b/src/Atc.Rest.ApiGenerator.Framework.Minimal/ProjectGenerator/ServerDomainGenerator.cs
@@ -6,42 +6,36 @@ public class ServerDomainGenerator : IServerDomainGenerator
{
private readonly ILogger logger;
private readonly INugetPackageReferenceProvider nugetPackageReferenceProvider;
- private readonly string projectName;
private readonly string apiProjectName;
- private readonly DirectoryInfo projectPath;
private readonly OpenApiDocument openApiDocument;
private readonly string codeGeneratorContentHeader;
private readonly AttributeParameters codeGeneratorAttribute;
+ private readonly GeneratorSettings settings;
public ServerDomainGenerator(
ILoggerFactory loggerFactory,
INugetPackageReferenceProvider nugetPackageReferenceProvider,
- Version apiGeneratorVersion,
- string projectName,
string apiProjectName,
- DirectoryInfo projectPath,
- OpenApiDocument openApiDocument)
+ OpenApiDocument openApiDocument,
+ GeneratorSettings generatorSettings)
{
ArgumentNullException.ThrowIfNull(loggerFactory);
ArgumentNullException.ThrowIfNull(nugetPackageReferenceProvider);
- ArgumentNullException.ThrowIfNull(apiGeneratorVersion);
- ArgumentNullException.ThrowIfNull(projectName);
ArgumentNullException.ThrowIfNull(apiProjectName);
- ArgumentNullException.ThrowIfNull(projectPath);
ArgumentNullException.ThrowIfNull(openApiDocument);
+ ArgumentNullException.ThrowIfNull(generatorSettings);
logger = loggerFactory.CreateLogger();
this.nugetPackageReferenceProvider = nugetPackageReferenceProvider;
- this.projectName = projectName;
this.apiProjectName = apiProjectName;
- this.projectPath = projectPath;
this.openApiDocument = openApiDocument;
+ settings = generatorSettings;
codeGeneratorContentHeader = GeneratedCodeHeaderGeneratorFactory
- .Create(apiGeneratorVersion)
+ .Create(settings.Version)
.Generate();
codeGeneratorAttribute = AttributeParametersFactory
- .CreateGeneratedCode(apiGeneratorVersion);
+ .CreateGeneratedCode(settings.Version);
}
public async Task ScaffoldProjectFile()
@@ -69,7 +63,7 @@ public async Task ScaffoldProjectFile()
new("GenerateDocumentationFile", Attributes: null, "true"),
],
[
- new("DocumentationFile", Attributes: null, @$"bin\Debug\net8.0\{projectName}.xml"),
+ new("DocumentationFile", Attributes: null, @$"bin\Debug\net8.0\{settings.ProjectName}.xml"),
new("NoWarn", Attributes: null, "$(NoWarn);1573;1591;1701;1702;1712;8618;"),
],
],
@@ -100,8 +94,8 @@ public async Task ScaffoldProjectFile()
var contentWriter = new ContentWriter(logger);
contentWriter.Write(
- projectPath,
- projectPath.CombineFileInfo($"{projectName}.csproj"),
+ settings.ProjectPath,
+ settings.ProjectPath.CombineFileInfo($"{settings.ProjectName}.csproj"),
ContentWriterArea.Src,
content,
overrideIfExist: false);
@@ -113,13 +107,16 @@ public void ScaffoldHandlers()
{
var apiGroupName = urlPath.GetApiGroupName();
+ var handlersLocation = LocationFactory.CreateWithApiGroupName(apiGroupName, settings.HandlersLocation);
+ var contractsLocation = LocationFactory.CreateWithApiGroupName(apiGroupName, settings.ContractsLocation);
+
+ var fullNamespace = NamespaceFactory.Create(settings.ProjectName, handlersLocation);
+
foreach (var openApiOperation in urlPath.Value.Operations)
{
- var fullNamespace = $"{projectName}.{ContentGeneratorConstants.Handlers}.{apiGroupName}";
-
var classParameters = ContentGeneratorServerHandlerParametersFactory.Create(
fullNamespace,
- $"Api.Generated.{ContentGeneratorConstants.Contracts}.{apiGroupName}",
+ $"Api.Generated.{contractsLocation}", // TODO: Fix this
urlPath.Value,
openApiOperation.Value);
@@ -131,11 +128,8 @@ public void ScaffoldHandlers()
var contentWriter = new ContentWriter(logger);
contentWriter.Write(
- projectPath,
- projectPath.CombineFileInfo(
- ContentGeneratorConstants.Handlers,
- apiGroupName,
- $"{classParameters.TypeName}.cs"),
+ settings.ProjectPath,
+ FileInfoFactory.Create(settings.ProjectPath, handlersLocation, $"{classParameters.TypeName}.cs"),
ContentWriterArea.Src,
content,
overrideIfExist: false);
@@ -151,7 +145,7 @@ public void GenerateAssemblyMarker()
var interfaceParameters = InterfaceParametersFactory.Create(
codeGeneratorContentHeader,
- projectName,
+ settings.ProjectName,
[suppressMessageAvoidEmptyInterfaceAttribute, codeGeneratorAttribute],
"IDomainAssemblyMarker");
@@ -163,8 +157,8 @@ public void GenerateAssemblyMarker()
var contentWriter = new ContentWriter(logger);
contentWriter.Write(
- projectPath,
- projectPath.CombineFileInfo("IDomainAssemblyMarker.cs"),
+ settings.ProjectPath,
+ settings.ProjectPath.CombineFileInfo("IDomainAssemblyMarker.cs"),
ContentWriterArea.Src,
content);
}
@@ -188,7 +182,7 @@ public void GenerateServiceCollectionEndpointHandlerExtensions()
var methodConfigureDomainServices = new MethodParameters(
DocumentationTags: null,
Attributes: null,
- AccessModifiers.PublicStatic,
+ DeclarationModifiers.PublicStatic,
ReturnGenericTypeName: null,
ReturnTypeName: "IServiceCollection",
Name: "ConfigureDomainHandlers",
@@ -219,10 +213,10 @@ public void GenerateServiceCollectionEndpointHandlerExtensions()
var classParameters = new ClassParameters(
codeGeneratorContentHeader,
- Namespace: $"{projectName}.Extensions",
+ Namespace: $"{settings.ProjectName}.Extensions",
DocumentationTags: null,
Attributes: [codeGeneratorAttribute],
- AccessModifiers.PublicStaticClass,
+ DeclarationModifiers.PublicStaticClass,
ClassTypeName: "ServiceCollectionEndpointHandlerExtensions",
GenericTypeName: null,
InheritedClassTypeName: null,
@@ -244,8 +238,8 @@ public void GenerateServiceCollectionEndpointHandlerExtensions()
var contentWriter = new ContentWriter(logger);
contentWriter.Write(
- projectPath,
- projectPath.CombineFileInfo("Extensions", "ServiceCollectionEndpointHandlerExtensions.cs"),
+ settings.ProjectPath,
+ settings.ProjectPath.CombineFileInfo("Extensions", "ServiceCollectionEndpointHandlerExtensions.cs"),
ContentWriterArea.Src,
content);
}
@@ -263,13 +257,12 @@ public void MaintainGlobalUsings(
var apiGroupNames = openApiDocument.GetApiGroupNames();
- requiredUsings.AddRange(apiGroupNames.Select(x => $"{apiProjectName}.{ContentGeneratorConstants.Contracts}.{x}"));
- requiredUsings.AddRange(apiGroupNames.Select(x => $"{projectName}.{ContentGeneratorConstants.Handlers}.{x}"));
+ requiredUsings.AddRange(apiGroupNames.Select(x => NamespaceFactory.Create(apiProjectName, LocationFactory.CreateWithApiGroupName(x, settings.ContractsLocation))));
GlobalUsingsHelper.CreateOrUpdate(
logger,
ContentWriterArea.Src,
- projectPath,
+ settings.ProjectPath,
requiredUsings,
removeNamespaceGroupSeparatorInGlobalUsings);
}
diff --git a/src/Atc.Rest.ApiGenerator.Framework.Minimal/ProjectGenerator/ServerHostGenerator.cs b/src/Atc.Rest.ApiGenerator.Framework.Minimal/ProjectGenerator/ServerHostGenerator.cs
index 40881b7e9..638e1e208 100644
--- a/src/Atc.Rest.ApiGenerator.Framework.Minimal/ProjectGenerator/ServerHostGenerator.cs
+++ b/src/Atc.Rest.ApiGenerator.Framework.Minimal/ProjectGenerator/ServerHostGenerator.cs
@@ -5,40 +5,32 @@ public class ServerHostGenerator : IServerHostGenerator
{
private readonly ILogger logger;
private readonly INugetPackageReferenceProvider nugetPackageReferenceProvider;
- private readonly Version apiGeneratorVersion;
- private readonly string projectName;
private readonly string apiProjectName;
private readonly string domainProjectName;
- private readonly DirectoryInfo projectPath;
private readonly OpenApiDocument openApiDocument;
+ private readonly GeneratorSettings settings;
public ServerHostGenerator(
ILoggerFactory loggerFactory,
INugetPackageReferenceProvider nugetPackageReferenceProvider,
- Version apiGeneratorVersion,
- string projectName,
string apiProjectName,
string domainProjectName,
- DirectoryInfo projectPath,
- OpenApiDocument openApiDocument)
+ OpenApiDocument openApiDocument,
+ GeneratorSettings generatorSettings)
{
ArgumentNullException.ThrowIfNull(loggerFactory);
ArgumentNullException.ThrowIfNull(nugetPackageReferenceProvider);
- ArgumentNullException.ThrowIfNull(apiGeneratorVersion);
- ArgumentNullException.ThrowIfNull(projectName);
ArgumentNullException.ThrowIfNull(apiProjectName);
ArgumentNullException.ThrowIfNull(domainProjectName);
- ArgumentNullException.ThrowIfNull(projectPath);
+ ArgumentNullException.ThrowIfNull(openApiDocument);
ArgumentNullException.ThrowIfNull(openApiDocument);
logger = loggerFactory.CreateLogger();
this.nugetPackageReferenceProvider = nugetPackageReferenceProvider;
- this.apiGeneratorVersion = apiGeneratorVersion;
- this.projectName = projectName;
this.apiProjectName = apiProjectName;
this.domainProjectName = domainProjectName;
- this.projectPath = projectPath;
this.openApiDocument = openApiDocument;
+ settings = generatorSettings;
}
///
@@ -71,7 +63,7 @@ public async Task ScaffoldProjectFile()
new("GenerateDocumentationFile", Attributes: null, "true"),
],
[
- new("DocumentationFile", Attributes: null, @$"bin\Debug\net8.0\{projectName}.xml"),
+ new("DocumentationFile", Attributes: null, @$"bin\Debug\net8.0\{settings.ProjectName}.xml"),
new("NoWarn", Attributes: null, "$(NoWarn);1573;1591;1701;1702;1712;8618;"),
],
],
@@ -100,8 +92,8 @@ public async Task ScaffoldProjectFile()
var contentWriter = new ContentWriter(logger);
contentWriter.Write(
- projectPath,
- projectPath.CombineFileInfo($"{projectName}.csproj"),
+ settings.ProjectPath,
+ settings.ProjectPath.CombineFileInfo($"{settings.ProjectName}.csproj"),
ContentWriterArea.Src,
content,
overrideIfExist: false);
@@ -109,21 +101,21 @@ public async Task ScaffoldProjectFile()
public void ScaffoldPropertiesLaunchSettingsFile()
=> ResourcesHelper.ScaffoldPropertiesLaunchSettingsFile(
- projectName,
- projectPath,
+ settings.ProjectName,
+ settings.ProjectPath,
useExtended: true);
public void ScaffoldJsonSerializerOptionsExtensions()
{
var contentGenerator = new ContentGenerators.ContentGeneratorServerJsonSerializerOptionsExtensions(
- new ContentGeneratorBaseParameters(Namespace: projectName));
+ new ContentGeneratorBaseParameters(Namespace: settings.ProjectName));
var content = contentGenerator.Generate();
var contentWriter = new ContentWriter(logger);
contentWriter.Write(
- projectPath,
- projectPath.CombineFileInfo("Extensions", "JsonSerializerOptionsExtensions.cs"),
+ settings.ProjectPath,
+ settings.ProjectPath.CombineFileInfo("Extensions", "JsonSerializerOptionsExtensions.cs"),
ContentWriterArea.Src,
content,
overrideIfExist: false);
@@ -132,14 +124,14 @@ public void ScaffoldJsonSerializerOptionsExtensions()
public void ScaffoldServiceCollectionExtensions()
{
var contentGenerator = new ContentGenerators.ContentGeneratorServerServiceCollectionExtensions(
- new ContentGeneratorBaseParameters(Namespace: projectName));
+ new ContentGeneratorBaseParameters(Namespace: settings.ProjectName));
var content = contentGenerator.Generate();
var contentWriter = new ContentWriter(logger);
contentWriter.Write(
- projectPath,
- projectPath.CombineFileInfo("Extensions", "ServiceCollectionExtensions.cs"),
+ settings.ProjectPath,
+ settings.ProjectPath.CombineFileInfo("Extensions", "ServiceCollectionExtensions.cs"),
ContentWriterArea.Src,
content,
overrideIfExist: false);
@@ -148,14 +140,14 @@ public void ScaffoldServiceCollectionExtensions()
public void ScaffoldWebApplicationBuilderExtensions()
{
var contentGenerator = new ContentGenerators.ContentGeneratorServerWebApplicationBuilderExtensions(
- new ContentGeneratorBaseParameters(Namespace: projectName));
+ new ContentGeneratorBaseParameters(Namespace: settings.ProjectName));
var content = contentGenerator.Generate();
var contentWriter = new ContentWriter(logger);
contentWriter.Write(
- projectPath,
- projectPath.CombineFileInfo("Extensions", "WebApplicationBuilderExtensions.cs"),
+ settings.ProjectPath,
+ settings.ProjectPath.CombineFileInfo("Extensions", "WebApplicationBuilderExtensions.cs"),
ContentWriterArea.Src,
content,
overrideIfExist: false);
@@ -165,7 +157,7 @@ public void ScaffoldWebApplicationExtensions(
SwaggerThemeMode swaggerThemeMode)
{
var contentGenerator = new ContentGenerators.ContentGeneratorServerWebApplicationExtensions(
- new ContentGeneratorBaseParameters(Namespace: projectName))
+ new ContentGeneratorBaseParameters(Namespace: settings.ProjectName))
{
SwaggerThemeMode = swaggerThemeMode,
};
@@ -174,8 +166,8 @@ public void ScaffoldWebApplicationExtensions(
var contentWriter = new ContentWriter(logger);
contentWriter.Write(
- projectPath,
- projectPath.CombineFileInfo("Extensions", "WebApplicationExtensions.cs"),
+ settings.ProjectPath,
+ settings.ProjectPath.CombineFileInfo("Extensions", "WebApplicationExtensions.cs"),
ContentWriterArea.Src,
content,
overrideIfExist: false);
@@ -185,7 +177,7 @@ public void ScaffoldProgramFile(
SwaggerThemeMode swaggerThemeMode)
{
var contentGenerator = new ContentGenerators.ContentGeneratorServerProgram(
- new ContentGeneratorBaseParameters(Namespace: projectName))
+ new ContentGeneratorBaseParameters(Namespace: settings.ProjectName))
{
SwaggerThemeMode = swaggerThemeMode,
};
@@ -194,8 +186,8 @@ public void ScaffoldProgramFile(
var contentWriter = new ContentWriter(logger);
contentWriter.Write(
- projectPath,
- projectPath.CombineFileInfo("Program.cs"),
+ settings.ProjectPath,
+ settings.ProjectPath.CombineFileInfo("Program.cs"),
ContentWriterArea.Src,
content,
overrideIfExist: false);
@@ -212,8 +204,8 @@ public void ScaffoldWebConfig()
var contentWriter = new ContentWriter(logger);
contentWriter.Write(
- projectPath,
- projectPath.CombineFileInfo("web.config"),
+ settings.ProjectPath,
+ settings.ProjectPath.CombineFileInfo("web.config"),
ContentWriterArea.Src,
content,
overrideIfExist: false);
@@ -221,7 +213,7 @@ public void ScaffoldWebConfig()
public void GenerateConfigureSwaggerDocOptions()
{
- var fullNamespace = $"{projectName}";
+ var fullNamespace = $"{settings.ProjectName}";
var contentGeneratorServerSwaggerDocOptionsParameters = ContentGeneratorServerSwaggerDocOptionsParameterFactory
.Create(
@@ -229,16 +221,16 @@ public void GenerateConfigureSwaggerDocOptions()
openApiDocument.ToSwaggerDocOptionsParameters());
var contentGenerator = new ContentGeneratorServerConfigureSwaggerDocOptions(
- new GeneratedCodeHeaderGenerator(new GeneratedCodeGeneratorParameters(apiGeneratorVersion)),
- new GeneratedCodeAttributeGenerator(new GeneratedCodeGeneratorParameters(apiGeneratorVersion)),
+ new GeneratedCodeHeaderGenerator(new GeneratedCodeGeneratorParameters(settings.Version)),
+ new GeneratedCodeAttributeGenerator(new GeneratedCodeGeneratorParameters(settings.Version)),
contentGeneratorServerSwaggerDocOptionsParameters);
var content = contentGenerator.Generate();
var contentWriter = new ContentWriter(logger);
contentWriter.Write(
- projectPath,
- projectPath.CombineFileInfo("Options", "ConfigureSwaggerDocOptions.cs"),
+ settings.ProjectPath,
+ settings.ProjectPath.CombineFileInfo("Options", "ConfigureSwaggerDocOptions.cs"),
ContentWriterArea.Src,
content);
}
@@ -264,9 +256,9 @@ public void MaintainGlobalUsings(
"Microsoft.Extensions.Options",
"Microsoft.OpenApi.Models",
"Swashbuckle.AspNetCore.SwaggerGen",
- $"{projectName}.Extensions",
- $"{projectName}.Generated",
- $"{projectName}.Options",
+ $"{settings.ProjectName}.Extensions",
+ $"{settings.ProjectName}.Generated",
+ $"{settings.ProjectName}.Options",
domainProjectName,
$"{domainProjectName}.Extensions",
};
@@ -274,11 +266,11 @@ public void MaintainGlobalUsings(
GlobalUsingsHelper.CreateOrUpdate(
logger,
ContentWriterArea.Src,
- projectPath,
+ settings.ProjectPath,
requiredUsings,
removeNamespaceGroupSeparatorInGlobalUsings);
}
public void MaintainWwwResources()
- => ResourcesHelper.MaintainWwwResources(projectPath);
+ => ResourcesHelper.MaintainWwwResources(settings.ProjectPath);
}
\ No newline at end of file
diff --git a/src/Atc.Rest.ApiGenerator.Framework.Minimal/ProjectGenerator/ServerHostTestGenerator.cs b/src/Atc.Rest.ApiGenerator.Framework.Minimal/ProjectGenerator/ServerHostTestGenerator.cs
index c0b8c662e..8a3f277db 100644
--- a/src/Atc.Rest.ApiGenerator.Framework.Minimal/ProjectGenerator/ServerHostTestGenerator.cs
+++ b/src/Atc.Rest.ApiGenerator.Framework.Minimal/ProjectGenerator/ServerHostTestGenerator.cs
@@ -4,54 +4,48 @@ public class ServerHostTestGenerator : IServerHostTestGenerator
{
private readonly ILogger logger;
private readonly INugetPackageReferenceProvider nugetPackageReferenceProvider;
- private readonly string projectName;
private readonly string hostProjectName;
private readonly string apiProjectName;
private readonly string domainProjectName;
- private readonly DirectoryInfo projectPath;
private readonly OpenApiDocument openApiDocument;
private readonly IList operationSchemaMappings;
private readonly string codeGeneratorContentHeader;
private readonly AttributeParameters codeGeneratorAttribute;
+ private readonly GeneratorSettings settings;
public ServerHostTestGenerator(
ILoggerFactory loggerFactory,
INugetPackageReferenceProvider nugetPackageReferenceProvider,
- Version apiGeneratorVersion,
- string projectName,
string hostProjectName,
string apiProjectName,
string domainProjectName,
- DirectoryInfo projectPath,
OpenApiDocument openApiDocument,
- IList operationSchemaMappings)
+ IList operationSchemaMappings,
+ GeneratorSettings generatorSettings)
{
ArgumentNullException.ThrowIfNull(loggerFactory);
ArgumentNullException.ThrowIfNull(nugetPackageReferenceProvider);
- ArgumentNullException.ThrowIfNull(apiGeneratorVersion);
- ArgumentNullException.ThrowIfNull(projectName);
ArgumentNullException.ThrowIfNull(hostProjectName);
ArgumentNullException.ThrowIfNull(apiProjectName);
ArgumentNullException.ThrowIfNull(domainProjectName);
- ArgumentNullException.ThrowIfNull(projectPath);
ArgumentNullException.ThrowIfNull(openApiDocument);
ArgumentNullException.ThrowIfNull(operationSchemaMappings);
+ ArgumentNullException.ThrowIfNull(generatorSettings);
logger = loggerFactory.CreateLogger();
this.nugetPackageReferenceProvider = nugetPackageReferenceProvider;
- this.projectName = projectName;
this.hostProjectName = hostProjectName;
this.apiProjectName = apiProjectName;
this.domainProjectName = domainProjectName;
- this.projectPath = projectPath;
this.openApiDocument = openApiDocument;
this.operationSchemaMappings = operationSchemaMappings;
+ settings = generatorSettings;
codeGeneratorContentHeader = GeneratedCodeHeaderGeneratorFactory
- .Create(apiGeneratorVersion)
+ .Create(settings.Version)
.Generate();
codeGeneratorAttribute = AttributeParametersFactory
- .CreateGeneratedCode(apiGeneratorVersion);
+ .CreateGeneratedCode(settings.Version);
}
public async Task ScaffoldProjectFile()
@@ -75,7 +69,7 @@ public async Task ScaffoldProjectFile()
new("TargetFramework", Attributes: null, "net8.0"),
],
[
- new("DocumentationFile", Attributes: null, @$"bin\Debug\net8.0\{projectName}.xml"),
+ new("DocumentationFile", Attributes: null, @$"bin\Debug\net8.0\{settings.ProjectName}.xml"),
new("NoWarn", Attributes: null, "$(NoWarn);1573;1591;1701;1702;1712;8618;"),
],
],
@@ -111,8 +105,8 @@ public async Task ScaffoldProjectFile()
var contentWriter = new ContentWriter(logger);
contentWriter.Write(
- projectPath,
- projectPath.CombineFileInfo($"{projectName}.csproj"),
+ settings.ProjectPath,
+ settings.ProjectPath.CombineFileInfo($"{settings.ProjectName}.csproj"),
ContentWriterArea.Src,
content,
overrideIfExist: false);
@@ -182,6 +176,10 @@ public void GenerateEndpointHandlerStubs()
{
var apiGroupName = openApiPath.GetApiGroupName();
+ var endpointsLocation = LocationFactory.CreateWithApiGroupName(apiGroupName, settings.EndpointsLocation);
+
+ var fullNamespace = NamespaceFactory.Create(settings.ProjectName, endpointsLocation);
+
foreach (var openApiOperation in openApiPath.Value.Operations)
{
if (openApiOperation.Value.Deprecated)
@@ -189,8 +187,6 @@ public void GenerateEndpointHandlerStubs()
continue;
}
- var fullNamespace = $"{projectName}.{ContentGeneratorConstants.Endpoints}.{apiGroupName}";
-
var classParameters = ContentGeneratorServerTestEndpointHandlerStubParametersFactory.Create(
codeGeneratorContentHeader,
fullNamespace,
@@ -206,8 +202,8 @@ public void GenerateEndpointHandlerStubs()
var contentWriter = new ContentWriter(logger);
contentWriter.Write(
- projectPath,
- projectPath.CombineFileInfo(ContentGeneratorConstants.Endpoints, apiGroupName, $"{classParameters.TypeName}.cs"),
+ settings.ProjectPath,
+ FileInfoFactory.Create(settings.ProjectPath, endpointsLocation, $"{classParameters.TypeName}.cs"),
ContentWriterArea.Test,
content);
}
@@ -279,7 +275,7 @@ public void MaintainGlobalUsings(
if (operationSchemaMappings.Any(apiOperation => apiOperation.Model.IsShared))
{
- requiredUsings.Add($"{apiProjectName}.Contracts");
+ requiredUsings.Add(NamespaceFactory.Create(apiProjectName, LocationFactory.CreateWithoutTemplateForApiGroupName(settings.ContractsLocation)));
}
var apiGroupNames = openApiDocument.GetApiGroupNames();
@@ -291,13 +287,13 @@ public void MaintainGlobalUsings(
continue;
}
- requiredUsings.Add($"{apiProjectName}.Contracts.{apiGroupName}");
+ requiredUsings.Add(NamespaceFactory.Create(apiProjectName, LocationFactory.CreateWithApiGroupName(apiGroupName, settings.ContractsLocation)));
}
GlobalUsingsHelper.CreateOrUpdate(
logger,
ContentWriterArea.Test,
- projectPath,
+ settings.ProjectPath,
requiredUsings,
removeNamespaceGroupSeparatorInGlobalUsings);
}
diff --git a/src/Atc.Rest.ApiGenerator.Framework.Mvc/ContentGenerators/ContentGeneratorServerController.cs b/src/Atc.Rest.ApiGenerator.Framework.Mvc/ContentGenerators/ContentGeneratorServerController.cs
index 4ad0ebe80..5fa3fa544 100644
--- a/src/Atc.Rest.ApiGenerator.Framework.Mvc/ContentGenerators/ContentGeneratorServerController.cs
+++ b/src/Atc.Rest.ApiGenerator.Framework.Mvc/ContentGenerators/ContentGeneratorServerController.cs
@@ -46,7 +46,7 @@ public string Generate()
sb.AppendLine($"[Route(\"{parameters.RouteBase}\")]");
sb.AppendLine(codeAttributeGenerator.Generate());
- sb.AppendLine($"public sealed class {parameters.ApiGroupName}Controller : ControllerBase");
+ sb.AppendLine($"{parameters.DeclarationModifier.GetDescription()} {parameters.ApiGroupName}Controller : ControllerBase");
sb.AppendLine("{");
AppendContent(sb);
sb.Append('}');
diff --git a/src/Atc.Rest.ApiGenerator.Framework.Mvc/ContentGenerators/ContentGeneratorServerParameter.cs b/src/Atc.Rest.ApiGenerator.Framework.Mvc/ContentGenerators/ContentGeneratorServerParameter.cs
index 0a46387b2..c46c2a2d1 100644
--- a/src/Atc.Rest.ApiGenerator.Framework.Mvc/ContentGenerators/ContentGeneratorServerParameter.cs
+++ b/src/Atc.Rest.ApiGenerator.Framework.Mvc/ContentGenerators/ContentGeneratorServerParameter.cs
@@ -36,7 +36,7 @@ public string Generate()
}
sb.AppendLine(codeAttributeGenerator.Generate());
- sb.AppendLine($"public class {parameters.ParameterName}");
+ sb.AppendLine($"{parameters.DeclarationModifier.GetDescription()} {parameters.ParameterName}");
sb.AppendLine("{");
foreach (var parameter in parameters.PropertyParameters)
diff --git a/src/Atc.Rest.ApiGenerator.Framework.Mvc/ContentGenerators/ContentGeneratorServerResult.cs b/src/Atc.Rest.ApiGenerator.Framework.Mvc/ContentGenerators/ContentGeneratorServerResult.cs
index 0659c8625..3b386adae 100644
--- a/src/Atc.Rest.ApiGenerator.Framework.Mvc/ContentGenerators/ContentGeneratorServerResult.cs
+++ b/src/Atc.Rest.ApiGenerator.Framework.Mvc/ContentGenerators/ContentGeneratorServerResult.cs
@@ -38,7 +38,7 @@ public string Generate()
}
sb.AppendLine(codeAttributeGenerator.Generate());
- sb.AppendLine($"public class {parameters.ResultName} : {nameof(Results.ResultBase)}");
+ sb.AppendLine($"{parameters.DeclarationModifier.GetDescription()} {parameters.ResultName} : {nameof(Results.ResultBase)}");
sb.AppendLine("{");
sb.AppendLine(4, $"private {parameters.ResultName}(ActionResult result) : base(result) {{ }}");
sb.AppendLine();
diff --git a/src/Atc.Rest.ApiGenerator.Framework.Mvc/Factories/ContentGeneratorServerHandlerInterfaceParametersFactory.cs b/src/Atc.Rest.ApiGenerator.Framework.Mvc/Factories/ContentGeneratorServerHandlerInterfaceParametersFactory.cs
index 5db774af6..cef845b38 100644
--- a/src/Atc.Rest.ApiGenerator.Framework.Mvc/Factories/ContentGeneratorServerHandlerInterfaceParametersFactory.cs
+++ b/src/Atc.Rest.ApiGenerator.Framework.Mvc/Factories/ContentGeneratorServerHandlerInterfaceParametersFactory.cs
@@ -53,7 +53,7 @@ public static InterfaceParameters Create(
exceptions: null,
@return: null),
Attributes: null,
- AccessModifier: AccessModifiers.None,
+ DeclarationModifier: DeclarationModifiers.None,
ReturnTypeName: $"{operationName}{ContentGeneratorConstants.Result}",
ReturnGenericTypeName: "Task",
Name: "ExecuteAsync",
@@ -68,7 +68,7 @@ public static InterfaceParameters Create(
@namespace,
DocumentationTags: openApiOperation.ExtractDocumentationTagsForHandlerInterface(),
new List { codeGeneratorAttribute },
- AccessModifiers.Public,
+ DeclarationModifiers.PublicInterface,
InterfaceTypeName: $"I{operationName}{ContentGeneratorConstants.Handler}",
InheritedInterfaceTypeName: null,
Properties: null,
diff --git a/src/Atc.Rest.ApiGenerator.Framework.Mvc/Factories/ContentGeneratorServerHandlerParametersFactory.cs b/src/Atc.Rest.ApiGenerator.Framework.Mvc/Factories/ContentGeneratorServerHandlerParametersFactory.cs
index ce0191b29..2500e4420 100644
--- a/src/Atc.Rest.ApiGenerator.Framework.Mvc/Factories/ContentGeneratorServerHandlerParametersFactory.cs
+++ b/src/Atc.Rest.ApiGenerator.Framework.Mvc/Factories/ContentGeneratorServerHandlerParametersFactory.cs
@@ -43,7 +43,7 @@ public static ClassParameters Create(
new(
DocumentationTags: null,
Attributes: null,
- AccessModifier: AccessModifiers.Public,
+ DeclarationModifier: DeclarationModifiers.Public,
ReturnTypeName: $"{operationName}{ContentGeneratorConstants.Result}",
ReturnGenericTypeName: "Task",
Name: "ExecuteAsync",
@@ -58,7 +58,7 @@ public static ClassParameters Create(
@namespace,
openApiOperation.ExtractDocumentationTagsForHandler(),
Attributes: null,
- AccessModifiers.PublicSealedClass,
+ DeclarationModifiers.PublicSealedClass,
ClassTypeName: $"{operationName}{ContentGeneratorConstants.Handler}",
GenericTypeName: null,
InheritedClassTypeName: $"I{operationName}{ContentGeneratorConstants.Handler}",
diff --git a/src/Atc.Rest.ApiGenerator.Framework.Mvc/Factories/ContentGeneratorServerResultParametersFactory.cs b/src/Atc.Rest.ApiGenerator.Framework.Mvc/Factories/ContentGeneratorServerResultParametersFactory.cs
index 9b7d71373..a88923598 100644
--- a/src/Atc.Rest.ApiGenerator.Framework.Mvc/Factories/ContentGeneratorServerResultParametersFactory.cs
+++ b/src/Atc.Rest.ApiGenerator.Framework.Mvc/Factories/ContentGeneratorServerResultParametersFactory.cs
@@ -54,6 +54,7 @@ public static ContentGeneratorServerResultParameters Create(
@namespace,
operationName,
openApiOperation.ExtractDocumentationTagsForResult(),
+ DeclarationModifiers.PublicClass,
$"{operationName}{ContentGeneratorConstants.Result}",
methodParameters,
implicitOperatorParameters);
diff --git a/src/Atc.Rest.ApiGenerator.Framework.Mvc/GlobalUsings.cs b/src/Atc.Rest.ApiGenerator.Framework.Mvc/GlobalUsings.cs
index a5f4885b1..d94a29403 100644
--- a/src/Atc.Rest.ApiGenerator.Framework.Mvc/GlobalUsings.cs
+++ b/src/Atc.Rest.ApiGenerator.Framework.Mvc/GlobalUsings.cs
@@ -16,6 +16,7 @@
global using Atc.Rest.ApiGenerator.Framework.ContentGenerators;
global using Atc.Rest.ApiGenerator.Framework.ContentGenerators.Server;
global using Atc.Rest.ApiGenerator.Framework.ContentGeneratorsParameters.Server;
+global using Atc.Rest.ApiGenerator.Framework.Factories;
global using Atc.Rest.ApiGenerator.Framework.Factories.Parameters.Server;
global using Atc.Rest.ApiGenerator.Framework.Factories.Parameters.ServerClient;
global using Atc.Rest.ApiGenerator.Framework.Factories.Server;
@@ -23,6 +24,7 @@
global using Atc.Rest.ApiGenerator.Framework.Mvc.Factories;
global using Atc.Rest.ApiGenerator.Framework.ProjectGenerator;
global using Atc.Rest.ApiGenerator.Framework.Providers;
+global using Atc.Rest.ApiGenerator.Framework.Settings;
global using Atc.Rest.ApiGenerator.Framework.Writers;
global using Atc.Rest.ApiGenerator.OpenApi.Extensions;
diff --git a/src/Atc.Rest.ApiGenerator.Framework.Mvc/ProjectGenerator/ServerApiGenerator.cs b/src/Atc.Rest.ApiGenerator.Framework.Mvc/ProjectGenerator/ServerApiGenerator.cs
index 121cd8f65..e0d6f125f 100644
--- a/src/Atc.Rest.ApiGenerator.Framework.Mvc/ProjectGenerator/ServerApiGenerator.cs
+++ b/src/Atc.Rest.ApiGenerator.Framework.Mvc/ProjectGenerator/ServerApiGenerator.cs
@@ -5,54 +5,40 @@ public class ServerApiGenerator : IServerApiGenerator
{
private readonly ILogger logger;
private readonly INugetPackageReferenceProvider nugetPackageReferenceProvider;
- private readonly Version apiGeneratorVersion;
- private readonly string projectName;
- private readonly DirectoryInfo projectPath;
private readonly OpenApiDocument openApiDocument;
private readonly IList operationSchemaMappings;
private readonly string routeBase;
private readonly string codeGeneratorContentHeader;
private readonly AttributeParameters codeGeneratorAttribute;
- private readonly bool useProblemDetailsAsDefaultResponseBody;
- private readonly bool includeDeprecated;
+ private readonly GeneratorSettings settings;
public ServerApiGenerator(
ILoggerFactory loggerFactory,
INugetPackageReferenceProvider nugetPackageReferenceProvider,
- Version apiGeneratorVersion,
- string projectName,
- DirectoryInfo projectPath,
OpenApiDocument openApiDocument,
IList operationSchemaMappings,
string routeBase,
- bool useProblemDetailsAsDefaultResponseBody,
- bool includeDeprecated)
+ GeneratorSettings generatorSettings)
{
ArgumentNullException.ThrowIfNull(loggerFactory);
ArgumentNullException.ThrowIfNull(nugetPackageReferenceProvider);
- ArgumentNullException.ThrowIfNull(apiGeneratorVersion);
- ArgumentNullException.ThrowIfNull(projectName);
- ArgumentNullException.ThrowIfNull(projectPath);
ArgumentNullException.ThrowIfNull(openApiDocument);
ArgumentNullException.ThrowIfNull(operationSchemaMappings);
ArgumentNullException.ThrowIfNull(routeBase);
+ ArgumentNullException.ThrowIfNull(generatorSettings);
logger = loggerFactory.CreateLogger();
this.nugetPackageReferenceProvider = nugetPackageReferenceProvider;
- this.apiGeneratorVersion = apiGeneratorVersion;
- this.projectName = projectName;
- this.projectPath = projectPath;
this.openApiDocument = openApiDocument;
this.operationSchemaMappings = operationSchemaMappings;
this.routeBase = routeBase;
- this.useProblemDetailsAsDefaultResponseBody = useProblemDetailsAsDefaultResponseBody;
- this.includeDeprecated = includeDeprecated;
+ settings = generatorSettings;
codeGeneratorContentHeader = GeneratedCodeHeaderGeneratorFactory
- .Create(apiGeneratorVersion)
+ .Create(settings.Version)
.Generate();
codeGeneratorAttribute = AttributeParametersFactory
- .CreateGeneratedCode(apiGeneratorVersion);
+ .CreateGeneratedCode(settings.Version);
}
public async Task ScaffoldProjectFile()
@@ -80,7 +66,7 @@ public async Task ScaffoldProjectFile()
new("GenerateDocumentationFile", Attributes: null, "true"),
],
[
- new("DocumentationFile", Attributes: null, @$"bin\Debug\net8.0\{projectName}.xml"),
+ new("DocumentationFile", Attributes: null, @$"bin\Debug\net8.0\{settings.ProjectName}.xml"),
new("NoWarn", Attributes: null, "$(NoWarn);1573;1591;1701;1702;1712;8618;"),
],
],
@@ -117,8 +103,8 @@ public async Task ScaffoldProjectFile()
var contentWriter = new ContentWriter(logger);
contentWriter.Write(
- projectPath,
- projectPath.CombineFileInfo($"{projectName}.csproj"),
+ settings.ProjectPath,
+ FileInfoFactory.Create(settings.ProjectPath, $"{settings.ProjectName}.csproj"),
ContentWriterArea.Src,
content,
overrideIfExist: false);
@@ -128,7 +114,7 @@ public void GenerateAssemblyMarker()
{
var classParameters = ClassParametersFactory.Create(
codeGeneratorContentHeader,
- projectName,
+ settings.ProjectName,
codeGeneratorAttribute,
"ApiRegistration");
@@ -140,8 +126,8 @@ public void GenerateAssemblyMarker()
var contentWriter = new ContentWriter(logger);
contentWriter.Write(
- projectPath,
- projectPath.CombineFileInfo("ApiRegistration.cs"),
+ settings.ProjectPath,
+ FileInfoFactory.Create(settings.ProjectPath, "ApiRegistration.cs"),
ContentWriterArea.Src,
content);
}
@@ -180,11 +166,13 @@ public void GenerateParameters()
{
var apiGroupName = openApiPath.GetApiGroupName();
- var fullNamespace = $"{projectName}.{ContentGeneratorConstants.Contracts}.{apiGroupName}";
+ var contractsLocation = LocationFactory.CreateWithApiGroupName(apiGroupName, settings.ContractsLocation);
+
+ var fullNamespace = NamespaceFactory.Create(settings.ProjectName, contractsLocation);
foreach (var openApiOperation in openApiPath.Value.Operations)
{
- if (openApiOperation.Value.Deprecated && !includeDeprecated)
+ if (openApiOperation.Value.Deprecated && !settings.IncludeDeprecatedOperations)
{
continue;
}
@@ -201,8 +189,8 @@ public void GenerateParameters()
openApiPath.Value.Parameters);
var contentGenerator = new ContentGenerators.ContentGeneratorServerParameter(
- new GeneratedCodeHeaderGenerator(new GeneratedCodeGeneratorParameters(apiGeneratorVersion)),
- new GeneratedCodeAttributeGenerator(new GeneratedCodeGeneratorParameters(apiGeneratorVersion)),
+ new GeneratedCodeHeaderGenerator(new GeneratedCodeGeneratorParameters(settings.Version)),
+ new GeneratedCodeAttributeGenerator(new GeneratedCodeGeneratorParameters(settings.Version)),
new CodeDocumentationTagsGenerator(),
parameterParameters);
@@ -210,8 +198,8 @@ public void GenerateParameters()
var contentWriter = new ContentWriter(logger);
contentWriter.Write(
- projectPath,
- projectPath.CombineFileInfo(ContentGeneratorConstants.Contracts, apiGroupName, ContentGeneratorConstants.Parameters, $"{parameterParameters.ParameterName}.cs"),
+ settings.ProjectPath,
+ FileInfoFactory.Create(settings.ProjectPath, contractsLocation, ContentGeneratorConstants.Parameters, $"{parameterParameters.ParameterName}.cs"),
ContentWriterArea.Src,
content);
}
@@ -224,11 +212,13 @@ public void GenerateResults()
{
var apiGroupName = openApiPath.GetApiGroupName();
- var fullNamespace = $"{projectName}.{ContentGeneratorConstants.Contracts}.{apiGroupName}";
+ var contractsLocation = LocationFactory.CreateWithApiGroupName(apiGroupName, settings.ContractsLocation);
+
+ var fullNamespace = NamespaceFactory.Create(settings.ProjectName, contractsLocation);
foreach (var openApiOperation in openApiPath.Value.Operations)
{
- if (openApiOperation.Value.Deprecated && !includeDeprecated)
+ if (openApiOperation.Value.Deprecated && !settings.IncludeDeprecatedOperations)
{
continue;
}
@@ -238,18 +228,18 @@ public void GenerateResults()
openApiOperation.Value);
var contentGenerator = new ContentGenerators.ContentGeneratorServerResult(
- new GeneratedCodeHeaderGenerator(new GeneratedCodeGeneratorParameters(apiGeneratorVersion)),
- new GeneratedCodeAttributeGenerator(new GeneratedCodeGeneratorParameters(apiGeneratorVersion)),
+ new GeneratedCodeHeaderGenerator(new GeneratedCodeGeneratorParameters(settings.Version)),
+ new GeneratedCodeAttributeGenerator(new GeneratedCodeGeneratorParameters(settings.Version)),
new CodeDocumentationTagsGenerator(),
resultParameters,
- useProblemDetailsAsDefaultResponseBody);
+ settings.UseProblemDetailsAsDefaultResponseBody);
var content = contentGenerator.Generate();
var contentWriter = new ContentWriter(logger);
contentWriter.Write(
- projectPath,
- projectPath.CombineFileInfo(ContentGeneratorConstants.Contracts, apiGroupName, ContentGeneratorConstants.Results, $"{resultParameters.ResultName}.cs"),
+ settings.ProjectPath,
+ FileInfoFactory.Create(settings.ProjectPath, contractsLocation, ContentGeneratorConstants.Results, $"{resultParameters.ResultName}.cs"),
ContentWriterArea.Src,
content);
}
@@ -262,11 +252,13 @@ public void GenerateInterfaces()
{
var apiGroupName = openApiPath.GetApiGroupName();
- var fullNamespace = $"{projectName}.{ContentGeneratorConstants.Contracts}.{apiGroupName}";
+ var contractsLocation = LocationFactory.CreateWithApiGroupName(apiGroupName, settings.ContractsLocation);
+
+ var fullNamespace = NamespaceFactory.Create(settings.ProjectName, contractsLocation);
foreach (var openApiOperation in openApiPath.Value.Operations)
{
- if (openApiOperation.Value.Deprecated && !includeDeprecated)
+ if (openApiOperation.Value.Deprecated && !settings.IncludeDeprecatedOperations)
{
continue;
}
@@ -286,8 +278,8 @@ public void GenerateInterfaces()
var contentWriter = new ContentWriter(logger);
contentWriter.Write(
- projectPath,
- projectPath.CombineFileInfo(ContentGeneratorConstants.Contracts, apiGroupName, ContentGeneratorConstants.Interfaces, $"{interfaceParameters.InterfaceTypeName}.cs"),
+ settings.ProjectPath,
+ FileInfoFactory.Create(settings.ProjectPath, contractsLocation, ContentGeneratorConstants.Interfaces, $"{interfaceParameters.InterfaceTypeName}.cs"),
ContentWriterArea.Src,
content);
}
@@ -298,28 +290,33 @@ public void GenerateEndpoints()
{
foreach (var apiGroupName in openApiDocument.GetApiGroupNames())
{
+ var endpointsLocation = LocationFactory.CreateWithoutTemplateForApiGroupName(settings.EndpointsLocation);
+
+ var fullNamespace = NamespaceFactory.Create(settings.ProjectName, endpointsLocation);
+
var controllerParameters = ContentGeneratorServerEndpointParametersFactory.Create(
operationSchemaMappings,
- projectName,
- $"{projectName}.{ContentGeneratorConstants.Endpoints}",
+ settings.ProjectName,
+ fullNamespace,
apiGroupName,
GetRouteByApiGroupName(apiGroupName),
ContentGeneratorConstants.Controller,
- openApiDocument);
+ openApiDocument,
+ settings.UsePartialClassForEndpoints);
var contentGenerator = new ContentGenerators.ContentGeneratorServerController(
- new GeneratedCodeHeaderGenerator(new GeneratedCodeGeneratorParameters(apiGeneratorVersion)),
- new GeneratedCodeAttributeGenerator(new GeneratedCodeGeneratorParameters(apiGeneratorVersion)),
+ new GeneratedCodeHeaderGenerator(new GeneratedCodeGeneratorParameters(settings.Version)),
+ new GeneratedCodeAttributeGenerator(new GeneratedCodeGeneratorParameters(settings.Version)),
new CodeDocumentationTagsGenerator(),
controllerParameters,
- useProblemDetailsAsDefaultResponseBody);
+ settings.UseProblemDetailsAsDefaultResponseBody);
var content = contentGenerator.Generate();
var contentWriter = new ContentWriter(logger);
contentWriter.Write(
- projectPath,
- projectPath.CombineFileInfo(ContentGeneratorConstants.Endpoints, $"{controllerParameters.EndpointName}.cs"),
+ settings.ProjectPath,
+ FileInfoFactory.Create(settings.ProjectPath, endpointsLocation, $"{controllerParameters.EndpointName}.cs"),
ContentWriterArea.Src,
content);
}
@@ -330,7 +327,7 @@ public void MaintainApiSpecification(
=> ResourcesHelper.CopyApiSpecification(
apiSpecificationFile,
openApiDocument,
- projectPath);
+ settings.ProjectPath);
public void MaintainGlobalUsings(
bool removeNamespaceGroupSeparatorInGlobalUsings)
@@ -347,35 +344,42 @@ public void MaintainGlobalUsings(
// TODO: Check for any use ??
requiredUsings.Add("System.Net");
- if (openApiDocument.IsUsingRequiredForSystemTextJsonSerializationAndSystemRuntimeSerialization(includeDeprecated))
+ if (openApiDocument.IsUsingRequiredForSystemTextJsonSerializationAndSystemRuntimeSerialization(settings.IncludeDeprecatedOperations))
{
requiredUsings.Add("System.Runtime.Serialization");
requiredUsings.Add("System.Text.Json.Serialization");
}
- if (openApiDocument.IsUsingRequiredForAsyncEnumerable(includeDeprecated))
+ if (openApiDocument.IsUsingRequiredForAsyncEnumerable(settings.IncludeDeprecatedOperations))
{
requiredUsings.Add("Atc.Factories");
}
- if (openApiDocument.IsUsingRequiredForMicrosoftAspNetCoreAuthorization(includeDeprecated))
+ if (openApiDocument.IsUsingRequiredForMicrosoftAspNetCoreAuthorization(settings.IncludeDeprecatedOperations))
{
requiredUsings.Add("Microsoft.AspNetCore.Authorization");
}
if (operationSchemaMappings.Any(apiOperation => apiOperation.Model.IsShared))
{
- requiredUsings.Add($"{projectName}.Contracts");
+ var requiredUsing = NamespaceFactory.Create(
+ settings.ProjectName,
+ LocationFactory.CreateWithoutTemplateForApiGroupName(settings.ContractsLocation));
+
+ if (!requiredUsings.Contains(requiredUsing, StringComparer.CurrentCulture))
+ {
+ requiredUsings.Add(requiredUsing);
+ }
}
var apiGroupNames = openApiDocument.GetApiGroupNames();
- requiredUsings.AddRange(apiGroupNames.Select(x => $"{projectName}.Contracts.{x}"));
+ requiredUsings.AddRange(apiGroupNames.Select(x => NamespaceFactory.Create(settings.ProjectName, LocationFactory.CreateWithApiGroupName(x, settings.ContractsLocation))));
GlobalUsingsHelper.CreateOrUpdate(
logger,
ContentWriterArea.Src,
- projectPath,
+ settings.ProjectPath,
requiredUsings,
removeNamespaceGroupSeparatorInGlobalUsings);
}
@@ -400,7 +404,9 @@ private void GenerateEnumerationType(
string enumerationName,
OpenApiSchema openApiSchemaEnumeration)
{
- var fullNamespace = $"{projectName}.{ContentGeneratorConstants.Contracts}";
+ var contractsLocation = LocationFactory.CreateWithoutTemplateForApiGroupName(settings.ContractsLocation);
+
+ var fullNamespace = NamespaceFactory.Create(settings.ProjectName, contractsLocation);
var enumParameters = ContentGeneratorServerClientEnumParametersFactory.Create(
codeGeneratorContentHeader,
@@ -417,8 +423,8 @@ private void GenerateEnumerationType(
var contentWriter = new ContentWriter(logger);
contentWriter.Write(
- projectPath,
- projectPath.CombineFileInfo(ContentGeneratorConstants.Contracts, ContentGeneratorConstants.SpecialFolderEnumerationTypes, $"{enumerationName}.cs"),
+ settings.ProjectPath,
+ FileInfoFactory.Create(settings.ProjectPath, contractsLocation, ContentGeneratorConstants.SpecialFolderEnumerationTypes, $"{enumerationName}.cs"),
ContentWriterArea.Src,
content);
}
@@ -429,9 +435,11 @@ private void GenerateModel(
string apiGroupName,
bool isSharedContract)
{
- var fullNamespace = isSharedContract
- ? $"{projectName}.{ContentGeneratorConstants.Contracts}"
- : $"{projectName}.{ContentGeneratorConstants.Contracts}.{apiGroupName}";
+ var contractsLocation = isSharedContract
+ ? LocationFactory.CreateWithoutTemplateForApiGroupName(settings.ContractsLocation)
+ : LocationFactory.CreateWithApiGroupName(apiGroupName, settings.ContractsLocation);
+
+ var fullNamespace = NamespaceFactory.Create(settings.ProjectName, contractsLocation);
var parameters = ContentGeneratorServerClientModelParametersFactory.CreateForClass(
codeGeneratorContentHeader,
@@ -439,7 +447,8 @@ private void GenerateModel(
codeGeneratorAttribute,
modelName,
apiSchemaModel,
- includeDeprecated);
+ settings.UsePartialClassForContracts,
+ settings.IncludeDeprecatedOperations);
var contentGeneratorClass = new GenerateContentForClass(
new CodeDocumentationTagsGenerator(),
@@ -449,10 +458,10 @@ private void GenerateModel(
var contentWriter = new ContentWriter(logger);
contentWriter.Write(
- projectPath,
+ settings.ProjectPath,
isSharedContract
- ? projectPath.CombineFileInfo(ContentGeneratorConstants.Contracts, ContentGeneratorConstants.SpecialFolderSharedModels, $"{modelName}.cs")
- : projectPath.CombineFileInfo(ContentGeneratorConstants.Contracts, apiGroupName, ContentGeneratorConstants.Models, $"{modelName}.cs"),
+ ? FileInfoFactory.Create(settings.ProjectPath, contractsLocation, ContentGeneratorConstants.SpecialFolderSharedModels, $"{modelName}.cs")
+ : FileInfoFactory.Create(settings.ProjectPath, contractsLocation, ContentGeneratorConstants.Models, $"{modelName}.cs"),
ContentWriterArea.Src,
content);
}
diff --git a/src/Atc.Rest.ApiGenerator.Framework.Mvc/ProjectGenerator/ServerDomainGenerator.cs b/src/Atc.Rest.ApiGenerator.Framework.Mvc/ProjectGenerator/ServerDomainGenerator.cs
index af8bc15c9..284189913 100644
--- a/src/Atc.Rest.ApiGenerator.Framework.Mvc/ProjectGenerator/ServerDomainGenerator.cs
+++ b/src/Atc.Rest.ApiGenerator.Framework.Mvc/ProjectGenerator/ServerDomainGenerator.cs
@@ -4,39 +4,33 @@ namespace Atc.Rest.ApiGenerator.Framework.Mvc.ProjectGenerator;
public class ServerDomainGenerator : IServerDomainGenerator
{
private readonly ILogger logger;
- private readonly string projectName;
private readonly string apiProjectName;
- private readonly DirectoryInfo projectPath;
private readonly OpenApiDocument openApiDocument;
private readonly string codeGeneratorContentHeader;
private readonly AttributeParameters codeGeneratorAttribute;
+ private readonly GeneratorSettings settings;
public ServerDomainGenerator(
ILoggerFactory loggerFactory,
- Version apiGeneratorVersion,
- string projectName,
string apiProjectName,
- DirectoryInfo projectPath,
- OpenApiDocument openApiDocument)
+ OpenApiDocument openApiDocument,
+ GeneratorSettings generatorSettings)
{
ArgumentNullException.ThrowIfNull(loggerFactory);
- ArgumentNullException.ThrowIfNull(apiGeneratorVersion);
- ArgumentNullException.ThrowIfNull(projectName);
ArgumentNullException.ThrowIfNull(apiProjectName);
- ArgumentNullException.ThrowIfNull(projectPath);
ArgumentNullException.ThrowIfNull(openApiDocument);
+ ArgumentNullException.ThrowIfNull(generatorSettings);
logger = loggerFactory.CreateLogger();
- this.projectName = projectName;
this.apiProjectName = apiProjectName;
- this.projectPath = projectPath;
this.openApiDocument = openApiDocument;
+ settings = generatorSettings;
codeGeneratorContentHeader = GeneratedCodeHeaderGeneratorFactory
- .Create(apiGeneratorVersion)
+ .Create(settings.Version)
.Generate();
codeGeneratorAttribute = AttributeParametersFactory
- .CreateGeneratedCode(apiGeneratorVersion);
+ .CreateGeneratedCode(settings.Version);
}
public async Task ScaffoldProjectFile()
@@ -54,7 +48,7 @@ public async Task ScaffoldProjectFile()
new("GenerateDocumentationFile", Attributes: null, "true"),
],
[
- new("DocumentationFile", Attributes: null, @$"bin\Debug\net8.0\{projectName}.xml"),
+ new("DocumentationFile", Attributes: null, @$"bin\Debug\net8.0\{settings.ProjectName}.xml"),
new("NoWarn", Attributes: null, "$(NoWarn);1573;1591;1701;1702;1712;8618;"),
],
],
@@ -84,8 +78,8 @@ public async Task ScaffoldProjectFile()
var contentWriter = new ContentWriter(logger);
contentWriter.Write(
- projectPath,
- projectPath.CombineFileInfo($"{projectName}.csproj"),
+ settings.ProjectPath,
+ settings.ProjectPath.CombineFileInfo($"{settings.ProjectName}.csproj"),
ContentWriterArea.Src,
content,
overrideIfExist: false);
@@ -97,10 +91,12 @@ public void ScaffoldHandlers()
{
var apiGroupName = urlPath.GetApiGroupName();
+ var handlersLocation = LocationFactory.CreateWithApiGroupName(apiGroupName, settings.HandlersLocation);
+
+ var fullNamespace = NamespaceFactory.Create(settings.ProjectName, handlersLocation);
+
foreach (var openApiOperation in urlPath.Value.Operations)
{
- var fullNamespace = $"{projectName}.{ContentGeneratorConstants.Handlers}.{apiGroupName}";
-
var classParameters = ContentGeneratorServerHandlerParametersFactory.Create(
fullNamespace,
urlPath.Value,
@@ -114,11 +110,8 @@ public void ScaffoldHandlers()
var contentWriter = new ContentWriter(logger);
contentWriter.Write(
- projectPath,
- projectPath.CombineFileInfo(
- ContentGeneratorConstants.Handlers,
- apiGroupName,
- $"{classParameters.TypeName}.cs"),
+ settings.ProjectPath,
+ FileInfoFactory.Create(settings.ProjectPath, handlersLocation, $"{classParameters.TypeName}.cs"),
ContentWriterArea.Src,
content,
overrideIfExist: false);
@@ -130,7 +123,7 @@ public void GenerateAssemblyMarker()
{
var classParameters = ClassParametersFactory.Create(
codeGeneratorContentHeader,
- projectName,
+ settings.ProjectName,
codeGeneratorAttribute,
"DomainRegistration");
@@ -142,8 +135,8 @@ public void GenerateAssemblyMarker()
var contentWriter = new ContentWriter(logger);
contentWriter.Write(
- projectPath,
- projectPath.CombineFileInfo("DomainRegistration.cs"),
+ settings.ProjectPath,
+ settings.ProjectPath.CombineFileInfo("DomainRegistration.cs"),
ContentWriterArea.Src,
content);
}
@@ -161,12 +154,12 @@ public void MaintainGlobalUsings(
var apiGroupNames = openApiDocument.GetApiGroupNames();
- requiredUsings.AddRange(apiGroupNames.Select(x => $"{apiProjectName}.{ContentGeneratorConstants.Contracts}.{x}"));
+ requiredUsings.AddRange(apiGroupNames.Select(x => NamespaceFactory.Create(apiProjectName, LocationFactory.CreateWithApiGroupName(x, settings.ContractsLocation))));
GlobalUsingsHelper.CreateOrUpdate(
logger,
ContentWriterArea.Src,
- projectPath,
+ settings.ProjectPath,
requiredUsings,
removeNamespaceGroupSeparatorInGlobalUsings);
}
diff --git a/src/Atc.Rest.ApiGenerator.Framework.Mvc/ProjectGenerator/ServerHostGenerator.cs b/src/Atc.Rest.ApiGenerator.Framework.Mvc/ProjectGenerator/ServerHostGenerator.cs
index 85c0b6fc4..d7a0312ee 100644
--- a/src/Atc.Rest.ApiGenerator.Framework.Mvc/ProjectGenerator/ServerHostGenerator.cs
+++ b/src/Atc.Rest.ApiGenerator.Framework.Mvc/ProjectGenerator/ServerHostGenerator.cs
@@ -5,40 +5,32 @@ public class ServerHostGenerator : IServerHostGenerator
{
private readonly ILogger logger;
private readonly INugetPackageReferenceProvider nugetPackageReferenceProvider;
- private readonly Version apiGeneratorVersion;
- private readonly string projectName;
private readonly string apiProjectName;
private readonly string domainProjectName;
- private readonly DirectoryInfo projectPath;
private readonly OpenApiDocument openApiDocument;
+ private readonly GeneratorSettings settings;
public ServerHostGenerator(
ILoggerFactory loggerFactory,
INugetPackageReferenceProvider nugetPackageReferenceProvider,
- Version apiGeneratorVersion,
- string projectName,
string apiProjectName,
string domainProjectName,
- DirectoryInfo projectPath,
- OpenApiDocument openApiDocument)
+ OpenApiDocument openApiDocument,
+ GeneratorSettings generatorSettings)
{
ArgumentNullException.ThrowIfNull(loggerFactory);
ArgumentNullException.ThrowIfNull(nugetPackageReferenceProvider);
- ArgumentNullException.ThrowIfNull(apiGeneratorVersion);
- ArgumentNullException.ThrowIfNull(projectName);
ArgumentNullException.ThrowIfNull(apiProjectName);
ArgumentNullException.ThrowIfNull(domainProjectName);
- ArgumentNullException.ThrowIfNull(projectPath);
ArgumentNullException.ThrowIfNull(openApiDocument);
+ ArgumentNullException.ThrowIfNull(generatorSettings);
logger = loggerFactory.CreateLogger();
this.nugetPackageReferenceProvider = nugetPackageReferenceProvider;
- this.apiGeneratorVersion = apiGeneratorVersion;
- this.projectName = projectName;
this.apiProjectName = apiProjectName;
this.domainProjectName = domainProjectName;
- this.projectPath = projectPath;
this.openApiDocument = openApiDocument;
+ settings = generatorSettings;
}
public bool UseRestExtended { get; set; }
@@ -68,7 +60,7 @@ public async Task ScaffoldProjectFile()
new("GenerateDocumentationFile", Attributes: null, "true"),
],
[
- new("DocumentationFile", Attributes: null, @$"bin\Debug\net8.0\{projectName}.xml"),
+ new("DocumentationFile", Attributes: null, @$"bin\Debug\net8.0\{settings.ProjectName}.xml"),
new("NoWarn", Attributes: null, "$(NoWarn);1573;1591;1701;1702;1712;8618;"),
],
],
@@ -98,8 +90,8 @@ public async Task ScaffoldProjectFile()
var contentWriter = new ContentWriter(logger);
contentWriter.Write(
- projectPath,
- projectPath.CombineFileInfo($"{projectName}.csproj"),
+ settings.ProjectPath,
+ settings.ProjectPath.CombineFileInfo($"{settings.ProjectName}.csproj"),
ContentWriterArea.Src,
content,
overrideIfExist: false);
@@ -107,8 +99,8 @@ public async Task ScaffoldProjectFile()
public void ScaffoldPropertiesLaunchSettingsFile()
=> ResourcesHelper.ScaffoldPropertiesLaunchSettingsFile(
- projectName,
- projectPath,
+ settings.ProjectName,
+ settings.ProjectPath,
useExtended: true);
public void ScaffoldJsonSerializerOptionsExtensions()
@@ -128,14 +120,14 @@ public void ScaffoldProgramFile(
SwaggerThemeMode swaggerThemeMode)
{
var contentGenerator = new ContentGenerators.ContentGeneratorServerProgram(
- new ContentGeneratorBaseParameters(Namespace: projectName));
+ new ContentGeneratorBaseParameters(Namespace: settings.ProjectName));
var content = contentGenerator.Generate();
var contentWriter = new ContentWriter(logger);
contentWriter.Write(
- projectPath,
- projectPath.CombineFileInfo("Program.cs"),
+ settings.ProjectPath,
+ settings.ProjectPath.CombineFileInfo("Program.cs"),
ContentWriterArea.Src,
content,
overrideIfExist: false);
@@ -144,14 +136,14 @@ public void ScaffoldProgramFile(
public void ScaffoldStartupFile()
{
var contentGenerator = new ContentGenerators.ContentGeneratorServerStartup(
- new ContentGeneratorBaseParameters(Namespace: projectName));
+ new ContentGeneratorBaseParameters(Namespace: settings.ProjectName));
var content = contentGenerator.Generate();
var contentWriter = new ContentWriter(logger);
contentWriter.Write(
- projectPath,
- projectPath.CombineFileInfo("Startup.cs"),
+ settings.ProjectPath,
+ settings.ProjectPath.CombineFileInfo("Startup.cs"),
ContentWriterArea.Src,
content,
overrideIfExist: false);
@@ -165,8 +157,8 @@ public void ScaffoldWebConfig()
var contentWriter = new ContentWriter(logger);
contentWriter.Write(
- projectPath,
- projectPath.CombineFileInfo("web.config"),
+ settings.ProjectPath,
+ settings.ProjectPath.CombineFileInfo("web.config"),
ContentWriterArea.Src,
content,
overrideIfExist: false);
@@ -174,7 +166,7 @@ public void ScaffoldWebConfig()
public void GenerateConfigureSwaggerDocOptions()
{
- var fullNamespace = $"{projectName}";
+ var fullNamespace = $"{settings.ProjectName}";
var contentGeneratorServerSwaggerDocOptionsParameters = ContentGeneratorServerSwaggerDocOptionsParameterFactory
.Create(
@@ -182,16 +174,16 @@ public void GenerateConfigureSwaggerDocOptions()
openApiDocument.ToSwaggerDocOptionsParameters());
var contentGenerator = new ContentGeneratorServerConfigureSwaggerDocOptions(
- new GeneratedCodeHeaderGenerator(new GeneratedCodeGeneratorParameters(apiGeneratorVersion)),
- new GeneratedCodeAttributeGenerator(new GeneratedCodeGeneratorParameters(apiGeneratorVersion)),
+ new GeneratedCodeHeaderGenerator(new GeneratedCodeGeneratorParameters(settings.Version)),
+ new GeneratedCodeAttributeGenerator(new GeneratedCodeGeneratorParameters(settings.Version)),
contentGeneratorServerSwaggerDocOptionsParameters);
var content = contentGenerator.Generate();
var contentWriter = new ContentWriter(logger);
contentWriter.Write(
- projectPath,
- projectPath.CombineFileInfo("Options", "ConfigureSwaggerDocOptions.cs"),
+ settings.ProjectPath,
+ settings.ProjectPath.CombineFileInfo("Options", "ConfigureSwaggerDocOptions.cs"),
ContentWriterArea.Src,
content);
}
@@ -205,8 +197,8 @@ public void MaintainGlobalUsings(
"System.Reflection",
"System.Text",
domainProjectName,
- $"{projectName}.Generated",
- $"{projectName}.Options",
+ $"{settings.ProjectName}.Generated",
+ $"{settings.ProjectName}.Options",
};
if (UseRestExtended)
@@ -221,11 +213,11 @@ public void MaintainGlobalUsings(
GlobalUsingsHelper.CreateOrUpdate(
logger,
ContentWriterArea.Src,
- projectPath,
+ settings.ProjectPath,
requiredUsings,
removeNamespaceGroupSeparatorInGlobalUsings);
}
public void MaintainWwwResources()
- => ResourcesHelper.MaintainWwwResources(projectPath);
+ => ResourcesHelper.MaintainWwwResources(settings.ProjectPath);
}
\ No newline at end of file
diff --git a/src/Atc.Rest.ApiGenerator.Framework.Mvc/ProjectGenerator/ServerHostTestGenerator.cs b/src/Atc.Rest.ApiGenerator.Framework.Mvc/ProjectGenerator/ServerHostTestGenerator.cs
index 0afe11257..5fda32d74 100644
--- a/src/Atc.Rest.ApiGenerator.Framework.Mvc/ProjectGenerator/ServerHostTestGenerator.cs
+++ b/src/Atc.Rest.ApiGenerator.Framework.Mvc/ProjectGenerator/ServerHostTestGenerator.cs
@@ -6,59 +6,48 @@ public class ServerHostTestGenerator : IServerHostTestGenerator
{
private readonly ILogger logger;
private readonly INugetPackageReferenceProvider nugetPackageReferenceProvider;
- private readonly Version apiGeneratorVersion;
- private readonly string projectName;
private readonly string hostProjectName;
private readonly string apiProjectName;
private readonly string domainProjectName;
- private readonly DirectoryInfo projectPath;
private readonly OpenApiDocument openApiDocument;
private readonly IList operationSchemaMappings;
private readonly string codeGeneratorContentHeader;
private readonly AttributeParameters codeGeneratorAttribute;
- private readonly bool includeDeprecated;
+ private readonly GeneratorSettings settings;
public ServerHostTestGenerator(
ILoggerFactory loggerFactory,
INugetPackageReferenceProvider nugetPackageReferenceProvider,
- Version apiGeneratorVersion,
- string projectName,
string hostProjectName,
string apiProjectName,
string domainProjectName,
- DirectoryInfo projectPath,
OpenApiDocument openApiDocument,
IList operationSchemaMappings,
- bool includeDeprecated)
+ GeneratorSettings generatorSettings)
{
ArgumentNullException.ThrowIfNull(loggerFactory);
ArgumentNullException.ThrowIfNull(nugetPackageReferenceProvider);
- ArgumentNullException.ThrowIfNull(apiGeneratorVersion);
- ArgumentNullException.ThrowIfNull(projectName);
ArgumentNullException.ThrowIfNull(hostProjectName);
ArgumentNullException.ThrowIfNull(apiProjectName);
ArgumentNullException.ThrowIfNull(domainProjectName);
- ArgumentNullException.ThrowIfNull(projectPath);
ArgumentNullException.ThrowIfNull(openApiDocument);
ArgumentNullException.ThrowIfNull(operationSchemaMappings);
+ ArgumentNullException.ThrowIfNull(generatorSettings);
logger = loggerFactory.CreateLogger();
this.nugetPackageReferenceProvider = nugetPackageReferenceProvider;
- this.apiGeneratorVersion = apiGeneratorVersion;
- this.projectName = projectName;
this.hostProjectName = hostProjectName;
this.apiProjectName = apiProjectName;
this.domainProjectName = domainProjectName;
- this.projectPath = projectPath;
this.openApiDocument = openApiDocument;
this.operationSchemaMappings = operationSchemaMappings;
- this.includeDeprecated = includeDeprecated;
+ settings = generatorSettings;
codeGeneratorContentHeader = GeneratedCodeHeaderGeneratorFactory
- .Create(apiGeneratorVersion)
+ .Create(settings.Version)
.Generate();
codeGeneratorAttribute = AttributeParametersFactory
- .CreateGeneratedCode(apiGeneratorVersion);
+ .CreateGeneratedCode(settings.Version);
}
public async Task ScaffoldProjectFile()
@@ -82,7 +71,7 @@ public async Task ScaffoldProjectFile()
new("TargetFramework", Attributes: null, "net8.0"),
],
[
- new("DocumentationFile", Attributes: null, @$"bin\Debug\net8.0\{projectName}.xml"),
+ new("DocumentationFile", Attributes: null, @$"bin\Debug\net8.0\{settings.ProjectName}.xml"),
new("NoWarn", Attributes: null, "$(NoWarn);1573;1591;1701;1702;1712;8618;"),
],
],
@@ -118,8 +107,8 @@ public async Task ScaffoldProjectFile()
var contentWriter = new ContentWriter(logger);
contentWriter.Write(
- projectPath,
- projectPath.CombineFileInfo($"{projectName}.csproj"),
+ settings.ProjectPath,
+ settings.ProjectPath.CombineFileInfo($"{settings.ProjectName}.csproj"),
ContentWriterArea.Src,
content,
overrideIfExist: false);
@@ -133,8 +122,8 @@ public void ScaffoldAppSettingsIntegrationTestFile()
var contentWriter = new ContentWriter(logger);
contentWriter.Write(
- projectPath,
- projectPath.CombineFileInfo("appsettings.integrationtest.json"),
+ settings.ProjectPath,
+ settings.ProjectPath.CombineFileInfo("appsettings.integrationtest.json"),
ContentWriterArea.Test,
content,
overrideIfExist: false);
@@ -143,11 +132,11 @@ public void ScaffoldAppSettingsIntegrationTestFile()
public void GenerateWebApiStartupFactoryFile()
{
var contentGeneratorServerWebApiStartupFactoryParameters = ContentGeneratorServerWebApiStartupFactoryParametersFactory.Create(
- projectName);
+ settings.ProjectName);
var contentGenerator = new ContentGenerators.ContentGeneratorServerWebApiStartupFactory(
- new GeneratedCodeHeaderGenerator(new GeneratedCodeGeneratorParameters(apiGeneratorVersion)),
- new GeneratedCodeAttributeGenerator(new GeneratedCodeGeneratorParameters(apiGeneratorVersion)),
+ new GeneratedCodeHeaderGenerator(new GeneratedCodeGeneratorParameters(settings.Version)),
+ new GeneratedCodeAttributeGenerator(new GeneratedCodeGeneratorParameters(settings.Version)),
new CodeDocumentationTagsGenerator(),
contentGeneratorServerWebApiStartupFactoryParameters);
@@ -155,8 +144,8 @@ public void GenerateWebApiStartupFactoryFile()
var contentWriter = new ContentWriter(logger);
contentWriter.Write(
- projectPath,
- projectPath.CombineFileInfo("WebApiStartupFactory.cs"),
+ settings.ProjectPath,
+ settings.ProjectPath.CombineFileInfo("WebApiStartupFactory.cs"),
ContentWriterArea.Test,
content,
overrideIfExist: false);
@@ -165,16 +154,16 @@ public void GenerateWebApiStartupFactoryFile()
public void GenerateWebApiControllerBaseTestFile()
{
var contentGenerator = new ContentGenerators.ContentGeneratorServerWebApiControllerBaseTest(
- new GeneratedCodeHeaderGenerator(new GeneratedCodeGeneratorParameters(apiGeneratorVersion)),
- new GeneratedCodeAttributeGenerator(new GeneratedCodeGeneratorParameters(apiGeneratorVersion)),
- new ContentGeneratorBaseParameters(projectName));
+ new GeneratedCodeHeaderGenerator(new GeneratedCodeGeneratorParameters(settings.Version)),
+ new GeneratedCodeAttributeGenerator(new GeneratedCodeGeneratorParameters(settings.Version)),
+ new ContentGeneratorBaseParameters(settings.ProjectName));
var content = contentGenerator.Generate();
var contentWriter = new ContentWriter(logger);
contentWriter.Write(
- projectPath,
- projectPath.CombineFileInfo("WebApiControllerBaseTest.cs"),
+ settings.ProjectPath,
+ settings.ProjectPath.CombineFileInfo("WebApiControllerBaseTest.cs"),
ContentWriterArea.Test,
content,
overrideIfExist: false);
@@ -186,15 +175,17 @@ public void GenerateEndpointHandlerStubs()
{
var apiGroupName = openApiPath.GetApiGroupName();
+ var endpointsLocation = LocationFactory.CreateWithApiGroupName(apiGroupName, settings.EndpointsLocation);
+
+ var fullNamespace = NamespaceFactory.Create(settings.ProjectName, endpointsLocation);
+
foreach (var openApiOperation in openApiPath.Value.Operations)
{
- if (openApiOperation.Value.Deprecated && !includeDeprecated)
+ if (openApiOperation.Value.Deprecated && !settings.IncludeDeprecatedOperations)
{
continue;
}
- var fullNamespace = $"{projectName}.{ContentGeneratorConstants.Endpoints}.{apiGroupName}";
-
var classParameters = ContentGeneratorServerTestEndpointHandlerStubParametersFactory.Create(
codeGeneratorContentHeader,
fullNamespace,
@@ -210,8 +201,8 @@ public void GenerateEndpointHandlerStubs()
var contentWriter = new ContentWriter(logger);
contentWriter.Write(
- projectPath,
- projectPath.CombineFileInfo(ContentGeneratorConstants.Endpoints, apiGroupName, $"{classParameters.TypeName}.cs"),
+ settings.ProjectPath,
+ FileInfoFactory.Create(settings.ProjectPath, endpointsLocation, $"{classParameters.TypeName}.cs"),
ContentWriterArea.Test,
content);
}
@@ -224,15 +215,17 @@ public void GenerateEndpointTests()
{
var apiGroupName = openApiPath.GetApiGroupName();
+ var endpointsLocation = LocationFactory.CreateWithApiGroupName(apiGroupName, settings.EndpointsLocation);
+
+ var fullNamespace = NamespaceFactory.Create(settings.ProjectName, endpointsLocation);
+
foreach (var openApiOperation in openApiPath.Value.Operations)
{
- if (openApiOperation.Value.Deprecated && !includeDeprecated)
+ if (openApiOperation.Value.Deprecated && !settings.IncludeDeprecatedOperations)
{
continue;
}
- var fullNamespace = $"{projectName}.{ContentGeneratorConstants.Endpoints}.{apiGroupName}";
-
var classParameters = ContentGeneratorServerTestEndpointTestsParametersFactory.Create(
fullNamespace,
openApiOperation.Value);
@@ -245,8 +238,8 @@ public void GenerateEndpointTests()
var contentWriter = new ContentWriter(logger);
contentWriter.Write(
- projectPath,
- projectPath.CombineFileInfo(ContentGeneratorConstants.Endpoints, apiGroupName, $"{classParameters.TypeName}.cs"),
+ settings.ProjectPath,
+ settings.ProjectPath.CombineFileInfo(ContentGeneratorConstants.Endpoints, apiGroupName, $"{classParameters.TypeName}.cs"),
ContentWriterArea.Test,
content);
}
@@ -284,7 +277,7 @@ public void MaintainGlobalUsings(
if (operationSchemaMappings.Any(apiOperation => apiOperation.Model.IsShared))
{
- requiredUsings.Add($"{apiProjectName}.Contracts");
+ requiredUsings.Add(NamespaceFactory.Create(apiProjectName, LocationFactory.CreateWithoutTemplateForApiGroupName(settings.ContractsLocation)));
}
requiredUsings.Add("AutoFixture");
@@ -299,13 +292,13 @@ public void MaintainGlobalUsings(
continue;
}
- requiredUsings.Add($"{apiProjectName}.Contracts.{apiGroupName}");
+ requiredUsings.Add(NamespaceFactory.Create(apiProjectName, LocationFactory.CreateWithApiGroupName(apiGroupName, settings.ContractsLocation)));
}
GlobalUsingsHelper.CreateOrUpdate(
logger,
ContentWriterArea.Test,
- projectPath,
+ settings.ProjectPath,
requiredUsings,
removeNamespaceGroupSeparatorInGlobalUsings);
}
diff --git a/src/Atc.Rest.ApiGenerator.Framework/ContentGeneratorsParameters/Server/ContentGeneratorServerEndpointParameters.cs b/src/Atc.Rest.ApiGenerator.Framework/ContentGeneratorsParameters/Server/ContentGeneratorServerEndpointParameters.cs
index 100455680..cde493cf2 100644
--- a/src/Atc.Rest.ApiGenerator.Framework/ContentGeneratorsParameters/Server/ContentGeneratorServerEndpointParameters.cs
+++ b/src/Atc.Rest.ApiGenerator.Framework/ContentGeneratorsParameters/Server/ContentGeneratorServerEndpointParameters.cs
@@ -5,6 +5,7 @@ public record ContentGeneratorServerEndpointParameters(
string ApiGroupName,
string RouteBase,
CodeDocumentationTags DocumentationTags,
+ DeclarationModifiers DeclarationModifier,
string EndpointName,
ApiAuthorizeModel? Authorization,
IList MethodParameters);
\ No newline at end of file
diff --git a/src/Atc.Rest.ApiGenerator.Framework/Extensions/StringExtensions.cs b/src/Atc.Rest.ApiGenerator.Framework/Extensions/StringExtensions.cs
new file mode 100644
index 000000000..fa3a163b5
--- /dev/null
+++ b/src/Atc.Rest.ApiGenerator.Framework/Extensions/StringExtensions.cs
@@ -0,0 +1,16 @@
+namespace Atc.Rest.ApiGenerator.Framework.Extensions;
+
+public static class StringExtensions
+{
+ public static string EnsureNamespaceFormat(
+ this string value)
+ => string.IsNullOrEmpty(value)
+ ? value
+ : value
+ .Trim()
+ .Replace('\\', ' ')
+ .Replace('-', ' ')
+ .Replace('.', ' ')
+ .PascalCase()
+ .Replace(' ', '.');
+}
\ No newline at end of file
diff --git a/src/Atc.Rest.ApiGenerator.Framework/Factories/FileInfoFactory.cs b/src/Atc.Rest.ApiGenerator.Framework/Factories/FileInfoFactory.cs
new file mode 100644
index 000000000..8878796ed
--- /dev/null
+++ b/src/Atc.Rest.ApiGenerator.Framework/Factories/FileInfoFactory.cs
@@ -0,0 +1,34 @@
+namespace Atc.Rest.ApiGenerator.Framework.Factories;
+
+public static class FileInfoFactory
+{
+ public static FileInfo Create(
+ DirectoryInfo projectPath,
+ params string[] subParts)
+ {
+ if (subParts is null || subParts.Length == 0)
+ {
+ throw new ArgumentException("At least one path part must be provided.", nameof(subParts));
+ }
+
+ var fileName = subParts[^1];
+
+ if (!fileName.Contains('.', StringComparison.Ordinal))
+ {
+ throw new ArgumentException("The file name must include a valid extension (e.g., .cs).", nameof(subParts));
+ }
+
+ var pathParts = subParts[..^1];
+
+ var subPath = string
+ .Join('.', pathParts)
+ .Trim()
+ .Replace('\\', ' ')
+ .Replace('-', ' ')
+ .Replace('.', ' ')
+ .PascalCase(separators: [' ', '-'])
+ .Replace("_shared", "_Shared", StringComparison.Ordinal)
+ .Replace("_enumerationTypes", "_EnumerationTypes", StringComparison.Ordinal);
+ return projectPath.CombineFileInfo(subPath.Split(' ').Concat([fileName]).ToArray());
+ }
+}
\ No newline at end of file
diff --git a/src/Atc.Rest.ApiGenerator.Framework/Factories/KeyValueItemFactory.cs b/src/Atc.Rest.ApiGenerator.Framework/Factories/KeyValueItemFactory.cs
new file mode 100644
index 000000000..0be062495
--- /dev/null
+++ b/src/Atc.Rest.ApiGenerator.Framework/Factories/KeyValueItemFactory.cs
@@ -0,0 +1,8 @@
+namespace Atc.Rest.ApiGenerator.Framework.Factories;
+
+public static class KeyValueItemFactory
+{
+ public static ICollection CreateTemplateCollectionWithApiGroupName(
+ string value)
+ => new List { new(ContentGeneratorConstants.TemplateKeyForApiGroupName, value) };
+}
\ No newline at end of file
diff --git a/src/Atc.Rest.ApiGenerator.Framework/Factories/LocationFactory.cs b/src/Atc.Rest.ApiGenerator.Framework/Factories/LocationFactory.cs
new file mode 100644
index 000000000..7b7e339f1
--- /dev/null
+++ b/src/Atc.Rest.ApiGenerator.Framework/Factories/LocationFactory.cs
@@ -0,0 +1,90 @@
+namespace Atc.Rest.ApiGenerator.Framework.Factories;
+
+public static class LocationFactory
+{
+ public static string CreateWithApiGroupName(
+ string apiGroupName,
+ string value)
+ {
+ var templateNames = KeyValueItemFactory.CreateTemplateCollectionWithApiGroupName(apiGroupName);
+
+ return Create(
+ templateNames,
+ value);
+ }
+
+ public static string CreateWithoutTemplateForApiGroupName(
+ string value)
+ {
+ if (value is null)
+ {
+ return string.Empty;
+ }
+
+ if (value.Contains(ContentGeneratorConstants.TemplateForApiGroupName, StringComparison.Ordinal))
+ {
+ value = value
+ .Replace(ContentGeneratorConstants.TemplateForApiGroupName, string.Empty, StringComparison.Ordinal)
+ .TrimStart('.')
+ .TrimEnd('.');
+ }
+
+ return value;
+ }
+
+ public static string Create(
+ ICollection templateItems,
+ params string[] values)
+ {
+ if (values is null)
+ {
+ return string.Empty;
+ }
+
+ if (templateItems is not null && templateItems.Count > 0)
+ {
+ values = AppendMissingTemplateKeysToNamespaceParts(templateItems, values);
+ }
+
+ var fullNamespace = string
+ .Join(' ', values)
+ .Replace(" . ", " ", StringComparison.Ordinal);
+
+ if (templateItems is not null && templateItems.Count > 0)
+ {
+ fullNamespace = ApplyTemplates(templateItems, fullNamespace);
+ }
+
+ return fullNamespace.EnsureNamespaceFormat();
+ }
+
+ private static string[] AppendMissingTemplateKeysToNamespaceParts(
+ ICollection templateItems,
+ string[] namespaceParts)
+ {
+ var templateKeys = new List();
+ foreach (var namespacePart in namespaceParts)
+ {
+ templateKeys.AddRange(namespacePart.GetTemplateKeys());
+ }
+
+ return templateItems
+ .Where(x => !templateKeys.Contains(x.Key, StringComparer.Ordinal))
+ .Aggregate(
+ namespaceParts,
+ (current, templateItem) => current
+ .Append(templateItem.Value)
+ .ToArray());
+ }
+
+ private static string ApplyTemplates(
+ ICollection templateItems,
+ string fullNamespace)
+ {
+ return templateItems.Aggregate(
+ fullNamespace,
+ (current, templateItem) => current.ReplaceTemplateKeyWithValue(
+ templateItem.Key,
+ templateItem.Value));
+ }
+}
\ No newline at end of file
diff --git a/src/Atc.Rest.ApiGenerator.Framework/Factories/NamespaceFactory.cs b/src/Atc.Rest.ApiGenerator.Framework/Factories/NamespaceFactory.cs
new file mode 100644
index 000000000..79d84f979
--- /dev/null
+++ b/src/Atc.Rest.ApiGenerator.Framework/Factories/NamespaceFactory.cs
@@ -0,0 +1,19 @@
+namespace Atc.Rest.ApiGenerator.Framework.Factories;
+
+public static class NamespaceFactory
+{
+ public static string Create(
+ params string[] values)
+ {
+ if (values is null)
+ {
+ return string.Empty;
+ }
+
+ var fullNamespace = string
+ .Join(' ', values)
+ .Replace(" . ", " ", StringComparison.Ordinal);
+
+ return fullNamespace.EnsureNamespaceFormat();
+ }
+}
\ No newline at end of file
diff --git a/src/Atc.Rest.ApiGenerator.Framework/Factories/Parameters/Client/ContentGeneratorClientEndpointInterfaceParametersFactory.cs b/src/Atc.Rest.ApiGenerator.Framework/Factories/Parameters/Client/ContentGeneratorClientEndpointInterfaceParametersFactory.cs
index a960d2c5f..a88bfb261 100644
--- a/src/Atc.Rest.ApiGenerator.Framework/Factories/Parameters/Client/ContentGeneratorClientEndpointInterfaceParametersFactory.cs
+++ b/src/Atc.Rest.ApiGenerator.Framework/Factories/Parameters/Client/ContentGeneratorClientEndpointInterfaceParametersFactory.cs
@@ -8,7 +8,8 @@ public static InterfaceParameters Create(
AttributeParameters codeGeneratorAttribute,
OpenApiPathItem openApiPath,
OpenApiOperation openApiOperation,
- string httpClientName)
+ string httpClientName,
+ bool usePartialInterface)
{
var operationName = openApiOperation.GetOperationName();
@@ -67,7 +68,7 @@ public static InterfaceParameters Create(
exceptions: null,
@return: null),
Attributes: null,
- AccessModifier: AccessModifiers.None,
+ DeclarationModifier: DeclarationModifiers.None,
ReturnTypeName: $"{operationName}{ContentGeneratorConstants.EndpointResult}",
ReturnGenericTypeName: "Task",
Name: "ExecuteAsync",
@@ -82,7 +83,7 @@ public static InterfaceParameters Create(
@namespace,
DocumentationTags: openApiOperation.ExtractDocumentationTagsForEndpointInterface(),
new List { codeGeneratorAttribute },
- AccessModifiers.Public,
+ usePartialInterface ? DeclarationModifiers.PublicPartialInterface : DeclarationModifiers.PublicInterface,
InterfaceTypeName: $"I{operationName}{ContentGeneratorConstants.Endpoint}",
InheritedInterfaceTypeName: null,
Properties: null,
diff --git a/src/Atc.Rest.ApiGenerator.Framework/Factories/Parameters/Client/ContentGeneratorClientEndpointParametersFactory.cs b/src/Atc.Rest.ApiGenerator.Framework/Factories/Parameters/Client/ContentGeneratorClientEndpointParametersFactory.cs
index 0dd1d1452..9573dbf70 100644
--- a/src/Atc.Rest.ApiGenerator.Framework/Factories/Parameters/Client/ContentGeneratorClientEndpointParametersFactory.cs
+++ b/src/Atc.Rest.ApiGenerator.Framework/Factories/Parameters/Client/ContentGeneratorClientEndpointParametersFactory.cs
@@ -6,11 +6,13 @@ public static ContentGeneratorClientEndpointParameters Create(
string projectName,
string apiGroupName,
string @namespace,
+ string contractsLocation,
OpenApiPathItem openApiPath,
OperationType httpMethod,
OpenApiOperation openApiOperation,
string httpClientName,
- string urlPath)
+ string urlPath,
+ bool usePartialClass)
{
ArgumentNullException.ThrowIfNull(openApiPath);
ArgumentNullException.ThrowIfNull(openApiOperation);
@@ -21,7 +23,7 @@ public static ContentGeneratorClientEndpointParameters Create(
AppendParameters(parameters, openApiOperation.Parameters);
AppendParametersFromBody(parameters, openApiOperation.RequestBody);
- var modelNamespace = $"{projectName}.{ContentGeneratorConstants.Contracts}.{apiGroupName}";
+ var modelNamespace = NamespaceFactory.Create(projectName, contractsLocation);
var operationName = openApiOperation.GetOperationName();
var controllerAuthorization = openApiPath.ExtractApiPathAuthorization();
var endpointAuthorization = openApiOperation.ExtractApiOperationAuthorization(openApiPath);
@@ -37,6 +39,7 @@ public static ContentGeneratorClientEndpointParameters Create(
DocumentationTags: openApiOperation.ExtractDocumentationTagsForEndpoint(),
HttpClientName: httpClientName,
UrlPath: urlPath,
+ usePartialClass ? DeclarationModifiers.PublicPartialClass : DeclarationModifiers.PublicClass,
EndpointName: $"{operationName}{ContentGeneratorConstants.Endpoint}",
InterfaceName: $"I{operationName}{ContentGeneratorConstants.Endpoint}",
ResultName: $"{operationName}{ContentGeneratorConstants.EndpointResult}",
@@ -54,6 +57,7 @@ public static ContentGeneratorClientEndpointParameters Create(
DocumentationTags: openApiOperation.ExtractDocumentationTagsForEndpoint(),
HttpClientName: httpClientName,
UrlPath: urlPath,
+ usePartialClass ? DeclarationModifiers.PublicPartialClass : DeclarationModifiers.PublicClass,
EndpointName: $"{operationName}{ContentGeneratorConstants.Endpoint}",
InterfaceName: $"I{operationName}{ContentGeneratorConstants.Endpoint}",
ResultName: $"{operationName}{ContentGeneratorConstants.EndpointResult}",
diff --git a/src/Atc.Rest.ApiGenerator.Framework/Factories/Parameters/Client/ContentGeneratorClientEndpointResultInterfaceParametersFactory.cs b/src/Atc.Rest.ApiGenerator.Framework/Factories/Parameters/Client/ContentGeneratorClientEndpointResultInterfaceParametersFactory.cs
index 8acba3a79..5d55ad825 100644
--- a/src/Atc.Rest.ApiGenerator.Framework/Factories/Parameters/Client/ContentGeneratorClientEndpointResultInterfaceParametersFactory.cs
+++ b/src/Atc.Rest.ApiGenerator.Framework/Factories/Parameters/Client/ContentGeneratorClientEndpointResultInterfaceParametersFactory.cs
@@ -6,8 +6,10 @@ public static ContentGeneratorClientEndpointResultInterfaceParameters Create(
string projectName,
string apiGroupName,
string @namespace,
+ string contractsLocation,
OpenApiPathItem openApiPath,
- OpenApiOperation openApiOperation)
+ OpenApiOperation openApiOperation,
+ bool usePartialClass)
{
ArgumentNullException.ThrowIfNull(openApiPath);
ArgumentNullException.ThrowIfNull(openApiOperation);
@@ -18,7 +20,7 @@ public static ContentGeneratorClientEndpointResultInterfaceParameters Create(
AppendParameters(parameters, openApiOperation.Parameters);
AppendParametersFromBody(parameters, openApiOperation.RequestBody);
- var modelNamespace = $"{projectName}.{ContentGeneratorConstants.Contracts}.{apiGroupName}";
+ var modelNamespace = NamespaceFactory.Create(projectName, contractsLocation);
var operationName = openApiOperation.GetOperationName();
var controllerAuthorization = openApiPath.ExtractApiPathAuthorization();
var endpointAuthorization = openApiOperation.ExtractApiOperationAuthorization(openApiPath);
@@ -29,6 +31,7 @@ public static ContentGeneratorClientEndpointResultInterfaceParameters Create(
Namespace: @namespace,
OperationName: operationName,
DocumentationTags: openApiOperation.ExtractDocumentationTagsForEndpointResultInterface(),
+ usePartialClass ? DeclarationModifiers.PublicPartialInterface : DeclarationModifiers.PublicInterface,
InterfaceName: $"I{operationName}{ContentGeneratorConstants.EndpointResult}",
InheritInterfaceName: "IEndpointResponse",
HasParameterType: hasParameterType,
diff --git a/src/Atc.Rest.ApiGenerator.Framework/Factories/Parameters/Client/ContentGeneratorClientEndpointResultParametersFactory.cs b/src/Atc.Rest.ApiGenerator.Framework/Factories/Parameters/Client/ContentGeneratorClientEndpointResultParametersFactory.cs
index e25c85e63..3d58d197a 100644
--- a/src/Atc.Rest.ApiGenerator.Framework/Factories/Parameters/Client/ContentGeneratorClientEndpointResultParametersFactory.cs
+++ b/src/Atc.Rest.ApiGenerator.Framework/Factories/Parameters/Client/ContentGeneratorClientEndpointResultParametersFactory.cs
@@ -6,8 +6,10 @@ public static ContentGeneratorClientEndpointResultParameters Create(
string projectName,
string apiGroupName,
string @namespace,
+ string contractsLocation,
OpenApiPathItem openApiPath,
- OpenApiOperation openApiOperation)
+ OpenApiOperation openApiOperation,
+ bool usePartialClass)
{
ArgumentNullException.ThrowIfNull(openApiPath);
ArgumentNullException.ThrowIfNull(openApiOperation);
@@ -18,7 +20,7 @@ public static ContentGeneratorClientEndpointResultParameters Create(
AppendParameters(parameters, openApiOperation.Parameters);
AppendParametersFromBody(parameters, openApiOperation.RequestBody);
- var modelNamespace = $"{projectName}.{ContentGeneratorConstants.Contracts}.{apiGroupName}";
+ var modelNamespace = NamespaceFactory.Create(projectName, contractsLocation);
var operationName = openApiOperation.GetOperationName();
var controllerAuthorization = openApiPath.ExtractApiPathAuthorization();
var endpointAuthorization = openApiOperation.ExtractApiOperationAuthorization(openApiPath);
@@ -31,6 +33,7 @@ public static ContentGeneratorClientEndpointResultParameters Create(
Namespace: @namespace,
OperationName: operationName,
DocumentationTags: openApiOperation.ExtractDocumentationTagsForEndpointResult(),
+ usePartialClass ? DeclarationModifiers.PublicPartialClass : DeclarationModifiers.PublicClass,
EndpointResultName: $"{operationName}{ContentGeneratorConstants.EndpointResult}",
EndpointResultInterfaceName: $"I{operationName}{ContentGeneratorConstants.EndpointResult}",
InheritClassName: ContentGeneratorConstants.EndpointResponse,
@@ -45,6 +48,7 @@ public static ContentGeneratorClientEndpointResultParameters Create(
Namespace: @namespace,
OperationName: operationName,
DocumentationTags: openApiOperation.ExtractDocumentationTagsForEndpointResult(),
+ usePartialClass ? DeclarationModifiers.PublicPartialClass : DeclarationModifiers.PublicClass,
EndpointResultName: $"{operationName}{ContentGeneratorConstants.EndpointResult}",
EndpointResultInterfaceName: $"I{operationName}{ContentGeneratorConstants.EndpointResult}",
InheritClassName: ContentGeneratorConstants.EndpointResponse,
diff --git a/src/Atc.Rest.ApiGenerator.Framework/Factories/Parameters/Client/ContentGeneratorClientParameterParametersFactory.cs b/src/Atc.Rest.ApiGenerator.Framework/Factories/Parameters/Client/ContentGeneratorClientParameterParametersFactory.cs
index e13227c0e..2732baf9d 100644
--- a/src/Atc.Rest.ApiGenerator.Framework/Factories/Parameters/Client/ContentGeneratorClientParameterParametersFactory.cs
+++ b/src/Atc.Rest.ApiGenerator.Framework/Factories/Parameters/Client/ContentGeneratorClientParameterParametersFactory.cs
@@ -25,6 +25,7 @@ public static ContentGeneratorClientParameterParameters Create(
@namespace,
operationName,
openApiOperation.ExtractDocumentationTagsForParameters(),
+ DeclarationModifiers.PublicClass,
ParameterName: $"{operationName}{ContentGeneratorConstants.Parameters}",
parameters);
}
diff --git a/src/Atc.Rest.ApiGenerator.Framework/Factories/Parameters/Server/ContentGeneratorServerParameterParametersFactory.cs b/src/Atc.Rest.ApiGenerator.Framework/Factories/Parameters/Server/ContentGeneratorServerParameterParametersFactory.cs
index fcee2e1f6..01de34df2 100644
--- a/src/Atc.Rest.ApiGenerator.Framework/Factories/Parameters/Server/ContentGeneratorServerParameterParametersFactory.cs
+++ b/src/Atc.Rest.ApiGenerator.Framework/Factories/Parameters/Server/ContentGeneratorServerParameterParametersFactory.cs
@@ -25,6 +25,7 @@ public static ContentGeneratorServerParameterParameters CreateForClass(
@namespace,
operationName,
openApiOperation.ExtractDocumentationTagsForParameters(),
+ DeclarationModifiers.PublicClass,
ParameterName: $"{operationName}{ContentGeneratorConstants.Parameters}",
parameters);
}
@@ -49,6 +50,7 @@ public static ContentGeneratorServerParameterParameters CreateForRecord(
@namespace,
operationName,
openApiOperation.ExtractDocumentationTagsForParameters(),
+ DeclarationModifiers.PublicClass,
ParameterName: $"{operationName}{ContentGeneratorConstants.Parameters}",
SortOptionalParametersMustAppearAfterAllRequiredParameters(parameters));
}
diff --git a/src/Atc.Rest.ApiGenerator.Framework/Factories/Parameters/Server/ContentGeneratorServerTestEndpointHandlerStubParametersFactory.cs b/src/Atc.Rest.ApiGenerator.Framework/Factories/Parameters/Server/ContentGeneratorServerTestEndpointHandlerStubParametersFactory.cs
index e45d0f1c1..320f4032d 100644
--- a/src/Atc.Rest.ApiGenerator.Framework/Factories/Parameters/Server/ContentGeneratorServerTestEndpointHandlerStubParametersFactory.cs
+++ b/src/Atc.Rest.ApiGenerator.Framework/Factories/Parameters/Server/ContentGeneratorServerTestEndpointHandlerStubParametersFactory.cs
@@ -51,7 +51,7 @@ public static ClassParameters Create(
new(
DocumentationTags: null,
Attributes: null,
- AccessModifier: AccessModifiers.Public,
+ DeclarationModifier: DeclarationModifiers.Public,
ReturnTypeName: returnTypeName,
ReturnGenericTypeName: "Task",
Name: "ExecuteAsync",
@@ -70,7 +70,7 @@ public static ClassParameters Create(
@namespace,
DocumentationTags: null,
new List { codeGeneratorAttribute },
- AccessModifiers.PublicClass,
+ DeclarationModifiers.PublicClass,
ClassTypeName: $"{operationName}{ContentGeneratorConstants.HandlerStub}",
GenericTypeName: null,
InheritedClassTypeName: inheritedClassTypeName,
diff --git a/src/Atc.Rest.ApiGenerator.Framework/Factories/Parameters/Server/ContentGeneratorServerTestEndpointTestsParametersFactory.cs b/src/Atc.Rest.ApiGenerator.Framework/Factories/Parameters/Server/ContentGeneratorServerTestEndpointTestsParametersFactory.cs
index 7bd0e2207..537106896 100644
--- a/src/Atc.Rest.ApiGenerator.Framework/Factories/Parameters/Server/ContentGeneratorServerTestEndpointTestsParametersFactory.cs
+++ b/src/Atc.Rest.ApiGenerator.Framework/Factories/Parameters/Server/ContentGeneratorServerTestEndpointTestsParametersFactory.cs
@@ -13,7 +13,7 @@ public static ClassParameters Create(
{
new(
DocumentationTags: null,
- AccessModifiers.Public,
+ DeclarationModifiers.Public,
GenericTypeName: null,
TypeName: $"{operationName}{ContentGeneratorConstants.Tests}",
InheritedClassTypeName: "base",
@@ -36,7 +36,7 @@ public static ClassParameters Create(
new(
DocumentationTags: null,
Attributes: AttributesParametersFactory.Create("Fact", "Skip = \"Change this to a real integration-test\""),
- AccessModifier: AccessModifiers.Public,
+ DeclarationModifier: DeclarationModifiers.Public,
ReturnTypeName: "void",
ReturnGenericTypeName: null,
Name: "Sample",
@@ -55,7 +55,7 @@ public static ClassParameters Create(
AttributeParametersFactory.Create("Collection", "\"Sequential-Endpoints\""),
AttributeParametersFactory.Create("Trait", "Traits.Category, Traits.Categories.Integration"),
},
- AccessModifiers.PublicClass,
+ DeclarationModifiers.PublicClass,
ClassTypeName: $"{operationName}{ContentGeneratorConstants.Tests}",
GenericTypeName: null,
InheritedClassTypeName: "WebApiControllerBaseTest",
diff --git a/src/Atc.Rest.ApiGenerator.Framework/Factories/Parameters/ServerClient/ContentGeneratorServerClientModelParametersFactory.cs b/src/Atc.Rest.ApiGenerator.Framework/Factories/Parameters/ServerClient/ContentGeneratorServerClientModelParametersFactory.cs
index 016f5e321..c97c77cfe 100644
--- a/src/Atc.Rest.ApiGenerator.Framework/Factories/Parameters/ServerClient/ContentGeneratorServerClientModelParametersFactory.cs
+++ b/src/Atc.Rest.ApiGenerator.Framework/Factories/Parameters/ServerClient/ContentGeneratorServerClientModelParametersFactory.cs
@@ -11,7 +11,8 @@ public static ClassParameters CreateForClass(
AttributeParameters codeGeneratorAttribute,
string modelName,
OpenApiSchema apiSchemaModel,
- bool includeDeprecated)
+ bool usePartialClass = false,
+ bool includeDeprecated = false)
{
ArgumentNullException.ThrowIfNull(apiSchemaModel);
ArgumentNullException.ThrowIfNull(modelName);
@@ -31,7 +32,7 @@ public static ClassParameters CreateForClass(
@namespace,
documentationTags,
new List { codeGeneratorAttribute },
- AccessModifiers.PublicClass,
+ usePartialClass ? DeclarationModifiers.PublicPartialClass : DeclarationModifiers.PublicClass,
ClassTypeName: modelName,
GenericTypeName: genericTypeName,
InheritedClassTypeName: null,
@@ -49,7 +50,8 @@ public static RecordsParameters CreateForRecord(
AttributeParameters codeGeneratorAttribute,
string modelName,
OpenApiSchema apiSchemaModel,
- bool includeDeprecated)
+ bool usePartialRecord = false,
+ bool includeDeprecated = false)
{
ArgumentNullException.ThrowIfNull(apiSchemaModel);
@@ -62,6 +64,7 @@ public static RecordsParameters CreateForRecord(
@namespace,
documentationTags,
new List { codeGeneratorAttribute },
+ usePartialRecord ? DeclarationModifiers.PublicPartialRecord : DeclarationModifiers.PublicRecord,
Parameters: recordParameters);
}
@@ -69,7 +72,8 @@ public static ClassParameters CreateForCustomErrorResponseModel(
string codeGeneratorContentHeader,
string fullNamespace,
AttributeParameters codeGeneratorAttribute,
- CustomErrorResponseModel customErrorResponseModel)
+ CustomErrorResponseModel customErrorResponseModel,
+ bool usePartialClass)
{
ArgumentNullException.ThrowIfNull(customErrorResponseModel);
@@ -92,7 +96,7 @@ public static ClassParameters CreateForCustomErrorResponseModel(
{
CodeDocumentationTags? documentationTag = null;
- var dataType = string.Empty;
+ string dataType;
var isNullableType = false;
string? defaultValue = null;
@@ -114,7 +118,7 @@ public static ClassParameters CreateForCustomErrorResponseModel(
new PropertyParameters(
documentationTag,
Attributes: null,
- AccessModifiers.Public,
+ DeclarationModifiers.Public,
GenericTypeName: null,
TypeName: dataType,
IsNullableType: isNullableType,
@@ -135,7 +139,7 @@ public static ClassParameters CreateForCustomErrorResponseModel(
fullNamespace,
documentationTags,
new List { codeGeneratorAttribute },
- AccessModifiers.PublicClass,
+ usePartialClass ? DeclarationModifiers.PublicPartialClass : DeclarationModifiers.PublicClass,
ClassTypeName: customErrorResponseModel.Name.EnsureFirstCharacterToUpper(),
GenericTypeName: null,
InheritedClassTypeName: null,
@@ -207,7 +211,7 @@ private static List ExtractPropertiesParameters(
new PropertyParameters(
documentationTags,
Attributes: null,
- AccessModifier: AccessModifiers.Public,
+ DeclarationModifier: DeclarationModifiers.Public,
GenericTypeName: NameConstants.List,
IsGenericListType: true,
TypeName: childModelName,
@@ -331,7 +335,7 @@ openApiParameter.Default is null &&
apiSchema.Key,
hasAnyPropertiesAsArrayWithFormatTypeBinary,
openApiParameter),
- AccessModifier: AccessModifiers.Public,
+ DeclarationModifier: DeclarationModifiers.Public,
GenericTypeName: dataTypeForList,
IsGenericListType: !string.IsNullOrEmpty(dataTypeForList),
TypeName: dataType,
@@ -382,7 +386,7 @@ private static List ExtractRecordParameters(
[
new(
documentationTags,
- AccessModifiers.PublicRecord,
+ DeclarationModifiers.PublicRecord,
Name: modelName,
Parameters: ExtractRecordParameterBaseParameters(apiSchemaModel, includeDeprecated))
@@ -405,7 +409,7 @@ private static List ExtractRecordParameterBaseParameter
new PropertyParameters(
DocumentationTags: null,
Attributes: null,
- AccessModifier: AccessModifiers.Public,
+ DeclarationModifier: DeclarationModifiers.Public,
GenericTypeName: NameConstants.List,
IsGenericListType: true,
TypeName: childModelName,
diff --git a/src/Atc.Rest.ApiGenerator.Framework/Factories/Server/ContentGeneratorServerEndpointParametersFactory.cs b/src/Atc.Rest.ApiGenerator.Framework/Factories/Server/ContentGeneratorServerEndpointParametersFactory.cs
index 3c1a63dd2..27a2a8541 100644
--- a/src/Atc.Rest.ApiGenerator.Framework/Factories/Server/ContentGeneratorServerEndpointParametersFactory.cs
+++ b/src/Atc.Rest.ApiGenerator.Framework/Factories/Server/ContentGeneratorServerEndpointParametersFactory.cs
@@ -9,7 +9,8 @@ public static ContentGeneratorServerEndpointParameters Create(
string apiGroupName,
string route,
string endpointSuffixName,
- OpenApiDocument openApiDocument)
+ OpenApiDocument openApiDocument,
+ bool usePartialClassForEndpoints)
{
var modelNamespace = $"{projectName}.{ContentGeneratorConstants.Contracts}.{apiGroupName}";
var methodParameters = new List();
@@ -50,6 +51,7 @@ public static ContentGeneratorServerEndpointParameters Create(
ApiGroupName: apiGroupName,
route,
documentationTags,
+ usePartialClassForEndpoints ? DeclarationModifiers.PublicPartialClass : DeclarationModifiers.PublicSealedClass,
EndpointName: $"{apiGroupName}{endpointSuffixName}",
controllerAuthorization,
methodParameters);
diff --git a/src/Atc.Rest.ApiGenerator.Framework/Factories/Server/ContentGeneratorServerHandlerParametersTestFactory.cs b/src/Atc.Rest.ApiGenerator.Framework/Factories/Server/ContentGeneratorServerHandlerParametersTestFactory.cs
index 8a1932ab3..8c7109a07 100644
--- a/src/Atc.Rest.ApiGenerator.Framework/Factories/Server/ContentGeneratorServerHandlerParametersTestFactory.cs
+++ b/src/Atc.Rest.ApiGenerator.Framework/Factories/Server/ContentGeneratorServerHandlerParametersTestFactory.cs
@@ -13,7 +13,7 @@ public static ClassParameters CreateForCustomTest(
new(
DocumentationTags: null,
Attributes: AttributesParametersFactory.Create("Fact", "Skip = \"Change this to a real test\""),
- AccessModifier: AccessModifiers.Public,
+ DeclarationModifier: DeclarationModifiers.Public,
ReturnTypeName: "void",
ReturnGenericTypeName: null,
Name: "Sample",
@@ -28,7 +28,7 @@ public static ClassParameters CreateForCustomTest(
@namespace,
DocumentationTags: null,
Attributes: null,
- AccessModifiers.PublicClass,
+ DeclarationModifiers.PublicClass,
ClassTypeName: $"{operationName}{ContentGeneratorConstants.HandlerTests}",
GenericTypeName: null,
InheritedClassTypeName: null,
diff --git a/src/Atc.Rest.ApiGenerator.Framework/GlobalUsings.cs b/src/Atc.Rest.ApiGenerator.Framework/GlobalUsings.cs
index c51dedc6c..0bd9325fd 100644
--- a/src/Atc.Rest.ApiGenerator.Framework/GlobalUsings.cs
+++ b/src/Atc.Rest.ApiGenerator.Framework/GlobalUsings.cs
@@ -14,6 +14,7 @@
global using Atc.CodeGeneration.CSharp.Content.Factories;
global using Atc.CodeGeneration.CSharp.Content.Generators;
global using Atc.CodeGeneration.CSharp.Extensions;
+global using Atc.Data.Models;
global using Atc.DotNet;
global using Atc.Helpers;
global using Atc.Rest.ApiGenerator.Contracts;
@@ -24,11 +25,14 @@
global using Atc.Rest.ApiGenerator.Contracts.Models;
global using Atc.Rest.ApiGenerator.Framework.ContentGenerators;
global using Atc.Rest.ApiGenerator.Framework.ContentGeneratorsParameters.Server;
+global using Atc.Rest.ApiGenerator.Framework.Extensions;
+global using Atc.Rest.ApiGenerator.Framework.Factories;
global using Atc.Rest.ApiGenerator.Framework.Factories.Parameters.ServerClient;
global using Atc.Rest.ApiGenerator.Framework.Factories.Server;
global using Atc.Rest.ApiGenerator.Framework.Helpers;
global using Atc.Rest.ApiGenerator.Framework.Providers;
global using Atc.Rest.ApiGenerator.Framework.Readers;
+global using Atc.Rest.ApiGenerator.Framework.Settings;
global using Atc.Rest.ApiGenerator.Framework.ToRefactor;
global using Atc.Rest.ApiGenerator.Framework.Writers;
global using Atc.Rest.ApiGenerator.Nuget.Clients;
diff --git a/src/Atc.Rest.ApiGenerator.Framework/ProjectGenerator/ServerDomainTestGenerator.cs b/src/Atc.Rest.ApiGenerator.Framework/ProjectGenerator/ServerDomainTestGenerator.cs
index 232a46e74..ab09b3c21 100644
--- a/src/Atc.Rest.ApiGenerator.Framework/ProjectGenerator/ServerDomainTestGenerator.cs
+++ b/src/Atc.Rest.ApiGenerator.Framework/ProjectGenerator/ServerDomainTestGenerator.cs
@@ -5,38 +5,32 @@ public class ServerDomainTestGenerator : IServerDomainTestGenerator
{
private readonly ILogger logger;
private readonly INugetPackageReferenceProvider nugetPackageReferenceProvider;
- private readonly string projectName;
private readonly string apiProjectName;
private readonly string domainProjectName;
- private readonly DirectoryInfo projectPath;
private readonly OpenApiDocument openApiDocument;
+ private readonly GeneratorSettings settings;
public ServerDomainTestGenerator(
ILoggerFactory loggerFactory,
INugetPackageReferenceProvider nugetPackageReferenceProvider,
- Version apiGeneratorVersion,
- string projectName,
string apiProjectName,
string domainProjectName,
- DirectoryInfo projectPath,
- OpenApiDocument openApiDocument)
+ OpenApiDocument openApiDocument,
+ GeneratorSettings generatorSettings)
{
ArgumentNullException.ThrowIfNull(loggerFactory);
ArgumentNullException.ThrowIfNull(nugetPackageReferenceProvider);
- ArgumentNullException.ThrowIfNull(apiGeneratorVersion);
- ArgumentNullException.ThrowIfNull(projectName);
ArgumentNullException.ThrowIfNull(apiProjectName);
ArgumentNullException.ThrowIfNull(domainProjectName);
- ArgumentNullException.ThrowIfNull(projectPath);
ArgumentNullException.ThrowIfNull(openApiDocument);
+ ArgumentNullException.ThrowIfNull(generatorSettings);
logger = loggerFactory.CreateLogger();
this.nugetPackageReferenceProvider = nugetPackageReferenceProvider;
- this.projectName = projectName;
this.apiProjectName = apiProjectName;
this.domainProjectName = domainProjectName;
- this.projectPath = projectPath;
this.openApiDocument = openApiDocument;
+ settings = generatorSettings;
}
public async Task ScaffoldProjectFile()
@@ -85,8 +79,8 @@ public async Task ScaffoldProjectFile()
var contentWriter = new ContentWriter(logger);
contentWriter.Write(
- projectPath,
- projectPath.CombineFileInfo($"{projectName}.csproj"),
+ settings.ProjectPath,
+ settings.ProjectPath.CombineFileInfo($"{settings.ProjectName}.csproj"),
ContentWriterArea.Src,
content,
overrideIfExist: false);
@@ -98,10 +92,12 @@ public void ScaffoldHandlers()
{
var apiGroupName = urlPath.GetApiGroupName();
+ var handlersLocation = LocationFactory.CreateWithApiGroupName(apiGroupName, settings.HandlersLocation);
+
+ var fullNamespace = NamespaceFactory.Create(settings.ProjectName, handlersLocation);
+
foreach (var openApiOperation in urlPath.Value.Operations)
{
- var fullNamespace = $"{projectName}.{ContentGeneratorConstants.Handlers}.{apiGroupName}";
-
var classParameters = ContentGeneratorServerHandlerParametersTestFactory.CreateForCustomTest(
fullNamespace,
openApiOperation.Value);
@@ -114,11 +110,8 @@ public void ScaffoldHandlers()
var contentWriter = new ContentWriter(logger);
contentWriter.Write(
- projectPath,
- projectPath.CombineFileInfo(
- ContentGeneratorConstants.Handlers,
- apiGroupName,
- $"{classParameters.TypeName}.cs"),
+ settings.ProjectPath,
+ FileInfoFactory.Create(settings.ProjectPath, handlersLocation, $"{classParameters.TypeName}.cs"),
ContentWriterArea.Test,
content,
overrideIfExist: false);
@@ -138,7 +131,7 @@ public void MaintainGlobalUsings(
GlobalUsingsHelper.CreateOrUpdate(
logger,
ContentWriterArea.Test,
- projectPath,
+ settings.ProjectPath,
requiredUsings,
removeNamespaceGroupSeparatorInGlobalUsings);
}
diff --git a/src/Atc.Rest.ApiGenerator.Framework/Providers/NugetPackageReferenceProvider.cs b/src/Atc.Rest.ApiGenerator.Framework/Providers/NugetPackageReferenceProvider.cs
index 64e0837ee..511c7dbf1 100644
--- a/src/Atc.Rest.ApiGenerator.Framework/Providers/NugetPackageReferenceProvider.cs
+++ b/src/Atc.Rest.ApiGenerator.Framework/Providers/NugetPackageReferenceProvider.cs
@@ -29,7 +29,7 @@ public class NugetPackageReferenceProvider(
{ "Microsoft.NET.Test.Sdk", "17.10.0" },
{ "NSubstitute", "5.1.0" },
{ "Swashbuckle.AspNetCore", "7.0.0" },
- { "xunit", "2.8.1" },
+ { "xunit", "2.9.2" },
{ "xunit.runner.visualstudio", "2.8.1" },
};
diff --git a/src/Atc.Rest.ApiGenerator.Framework/Resources/wwwroot/swagger-ui/SwaggerDark.css b/src/Atc.Rest.ApiGenerator.Framework/Resources/wwwroot/swagger-ui/SwaggerDark.css
index ca7314507..d2bbde8f2 100644
--- a/src/Atc.Rest.ApiGenerator.Framework/Resources/wwwroot/swagger-ui/SwaggerDark.css
+++ b/src/Atc.Rest.ApiGenerator.Framework/Resources/wwwroot/swagger-ui/SwaggerDark.css
@@ -66,7 +66,7 @@ button, input, select, textarea {
}
.swagger-ui pre {
- font-family: monospace,monospace;
+ font-family: monospace;
font-size: 1em
}
@@ -77,8 +77,6 @@ button, input, select, textarea {
.swagger-ui abbr[title] {
border-bottom: none;
- text-decoration: underline;
- -webkit-text-decoration: underline dotted;
text-decoration: underline dotted
}
@@ -88,7 +86,7 @@ button, input, select, textarea {
}
.swagger-ui code, .swagger-ui kbd, .swagger-ui samp {
- font-family: monospace,monospace;
+ font-family: monospace;
font-size: 1em
}
@@ -1065,7 +1063,7 @@ button, input, select, textarea {
}
.swagger-ui .b--washed-yellow {
- border-color: #1c1c21ceb
+ border-color: #1c1c21ce
}
.swagger-ui .b--washed-red {
@@ -1603,7 +1601,6 @@ button, input, select, textarea {
.swagger-ui .pre {
overflow-x: auto;
overflow-y: hidden;
- overflow: scroll
}
.swagger-ui .top-0 {
@@ -4940,7 +4937,7 @@ button, input, select, textarea {
}
.swagger-ui .washed-yellow {
- color: #1c1c21ceb
+ color: #1c1c21ce
}
.swagger-ui .washed-red {
@@ -5168,7 +5165,7 @@ button, input, select, textarea {
}
.swagger-ui .bg-washed-yellow {
- background-color: #1c1c21ceb
+ background-color: #1c1c21ce
}
.swagger-ui .bg-washed-red {
@@ -5512,7 +5509,7 @@ button, input, select, textarea {
}
.swagger-ui .hover-washed-yellow:focus, .swagger-ui .hover-washed-yellow:hover {
- color: #1c1c21ceb
+ color: #1c1c21ce
}
.swagger-ui .hover-washed-red:focus, .swagger-ui .hover-washed-red:hover {
@@ -5612,7 +5609,7 @@ button, input, select, textarea {
}
.swagger-ui .hover-bg-washed-yellow:focus, .swagger-ui .hover-bg-washed-yellow:hover {
- background-color: #1c1c21ceb
+ background-color: #1c1c21ce
}
.swagger-ui .hover-bg-washed-red:focus, .swagger-ui .hover-bg-washed-red:hover {
diff --git a/src/Atc.Rest.ApiGenerator.Framework/Resources/wwwroot/swagger-ui/SwaggerLight.css b/src/Atc.Rest.ApiGenerator.Framework/Resources/wwwroot/swagger-ui/SwaggerLight.css
index 6779f1b06..a6d881a25 100644
--- a/src/Atc.Rest.ApiGenerator.Framework/Resources/wwwroot/swagger-ui/SwaggerLight.css
+++ b/src/Atc.Rest.ApiGenerator.Framework/Resources/wwwroot/swagger-ui/SwaggerLight.css
@@ -53,7 +53,7 @@
}
.swagger-ui pre {
- font-family: monospace,monospace;
+ font-family: monospace;
font-size: 1em
}
@@ -64,8 +64,6 @@
.swagger-ui abbr[title] {
border-bottom: none;
- text-decoration: underline;
- -webkit-text-decoration: underline dotted;
text-decoration: underline dotted
}
@@ -75,7 +73,7 @@
}
.swagger-ui code, .swagger-ui kbd, .swagger-ui samp {
- font-family: monospace,monospace;
+ font-family: monospace;
font-size: 1em
}
@@ -1590,7 +1588,6 @@
.swagger-ui .pre {
overflow-x: auto;
overflow-y: hidden;
- overflow: scroll
}
.swagger-ui .top-0 {
diff --git a/src/Atc.Rest.ApiGenerator.Framework/Resources/wwwroot/swagger-ui/SwaggerLight.css.bak b/src/Atc.Rest.ApiGenerator.Framework/Resources/wwwroot/swagger-ui/SwaggerLight.css.bak
deleted file mode 100644
index f1674c184..000000000
--- a/src/Atc.Rest.ApiGenerator.Framework/Resources/wwwroot/swagger-ui/SwaggerLight.css.bak
+++ /dev/null
@@ -1,1346 +0,0 @@
-/* Inject clean Swagger Image */
-.topbar-wrapper .link {
- background: url(swagger.png);
- background-size: contain;
- height: 22px;
- width: 220px;
- background-repeat: no-repeat;
- flex: none !important;
-}
-
-/* Remove Existing Swagger/SmartBear image */
-.topbar-wrapper .link img, .topbar-wrapper .link span {
- display: none;
-}
-
-
-/* Light Mode */
-a {
- color: #8c8cfa;
-}
-
-::-webkit-scrollbar-track-piece {
- background-color: rgba(247, 247, 247, .2) !important;
-}
-
-::-webkit-scrollbar-track {
- background-color: rgba(247, 247, 247, .3) !important;
-}
-
-::-webkit-scrollbar-thumb {
- background-color: rgba(247, 247, 247, .5) !important;
-}
-
-embed[type="application/pdf"] {
- filter: invert(90%);
-}
-
-html {
- background: #f7f7f7 !important;
- box-sizing: border-box;
- filter: contrast(100%) brightness(100%) saturate(100%);
- overflow-y: scroll;
-}
-
-body {
- background: #f7f7f7;
- background-color: #f7f7f7;
- background-image: none !important;
-}
-
-button, input, select, textarea {
- background-color: #f7f7f7;
- color: #bfbfbf;
-}
-
-font, html {
- color: #bfbfbf;
-}
-
-.swagger-ui, .swagger-ui section h3 {
- color: #b5bac9;
-}
-
- .swagger-ui a {
- background-color: transparent;
- }
-
- .swagger-ui mark {
- background-color: #664b00;
- color: #bfbfbf;
- }
-
- .swagger-ui legend {
- color: inherit;
- }
-
- .swagger-ui .debug * {
- outline: #e6da99 solid 1px;
- }
-
- .swagger-ui .debug-white * {
- outline: #fff solid 1px;
- }
-
- .swagger-ui .debug-black * {
- outline: #bfbfbf solid 1px;
- }
-
- .swagger-ui .debug-grid {
- background: url() 0 0;
- }
-
- .swagger-ui .debug-grid-16 {
- background: url() 0 0;
- }
-
- .swagger-ui .debug-grid-8-solid {
- background: url() 0 0 #1c1c21;
- }
-
- .swagger-ui .debug-grid-16-solid {
- background: url() 0 0 #1c1c21;
- }
-
- .swagger-ui .b--black {
- border-color: #000;
- }
-
- .swagger-ui .b--near-black {
- border-color: #121212;
- }
-
- .swagger-ui .b--dark-gray {
- border-color: #333;
- }
-
- .swagger-ui .b--mid-gray {
- border-color: #545454;
- }
-
- .swagger-ui .b--gray {
- border-color: #787878;
- }
-
- .swagger-ui .b--silver {
- border-color: #999;
- }
-
- .swagger-ui .b--light-silver {
- border-color: #6e6e6e;
- }
-
- .swagger-ui .b--moon-gray {
- border-color: #4d4d4d;
- }
-
- .swagger-ui .b--light-gray {
- border-color: #2b2b2b;
- }
-
- .swagger-ui .b--near-white {
- border-color: #242424;
- }
-
- .swagger-ui .b--white {
- border-color: #1c1c21;
- }
-
- .swagger-ui .b--white-90 {
- border-color: rgba(28, 28, 33, .9);
- }
-
- .swagger-ui .b--white-80 {
- border-color: rgba(28, 28, 33, .8);
- }
-
- .swagger-ui .b--white-70 {
- border-color: rgba(28, 28, 33, .7);
- }
-
- .swagger-ui .b--white-60 {
- border-color: rgba(28, 28, 33, .6);
- }
-
- .swagger-ui .b--white-50 {
- border-color: rgba(28, 28, 33, .5);
- }
-
- .swagger-ui .b--white-40 {
- border-color: rgba(28, 28, 33, .4);
- }
-
- .swagger-ui .b--white-30 {
- border-color: rgba(28, 28, 33, .3);
- }
-
- .swagger-ui .b--white-20 {
- border-color: rgba(28, 28, 33, .2);
- }
-
- .swagger-ui .b--white-10 {
- border-color: rgba(28, 28, 33, .1);
- }
-
- .swagger-ui .b--white-05 {
- border-color: rgba(28, 28, 33, .05);
- }
-
- .swagger-ui .b--white-025 {
- border-color: rgba(28, 28, 33, .024);
- }
-
- .swagger-ui .b--white-0125 {
- border-color: rgba(28, 28, 33, .01);
- }
-
- .swagger-ui .b--black-90 {
- border-color: rgba(0, 0, 0, .9);
- }
-
- .swagger-ui .b--black-80 {
- border-color: rgba(0, 0, 0, .8);
- }
-
- .swagger-ui .b--black-70 {
- border-color: rgba(0, 0, 0, .7);
- }
-
- .swagger-ui .b--black-60 {
- border-color: rgba(0, 0, 0, .6);
- }
-
- .swagger-ui .b--black-50 {
- border-color: rgba(0, 0, 0, .5);
- }
-
- .swagger-ui .b--black-40 {
- border-color: rgba(0, 0, 0, .4);
- }
-
- .swagger-ui .b--black-30 {
- border-color: rgba(0, 0, 0, .3);
- }
-
- .swagger-ui .b--black-20 {
- border-color: rgba(0, 0, 0, .2);
- }
-
- .swagger-ui .b--black-10 {
- border-color: rgba(0, 0, 0, .1);
- }
-
- .swagger-ui .b--black-05 {
- border-color: rgba(0, 0, 0, .05);
- }
-
- .swagger-ui .b--black-025 {
- border-color: rgba(0, 0, 0, .024);
- }
-
- .swagger-ui .b--black-0125 {
- border-color: rgba(0, 0, 0, .01);
- }
-
- .swagger-ui .b--dark-red {
- border-color: #bc2f36;
- }
-
- .swagger-ui .b--red {
- border-color: #c83932;
- }
-
- .swagger-ui .b--light-red {
- border-color: #ab3c2b;
- }
-
- .swagger-ui .b--orange {
- border-color: #cc6e33;
- }
-
- .swagger-ui .b--purple {
- border-color: #5e2ca5;
- }
-
- .swagger-ui .b--light-purple {
- border-color: #672caf;
- }
-
- .swagger-ui .b--dark-pink {
- border-color: #ab2b81;
- }
-
- .swagger-ui .b--hot-pink {
- border-color: #c03086;
- }
-
- .swagger-ui .b--pink {
- border-color: #8f2464;
- }
-
- .swagger-ui .b--light-pink {
- border-color: #721d4d;
- }
-
- .swagger-ui .b--dark-green {
- border-color: #1c6e50;
- }
-
- .swagger-ui .b--green {
- border-color: #279b70;
- }
-
- .swagger-ui .b--light-green {
- border-color: #228762;
- }
-
- .swagger-ui .b--navy {
- border-color: #0d1d35;
- }
-
- .swagger-ui .b--dark-blue {
- border-color: #20497e;
- }
-
- .swagger-ui .b--blue {
- border-color: #4380d0;
- }
-
- .swagger-ui .b--light-blue {
- border-color: #20517e;
- }
-
- .swagger-ui .b--lightest-blue {
- border-color: #143a52;
- }
-
- .swagger-ui .b--washed-blue {
- border-color: #0c312d;
- }
-
- .swagger-ui .b--washed-green {
- border-color: #0f3d2c;
- }
-
- .swagger-ui .b--washed-red {
- border-color: #411010;
- }
-
- .swagger-ui .b--transparent {
- border-color: transparent;
- }
-
- .swagger-ui .b--gold, .swagger-ui .b--light-yellow, .swagger-ui .b--washed-yellow, .swagger-ui .b--yellow {
- border-color: #664b00;
- }
-
- .swagger-ui .shadow-1 {
- box-shadow: rgba(0, 0, 0, .2) 0 0 4px 2px;
- }
-
- .swagger-ui .shadow-2 {
- box-shadow: rgba(0, 0, 0, .2) 0 0 8px 2px;
- }
-
- .swagger-ui .shadow-3 {
- box-shadow: rgba(0, 0, 0, .2) 2px 2px 4px 2px;
- }
-
- .swagger-ui .shadow-4 {
- box-shadow: rgba(0, 0, 0, .2) 2px 2px 8px 0;
- }
-
- .swagger-ui .shadow-5 {
- box-shadow: rgba(0, 0, 0, .2) 4px 4px 8px 0;
- }
-
-@media screen and (min-width: 30em) {
- .swagger-ui .shadow-1-ns {
- box-shadow: rgba(0, 0, 0, .2) 0 0 4px 2px;
- }
-
- .swagger-ui .shadow-2-ns {
- box-shadow: rgba(0, 0, 0, .2) 0 0 8px 2px;
- }
-
- .swagger-ui .shadow-3-ns {
- box-shadow: rgba(0, 0, 0, .2) 2px 2px 4px 2px;
- }
-
- .swagger-ui .shadow-4-ns {
- box-shadow: rgba(0, 0, 0, .2) 2px 2px 8px 0;
- }
-
- .swagger-ui .shadow-5-ns {
- box-shadow: rgba(0, 0, 0, .2) 4px 4px 8px 0;
- }
-}
-
-@media screen and (max-width: 60em) and (min-width: 30em) {
- .swagger-ui .shadow-1-m {
- box-shadow: rgba(0, 0, 0, .2) 0 0 4px 2px;
- }
-
- .swagger-ui .shadow-2-m {
- box-shadow: rgba(0, 0, 0, .2) 0 0 8px 2px;
- }
-
- .swagger-ui .shadow-3-m {
- box-shadow: rgba(0, 0, 0, .2) 2px 2px 4px 2px;
- }
-
- .swagger-ui .shadow-4-m {
- box-shadow: rgba(0, 0, 0, .2) 2px 2px 8px 0;
- }
-
- .swagger-ui .shadow-5-m {
- box-shadow: rgba(0, 0, 0, .2) 4px 4px 8px 0;
- }
-}
-
-@media screen and (min-width: 60em) {
- .swagger-ui .shadow-1-l {
- box-shadow: rgba(0, 0, 0, .2) 0 0 4px 2px;
- }
-
- .swagger-ui .shadow-2-l {
- box-shadow: rgba(0, 0, 0, .2) 0 0 8px 2px;
- }
-
- .swagger-ui .shadow-3-l {
- box-shadow: rgba(0, 0, 0, .2) 2px 2px 4px 2px;
- }
-
- .swagger-ui .shadow-4-l {
- box-shadow: rgba(0, 0, 0, .2) 2px 2px 8px 0;
- }
-
- .swagger-ui .shadow-5-l {
- box-shadow: rgba(0, 0, 0, .2) 4px 4px 8px 0;
- }
-}
-
-.swagger-ui .black-05 {
- color: rgba(191, 191, 191, .05);
-}
-
-.swagger-ui .bg-black-05 {
- background-color: rgba(0, 0, 0, .05);
-}
-
-.swagger-ui .black-90, .swagger-ui .hover-black-90:focus, .swagger-ui .hover-black-90:hover {
- color: rgba(191, 191, 191, .9);
-}
-
-.swagger-ui .black-80, .swagger-ui .hover-black-80:focus, .swagger-ui .hover-black-80:hover {
- color: rgba(191, 191, 191, .8);
-}
-
-.swagger-ui .black-70, .swagger-ui .hover-black-70:focus, .swagger-ui .hover-black-70:hover {
- color: rgba(191, 191, 191, .7);
-}
-
-.swagger-ui .black-60, .swagger-ui .hover-black-60:focus, .swagger-ui .hover-black-60:hover {
- color: rgba(191, 191, 191, .6);
-}
-
-.swagger-ui .black-50, .swagger-ui .hover-black-50:focus, .swagger-ui .hover-black-50:hover {
- color: rgba(191, 191, 191, .5);
-}
-
-.swagger-ui .black-40, .swagger-ui .hover-black-40:focus, .swagger-ui .hover-black-40:hover {
- color: rgba(191, 191, 191, .4);
-}
-
-.swagger-ui .black-30, .swagger-ui .hover-black-30:focus, .swagger-ui .hover-black-30:hover {
- color: rgba(191, 191, 191, .3);
-}
-
-.swagger-ui .black-20, .swagger-ui .hover-black-20:focus, .swagger-ui .hover-black-20:hover {
- color: rgba(191, 191, 191, .2);
-}
-
-.swagger-ui .black-10, .swagger-ui .hover-black-10:focus, .swagger-ui .hover-black-10:hover {
- color: rgba(191, 191, 191, .1);
-}
-
-.swagger-ui .hover-white-90:focus, .swagger-ui .hover-white-90:hover, .swagger-ui .white-90 {
- color: rgba(247, 247, 247, .9);
-}
-
-.swagger-ui .hover-white-80:focus, .swagger-ui .hover-white-80:hover, .swagger-ui .white-80 {
- color: rgba(247, 247, 247, .8);
-}
-
-.swagger-ui .hover-white-70:focus, .swagger-ui .hover-white-70:hover, .swagger-ui .white-70 {
- color: rgba(247, 247, 247, .7);
-}
-
-.swagger-ui .hover-white-60:focus, .swagger-ui .hover-white-60:hover, .swagger-ui .white-60 {
- color: rgba(247, 247, 247, .6);
-}
-
-.swagger-ui .hover-white-50:focus, .swagger-ui .hover-white-50:hover, .swagger-ui .white-50 {
- color: rgba(247, 247, 247, .5);
-}
-
-.swagger-ui .hover-white-40:focus, .swagger-ui .hover-white-40:hover, .swagger-ui .white-40 {
- color: rgba(247, 247, 247, .4);
-}
-
-.swagger-ui .hover-white-30:focus, .swagger-ui .hover-white-30:hover, .swagger-ui .white-30 {
- color: rgba(247, 247, 247, .3);
-}
-
-.swagger-ui .hover-white-20:focus, .swagger-ui .hover-white-20:hover, .swagger-ui .white-20 {
- color: rgba(247, 247, 247, .2);
-}
-
-.swagger-ui .hover-white-10:focus, .swagger-ui .hover-white-10:hover, .swagger-ui .white-10 {
- color: rgba(247, 247, 247, .1);
-}
-
-.swagger-ui .hover-moon-gray:focus, .swagger-ui .hover-moon-gray:hover, .swagger-ui .moon-gray {
- color: #ccc;
-}
-
-.swagger-ui .hover-light-gray:focus, .swagger-ui .hover-light-gray:hover, .swagger-ui .light-gray {
- color: #ededed;
-}
-
-.swagger-ui .hover-near-white:focus, .swagger-ui .hover-near-white:hover, .swagger-ui .near-white {
- color: #f5f5f5;
-}
-
-.swagger-ui .dark-red, .swagger-ui .hover-dark-red:focus, .swagger-ui .hover-dark-red:hover {
- color: #e6999d;
-}
-
-.swagger-ui .hover-red:focus, .swagger-ui .hover-red:hover, .swagger-ui .red {
- color: #e69d99;
-}
-
-.swagger-ui .hover-light-red:focus, .swagger-ui .hover-light-red:hover, .swagger-ui .light-red {
- color: #e6a399;
-}
-
-.swagger-ui .hover-orange:focus, .swagger-ui .hover-orange:hover, .swagger-ui .orange {
- color: #e6b699;
-}
-
-.swagger-ui .gold, .swagger-ui .hover-gold:focus, .swagger-ui .hover-gold:hover {
- color: #e6d099;
-}
-
-.swagger-ui .hover-yellow:focus, .swagger-ui .hover-yellow:hover, .swagger-ui .yellow {
- color: #e6da99;
-}
-
-.swagger-ui .hover-light-yellow:focus, .swagger-ui .hover-light-yellow:hover, .swagger-ui .light-yellow {
- color: #ede6b6;
-}
-
-.swagger-ui .hover-purple:focus, .swagger-ui .hover-purple:hover, .swagger-ui .purple {
- color: #b99ae4;
-}
-
-.swagger-ui .hover-light-purple:focus, .swagger-ui .hover-light-purple:hover, .swagger-ui .light-purple {
- color: #bb99e6;
-}
-
-.swagger-ui .dark-pink, .swagger-ui .hover-dark-pink:focus, .swagger-ui .hover-dark-pink:hover {
- color: #e699cc;
-}
-
-.swagger-ui .hot-pink, .swagger-ui .hover-hot-pink:focus, .swagger-ui .hover-hot-pink:hover, .swagger-ui .hover-pink:focus, .swagger-ui .hover-pink:hover, .swagger-ui .pink {
- color: #e699c7;
-}
-
-.swagger-ui .hover-light-pink:focus, .swagger-ui .hover-light-pink:hover, .swagger-ui .light-pink {
- color: #edb6d5;
-}
-
-.swagger-ui .dark-green, .swagger-ui .green, .swagger-ui .hover-dark-green:focus, .swagger-ui .hover-dark-green:hover, .swagger-ui .hover-green:focus, .swagger-ui .hover-green:hover {
- color: #99e6c9;
-}
-
-.swagger-ui .hover-light-green:focus, .swagger-ui .hover-light-green:hover, .swagger-ui .light-green {
- color: #a1e8ce;
-}
-
-.swagger-ui .hover-navy:focus, .swagger-ui .hover-navy:hover, .swagger-ui .navy {
- color: #99b8e6;
-}
-
-.swagger-ui .blue, .swagger-ui .dark-blue, .swagger-ui .hover-blue:focus, .swagger-ui .hover-blue:hover, .swagger-ui .hover-dark-blue:focus, .swagger-ui .hover-dark-blue:hover {
- color: #99bae6;
-}
-
-.swagger-ui .hover-light-blue:focus, .swagger-ui .hover-light-blue:hover, .swagger-ui .light-blue {
- color: #a9cbea;
-}
-
-.swagger-ui .hover-lightest-blue:focus, .swagger-ui .hover-lightest-blue:hover, .swagger-ui .lightest-blue {
- color: #d6e9f5;
-}
-
-.swagger-ui .hover-washed-blue:focus, .swagger-ui .hover-washed-blue:hover, .swagger-ui .washed-blue {
- color: #f7fdfc;
-}
-
-.swagger-ui .hover-washed-green:focus, .swagger-ui .hover-washed-green:hover, .swagger-ui .washed-green {
- color: #ebfaf4;
-}
-
-.swagger-ui .hover-washed-yellow:focus, .swagger-ui .hover-washed-yellow:hover, .swagger-ui .washed-yellow {
- color: #fbf9ef;
-}
-
-.swagger-ui .hover-washed-red:focus, .swagger-ui .hover-washed-red:hover, .swagger-ui .washed-red {
- color: #f9e7e7;
-}
-
-.swagger-ui .color-inherit, .swagger-ui .hover-inherit:focus, .swagger-ui .hover-inherit:hover {
- color: inherit;
-}
-
-.swagger-ui .bg-black-90, .swagger-ui .hover-bg-black-90:focus, .swagger-ui .hover-bg-black-90:hover {
- background-color: rgba(0, 0, 0, .9);
-}
-
-.swagger-ui .bg-black-80, .swagger-ui .hover-bg-black-80:focus, .swagger-ui .hover-bg-black-80:hover {
- background-color: rgba(0, 0, 0, .8);
-}
-
-.swagger-ui .bg-black-70, .swagger-ui .hover-bg-black-70:focus, .swagger-ui .hover-bg-black-70:hover {
- background-color: rgba(0, 0, 0, .7);
-}
-
-.swagger-ui .bg-black-60, .swagger-ui .hover-bg-black-60:focus, .swagger-ui .hover-bg-black-60:hover {
- background-color: rgba(0, 0, 0, .6);
-}
-
-.swagger-ui .bg-black-50, .swagger-ui .hover-bg-black-50:focus, .swagger-ui .hover-bg-black-50:hover {
- background-color: rgba(0, 0, 0, .5);
-}
-
-.swagger-ui .bg-black-40, .swagger-ui .hover-bg-black-40:focus, .swagger-ui .hover-bg-black-40:hover {
- background-color: rgba(0, 0, 0, .4);
-}
-
-.swagger-ui .bg-black-30, .swagger-ui .hover-bg-black-30:focus, .swagger-ui .hover-bg-black-30:hover {
- background-color: rgba(0, 0, 0, .3);
-}
-
-.swagger-ui .bg-black-20, .swagger-ui .hover-bg-black-20:focus, .swagger-ui .hover-bg-black-20:hover {
- background-color: rgba(0, 0, 0, .2);
-}
-
-.swagger-ui .bg-white-90, .swagger-ui .hover-bg-white-90:focus, .swagger-ui .hover-bg-white-90:hover {
- background-color: rgba(28, 28, 33, .9);
-}
-
-.swagger-ui .bg-white-80, .swagger-ui .hover-bg-white-80:focus, .swagger-ui .hover-bg-white-80:hover {
- background-color: rgba(28, 28, 33, .8);
-}
-
-.swagger-ui .bg-white-70, .swagger-ui .hover-bg-white-70:focus, .swagger-ui .hover-bg-white-70:hover {
- background-color: rgba(28, 28, 33, .7);
-}
-
-.swagger-ui .bg-white-60, .swagger-ui .hover-bg-white-60:focus, .swagger-ui .hover-bg-white-60:hover {
- background-color: rgba(28, 28, 33, .6);
-}
-
-.swagger-ui .bg-white-50, .swagger-ui .hover-bg-white-50:focus, .swagger-ui .hover-bg-white-50:hover {
- background-color: rgba(28, 28, 33, .5);
-}
-
-.swagger-ui .bg-white-40, .swagger-ui .hover-bg-white-40:focus, .swagger-ui .hover-bg-white-40:hover {
- background-color: rgba(28, 28, 33, .4);
-}
-
-.swagger-ui .bg-white-30, .swagger-ui .hover-bg-white-30:focus, .swagger-ui .hover-bg-white-30:hover {
- background-color: rgba(28, 28, 33, .3);
-}
-
-.swagger-ui .bg-white-20, .swagger-ui .hover-bg-white-20:focus, .swagger-ui .hover-bg-white-20:hover {
- background-color: rgba(28, 28, 33, .2);
-}
-
-.swagger-ui .bg-black, .swagger-ui .hover-bg-black:focus, .swagger-ui .hover-bg-black:hover {
- background-color: #000;
-}
-
-.swagger-ui .bg-near-black, .swagger-ui .hover-bg-near-black:focus, .swagger-ui .hover-bg-near-black:hover {
- background-color: #121212;
-}
-
-.swagger-ui .bg-dark-gray, .swagger-ui .hover-bg-dark-gray:focus, .swagger-ui .hover-bg-dark-gray:hover {
- background-color: #333;
-}
-
-.swagger-ui .bg-mid-gray, .swagger-ui .hover-bg-mid-gray:focus, .swagger-ui .hover-bg-mid-gray:hover {
- background-color: #545454;
-}
-
-.swagger-ui .bg-gray, .swagger-ui .hover-bg-gray:focus, .swagger-ui .hover-bg-gray:hover {
- background-color: #787878;
-}
-
-.swagger-ui .bg-silver, .swagger-ui .hover-bg-silver:focus, .swagger-ui .hover-bg-silver:hover {
- background-color: #999;
-}
-
-.swagger-ui .bg-white, .swagger-ui .hover-bg-white:focus, .swagger-ui .hover-bg-white:hover {
- background-color: #1c1c21;
-}
-
-.swagger-ui .bg-transparent, .swagger-ui .hover-bg-transparent:focus, .swagger-ui .hover-bg-transparent:hover {
- background-color: transparent;
-}
-
-.swagger-ui .bg-dark-red, .swagger-ui .hover-bg-dark-red:focus, .swagger-ui .hover-bg-dark-red:hover {
- background-color: #bc2f36;
-}
-
-.swagger-ui .bg-red, .swagger-ui .hover-bg-red:focus, .swagger-ui .hover-bg-red:hover {
- background-color: #c83932;
-}
-
-.swagger-ui .bg-light-red, .swagger-ui .hover-bg-light-red:focus, .swagger-ui .hover-bg-light-red:hover {
- background-color: #ab3c2b;
-}
-
-.swagger-ui .bg-orange, .swagger-ui .hover-bg-orange:focus, .swagger-ui .hover-bg-orange:hover {
- background-color: #cc6e33;
-}
-
-.swagger-ui .bg-gold, .swagger-ui .bg-light-yellow, .swagger-ui .bg-washed-yellow, .swagger-ui .bg-yellow, .swagger-ui .hover-bg-gold:focus, .swagger-ui .hover-bg-gold:hover, .swagger-ui .hover-bg-light-yellow:focus, .swagger-ui .hover-bg-light-yellow:hover, .swagger-ui .hover-bg-washed-yellow:focus, .swagger-ui .hover-bg-washed-yellow:hover, .swagger-ui .hover-bg-yellow:focus, .swagger-ui .hover-bg-yellow:hover {
- background-color: #664b00;
-}
-
-.swagger-ui .bg-purple, .swagger-ui .hover-bg-purple:focus, .swagger-ui .hover-bg-purple:hover {
- background-color: #5e2ca5;
-}
-
-.swagger-ui .bg-light-purple, .swagger-ui .hover-bg-light-purple:focus, .swagger-ui .hover-bg-light-purple:hover {
- background-color: #672caf;
-}
-
-.swagger-ui .bg-dark-pink, .swagger-ui .hover-bg-dark-pink:focus, .swagger-ui .hover-bg-dark-pink:hover {
- background-color: #ab2b81;
-}
-
-.swagger-ui .bg-hot-pink, .swagger-ui .hover-bg-hot-pink:focus, .swagger-ui .hover-bg-hot-pink:hover {
- background-color: #c03086;
-}
-
-.swagger-ui .bg-pink, .swagger-ui .hover-bg-pink:focus, .swagger-ui .hover-bg-pink:hover {
- background-color: #8f2464;
-}
-
-.swagger-ui .bg-light-pink, .swagger-ui .hover-bg-light-pink:focus, .swagger-ui .hover-bg-light-pink:hover {
- background-color: #721d4d;
-}
-
-.swagger-ui .bg-dark-green, .swagger-ui .hover-bg-dark-green:focus, .swagger-ui .hover-bg-dark-green:hover {
- background-color: #1c6e50;
-}
-
-.swagger-ui .bg-green, .swagger-ui .hover-bg-green:focus, .swagger-ui .hover-bg-green:hover {
- background-color: #279b70;
-}
-
-.swagger-ui .bg-light-green, .swagger-ui .hover-bg-light-green:focus, .swagger-ui .hover-bg-light-green:hover {
- background-color: #228762;
-}
-
-.swagger-ui .bg-navy, .swagger-ui .hover-bg-navy:focus, .swagger-ui .hover-bg-navy:hover {
- background-color: #0d1d35;
-}
-
-.swagger-ui .bg-dark-blue, .swagger-ui .hover-bg-dark-blue:focus, .swagger-ui .hover-bg-dark-blue:hover {
- background-color: #20497e;
-}
-
-.swagger-ui .bg-blue, .swagger-ui .hover-bg-blue:focus, .swagger-ui .hover-bg-blue:hover {
- background-color: #4380d0;
-}
-
-.swagger-ui .bg-light-blue, .swagger-ui .hover-bg-light-blue:focus, .swagger-ui .hover-bg-light-blue:hover {
- background-color: #20517e;
-}
-
-.swagger-ui .bg-lightest-blue, .swagger-ui .hover-bg-lightest-blue:focus, .swagger-ui .hover-bg-lightest-blue:hover {
- background-color: #143a52;
-}
-
-.swagger-ui .bg-washed-blue, .swagger-ui .hover-bg-washed-blue:focus, .swagger-ui .hover-bg-washed-blue:hover {
- background-color: #0c312d;
-}
-
-.swagger-ui .bg-washed-green, .swagger-ui .hover-bg-washed-green:focus, .swagger-ui .hover-bg-washed-green:hover {
- background-color: #0f3d2c;
-}
-
-.swagger-ui .bg-washed-red, .swagger-ui .hover-bg-washed-red:focus, .swagger-ui .hover-bg-washed-red:hover {
- background-color: #411010;
-}
-
-.swagger-ui .bg-inherit, .swagger-ui .hover-bg-inherit:focus, .swagger-ui .hover-bg-inherit:hover {
- background-color: inherit;
-}
-
-.swagger-ui .shadow-hover {
- transition: all .5s cubic-bezier(.165, .84, .44, 1) 0s;
-}
-
- .swagger-ui .shadow-hover::after {
- border-radius: inherit;
- box-shadow: rgba(0, 0, 0, .2) 0 0 16px 2px;
- content: "";
- height: 100%;
- left: 0;
- opacity: 0;
- position: absolute;
- top: 0;
- transition: opacity .5s cubic-bezier(.165, .84, .44, 1) 0s;
- width: 100%;
- z-index: -1;
- }
-
-.swagger-ui .bg-animate, .swagger-ui .bg-animate:focus, .swagger-ui .bg-animate:hover {
- transition: background-color .15s ease-in-out 0s;
-}
-
-.swagger-ui .nested-links a {
- color: #99bae6;
- transition: color .15s ease-in 0s;
-}
-
- .swagger-ui .nested-links a:focus, .swagger-ui .nested-links a:hover {
- color: #a9cbea;
- transition: color .15s ease-in 0s;
- }
-
-.swagger-ui .opblock-tag {
- border-bottom: 1px solid rgba(58, 64, 80, .3);
- color: #b5bac9;
- transition: all .2s ease 0s;
-}
-
- .swagger-ui .opblock-tag svg, .swagger-ui section.models h4 svg {
- transition: all .4s ease 0s;
- }
-
-.swagger-ui .opblock {
- border: 1px solid #000;
- border-radius: 4px;
- box-shadow: rgba(0, 0, 0, .19) 0 0 3px;
- margin: 0 0 15px;
-}
-
- .swagger-ui .opblock .tab-header .tab-item.active h4 span::after {
- background: gray;
- }
-
- .swagger-ui .opblock.is-open .opblock-summary {
- border-bottom: 1px solid #000;
- }
-
- .swagger-ui .opblock .opblock-section-header {
- background: rgba(28, 28, 33, .8);
- box-shadow: rgba(0, 0, 0, .1) 0 1px 2px;
- }
-
- .swagger-ui .opblock .opblock-section-header > label > span {
- padding: 0 10px 0 0;
- }
-
- .swagger-ui .opblock .opblock-summary-method {
- background: #000;
- color: #fff;
- text-shadow: rgba(0, 0, 0, .1) 0 1px 0;
- }
-
- .swagger-ui .opblock.opblock-post {
- background: rgba(72, 203, 144, .1);
- border-color: #48cb90;
- }
-
- .swagger-ui .opblock.opblock-post .opblock-summary-method, .swagger-ui .opblock.opblock-post .tab-header .tab-item.active h4 span::after {
- background: #48cb90;
- }
-
- .swagger-ui .opblock.opblock-post .opblock-summary {
- border-color: #48cb90;
- }
-
- .swagger-ui .opblock.opblock-put {
- background: rgba(213, 157, 88, .1);
- border-color: #d59d58;
- }
-
- .swagger-ui .opblock.opblock-put .opblock-summary-method, .swagger-ui .opblock.opblock-put .tab-header .tab-item.active h4 span::after {
- background: #d59d58;
- }
-
- .swagger-ui .opblock.opblock-put .opblock-summary {
- border-color: #d59d58;
- }
-
- .swagger-ui .opblock.opblock-delete {
- background: rgba(200, 50, 50, .1);
- border-color: #c83232;
- }
-
- .swagger-ui .opblock.opblock-delete .opblock-summary-method, .swagger-ui .opblock.opblock-delete .tab-header .tab-item.active h4 span::after {
- background: #c83232;
- }
-
- .swagger-ui .opblock.opblock-delete .opblock-summary {
- border-color: #c83232;
- }
-
- .swagger-ui .opblock.opblock-get {
- background: rgba(42, 105, 167, .1);
- border-color: #2a69a7;
- }
-
- .swagger-ui .opblock.opblock-get .opblock-summary-method, .swagger-ui .opblock.opblock-get .tab-header .tab-item.active h4 span::after {
- background: #2a69a7;
- }
-
- .swagger-ui .opblock.opblock-get .opblock-summary {
- border-color: #2a69a7;
- }
-
- .swagger-ui .opblock.opblock-patch {
- background: rgba(92, 214, 188, .1);
- border-color: #5cd6bc;
- }
-
- .swagger-ui .opblock.opblock-patch .opblock-summary-method, .swagger-ui .opblock.opblock-patch .tab-header .tab-item.active h4 span::after {
- background: #5cd6bc;
- }
-
- .swagger-ui .opblock.opblock-patch .opblock-summary {
- border-color: #5cd6bc;
- }
-
- .swagger-ui .opblock.opblock-head {
- background: rgba(140, 63, 207, .1);
- border-color: #8c3fcf;
- }
-
- .swagger-ui .opblock.opblock-head .opblock-summary-method, .swagger-ui .opblock.opblock-head .tab-header .tab-item.active h4 span::after {
- background: #8c3fcf;
- }
-
- .swagger-ui .opblock.opblock-head .opblock-summary {
- border-color: #8c3fcf;
- }
-
- .swagger-ui .opblock.opblock-options {
- background: rgba(36, 89, 143, .1);
- border-color: #24598f;
- }
-
- .swagger-ui .opblock.opblock-options .opblock-summary-method, .swagger-ui .opblock.opblock-options .tab-header .tab-item.active h4 span::after {
- background: #24598f;
- }
-
- .swagger-ui .opblock.opblock-options .opblock-summary {
- border-color: #24598f;
- }
-
- .swagger-ui .opblock.opblock-deprecated {
- background: rgba(46, 46, 46, .1);
- border-color: #2e2e2e;
- opacity: .6;
- }
-
- .swagger-ui .opblock.opblock-deprecated .opblock-summary-method, .swagger-ui .opblock.opblock-deprecated .tab-header .tab-item.active h4 span::after {
- background: #2e2e2e;
- }
-
- .swagger-ui .opblock.opblock-deprecated .opblock-summary {
- border-color: #2e2e2e;
- }
-
-.swagger-ui .filter .operation-filter-input {
- border: 2px solid #2b3446;
-}
-
-.swagger-ui .tab li:first-of-type::after {
- background: rgba(0, 0, 0, .2);
-}
-
-.swagger-ui .download-contents {
- background: #7c8192;
- color: #fff;
-}
-
-.swagger-ui .scheme-container {
- background: #1c1c21;
- box-shadow: rgba(0, 0, 0, .15) 0 1px 2px 0;
-}
-
-.swagger-ui .loading-container .loading::before {
- animation: 1s linear 0s infinite normal none running rotation, .5s ease 0s 1 normal none running opacity;
- border-color: rgba(0, 0, 0, .6) rgba(84, 84, 84, .1) rgba(84, 84, 84, .1);
-}
-
-.swagger-ui .response-control-media-type--accept-controller select {
- border-color: #196619;
-}
-
-.swagger-ui .response-control-media-type__accept-message {
- color: #99e699;
-}
-
-.swagger-ui .version-pragma__message code {
- background-color: #3b3b3b;
-}
-
-.swagger-ui .btn {
- background: 0 0;
- border: 2px solid gray;
- box-shadow: rgba(0, 0, 0, .1) 0 1px 2px;
- color: #b5bac9;
-}
-
- .swagger-ui .btn:hover {
- box-shadow: rgba(0, 0, 0, .3) 0 0 5px;
- }
-
- .swagger-ui .btn.authorize, .swagger-ui .btn.cancel {
- background-color: transparent;
- border-color: #a72a2a;
- color: #e69999;
- }
-
- .swagger-ui .btn.authorize {
- border-color: #48cb90;
- color: #9ce3c3;
- }
-
- .swagger-ui .btn.authorize svg {
- fill: #9ce3c3;
- }
-
- .swagger-ui .btn.execute {
- background-color: #5892d5;
- border-color: #5892d5;
- color: #fff;
- }
-
-.swagger-ui .copy-to-clipboard {
- background: #7c8192;
-}
-
- .swagger-ui .copy-to-clipboard button {
- background: url("data:image/svg+xml;charset=utf-8,") 50% center no-repeat;
- }
-
-.swagger-ui select {
- background: url("data:image/svg+xml;charset=utf-8,") right 10px center/20px no-repeat #212121;
- background: url() right 10px center/20px no-repeat #1c1c21;
- border: 2px solid #41444e;
-}
-
- .swagger-ui select[multiple] {
- background: #212121;
- }
-
- .swagger-ui button.invalid, .swagger-ui input[type=email].invalid, .swagger-ui input[type=file].invalid, .swagger-ui input[type=password].invalid, .swagger-ui input[type=search].invalid, .swagger-ui input[type=text].invalid, .swagger-ui select.invalid, .swagger-ui textarea.invalid {
- background: #390e0e;
- border-color: #c83232;
- }
-
-.swagger-ui input[type=email], .swagger-ui input[type=file], .swagger-ui input[type=password], .swagger-ui input[type=search], .swagger-ui input[type=text], .swagger-ui textarea {
- background: #1c1c21;
- border: 1px solid #404040;
-}
-
-.swagger-ui textarea {
- background: rgba(28, 28, 33, .8);
- color: #b5bac9;
-}
-
-.swagger-ui input[disabled], .swagger-ui select[disabled] {
- background-color: #f7f7f7;
- color: #bfbfbf;
-}
-
-.swagger-ui textarea[disabled] {
- background-color: #41444e;
- color: #fff;
-}
-
-.swagger-ui select[disabled] {
- border-color: #878787;
-}
-
-.swagger-ui textarea:focus {
- border: 2px solid #2a69a7;
-}
-
-.swagger-ui .checkbox input[type=checkbox] + label > .item {
- background: #303030;
- box-shadow: #303030 0 0 0 2px;
-}
-
-.swagger-ui .checkbox input[type=checkbox]:checked + label > .item {
- background: url("data:image/svg+xml;charset=utf-8,") 50% center no-repeat #303030;
-}
-
-.swagger-ui .dialog-ux .backdrop-ux {
- background: rgba(0, 0, 0, .8);
-}
-
-.swagger-ui .dialog-ux .modal-ux {
- background: #1c1c21;
- border: 1px solid #2e2e2e;
- box-shadow: rgba(0, 0, 0, .2) 0 10px 30px 0;
-}
-
-.swagger-ui .dialog-ux .modal-ux-header .close-modal {
- background: 0 0;
-}
-
-.swagger-ui .model .deprecated span, .swagger-ui .model .deprecated td {
- color: #bfbfbf !important;
-}
-
-.swagger-ui .model-toggle::after {
- background: url("data:image/svg+xml;charset=utf-8,") 50% center/100% no-repeat;
-}
-
-.swagger-ui .model-hint {
- background: rgba(0, 0, 0, .7);
- color: #ebebeb;
-}
-
-.swagger-ui section.models {
- border: 1px solid rgba(58, 64, 80, .3);
-}
-
- .swagger-ui section.models.is-open h4 {
- border-bottom: 1px solid rgba(58, 64, 80, .3);
- }
-
- .swagger-ui section.models .model-container {
- background: rgba(0, 0, 0, .05);
- }
-
- .swagger-ui section.models .model-container:hover {
- background: rgba(0, 0, 0, .07);
- }
-
-.swagger-ui .model-box {
- background: rgba(0, 0, 0, .1);
-}
-
-.swagger-ui .prop-type {
- color: #aaaad4;
-}
-
-.swagger-ui table thead tr td, .swagger-ui table thead tr th {
- border-bottom: 1px solid rgba(58, 64, 80, .2);
- color: #b5bac9;
-}
-
-.swagger-ui .parameter__name.required::after {
- color: rgba(230, 153, 153, .6);
-}
-
-.swagger-ui .topbar .download-url-wrapper .select-label {
- color: #f0f0f0;
-}
-
-.swagger-ui .topbar .download-url-wrapper .download-url-button {
- background: #63a040;
- color: #fff;
-}
-
-.swagger-ui .info .title small {
- background: #7c8492;
-}
-
- .swagger-ui .info .title small.version-stamp {
- background-color: #7a9b27;
- }
-
-.swagger-ui .auth-container .errors {
- background-color: #350d0d;
- color: #b5bac9;
-}
-
-.swagger-ui .errors-wrapper {
- background: rgba(200, 50, 50, .1);
- border: 2px solid #c83232;
-}
-
-.swagger-ui .markdown code, .swagger-ui .renderedmarkdown code {
- background: rgba(0, 0, 0, .05);
- color: #c299e6;
-}
-
-.swagger-ui .model-toggle:after {
- background: url() 50% no-repeat;
-}
-
-.swagger-ui .expand-operation svg, .swagger-ui section.models h4 svg {
- fill: #fff;
-}
-
-::-webkit-scrollbar-track {
- background-color: #646464 !important;
-}
-
-::-webkit-scrollbar-thumb {
- background-color: #242424 !important;
- border: 2px solid #3e4346 !important;
-}
-
-::-webkit-scrollbar-button:vertical:start:decrement {
- background: linear-gradient(130deg, #696969 40%, rgba(255, 0, 0, 0) 41%), linear-gradient(230deg, #696969 40%, transparent 41%), linear-gradient(0deg, #696969 40%, transparent 31%);
- background-color: #b6b6b6;
-}
-
-::-webkit-scrollbar-button:vertical:end:increment {
- background: linear-gradient(310deg, #696969 40%, transparent 41%), linear-gradient(50deg, #696969 40%, transparent 41%), linear-gradient(180deg, #696969 40%, transparent 31%);
- background-color: #b6b6b6;
-}
-
-::-webkit-scrollbar-button:horizontal:end:increment {
- background: linear-gradient(210deg, #696969 40%, transparent 41%), linear-gradient(330deg, #696969 40%, transparent 41%), linear-gradient(90deg, #696969 30%, transparent 31%);
- background-color: #b6b6b6;
-}
-
-::-webkit-scrollbar-button:horizontal:start:decrement {
- background: linear-gradient(30deg, #696969 40%, transparent 41%), linear-gradient(150deg, #696969 40%, transparent 41%), linear-gradient(270deg, #696969 30%, transparent 31%);
- background-color: #b6b6b6;
-}
-
-::-webkit-scrollbar-button, ::-webkit-scrollbar-track-piece {
- background-color: #3e4346 !important;
-}
-
-.swagger-ui .black, .swagger-ui .checkbox, .swagger-ui .dark-gray, .swagger-ui .download-url-wrapper .loading, .swagger-ui .errors-wrapper .errors small, .swagger-ui .fallback, .swagger-ui .filter .loading, .swagger-ui .gray, .swagger-ui .hover-black:focus, .swagger-ui .hover-black:hover, .swagger-ui .hover-dark-gray:focus, .swagger-ui .hover-dark-gray:hover, .swagger-ui .hover-gray:focus, .swagger-ui .hover-gray:hover, .swagger-ui .hover-light-silver:focus, .swagger-ui .hover-light-silver:hover, .swagger-ui .hover-mid-gray:focus, .swagger-ui .hover-mid-gray:hover, .swagger-ui .hover-near-black:focus, .swagger-ui .hover-near-black:hover, .swagger-ui .hover-silver:focus, .swagger-ui .hover-silver:hover, .swagger-ui .light-silver, .swagger-ui .markdown pre, .swagger-ui .mid-gray, .swagger-ui .model .property, .swagger-ui .model .property.primitive, .swagger-ui .model-title, .swagger-ui .near-black, .swagger-ui .parameter__extension, .swagger-ui .parameter__in, .swagger-ui .prop-format, .swagger-ui .renderedmarkdown pre, .swagger-ui .response-col_links .response-undocumented, .swagger-ui .response-col_status .response-undocumented, .swagger-ui .silver, .swagger-ui section.models h4, .swagger-ui section.models h5, .swagger-ui span.token-not-formatted, .swagger-ui span.token-string, .swagger-ui table.headers .header-example, .swagger-ui table.model tr.description, .swagger-ui table.model tr.extension {
- color: #bfbfbf;
-}
-
-.swagger-ui .hover-white:focus, .swagger-ui .hover-white:hover, .swagger-ui .info .title small pre, .swagger-ui .topbar a, .swagger-ui .white {
- color: #fff;
-}
-
-.swagger-ui .bg-black-10, .swagger-ui .hover-bg-black-10:focus, .swagger-ui .hover-bg-black-10:hover, .swagger-ui .stripe-dark:nth-child(2n + 1) {
- background-color: rgba(0, 0, 0, .1);
-}
-
-.swagger-ui .bg-white-10, .swagger-ui .hover-bg-white-10:focus, .swagger-ui .hover-bg-white-10:hover, .swagger-ui .stripe-light:nth-child(2n + 1) {
- background-color: rgba(28, 28, 33, .1);
-}
-
-.swagger-ui .bg-light-silver, .swagger-ui .hover-bg-light-silver:focus, .swagger-ui .hover-bg-light-silver:hover, .swagger-ui .striped--light-silver:nth-child(2n + 1) {
- background-color: #6e6e6e;
-}
-
-.swagger-ui .bg-moon-gray, .swagger-ui .hover-bg-moon-gray:focus, .swagger-ui .hover-bg-moon-gray:hover, .swagger-ui .striped--moon-gray:nth-child(2n + 1) {
- background-color: #4d4d4d;
-}
-
-.swagger-ui .bg-light-gray, .swagger-ui .hover-bg-light-gray:focus, .swagger-ui .hover-bg-light-gray:hover, .swagger-ui .striped--light-gray:nth-child(2n + 1) {
- background-color: #2b2b2b;
-}
-
-.swagger-ui .bg-near-white, .swagger-ui .hover-bg-near-white:focus, .swagger-ui .hover-bg-near-white:hover, .swagger-ui .striped--near-white:nth-child(2n + 1) {
- background-color: #242424;
-}
-
-.swagger-ui .opblock-tag:hover, .swagger-ui section.models h4:hover {
- background: rgba(0, 0, 0, .02);
-}
-
-.swagger-ui .checkbox p, .swagger-ui .dialog-ux .modal-ux-content h4, .swagger-ui .dialog-ux .modal-ux-content p, .swagger-ui .dialog-ux .modal-ux-header h3, .swagger-ui .errors-wrapper .errors h4, .swagger-ui .errors-wrapper hgroup h4, .swagger-ui .info .base-url, .swagger-ui .info .title, .swagger-ui .info h1, .swagger-ui .info h2, .swagger-ui .info h3, .swagger-ui .info h4, .swagger-ui .info h5, .swagger-ui .info li, .swagger-ui .info p, .swagger-ui .info table, .swagger-ui .loading-container .loading::after, .swagger-ui .model, .swagger-ui .opblock .opblock-section-header h4, .swagger-ui .opblock .opblock-section-header > label, .swagger-ui .opblock .opblock-summary-description, .swagger-ui .opblock .opblock-summary-operation-id, .swagger-ui .opblock .opblock-summary-path, .swagger-ui .opblock .opblock-summary-path__deprecated, .swagger-ui .opblock-description-wrapper, .swagger-ui .opblock-description-wrapper h4, .swagger-ui .opblock-description-wrapper p, .swagger-ui .opblock-external-docs-wrapper, .swagger-ui .opblock-external-docs-wrapper h4, .swagger-ui .opblock-external-docs-wrapper p, .swagger-ui .opblock-tag small, .swagger-ui .opblock-title_normal, .swagger-ui .opblock-title_normal h4, .swagger-ui .opblock-title_normal p, .swagger-ui .parameter__name, .swagger-ui .parameter__type, .swagger-ui .response-col_links, .swagger-ui .response-col_status, .swagger-ui .responses-inner h4, .swagger-ui .responses-inner h5, .swagger-ui .scheme-container .schemes > label, .swagger-ui .scopes h2, .swagger-ui .servers > label, .swagger-ui .tab li, .swagger-ui label, .swagger-ui select, .swagger-ui table.headers td {
- color: #b5bac9;
-}
-
- .swagger-ui .download-url-wrapper .failed, .swagger-ui .filter .failed, .swagger-ui .model-deprecated-warning, .swagger-ui .parameter__deprecated, .swagger-ui .parameter__name.required span, .swagger-ui table.model tr.property-row .star {
- color: #e69999;
- }
-
-.swagger-ui .opblock-body pre.microlight, .swagger-ui textarea.curl {
- background: #41444e;
- border-radius: 4px;
- color: #fff;
-}
-
-.swagger-ui .expand-methods svg, .swagger-ui .expand-methods:hover svg {
- fill: #bfbfbf;
-}
-
-.swagger-ui .auth-container, .swagger-ui .dialog-ux .modal-ux-header {
- border-bottom: 1px solid #2e2e2e;
-}
-
-.swagger-ui .topbar .download-url-wrapper .select-label select, .swagger-ui .topbar .download-url-wrapper input[type=text] {
- border: 2px solid #63a040;
-}
-
-.swagger-ui .info a, .swagger-ui .info a:hover, .swagger-ui .scopes h2 a {
- color: #99bde6;
-}
-
-/* Dark Scrollbar */
-::-webkit-scrollbar {
- width: 14px;
- height: 14px;
-}
-
-::-webkit-scrollbar-button {
- background-color: #3e4346 !important;
-}
-
-::-webkit-scrollbar-track {
- background-color: #646464 !important;
-}
-
-::-webkit-scrollbar-track-piece {
- background-color: #3e4346 !important;
-}
-
-::-webkit-scrollbar-thumb {
- height: 50px;
- background-color: #242424 !important;
- border: 2px solid #3e4346 !important;
-}
-
-::-webkit-scrollbar-corner {
-}
-
-::-webkit-resizer {
-}
-
-::-webkit-scrollbar-button:vertical:start:decrement {
- background: linear-gradient(130deg, #696969 40%, rgba(255, 0, 0, 0) 41%), linear-gradient(230deg, #696969 40%, rgba(0, 0, 0, 0) 41%), linear-gradient(0deg, #696969 40%, rgba(0, 0, 0, 0) 31%);
- background-color: #b6b6b6;
-}
-
-::-webkit-scrollbar-button:vertical:end:increment {
- background: linear-gradient(310deg, #696969 40%, rgba(0, 0, 0, 0) 41%), linear-gradient(50deg, #696969 40%, rgba(0, 0, 0, 0) 41%), linear-gradient(180deg, #696969 40%, rgba(0, 0, 0, 0) 31%);
- background-color: #b6b6b6;
-}
-
-::-webkit-scrollbar-button:horizontal:end:increment {
- background: linear-gradient(210deg, #696969 40%, rgba(0, 0, 0, 0) 41%), linear-gradient(330deg, #696969 40%, rgba(0, 0, 0, 0) 41%), linear-gradient(90deg, #696969 30%, rgba(0, 0, 0, 0) 31%);
- background-color: #b6b6b6;
-}
-
-::-webkit-scrollbar-button:horizontal:start:decrement {
- background: linear-gradient(30deg, #696969 40%, rgba(0, 0, 0, 0) 41%), linear-gradient(150deg, #696969 40%, rgba(0, 0, 0, 0) 41%), linear-gradient(270deg, #696969 30%, rgba(0, 0, 0, 0) 31%);
- background-color: #b6b6b6;
-}
diff --git a/src/Atc.Rest.ApiGenerator.Framework/Resources/wwwroot/swagger-ui/main.js b/src/Atc.Rest.ApiGenerator.Framework/Resources/wwwroot/swagger-ui/main.js
index a07b5763b..1af0dc39b 100644
--- a/src/Atc.Rest.ApiGenerator.Framework/Resources/wwwroot/swagger-ui/main.js
+++ b/src/Atc.Rest.ApiGenerator.Framework/Resources/wwwroot/swagger-ui/main.js
@@ -1,4 +1,4 @@
-var link = document.querySelector("link[rel*='icon']") || document.createElement("link");
+let link = document.querySelector("link[rel*='icon']") || document.createElement("link");
link.type = "image/x-icon";
link.rel = "shortcut icon";
link.href = "/favicon.ico";
diff --git a/src/Atc.Rest.ApiGenerator.Framework/Settings/GeneratorSettings.cs b/src/Atc.Rest.ApiGenerator.Framework/Settings/GeneratorSettings.cs
new file mode 100644
index 000000000..b71b4f525
--- /dev/null
+++ b/src/Atc.Rest.ApiGenerator.Framework/Settings/GeneratorSettings.cs
@@ -0,0 +1,27 @@
+namespace Atc.Rest.ApiGenerator.Framework.Settings;
+
+public class GeneratorSettings(
+ Version version,
+ string projectName,
+ DirectoryInfo projectPath)
+{
+ public Version Version { get; private set; } = version;
+
+ public string ProjectName { get; private set; } = projectName;
+
+ public DirectoryInfo ProjectPath { get; private set; } = projectPath;
+
+ public string EndpointsLocation { get; set; } = ContentGeneratorConstants.Endpoints;
+
+ public string ContractsLocation { get; set; } = ContentGeneratorConstants.Contracts;
+
+ public string HandlersLocation { get; set; } = ContentGeneratorConstants.Handlers;
+
+ public bool UsePartialClassForContracts { get; set; }
+
+ public bool UsePartialClassForEndpoints { get; set; }
+
+ public bool UseProblemDetailsAsDefaultResponseBody { get; set; }
+
+ public bool IncludeDeprecatedOperations { get; set; }
+}
\ No newline at end of file
diff --git a/src/Atc.Rest.ApiGenerator/Factories/GeneratorSettingsFactory.cs b/src/Atc.Rest.ApiGenerator/Factories/GeneratorSettingsFactory.cs
new file mode 100644
index 000000000..eb2fee70b
--- /dev/null
+++ b/src/Atc.Rest.ApiGenerator/Factories/GeneratorSettingsFactory.cs
@@ -0,0 +1,42 @@
+namespace Atc.Rest.ApiGenerator.Factories;
+
+public static class GeneratorSettingsFactory
+{
+ public static GeneratorSettings Create(
+ Version version,
+ string projectName,
+ DirectoryInfo projectPath,
+ ApiOptionsGenerator apiOptionsGenerator,
+ bool includeDeprecatedOperations)
+ {
+ ArgumentNullException.ThrowIfNull(apiOptionsGenerator);
+
+ var generatorSettings = new GeneratorSettings(
+ version,
+ projectName,
+ projectPath)
+ {
+ UseProblemDetailsAsDefaultResponseBody = apiOptionsGenerator.Response.UseProblemDetailsAsDefaultBody,
+ UsePartialClassForContracts = apiOptionsGenerator.UsePartialClassForContracts,
+ UsePartialClassForEndpoints = apiOptionsGenerator.UsePartialClassForEndpoints,
+ IncludeDeprecatedOperations = includeDeprecatedOperations,
+ };
+
+ if (!string.IsNullOrEmpty(apiOptionsGenerator.EndpointsLocation))
+ {
+ generatorSettings.EndpointsLocation = apiOptionsGenerator.EndpointsLocation;
+ }
+
+ if (!string.IsNullOrEmpty(apiOptionsGenerator.ContractsLocation))
+ {
+ generatorSettings.ContractsLocation = apiOptionsGenerator.ContractsLocation;
+ }
+
+ if (!string.IsNullOrEmpty(apiOptionsGenerator.HandlersLocation))
+ {
+ generatorSettings.HandlersLocation = apiOptionsGenerator.HandlersLocation;
+ }
+
+ return generatorSettings;
+ }
+}
\ No newline at end of file
diff --git a/src/Atc.Rest.ApiGenerator/Generators/ClientCSharpApiGenerator.cs b/src/Atc.Rest.ApiGenerator/Generators/ClientCSharpApiGenerator.cs
index 65915a1e1..80865331a 100644
--- a/src/Atc.Rest.ApiGenerator/Generators/ClientCSharpApiGenerator.cs
+++ b/src/Atc.Rest.ApiGenerator/Generators/ClientCSharpApiGenerator.cs
@@ -23,26 +23,24 @@ public ClientCSharpApiGenerator(
var operationSchemaMappings = apiOperationExtractor.Extract(projectOptions.Document);
- clientCSharpApiGenerator = new Client.CSharp.ProjectGenerator.ClientCSharpApiGenerator(
- loggerFactory,
- nugetPackageReferenceProvider,
+ var generatorSettings = GeneratorSettingsFactory.Create(
projectOptions.ApiGeneratorVersion,
projectOptions.ProjectName,
projectOptions.PathForSrcGenerate,
+ projectOptions.ApiOptions.Generator,
+ projectOptions.ApiOptions.IncludeDeprecatedOperations);
+
+ clientCSharpApiGenerator = new Client.CSharp.ProjectGenerator.ClientCSharpApiGenerator(
+ loggerFactory,
+ nugetPackageReferenceProvider,
projectOptions.Document,
operationSchemaMappings,
- projectOptions.ApiOptions.Generator.Response.UseProblemDetailsAsDefaultBody,
- projectOptions.ApiOptions.Generator.IncludeDeprecated,
+ generatorSettings,
projectOptions.ApiOptions.Generator.Response.CustomErrorResponseModel);
if (projectOptions.ApiOptions.Generator.Client is not null)
{
clientCSharpApiGenerator.HttpClientName = projectOptions.ApiOptions.Generator.Client.HttpClientName;
-
- if (!string.IsNullOrEmpty(projectOptions.ApiOptions.Generator.Client.FolderName))
- {
- clientCSharpApiGenerator.ClientFolderName = projectOptions.ApiOptions.Generator.Client.FolderName;
- }
}
}
diff --git a/src/Atc.Rest.ApiGenerator/Generators/ServerApiGenerator.cs b/src/Atc.Rest.ApiGenerator/Generators/ServerApiGenerator.cs
index 4ed705081..cdae8e65e 100644
--- a/src/Atc.Rest.ApiGenerator/Generators/ServerApiGenerator.cs
+++ b/src/Atc.Rest.ApiGenerator/Generators/ServerApiGenerator.cs
@@ -29,29 +29,28 @@ public ServerApiGenerator(
var operationSchemaMappings = apiOperationExtractor.Extract(projectOptions.Document);
- serverApiGeneratorMvc = new Framework.Mvc.ProjectGenerator.ServerApiGenerator(
- loggerFactory,
- nugetPackageReferenceProvider,
+ var generatorSettings = GeneratorSettingsFactory.Create(
projectOptions.ApiGeneratorVersion,
projectOptions.ProjectName,
projectOptions.PathForSrcGenerate,
+ projectOptions.ApiOptions.Generator,
+ projectOptions.ApiOptions.IncludeDeprecatedOperations);
+
+ serverApiGeneratorMvc = new Framework.Mvc.ProjectGenerator.ServerApiGenerator(
+ loggerFactory,
+ nugetPackageReferenceProvider,
projectOptions.Document,
operationSchemaMappings,
projectOptions.RouteBase,
- projectOptions.ApiOptions.Generator.Response.UseProblemDetailsAsDefaultBody,
- projectOptions.ApiOptions.Generator.IncludeDeprecated);
+ generatorSettings);
serverApiGeneratorMinimalApi = new Framework.Minimal.ProjectGenerator.ServerApiGenerator(
loggerFactory,
nugetPackageReferenceProvider,
- projectOptions.ApiGeneratorVersion,
- projectOptions.ProjectName,
- projectOptions.PathForSrcGenerate,
projectOptions.Document,
operationSchemaMappings,
projectOptions.RouteBase,
- projectOptions.ApiOptions.Generator.Response.UseProblemDetailsAsDefaultBody,
- projectOptions.ApiOptions.Generator.IncludeDeprecated);
+ generatorSettings);
}
public async Task Generate()
diff --git a/src/Atc.Rest.ApiGenerator/Generators/ServerDomainGenerator.cs b/src/Atc.Rest.ApiGenerator/Generators/ServerDomainGenerator.cs
index 77fbcb293..118b286f3 100644
--- a/src/Atc.Rest.ApiGenerator/Generators/ServerDomainGenerator.cs
+++ b/src/Atc.Rest.ApiGenerator/Generators/ServerDomainGenerator.cs
@@ -29,34 +29,42 @@ public ServerDomainGenerator(
var apiProjectName = projectOptions.ProjectName.Replace(".Domain", ".Api.Generated", StringComparison.Ordinal);
- serverDomainGeneratorMvc = new Framework.Mvc.ProjectGenerator.ServerDomainGenerator(
- loggerFactory,
+ var generatorSettings = GeneratorSettingsFactory.Create(
projectOptions.ApiGeneratorVersion,
projectOptions.ProjectName,
- apiProjectName,
projectOptions.PathForSrcGenerate,
- projectOptions.Document);
+ projectOptions.ApiOptions.Generator,
+ projectOptions.ApiOptions.IncludeDeprecatedOperations);
+
+ serverDomainGeneratorMvc = new Framework.Mvc.ProjectGenerator.ServerDomainGenerator(
+ loggerFactory,
+ apiProjectName,
+ projectOptions.Document,
+ generatorSettings);
serverDomainGeneratorMinimalApi = new Framework.Minimal.ProjectGenerator.ServerDomainGenerator(
loggerFactory,
nugetPackageReferenceProvider,
- projectOptions.ApiGeneratorVersion,
- projectOptions.ProjectName,
apiProjectName,
- projectOptions.PathForSrcGenerate,
- projectOptions.Document);
+ projectOptions.Document,
+ generatorSettings);
if (projectOptions.PathForTestGenerate is not null)
{
- serverDomainTestGenerator = new Framework.ProjectGenerator.ServerDomainTestGenerator(
- loggerFactory,
- nugetPackageReferenceProvider,
+ var generatorTestSettings = GeneratorSettingsFactory.Create(
projectOptions.ApiGeneratorVersion,
$"{projectOptions.ProjectName}.{ContentGeneratorConstants.Tests}",
+ projectOptions.PathForTestGenerate,
+ projectOptions.ApiOptions.Generator,
+ projectOptions.ApiOptions.IncludeDeprecatedOperations);
+
+ serverDomainTestGenerator = new ServerDomainTestGenerator(
+ loggerFactory,
+ nugetPackageReferenceProvider,
apiProjectName,
projectOptions.ProjectName,
- projectOptions.PathForTestGenerate,
- projectOptions.Document);
+ projectOptions.Document,
+ generatorTestSettings);
}
}
diff --git a/src/Atc.Rest.ApiGenerator/Generators/ServerHostGenerator.cs b/src/Atc.Rest.ApiGenerator/Generators/ServerHostGenerator.cs
index deecb6384..a91b66671 100644
--- a/src/Atc.Rest.ApiGenerator/Generators/ServerHostGenerator.cs
+++ b/src/Atc.Rest.ApiGenerator/Generators/ServerHostGenerator.cs
@@ -31,15 +31,20 @@ public ServerHostGenerator(
var domainProjectName = projectOptions.ProjectName.Replace(".Api", ".Domain", StringComparison.Ordinal);
var operationSchemaMappings = apiOperationExtractor.Extract(projectOptions.Document);
+ var generatorSettings = GeneratorSettingsFactory.Create(
+ projectOptions.ApiGeneratorVersion,
+ projectOptions.ProjectName,
+ projectOptions.PathForSrcGenerate,
+ projectOptions.ApiOptions.Generator,
+ projectOptions.ApiOptions.IncludeDeprecatedOperations);
+
serverHostGeneratorMvc = new Framework.Mvc.ProjectGenerator.ServerHostGenerator(
loggerFactory,
nugetPackageReferenceProvider,
- projectOptions.ApiGeneratorVersion,
- projectOptions.ProjectName,
apiProjectName,
domainProjectName,
- projectOptions.PathForSrcGenerate,
- projectOptions.Document)
+ projectOptions.Document,
+ generatorSettings)
{
UseRestExtended = projectOptions.UseRestExtended,
};
@@ -47,39 +52,39 @@ public ServerHostGenerator(
serverHostGeneratorMinimalApi = new Framework.Minimal.ProjectGenerator.ServerHostGenerator(
loggerFactory,
nugetPackageReferenceProvider,
- projectOptions.ApiGeneratorVersion,
- projectOptions.ProjectName,
apiProjectName,
domainProjectName,
- projectOptions.PathForSrcGenerate,
- projectOptions.Document);
+ projectOptions.Document,
+ generatorSettings);
if (projectOptions.PathForTestGenerate is not null)
{
+ var generatorTestSettings = GeneratorSettingsFactory.Create(
+ projectOptions.ApiGeneratorVersion,
+ $"{projectOptions.ProjectName}.{ContentGeneratorConstants.Tests}",
+ projectOptions.PathForTestGenerate,
+ projectOptions.ApiOptions.Generator,
+ projectOptions.ApiOptions.IncludeDeprecatedOperations);
+
serverHostTestGeneratorMvc = new Framework.Mvc.ProjectGenerator.ServerHostTestGenerator(
loggerFactory,
nugetPackageReferenceProvider,
- projectOptions.ApiGeneratorVersion,
- $"{projectOptions.ProjectName}.{ContentGeneratorConstants.Tests}",
projectOptions.ProjectName,
apiProjectName,
domainProjectName,
- projectOptions.PathForTestGenerate,
projectOptions.Document,
operationSchemaMappings,
- projectOptions.ApiOptions.IncludeDeprecated);
+ generatorTestSettings);
serverHostTestGeneratorMinimalApi = new Framework.Minimal.ProjectGenerator.ServerHostTestGenerator(
loggerFactory,
nugetPackageReferenceProvider,
- projectOptions.ApiGeneratorVersion,
- $"{projectOptions.ProjectName}.{ContentGeneratorConstants.Tests}",
projectOptions.ProjectName,
apiProjectName,
domainProjectName,
- projectOptions.PathForTestGenerate,
projectOptions.Document,
- operationSchemaMappings);
+ operationSchemaMappings,
+ generatorTestSettings);
}
}
diff --git a/src/Atc.Rest.ApiGenerator/GlobalUsings.cs b/src/Atc.Rest.ApiGenerator/GlobalUsings.cs
index 6ddf3edbf..4ec580e48 100644
--- a/src/Atc.Rest.ApiGenerator/GlobalUsings.cs
+++ b/src/Atc.Rest.ApiGenerator/GlobalUsings.cs
@@ -6,8 +6,10 @@
global using Atc.Rest.ApiGenerator.Contracts;
global using Atc.Rest.ApiGenerator.Contracts.Models;
global using Atc.Rest.ApiGenerator.Contracts.Options;
+global using Atc.Rest.ApiGenerator.Factories;
global using Atc.Rest.ApiGenerator.Framework.ProjectGenerator;
global using Atc.Rest.ApiGenerator.Framework.Providers;
+global using Atc.Rest.ApiGenerator.Framework.Settings;
global using Atc.Rest.ApiGenerator.Framework.Writers;
global using Atc.Rest.ApiGenerator.Generators;
global using Atc.Rest.ApiGenerator.Models;
diff --git a/src/Atc.Rest.ApiGenerator/Models/ApiProjectOptions.cs b/src/Atc.Rest.ApiGenerator/Models/ApiProjectOptions.cs
index c0f00d465..1de1e2c51 100644
--- a/src/Atc.Rest.ApiGenerator/Models/ApiProjectOptions.cs
+++ b/src/Atc.Rest.ApiGenerator/Models/ApiProjectOptions.cs
@@ -11,8 +11,7 @@ public ApiProjectOptions(
string? projectSuffixName,
ApiOptions apiOptions,
bool usingCodingRules,
- bool forClient = false,
- string? clientFolderName = null)
+ bool forClient = false)
: base(
projectSrcGeneratePath,
projectTestGeneratePath,
@@ -22,26 +21,7 @@ public ApiProjectOptions(
projectSuffixName,
apiOptions,
usingCodingRules,
- forClient,
- clientFolderName)
+ forClient)
{
- if (string.IsNullOrEmpty(clientFolderName))
- {
- PathForEndpoints = new DirectoryInfo(Path.Combine(PathForSrcGenerate.FullName, ContentGeneratorConstants.Endpoints));
- PathForContracts = new DirectoryInfo(Path.Combine(PathForSrcGenerate.FullName, ContentGeneratorConstants.Contracts));
- PathForContractsShared = new DirectoryInfo(Path.Combine(PathForContracts.FullName, ContentGeneratorConstants.SpecialFolderSharedModels));
- }
- else
- {
- PathForEndpoints = new DirectoryInfo(Path.Combine(Path.Combine(PathForSrcGenerate.FullName, clientFolderName), ContentGeneratorConstants.Endpoints));
- PathForContracts = new DirectoryInfo(Path.Combine(Path.Combine(PathForSrcGenerate.FullName, clientFolderName), ContentGeneratorConstants.Contracts));
- PathForContractsShared = new DirectoryInfo(Path.Combine(Path.Combine(PathForContracts.FullName), ContentGeneratorConstants.SpecialFolderSharedModels));
- }
}
-
- public DirectoryInfo PathForEndpoints { get; }
-
- public DirectoryInfo PathForContracts { get; }
-
- public DirectoryInfo PathForContractsShared { get; }
}
\ No newline at end of file
diff --git a/src/Atc.Rest.ApiGenerator/Models/BaseProjectOptions.cs b/src/Atc.Rest.ApiGenerator/Models/BaseProjectOptions.cs
index 4de23d279..c853f3be3 100644
--- a/src/Atc.Rest.ApiGenerator/Models/BaseProjectOptions.cs
+++ b/src/Atc.Rest.ApiGenerator/Models/BaseProjectOptions.cs
@@ -11,8 +11,7 @@ protected BaseProjectOptions(
string? projectSuffixName,
ApiOptions apiOptions,
bool usingCodingRules,
- bool forClient = false,
- string? clientFolderName = null)
+ bool forClient = false)
{
ArgumentNullException.ThrowIfNull(projectSrcGeneratePath);
@@ -70,7 +69,6 @@ protected BaseProjectOptions(
UsingCodingRules = usingCodingRules;
IsForClient = forClient;
- ClientFolderName = clientFolderName;
ApiGroupNames = openApiDocument.GetApiGroupNames();
}
@@ -117,7 +115,5 @@ public string ProjectTestCsProjDisplayLocation
public bool IsForClient { get; }
- public string? ClientFolderName { get; }
-
public IList ApiGroupNames { get; }
}
\ No newline at end of file
diff --git a/src/Atc.Rest.ApiGenerator/Options/ApiOptions.cs b/src/Atc.Rest.ApiGenerator/Options/ApiOptions.cs
index 99bbbe086..ef165e631 100644
--- a/src/Atc.Rest.ApiGenerator/Options/ApiOptions.cs
+++ b/src/Atc.Rest.ApiGenerator/Options/ApiOptions.cs
@@ -6,8 +6,8 @@ public class ApiOptions
public ApiOptionsValidation Validation { get; set; } = new();
- public bool IncludeDeprecated { get; set; }
+ public bool IncludeDeprecatedOperations { get; set; }
public override string ToString()
- => $"{nameof(Generator)}: {Generator}, {nameof(Validation)}: ({Validation}), {nameof(IncludeDeprecated)}: ({IncludeDeprecated})";
+ => $"{nameof(Generator)}: {Generator}, {nameof(Validation)}: ({Validation}), {nameof(IncludeDeprecatedOperations)}: ({IncludeDeprecatedOperations})";
}
\ No newline at end of file
diff --git a/src/Atc.Rest.ApiGenerator/Options/ApiOptionsGenerator.cs b/src/Atc.Rest.ApiGenerator/Options/ApiOptionsGenerator.cs
index 8a5e328e0..94db2e280 100644
--- a/src/Atc.Rest.ApiGenerator/Options/ApiOptionsGenerator.cs
+++ b/src/Atc.Rest.ApiGenerator/Options/ApiOptionsGenerator.cs
@@ -8,12 +8,20 @@ public class ApiOptionsGenerator
public bool UseRestExtended { get; set; } = true;
- public bool IncludeDeprecated { get; set; }
-
public string ProjectName { get; set; } = string.Empty;
public string ProjectSuffixName { get; set; } = string.Empty;
+ public string ContractsLocation { get; set; } = ContentGeneratorConstants.Contracts + ".[[apiGroupName]]";
+
+ public string EndpointsLocation { get; set; } = ContentGeneratorConstants.Endpoints + ".[[apiGroupName]]";
+
+ public string HandlersLocation { get; set; } = ContentGeneratorConstants.Handlers + ".[[apiGroupName]]";
+
+ public bool UsePartialClassForContracts { get; set; }
+
+ public bool UsePartialClassForEndpoints { get; set; }
+
public bool RemoveNamespaceGroupSeparatorInGlobalUsings { get; set; }
public ApiOptionsGeneratorRequest Request { get; set; } = new();
@@ -23,5 +31,5 @@ public class ApiOptionsGenerator
public ApiOptionsGeneratorClient? Client { get; set; }
public override string ToString()
- => $"{nameof(AspNetOutputType)}: {AspNetOutputType}, {nameof(SwaggerThemeMode)}: {SwaggerThemeMode}, {nameof(UseRestExtended)}: {UseRestExtended}, {nameof(IncludeDeprecated)}: {IncludeDeprecated}, {nameof(ProjectName)}: {ProjectName}, {nameof(ProjectSuffixName)}: {ProjectSuffixName}, {nameof(RemoveNamespaceGroupSeparatorInGlobalUsings)}: {RemoveNamespaceGroupSeparatorInGlobalUsings}, {nameof(Request)}: ({Request}), {nameof(Response)}: ({Response}), {nameof(Client)}: ({Client})";
+ => $"{nameof(AspNetOutputType)}: {AspNetOutputType}, {nameof(SwaggerThemeMode)}: {SwaggerThemeMode}, {nameof(UseRestExtended)}: {UseRestExtended}, {nameof(ProjectName)}: {ProjectName}, {nameof(ProjectSuffixName)}: {ProjectSuffixName}, {nameof(RemoveNamespaceGroupSeparatorInGlobalUsings)}: {RemoveNamespaceGroupSeparatorInGlobalUsings}, {nameof(Request)}: ({Request}), {nameof(Response)}: ({Response}), {nameof(Client)}: ({Client})";
}
\ No newline at end of file
diff --git a/src/Atc.Rest.ApiGenerator/Options/ApiOptionsGeneratorClient.cs b/src/Atc.Rest.ApiGenerator/Options/ApiOptionsGeneratorClient.cs
index f88e7923f..7115aec1b 100644
--- a/src/Atc.Rest.ApiGenerator/Options/ApiOptionsGeneratorClient.cs
+++ b/src/Atc.Rest.ApiGenerator/Options/ApiOptionsGeneratorClient.cs
@@ -2,12 +2,10 @@ namespace Atc.Rest.ApiGenerator.Options;
public class ApiOptionsGeneratorClient
{
- public string FolderName { get; set; } = string.Empty;
+ public string HttpClientName { get; set; } = ContentGeneratorConstants.DefaultHttpClientName;
public bool ExcludeEndpointGeneration { get; set; }
- public string HttpClientName { get; set; } = "ApiClient";
-
public override string ToString()
- => $"{nameof(FolderName)}: {FolderName}, {nameof(ExcludeEndpointGeneration)}: {ExcludeEndpointGeneration}, {nameof(HttpClientName)}: {HttpClientName}";
+ => $"{nameof(HttpClientName)}: {HttpClientName}, {nameof(ExcludeEndpointGeneration)}: {ExcludeEndpointGeneration}";
}
\ No newline at end of file
diff --git a/test/Atc.CodeGeneration.CSharp.Tests/Content/Generators/GenerateContentForClassTests.cs b/test/Atc.CodeGeneration.CSharp.Tests/Content/Generators/GenerateContentForClassTests.cs
index 650eb7048..d1636eb66 100644
--- a/test/Atc.CodeGeneration.CSharp.Tests/Content/Generators/GenerateContentForClassTests.cs
+++ b/test/Atc.CodeGeneration.CSharp.Tests/Content/Generators/GenerateContentForClassTests.cs
@@ -36,7 +36,7 @@ public override string ToString()
new(
DocumentationTags: null,
Attributes: null,
- AccessModifier: AccessModifiers.Public,
+ DeclarationModifier: DeclarationModifiers.Public,
GenericTypeName: null,
IsGenericListType: false,
TypeName: "string",
@@ -57,7 +57,7 @@ public override string ToString()
Namespace: "Demo.Api.Generated.Contracts.Accounts",
DocumentationTags: documentationTags,
Attributes: AttributesWithGeneratedCode,
- AccessModifier: AccessModifiers.PublicClass,
+ DeclarationModifier: DeclarationModifiers.PublicClass,
ClassTypeName: "UpdateAccountRequest",
GenericTypeName: null,
InheritedClassTypeName: null,
@@ -128,7 +128,7 @@ public override string ToString()
new("FromRoute", "Name = \"accountId\""),
new("Required", null),
},
- AccessModifier: AccessModifiers.Public,
+ DeclarationModifier: DeclarationModifiers.Public,
GenericTypeName: null,
IsGenericListType: false,
TypeName: "Guid",
@@ -148,7 +148,7 @@ public override string ToString()
{
new("FromHeader", "Name = \"name\""),
},
- AccessModifier: AccessModifiers.Public,
+ DeclarationModifier: DeclarationModifiers.Public,
GenericTypeName: null,
IsGenericListType: false,
TypeName: "string",
@@ -169,7 +169,7 @@ public override string ToString()
Namespace: "Demo.Api.Generated.Contracts.Accounts",
DocumentationTags: documentationTags,
Attributes: AttributesWithGeneratedCode,
- AccessModifier: AccessModifiers.PublicClass,
+ DeclarationModifier: DeclarationModifiers.PublicClass,
ClassTypeName: "UpdateAccountNameParameters",
GenericTypeName: null,
InheritedClassTypeName: null,
@@ -265,7 +265,7 @@ public async Task SetAccountName(
new("ProducesResponseType", "typeof(ProblemDetails), StatusCodes.Status401Unauthorized"),
new("ProducesResponseType", "typeof(ProblemDetails), StatusCodes.Status403Forbidden"),
},
- AccessModifier: AccessModifiers.PublicAsync,
+ DeclarationModifier: DeclarationModifiers.PublicAsync,
ReturnGenericTypeName: "Task",
ReturnTypeName: "ActionResult",
Name: "UpdateAccountName",
@@ -288,7 +288,7 @@ public async Task SetAccountName(
new("ProducesResponseType", "typeof(ProblemDetails), StatusCodes.Status401Unauthorized"),
new("ProducesResponseType", "typeof(ProblemDetails), StatusCodes.Status403Forbidden"),
},
- AccessModifier: AccessModifiers.PublicAsync,
+ DeclarationModifier: DeclarationModifiers.PublicAsync,
ReturnGenericTypeName: "Task",
ReturnTypeName: "ActionResult",
Name: "SetAccountName",
@@ -308,7 +308,7 @@ public async Task SetAccountName(
Namespace: "Demo.Api.Generated.Endpoints",
DocumentationTags: documentationTags,
Attributes: attributes,
- AccessModifier: AccessModifiers.PublicClass,
+ DeclarationModifier: DeclarationModifiers.PublicClass,
ClassTypeName: "AccountsController",
GenericTypeName: null,
InheritedClassTypeName: "ControllerBase",
@@ -371,7 +371,7 @@ public static implicit operator UpdateAccountNameResult(string response)
{
new(
DocumentationTags: null,
- AccessModifier: AccessModifiers.Private,
+ DeclarationModifier: DeclarationModifiers.Private,
GenericTypeName: null,
TypeName: "UpdateAccountNameResult",
InheritedClassTypeName: "base",
@@ -394,7 +394,7 @@ public static implicit operator UpdateAccountNameResult(string response)
new(
DocumentationTags: new CodeDocumentationTags("200 - Ok response."),
Attributes: null,
- AccessModifier: AccessModifiers.PublicStatic,
+ DeclarationModifier: DeclarationModifiers.PublicStatic,
ReturnGenericTypeName: null,
ReturnTypeName: "UpdateAccountNameResult",
Name: "Ok",
@@ -405,7 +405,7 @@ public static implicit operator UpdateAccountNameResult(string response)
new(
DocumentationTags: new CodeDocumentationTags("Performs an implicit conversion from UpdateAccountNameResult to ActionResult."),
Attributes: null,
- AccessModifier: AccessModifiers.PublicStaticImplicitOperator,
+ DeclarationModifier: DeclarationModifiers.PublicStaticImplicitOperator,
ReturnGenericTypeName: null,
ReturnTypeName: null,
Name: "UpdateAccountNameResult",
@@ -420,7 +420,7 @@ public static implicit operator UpdateAccountNameResult(string response)
Namespace: "Demo.Api.Generated.Contracts.Accounts",
DocumentationTags: documentationTags,
Attributes: AttributesWithGeneratedCode,
- AccessModifier: AccessModifiers.PublicClass,
+ DeclarationModifier: DeclarationModifiers.PublicClass,
ClassTypeName: "UpdateAccountNameResult",
GenericTypeName: null,
InheritedClassTypeName: "ResultBase",
@@ -520,7 +520,7 @@ public async Task ExecuteAsync(
{
new(
DocumentationTags: null,
- AccessModifier: AccessModifiers.Public,
+ DeclarationModifier: DeclarationModifiers.Public,
GenericTypeName: null,
TypeName: "CreateLocationEndpoint",
InheritedClassTypeName: null,
@@ -552,7 +552,7 @@ public async Task ExecuteAsync(
new(
DocumentationTags: null,
Attributes: null,
- AccessModifier: AccessModifiers.PublicAsync,
+ DeclarationModifier: DeclarationModifiers.PublicAsync,
ReturnGenericTypeName: "Task",
ReturnTypeName: "ICreateLocationEndpointResult",
Name: "ExecuteAsync",
@@ -587,7 +587,7 @@ public async Task ExecuteAsync(
Namespace: "XXX.ApiClient.Generated.Endpoints",
DocumentationTags: documentationTags,
Attributes: AttributesWithGeneratedCode,
- AccessModifier: AccessModifiers.PublicClass,
+ DeclarationModifier: DeclarationModifiers.PublicClass,
ClassTypeName: "CreateLocationEndpoint",
GenericTypeName: null,
InheritedClassTypeName: "ICreateLocationEndpoint",
@@ -681,7 +681,7 @@ public ProblemDetails InternalServerErrorContent
{
new(
DocumentationTags: null,
- AccessModifier: AccessModifiers.Public,
+ DeclarationModifier: DeclarationModifiers.Public,
GenericTypeName: null,
TypeName: "CreateLocationEndpointResult",
InheritedClassTypeName: "base",
@@ -704,7 +704,7 @@ public ProblemDetails InternalServerErrorContent
new(
DocumentationTags: null,
Attributes: null,
- AccessModifier: AccessModifiers.Public,
+ DeclarationModifier: DeclarationModifiers.Public,
GenericTypeName: null,
IsGenericListType: false,
TypeName: "bool",
@@ -721,7 +721,7 @@ public ProblemDetails InternalServerErrorContent
new(
DocumentationTags: null,
Attributes: null,
- AccessModifier: AccessModifiers.Public,
+ DeclarationModifier: DeclarationModifiers.Public,
GenericTypeName: null,
IsGenericListType: false,
TypeName: "bool",
@@ -738,7 +738,7 @@ public ProblemDetails InternalServerErrorContent
new(
DocumentationTags: null,
Attributes: null,
- AccessModifier: AccessModifiers.Public,
+ DeclarationModifier: DeclarationModifiers.Public,
GenericTypeName: null,
IsGenericListType: false,
TypeName: "bool",
@@ -755,7 +755,7 @@ public ProblemDetails InternalServerErrorContent
new(
DocumentationTags: null,
Attributes: null,
- AccessModifier: AccessModifiers.Public,
+ DeclarationModifier: DeclarationModifiers.Public,
GenericTypeName: null,
IsGenericListType: false,
TypeName: "bool",
@@ -772,7 +772,7 @@ public ProblemDetails InternalServerErrorContent
new(
DocumentationTags: null,
Attributes: null,
- AccessModifier: AccessModifiers.Public,
+ DeclarationModifier: DeclarationModifiers.Public,
GenericTypeName: null,
IsGenericListType: false,
TypeName: "bool",
@@ -789,7 +789,7 @@ public ProblemDetails InternalServerErrorContent
new(
DocumentationTags: null,
Attributes: null,
- AccessModifier: AccessModifiers.Public,
+ DeclarationModifier: DeclarationModifiers.Public,
GenericTypeName: null,
IsGenericListType: false,
TypeName: "Location",
@@ -806,7 +806,7 @@ public ProblemDetails InternalServerErrorContent
new(
DocumentationTags: null,
Attributes: null,
- AccessModifier: AccessModifiers.Public,
+ DeclarationModifier: DeclarationModifiers.Public,
GenericTypeName: null,
IsGenericListType: false,
TypeName: "ValidationProblemDetails",
@@ -823,7 +823,7 @@ public ProblemDetails InternalServerErrorContent
new(
DocumentationTags: null,
Attributes: null,
- AccessModifier: AccessModifiers.Public,
+ DeclarationModifier: DeclarationModifiers.Public,
GenericTypeName: null,
IsGenericListType: false,
TypeName: "ProblemDetails",
@@ -840,7 +840,7 @@ public ProblemDetails InternalServerErrorContent
new(
DocumentationTags: null,
Attributes: null,
- AccessModifier: AccessModifiers.Public,
+ DeclarationModifier: DeclarationModifiers.Public,
GenericTypeName: null,
IsGenericListType: false,
TypeName: "ProblemDetails",
@@ -857,7 +857,7 @@ public ProblemDetails InternalServerErrorContent
new(
DocumentationTags: null,
Attributes: null,
- AccessModifier: AccessModifiers.Public,
+ DeclarationModifier: DeclarationModifiers.Public,
GenericTypeName: null,
IsGenericListType: false,
TypeName: "ProblemDetails",
@@ -878,7 +878,7 @@ public ProblemDetails InternalServerErrorContent
Namespace: "XXX.ApiClient.Generated.Endpoints",
DocumentationTags: documentationTags,
Attributes: AttributesWithGeneratedCode,
- AccessModifier: AccessModifiers.PublicClass,
+ DeclarationModifier: DeclarationModifiers.PublicClass,
ClassTypeName: "CreateLocationEndpointResult",
GenericTypeName: null,
InheritedClassTypeName: "EndpointResponse",
diff --git a/test/Atc.CodeGeneration.CSharp.Tests/Content/Generators/GenerateContentForInterfaceTests.cs b/test/Atc.CodeGeneration.CSharp.Tests/Content/Generators/GenerateContentForInterfaceTests.cs
index 42c260dd7..865f0dbf3 100644
--- a/test/Atc.CodeGeneration.CSharp.Tests/Content/Generators/GenerateContentForInterfaceTests.cs
+++ b/test/Atc.CodeGeneration.CSharp.Tests/Content/Generators/GenerateContentForInterfaceTests.cs
@@ -17,7 +17,7 @@ public interface MyInterface
Namespace: "App.MyNamespace",
DocumentationTags: null,
Attributes: null,
- AccessModifier: AccessModifiers.Public,
+ DeclarationModifier: DeclarationModifiers.PublicInterface,
InterfaceTypeName: "MyInterface",
InheritedInterfaceTypeName: null,
Properties: null,
@@ -48,7 +48,7 @@ public interface MyInterface : MyInterfaceBase
Namespace: "App.MyNamespace",
DocumentationTags: null,
Attributes: null,
- AccessModifier: AccessModifiers.Public,
+ DeclarationModifier: DeclarationModifiers.PublicInterface,
InterfaceTypeName: "MyInterface",
InheritedInterfaceTypeName: "MyInterfaceBase",
Properties: null,
@@ -113,7 +113,7 @@ Task ExecuteAsync(
exceptions: null,
@return: null),
Attributes: null,
- AccessModifier: AccessModifiers.None,
+ DeclarationModifier: DeclarationModifiers.None,
ReturnTypeName: "SetAccountNameResult",
ReturnGenericTypeName: "Task",
Name: "ExecuteAsync",
@@ -148,7 +148,7 @@ Task ExecuteAsync(
Namespace: "Demo.Api.Generated.Contracts.Accounts",
DocumentationTags: documentationTags,
Attributes: AttributesWithGeneratedCode,
- AccessModifier: AccessModifiers.Public,
+ DeclarationModifier: DeclarationModifiers.PublicInterface,
InterfaceTypeName: "ISetAccountNameHandler",
InheritedInterfaceTypeName: null,
Properties: null,
@@ -213,7 +213,7 @@ Task ExecuteAsync(
exceptions: null,
@return: null),
Attributes: null,
- AccessModifier: AccessModifiers.None,
+ DeclarationModifier: DeclarationModifiers.None,
ReturnTypeName: "UpdateAccountNameResult",
ReturnGenericTypeName: "Task",
Name: "ExecuteAsync",
@@ -248,7 +248,7 @@ Task ExecuteAsync(
Namespace: "Demo.Api.Generated.Contracts.Accounts",
DocumentationTags: documentationTags,
Attributes: AttributesWithGeneratedCode,
- AccessModifier: AccessModifiers.Public,
+ DeclarationModifier: DeclarationModifiers.PublicInterface,
InterfaceTypeName: "IUpdateAccountNameHandler",
InheritedInterfaceTypeName: null,
Properties: null,
@@ -313,7 +313,7 @@ Task ExecuteAsync(
exceptions: null,
@return: null),
Attributes: null,
- AccessModifier: AccessModifiers.None,
+ DeclarationModifier: DeclarationModifiers.None,
ReturnTypeName: "ICreateLocationEndpointResult",
ReturnGenericTypeName: "Task",
Name: "ExecuteAsync",
@@ -348,7 +348,7 @@ Task ExecuteAsync(
Namespace: "XXX.ApiClient.Generated.Endpoints",
DocumentationTags: documentationTags,
Attributes: AttributesWithGeneratedCode,
- AccessModifier: AccessModifiers.Public,
+ DeclarationModifier: DeclarationModifiers.PublicInterface,
InterfaceTypeName: "ICreateLocationEndpoint",
InheritedInterfaceTypeName: null,
Properties: null,
@@ -413,7 +413,7 @@ public interface ICreateLocationEndpointResult : IEndpointResponse
new(
DocumentationTags: null,
Attributes: null,
- AccessModifier: AccessModifiers.None,
+ DeclarationModifier: DeclarationModifiers.None,
GenericTypeName: null,
IsGenericListType: false,
TypeName: "bool",
@@ -430,7 +430,7 @@ public interface ICreateLocationEndpointResult : IEndpointResponse
new(
DocumentationTags: null,
Attributes: null,
- AccessModifier: AccessModifiers.None,
+ DeclarationModifier: DeclarationModifiers.None,
GenericTypeName: null,
IsGenericListType: false,
TypeName: "bool",
@@ -447,7 +447,7 @@ public interface ICreateLocationEndpointResult : IEndpointResponse
new(
DocumentationTags: null,
Attributes: null,
- AccessModifier: AccessModifiers.None,
+ DeclarationModifier: DeclarationModifiers.None,
GenericTypeName: null,
IsGenericListType: false,
TypeName: "bool",
@@ -464,7 +464,7 @@ public interface ICreateLocationEndpointResult : IEndpointResponse
new(
DocumentationTags: null,
Attributes: null,
- AccessModifier: AccessModifiers.None,
+ DeclarationModifier: DeclarationModifiers.None,
GenericTypeName: null,
IsGenericListType: false,
TypeName: "bool",
@@ -481,7 +481,7 @@ public interface ICreateLocationEndpointResult : IEndpointResponse
new(
DocumentationTags: null,
Attributes: null,
- AccessModifier: AccessModifiers.None,
+ DeclarationModifier: DeclarationModifiers.None,
GenericTypeName: null,
IsGenericListType: false,
TypeName: "bool",
@@ -498,7 +498,7 @@ public interface ICreateLocationEndpointResult : IEndpointResponse
new(
DocumentationTags: null,
Attributes: null,
- AccessModifier: AccessModifiers.None,
+ DeclarationModifier: DeclarationModifiers.None,
GenericTypeName: null,
IsGenericListType: false,
TypeName: "Location",
@@ -515,7 +515,7 @@ public interface ICreateLocationEndpointResult : IEndpointResponse
new(
DocumentationTags: null,
Attributes: null,
- AccessModifier: AccessModifiers.None,
+ DeclarationModifier: DeclarationModifiers.None,
GenericTypeName: null,
IsGenericListType: false,
TypeName: "ValidationProblemDetails",
@@ -532,7 +532,7 @@ public interface ICreateLocationEndpointResult : IEndpointResponse
new(
DocumentationTags: null,
Attributes: null,
- AccessModifier: AccessModifiers.None,
+ DeclarationModifier: DeclarationModifiers.None,
GenericTypeName: null,
IsGenericListType: false,
TypeName: "ProblemDetails",
@@ -549,7 +549,7 @@ public interface ICreateLocationEndpointResult : IEndpointResponse
new(
DocumentationTags: null,
Attributes: null,
- AccessModifier: AccessModifiers.None,
+ DeclarationModifier: DeclarationModifiers.None,
GenericTypeName: null,
IsGenericListType: false,
TypeName: "ProblemDetails",
@@ -566,7 +566,7 @@ public interface ICreateLocationEndpointResult : IEndpointResponse
new(
DocumentationTags: null,
Attributes: null,
- AccessModifier: AccessModifiers.None,
+ DeclarationModifier: DeclarationModifiers.None,
GenericTypeName: null,
IsGenericListType: false,
TypeName: "ProblemDetails",
@@ -587,7 +587,7 @@ public interface ICreateLocationEndpointResult : IEndpointResponse
Namespace: "XXX.ApiClient.Generated.Endpoints",
DocumentationTags: documentationTags,
Attributes: AttributesWithGeneratedCode,
- AccessModifier: AccessModifiers.Public,
+ DeclarationModifier: DeclarationModifiers.PublicInterface,
InterfaceTypeName: "ICreateLocationEndpointResult",
InheritedInterfaceTypeName: "IEndpointResponse",
Properties: propertyParameters,
diff --git a/test/Atc.CodeGeneration.CSharp.Tests/Content/Generators/GenerateContentForRecordsTests.cs b/test/Atc.CodeGeneration.CSharp.Tests/Content/Generators/GenerateContentForRecordsTests.cs
index 44a1a55e8..cbba3c68d 100644
--- a/test/Atc.CodeGeneration.CSharp.Tests/Content/Generators/GenerateContentForRecordsTests.cs
+++ b/test/Atc.CodeGeneration.CSharp.Tests/Content/Generators/GenerateContentForRecordsTests.cs
@@ -22,11 +22,12 @@ public record GetLocationsByCountryCodeA3Parameters(
"Energy.Consumption.Api.Contracts.Contracts.Petrol.Parameters",
DocumentationTags: null,
Attributes: null,
+ DeclarationModifiers.PublicRecord,
new List
{
new(
DocumentationTags: null,
- AccessModifiers.PublicRecord,
+ DeclarationModifiers.PublicRecord,
Name: "CreateLocationParameters",
new List
{
@@ -42,7 +43,7 @@ public record GetLocationsByCountryCodeA3Parameters(
}),
new(
DocumentationTags: null,
- AccessModifiers.PublicRecord,
+ DeclarationModifiers.PublicRecord,
Name: "GetLocationByIdParameters",
new List
{
@@ -58,7 +59,7 @@ public record GetLocationsByCountryCodeA3Parameters(
}),
new(
DocumentationTags: null,
- AccessModifiers.PublicRecord,
+ DeclarationModifiers.PublicRecord,
Name: "GetLocationsByCountryCodeA3Parameters",
new List
{
diff --git a/test/Atc.CodeGeneration.CSharp.Tests/Extensions/StringBuilderExtensionsTests.cs b/test/Atc.CodeGeneration.CSharp.Tests/Extensions/StringBuilderExtensionsTests.cs
index e6b76f66a..ddb1f2b4f 100644
--- a/test/Atc.CodeGeneration.CSharp.Tests/Extensions/StringBuilderExtensionsTests.cs
+++ b/test/Atc.CodeGeneration.CSharp.Tests/Extensions/StringBuilderExtensionsTests.cs
@@ -4,25 +4,25 @@ namespace Atc.CodeGeneration.CSharp.Tests.Extensions;
public class StringBuilderExtensionsTests
{
[Theory]
- [InlineData("", AccessModifiers.None)]
- [InlineData("public ", AccessModifiers.Public)]
- [InlineData("public async ", AccessModifiers.PublicAsync)]
- [InlineData("public static ", AccessModifiers.PublicStatic)]
- [InlineData("public static implicit operator ", AccessModifiers.PublicStaticImplicitOperator)]
- [InlineData("public record ", AccessModifiers.PublicRecord)]
- [InlineData("public record struct ", AccessModifiers.PublicRecordStruct)]
- [InlineData("private ", AccessModifiers.Private)]
- [InlineData("protected ", AccessModifiers.Protected)]
- [InlineData("internal ", AccessModifiers.Internal)]
- public void AppendAccessModifier(
+ [InlineData("", DeclarationModifiers.None)]
+ [InlineData("public ", DeclarationModifiers.Public)]
+ [InlineData("public async ", DeclarationModifiers.PublicAsync)]
+ [InlineData("public static ", DeclarationModifiers.PublicStatic)]
+ [InlineData("public static implicit operator ", DeclarationModifiers.PublicStaticImplicitOperator)]
+ [InlineData("public record ", DeclarationModifiers.PublicRecord)]
+ [InlineData("public record struct ", DeclarationModifiers.PublicRecordStruct)]
+ [InlineData("private ", DeclarationModifiers.Private)]
+ [InlineData("protected ", DeclarationModifiers.Protected)]
+ [InlineData("internal ", DeclarationModifiers.Internal)]
+ public void AppendDeclarationModifier(
string expected,
- AccessModifiers accessModifier)
+ DeclarationModifiers declarationModifier)
{
// Arrange
var sb = new StringBuilder();
// Act
- sb.AppendAccessModifier(accessModifier);
+ sb.AppendDeclarationModifier(declarationModifier);
var actual = sb.ToString();
// Assert
@@ -30,26 +30,26 @@ public void AppendAccessModifier(
}
[Theory]
- [InlineData("", 3, AccessModifiers.None)]
- [InlineData(" public ", 3, AccessModifiers.Public)]
- [InlineData(" public async ", 3, AccessModifiers.PublicAsync)]
- [InlineData(" public static ", 3, AccessModifiers.PublicStatic)]
- [InlineData(" public static implicit operator ", 3, AccessModifiers.PublicStaticImplicitOperator)]
- [InlineData(" public record ", 3, AccessModifiers.PublicRecord)]
- [InlineData(" public record struct ", 3, AccessModifiers.PublicRecordStruct)]
- [InlineData(" private ", 3, AccessModifiers.Private)]
- [InlineData(" protected ", 3, AccessModifiers.Protected)]
- [InlineData(" internal ", 3, AccessModifiers.Internal)]
- public void AppendAccessModifier_WithIndentSpaces(
+ [InlineData("", 3, DeclarationModifiers.None)]
+ [InlineData(" public ", 3, DeclarationModifiers.Public)]
+ [InlineData(" public async ", 3, DeclarationModifiers.PublicAsync)]
+ [InlineData(" public static ", 3, DeclarationModifiers.PublicStatic)]
+ [InlineData(" public static implicit operator ", 3, DeclarationModifiers.PublicStaticImplicitOperator)]
+ [InlineData(" public record ", 3, DeclarationModifiers.PublicRecord)]
+ [InlineData(" public record struct ", 3, DeclarationModifiers.PublicRecordStruct)]
+ [InlineData(" private ", 3, DeclarationModifiers.Private)]
+ [InlineData(" protected ", 3, DeclarationModifiers.Protected)]
+ [InlineData(" internal ", 3, DeclarationModifiers.Internal)]
+ public void AppendDeclarationModifier_WithIndentSpaces(
string expected,
int indentSpaces,
- AccessModifiers accessModifier)
+ DeclarationModifiers declarationModifier)
{
// Arrange
var sb = new StringBuilder();
// Act
- sb.AppendAccessModifier(indentSpaces, accessModifier);
+ sb.AppendDeclarationModifier(indentSpaces, declarationModifier);
var actual = sb.ToString();
// Assert
diff --git a/test/Atc.Rest.ApiGenerator.CLI.Tests/Atc.Rest.ApiGenerator.CLI.Tests.csproj b/test/Atc.Rest.ApiGenerator.CLI.Tests/Atc.Rest.ApiGenerator.CLI.Tests.csproj
index 379240bb3..64458158f 100644
--- a/test/Atc.Rest.ApiGenerator.CLI.Tests/Atc.Rest.ApiGenerator.CLI.Tests.csproj
+++ b/test/Atc.Rest.ApiGenerator.CLI.Tests/Atc.Rest.ApiGenerator.CLI.Tests.csproj
@@ -24,6 +24,8 @@
+
+
@@ -39,6 +41,8 @@
+
+
@@ -54,6 +58,8 @@
+
+
diff --git a/test/Atc.Rest.ApiGenerator.CLI.Tests/Scenarios/DemoSample/VerifyClient/WOPD/src/DemoSample.ApiClient.Generated/GlobalUsings.verified.cs b/test/Atc.Rest.ApiGenerator.CLI.Tests/Scenarios/DemoSample/VerifyClient/WOPD/src/DemoSample.ApiClient.Generated/GlobalUsings.verified.cs
index b364f1614..3759d4054 100644
--- a/test/Atc.Rest.ApiGenerator.CLI.Tests/Scenarios/DemoSample/VerifyClient/WOPD/src/DemoSample.ApiClient.Generated/GlobalUsings.verified.cs
+++ b/test/Atc.Rest.ApiGenerator.CLI.Tests/Scenarios/DemoSample/VerifyClient/WOPD/src/DemoSample.ApiClient.Generated/GlobalUsings.verified.cs
@@ -1,4 +1,4 @@
-global using System;
+global using System;
global using System.CodeDom.Compiler;
global using System.Collections.Generic;
global using System.ComponentModel.DataAnnotations;
@@ -19,7 +19,6 @@
global using DemoSample.ApiClient.Generated.Contracts.Files;
global using DemoSample.ApiClient.Generated.Contracts.Items;
global using DemoSample.ApiClient.Generated.Contracts.Orders;
-global using DemoSample.ApiClient.Generated.Contracts.Tasks;
global using DemoSample.ApiClient.Generated.Contracts.Users;
global using DemoSample.ApiClient.Generated.Endpoints.Accounts.Interfaces;
global using DemoSample.ApiClient.Generated.Endpoints.Addresses.Interfaces;
diff --git a/test/Atc.Rest.ApiGenerator.CLI.Tests/Scenarios/DemoSample/VerifyClient/WPD/src/DemoSample.ApiClient.Generated/GlobalUsings.verified.cs b/test/Atc.Rest.ApiGenerator.CLI.Tests/Scenarios/DemoSample/VerifyClient/WPD/src/DemoSample.ApiClient.Generated/GlobalUsings.verified.cs
index b364f1614..3759d4054 100644
--- a/test/Atc.Rest.ApiGenerator.CLI.Tests/Scenarios/DemoSample/VerifyClient/WPD/src/DemoSample.ApiClient.Generated/GlobalUsings.verified.cs
+++ b/test/Atc.Rest.ApiGenerator.CLI.Tests/Scenarios/DemoSample/VerifyClient/WPD/src/DemoSample.ApiClient.Generated/GlobalUsings.verified.cs
@@ -1,4 +1,4 @@
-global using System;
+global using System;
global using System.CodeDom.Compiler;
global using System.Collections.Generic;
global using System.ComponentModel.DataAnnotations;
@@ -19,7 +19,6 @@
global using DemoSample.ApiClient.Generated.Contracts.Files;
global using DemoSample.ApiClient.Generated.Contracts.Items;
global using DemoSample.ApiClient.Generated.Contracts.Orders;
-global using DemoSample.ApiClient.Generated.Contracts.Tasks;
global using DemoSample.ApiClient.Generated.Contracts.Users;
global using DemoSample.ApiClient.Generated.Endpoints.Accounts.Interfaces;
global using DemoSample.ApiClient.Generated.Endpoints.Addresses.Interfaces;
diff --git a/test/Atc.Rest.ApiGenerator.CLI.Tests/Scenarios/ExAsyncEnumerable/VerifyServerAll/MinimalApi_WOPD/src/ExAsyncEnumerable.Domain/GlobalUsings.verified.cs b/test/Atc.Rest.ApiGenerator.CLI.Tests/Scenarios/ExAsyncEnumerable/VerifyServerAll/MinimalApi_WOPD/src/ExAsyncEnumerable.Domain/GlobalUsings.verified.cs
index 68af4d8d7..96b6a39d7 100644
--- a/test/Atc.Rest.ApiGenerator.CLI.Tests/Scenarios/ExAsyncEnumerable/VerifyServerAll/MinimalApi_WOPD/src/ExAsyncEnumerable.Domain/GlobalUsings.verified.cs
+++ b/test/Atc.Rest.ApiGenerator.CLI.Tests/Scenarios/ExAsyncEnumerable/VerifyServerAll/MinimalApi_WOPD/src/ExAsyncEnumerable.Domain/GlobalUsings.verified.cs
@@ -3,8 +3,6 @@
global using ExAsyncEnumerable.Api.Generated.Contracts.Customers;
global using ExAsyncEnumerable.Api.Generated.Contracts.Users;
-global using ExAsyncEnumerable.Domain.Handlers.Customers;
-global using ExAsyncEnumerable.Domain.Handlers.Users;
global using Microsoft.Extensions.Configuration;
global using Microsoft.Extensions.DependencyInjection;
\ No newline at end of file
diff --git a/test/Atc.Rest.ApiGenerator.CLI.Tests/Scenarios/ExAsyncEnumerable/VerifyServerAll/MinimalApi_WPD/src/ExAsyncEnumerable.Domain/GlobalUsings.verified.cs b/test/Atc.Rest.ApiGenerator.CLI.Tests/Scenarios/ExAsyncEnumerable/VerifyServerAll/MinimalApi_WPD/src/ExAsyncEnumerable.Domain/GlobalUsings.verified.cs
index 68af4d8d7..96b6a39d7 100644
--- a/test/Atc.Rest.ApiGenerator.CLI.Tests/Scenarios/ExAsyncEnumerable/VerifyServerAll/MinimalApi_WPD/src/ExAsyncEnumerable.Domain/GlobalUsings.verified.cs
+++ b/test/Atc.Rest.ApiGenerator.CLI.Tests/Scenarios/ExAsyncEnumerable/VerifyServerAll/MinimalApi_WPD/src/ExAsyncEnumerable.Domain/GlobalUsings.verified.cs
@@ -3,8 +3,6 @@
global using ExAsyncEnumerable.Api.Generated.Contracts.Customers;
global using ExAsyncEnumerable.Api.Generated.Contracts.Users;
-global using ExAsyncEnumerable.Domain.Handlers.Customers;
-global using ExAsyncEnumerable.Domain.Handlers.Users;
global using Microsoft.Extensions.Configuration;
global using Microsoft.Extensions.DependencyInjection;
\ No newline at end of file
diff --git a/test/Atc.Rest.ApiGenerator.CLI.Tests/Scenarios/ExNsWithTask/VerifyClient/WOPD/src/ExNsWithTask.ApiClient.Generated/GlobalUsings.verified.cs b/test/Atc.Rest.ApiGenerator.CLI.Tests/Scenarios/ExNsWithTask/VerifyClient/WOPD/src/ExNsWithTask.ApiClient.Generated/GlobalUsings.verified.cs
index 7b76232d7..70b8fc3d1 100644
--- a/test/Atc.Rest.ApiGenerator.CLI.Tests/Scenarios/ExNsWithTask/VerifyClient/WOPD/src/ExNsWithTask.ApiClient.Generated/GlobalUsings.verified.cs
+++ b/test/Atc.Rest.ApiGenerator.CLI.Tests/Scenarios/ExNsWithTask/VerifyClient/WOPD/src/ExNsWithTask.ApiClient.Generated/GlobalUsings.verified.cs
@@ -13,7 +13,6 @@
global using ExNsWithTask.ApiClient.Generated.Contracts;
global using ExNsWithTask.ApiClient.Generated.Contracts.EventArgs;
global using ExNsWithTask.ApiClient.Generated.Contracts.Orders;
-global using ExNsWithTask.ApiClient.Generated.Contracts.Tasks;
global using ExNsWithTask.ApiClient.Generated.Contracts.TestUnits;
global using ExNsWithTask.ApiClient.Generated.Endpoints.EventArgs.Interfaces;
global using ExNsWithTask.ApiClient.Generated.Endpoints.Orders.Interfaces;
diff --git a/test/Atc.Rest.ApiGenerator.CLI.Tests/Scenarios/ExNsWithTask/VerifyClient/WPD/src/ExNsWithTask.ApiClient.Generated/GlobalUsings.verified.cs b/test/Atc.Rest.ApiGenerator.CLI.Tests/Scenarios/ExNsWithTask/VerifyClient/WPD/src/ExNsWithTask.ApiClient.Generated/GlobalUsings.verified.cs
index 7b76232d7..70b8fc3d1 100644
--- a/test/Atc.Rest.ApiGenerator.CLI.Tests/Scenarios/ExNsWithTask/VerifyClient/WPD/src/ExNsWithTask.ApiClient.Generated/GlobalUsings.verified.cs
+++ b/test/Atc.Rest.ApiGenerator.CLI.Tests/Scenarios/ExNsWithTask/VerifyClient/WPD/src/ExNsWithTask.ApiClient.Generated/GlobalUsings.verified.cs
@@ -13,7 +13,6 @@
global using ExNsWithTask.ApiClient.Generated.Contracts;
global using ExNsWithTask.ApiClient.Generated.Contracts.EventArgs;
global using ExNsWithTask.ApiClient.Generated.Contracts.Orders;
-global using ExNsWithTask.ApiClient.Generated.Contracts.Tasks;
global using ExNsWithTask.ApiClient.Generated.Contracts.TestUnits;
global using ExNsWithTask.ApiClient.Generated.Endpoints.EventArgs.Interfaces;
global using ExNsWithTask.ApiClient.Generated.Endpoints.Orders.Interfaces;
diff --git a/test/Atc.Rest.ApiGenerator.CLI.Tests/Scenarios/Monta/ApiGeneratorOptions.json b/test/Atc.Rest.ApiGenerator.CLI.Tests/Scenarios/Monta/ApiGeneratorOptions.json
index fe79e7e2f..04c42efa6 100644
--- a/test/Atc.Rest.ApiGenerator.CLI.Tests/Scenarios/Monta/ApiGeneratorOptions.json
+++ b/test/Atc.Rest.ApiGenerator.CLI.Tests/Scenarios/Monta/ApiGeneratorOptions.json
@@ -5,6 +5,11 @@
"useRestExtended": true,
"includeDeprecated": false,
"projectSuffixName": "",
+ "contractsLocation": "Contracts.[[apiGroupName]]",
+ "endpointsLocation": "Endpoints.[[apiGroupName]]",
+ "handlersLocation": "Handlers.[[apiGroupName]]",
+ "usePartialClassForContracts": false,
+ "usePartialClassForEndpoints": false,
"removeNamespaceGroupSeparatorInGlobalUsings": false,
"request": {},
"response": {
@@ -37,7 +42,6 @@
}
},
"client": {
- "folderName": "",
"excludeEndpointGeneration": false,
"httpClientName": "Monta-ApiClient"
}
@@ -49,5 +53,5 @@
"modelNameCasingStyle": "PascalCase",
"modelPropertyNameCasingStyle": "CamelCase"
},
- "includeDeprecated": false
+ "includeDeprecatedOperations": false
}
\ No newline at end of file
diff --git a/test/Atc.Rest.ApiGenerator.CLI.Tests/Scenarios/Structure1/Structure1.yaml b/test/Atc.Rest.ApiGenerator.CLI.Tests/Scenarios/Structure1/Structure1.yaml
new file mode 100644
index 000000000..cf543aff2
--- /dev/null
+++ b/test/Atc.Rest.ApiGenerator.CLI.Tests/Scenarios/Structure1/Structure1.yaml
@@ -0,0 +1,969 @@
+openapi: 3.0.1
+info:
+ title: Demo Sample Api
+ description: Demo Sample Api - SingleFileVersion
+ version: '1.0'
+ contact:
+ name: atc-net A/S
+servers:
+ - url: /api/v1
+ description: Api version 1.0
+x-authorize-roles:
+ - admin
+ - operator
+paths:
+ /orders:
+ x-authentication-required: true
+ get:
+ tags:
+ - Orders
+ summary: Get orders
+ description: Get orders
+ operationId: getOrders
+ parameters:
+ - $ref: '#/components/parameters/pagingPageSize'
+ - $ref: '#/components/parameters/pagingPageIndex'
+ - $ref: '#/components/parameters/queryString'
+ - $ref: '#/components/parameters/queryStringArray'
+ - $ref: '#/components/parameters/continuationToken'
+ responses:
+ '200':
+ description: Expected response to a valid request
+ content:
+ application/json:
+ schema:
+ allOf:
+ - $ref: '#/components/schemas/Pagination'
+ - $ref: '#/components/schemas/Orders'
+ '404':
+ description: Not Found
+ '/orders/{id}':
+ x-authentication-required: true
+ x-authorize-roles:
+ - operator
+ get:
+ tags:
+ - Orders
+ summary: Get order by id
+ description: Get order by id
+ operationId: getOrderById
+ x-authentication-required: false
+ parameters:
+ - name: myEmail
+ in: query
+ description: The email for filter orders to retrieve
+ schema:
+ type: string
+ format: email
+ nullable: true
+ responses:
+ '200':
+ description: Expected response to a valid request
+ content:
+ application/json:
+ schema:
+ $ref: '#/components/schemas/Order'
+ '404':
+ description: Not Found
+ patch:
+ summary: Update part of order by id
+ description: Update part of order by id
+ operationId: patchOrdersId
+ x-authorize-roles:
+ - admin
+ - operator
+ parameters:
+ - name: myTestHeader
+ in: header
+ required: true
+ description: The myTestHeader special key
+ schema:
+ type: string
+ - name: myTestHeaderBool
+ in: header
+ required: true
+ description: The myTestHeaderBool special key
+ schema:
+ type: boolean
+ - name: myTestHeaderInt
+ in: header
+ required: true
+ description: The myTestHeaderInt special key
+ schema:
+ type: integer
+ - name: x-correlation-id
+ in: header
+ required: true
+ description: The correlationId
+ schema:
+ type: string
+ requestBody:
+ content:
+ application/json:
+ schema:
+ $ref: '#/components/schemas/UpdateOrderRequest'
+ responses:
+ '200':
+ description: OK
+ '404':
+ description: Not Found
+ '409':
+ description: Conflict
+ '502':
+ description: Bad Gateway
+ content:
+ application/json:
+ schema:
+ $ref: '#/components/schemas/ProblemDetails'
+ parameters:
+ - name: id
+ in: path
+ description: The id of the order
+ required: true
+ schema:
+ type: string
+ format: uuid
+ /users/email:
+ get:
+ tags:
+ - Users
+ summary: Get user by email
+ description: Get user by email
+ operationId: getUserByEmail
+ parameters:
+ - name: email
+ in: query
+ description: The email of the user to retrieve
+ required: true
+ schema:
+ type: string
+ format: email
+ responses:
+ '200':
+ description: Expected response to a valid request
+ content:
+ application/json:
+ schema:
+ $ref: '#/components/schemas/User'
+ '400':
+ description: Bad Request
+ '404':
+ description: Not Found
+ '409':
+ description: Conflict
+ '/users/{id}':
+ get:
+ summary: Get user by id
+ description: Get user by id
+ operationId: getUserById
+ responses:
+ '200':
+ description: OK
+ content:
+ application/json:
+ schema:
+ $ref: '#/components/schemas/User'
+ '404':
+ description: Not Found
+ '409':
+ description: Conflict
+ put:
+ summary: Update user by id
+ description: Update user by id
+ operationId: updateUserById
+ responses:
+ '200':
+ description: OK
+ '400':
+ description: Bad Request
+ '404':
+ description: Not Found
+ '409':
+ description: Conflict
+ requestBody:
+ content:
+ application/json:
+ schema:
+ $ref: '#/components/schemas/UpdateUserRequest'
+ delete:
+ summary: Delete user by id
+ description: Delete user by id
+ operationId: deleteUserById
+ responses:
+ '200':
+ description: OK
+ '404':
+ description: Not Found
+ '409':
+ description: Conflict
+ parameters:
+ - name: id
+ in: path
+ description: Id of the user
+ required: true
+ schema:
+ type: string
+ format: uuid
+ /users:
+ get:
+ summary: Get all users
+ description: Get all users
+ operationId: getUsers
+ tags: []
+ responses:
+ '200':
+ description: OK
+ content:
+ application/json:
+ schema:
+ $ref: '#/components/schemas/Users'
+ '409':
+ description: Conflict
+ post:
+ summary: Create a new user
+ description: Create a new user
+ operationId: postUser
+ responses:
+ '201':
+ description: Created
+ '400':
+ description: Bad Request
+ '409':
+ description: Conflict
+ requestBody:
+ content:
+ application/json:
+ schema:
+ $ref: '#/components/schemas/CreateUserRequest'
+ '/users/{id}/gender':
+ put:
+ summary: Update gender on a user
+ description: Update gender on a user
+ operationId: updateMyTestGender
+ parameters:
+ - name: genderParam
+ in: query
+ description: The gender to set on the user
+ schema:
+ $ref: '#/components/schemas/GenderType'
+ responses:
+ '200':
+ description: OK
+ '400':
+ description: Bad Request
+ '404':
+ description: Not Found
+ '409':
+ description: Conflict
+ requestBody:
+ content:
+ application/json:
+ schema:
+ $ref: '#/components/schemas/UpdateTestGenderRequest'
+ parameters:
+ - name: id
+ description: Id of the user
+ in: path
+ required: true
+ schema:
+ type: string
+ format: uuid
+ '/accounts/{accountId}/name':
+ put:
+ summary: Update name of account
+ description: Update name of account
+ operationId: updateAccountName
+ responses:
+ '200':
+ description: OK
+ parameters:
+ - name: name
+ in: header
+ description: The account name
+ schema:
+ type: string
+ post:
+ summary: Set name of account
+ description: Set name of account
+ operationId: setAccountName
+ responses:
+ '200':
+ description: OK
+ requestBody:
+ content:
+ application/json:
+ schema:
+ $ref: '#/components/schemas/UpdateAccountRequest'
+ parameters:
+ - name: accountId
+ in: path
+ required: true
+ description: The accountId
+ schema:
+ type: string
+ format: uuid
+ '/addresses/{postalCode}':
+ get:
+ summary: Get addresses by postal code
+ description: Get addresses by postal code
+ operationId: getAddressesByPostalCodes
+ tags: []
+ responses:
+ '200':
+ description: OK
+ content:
+ application/json:
+ schema:
+ type: array
+ items:
+ $ref: '#/components/schemas/Address'
+ '404':
+ description: Not Found
+ parameters:
+ - name: postalCode
+ in: path
+ required: true
+ description: The postalCode to limit addresses on
+ schema:
+ type: string
+ /route-with-dash:
+ get:
+ summary: Your GET endpoint
+ description: Your GET endpoint
+ tags: []
+ responses:
+ '200':
+ description: OK
+ operationId: getRouteWithDash
+ /items:
+ post:
+ summary: Create a new item
+ description: Create a new item
+ operationId: createItem
+ responses:
+ '200':
+ description: OK
+ requestBody:
+ content:
+ application/json:
+ schema:
+ $ref: '#/components/schemas/CreateItemRequest'
+ '/items/{id}':
+ put:
+ summary: Updates an item
+ description: Updates an item
+ operationId: updateItem
+ responses:
+ '200':
+ description: OK
+ content:
+ application/json:
+ schema:
+ type: string
+ format: uuid
+ requestBody:
+ content:
+ application/json:
+ schema:
+ $ref: '#/components/schemas/UpdateItemRequest'
+ parameters:
+ - name: id
+ in: path
+ description: The id of the order
+ required: true
+ schema:
+ type: string
+ format: uuid
+ /tasks:
+ get:
+ operationId: getTasks
+ summary: Returns tasks
+ description: Returns tasks
+ tags: []
+ responses:
+ '200':
+ description: OK
+ content:
+ application/json:
+ schema:
+ $ref: '#/components/schemas/Tasks'
+ '/eventArgs/{id}':
+ parameters:
+ - name: id
+ in: path
+ description: The id of the eventArgs
+ required: true
+ schema:
+ type: string
+ get:
+ summary: Get EventArgs By Id
+ description: Get EventArgs By Id
+ tags: []
+ responses:
+ '200':
+ description: OK
+ content:
+ application/json:
+ schema:
+ $ref: '#/components/schemas/EventArgs'
+ '404':
+ description: Not Found
+ operationId: getEventArgById
+ /eventArgs:
+ get:
+ operationId: getEventArgs
+ summary: Get EventArgs List
+ description: Get EventArgs List
+ tags: []
+ responses:
+ '200':
+ description: OK
+ content:
+ application/json:
+ schema:
+ type: array
+ items:
+ $ref: '#/components/schemas/EventArgs'
+ '/files/{id}':
+ parameters:
+ - name: id
+ in: path
+ description: The file id
+ required: true
+ schema:
+ type: string
+ get:
+ operationId: getFileById
+ summary: Get File By Id
+ description: Get File By Id
+ tags: []
+ responses:
+ '200':
+ description: OK
+ content:
+ application/octet-stream:
+ schema:
+ type: string
+ format: binary
+ headers: {}
+ '404':
+ description: Not Found
+ /files/form-data/singleObject:
+ post:
+ operationId: uploadSingleObjectWithFileAsFormData
+ summary: Upload a file as FormData
+ description: Upload a file as FormData
+ responses:
+ '200':
+ description: OK
+ '400':
+ description: Bad Request
+ requestBody:
+ content:
+ multipart/form-data:
+ schema:
+ $ref: '#/components/schemas/FileAsFormDataRequest'
+ parameters: []
+ /files/form-data/singleObjectMultiFile:
+ post:
+ operationId: uploadSingleObjectWithFilesAsFormData
+ summary: Upload files as FormData
+ description: Upload files as FormData
+ responses:
+ '200':
+ description: OK
+ '400':
+ description: Bad Request
+ requestBody:
+ content:
+ multipart/form-data:
+ schema:
+ $ref: '#/components/schemas/FilesAsFormDataRequest'
+ parameters: []
+ /files/form-data/singleFile:
+ post:
+ operationId: uploadSingleFileAsFormData
+ summary: Upload a file as OctetStream
+ description: Upload a file as OctetStream
+ responses:
+ '200':
+ description: OK
+ requestBody:
+ content:
+ application/octet-stream:
+ schema:
+ type: string
+ format: binary
+ parameters: []
+ /files/form-data/multiFile:
+ post:
+ summary: Upload multi files as form data
+ description: Upload multi files as form data
+ operationId: uploadMultiFilesAsFormData
+ responses:
+ '200':
+ description: OK
+ requestBody:
+ content:
+ multipart/form-data:
+ schema:
+ type: array
+ items:
+ type: string
+ format: binary
+components:
+ parameters:
+ pagingPageSize:
+ name: pageSize
+ in: query
+ required: true
+ schema:
+ type: integer
+ minimum: 1
+ maximum: 100
+ default: 10
+ description: The numbers of items to return.
+ pagingPageIndex:
+ name: pageIndex
+ in: query
+ required: false
+ schema:
+ type: integer
+ minimum: 0
+ default: 0
+ description: The number of items to skip before starting to collect the result set.
+ queryString:
+ name: queryString
+ in: query
+ required: false
+ schema:
+ type: string
+ nullable: true
+ description: The query string.
+ queryStringArray:
+ name: queryStringArray
+ in: query
+ required: false
+ schema:
+ type: array
+ items:
+ type: string
+ nullable: true
+ description: The query array of string.
+ continuationToken:
+ name: continuationToken
+ in: query
+ required: false
+ schema:
+ type: string
+ nullable: true
+ description: The continuation token.
+ schemas:
+ Pagination:
+ type: object
+ title: Pagination
+ description: A item result subset of a data query.
+ properties:
+ pageSize:
+ type: number
+ description: The number of items to request.
+ pageIndex:
+ type: number
+ nullable: true
+ description: The given page index starting with 0.
+ queryString:
+ type: string
+ nullable: true
+ description: The query to filter items by.
+ continuationToken:
+ type: string
+ nullable: true
+ description: Token to indicate next result set.
+ count:
+ type: number
+ description: Items count in result set.
+ totalCount:
+ type: number
+ nullable: true
+ description: Total items count.
+ totalPages:
+ type: number
+ nullable: true
+ description: Total pages.
+ required:
+ - pageSize
+ - count
+ ProblemDetails:
+ type: object
+ title: ProblemDetails
+ description: 'A machine-readable format for specifying errors in HTTP API responses based on https://tools.ietf.org/html/rfc7807.'
+ properties:
+ type:
+ type: string
+ description: 'A URI reference [RFC3986] that identifies the problem type. This specification encourages that, when dereferenced, it provide human-readable documentation for the problem type (e.g., using HTML [W3C.REC-html5-20141028]).'
+ title:
+ type: string
+ description: 'A short, human-readable summary of the problem type.It SHOULD NOT change from occurrence to occurrence of the problem, except for purposes of localization(e.g., using proactive content negotiation; see[RFC7231], Section 3.4).'
+ status:
+ type: integer
+ format: int32
+ description: 'The HTTP status code([RFC7231], Section 6) generated by the origin server for this occurrence of the problem.'
+ detail:
+ type: string
+ description: A human-readable explanation specific to this occurrence of the problem.
+ instance:
+ type: string
+ description: A URI reference that identifies the specific occurrence of the problem. It may or may not yield further information if dereferenced.
+ Order:
+ title: Order
+ description: |-
+ A single order.
+ Hallo description with multiline and no ending dot
+ type: object
+ x-examples:
+ MyExample:
+ id: 123
+ name: Hallo world
+ MyExample2: {}
+ properties:
+ id:
+ type: string
+ format: uuid
+ description:
+ type: string
+ myTime:
+ type: string
+ format: time
+ myEmail:
+ type: string
+ format: email
+ default: a@a.com
+ myNullableDateTime:
+ type: string
+ format: date-time
+ nullable: true
+ myDateTime:
+ type: string
+ format: date-time
+ myNumber:
+ type: number
+ minimum: 1.1
+ maximum: 20.2
+ myInteger:
+ type: integer
+ maximum: 50
+ default: 15
+ myBool:
+ type: boolean
+ description: MyBool is great
+ myUri:
+ type: string
+ format: uri
+ description: 'This is the good uri :-)'
+ myByte:
+ type: string
+ format: byte
+ myStringList:
+ type: array
+ description: 'Hallo myStringList desc :-)'
+ items:
+ type: string
+ myLong:
+ type: integer
+ format: int64
+ minimum: 10
+ exclusiveMinimum: false
+ deliveryAddress:
+ $ref: '#/components/schemas/Address'
+ Orders:
+ description: A list of orders.
+ type: array
+ x-tags:
+ - Orders
+ title: Orders
+ items:
+ $ref: '#/components/schemas/Order'
+ GenderType:
+ title: GenderType
+ description: ''
+ type: object
+ properties:
+ gender:
+ type: string
+ description: The users gender type
+ enum:
+ - None
+ - NonBinary
+ - Male
+ - Female
+ required:
+ - gender
+ ColorType:
+ title: ColorType
+ description: ''
+ type: object
+ properties:
+ color:
+ type: string
+ description: The users color type
+ enum:
+ - None = 0
+ - Black = 1
+ - White = 2
+ - Yellow = 4
+ - Red = 8
+ required:
+ - color
+ User:
+ title: User
+ description: A single user.
+ type: object
+ properties:
+ id:
+ type: string
+ format: uuid
+ example: 00000000-0000-0000-0000-000000000000
+ gender:
+ $ref: '#/components/schemas/GenderType'
+ firstName:
+ type: string
+ lastName:
+ type: string
+ email:
+ type: string
+ format: email
+ example: email@email.dk
+ homepage:
+ type: string
+ format: uri
+ color:
+ $ref: '#/components/schemas/ColorType'
+ homeAddress:
+ $ref: '#/components/schemas/Address'
+ companyAddress:
+ $ref: '#/components/schemas/Address'
+ Users:
+ description: A list of users.
+ type: array
+ items:
+ $ref: '#/components/schemas/User'
+ x-tags:
+ - Users
+ title: Users
+ CreateUserRequest:
+ title: CreateUserRequest
+ description: Request to create a user
+ type: object
+ properties:
+ firstName:
+ type: string
+ lastName:
+ type: string
+ myNullableDateTime:
+ type: string
+ format: date-time
+ nullable: true
+ myDateTime:
+ type: string
+ format: date-time
+ email:
+ type: string
+ format: email
+ example: email@email.dk
+ homepage:
+ type: string
+ format: uri
+ gender:
+ $ref: '#/components/schemas/GenderType'
+ myNullableAddress:
+ nullable: true
+ oneOf:
+ - $ref: '#/components/schemas/Address'
+ tags:
+ type: object
+ additionalProperties:
+ type: string
+ desiredProperties1:
+ type: object
+ additionalProperties:
+ type: string
+ desiredProperties2:
+ type: object
+ nullable: true
+ additionalProperties:
+ type: string
+ desiredProperties3:
+ type: object
+ nullable: true
+ additionalProperties:
+ type: integer
+ required:
+ - firstName
+ - lastName
+ - myDateTime
+ - email
+ - gender
+ - tags
+ CreateUsersRequest:
+ description: A list of users.
+ type: array
+ x-tags:
+ - CreateUsersRequest
+ title: CreateUsersRequest
+ items:
+ $ref: '#/components/schemas/CreateUserRequest'
+ UpdateUserRequest:
+ title: UpdateUserRequest
+ description: Request to update a user
+ type: object
+ properties:
+ firstName:
+ type: string
+ lastName:
+ type: string
+ email:
+ type: string
+ format: email
+ example: email@email.dk
+ gender:
+ $ref: '#/components/schemas/GenderType'
+ UpdateTestGenderRequest:
+ title: Update test-gender Request
+ description: ''
+ type: object
+ properties:
+ gender:
+ $ref: '#/components/schemas/GenderType'
+ Address:
+ title: Address
+ type: object
+ properties:
+ streetName:
+ type: string
+ maxLength: 255
+ streetNumber:
+ type: string
+ postalCode:
+ type: string
+ cityName:
+ type: string
+ myCountry:
+ $ref: '#/components/schemas/Country'
+ Country:
+ title: Country
+ type: object
+ properties:
+ name:
+ type: string
+ alpha2Code:
+ type: string
+ minLength: 2
+ maxLength: 2
+ pattern: '^[A-Za-z]{2}$'
+ alpha3Code:
+ type: string
+ minLength: 3
+ maxLength: 3
+ pattern: '^[A-Za-z]{3}$'
+ required:
+ - name
+ - alpha2Code
+ - alpha3Code
+ UpdateOrderRequest:
+ title: UpdateOrderRequest
+ description: Request to update an order
+ type: object
+ properties:
+ myEmail:
+ type: string
+ format: email
+ required:
+ - myEmail
+ Item:
+ title: Item
+ type: object
+ properties:
+ name:
+ type: string
+ required:
+ - name
+ CreateItemRequest:
+ title: CreateItemRequest
+ type: object
+ properties:
+ item:
+ $ref: '#/components/schemas/Item'
+ myItems:
+ type: array
+ items:
+ $ref: '#/components/schemas/Item'
+ required:
+ - item
+ - myItems
+ UpdateItemRequest:
+ title: UpdateItemRequest
+ type: object
+ properties:
+ item:
+ $ref: '#/components/schemas/Item'
+ required:
+ - item
+ Task:
+ title: Task
+ type: object
+ properties:
+ id:
+ type: string
+ format: uuid
+ name:
+ type: string
+ description: Describes a single task.
+ Tasks:
+ title: Tasks
+ type: array
+ items:
+ $ref: '#/components/schemas/Task'
+ description: Contains a list of Tasks
+ EventArgs:
+ title: EventArgs
+ type: object
+ properties:
+ id:
+ type: string
+ format: uuid
+ eventName:
+ type: string
+ FileAsFormDataRequest:
+ title: FileAsFormDataRequest
+ type: object
+ properties:
+ itemName:
+ type: string
+ file:
+ type: string
+ format: binary
+ nullable: true
+ items:
+ type: array
+ items:
+ type: string
+ required:
+ - itemName
+ - items
+ FilesAsFormDataRequest:
+ title: FilesAsFormDataRequest
+ type: object
+ properties:
+ files:
+ type: array
+ items:
+ type: string
+ format: binary
+ required:
+ - files
+ UpdateAccountRequest:
+ title: UpdateAccountRequest
+ type: object
+ properties:
+ name:
+ type: string
\ No newline at end of file
diff --git a/test/Atc.Rest.ApiGenerator.CLI.Tests/Scenarios/Structure1/VerifyClient/WOPD/src/Structure1.ApiClient.Generated/Accounts/MyContracts/RequestParameters/SetAccountNameParameters.verified.cs b/test/Atc.Rest.ApiGenerator.CLI.Tests/Scenarios/Structure1/VerifyClient/WOPD/src/Structure1.ApiClient.Generated/Accounts/MyContracts/RequestParameters/SetAccountNameParameters.verified.cs
new file mode 100644
index 000000000..ebd55f30f
--- /dev/null
+++ b/test/Atc.Rest.ApiGenerator.CLI.Tests/Scenarios/Structure1/VerifyClient/WOPD/src/Structure1.ApiClient.Generated/Accounts/MyContracts/RequestParameters/SetAccountNameParameters.verified.cs
@@ -0,0 +1,32 @@
+//------------------------------------------------------------------------------
+// This code was auto-generated by ApiGenerator x.x.x.x.
+//
+// Changes to this file may cause incorrect behavior and will be lost if
+// the code is regenerated.
+//------------------------------------------------------------------------------
+namespace Structure1.ApiClient.Generated.Accounts.MyContracts;
+
+///
+/// Parameters for operation request.
+/// Description: Set name of account.
+/// Operation: SetAccountName.
+///
+[GeneratedCode("ApiGenerator", "x.x.x.x")]
+public class SetAccountNameParameters
+{
+ ///
+ /// The accountId.
+ ///
+ [Required]
+ public Guid AccountId { get; set; }
+
+ ///
+ /// UpdateAccountRequest.
+ ///
+ [Required]
+ public UpdateAccountRequest Request { get; set; }
+
+ ///
+ public override string ToString()
+ => $"{nameof(AccountId)}: {AccountId}, {nameof(Request)}: ({Request})";
+}
\ No newline at end of file
diff --git a/test/Atc.Rest.ApiGenerator.CLI.Tests/Scenarios/Structure1/VerifyClient/WOPD/src/Structure1.ApiClient.Generated/Accounts/MyContracts/RequestParameters/UpdateAccountNameParameters.verified.cs b/test/Atc.Rest.ApiGenerator.CLI.Tests/Scenarios/Structure1/VerifyClient/WOPD/src/Structure1.ApiClient.Generated/Accounts/MyContracts/RequestParameters/UpdateAccountNameParameters.verified.cs
new file mode 100644
index 000000000..8a179d181
--- /dev/null
+++ b/test/Atc.Rest.ApiGenerator.CLI.Tests/Scenarios/Structure1/VerifyClient/WOPD/src/Structure1.ApiClient.Generated/Accounts/MyContracts/RequestParameters/UpdateAccountNameParameters.verified.cs
@@ -0,0 +1,31 @@
+//------------------------------------------------------------------------------
+// This code was auto-generated by ApiGenerator x.x.x.x.
+//
+// Changes to this file may cause incorrect behavior and will be lost if
+// the code is regenerated.
+//------------------------------------------------------------------------------
+namespace Structure1.ApiClient.Generated.Accounts.MyContracts;
+
+///
+/// Parameters for operation request.
+/// Description: Update name of account.
+/// Operation: UpdateAccountName.
+///
+[GeneratedCode("ApiGenerator", "x.x.x.x")]
+public class UpdateAccountNameParameters
+{
+ ///
+ /// The accountId.
+ ///
+ [Required]
+ public Guid AccountId { get; set; }
+
+ ///
+ /// The account name.
+ ///
+ public string Name { get; set; }
+
+ ///
+ public override string ToString()
+ => $"{nameof(AccountId)}: {AccountId}, {nameof(Name)}: {Name}";
+}
\ No newline at end of file
diff --git a/test/Atc.Rest.ApiGenerator.CLI.Tests/Scenarios/Structure1/VerifyClient/WOPD/src/Structure1.ApiClient.Generated/Accounts/MyContracts/UpdateAccountRequest.verified.cs b/test/Atc.Rest.ApiGenerator.CLI.Tests/Scenarios/Structure1/VerifyClient/WOPD/src/Structure1.ApiClient.Generated/Accounts/MyContracts/UpdateAccountRequest.verified.cs
new file mode 100644
index 000000000..892a401ed
--- /dev/null
+++ b/test/Atc.Rest.ApiGenerator.CLI.Tests/Scenarios/Structure1/VerifyClient/WOPD/src/Structure1.ApiClient.Generated/Accounts/MyContracts/UpdateAccountRequest.verified.cs
@@ -0,0 +1,20 @@
+//------------------------------------------------------------------------------
+// This code was auto-generated by ApiGenerator x.x.x.x.
+//
+// Changes to this file may cause incorrect behavior and will be lost if
+// the code is regenerated.
+//------------------------------------------------------------------------------
+namespace Structure1.ApiClient.Generated.Accounts.MyContracts;
+
+///
+/// UpdateAccountRequest.
+///
+[GeneratedCode("ApiGenerator", "x.x.x.x")]
+public class UpdateAccountRequest
+{
+ public string Name { get; set; }
+
+ ///
+ public override string ToString()
+ => $"{nameof(Name)}: {Name}";
+}
\ No newline at end of file
diff --git a/test/Atc.Rest.ApiGenerator.CLI.Tests/Scenarios/Structure1/VerifyClient/WOPD/src/Structure1.ApiClient.Generated/Accounts/MyEndpoints/Interfaces/ISetAccountNameEndpoint.verified.cs b/test/Atc.Rest.ApiGenerator.CLI.Tests/Scenarios/Structure1/VerifyClient/WOPD/src/Structure1.ApiClient.Generated/Accounts/MyEndpoints/Interfaces/ISetAccountNameEndpoint.verified.cs
new file mode 100644
index 000000000..7dd9edc6d
--- /dev/null
+++ b/test/Atc.Rest.ApiGenerator.CLI.Tests/Scenarios/Structure1/VerifyClient/WOPD/src/Structure1.ApiClient.Generated/Accounts/MyEndpoints/Interfaces/ISetAccountNameEndpoint.verified.cs
@@ -0,0 +1,27 @@
+//------------------------------------------------------------------------------
+// This code was auto-generated by ApiGenerator x.x.x.x.
+//
+// Changes to this file may cause incorrect behavior and will be lost if
+// the code is regenerated.
+//------------------------------------------------------------------------------
+namespace Structure1.ApiClient.Generated.Accounts.MyEndpoints.Interfaces;
+
+///
+/// Interface for Client Endpoint.
+/// Description: Set name of account.
+/// Operation: SetAccountName.
+///
+[GeneratedCode("ApiGenerator", "x.x.x.x")]
+public interface ISetAccountNameEndpoint
+{
+ ///
+ /// Execute method.
+ ///
+ /// The parameters.
+ /// The http client name.
+ /// The cancellation token.
+ Task ExecuteAsync(
+ SetAccountNameParameters parameters,
+ string httpClientName = "Structure1-ApiClient",
+ CancellationToken cancellationToken = default);
+}
\ No newline at end of file
diff --git a/test/Atc.Rest.ApiGenerator.CLI.Tests/Scenarios/Structure1/VerifyClient/WOPD/src/Structure1.ApiClient.Generated/Accounts/MyEndpoints/Interfaces/ISetAccountNameEndpointResult.verified.cs b/test/Atc.Rest.ApiGenerator.CLI.Tests/Scenarios/Structure1/VerifyClient/WOPD/src/Structure1.ApiClient.Generated/Accounts/MyEndpoints/Interfaces/ISetAccountNameEndpointResult.verified.cs
new file mode 100644
index 000000000..193943fc9
--- /dev/null
+++ b/test/Atc.Rest.ApiGenerator.CLI.Tests/Scenarios/Structure1/VerifyClient/WOPD/src/Structure1.ApiClient.Generated/Accounts/MyEndpoints/Interfaces/ISetAccountNameEndpointResult.verified.cs
@@ -0,0 +1,25 @@
+//------------------------------------------------------------------------------
+// This code was auto-generated by ApiGenerator x.x.x.x.
+//
+// Changes to this file may cause incorrect behavior and will be lost if
+// the code is regenerated.
+//------------------------------------------------------------------------------
+namespace Structure1.ApiClient.Generated.Accounts.MyEndpoints.Interfaces;
+
+///
+/// Interface for Client Endpoint Result.
+/// Description: Set name of account.
+/// Operation: SetAccountName.
+///
+[GeneratedCode("ApiGenerator", "x.x.x.x")]
+public interface ISetAccountNameEndpointResult : IEndpointResponse
+{
+
+ bool IsOk { get; }
+
+ bool IsBadRequest { get; }
+
+ string? OkContent { get; }
+
+ string? BadRequestContent { get; }
+}
\ No newline at end of file
diff --git a/test/Atc.Rest.ApiGenerator.CLI.Tests/Scenarios/Structure1/VerifyClient/WOPD/src/Structure1.ApiClient.Generated/Accounts/MyEndpoints/Interfaces/IUpdateAccountNameEndpoint.verified.cs b/test/Atc.Rest.ApiGenerator.CLI.Tests/Scenarios/Structure1/VerifyClient/WOPD/src/Structure1.ApiClient.Generated/Accounts/MyEndpoints/Interfaces/IUpdateAccountNameEndpoint.verified.cs
new file mode 100644
index 000000000..ae216ccb0
--- /dev/null
+++ b/test/Atc.Rest.ApiGenerator.CLI.Tests/Scenarios/Structure1/VerifyClient/WOPD/src/Structure1.ApiClient.Generated/Accounts/MyEndpoints/Interfaces/IUpdateAccountNameEndpoint.verified.cs
@@ -0,0 +1,27 @@
+//------------------------------------------------------------------------------
+// This code was auto-generated by ApiGenerator x.x.x.x.
+//
+// Changes to this file may cause incorrect behavior and will be lost if
+// the code is regenerated.
+//------------------------------------------------------------------------------
+namespace Structure1.ApiClient.Generated.Accounts.MyEndpoints.Interfaces;
+
+///
+/// Interface for Client Endpoint.
+/// Description: Update name of account.
+/// Operation: UpdateAccountName.
+///
+[GeneratedCode("ApiGenerator", "x.x.x.x")]
+public interface IUpdateAccountNameEndpoint
+{
+ ///
+ /// Execute method.
+ ///
+ /// The parameters.
+ /// The http client name.
+ /// The cancellation token.
+ Task ExecuteAsync(
+ UpdateAccountNameParameters parameters,
+ string httpClientName = "Structure1-ApiClient",
+ CancellationToken cancellationToken = default);
+}
\ No newline at end of file
diff --git a/test/Atc.Rest.ApiGenerator.CLI.Tests/Scenarios/Structure1/VerifyClient/WOPD/src/Structure1.ApiClient.Generated/Accounts/MyEndpoints/Interfaces/IUpdateAccountNameEndpointResult.verified.cs b/test/Atc.Rest.ApiGenerator.CLI.Tests/Scenarios/Structure1/VerifyClient/WOPD/src/Structure1.ApiClient.Generated/Accounts/MyEndpoints/Interfaces/IUpdateAccountNameEndpointResult.verified.cs
new file mode 100644
index 000000000..7e9545d99
--- /dev/null
+++ b/test/Atc.Rest.ApiGenerator.CLI.Tests/Scenarios/Structure1/VerifyClient/WOPD/src/Structure1.ApiClient.Generated/Accounts/MyEndpoints/Interfaces/IUpdateAccountNameEndpointResult.verified.cs
@@ -0,0 +1,25 @@
+//------------------------------------------------------------------------------
+// This code was auto-generated by ApiGenerator x.x.x.x.
+//
+// Changes to this file may cause incorrect behavior and will be lost if
+// the code is regenerated.
+//------------------------------------------------------------------------------
+namespace Structure1.ApiClient.Generated.Accounts.MyEndpoints.Interfaces;
+
+///
+/// Interface for Client Endpoint Result.
+/// Description: Update name of account.
+/// Operation: UpdateAccountName.
+///
+[GeneratedCode("ApiGenerator", "x.x.x.x")]
+public interface IUpdateAccountNameEndpointResult : IEndpointResponse
+{
+
+ bool IsOk { get; }
+
+ bool IsBadRequest { get; }
+
+ string? OkContent { get; }
+
+ string? BadRequestContent { get; }
+}
\ No newline at end of file
diff --git a/test/Atc.Rest.ApiGenerator.CLI.Tests/Scenarios/Structure1/VerifyClient/WOPD/src/Structure1.ApiClient.Generated/Accounts/MyEndpoints/SetAccountNameEndpoint.verified.cs b/test/Atc.Rest.ApiGenerator.CLI.Tests/Scenarios/Structure1/VerifyClient/WOPD/src/Structure1.ApiClient.Generated/Accounts/MyEndpoints/SetAccountNameEndpoint.verified.cs
new file mode 100644
index 000000000..1f717bf17
--- /dev/null
+++ b/test/Atc.Rest.ApiGenerator.CLI.Tests/Scenarios/Structure1/VerifyClient/WOPD/src/Structure1.ApiClient.Generated/Accounts/MyEndpoints/SetAccountNameEndpoint.verified.cs
@@ -0,0 +1,47 @@
+//------------------------------------------------------------------------------
+// This code was auto-generated by ApiGenerator x.x.x.x.
+//
+// Changes to this file may cause incorrect behavior and will be lost if
+// the code is regenerated.
+//------------------------------------------------------------------------------
+namespace Structure1.ApiClient.Generated.Accounts.MyEndpoints;
+
+///
+/// Client Endpoint.
+/// Description: Set name of account.
+/// Operation: SetAccountName.
+///
+[GeneratedCode("ApiGenerator", "x.x.x.x")]
+public class SetAccountNameEndpoint : ISetAccountNameEndpoint
+{
+ private readonly IHttpClientFactory factory;
+ private readonly IHttpMessageFactory httpMessageFactory;
+
+ public SetAccountNameEndpoint(
+ IHttpClientFactory factory,
+ IHttpMessageFactory httpMessageFactory)
+ {
+ this.factory = factory;
+ this.httpMessageFactory = httpMessageFactory;
+ }
+
+ public async Task ExecuteAsync(
+ SetAccountNameParameters parameters,
+ string httpClientName = "Structure1-ApiClient",
+ CancellationToken cancellationToken = default)
+ {
+ var client = factory.CreateClient(httpClientName);
+
+ var requestBuilder = httpMessageFactory.FromTemplate("/api/v1/accounts/{accountId}/name");
+ requestBuilder.WithPathParameter("accountId", parameters.AccountId);
+ requestBuilder.WithBody(parameters.Request);
+
+ using var requestMessage = requestBuilder.Build(HttpMethod.Post);
+ using var response = await client.SendAsync(requestMessage, cancellationToken);
+
+ var responseBuilder = httpMessageFactory.FromResponse(response);
+ responseBuilder.AddSuccessResponse(HttpStatusCode.OK);
+ responseBuilder.AddErrorResponse(HttpStatusCode.BadRequest);
+ return await responseBuilder.BuildResponseAsync(x => new SetAccountNameEndpointResult(x), cancellationToken);
+ }
+}
\ No newline at end of file
diff --git a/test/Atc.Rest.ApiGenerator.CLI.Tests/Scenarios/Structure1/VerifyClient/WOPD/src/Structure1.ApiClient.Generated/Accounts/MyEndpoints/SetAccountNameEndpointResult.verified.cs b/test/Atc.Rest.ApiGenerator.CLI.Tests/Scenarios/Structure1/VerifyClient/WOPD/src/Structure1.ApiClient.Generated/Accounts/MyEndpoints/SetAccountNameEndpointResult.verified.cs
new file mode 100644
index 000000000..59cbff3da
--- /dev/null
+++ b/test/Atc.Rest.ApiGenerator.CLI.Tests/Scenarios/Structure1/VerifyClient/WOPD/src/Structure1.ApiClient.Generated/Accounts/MyEndpoints/SetAccountNameEndpointResult.verified.cs
@@ -0,0 +1,37 @@
+//------------------------------------------------------------------------------
+// This code was auto-generated by ApiGenerator x.x.x.x.
+//
+// Changes to this file may cause incorrect behavior and will be lost if
+// the code is regenerated.
+//------------------------------------------------------------------------------
+namespace Structure1.ApiClient.Generated.Accounts.MyEndpoints;
+
+///
+/// Client Endpoint result.
+/// Description: Set name of account.
+/// Operation: SetAccountName.
+///
+[GeneratedCode("ApiGenerator", "x.x.x.x")]
+public class SetAccountNameEndpointResult : EndpointResponse, ISetAccountNameEndpointResult
+{
+ public SetAccountNameEndpointResult(EndpointResponse response)
+ : base(response)
+ {
+ }
+
+ public bool IsOk
+ => StatusCode == HttpStatusCode.OK;
+
+ public bool IsBadRequest
+ => StatusCode == HttpStatusCode.BadRequest;
+
+ public string? OkContent
+ => IsOk && ContentObject is string result
+ ? result
+ : throw new InvalidOperationException("Content is not the expected type - please use the IsOk property first.");
+
+ public string? BadRequestContent
+ => IsBadRequest && ContentObject is string result
+ ? result
+ : throw new InvalidOperationException("Content is not the expected type - please use the IsBadRequest property first.");
+}
\ No newline at end of file
diff --git a/test/Atc.Rest.ApiGenerator.CLI.Tests/Scenarios/Structure1/VerifyClient/WOPD/src/Structure1.ApiClient.Generated/Accounts/MyEndpoints/UpdateAccountNameEndpoint.verified.cs b/test/Atc.Rest.ApiGenerator.CLI.Tests/Scenarios/Structure1/VerifyClient/WOPD/src/Structure1.ApiClient.Generated/Accounts/MyEndpoints/UpdateAccountNameEndpoint.verified.cs
new file mode 100644
index 000000000..9128f0b5e
--- /dev/null
+++ b/test/Atc.Rest.ApiGenerator.CLI.Tests/Scenarios/Structure1/VerifyClient/WOPD/src/Structure1.ApiClient.Generated/Accounts/MyEndpoints/UpdateAccountNameEndpoint.verified.cs
@@ -0,0 +1,47 @@
+//------------------------------------------------------------------------------
+// This code was auto-generated by ApiGenerator x.x.x.x.
+//
+// Changes to this file may cause incorrect behavior and will be lost if
+// the code is regenerated.
+//------------------------------------------------------------------------------
+namespace Structure1.ApiClient.Generated.Accounts.MyEndpoints;
+
+///
+/// Client Endpoint.
+/// Description: Update name of account.
+/// Operation: UpdateAccountName.
+///
+[GeneratedCode("ApiGenerator", "x.x.x.x")]
+public class UpdateAccountNameEndpoint : IUpdateAccountNameEndpoint
+{
+ private readonly IHttpClientFactory factory;
+ private readonly IHttpMessageFactory httpMessageFactory;
+
+ public UpdateAccountNameEndpoint(
+ IHttpClientFactory factory,
+ IHttpMessageFactory httpMessageFactory)
+ {
+ this.factory = factory;
+ this.httpMessageFactory = httpMessageFactory;
+ }
+
+ public async Task ExecuteAsync(
+ UpdateAccountNameParameters parameters,
+ string httpClientName = "Structure1-ApiClient",
+ CancellationToken cancellationToken = default)
+ {
+ var client = factory.CreateClient(httpClientName);
+
+ var requestBuilder = httpMessageFactory.FromTemplate("/api/v1/accounts/{accountId}/name");
+ requestBuilder.WithPathParameter("accountId", parameters.AccountId);
+ requestBuilder.WithHeaderParameter("name", parameters.Name);
+
+ using var requestMessage = requestBuilder.Build(HttpMethod.Put);
+ using var response = await client.SendAsync(requestMessage, cancellationToken);
+
+ var responseBuilder = httpMessageFactory.FromResponse(response);
+ responseBuilder.AddSuccessResponse(HttpStatusCode.OK);
+ responseBuilder.AddErrorResponse(HttpStatusCode.BadRequest);
+ return await responseBuilder.BuildResponseAsync(x => new UpdateAccountNameEndpointResult(x), cancellationToken);
+ }
+}
\ No newline at end of file
diff --git a/test/Atc.Rest.ApiGenerator.CLI.Tests/Scenarios/Structure1/VerifyClient/WOPD/src/Structure1.ApiClient.Generated/Accounts/MyEndpoints/UpdateAccountNameEndpointResult.verified.cs b/test/Atc.Rest.ApiGenerator.CLI.Tests/Scenarios/Structure1/VerifyClient/WOPD/src/Structure1.ApiClient.Generated/Accounts/MyEndpoints/UpdateAccountNameEndpointResult.verified.cs
new file mode 100644
index 000000000..855d4cacc
--- /dev/null
+++ b/test/Atc.Rest.ApiGenerator.CLI.Tests/Scenarios/Structure1/VerifyClient/WOPD/src/Structure1.ApiClient.Generated/Accounts/MyEndpoints/UpdateAccountNameEndpointResult.verified.cs
@@ -0,0 +1,37 @@
+//------------------------------------------------------------------------------
+// This code was auto-generated by ApiGenerator x.x.x.x.
+//
+// Changes to this file may cause incorrect behavior and will be lost if
+// the code is regenerated.
+//------------------------------------------------------------------------------
+namespace Structure1.ApiClient.Generated.Accounts.MyEndpoints;
+
+///
+/// Client Endpoint result.
+/// Description: Update name of account.
+/// Operation: UpdateAccountName.
+///
+[GeneratedCode("ApiGenerator", "x.x.x.x")]
+public class UpdateAccountNameEndpointResult : EndpointResponse, IUpdateAccountNameEndpointResult
+{
+ public UpdateAccountNameEndpointResult(EndpointResponse response)
+ : base(response)
+ {
+ }
+
+ public bool IsOk
+ => StatusCode == HttpStatusCode.OK;
+
+ public bool IsBadRequest
+ => StatusCode == HttpStatusCode.BadRequest;
+
+ public string? OkContent
+ => IsOk && ContentObject is string result
+ ? result
+ : throw new InvalidOperationException("Content is not the expected type - please use the IsOk property first.");
+
+ public string? BadRequestContent
+ => IsBadRequest && ContentObject is string result
+ ? result
+ : throw new InvalidOperationException("Content is not the expected type - please use the IsBadRequest property first.");
+}
\ No newline at end of file
diff --git a/test/Atc.Rest.ApiGenerator.CLI.Tests/Scenarios/Structure1/VerifyClient/WOPD/src/Structure1.ApiClient.Generated/Addresses/MyContracts/RequestParameters/GetAddressesByPostalCodesParameters.verified.cs b/test/Atc.Rest.ApiGenerator.CLI.Tests/Scenarios/Structure1/VerifyClient/WOPD/src/Structure1.ApiClient.Generated/Addresses/MyContracts/RequestParameters/GetAddressesByPostalCodesParameters.verified.cs
new file mode 100644
index 000000000..4a4dccec8
--- /dev/null
+++ b/test/Atc.Rest.ApiGenerator.CLI.Tests/Scenarios/Structure1/VerifyClient/WOPD/src/Structure1.ApiClient.Generated/Addresses/MyContracts/RequestParameters/GetAddressesByPostalCodesParameters.verified.cs
@@ -0,0 +1,26 @@
+//------------------------------------------------------------------------------
+// This code was auto-generated by ApiGenerator x.x.x.x.
+//
+// Changes to this file may cause incorrect behavior and will be lost if
+// the code is regenerated.
+//------------------------------------------------------------------------------
+namespace Structure1.ApiClient.Generated.Addresses.MyContracts;
+
+///
+/// Parameters for operation request.
+/// Description: Get addresses by postal code.
+/// Operation: GetAddressesByPostalCodes.
+///
+[GeneratedCode("ApiGenerator", "x.x.x.x")]
+public class GetAddressesByPostalCodesParameters
+{
+ ///
+ /// The postalCode to limit addresses on.
+ ///
+ [Required]
+ public string PostalCode { get; set; }
+
+ ///
+ public override string ToString()
+ => $"{nameof(PostalCode)}: {PostalCode}";
+}
\ No newline at end of file
diff --git a/test/Atc.Rest.ApiGenerator.CLI.Tests/Scenarios/Structure1/VerifyClient/WOPD/src/Structure1.ApiClient.Generated/Addresses/MyEndpoints/GetAddressesByPostalCodesEndpoint.verified.cs b/test/Atc.Rest.ApiGenerator.CLI.Tests/Scenarios/Structure1/VerifyClient/WOPD/src/Structure1.ApiClient.Generated/Addresses/MyEndpoints/GetAddressesByPostalCodesEndpoint.verified.cs
new file mode 100644
index 000000000..a29fbb34e
--- /dev/null
+++ b/test/Atc.Rest.ApiGenerator.CLI.Tests/Scenarios/Structure1/VerifyClient/WOPD/src/Structure1.ApiClient.Generated/Addresses/MyEndpoints/GetAddressesByPostalCodesEndpoint.verified.cs
@@ -0,0 +1,47 @@
+//------------------------------------------------------------------------------
+// This code was auto-generated by ApiGenerator x.x.x.x.
+//
+// Changes to this file may cause incorrect behavior and will be lost if
+// the code is regenerated.
+//------------------------------------------------------------------------------
+namespace Structure1.ApiClient.Generated.Addresses.MyEndpoints;
+
+///
+/// Client Endpoint.
+/// Description: Get addresses by postal code.
+/// Operation: GetAddressesByPostalCodes.
+///
+[GeneratedCode("ApiGenerator", "x.x.x.x")]
+public class GetAddressesByPostalCodesEndpoint : IGetAddressesByPostalCodesEndpoint
+{
+ private readonly IHttpClientFactory factory;
+ private readonly IHttpMessageFactory httpMessageFactory;
+
+ public GetAddressesByPostalCodesEndpoint(
+ IHttpClientFactory factory,
+ IHttpMessageFactory httpMessageFactory)
+ {
+ this.factory = factory;
+ this.httpMessageFactory = httpMessageFactory;
+ }
+
+ public async Task ExecuteAsync(
+ GetAddressesByPostalCodesParameters parameters,
+ string httpClientName = "Structure1-ApiClient",
+ CancellationToken cancellationToken = default)
+ {
+ var client = factory.CreateClient(httpClientName);
+
+ var requestBuilder = httpMessageFactory.FromTemplate("/api/v1/addresses/{postalCode}");
+ requestBuilder.WithPathParameter("postalCode", parameters.PostalCode);
+
+ using var requestMessage = requestBuilder.Build(HttpMethod.Get);
+ using var response = await client.SendAsync(requestMessage, cancellationToken);
+
+ var responseBuilder = httpMessageFactory.FromResponse(response);
+ responseBuilder.AddSuccessResponse>(HttpStatusCode.OK);
+ responseBuilder.AddErrorResponse(HttpStatusCode.BadRequest);
+ responseBuilder.AddErrorResponse(HttpStatusCode.NotFound);
+ return await responseBuilder.BuildResponseAsync(x => new GetAddressesByPostalCodesEndpointResult(x), cancellationToken);
+ }
+}
\ No newline at end of file
diff --git a/test/Atc.Rest.ApiGenerator.CLI.Tests/Scenarios/Structure1/VerifyClient/WOPD/src/Structure1.ApiClient.Generated/Addresses/MyEndpoints/GetAddressesByPostalCodesEndpointResult.verified.cs b/test/Atc.Rest.ApiGenerator.CLI.Tests/Scenarios/Structure1/VerifyClient/WOPD/src/Structure1.ApiClient.Generated/Addresses/MyEndpoints/GetAddressesByPostalCodesEndpointResult.verified.cs
new file mode 100644
index 000000000..bcc846862
--- /dev/null
+++ b/test/Atc.Rest.ApiGenerator.CLI.Tests/Scenarios/Structure1/VerifyClient/WOPD/src/Structure1.ApiClient.Generated/Addresses/MyEndpoints/GetAddressesByPostalCodesEndpointResult.verified.cs
@@ -0,0 +1,45 @@
+//------------------------------------------------------------------------------
+// This code was auto-generated by ApiGenerator x.x.x.x.
+//
+// Changes to this file may cause incorrect behavior and will be lost if
+// the code is regenerated.
+//------------------------------------------------------------------------------
+namespace Structure1.ApiClient.Generated.Addresses.MyEndpoints;
+
+///
+/// Client Endpoint result.
+/// Description: Get addresses by postal code.
+/// Operation: GetAddressesByPostalCodes.
+///
+[GeneratedCode("ApiGenerator", "x.x.x.x")]
+public class GetAddressesByPostalCodesEndpointResult : EndpointResponse, IGetAddressesByPostalCodesEndpointResult
+{
+ public GetAddressesByPostalCodesEndpointResult(EndpointResponse response)
+ : base(response)
+ {
+ }
+
+ public bool IsOk
+ => StatusCode == HttpStatusCode.OK;
+
+ public bool IsBadRequest
+ => StatusCode == HttpStatusCode.BadRequest;
+
+ public bool IsNotFound
+ => StatusCode == HttpStatusCode.NotFound;
+
+ public IEnumerable OkContent
+ => IsOk && ContentObject is IEnumerable result
+ ? result
+ : throw new InvalidOperationException("Content is not the expected type - please use the IsOk property first.");
+
+ public string? BadRequestContent
+ => IsBadRequest && ContentObject is string result
+ ? result
+ : throw new InvalidOperationException("Content is not the expected type - please use the IsBadRequest property first.");
+
+ public string? NotFoundContent
+ => IsNotFound && ContentObject is string result
+ ? result
+ : throw new InvalidOperationException("Content is not the expected type - please use the IsNotFound property first.");
+}
\ No newline at end of file
diff --git a/test/Atc.Rest.ApiGenerator.CLI.Tests/Scenarios/Structure1/VerifyClient/WOPD/src/Structure1.ApiClient.Generated/Addresses/MyEndpoints/Interfaces/IGetAddressesByPostalCodesEndpoint.verified.cs b/test/Atc.Rest.ApiGenerator.CLI.Tests/Scenarios/Structure1/VerifyClient/WOPD/src/Structure1.ApiClient.Generated/Addresses/MyEndpoints/Interfaces/IGetAddressesByPostalCodesEndpoint.verified.cs
new file mode 100644
index 000000000..caec7e29d
--- /dev/null
+++ b/test/Atc.Rest.ApiGenerator.CLI.Tests/Scenarios/Structure1/VerifyClient/WOPD/src/Structure1.ApiClient.Generated/Addresses/MyEndpoints/Interfaces/IGetAddressesByPostalCodesEndpoint.verified.cs
@@ -0,0 +1,27 @@
+//------------------------------------------------------------------------------
+// This code was auto-generated by ApiGenerator x.x.x.x.
+//
+// Changes to this file may cause incorrect behavior and will be lost if
+// the code is regenerated.
+//------------------------------------------------------------------------------
+namespace Structure1.ApiClient.Generated.Addresses.MyEndpoints.Interfaces;
+
+///
+/// Interface for Client Endpoint.
+/// Description: Get addresses by postal code.
+/// Operation: GetAddressesByPostalCodes.
+///
+[GeneratedCode("ApiGenerator", "x.x.x.x")]
+public interface IGetAddressesByPostalCodesEndpoint
+{
+ ///
+ /// Execute method.
+ ///
+ /// The parameters.
+ /// The http client name.
+ /// The cancellation token.
+ Task ExecuteAsync(
+ GetAddressesByPostalCodesParameters parameters,
+ string httpClientName = "Structure1-ApiClient",
+ CancellationToken cancellationToken = default);
+}
\ No newline at end of file
diff --git a/test/Atc.Rest.ApiGenerator.CLI.Tests/Scenarios/Structure1/VerifyClient/WOPD/src/Structure1.ApiClient.Generated/Addresses/MyEndpoints/Interfaces/IGetAddressesByPostalCodesEndpointResult.verified.cs b/test/Atc.Rest.ApiGenerator.CLI.Tests/Scenarios/Structure1/VerifyClient/WOPD/src/Structure1.ApiClient.Generated/Addresses/MyEndpoints/Interfaces/IGetAddressesByPostalCodesEndpointResult.verified.cs
new file mode 100644
index 000000000..f0f654b9b
--- /dev/null
+++ b/test/Atc.Rest.ApiGenerator.CLI.Tests/Scenarios/Structure1/VerifyClient/WOPD/src/Structure1.ApiClient.Generated/Addresses/MyEndpoints/Interfaces/IGetAddressesByPostalCodesEndpointResult.verified.cs
@@ -0,0 +1,29 @@
+//------------------------------------------------------------------------------
+// This code was auto-generated by ApiGenerator x.x.x.x.
+//
+// Changes to this file may cause incorrect behavior and will be lost if
+// the code is regenerated.
+//------------------------------------------------------------------------------
+namespace Structure1.ApiClient.Generated.Addresses.MyEndpoints.Interfaces;
+
+///
+/// Interface for Client Endpoint Result.
+/// Description: Get addresses by postal code.
+/// Operation: GetAddressesByPostalCodes.
+///
+[GeneratedCode("ApiGenerator", "x.x.x.x")]
+public interface IGetAddressesByPostalCodesEndpointResult : IEndpointResponse
+{
+
+ bool IsOk { get; }
+
+ bool IsBadRequest { get; }
+
+ bool IsNotFound { get; }
+
+ IEnumerable OkContent { get; }
+
+ string? BadRequestContent { get; }
+
+ string? NotFoundContent { get; }
+}
\ No newline at end of file
diff --git a/test/Atc.Rest.ApiGenerator.CLI.Tests/Scenarios/Structure1/VerifyClient/WOPD/src/Structure1.ApiClient.Generated/EventArgs/MyContracts/EventArgs.verified.cs b/test/Atc.Rest.ApiGenerator.CLI.Tests/Scenarios/Structure1/VerifyClient/WOPD/src/Structure1.ApiClient.Generated/EventArgs/MyContracts/EventArgs.verified.cs
new file mode 100644
index 000000000..ca95a836d
--- /dev/null
+++ b/test/Atc.Rest.ApiGenerator.CLI.Tests/Scenarios/Structure1/VerifyClient/WOPD/src/Structure1.ApiClient.Generated/EventArgs/MyContracts/EventArgs.verified.cs
@@ -0,0 +1,22 @@
+//------------------------------------------------------------------------------
+// This code was auto-generated by ApiGenerator x.x.x.x.
+//
+// Changes to this file may cause incorrect behavior and will be lost if
+// the code is regenerated.
+//------------------------------------------------------------------------------
+namespace Structure1.ApiClient.Generated.EventArgs.MyContracts;
+
+///
+/// EventArgs.
+///
+[GeneratedCode("ApiGenerator", "x.x.x.x")]
+public class EventArgs
+{
+ public Guid Id { get; set; }
+
+ public string EventName { get; set; }
+
+ ///
+ public override string ToString()
+ => $"{nameof(Id)}: {Id}, {nameof(EventName)}: {EventName}";
+}
\ No newline at end of file
diff --git a/test/Atc.Rest.ApiGenerator.CLI.Tests/Scenarios/Structure1/VerifyClient/WOPD/src/Structure1.ApiClient.Generated/EventArgs/MyContracts/RequestParameters/GetEventArgByIdParameters.verified.cs b/test/Atc.Rest.ApiGenerator.CLI.Tests/Scenarios/Structure1/VerifyClient/WOPD/src/Structure1.ApiClient.Generated/EventArgs/MyContracts/RequestParameters/GetEventArgByIdParameters.verified.cs
new file mode 100644
index 000000000..4509c563c
--- /dev/null
+++ b/test/Atc.Rest.ApiGenerator.CLI.Tests/Scenarios/Structure1/VerifyClient/WOPD/src/Structure1.ApiClient.Generated/EventArgs/MyContracts/RequestParameters/GetEventArgByIdParameters.verified.cs
@@ -0,0 +1,26 @@
+//------------------------------------------------------------------------------
+// This code was auto-generated by ApiGenerator x.x.x.x.
+//
+// Changes to this file may cause incorrect behavior and will be lost if
+// the code is regenerated.
+//------------------------------------------------------------------------------
+namespace Structure1.ApiClient.Generated.EventArgs.MyContracts;
+
+///
+/// Parameters for operation request.
+/// Description: Get EventArgs By Id.
+/// Operation: GetEventArgById.
+///
+[GeneratedCode("ApiGenerator", "x.x.x.x")]
+public class GetEventArgByIdParameters
+{
+ ///
+ /// The id of the eventArgs.
+ ///
+ [Required]
+ public string Id { get; set; }
+
+ ///
+ public override string ToString()
+ => $"{nameof(Id)}: {Id}";
+}
\ No newline at end of file
diff --git a/test/Atc.Rest.ApiGenerator.CLI.Tests/Scenarios/Structure1/VerifyClient/WOPD/src/Structure1.ApiClient.Generated/EventArgs/MyEndpoints/GetEventArgByIdEndpoint.verified.cs b/test/Atc.Rest.ApiGenerator.CLI.Tests/Scenarios/Structure1/VerifyClient/WOPD/src/Structure1.ApiClient.Generated/EventArgs/MyEndpoints/GetEventArgByIdEndpoint.verified.cs
new file mode 100644
index 000000000..d19708e64
--- /dev/null
+++ b/test/Atc.Rest.ApiGenerator.CLI.Tests/Scenarios/Structure1/VerifyClient/WOPD/src/Structure1.ApiClient.Generated/EventArgs/MyEndpoints/GetEventArgByIdEndpoint.verified.cs
@@ -0,0 +1,47 @@
+//------------------------------------------------------------------------------
+// This code was auto-generated by ApiGenerator x.x.x.x.
+//
+// Changes to this file may cause incorrect behavior and will be lost if
+// the code is regenerated.
+//------------------------------------------------------------------------------
+namespace Structure1.ApiClient.Generated.EventArgs.MyEndpoints;
+
+///
+/// Client Endpoint.
+/// Description: Get EventArgs By Id.
+/// Operation: GetEventArgById.
+///
+[GeneratedCode("ApiGenerator", "x.x.x.x")]
+public class GetEventArgByIdEndpoint : IGetEventArgByIdEndpoint
+{
+ private readonly IHttpClientFactory factory;
+ private readonly IHttpMessageFactory httpMessageFactory;
+
+ public GetEventArgByIdEndpoint(
+ IHttpClientFactory factory,
+ IHttpMessageFactory httpMessageFactory)
+ {
+ this.factory = factory;
+ this.httpMessageFactory = httpMessageFactory;
+ }
+
+ public async Task ExecuteAsync(
+ GetEventArgByIdParameters parameters,
+ string httpClientName = "Structure1-ApiClient",
+ CancellationToken cancellationToken = default)
+ {
+ var client = factory.CreateClient(httpClientName);
+
+ var requestBuilder = httpMessageFactory.FromTemplate("/api/v1/eventArgs/{id}");
+ requestBuilder.WithPathParameter("id", parameters.Id);
+
+ using var requestMessage = requestBuilder.Build(HttpMethod.Get);
+ using var response = await client.SendAsync(requestMessage, cancellationToken);
+
+ var responseBuilder = httpMessageFactory.FromResponse(response);
+ responseBuilder.AddSuccessResponse(HttpStatusCode.OK);
+ responseBuilder.AddErrorResponse(HttpStatusCode.BadRequest);
+ responseBuilder.AddErrorResponse(HttpStatusCode.NotFound);
+ return await responseBuilder.BuildResponseAsync(x => new GetEventArgByIdEndpointResult(x), cancellationToken);
+ }
+}
\ No newline at end of file
diff --git a/test/Atc.Rest.ApiGenerator.CLI.Tests/Scenarios/Structure1/VerifyClient/WOPD/src/Structure1.ApiClient.Generated/EventArgs/MyEndpoints/GetEventArgByIdEndpointResult.verified.cs b/test/Atc.Rest.ApiGenerator.CLI.Tests/Scenarios/Structure1/VerifyClient/WOPD/src/Structure1.ApiClient.Generated/EventArgs/MyEndpoints/GetEventArgByIdEndpointResult.verified.cs
new file mode 100644
index 000000000..14decc6ca
--- /dev/null
+++ b/test/Atc.Rest.ApiGenerator.CLI.Tests/Scenarios/Structure1/VerifyClient/WOPD/src/Structure1.ApiClient.Generated/EventArgs/MyEndpoints/GetEventArgByIdEndpointResult.verified.cs
@@ -0,0 +1,45 @@
+//------------------------------------------------------------------------------
+// This code was auto-generated by ApiGenerator x.x.x.x.
+//
+// Changes to this file may cause incorrect behavior and will be lost if
+// the code is regenerated.
+//------------------------------------------------------------------------------
+namespace Structure1.ApiClient.Generated.EventArgs.MyEndpoints;
+
+///
+/// Client Endpoint result.
+/// Description: Get EventArgs By Id.
+/// Operation: GetEventArgById.
+///
+[GeneratedCode("ApiGenerator", "x.x.x.x")]
+public class GetEventArgByIdEndpointResult : EndpointResponse, IGetEventArgByIdEndpointResult
+{
+ public GetEventArgByIdEndpointResult(EndpointResponse response)
+ : base(response)
+ {
+ }
+
+ public bool IsOk
+ => StatusCode == HttpStatusCode.OK;
+
+ public bool IsBadRequest
+ => StatusCode == HttpStatusCode.BadRequest;
+
+ public bool IsNotFound
+ => StatusCode == HttpStatusCode.NotFound;
+
+ public Structure1.ApiClient.Generated.EventArgs.MyContracts.EventArgs OkContent
+ => IsOk && ContentObject is Structure1.ApiClient.Generated.EventArgs.MyContracts.EventArgs result
+ ? result
+ : throw new InvalidOperationException("Content is not the expected type - please use the IsOk property first.");
+
+ public string? BadRequestContent
+ => IsBadRequest && ContentObject is string result
+ ? result
+ : throw new InvalidOperationException("Content is not the expected type - please use the IsBadRequest property first.");
+
+ public string? NotFoundContent
+ => IsNotFound && ContentObject is string result
+ ? result
+ : throw new InvalidOperationException("Content is not the expected type - please use the IsNotFound property first.");
+}
\ No newline at end of file
diff --git a/test/Atc.Rest.ApiGenerator.CLI.Tests/Scenarios/Structure1/VerifyClient/WOPD/src/Structure1.ApiClient.Generated/EventArgs/MyEndpoints/GetEventArgsEndpoint.verified.cs b/test/Atc.Rest.ApiGenerator.CLI.Tests/Scenarios/Structure1/VerifyClient/WOPD/src/Structure1.ApiClient.Generated/EventArgs/MyEndpoints/GetEventArgsEndpoint.verified.cs
new file mode 100644
index 000000000..afdd09edf
--- /dev/null
+++ b/test/Atc.Rest.ApiGenerator.CLI.Tests/Scenarios/Structure1/VerifyClient/WOPD/src/Structure1.ApiClient.Generated/EventArgs/MyEndpoints/GetEventArgsEndpoint.verified.cs
@@ -0,0 +1,43 @@
+//------------------------------------------------------------------------------
+// This code was auto-generated by ApiGenerator x.x.x.x.
+//
+// Changes to this file may cause incorrect behavior and will be lost if
+// the code is regenerated.
+//------------------------------------------------------------------------------
+namespace Structure1.ApiClient.Generated.EventArgs.MyEndpoints;
+
+///
+/// Client Endpoint.
+/// Description: Get EventArgs List.
+/// Operation: GetEventArgs.
+///
+[GeneratedCode("ApiGenerator", "x.x.x.x")]
+public class GetEventArgsEndpoint : IGetEventArgsEndpoint
+{
+ private readonly IHttpClientFactory factory;
+ private readonly IHttpMessageFactory httpMessageFactory;
+
+ public GetEventArgsEndpoint(
+ IHttpClientFactory factory,
+ IHttpMessageFactory httpMessageFactory)
+ {
+ this.factory = factory;
+ this.httpMessageFactory = httpMessageFactory;
+ }
+
+ public async Task ExecuteAsync(
+ string httpClientName = "Structure1-ApiClient",
+ CancellationToken cancellationToken = default)
+ {
+ var client = factory.CreateClient(httpClientName);
+
+ var requestBuilder = httpMessageFactory.FromTemplate("/api/v1/eventArgs");
+
+ using var requestMessage = requestBuilder.Build(HttpMethod.Get);
+ using var response = await client.SendAsync(requestMessage, cancellationToken);
+
+ var responseBuilder = httpMessageFactory.FromResponse(response);
+ responseBuilder.AddSuccessResponse>(HttpStatusCode.OK);
+ return await responseBuilder.BuildResponseAsync(x => new GetEventArgsEndpointResult(x), cancellationToken);
+ }
+}
\ No newline at end of file
diff --git a/test/Atc.Rest.ApiGenerator.CLI.Tests/Scenarios/Structure1/VerifyClient/WOPD/src/Structure1.ApiClient.Generated/EventArgs/MyEndpoints/GetEventArgsEndpointResult.verified.cs b/test/Atc.Rest.ApiGenerator.CLI.Tests/Scenarios/Structure1/VerifyClient/WOPD/src/Structure1.ApiClient.Generated/EventArgs/MyEndpoints/GetEventArgsEndpointResult.verified.cs
new file mode 100644
index 000000000..5b80591b1
--- /dev/null
+++ b/test/Atc.Rest.ApiGenerator.CLI.Tests/Scenarios/Structure1/VerifyClient/WOPD/src/Structure1.ApiClient.Generated/EventArgs/MyEndpoints/GetEventArgsEndpointResult.verified.cs
@@ -0,0 +1,29 @@
+//------------------------------------------------------------------------------
+// This code was auto-generated by ApiGenerator x.x.x.x.
+//
+// Changes to this file may cause incorrect behavior and will be lost if
+// the code is regenerated.
+//------------------------------------------------------------------------------
+namespace Structure1.ApiClient.Generated.EventArgs.MyEndpoints;
+
+///
+/// Client Endpoint result.
+/// Description: Get EventArgs List.
+/// Operation: GetEventArgs.
+///
+[GeneratedCode("ApiGenerator", "x.x.x.x")]
+public class GetEventArgsEndpointResult : EndpointResponse, IGetEventArgsEndpointResult
+{
+ public GetEventArgsEndpointResult(EndpointResponse response)
+ : base(response)
+ {
+ }
+
+ public bool IsOk
+ => StatusCode == HttpStatusCode.OK;
+
+ public IEnumerable OkContent
+ => IsOk && ContentObject is IEnumerable result
+ ? result
+ : throw new InvalidOperationException("Content is not the expected type - please use the IsOk property first.");
+}
\ No newline at end of file
diff --git a/test/Atc.Rest.ApiGenerator.CLI.Tests/Scenarios/Structure1/VerifyClient/WOPD/src/Structure1.ApiClient.Generated/EventArgs/MyEndpoints/Interfaces/IGetEventArgByIdEndpoint.verified.cs b/test/Atc.Rest.ApiGenerator.CLI.Tests/Scenarios/Structure1/VerifyClient/WOPD/src/Structure1.ApiClient.Generated/EventArgs/MyEndpoints/Interfaces/IGetEventArgByIdEndpoint.verified.cs
new file mode 100644
index 000000000..b92c64595
--- /dev/null
+++ b/test/Atc.Rest.ApiGenerator.CLI.Tests/Scenarios/Structure1/VerifyClient/WOPD/src/Structure1.ApiClient.Generated/EventArgs/MyEndpoints/Interfaces/IGetEventArgByIdEndpoint.verified.cs
@@ -0,0 +1,27 @@
+//------------------------------------------------------------------------------
+// This code was auto-generated by ApiGenerator x.x.x.x.
+//
+// Changes to this file may cause incorrect behavior and will be lost if
+// the code is regenerated.
+//------------------------------------------------------------------------------
+namespace Structure1.ApiClient.Generated.EventArgs.MyEndpoints.Interfaces;
+
+///
+/// Interface for Client Endpoint.
+/// Description: Get EventArgs By Id.
+/// Operation: GetEventArgById.
+///
+[GeneratedCode("ApiGenerator", "x.x.x.x")]
+public interface IGetEventArgByIdEndpoint
+{
+ ///
+ /// Execute method.
+ ///
+ /// The parameters.
+ /// The http client name.
+ /// The cancellation token.
+ Task ExecuteAsync(
+ GetEventArgByIdParameters parameters,
+ string httpClientName = "Structure1-ApiClient",
+ CancellationToken cancellationToken = default);
+}
\ No newline at end of file
diff --git a/test/Atc.Rest.ApiGenerator.CLI.Tests/Scenarios/Structure1/VerifyClient/WOPD/src/Structure1.ApiClient.Generated/EventArgs/MyEndpoints/Interfaces/IGetEventArgByIdEndpointResult.verified.cs b/test/Atc.Rest.ApiGenerator.CLI.Tests/Scenarios/Structure1/VerifyClient/WOPD/src/Structure1.ApiClient.Generated/EventArgs/MyEndpoints/Interfaces/IGetEventArgByIdEndpointResult.verified.cs
new file mode 100644
index 000000000..7efd544e1
--- /dev/null
+++ b/test/Atc.Rest.ApiGenerator.CLI.Tests/Scenarios/Structure1/VerifyClient/WOPD/src/Structure1.ApiClient.Generated/EventArgs/MyEndpoints/Interfaces/IGetEventArgByIdEndpointResult.verified.cs
@@ -0,0 +1,29 @@
+//------------------------------------------------------------------------------
+// This code was auto-generated by ApiGenerator x.x.x.x.
+//
+// Changes to this file may cause incorrect behavior and will be lost if
+// the code is regenerated.
+//------------------------------------------------------------------------------
+namespace Structure1.ApiClient.Generated.EventArgs.MyEndpoints.Interfaces;
+
+///
+/// Interface for Client Endpoint Result.
+/// Description: Get EventArgs By Id.
+/// Operation: GetEventArgById.
+///
+[GeneratedCode("ApiGenerator", "x.x.x.x")]
+public interface IGetEventArgByIdEndpointResult : IEndpointResponse
+{
+
+ bool IsOk { get; }
+
+ bool IsBadRequest { get; }
+
+ bool IsNotFound { get; }
+
+ Structure1.ApiClient.Generated.EventArgs.MyContracts.EventArgs OkContent { get; }
+
+ string? BadRequestContent { get; }
+
+ string? NotFoundContent { get; }
+}
\ No newline at end of file
diff --git a/test/Atc.Rest.ApiGenerator.CLI.Tests/Scenarios/Structure1/VerifyClient/WOPD/src/Structure1.ApiClient.Generated/EventArgs/MyEndpoints/Interfaces/IGetEventArgsEndpoint.verified.cs b/test/Atc.Rest.ApiGenerator.CLI.Tests/Scenarios/Structure1/VerifyClient/WOPD/src/Structure1.ApiClient.Generated/EventArgs/MyEndpoints/Interfaces/IGetEventArgsEndpoint.verified.cs
new file mode 100644
index 000000000..e09fea10a
--- /dev/null
+++ b/test/Atc.Rest.ApiGenerator.CLI.Tests/Scenarios/Structure1/VerifyClient/WOPD/src/Structure1.ApiClient.Generated/EventArgs/MyEndpoints/Interfaces/IGetEventArgsEndpoint.verified.cs
@@ -0,0 +1,25 @@
+//------------------------------------------------------------------------------
+// This code was auto-generated by ApiGenerator x.x.x.x.
+//
+// Changes to this file may cause incorrect behavior and will be lost if
+// the code is regenerated.
+//------------------------------------------------------------------------------
+namespace Structure1.ApiClient.Generated.EventArgs.MyEndpoints.Interfaces;
+
+///
+/// Interface for Client Endpoint.
+/// Description: Get EventArgs List.
+/// Operation: GetEventArgs.
+///
+[GeneratedCode("ApiGenerator", "x.x.x.x")]
+public interface IGetEventArgsEndpoint
+{
+ ///
+ /// Execute method.
+ ///
+ /// The http client name.
+ /// The cancellation token.
+ Task ExecuteAsync(
+ string httpClientName = "Structure1-ApiClient",
+ CancellationToken cancellationToken = default);
+}
\ No newline at end of file
diff --git a/test/Atc.Rest.ApiGenerator.CLI.Tests/Scenarios/Structure1/VerifyClient/WOPD/src/Structure1.ApiClient.Generated/EventArgs/MyEndpoints/Interfaces/IGetEventArgsEndpointResult.verified.cs b/test/Atc.Rest.ApiGenerator.CLI.Tests/Scenarios/Structure1/VerifyClient/WOPD/src/Structure1.ApiClient.Generated/EventArgs/MyEndpoints/Interfaces/IGetEventArgsEndpointResult.verified.cs
new file mode 100644
index 000000000..4b09921d4
--- /dev/null
+++ b/test/Atc.Rest.ApiGenerator.CLI.Tests/Scenarios/Structure1/VerifyClient/WOPD/src/Structure1.ApiClient.Generated/EventArgs/MyEndpoints/Interfaces/IGetEventArgsEndpointResult.verified.cs
@@ -0,0 +1,21 @@
+//------------------------------------------------------------------------------
+// This code was auto-generated by ApiGenerator x.x.x.x.
+//
+// Changes to this file may cause incorrect behavior and will be lost if
+// the code is regenerated.
+//------------------------------------------------------------------------------
+namespace Structure1.ApiClient.Generated.EventArgs.MyEndpoints.Interfaces;
+
+///
+/// Interface for Client Endpoint Result.
+/// Description: Get EventArgs List.
+/// Operation: GetEventArgs.
+///
+[GeneratedCode("ApiGenerator", "x.x.x.x")]
+public interface IGetEventArgsEndpointResult : IEndpointResponse
+{
+
+ bool IsOk { get; }
+
+ IEnumerable OkContent { get; }
+}
\ No newline at end of file
diff --git a/test/Atc.Rest.ApiGenerator.CLI.Tests/Scenarios/Structure1/VerifyClient/WOPD/src/Structure1.ApiClient.Generated/Files/MyContracts/FileAsFormDataRequest.verified.cs b/test/Atc.Rest.ApiGenerator.CLI.Tests/Scenarios/Structure1/VerifyClient/WOPD/src/Structure1.ApiClient.Generated/Files/MyContracts/FileAsFormDataRequest.verified.cs
new file mode 100644
index 000000000..130183d18
--- /dev/null
+++ b/test/Atc.Rest.ApiGenerator.CLI.Tests/Scenarios/Structure1/VerifyClient/WOPD/src/Structure1.ApiClient.Generated/Files/MyContracts/FileAsFormDataRequest.verified.cs
@@ -0,0 +1,26 @@
+//------------------------------------------------------------------------------
+// This code was auto-generated by ApiGenerator x.x.x.x.
+//
+// Changes to this file may cause incorrect behavior and will be lost if
+// the code is regenerated.
+//------------------------------------------------------------------------------
+namespace Structure1.ApiClient.Generated.Files.MyContracts;
+
+///
+/// FileAsFormDataRequest.
+///
+[GeneratedCode("ApiGenerator", "x.x.x.x")]
+public class FileAsFormDataRequest
+{
+ [Required]
+ public string ItemName { get; set; }
+
+ public IFormFile? File { get; set; }
+
+ [Required]
+ public List Items { get; set; }
+
+ ///
+ public override string ToString()
+ => $"{nameof(ItemName)}: {ItemName}, {nameof(File)}: {File}, {nameof(Items)}.Count: {Items?.Count ?? 0}";
+}
\ No newline at end of file
diff --git a/test/Atc.Rest.ApiGenerator.CLI.Tests/Scenarios/Structure1/VerifyClient/WOPD/src/Structure1.ApiClient.Generated/Files/MyContracts/FilesAsFormDataRequest.verified.cs b/test/Atc.Rest.ApiGenerator.CLI.Tests/Scenarios/Structure1/VerifyClient/WOPD/src/Structure1.ApiClient.Generated/Files/MyContracts/FilesAsFormDataRequest.verified.cs
new file mode 100644
index 000000000..72a31c919
--- /dev/null
+++ b/test/Atc.Rest.ApiGenerator.CLI.Tests/Scenarios/Structure1/VerifyClient/WOPD/src/Structure1.ApiClient.Generated/Files/MyContracts/FilesAsFormDataRequest.verified.cs
@@ -0,0 +1,23 @@
+//------------------------------------------------------------------------------
+// This code was auto-generated by ApiGenerator x.x.x.x.
+//
+// Changes to this file may cause incorrect behavior and will be lost if
+// the code is regenerated.
+//------------------------------------------------------------------------------
+namespace Structure1.ApiClient.Generated.Files.MyContracts;
+
+///
+/// FilesAsFormDataRequest.
+///
+[GeneratedCode("ApiGenerator", "x.x.x.x")]
+public class FilesAsFormDataRequest
+{
+ ///
+ /// A list of File(s).
+ ///
+ public List Files { get; set; } = new List();
+
+ ///
+ public override string ToString()
+ => $"{nameof(Files)}.Count: {Files?.Count ?? 0}";
+}
\ No newline at end of file
diff --git a/test/Atc.Rest.ApiGenerator.CLI.Tests/Scenarios/Structure1/VerifyClient/WOPD/src/Structure1.ApiClient.Generated/Files/MyContracts/RequestParameters/GetFileByIdParameters.verified.cs b/test/Atc.Rest.ApiGenerator.CLI.Tests/Scenarios/Structure1/VerifyClient/WOPD/src/Structure1.ApiClient.Generated/Files/MyContracts/RequestParameters/GetFileByIdParameters.verified.cs
new file mode 100644
index 000000000..b7569e00f
--- /dev/null
+++ b/test/Atc.Rest.ApiGenerator.CLI.Tests/Scenarios/Structure1/VerifyClient/WOPD/src/Structure1.ApiClient.Generated/Files/MyContracts/RequestParameters/GetFileByIdParameters.verified.cs
@@ -0,0 +1,26 @@
+//------------------------------------------------------------------------------
+// This code was auto-generated by ApiGenerator x.x.x.x.
+//
+// Changes to this file may cause incorrect behavior and will be lost if
+// the code is regenerated.
+//------------------------------------------------------------------------------
+namespace Structure1.ApiClient.Generated.Files.MyContracts;
+
+///
+/// Parameters for operation request.
+/// Description: Get File By Id.
+/// Operation: GetFileById.
+///
+[GeneratedCode("ApiGenerator", "x.x.x.x")]
+public class GetFileByIdParameters
+{
+ ///
+ /// The file id.
+ ///
+ [Required]
+ public string Id { get; set; }
+
+ ///
+ public override string ToString()
+ => $"{nameof(Id)}: {Id}";
+}
\ No newline at end of file
diff --git a/test/Atc.Rest.ApiGenerator.CLI.Tests/Scenarios/Structure1/VerifyClient/WOPD/src/Structure1.ApiClient.Generated/Files/MyContracts/RequestParameters/UploadMultiFilesAsFormDataParameters.verified.cs b/test/Atc.Rest.ApiGenerator.CLI.Tests/Scenarios/Structure1/VerifyClient/WOPD/src/Structure1.ApiClient.Generated/Files/MyContracts/RequestParameters/UploadMultiFilesAsFormDataParameters.verified.cs
new file mode 100644
index 000000000..71ac6707b
--- /dev/null
+++ b/test/Atc.Rest.ApiGenerator.CLI.Tests/Scenarios/Structure1/VerifyClient/WOPD/src/Structure1.ApiClient.Generated/Files/MyContracts/RequestParameters/UploadMultiFilesAsFormDataParameters.verified.cs
@@ -0,0 +1,23 @@
+//------------------------------------------------------------------------------
+// This code was auto-generated by ApiGenerator x.x.x.x.
+//
+// Changes to this file may cause incorrect behavior and will be lost if
+// the code is regenerated.
+//------------------------------------------------------------------------------
+namespace Structure1.ApiClient.Generated.Files.MyContracts;
+
+///
+/// Parameters for operation request.
+/// Description: Upload multi files as form data.
+/// Operation: UploadMultiFilesAsFormData.
+///
+[GeneratedCode("ApiGenerator", "x.x.x.x")]
+public class UploadMultiFilesAsFormDataParameters
+{
+ [Required]
+ public List Request { get; set; } = new List();
+
+ ///
+ public override string ToString()
+ => $"{nameof(Request)}.Count: {Request?.Count ?? 0}";
+}
\ No newline at end of file
diff --git a/test/Atc.Rest.ApiGenerator.CLI.Tests/Scenarios/Structure1/VerifyClient/WOPD/src/Structure1.ApiClient.Generated/Files/MyContracts/RequestParameters/UploadSingleFileAsFormDataParameters.verified.cs b/test/Atc.Rest.ApiGenerator.CLI.Tests/Scenarios/Structure1/VerifyClient/WOPD/src/Structure1.ApiClient.Generated/Files/MyContracts/RequestParameters/UploadSingleFileAsFormDataParameters.verified.cs
new file mode 100644
index 000000000..ba28c10f2
--- /dev/null
+++ b/test/Atc.Rest.ApiGenerator.CLI.Tests/Scenarios/Structure1/VerifyClient/WOPD/src/Structure1.ApiClient.Generated/Files/MyContracts/RequestParameters/UploadSingleFileAsFormDataParameters.verified.cs
@@ -0,0 +1,23 @@
+//------------------------------------------------------------------------------
+// This code was auto-generated by ApiGenerator x.x.x.x.
+//
+// Changes to this file may cause incorrect behavior and will be lost if
+// the code is regenerated.
+//------------------------------------------------------------------------------
+namespace Structure1.ApiClient.Generated.Files.MyContracts;
+
+///
+/// Parameters for operation request.
+/// Description: Upload a file as OctetStream.
+/// Operation: UploadSingleFileAsFormData.
+///
+[GeneratedCode("ApiGenerator", "x.x.x.x")]
+public class UploadSingleFileAsFormDataParameters
+{
+ [Required]
+ public IFormFile Request { get; set; }
+
+ ///
+ public override string ToString()
+ => $"{nameof(Request)}: ({Request})";
+}
\ No newline at end of file
diff --git a/test/Atc.Rest.ApiGenerator.CLI.Tests/Scenarios/Structure1/VerifyClient/WOPD/src/Structure1.ApiClient.Generated/Files/MyContracts/RequestParameters/UploadSingleObjectWithFileAsFormDataParameters.verified.cs b/test/Atc.Rest.ApiGenerator.CLI.Tests/Scenarios/Structure1/VerifyClient/WOPD/src/Structure1.ApiClient.Generated/Files/MyContracts/RequestParameters/UploadSingleObjectWithFileAsFormDataParameters.verified.cs
new file mode 100644
index 000000000..ab3f552f2
--- /dev/null
+++ b/test/Atc.Rest.ApiGenerator.CLI.Tests/Scenarios/Structure1/VerifyClient/WOPD/src/Structure1.ApiClient.Generated/Files/MyContracts/RequestParameters/UploadSingleObjectWithFileAsFormDataParameters.verified.cs
@@ -0,0 +1,26 @@
+//------------------------------------------------------------------------------
+// This code was auto-generated by ApiGenerator x.x.x.x.
+//
+// Changes to this file may cause incorrect behavior and will be lost if
+// the code is regenerated.
+//------------------------------------------------------------------------------
+namespace Structure1.ApiClient.Generated.Files.MyContracts;
+
+///
+/// Parameters for operation request.
+/// Description: Upload a file as FormData.
+/// Operation: UploadSingleObjectWithFileAsFormData.
+///
+[GeneratedCode("ApiGenerator", "x.x.x.x")]
+public class UploadSingleObjectWithFileAsFormDataParameters
+{
+ ///
+ /// FileAsFormDataRequest.
+ ///
+ [Required]
+ public FileAsFormDataRequest Request { get; set; }
+
+ ///
+ public override string ToString()
+ => $"{nameof(Request)}: ({Request})";
+}
\ No newline at end of file
diff --git a/test/Atc.Rest.ApiGenerator.CLI.Tests/Scenarios/Structure1/VerifyClient/WOPD/src/Structure1.ApiClient.Generated/Files/MyContracts/RequestParameters/UploadSingleObjectWithFilesAsFormDataParameters.verified.cs b/test/Atc.Rest.ApiGenerator.CLI.Tests/Scenarios/Structure1/VerifyClient/WOPD/src/Structure1.ApiClient.Generated/Files/MyContracts/RequestParameters/UploadSingleObjectWithFilesAsFormDataParameters.verified.cs
new file mode 100644
index 000000000..5e2d14dca
--- /dev/null
+++ b/test/Atc.Rest.ApiGenerator.CLI.Tests/Scenarios/Structure1/VerifyClient/WOPD/src/Structure1.ApiClient.Generated/Files/MyContracts/RequestParameters/UploadSingleObjectWithFilesAsFormDataParameters.verified.cs
@@ -0,0 +1,26 @@
+//------------------------------------------------------------------------------
+// This code was auto-generated by ApiGenerator x.x.x.x.
+//
+// Changes to this file may cause incorrect behavior and will be lost if
+// the code is regenerated.
+//------------------------------------------------------------------------------
+namespace Structure1.ApiClient.Generated.Files.MyContracts;
+
+///
+/// Parameters for operation request.
+/// Description: Upload files as FormData.
+/// Operation: UploadSingleObjectWithFilesAsFormData.
+///
+[GeneratedCode("ApiGenerator", "x.x.x.x")]
+public class UploadSingleObjectWithFilesAsFormDataParameters
+{
+ ///
+ /// FilesAsFormDataRequest.
+ ///
+ [Required]
+ public FilesAsFormDataRequest Request { get; set; }
+
+ ///
+ public override string ToString()
+ => $"{nameof(Request)}: ({Request})";
+}
\ No newline at end of file
diff --git a/test/Atc.Rest.ApiGenerator.CLI.Tests/Scenarios/Structure1/VerifyClient/WOPD/src/Structure1.ApiClient.Generated/Files/MyEndpoints/GetFileByIdEndpoint.verified.cs b/test/Atc.Rest.ApiGenerator.CLI.Tests/Scenarios/Structure1/VerifyClient/WOPD/src/Structure1.ApiClient.Generated/Files/MyEndpoints/GetFileByIdEndpoint.verified.cs
new file mode 100644
index 000000000..17242b471
--- /dev/null
+++ b/test/Atc.Rest.ApiGenerator.CLI.Tests/Scenarios/Structure1/VerifyClient/WOPD/src/Structure1.ApiClient.Generated/Files/MyEndpoints/GetFileByIdEndpoint.verified.cs
@@ -0,0 +1,47 @@
+//------------------------------------------------------------------------------
+// This code was auto-generated by ApiGenerator x.x.x.x.
+//
+// Changes to this file may cause incorrect behavior and will be lost if
+// the code is regenerated.
+//------------------------------------------------------------------------------
+namespace Structure1.ApiClient.Generated.Files.MyEndpoints;
+
+///
+/// Client Endpoint.
+/// Description: Get File By Id.
+/// Operation: GetFileById.
+///
+[GeneratedCode("ApiGenerator", "x.x.x.x")]
+public class GetFileByIdEndpoint : IGetFileByIdEndpoint
+{
+ private readonly IHttpClientFactory factory;
+ private readonly IHttpMessageFactory httpMessageFactory;
+
+ public GetFileByIdEndpoint(
+ IHttpClientFactory factory,
+ IHttpMessageFactory httpMessageFactory)
+ {
+ this.factory = factory;
+ this.httpMessageFactory = httpMessageFactory;
+ }
+
+ public async Task ExecuteAsync(
+ GetFileByIdParameters parameters,
+ string httpClientName = "Structure1-ApiClient",
+ CancellationToken cancellationToken = default)
+ {
+ var client = factory.CreateClient(httpClientName);
+
+ var requestBuilder = httpMessageFactory.FromTemplate("/api/v1/files/{id}");
+ requestBuilder.WithPathParameter("id", parameters.Id);
+
+ using var requestMessage = requestBuilder.Build(HttpMethod.Get);
+ using var response = await client.SendAsync(requestMessage, cancellationToken);
+
+ var responseBuilder = httpMessageFactory.FromResponse(response);
+ responseBuilder.AddSuccessResponse(HttpStatusCode.OK);
+ responseBuilder.AddErrorResponse(HttpStatusCode.BadRequest);
+ responseBuilder.AddErrorResponse(HttpStatusCode.NotFound);
+ return await responseBuilder.BuildResponseAsync(x => new GetFileByIdEndpointResult(x), cancellationToken);
+ }
+}
\ No newline at end of file
diff --git a/test/Atc.Rest.ApiGenerator.CLI.Tests/Scenarios/Structure1/VerifyClient/WOPD/src/Structure1.ApiClient.Generated/Files/MyEndpoints/GetFileByIdEndpointResult.verified.cs b/test/Atc.Rest.ApiGenerator.CLI.Tests/Scenarios/Structure1/VerifyClient/WOPD/src/Structure1.ApiClient.Generated/Files/MyEndpoints/GetFileByIdEndpointResult.verified.cs
new file mode 100644
index 000000000..b9a6c73b3
--- /dev/null
+++ b/test/Atc.Rest.ApiGenerator.CLI.Tests/Scenarios/Structure1/VerifyClient/WOPD/src/Structure1.ApiClient.Generated/Files/MyEndpoints/GetFileByIdEndpointResult.verified.cs
@@ -0,0 +1,45 @@
+//------------------------------------------------------------------------------
+// This code was auto-generated by ApiGenerator x.x.x.x.
+//
+// Changes to this file may cause incorrect behavior and will be lost if
+// the code is regenerated.
+//------------------------------------------------------------------------------
+namespace Structure1.ApiClient.Generated.Files.MyEndpoints;
+
+///
+/// Client Endpoint result.
+/// Description: Get File By Id.
+/// Operation: GetFileById.
+///
+[GeneratedCode("ApiGenerator", "x.x.x.x")]
+public class GetFileByIdEndpointResult : EndpointResponse, IGetFileByIdEndpointResult
+{
+ public GetFileByIdEndpointResult(EndpointResponse response)
+ : base(response)
+ {
+ }
+
+ public bool IsOk
+ => StatusCode == HttpStatusCode.OK;
+
+ public bool IsBadRequest
+ => StatusCode == HttpStatusCode.BadRequest;
+
+ public bool IsNotFound
+ => StatusCode == HttpStatusCode.NotFound;
+
+ public byte[] OkContent
+ => IsOk && ContentObject is byte[] result
+ ? result
+ : throw new InvalidOperationException("Content is not the expected type - please use the IsOk property first.");
+
+ public string? BadRequestContent
+ => IsBadRequest && ContentObject is string result
+ ? result
+ : throw new InvalidOperationException("Content is not the expected type - please use the IsBadRequest property first.");
+
+ public string? NotFoundContent
+ => IsNotFound && ContentObject is string result
+ ? result
+ : throw new InvalidOperationException("Content is not the expected type - please use the IsNotFound property first.");
+}
\ No newline at end of file
diff --git a/test/Atc.Rest.ApiGenerator.CLI.Tests/Scenarios/Structure1/VerifyClient/WOPD/src/Structure1.ApiClient.Generated/Files/MyEndpoints/Interfaces/IGetFileByIdEndpoint.verified.cs b/test/Atc.Rest.ApiGenerator.CLI.Tests/Scenarios/Structure1/VerifyClient/WOPD/src/Structure1.ApiClient.Generated/Files/MyEndpoints/Interfaces/IGetFileByIdEndpoint.verified.cs
new file mode 100644
index 000000000..3ecf63afd
--- /dev/null
+++ b/test/Atc.Rest.ApiGenerator.CLI.Tests/Scenarios/Structure1/VerifyClient/WOPD/src/Structure1.ApiClient.Generated/Files/MyEndpoints/Interfaces/IGetFileByIdEndpoint.verified.cs
@@ -0,0 +1,27 @@
+//------------------------------------------------------------------------------
+// This code was auto-generated by ApiGenerator x.x.x.x.
+//
+// Changes to this file may cause incorrect behavior and will be lost if
+// the code is regenerated.
+//------------------------------------------------------------------------------
+namespace Structure1.ApiClient.Generated.Files.MyEndpoints.Interfaces;
+
+///
+/// Interface for Client Endpoint.
+/// Description: Get File By Id.
+/// Operation: GetFileById.
+///
+[GeneratedCode("ApiGenerator", "x.x.x.x")]
+public interface IGetFileByIdEndpoint
+{
+ ///
+ /// Execute method.
+ ///
+ /// The parameters.
+ /// The http client name.
+ /// The cancellation token.
+ Task ExecuteAsync(
+ GetFileByIdParameters parameters,
+ string httpClientName = "Structure1-ApiClient",
+ CancellationToken cancellationToken = default);
+}
\ No newline at end of file
diff --git a/test/Atc.Rest.ApiGenerator.CLI.Tests/Scenarios/Structure1/VerifyClient/WOPD/src/Structure1.ApiClient.Generated/Files/MyEndpoints/Interfaces/IGetFileByIdEndpointResult.verified.cs b/test/Atc.Rest.ApiGenerator.CLI.Tests/Scenarios/Structure1/VerifyClient/WOPD/src/Structure1.ApiClient.Generated/Files/MyEndpoints/Interfaces/IGetFileByIdEndpointResult.verified.cs
new file mode 100644
index 000000000..a8aaf73c5
--- /dev/null
+++ b/test/Atc.Rest.ApiGenerator.CLI.Tests/Scenarios/Structure1/VerifyClient/WOPD/src/Structure1.ApiClient.Generated/Files/MyEndpoints/Interfaces/IGetFileByIdEndpointResult.verified.cs
@@ -0,0 +1,29 @@
+//------------------------------------------------------------------------------
+// This code was auto-generated by ApiGenerator x.x.x.x.
+//
+// Changes to this file may cause incorrect behavior and will be lost if
+// the code is regenerated.
+//------------------------------------------------------------------------------
+namespace Structure1.ApiClient.Generated.Files.MyEndpoints.Interfaces;
+
+///
+/// Interface for Client Endpoint Result.
+/// Description: Get File By Id.
+/// Operation: GetFileById.
+///
+[GeneratedCode("ApiGenerator", "x.x.x.x")]
+public interface IGetFileByIdEndpointResult : IEndpointResponse
+{
+
+ bool IsOk { get; }
+
+ bool IsBadRequest { get; }
+
+ bool IsNotFound { get; }
+
+ byte[] OkContent { get; }
+
+ string? BadRequestContent { get; }
+
+ string? NotFoundContent { get; }
+}
\ No newline at end of file
diff --git a/test/Atc.Rest.ApiGenerator.CLI.Tests/Scenarios/Structure1/VerifyClient/WOPD/src/Structure1.ApiClient.Generated/Files/MyEndpoints/Interfaces/IUploadMultiFilesAsFormDataEndpoint.verified.cs b/test/Atc.Rest.ApiGenerator.CLI.Tests/Scenarios/Structure1/VerifyClient/WOPD/src/Structure1.ApiClient.Generated/Files/MyEndpoints/Interfaces/IUploadMultiFilesAsFormDataEndpoint.verified.cs
new file mode 100644
index 000000000..d4cacc231
--- /dev/null
+++ b/test/Atc.Rest.ApiGenerator.CLI.Tests/Scenarios/Structure1/VerifyClient/WOPD/src/Structure1.ApiClient.Generated/Files/MyEndpoints/Interfaces/IUploadMultiFilesAsFormDataEndpoint.verified.cs
@@ -0,0 +1,27 @@
+//------------------------------------------------------------------------------
+// This code was auto-generated by ApiGenerator x.x.x.x.
+//
+// Changes to this file may cause incorrect behavior and will be lost if
+// the code is regenerated.
+//------------------------------------------------------------------------------
+namespace Structure1.ApiClient.Generated.Files.MyEndpoints.Interfaces;
+
+///
+/// Interface for Client Endpoint.
+/// Description: Upload multi files as form data.
+/// Operation: UploadMultiFilesAsFormData.
+///
+[GeneratedCode("ApiGenerator", "x.x.x.x")]
+public interface IUploadMultiFilesAsFormDataEndpoint
+{
+ ///
+ /// Execute method.
+ ///
+ /// The parameters.
+ /// The http client name.
+ /// The cancellation token.
+ Task ExecuteAsync(
+ UploadMultiFilesAsFormDataParameters parameters,
+ string httpClientName = "Structure1-ApiClient",
+ CancellationToken cancellationToken = default);
+}
\ No newline at end of file
diff --git a/test/Atc.Rest.ApiGenerator.CLI.Tests/Scenarios/Structure1/VerifyClient/WOPD/src/Structure1.ApiClient.Generated/Files/MyEndpoints/Interfaces/IUploadMultiFilesAsFormDataEndpointResult.verified.cs b/test/Atc.Rest.ApiGenerator.CLI.Tests/Scenarios/Structure1/VerifyClient/WOPD/src/Structure1.ApiClient.Generated/Files/MyEndpoints/Interfaces/IUploadMultiFilesAsFormDataEndpointResult.verified.cs
new file mode 100644
index 000000000..9fdb7f754
--- /dev/null
+++ b/test/Atc.Rest.ApiGenerator.CLI.Tests/Scenarios/Structure1/VerifyClient/WOPD/src/Structure1.ApiClient.Generated/Files/MyEndpoints/Interfaces/IUploadMultiFilesAsFormDataEndpointResult.verified.cs
@@ -0,0 +1,25 @@
+//------------------------------------------------------------------------------
+// This code was auto-generated by ApiGenerator x.x.x.x.
+//
+// Changes to this file may cause incorrect behavior and will be lost if
+// the code is regenerated.
+//------------------------------------------------------------------------------
+namespace Structure1.ApiClient.Generated.Files.MyEndpoints.Interfaces;
+
+///
+/// Interface for Client Endpoint Result.
+/// Description: Upload multi files as form data.
+/// Operation: UploadMultiFilesAsFormData.
+///
+[GeneratedCode("ApiGenerator", "x.x.x.x")]
+public interface IUploadMultiFilesAsFormDataEndpointResult : IEndpointResponse
+{
+
+ bool IsOk { get; }
+
+ bool IsBadRequest { get; }
+
+ string? OkContent { get; }
+
+ string? BadRequestContent { get; }
+}
\ No newline at end of file
diff --git a/test/Atc.Rest.ApiGenerator.CLI.Tests/Scenarios/Structure1/VerifyClient/WOPD/src/Structure1.ApiClient.Generated/Files/MyEndpoints/Interfaces/IUploadSingleFileAsFormDataEndpoint.verified.cs b/test/Atc.Rest.ApiGenerator.CLI.Tests/Scenarios/Structure1/VerifyClient/WOPD/src/Structure1.ApiClient.Generated/Files/MyEndpoints/Interfaces/IUploadSingleFileAsFormDataEndpoint.verified.cs
new file mode 100644
index 000000000..fde836c91
--- /dev/null
+++ b/test/Atc.Rest.ApiGenerator.CLI.Tests/Scenarios/Structure1/VerifyClient/WOPD/src/Structure1.ApiClient.Generated/Files/MyEndpoints/Interfaces/IUploadSingleFileAsFormDataEndpoint.verified.cs
@@ -0,0 +1,27 @@
+//------------------------------------------------------------------------------
+// This code was auto-generated by ApiGenerator x.x.x.x.
+//
+// Changes to this file may cause incorrect behavior and will be lost if
+// the code is regenerated.
+//------------------------------------------------------------------------------
+namespace Structure1.ApiClient.Generated.Files.MyEndpoints.Interfaces;
+
+///
+/// Interface for Client Endpoint.
+/// Description: Upload a file as OctetStream.
+/// Operation: UploadSingleFileAsFormData.
+///
+[GeneratedCode("ApiGenerator", "x.x.x.x")]
+public interface IUploadSingleFileAsFormDataEndpoint
+{
+ ///
+ /// Execute method.
+ ///
+ /// The parameters.
+ /// The http client name.
+ /// The cancellation token.
+ Task ExecuteAsync(
+ UploadSingleFileAsFormDataParameters parameters,
+ string httpClientName = "Structure1-ApiClient",
+ CancellationToken cancellationToken = default);
+}
\ No newline at end of file
diff --git a/test/Atc.Rest.ApiGenerator.CLI.Tests/Scenarios/Structure1/VerifyClient/WOPD/src/Structure1.ApiClient.Generated/Files/MyEndpoints/Interfaces/IUploadSingleFileAsFormDataEndpointResult.verified.cs b/test/Atc.Rest.ApiGenerator.CLI.Tests/Scenarios/Structure1/VerifyClient/WOPD/src/Structure1.ApiClient.Generated/Files/MyEndpoints/Interfaces/IUploadSingleFileAsFormDataEndpointResult.verified.cs
new file mode 100644
index 000000000..b4f4862f2
--- /dev/null
+++ b/test/Atc.Rest.ApiGenerator.CLI.Tests/Scenarios/Structure1/VerifyClient/WOPD/src/Structure1.ApiClient.Generated/Files/MyEndpoints/Interfaces/IUploadSingleFileAsFormDataEndpointResult.verified.cs
@@ -0,0 +1,25 @@
+//------------------------------------------------------------------------------
+// This code was auto-generated by ApiGenerator x.x.x.x.
+//
+// Changes to this file may cause incorrect behavior and will be lost if
+// the code is regenerated.
+//------------------------------------------------------------------------------
+namespace Structure1.ApiClient.Generated.Files.MyEndpoints.Interfaces;
+
+///
+/// Interface for Client Endpoint Result.
+/// Description: Upload a file as OctetStream.
+/// Operation: UploadSingleFileAsFormData.
+///
+[GeneratedCode("ApiGenerator", "x.x.x.x")]
+public interface IUploadSingleFileAsFormDataEndpointResult : IEndpointResponse
+{
+
+ bool IsOk { get; }
+
+ bool IsBadRequest { get; }
+
+ string? OkContent { get; }
+
+ string? BadRequestContent { get; }
+}
\ No newline at end of file
diff --git a/test/Atc.Rest.ApiGenerator.CLI.Tests/Scenarios/Structure1/VerifyClient/WOPD/src/Structure1.ApiClient.Generated/Files/MyEndpoints/Interfaces/IUploadSingleObjectWithFileAsFormDataEndpoint.verified.cs b/test/Atc.Rest.ApiGenerator.CLI.Tests/Scenarios/Structure1/VerifyClient/WOPD/src/Structure1.ApiClient.Generated/Files/MyEndpoints/Interfaces/IUploadSingleObjectWithFileAsFormDataEndpoint.verified.cs
new file mode 100644
index 000000000..860964fd7
--- /dev/null
+++ b/test/Atc.Rest.ApiGenerator.CLI.Tests/Scenarios/Structure1/VerifyClient/WOPD/src/Structure1.ApiClient.Generated/Files/MyEndpoints/Interfaces/IUploadSingleObjectWithFileAsFormDataEndpoint.verified.cs
@@ -0,0 +1,27 @@
+//------------------------------------------------------------------------------
+// This code was auto-generated by ApiGenerator x.x.x.x.
+//
+// Changes to this file may cause incorrect behavior and will be lost if
+// the code is regenerated.
+//------------------------------------------------------------------------------
+namespace Structure1.ApiClient.Generated.Files.MyEndpoints.Interfaces;
+
+///
+/// Interface for Client Endpoint.
+/// Description: Upload a file as FormData.
+/// Operation: UploadSingleObjectWithFileAsFormData.
+///
+[GeneratedCode("ApiGenerator", "x.x.x.x")]
+public interface IUploadSingleObjectWithFileAsFormDataEndpoint
+{
+ ///
+ /// Execute method.
+ ///
+ /// The parameters.
+ /// The http client name.
+ /// The cancellation token.
+ Task ExecuteAsync(
+ UploadSingleObjectWithFileAsFormDataParameters parameters,
+ string httpClientName = "Structure1-ApiClient",
+ CancellationToken cancellationToken = default);
+}
\ No newline at end of file
diff --git a/test/Atc.Rest.ApiGenerator.CLI.Tests/Scenarios/Structure1/VerifyClient/WOPD/src/Structure1.ApiClient.Generated/Files/MyEndpoints/Interfaces/IUploadSingleObjectWithFileAsFormDataEndpointResult.verified.cs b/test/Atc.Rest.ApiGenerator.CLI.Tests/Scenarios/Structure1/VerifyClient/WOPD/src/Structure1.ApiClient.Generated/Files/MyEndpoints/Interfaces/IUploadSingleObjectWithFileAsFormDataEndpointResult.verified.cs
new file mode 100644
index 000000000..490971ab0
--- /dev/null
+++ b/test/Atc.Rest.ApiGenerator.CLI.Tests/Scenarios/Structure1/VerifyClient/WOPD/src/Structure1.ApiClient.Generated/Files/MyEndpoints/Interfaces/IUploadSingleObjectWithFileAsFormDataEndpointResult.verified.cs
@@ -0,0 +1,25 @@
+//------------------------------------------------------------------------------
+// This code was auto-generated by ApiGenerator x.x.x.x.
+//
+// Changes to this file may cause incorrect behavior and will be lost if
+// the code is regenerated.
+//------------------------------------------------------------------------------
+namespace Structure1.ApiClient.Generated.Files.MyEndpoints.Interfaces;
+
+///
+/// Interface for Client Endpoint Result.
+/// Description: Upload a file as FormData.
+/// Operation: UploadSingleObjectWithFileAsFormData.
+///
+[GeneratedCode("ApiGenerator", "x.x.x.x")]
+public interface IUploadSingleObjectWithFileAsFormDataEndpointResult : IEndpointResponse
+{
+
+ bool IsOk { get; }
+
+ bool IsBadRequest { get; }
+
+ string? OkContent { get; }
+
+ string? BadRequestContent { get; }
+}
\ No newline at end of file
diff --git a/test/Atc.Rest.ApiGenerator.CLI.Tests/Scenarios/Structure1/VerifyClient/WOPD/src/Structure1.ApiClient.Generated/Files/MyEndpoints/Interfaces/IUploadSingleObjectWithFilesAsFormDataEndpoint.verified.cs b/test/Atc.Rest.ApiGenerator.CLI.Tests/Scenarios/Structure1/VerifyClient/WOPD/src/Structure1.ApiClient.Generated/Files/MyEndpoints/Interfaces/IUploadSingleObjectWithFilesAsFormDataEndpoint.verified.cs
new file mode 100644
index 000000000..dbae2f9b1
--- /dev/null
+++ b/test/Atc.Rest.ApiGenerator.CLI.Tests/Scenarios/Structure1/VerifyClient/WOPD/src/Structure1.ApiClient.Generated/Files/MyEndpoints/Interfaces/IUploadSingleObjectWithFilesAsFormDataEndpoint.verified.cs
@@ -0,0 +1,27 @@
+//------------------------------------------------------------------------------
+// This code was auto-generated by ApiGenerator x.x.x.x.
+//
+// Changes to this file may cause incorrect behavior and will be lost if
+// the code is regenerated.
+//------------------------------------------------------------------------------
+namespace Structure1.ApiClient.Generated.Files.MyEndpoints.Interfaces;
+
+///
+/// Interface for Client Endpoint.
+/// Description: Upload files as FormData.
+/// Operation: UploadSingleObjectWithFilesAsFormData.
+///
+[GeneratedCode("ApiGenerator", "x.x.x.x")]
+public interface IUploadSingleObjectWithFilesAsFormDataEndpoint
+{
+ ///
+ /// Execute method.
+ ///
+ /// The parameters.
+ /// The http client name.
+ /// The cancellation token.
+ Task ExecuteAsync(
+ UploadSingleObjectWithFilesAsFormDataParameters parameters,
+ string httpClientName = "Structure1-ApiClient",
+ CancellationToken cancellationToken = default);
+}
\ No newline at end of file
diff --git a/test/Atc.Rest.ApiGenerator.CLI.Tests/Scenarios/Structure1/VerifyClient/WOPD/src/Structure1.ApiClient.Generated/Files/MyEndpoints/Interfaces/IUploadSingleObjectWithFilesAsFormDataEndpointResult.verified.cs b/test/Atc.Rest.ApiGenerator.CLI.Tests/Scenarios/Structure1/VerifyClient/WOPD/src/Structure1.ApiClient.Generated/Files/MyEndpoints/Interfaces/IUploadSingleObjectWithFilesAsFormDataEndpointResult.verified.cs
new file mode 100644
index 000000000..4c24174ef
--- /dev/null
+++ b/test/Atc.Rest.ApiGenerator.CLI.Tests/Scenarios/Structure1/VerifyClient/WOPD/src/Structure1.ApiClient.Generated/Files/MyEndpoints/Interfaces/IUploadSingleObjectWithFilesAsFormDataEndpointResult.verified.cs
@@ -0,0 +1,25 @@
+//------------------------------------------------------------------------------
+// This code was auto-generated by ApiGenerator x.x.x.x.
+//
+// Changes to this file may cause incorrect behavior and will be lost if
+// the code is regenerated.
+//------------------------------------------------------------------------------
+namespace Structure1.ApiClient.Generated.Files.MyEndpoints.Interfaces;
+
+///
+/// Interface for Client Endpoint Result.
+/// Description: Upload files as FormData.
+/// Operation: UploadSingleObjectWithFilesAsFormData.
+///
+[GeneratedCode("ApiGenerator", "x.x.x.x")]
+public interface IUploadSingleObjectWithFilesAsFormDataEndpointResult : IEndpointResponse
+{
+
+ bool IsOk { get; }
+
+ bool IsBadRequest { get; }
+
+ string? OkContent { get; }
+
+ string? BadRequestContent { get; }
+}
\ No newline at end of file
diff --git a/test/Atc.Rest.ApiGenerator.CLI.Tests/Scenarios/Structure1/VerifyClient/WOPD/src/Structure1.ApiClient.Generated/Files/MyEndpoints/UploadMultiFilesAsFormDataEndpoint.verified.cs b/test/Atc.Rest.ApiGenerator.CLI.Tests/Scenarios/Structure1/VerifyClient/WOPD/src/Structure1.ApiClient.Generated/Files/MyEndpoints/UploadMultiFilesAsFormDataEndpoint.verified.cs
new file mode 100644
index 000000000..675bccc3c
--- /dev/null
+++ b/test/Atc.Rest.ApiGenerator.CLI.Tests/Scenarios/Structure1/VerifyClient/WOPD/src/Structure1.ApiClient.Generated/Files/MyEndpoints/UploadMultiFilesAsFormDataEndpoint.verified.cs
@@ -0,0 +1,46 @@
+//------------------------------------------------------------------------------
+// This code was auto-generated by ApiGenerator x.x.x.x.
+//
+// Changes to this file may cause incorrect behavior and will be lost if
+// the code is regenerated.
+//------------------------------------------------------------------------------
+namespace Structure1.ApiClient.Generated.Files.MyEndpoints;
+
+///
+/// Client Endpoint.
+/// Description: Upload multi files as form data.
+/// Operation: UploadMultiFilesAsFormData.
+///
+[GeneratedCode("ApiGenerator", "x.x.x.x")]
+public class UploadMultiFilesAsFormDataEndpoint : IUploadMultiFilesAsFormDataEndpoint
+{
+ private readonly IHttpClientFactory factory;
+ private readonly IHttpMessageFactory httpMessageFactory;
+
+ public UploadMultiFilesAsFormDataEndpoint(
+ IHttpClientFactory factory,
+ IHttpMessageFactory httpMessageFactory)
+ {
+ this.factory = factory;
+ this.httpMessageFactory = httpMessageFactory;
+ }
+
+ public async Task ExecuteAsync(
+ UploadMultiFilesAsFormDataParameters parameters,
+ string httpClientName = "Structure1-ApiClient",
+ CancellationToken cancellationToken = default)
+ {
+ var client = factory.CreateClient(httpClientName);
+
+ var requestBuilder = httpMessageFactory.FromTemplate("/api/v1/files/form-data/multiFile");
+ // TODO: Imp. With-Form
+
+ using var requestMessage = requestBuilder.Build(HttpMethod.Post);
+ using var response = await client.SendAsync(requestMessage, cancellationToken);
+
+ var responseBuilder = httpMessageFactory.FromResponse(response);
+ responseBuilder.AddSuccessResponse(HttpStatusCode.OK);
+ responseBuilder.AddErrorResponse(HttpStatusCode.BadRequest);
+ return await responseBuilder.BuildResponseAsync(x => new UploadMultiFilesAsFormDataEndpointResult(x), cancellationToken);
+ }
+}
\ No newline at end of file
diff --git a/test/Atc.Rest.ApiGenerator.CLI.Tests/Scenarios/Structure1/VerifyClient/WOPD/src/Structure1.ApiClient.Generated/Files/MyEndpoints/UploadMultiFilesAsFormDataEndpointResult.verified.cs b/test/Atc.Rest.ApiGenerator.CLI.Tests/Scenarios/Structure1/VerifyClient/WOPD/src/Structure1.ApiClient.Generated/Files/MyEndpoints/UploadMultiFilesAsFormDataEndpointResult.verified.cs
new file mode 100644
index 000000000..4acf140ac
--- /dev/null
+++ b/test/Atc.Rest.ApiGenerator.CLI.Tests/Scenarios/Structure1/VerifyClient/WOPD/src/Structure1.ApiClient.Generated/Files/MyEndpoints/UploadMultiFilesAsFormDataEndpointResult.verified.cs
@@ -0,0 +1,37 @@
+//------------------------------------------------------------------------------
+// This code was auto-generated by ApiGenerator x.x.x.x.
+//
+// Changes to this file may cause incorrect behavior and will be lost if
+// the code is regenerated.
+//------------------------------------------------------------------------------
+namespace Structure1.ApiClient.Generated.Files.MyEndpoints;
+
+///
+/// Client Endpoint result.
+/// Description: Upload multi files as form data.
+/// Operation: UploadMultiFilesAsFormData.
+///
+[GeneratedCode("ApiGenerator", "x.x.x.x")]
+public class UploadMultiFilesAsFormDataEndpointResult : EndpointResponse, IUploadMultiFilesAsFormDataEndpointResult
+{
+ public UploadMultiFilesAsFormDataEndpointResult(EndpointResponse response)
+ : base(response)
+ {
+ }
+
+ public bool IsOk
+ => StatusCode == HttpStatusCode.OK;
+
+ public bool IsBadRequest
+ => StatusCode == HttpStatusCode.BadRequest;
+
+ public string? OkContent
+ => IsOk && ContentObject is string result
+ ? result
+ : throw new InvalidOperationException("Content is not the expected type - please use the IsOk property first.");
+
+ public string? BadRequestContent
+ => IsBadRequest && ContentObject is string result
+ ? result
+ : throw new InvalidOperationException("Content is not the expected type - please use the IsBadRequest property first.");
+}
\ No newline at end of file
diff --git a/test/Atc.Rest.ApiGenerator.CLI.Tests/Scenarios/Structure1/VerifyClient/WOPD/src/Structure1.ApiClient.Generated/Files/MyEndpoints/UploadSingleFileAsFormDataEndpoint.verified.cs b/test/Atc.Rest.ApiGenerator.CLI.Tests/Scenarios/Structure1/VerifyClient/WOPD/src/Structure1.ApiClient.Generated/Files/MyEndpoints/UploadSingleFileAsFormDataEndpoint.verified.cs
new file mode 100644
index 000000000..d7b5294c9
--- /dev/null
+++ b/test/Atc.Rest.ApiGenerator.CLI.Tests/Scenarios/Structure1/VerifyClient/WOPD/src/Structure1.ApiClient.Generated/Files/MyEndpoints/UploadSingleFileAsFormDataEndpoint.verified.cs
@@ -0,0 +1,46 @@
+//------------------------------------------------------------------------------
+// This code was auto-generated by ApiGenerator x.x.x.x.
+//
+// Changes to this file may cause incorrect behavior and will be lost if
+// the code is regenerated.
+//------------------------------------------------------------------------------
+namespace Structure1.ApiClient.Generated.Files.MyEndpoints;
+
+///
+/// Client Endpoint.
+/// Description: Upload a file as OctetStream.
+/// Operation: UploadSingleFileAsFormData.
+///
+[GeneratedCode("ApiGenerator", "x.x.x.x")]
+public class UploadSingleFileAsFormDataEndpoint : IUploadSingleFileAsFormDataEndpoint
+{
+ private readonly IHttpClientFactory factory;
+ private readonly IHttpMessageFactory httpMessageFactory;
+
+ public UploadSingleFileAsFormDataEndpoint(
+ IHttpClientFactory factory,
+ IHttpMessageFactory httpMessageFactory)
+ {
+ this.factory = factory;
+ this.httpMessageFactory = httpMessageFactory;
+ }
+
+ public async Task ExecuteAsync(
+ UploadSingleFileAsFormDataParameters parameters,
+ string httpClientName = "Structure1-ApiClient",
+ CancellationToken cancellationToken = default)
+ {
+ var client = factory.CreateClient(httpClientName);
+
+ var requestBuilder = httpMessageFactory.FromTemplate("/api/v1/files/form-data/singleFile");
+ requestBuilder.WithBody(parameters.Request);
+
+ using var requestMessage = requestBuilder.Build(HttpMethod.Post);
+ using var response = await client.SendAsync(requestMessage, cancellationToken);
+
+ var responseBuilder = httpMessageFactory.FromResponse(response);
+ responseBuilder.AddSuccessResponse(HttpStatusCode.OK);
+ responseBuilder.AddErrorResponse(HttpStatusCode.BadRequest);
+ return await responseBuilder.BuildResponseAsync(x => new UploadSingleFileAsFormDataEndpointResult(x), cancellationToken);
+ }
+}
\ No newline at end of file
diff --git a/test/Atc.Rest.ApiGenerator.CLI.Tests/Scenarios/Structure1/VerifyClient/WOPD/src/Structure1.ApiClient.Generated/Files/MyEndpoints/UploadSingleFileAsFormDataEndpointResult.verified.cs b/test/Atc.Rest.ApiGenerator.CLI.Tests/Scenarios/Structure1/VerifyClient/WOPD/src/Structure1.ApiClient.Generated/Files/MyEndpoints/UploadSingleFileAsFormDataEndpointResult.verified.cs
new file mode 100644
index 000000000..7e7a17226
--- /dev/null
+++ b/test/Atc.Rest.ApiGenerator.CLI.Tests/Scenarios/Structure1/VerifyClient/WOPD/src/Structure1.ApiClient.Generated/Files/MyEndpoints/UploadSingleFileAsFormDataEndpointResult.verified.cs
@@ -0,0 +1,37 @@
+//------------------------------------------------------------------------------
+// This code was auto-generated by ApiGenerator x.x.x.x.
+//
+// Changes to this file may cause incorrect behavior and will be lost if
+// the code is regenerated.
+//------------------------------------------------------------------------------
+namespace Structure1.ApiClient.Generated.Files.MyEndpoints;
+
+///
+/// Client Endpoint result.
+/// Description: Upload a file as OctetStream.
+/// Operation: UploadSingleFileAsFormData.
+///
+[GeneratedCode("ApiGenerator", "x.x.x.x")]
+public class UploadSingleFileAsFormDataEndpointResult : EndpointResponse, IUploadSingleFileAsFormDataEndpointResult
+{
+ public UploadSingleFileAsFormDataEndpointResult(EndpointResponse response)
+ : base(response)
+ {
+ }
+
+ public bool IsOk
+ => StatusCode == HttpStatusCode.OK;
+
+ public bool IsBadRequest
+ => StatusCode == HttpStatusCode.BadRequest;
+
+ public string? OkContent
+ => IsOk && ContentObject is string result
+ ? result
+ : throw new InvalidOperationException("Content is not the expected type - please use the IsOk property first.");
+
+ public string? BadRequestContent
+ => IsBadRequest && ContentObject is string result
+ ? result
+ : throw new InvalidOperationException("Content is not the expected type - please use the IsBadRequest property first.");
+}
\ No newline at end of file
diff --git a/test/Atc.Rest.ApiGenerator.CLI.Tests/Scenarios/Structure1/VerifyClient/WOPD/src/Structure1.ApiClient.Generated/Files/MyEndpoints/UploadSingleObjectWithFileAsFormDataEndpoint.verified.cs b/test/Atc.Rest.ApiGenerator.CLI.Tests/Scenarios/Structure1/VerifyClient/WOPD/src/Structure1.ApiClient.Generated/Files/MyEndpoints/UploadSingleObjectWithFileAsFormDataEndpoint.verified.cs
new file mode 100644
index 000000000..aabd83e6b
--- /dev/null
+++ b/test/Atc.Rest.ApiGenerator.CLI.Tests/Scenarios/Structure1/VerifyClient/WOPD/src/Structure1.ApiClient.Generated/Files/MyEndpoints/UploadSingleObjectWithFileAsFormDataEndpoint.verified.cs
@@ -0,0 +1,46 @@
+//------------------------------------------------------------------------------
+// This code was auto-generated by ApiGenerator x.x.x.x.
+//
+// Changes to this file may cause incorrect behavior and will be lost if
+// the code is regenerated.
+//------------------------------------------------------------------------------
+namespace Structure1.ApiClient.Generated.Files.MyEndpoints;
+
+///
+/// Client Endpoint.
+/// Description: Upload a file as FormData.
+/// Operation: UploadSingleObjectWithFileAsFormData.
+///
+[GeneratedCode("ApiGenerator", "x.x.x.x")]
+public class UploadSingleObjectWithFileAsFormDataEndpoint : IUploadSingleObjectWithFileAsFormDataEndpoint
+{
+ private readonly IHttpClientFactory factory;
+ private readonly IHttpMessageFactory httpMessageFactory;
+
+ public UploadSingleObjectWithFileAsFormDataEndpoint(
+ IHttpClientFactory factory,
+ IHttpMessageFactory httpMessageFactory)
+ {
+ this.factory = factory;
+ this.httpMessageFactory = httpMessageFactory;
+ }
+
+ public async Task ExecuteAsync(
+ UploadSingleObjectWithFileAsFormDataParameters parameters,
+ string httpClientName = "Structure1-ApiClient",
+ CancellationToken cancellationToken = default)
+ {
+ var client = factory.CreateClient(httpClientName);
+
+ var requestBuilder = httpMessageFactory.FromTemplate("/api/v1/files/form-data/singleObject");
+ // TODO: Imp. With-Form
+
+ using var requestMessage = requestBuilder.Build(HttpMethod.Post);
+ using var response = await client.SendAsync(requestMessage, cancellationToken);
+
+ var responseBuilder = httpMessageFactory.FromResponse(response);
+ responseBuilder.AddSuccessResponse(HttpStatusCode.OK);
+ responseBuilder.AddErrorResponse(HttpStatusCode.BadRequest);
+ return await responseBuilder.BuildResponseAsync(x => new UploadSingleObjectWithFileAsFormDataEndpointResult(x), cancellationToken);
+ }
+}
\ No newline at end of file
diff --git a/test/Atc.Rest.ApiGenerator.CLI.Tests/Scenarios/Structure1/VerifyClient/WOPD/src/Structure1.ApiClient.Generated/Files/MyEndpoints/UploadSingleObjectWithFileAsFormDataEndpointResult.verified.cs b/test/Atc.Rest.ApiGenerator.CLI.Tests/Scenarios/Structure1/VerifyClient/WOPD/src/Structure1.ApiClient.Generated/Files/MyEndpoints/UploadSingleObjectWithFileAsFormDataEndpointResult.verified.cs
new file mode 100644
index 000000000..d08a76c01
--- /dev/null
+++ b/test/Atc.Rest.ApiGenerator.CLI.Tests/Scenarios/Structure1/VerifyClient/WOPD/src/Structure1.ApiClient.Generated/Files/MyEndpoints/UploadSingleObjectWithFileAsFormDataEndpointResult.verified.cs
@@ -0,0 +1,37 @@
+//------------------------------------------------------------------------------
+// This code was auto-generated by ApiGenerator x.x.x.x.
+//
+// Changes to this file may cause incorrect behavior and will be lost if
+// the code is regenerated.
+//------------------------------------------------------------------------------
+namespace Structure1.ApiClient.Generated.Files.MyEndpoints;
+
+///
+/// Client Endpoint result.
+/// Description: Upload a file as FormData.
+/// Operation: UploadSingleObjectWithFileAsFormData.
+///
+[GeneratedCode("ApiGenerator", "x.x.x.x")]
+public class UploadSingleObjectWithFileAsFormDataEndpointResult : EndpointResponse, IUploadSingleObjectWithFileAsFormDataEndpointResult
+{
+ public UploadSingleObjectWithFileAsFormDataEndpointResult(EndpointResponse response)
+ : base(response)
+ {
+ }
+
+ public bool IsOk
+ => StatusCode == HttpStatusCode.OK;
+
+ public bool IsBadRequest
+ => StatusCode == HttpStatusCode.BadRequest;
+
+ public string? OkContent
+ => IsOk && ContentObject is string result
+ ? result
+ : throw new InvalidOperationException("Content is not the expected type - please use the IsOk property first.");
+
+ public string? BadRequestContent
+ => IsBadRequest && ContentObject is string result
+ ? result
+ : throw new InvalidOperationException("Content is not the expected type - please use the IsBadRequest property first.");
+}
\ No newline at end of file
diff --git a/test/Atc.Rest.ApiGenerator.CLI.Tests/Scenarios/Structure1/VerifyClient/WOPD/src/Structure1.ApiClient.Generated/Files/MyEndpoints/UploadSingleObjectWithFilesAsFormDataEndpoint.verified.cs b/test/Atc.Rest.ApiGenerator.CLI.Tests/Scenarios/Structure1/VerifyClient/WOPD/src/Structure1.ApiClient.Generated/Files/MyEndpoints/UploadSingleObjectWithFilesAsFormDataEndpoint.verified.cs
new file mode 100644
index 000000000..e1e1cb07a
--- /dev/null
+++ b/test/Atc.Rest.ApiGenerator.CLI.Tests/Scenarios/Structure1/VerifyClient/WOPD/src/Structure1.ApiClient.Generated/Files/MyEndpoints/UploadSingleObjectWithFilesAsFormDataEndpoint.verified.cs
@@ -0,0 +1,46 @@
+//------------------------------------------------------------------------------
+// This code was auto-generated by ApiGenerator x.x.x.x.
+//
+// Changes to this file may cause incorrect behavior and will be lost if
+// the code is regenerated.
+//------------------------------------------------------------------------------
+namespace Structure1.ApiClient.Generated.Files.MyEndpoints;
+
+///
+/// Client Endpoint.
+/// Description: Upload files as FormData.
+/// Operation: UploadSingleObjectWithFilesAsFormData.
+///
+[GeneratedCode("ApiGenerator", "x.x.x.x")]
+public class UploadSingleObjectWithFilesAsFormDataEndpoint : IUploadSingleObjectWithFilesAsFormDataEndpoint
+{
+ private readonly IHttpClientFactory factory;
+ private readonly IHttpMessageFactory httpMessageFactory;
+
+ public UploadSingleObjectWithFilesAsFormDataEndpoint(
+ IHttpClientFactory factory,
+ IHttpMessageFactory httpMessageFactory)
+ {
+ this.factory = factory;
+ this.httpMessageFactory = httpMessageFactory;
+ }
+
+ public async Task ExecuteAsync(
+ UploadSingleObjectWithFilesAsFormDataParameters parameters,
+ string httpClientName = "Structure1-ApiClient",
+ CancellationToken cancellationToken = default)
+ {
+ var client = factory.CreateClient(httpClientName);
+
+ var requestBuilder = httpMessageFactory.FromTemplate("/api/v1/files/form-data/singleObjectMultiFile");
+ // TODO: Imp. With-Form
+
+ using var requestMessage = requestBuilder.Build(HttpMethod.Post);
+ using var response = await client.SendAsync(requestMessage, cancellationToken);
+
+ var responseBuilder = httpMessageFactory.FromResponse(response);
+ responseBuilder.AddSuccessResponse(HttpStatusCode.OK);
+ responseBuilder.AddErrorResponse(HttpStatusCode.BadRequest);
+ return await responseBuilder.BuildResponseAsync(x => new UploadSingleObjectWithFilesAsFormDataEndpointResult(x), cancellationToken);
+ }
+}
\ No newline at end of file
diff --git a/test/Atc.Rest.ApiGenerator.CLI.Tests/Scenarios/Structure1/VerifyClient/WOPD/src/Structure1.ApiClient.Generated/Files/MyEndpoints/UploadSingleObjectWithFilesAsFormDataEndpointResult.verified.cs b/test/Atc.Rest.ApiGenerator.CLI.Tests/Scenarios/Structure1/VerifyClient/WOPD/src/Structure1.ApiClient.Generated/Files/MyEndpoints/UploadSingleObjectWithFilesAsFormDataEndpointResult.verified.cs
new file mode 100644
index 000000000..896b4b324
--- /dev/null
+++ b/test/Atc.Rest.ApiGenerator.CLI.Tests/Scenarios/Structure1/VerifyClient/WOPD/src/Structure1.ApiClient.Generated/Files/MyEndpoints/UploadSingleObjectWithFilesAsFormDataEndpointResult.verified.cs
@@ -0,0 +1,37 @@
+//------------------------------------------------------------------------------
+// This code was auto-generated by ApiGenerator x.x.x.x.
+//
+// Changes to this file may cause incorrect behavior and will be lost if
+// the code is regenerated.
+//------------------------------------------------------------------------------
+namespace Structure1.ApiClient.Generated.Files.MyEndpoints;
+
+///
+/// Client Endpoint result.
+/// Description: Upload files as FormData.
+/// Operation: UploadSingleObjectWithFilesAsFormData.
+///
+[GeneratedCode("ApiGenerator", "x.x.x.x")]
+public class UploadSingleObjectWithFilesAsFormDataEndpointResult : EndpointResponse, IUploadSingleObjectWithFilesAsFormDataEndpointResult
+{
+ public UploadSingleObjectWithFilesAsFormDataEndpointResult(EndpointResponse response)
+ : base(response)
+ {
+ }
+
+ public bool IsOk
+ => StatusCode == HttpStatusCode.OK;
+
+ public bool IsBadRequest
+ => StatusCode == HttpStatusCode.BadRequest;
+
+ public string? OkContent
+ => IsOk && ContentObject is string result
+ ? result
+ : throw new InvalidOperationException("Content is not the expected type - please use the IsOk property first.");
+
+ public string? BadRequestContent
+ => IsBadRequest && ContentObject is string result
+ ? result
+ : throw new InvalidOperationException("Content is not the expected type - please use the IsBadRequest property first.");
+}
\ No newline at end of file
diff --git a/test/Atc.Rest.ApiGenerator.CLI.Tests/Scenarios/Structure1/VerifyClient/WOPD/src/Structure1.ApiClient.Generated/GlobalUsings.verified.cs b/test/Atc.Rest.ApiGenerator.CLI.Tests/Scenarios/Structure1/VerifyClient/WOPD/src/Structure1.ApiClient.Generated/GlobalUsings.verified.cs
new file mode 100644
index 000000000..a49ad84a8
--- /dev/null
+++ b/test/Atc.Rest.ApiGenerator.CLI.Tests/Scenarios/Structure1/VerifyClient/WOPD/src/Structure1.ApiClient.Generated/GlobalUsings.verified.cs
@@ -0,0 +1,34 @@
+global using System;
+global using System.CodeDom.Compiler;
+global using System.Collections.Generic;
+global using System.ComponentModel.DataAnnotations;
+global using System.Linq;
+global using System.Net;
+global using System.Net.Http;
+global using System.Threading;
+global using System.Threading.Tasks;
+
+global using Atc.Rest.Client;
+global using Atc.Rest.Client.Builder;
+global using Atc.Rest.Results;
+
+global using Microsoft.AspNetCore.Http;
+global using Microsoft.AspNetCore.Mvc;
+
+global using Structure1.ApiClient.Generated.Accounts.MyContracts;
+global using Structure1.ApiClient.Generated.Accounts.MyEndpoints.Interfaces;
+global using Structure1.ApiClient.Generated.Addresses.MyContracts;
+global using Structure1.ApiClient.Generated.Addresses.MyEndpoints.Interfaces;
+global using Structure1.ApiClient.Generated.EventArgs.MyContracts;
+global using Structure1.ApiClient.Generated.EventArgs.MyEndpoints.Interfaces;
+global using Structure1.ApiClient.Generated.Files.MyContracts;
+global using Structure1.ApiClient.Generated.Files.MyEndpoints.Interfaces;
+global using Structure1.ApiClient.Generated.Items.MyContracts;
+global using Structure1.ApiClient.Generated.Items.MyEndpoints.Interfaces;
+global using Structure1.ApiClient.Generated.MyContracts;
+global using Structure1.ApiClient.Generated.Orders.MyContracts;
+global using Structure1.ApiClient.Generated.Orders.MyEndpoints.Interfaces;
+global using Structure1.ApiClient.Generated.RouteWithDash.MyEndpoints.Interfaces;
+global using Structure1.ApiClient.Generated.Tasks.MyEndpoints.Interfaces;
+global using Structure1.ApiClient.Generated.Users.MyContracts;
+global using Structure1.ApiClient.Generated.Users.MyEndpoints.Interfaces;
\ No newline at end of file
diff --git a/test/Atc.Rest.ApiGenerator.CLI.Tests/Scenarios/Structure1/VerifyClient/WOPD/src/Structure1.ApiClient.Generated/Items/MyContracts/CreateItemRequest.verified.cs b/test/Atc.Rest.ApiGenerator.CLI.Tests/Scenarios/Structure1/VerifyClient/WOPD/src/Structure1.ApiClient.Generated/Items/MyContracts/CreateItemRequest.verified.cs
new file mode 100644
index 000000000..72946b7e8
--- /dev/null
+++ b/test/Atc.Rest.ApiGenerator.CLI.Tests/Scenarios/Structure1/VerifyClient/WOPD/src/Structure1.ApiClient.Generated/Items/MyContracts/CreateItemRequest.verified.cs
@@ -0,0 +1,30 @@
+//------------------------------------------------------------------------------
+// This code was auto-generated by ApiGenerator x.x.x.x.
+//
+// Changes to this file may cause incorrect behavior and will be lost if
+// the code is regenerated.
+//------------------------------------------------------------------------------
+namespace Structure1.ApiClient.Generated.Items.MyContracts;
+
+///
+/// CreateItemRequest.
+///
+[GeneratedCode("ApiGenerator", "x.x.x.x")]
+public class CreateItemRequest
+{
+ ///
+ /// Item.
+ ///
+ [Required]
+ public Item Item { get; set; }
+
+ ///
+ /// A list of Item.
+ ///
+ [Required]
+ public List- MyItems { get; set; }
+
+ ///
+ public override string ToString()
+ => $"{nameof(Item)}: ({Item}), {nameof(MyItems)}.Count: {MyItems?.Count ?? 0}";
+}
\ No newline at end of file
diff --git a/test/Atc.Rest.ApiGenerator.CLI.Tests/Scenarios/Structure1/VerifyClient/WOPD/src/Structure1.ApiClient.Generated/Items/MyContracts/Item.verified.cs b/test/Atc.Rest.ApiGenerator.CLI.Tests/Scenarios/Structure1/VerifyClient/WOPD/src/Structure1.ApiClient.Generated/Items/MyContracts/Item.verified.cs
new file mode 100644
index 000000000..338def7fd
--- /dev/null
+++ b/test/Atc.Rest.ApiGenerator.CLI.Tests/Scenarios/Structure1/VerifyClient/WOPD/src/Structure1.ApiClient.Generated/Items/MyContracts/Item.verified.cs
@@ -0,0 +1,21 @@
+//------------------------------------------------------------------------------
+// This code was auto-generated by ApiGenerator x.x.x.x.
+//
+// Changes to this file may cause incorrect behavior and will be lost if
+// the code is regenerated.
+//------------------------------------------------------------------------------
+namespace Structure1.ApiClient.Generated.Items.MyContracts;
+
+///
+/// Item.
+///
+[GeneratedCode("ApiGenerator", "x.x.x.x")]
+public class Item
+{
+ [Required]
+ public string Name { get; set; }
+
+ ///
+ public override string ToString()
+ => $"{nameof(Name)}: {Name}";
+}
\ No newline at end of file
diff --git a/test/Atc.Rest.ApiGenerator.CLI.Tests/Scenarios/Structure1/VerifyClient/WOPD/src/Structure1.ApiClient.Generated/Items/MyContracts/RequestParameters/CreateItemParameters.verified.cs b/test/Atc.Rest.ApiGenerator.CLI.Tests/Scenarios/Structure1/VerifyClient/WOPD/src/Structure1.ApiClient.Generated/Items/MyContracts/RequestParameters/CreateItemParameters.verified.cs
new file mode 100644
index 000000000..6d1f62ea4
--- /dev/null
+++ b/test/Atc.Rest.ApiGenerator.CLI.Tests/Scenarios/Structure1/VerifyClient/WOPD/src/Structure1.ApiClient.Generated/Items/MyContracts/RequestParameters/CreateItemParameters.verified.cs
@@ -0,0 +1,26 @@
+//------------------------------------------------------------------------------
+// This code was auto-generated by ApiGenerator x.x.x.x.
+//
+// Changes to this file may cause incorrect behavior and will be lost if
+// the code is regenerated.
+//------------------------------------------------------------------------------
+namespace Structure1.ApiClient.Generated.Items.MyContracts;
+
+///
+/// Parameters for operation request.
+/// Description: Create a new item.
+/// Operation: CreateItem.
+///
+[GeneratedCode("ApiGenerator", "x.x.x.x")]
+public class CreateItemParameters
+{
+ ///
+ /// CreateItemRequest.
+ ///
+ [Required]
+ public CreateItemRequest Request { get; set; }
+
+ ///
+ public override string ToString()
+ => $"{nameof(Request)}: ({Request})";
+}
\ No newline at end of file
diff --git a/test/Atc.Rest.ApiGenerator.CLI.Tests/Scenarios/Structure1/VerifyClient/WOPD/src/Structure1.ApiClient.Generated/Items/MyContracts/RequestParameters/UpdateItemParameters.verified.cs b/test/Atc.Rest.ApiGenerator.CLI.Tests/Scenarios/Structure1/VerifyClient/WOPD/src/Structure1.ApiClient.Generated/Items/MyContracts/RequestParameters/UpdateItemParameters.verified.cs
new file mode 100644
index 000000000..857f8164e
--- /dev/null
+++ b/test/Atc.Rest.ApiGenerator.CLI.Tests/Scenarios/Structure1/VerifyClient/WOPD/src/Structure1.ApiClient.Generated/Items/MyContracts/RequestParameters/UpdateItemParameters.verified.cs
@@ -0,0 +1,32 @@
+//------------------------------------------------------------------------------
+// This code was auto-generated by ApiGenerator x.x.x.x.
+//
+// Changes to this file may cause incorrect behavior and will be lost if
+// the code is regenerated.
+//------------------------------------------------------------------------------
+namespace Structure1.ApiClient.Generated.Items.MyContracts;
+
+///
+/// Parameters for operation request.
+/// Description: Updates an item.
+/// Operation: UpdateItem.
+///
+[GeneratedCode("ApiGenerator", "x.x.x.x")]
+public class UpdateItemParameters
+{
+ ///
+ /// The id of the order.
+ ///
+ [Required]
+ public Guid Id { get; set; }
+
+ ///
+ /// UpdateItemRequest.
+ ///
+ [Required]
+ public UpdateItemRequest Request { get; set; }
+
+ ///
+ public override string ToString()
+ => $"{nameof(Id)}: {Id}, {nameof(Request)}: ({Request})";
+}
\ No newline at end of file
diff --git a/test/Atc.Rest.ApiGenerator.CLI.Tests/Scenarios/Structure1/VerifyClient/WOPD/src/Structure1.ApiClient.Generated/Items/MyContracts/UpdateItemRequest.verified.cs b/test/Atc.Rest.ApiGenerator.CLI.Tests/Scenarios/Structure1/VerifyClient/WOPD/src/Structure1.ApiClient.Generated/Items/MyContracts/UpdateItemRequest.verified.cs
new file mode 100644
index 000000000..25bc5c565
--- /dev/null
+++ b/test/Atc.Rest.ApiGenerator.CLI.Tests/Scenarios/Structure1/VerifyClient/WOPD/src/Structure1.ApiClient.Generated/Items/MyContracts/UpdateItemRequest.verified.cs
@@ -0,0 +1,24 @@
+//------------------------------------------------------------------------------
+// This code was auto-generated by ApiGenerator x.x.x.x.
+//
+// Changes to this file may cause incorrect behavior and will be lost if
+// the code is regenerated.
+//------------------------------------------------------------------------------
+namespace Structure1.ApiClient.Generated.Items.MyContracts;
+
+///
+/// UpdateItemRequest.
+///
+[GeneratedCode("ApiGenerator", "x.x.x.x")]
+public class UpdateItemRequest
+{
+ ///
+ /// Item.
+ ///
+ [Required]
+ public Item Item { get; set; }
+
+ ///
+ public override string ToString()
+ => $"{nameof(Item)}: ({Item})";
+}
\ No newline at end of file
diff --git a/test/Atc.Rest.ApiGenerator.CLI.Tests/Scenarios/Structure1/VerifyClient/WOPD/src/Structure1.ApiClient.Generated/Items/MyEndpoints/CreateItemEndpoint.verified.cs b/test/Atc.Rest.ApiGenerator.CLI.Tests/Scenarios/Structure1/VerifyClient/WOPD/src/Structure1.ApiClient.Generated/Items/MyEndpoints/CreateItemEndpoint.verified.cs
new file mode 100644
index 000000000..c151d8eb3
--- /dev/null
+++ b/test/Atc.Rest.ApiGenerator.CLI.Tests/Scenarios/Structure1/VerifyClient/WOPD/src/Structure1.ApiClient.Generated/Items/MyEndpoints/CreateItemEndpoint.verified.cs
@@ -0,0 +1,46 @@
+//------------------------------------------------------------------------------
+// This code was auto-generated by ApiGenerator x.x.x.x.
+//
+// Changes to this file may cause incorrect behavior and will be lost if
+// the code is regenerated.
+//------------------------------------------------------------------------------
+namespace Structure1.ApiClient.Generated.Items.MyEndpoints;
+
+///
+/// Client Endpoint.
+/// Description: Create a new item.
+/// Operation: CreateItem.
+///
+[GeneratedCode("ApiGenerator", "x.x.x.x")]
+public class CreateItemEndpoint : ICreateItemEndpoint
+{
+ private readonly IHttpClientFactory factory;
+ private readonly IHttpMessageFactory httpMessageFactory;
+
+ public CreateItemEndpoint(
+ IHttpClientFactory factory,
+ IHttpMessageFactory httpMessageFactory)
+ {
+ this.factory = factory;
+ this.httpMessageFactory = httpMessageFactory;
+ }
+
+ public async Task ExecuteAsync(
+ CreateItemParameters parameters,
+ string httpClientName = "Structure1-ApiClient",
+ CancellationToken cancellationToken = default)
+ {
+ var client = factory.CreateClient(httpClientName);
+
+ var requestBuilder = httpMessageFactory.FromTemplate("/api/v1/items");
+ requestBuilder.WithBody(parameters.Request);
+
+ using var requestMessage = requestBuilder.Build(HttpMethod.Post);
+ using var response = await client.SendAsync(requestMessage, cancellationToken);
+
+ var responseBuilder = httpMessageFactory.FromResponse(response);
+ responseBuilder.AddSuccessResponse(HttpStatusCode.OK);
+ responseBuilder.AddErrorResponse(HttpStatusCode.BadRequest);
+ return await responseBuilder.BuildResponseAsync(x => new CreateItemEndpointResult(x), cancellationToken);
+ }
+}
\ No newline at end of file
diff --git a/test/Atc.Rest.ApiGenerator.CLI.Tests/Scenarios/Structure1/VerifyClient/WOPD/src/Structure1.ApiClient.Generated/Items/MyEndpoints/CreateItemEndpointResult.verified.cs b/test/Atc.Rest.ApiGenerator.CLI.Tests/Scenarios/Structure1/VerifyClient/WOPD/src/Structure1.ApiClient.Generated/Items/MyEndpoints/CreateItemEndpointResult.verified.cs
new file mode 100644
index 000000000..1a3816e90
--- /dev/null
+++ b/test/Atc.Rest.ApiGenerator.CLI.Tests/Scenarios/Structure1/VerifyClient/WOPD/src/Structure1.ApiClient.Generated/Items/MyEndpoints/CreateItemEndpointResult.verified.cs
@@ -0,0 +1,37 @@
+//------------------------------------------------------------------------------
+// This code was auto-generated by ApiGenerator x.x.x.x.
+//
+// Changes to this file may cause incorrect behavior and will be lost if
+// the code is regenerated.
+//------------------------------------------------------------------------------
+namespace Structure1.ApiClient.Generated.Items.MyEndpoints;
+
+///
+/// Client Endpoint result.
+/// Description: Create a new item.
+/// Operation: CreateItem.
+///
+[GeneratedCode("ApiGenerator", "x.x.x.x")]
+public class CreateItemEndpointResult : EndpointResponse, ICreateItemEndpointResult
+{
+ public CreateItemEndpointResult(EndpointResponse response)
+ : base(response)
+ {
+ }
+
+ public bool IsOk
+ => StatusCode == HttpStatusCode.OK;
+
+ public bool IsBadRequest
+ => StatusCode == HttpStatusCode.BadRequest;
+
+ public string? OkContent
+ => IsOk && ContentObject is string result
+ ? result
+ : throw new InvalidOperationException("Content is not the expected type - please use the IsOk property first.");
+
+ public string? BadRequestContent
+ => IsBadRequest && ContentObject is string result
+ ? result
+ : throw new InvalidOperationException("Content is not the expected type - please use the IsBadRequest property first.");
+}
\ No newline at end of file
diff --git a/test/Atc.Rest.ApiGenerator.CLI.Tests/Scenarios/Structure1/VerifyClient/WOPD/src/Structure1.ApiClient.Generated/Items/MyEndpoints/Interfaces/ICreateItemEndpoint.verified.cs b/test/Atc.Rest.ApiGenerator.CLI.Tests/Scenarios/Structure1/VerifyClient/WOPD/src/Structure1.ApiClient.Generated/Items/MyEndpoints/Interfaces/ICreateItemEndpoint.verified.cs
new file mode 100644
index 000000000..a030a7ffe
--- /dev/null
+++ b/test/Atc.Rest.ApiGenerator.CLI.Tests/Scenarios/Structure1/VerifyClient/WOPD/src/Structure1.ApiClient.Generated/Items/MyEndpoints/Interfaces/ICreateItemEndpoint.verified.cs
@@ -0,0 +1,27 @@
+//------------------------------------------------------------------------------
+// This code was auto-generated by ApiGenerator x.x.x.x.
+//
+// Changes to this file may cause incorrect behavior and will be lost if
+// the code is regenerated.
+//------------------------------------------------------------------------------
+namespace Structure1.ApiClient.Generated.Items.MyEndpoints.Interfaces;
+
+///
+/// Interface for Client Endpoint.
+/// Description: Create a new item.
+/// Operation: CreateItem.
+///
+[GeneratedCode("ApiGenerator", "x.x.x.x")]
+public interface ICreateItemEndpoint
+{
+ ///
+ /// Execute method.
+ ///
+ /// The parameters.
+ /// The http client name.
+ /// The cancellation token.
+ Task ExecuteAsync(
+ CreateItemParameters parameters,
+ string httpClientName = "Structure1-ApiClient",
+ CancellationToken cancellationToken = default);
+}
\ No newline at end of file
diff --git a/test/Atc.Rest.ApiGenerator.CLI.Tests/Scenarios/Structure1/VerifyClient/WOPD/src/Structure1.ApiClient.Generated/Items/MyEndpoints/Interfaces/ICreateItemEndpointResult.verified.cs b/test/Atc.Rest.ApiGenerator.CLI.Tests/Scenarios/Structure1/VerifyClient/WOPD/src/Structure1.ApiClient.Generated/Items/MyEndpoints/Interfaces/ICreateItemEndpointResult.verified.cs
new file mode 100644
index 000000000..5fba321c3
--- /dev/null
+++ b/test/Atc.Rest.ApiGenerator.CLI.Tests/Scenarios/Structure1/VerifyClient/WOPD/src/Structure1.ApiClient.Generated/Items/MyEndpoints/Interfaces/ICreateItemEndpointResult.verified.cs
@@ -0,0 +1,25 @@
+//------------------------------------------------------------------------------
+// This code was auto-generated by ApiGenerator x.x.x.x.
+//
+// Changes to this file may cause incorrect behavior and will be lost if
+// the code is regenerated.
+//------------------------------------------------------------------------------
+namespace Structure1.ApiClient.Generated.Items.MyEndpoints.Interfaces;
+
+///
+/// Interface for Client Endpoint Result.
+/// Description: Create a new item.
+/// Operation: CreateItem.
+///
+[GeneratedCode("ApiGenerator", "x.x.x.x")]
+public interface ICreateItemEndpointResult : IEndpointResponse
+{
+
+ bool IsOk { get; }
+
+ bool IsBadRequest { get; }
+
+ string? OkContent { get; }
+
+ string? BadRequestContent { get; }
+}
\ No newline at end of file
diff --git a/test/Atc.Rest.ApiGenerator.CLI.Tests/Scenarios/Structure1/VerifyClient/WOPD/src/Structure1.ApiClient.Generated/Items/MyEndpoints/Interfaces/IUpdateItemEndpoint.verified.cs b/test/Atc.Rest.ApiGenerator.CLI.Tests/Scenarios/Structure1/VerifyClient/WOPD/src/Structure1.ApiClient.Generated/Items/MyEndpoints/Interfaces/IUpdateItemEndpoint.verified.cs
new file mode 100644
index 000000000..109aedace
--- /dev/null
+++ b/test/Atc.Rest.ApiGenerator.CLI.Tests/Scenarios/Structure1/VerifyClient/WOPD/src/Structure1.ApiClient.Generated/Items/MyEndpoints/Interfaces/IUpdateItemEndpoint.verified.cs
@@ -0,0 +1,27 @@
+//------------------------------------------------------------------------------
+// This code was auto-generated by ApiGenerator x.x.x.x.
+//
+// Changes to this file may cause incorrect behavior and will be lost if
+// the code is regenerated.
+//------------------------------------------------------------------------------
+namespace Structure1.ApiClient.Generated.Items.MyEndpoints.Interfaces;
+
+///
+/// Interface for Client Endpoint.
+/// Description: Updates an item.
+/// Operation: UpdateItem.
+///
+[GeneratedCode("ApiGenerator", "x.x.x.x")]
+public interface IUpdateItemEndpoint
+{
+ ///
+ /// Execute method.
+ ///
+ /// The parameters.
+ /// The http client name.
+ /// The cancellation token.
+ Task ExecuteAsync(
+ UpdateItemParameters parameters,
+ string httpClientName = "Structure1-ApiClient",
+ CancellationToken cancellationToken = default);
+}
\ No newline at end of file
diff --git a/test/Atc.Rest.ApiGenerator.CLI.Tests/Scenarios/Structure1/VerifyClient/WOPD/src/Structure1.ApiClient.Generated/Items/MyEndpoints/Interfaces/IUpdateItemEndpointResult.verified.cs b/test/Atc.Rest.ApiGenerator.CLI.Tests/Scenarios/Structure1/VerifyClient/WOPD/src/Structure1.ApiClient.Generated/Items/MyEndpoints/Interfaces/IUpdateItemEndpointResult.verified.cs
new file mode 100644
index 000000000..6ee009d6a
--- /dev/null
+++ b/test/Atc.Rest.ApiGenerator.CLI.Tests/Scenarios/Structure1/VerifyClient/WOPD/src/Structure1.ApiClient.Generated/Items/MyEndpoints/Interfaces/IUpdateItemEndpointResult.verified.cs
@@ -0,0 +1,25 @@
+//------------------------------------------------------------------------------
+// This code was auto-generated by ApiGenerator x.x.x.x.
+//
+// Changes to this file may cause incorrect behavior and will be lost if
+// the code is regenerated.
+//------------------------------------------------------------------------------
+namespace Structure1.ApiClient.Generated.Items.MyEndpoints.Interfaces;
+
+///
+/// Interface for Client Endpoint Result.
+/// Description: Updates an item.
+/// Operation: UpdateItem.
+///
+[GeneratedCode("ApiGenerator", "x.x.x.x")]
+public interface IUpdateItemEndpointResult : IEndpointResponse
+{
+
+ bool IsOk { get; }
+
+ bool IsBadRequest { get; }
+
+ Guid OkContent { get; }
+
+ string? BadRequestContent { get; }
+}
\ No newline at end of file
diff --git a/test/Atc.Rest.ApiGenerator.CLI.Tests/Scenarios/Structure1/VerifyClient/WOPD/src/Structure1.ApiClient.Generated/Items/MyEndpoints/UpdateItemEndpoint.verified.cs b/test/Atc.Rest.ApiGenerator.CLI.Tests/Scenarios/Structure1/VerifyClient/WOPD/src/Structure1.ApiClient.Generated/Items/MyEndpoints/UpdateItemEndpoint.verified.cs
new file mode 100644
index 000000000..3cc6a083d
--- /dev/null
+++ b/test/Atc.Rest.ApiGenerator.CLI.Tests/Scenarios/Structure1/VerifyClient/WOPD/src/Structure1.ApiClient.Generated/Items/MyEndpoints/UpdateItemEndpoint.verified.cs
@@ -0,0 +1,47 @@
+//------------------------------------------------------------------------------
+// This code was auto-generated by ApiGenerator x.x.x.x.
+//
+// Changes to this file may cause incorrect behavior and will be lost if
+// the code is regenerated.
+//------------------------------------------------------------------------------
+namespace Structure1.ApiClient.Generated.Items.MyEndpoints;
+
+///
+/// Client Endpoint.
+/// Description: Updates an item.
+/// Operation: UpdateItem.
+///
+[GeneratedCode("ApiGenerator", "x.x.x.x")]
+public class UpdateItemEndpoint : IUpdateItemEndpoint
+{
+ private readonly IHttpClientFactory factory;
+ private readonly IHttpMessageFactory httpMessageFactory;
+
+ public UpdateItemEndpoint(
+ IHttpClientFactory factory,
+ IHttpMessageFactory httpMessageFactory)
+ {
+ this.factory = factory;
+ this.httpMessageFactory = httpMessageFactory;
+ }
+
+ public async Task ExecuteAsync(
+ UpdateItemParameters parameters,
+ string httpClientName = "Structure1-ApiClient",
+ CancellationToken cancellationToken = default)
+ {
+ var client = factory.CreateClient(httpClientName);
+
+ var requestBuilder = httpMessageFactory.FromTemplate("/api/v1/items/{id}");
+ requestBuilder.WithPathParameter("id", parameters.Id);
+ requestBuilder.WithBody(parameters.Request);
+
+ using var requestMessage = requestBuilder.Build(HttpMethod.Put);
+ using var response = await client.SendAsync(requestMessage, cancellationToken);
+
+ var responseBuilder = httpMessageFactory.FromResponse(response);
+ responseBuilder.AddSuccessResponse(HttpStatusCode.OK);
+ responseBuilder.AddErrorResponse(HttpStatusCode.BadRequest);
+ return await responseBuilder.BuildResponseAsync(x => new UpdateItemEndpointResult(x), cancellationToken);
+ }
+}
\ No newline at end of file
diff --git a/test/Atc.Rest.ApiGenerator.CLI.Tests/Scenarios/Structure1/VerifyClient/WOPD/src/Structure1.ApiClient.Generated/Items/MyEndpoints/UpdateItemEndpointResult.verified.cs b/test/Atc.Rest.ApiGenerator.CLI.Tests/Scenarios/Structure1/VerifyClient/WOPD/src/Structure1.ApiClient.Generated/Items/MyEndpoints/UpdateItemEndpointResult.verified.cs
new file mode 100644
index 000000000..63f9cacbf
--- /dev/null
+++ b/test/Atc.Rest.ApiGenerator.CLI.Tests/Scenarios/Structure1/VerifyClient/WOPD/src/Structure1.ApiClient.Generated/Items/MyEndpoints/UpdateItemEndpointResult.verified.cs
@@ -0,0 +1,37 @@
+//------------------------------------------------------------------------------
+// This code was auto-generated by ApiGenerator x.x.x.x.
+//
+// Changes to this file may cause incorrect behavior and will be lost if
+// the code is regenerated.
+//------------------------------------------------------------------------------
+namespace Structure1.ApiClient.Generated.Items.MyEndpoints;
+
+///
+/// Client Endpoint result.
+/// Description: Updates an item.
+/// Operation: UpdateItem.
+///
+[GeneratedCode("ApiGenerator", "x.x.x.x")]
+public class UpdateItemEndpointResult : EndpointResponse, IUpdateItemEndpointResult
+{
+ public UpdateItemEndpointResult(EndpointResponse response)
+ : base(response)
+ {
+ }
+
+ public bool IsOk
+ => StatusCode == HttpStatusCode.OK;
+
+ public bool IsBadRequest
+ => StatusCode == HttpStatusCode.BadRequest;
+
+ public Guid OkContent
+ => IsOk && ContentObject is Guid result
+ ? result
+ : throw new InvalidOperationException("Content is not the expected type - please use the IsOk property first.");
+
+ public string? BadRequestContent
+ => IsBadRequest && ContentObject is string result
+ ? result
+ : throw new InvalidOperationException("Content is not the expected type - please use the IsBadRequest property first.");
+}
\ No newline at end of file
diff --git a/test/Atc.Rest.ApiGenerator.CLI.Tests/Scenarios/Structure1/VerifyClient/WOPD/src/Structure1.ApiClient.Generated/MyContracts/_EnumerationTypes/ColorType.verified.cs b/test/Atc.Rest.ApiGenerator.CLI.Tests/Scenarios/Structure1/VerifyClient/WOPD/src/Structure1.ApiClient.Generated/MyContracts/_EnumerationTypes/ColorType.verified.cs
new file mode 100644
index 000000000..2482e9d82
--- /dev/null
+++ b/test/Atc.Rest.ApiGenerator.CLI.Tests/Scenarios/Structure1/VerifyClient/WOPD/src/Structure1.ApiClient.Generated/MyContracts/_EnumerationTypes/ColorType.verified.cs
@@ -0,0 +1,21 @@
+//------------------------------------------------------------------------------
+// This code was auto-generated by ApiGenerator x.x.x.x.
+//
+// Changes to this file may cause incorrect behavior and will be lost if
+// the code is regenerated.
+//------------------------------------------------------------------------------
+namespace Structure1.ApiClient.Generated.MyContracts;
+
+///
+/// Enumeration: ColorType.
+///
+[GeneratedCode("ApiGenerator", "x.x.x.x")]
+[Flags]
+public enum ColorType
+{
+ None = 0,
+ Black = 1,
+ White = 2,
+ Yellow = 4,
+ Red = 8,
+}
\ No newline at end of file
diff --git a/test/Atc.Rest.ApiGenerator.CLI.Tests/Scenarios/Structure1/VerifyClient/WOPD/src/Structure1.ApiClient.Generated/MyContracts/_EnumerationTypes/GenderType.verified.cs b/test/Atc.Rest.ApiGenerator.CLI.Tests/Scenarios/Structure1/VerifyClient/WOPD/src/Structure1.ApiClient.Generated/MyContracts/_EnumerationTypes/GenderType.verified.cs
new file mode 100644
index 000000000..226ad596f
--- /dev/null
+++ b/test/Atc.Rest.ApiGenerator.CLI.Tests/Scenarios/Structure1/VerifyClient/WOPD/src/Structure1.ApiClient.Generated/MyContracts/_EnumerationTypes/GenderType.verified.cs
@@ -0,0 +1,19 @@
+//------------------------------------------------------------------------------
+// This code was auto-generated by ApiGenerator x.x.x.x.
+//
+// Changes to this file may cause incorrect behavior and will be lost if
+// the code is regenerated.
+//------------------------------------------------------------------------------
+namespace Structure1.ApiClient.Generated.MyContracts;
+
+///
+/// Enumeration: GenderType.
+///
+[GeneratedCode("ApiGenerator", "x.x.x.x")]
+public enum GenderType
+{
+ None,
+ NonBinary,
+ Male,
+ Female,
+}
\ No newline at end of file
diff --git a/test/Atc.Rest.ApiGenerator.CLI.Tests/Scenarios/Structure1/VerifyClient/WOPD/src/Structure1.ApiClient.Generated/MyContracts/_Shared/Address.verified.cs b/test/Atc.Rest.ApiGenerator.CLI.Tests/Scenarios/Structure1/VerifyClient/WOPD/src/Structure1.ApiClient.Generated/MyContracts/_Shared/Address.verified.cs
new file mode 100644
index 000000000..a2d705631
--- /dev/null
+++ b/test/Atc.Rest.ApiGenerator.CLI.Tests/Scenarios/Structure1/VerifyClient/WOPD/src/Structure1.ApiClient.Generated/MyContracts/_Shared/Address.verified.cs
@@ -0,0 +1,32 @@
+//------------------------------------------------------------------------------
+// This code was auto-generated by ApiGenerator x.x.x.x.
+//
+// Changes to this file may cause incorrect behavior and will be lost if
+// the code is regenerated.
+//------------------------------------------------------------------------------
+namespace Structure1.ApiClient.Generated.MyContracts;
+
+///
+/// Address.
+///
+[GeneratedCode("ApiGenerator", "x.x.x.x")]
+public class Address
+{
+ [StringLength(255)]
+ public string StreetName { get; set; }
+
+ public string StreetNumber { get; set; }
+
+ public string PostalCode { get; set; }
+
+ public string CityName { get; set; }
+
+ ///
+ /// Country.
+ ///
+ public Country MyCountry { get; set; }
+
+ ///
+ public override string ToString()
+ => $"{nameof(StreetName)}: {StreetName}, {nameof(StreetNumber)}: {StreetNumber}, {nameof(PostalCode)}: {PostalCode}, {nameof(CityName)}: {CityName}, {nameof(MyCountry)}: ({MyCountry})";
+}
\ No newline at end of file
diff --git a/test/Atc.Rest.ApiGenerator.CLI.Tests/Scenarios/Structure1/VerifyClient/WOPD/src/Structure1.ApiClient.Generated/MyContracts/_Shared/Country.verified.cs b/test/Atc.Rest.ApiGenerator.CLI.Tests/Scenarios/Structure1/VerifyClient/WOPD/src/Structure1.ApiClient.Generated/MyContracts/_Shared/Country.verified.cs
new file mode 100644
index 000000000..b26edf4df
--- /dev/null
+++ b/test/Atc.Rest.ApiGenerator.CLI.Tests/Scenarios/Structure1/VerifyClient/WOPD/src/Structure1.ApiClient.Generated/MyContracts/_Shared/Country.verified.cs
@@ -0,0 +1,33 @@
+//------------------------------------------------------------------------------
+// This code was auto-generated by ApiGenerator x.x.x.x.
+//
+// Changes to this file may cause incorrect behavior and will be lost if
+// the code is regenerated.
+//------------------------------------------------------------------------------
+namespace Structure1.ApiClient.Generated.MyContracts;
+
+///
+/// Country.
+///
+[GeneratedCode("ApiGenerator", "x.x.x.x")]
+public class Country
+{
+ [Required]
+ public string Name { get; set; }
+
+ [Required]
+ [MinLength(2)]
+ [MaxLength(2)]
+ [RegularExpression("^[A-Za-z]{2}$")]
+ public string Alpha2Code { get; set; }
+
+ [Required]
+ [MinLength(3)]
+ [MaxLength(3)]
+ [RegularExpression("^[A-Za-z]{3}$")]
+ public string Alpha3Code { get; set; }
+
+ ///
+ public override string ToString()
+ => $"{nameof(Name)}: {Name}, {nameof(Alpha2Code)}: {Alpha2Code}, {nameof(Alpha3Code)}: {Alpha3Code}";
+}
\ No newline at end of file
diff --git a/test/Atc.Rest.ApiGenerator.CLI.Tests/Scenarios/Structure1/VerifyClient/WOPD/src/Structure1.ApiClient.Generated/Orders/MyContracts/Order.verified.cs b/test/Atc.Rest.ApiGenerator.CLI.Tests/Scenarios/Structure1/VerifyClient/WOPD/src/Structure1.ApiClient.Generated/Orders/MyContracts/Order.verified.cs
new file mode 100644
index 000000000..77a20ee94
--- /dev/null
+++ b/test/Atc.Rest.ApiGenerator.CLI.Tests/Scenarios/Structure1/VerifyClient/WOPD/src/Structure1.ApiClient.Generated/Orders/MyContracts/Order.verified.cs
@@ -0,0 +1,79 @@
+//------------------------------------------------------------------------------
+// This code was auto-generated by ApiGenerator x.x.x.x.
+//
+// Changes to this file may cause incorrect behavior and will be lost if
+// the code is regenerated.
+//------------------------------------------------------------------------------
+namespace Structure1.ApiClient.Generated.Orders.MyContracts;
+
+///
+/// A single order.
+/// Hallo description with multiline and no ending dot.
+///
+[GeneratedCode("ApiGenerator", "x.x.x.x")]
+public class Order
+{
+ public Guid Id { get; set; }
+
+ public string Description { get; set; }
+
+ public DateTimeOffset MyTime { get; set; }
+
+ ///
+ /// Undefined description.
+ ///
+ ///
+ /// Email validation being enforced.
+ ///
+ [EmailAddress]
+ public string MyEmail { get; set; } = "a@a.com";
+
+ public DateTimeOffset? MyNullableDateTime { get; set; }
+
+ public DateTimeOffset MyDateTime { get; set; }
+
+ [Range(1.1, 20.2)]
+ public double MyNumber { get; set; }
+
+ [Range(int.MinValue, 50)]
+ public int MyInteger { get; set; } = 15;
+
+ ///
+ /// MyBool is great.
+ ///
+ public bool MyBool { get; set; }
+
+ ///
+ /// This is the good uri :-).
+ ///
+ ///
+ /// Url validation being enforced.
+ ///
+ [Uri]
+ public Uri MyUri { get; set; }
+
+ ///
+ /// Undefined description.
+ ///
+ ///
+ /// This string should be base64-encoded.
+ ///
+ public string MyByte { get; set; }
+
+ ///
+ /// Hallo myStringList desc :-).
+ ///
+ public List MyStringList { get; set; } = new List();
+
+ [Range(10, int.MaxValue)]
+ public long MyLong { get; set; }
+
+ ///
+ /// Address.
+ ///
+ public Address DeliveryAddress { get; set; }
+
+ ///
+ public override string ToString()
+ => $"{nameof(Id)}: {Id}, {nameof(Description)}: {Description}, {nameof(MyTime)}: ({MyTime}), {nameof(MyEmail)}: {MyEmail}, {nameof(MyNullableDateTime)}: ({MyNullableDateTime}), {nameof(MyDateTime)}: ({MyDateTime}), {nameof(MyNumber)}: {MyNumber}, {nameof(MyInteger)}: {MyInteger}, {nameof(MyBool)}: {MyBool}, {nameof(MyUri)}: ({MyUri}), {nameof(MyByte)}: {MyByte}, {nameof(MyStringList)}.Count: {MyStringList?.Count ?? 0}, {nameof(MyLong)}: {MyLong}, {nameof(DeliveryAddress)}: ({DeliveryAddress})";
+}
\ No newline at end of file
diff --git a/test/Atc.Rest.ApiGenerator.CLI.Tests/Scenarios/Structure1/VerifyClient/WOPD/src/Structure1.ApiClient.Generated/Orders/MyContracts/RequestParameters/GetOrderByIdParameters.verified.cs b/test/Atc.Rest.ApiGenerator.CLI.Tests/Scenarios/Structure1/VerifyClient/WOPD/src/Structure1.ApiClient.Generated/Orders/MyContracts/RequestParameters/GetOrderByIdParameters.verified.cs
new file mode 100644
index 000000000..9a9629ec5
--- /dev/null
+++ b/test/Atc.Rest.ApiGenerator.CLI.Tests/Scenarios/Structure1/VerifyClient/WOPD/src/Structure1.ApiClient.Generated/Orders/MyContracts/RequestParameters/GetOrderByIdParameters.verified.cs
@@ -0,0 +1,35 @@
+//------------------------------------------------------------------------------
+// This code was auto-generated by ApiGenerator x.x.x.x.
+//
+// Changes to this file may cause incorrect behavior and will be lost if
+// the code is regenerated.
+//------------------------------------------------------------------------------
+namespace Structure1.ApiClient.Generated.Orders.MyContracts;
+
+///
+/// Parameters for operation request.
+/// Description: Get order by id.
+/// Operation: GetOrderById.
+///
+[GeneratedCode("ApiGenerator", "x.x.x.x")]
+public class GetOrderByIdParameters
+{
+ ///
+ /// The id of the order.
+ ///
+ [Required]
+ public Guid Id { get; set; }
+
+ ///
+ /// The email for filter orders to retrieve.
+ ///
+ ///
+ /// Email validation being enforced.
+ ///
+ [EmailAddress]
+ public string? MyEmail { get; set; }
+
+ ///
+ public override string ToString()
+ => $"{nameof(Id)}: {Id}, {nameof(MyEmail)}: {MyEmail}";
+}
\ No newline at end of file
diff --git a/test/Atc.Rest.ApiGenerator.CLI.Tests/Scenarios/Structure1/VerifyClient/WOPD/src/Structure1.ApiClient.Generated/Orders/MyContracts/RequestParameters/GetOrdersParameters.verified.cs b/test/Atc.Rest.ApiGenerator.CLI.Tests/Scenarios/Structure1/VerifyClient/WOPD/src/Structure1.ApiClient.Generated/Orders/MyContracts/RequestParameters/GetOrdersParameters.verified.cs
new file mode 100644
index 000000000..213643daa
--- /dev/null
+++ b/test/Atc.Rest.ApiGenerator.CLI.Tests/Scenarios/Structure1/VerifyClient/WOPD/src/Structure1.ApiClient.Generated/Orders/MyContracts/RequestParameters/GetOrdersParameters.verified.cs
@@ -0,0 +1,48 @@
+//------------------------------------------------------------------------------
+// This code was auto-generated by ApiGenerator x.x.x.x.
+//
+// Changes to this file may cause incorrect behavior and will be lost if
+// the code is regenerated.
+//------------------------------------------------------------------------------
+namespace Structure1.ApiClient.Generated.Orders.MyContracts;
+
+///
+/// Parameters for operation request.
+/// Description: Get orders.
+/// Operation: GetOrders.
+///
+[GeneratedCode("ApiGenerator", "x.x.x.x")]
+public class GetOrdersParameters
+{
+ ///
+ /// The numbers of items to return.
+ ///
+ [Required]
+ [Range(1, 100)]
+ public int PageSize { get; set; } = 10;
+
+ ///
+ /// The number of items to skip before starting to collect the result set.
+ ///
+ [Range(0, 2147483647)]
+ public int PageIndex { get; set; } = 0;
+
+ ///
+ /// The query string.
+ ///
+ public string? QueryString { get; set; }
+
+ ///
+ /// The query array of string.
+ ///
+ public List QueryStringArray { get; set; } = new List();
+
+ ///
+ /// The continuation token.
+ ///
+ public string? ContinuationToken { get; set; }
+
+ ///
+ public override string ToString()
+ => $"{nameof(PageSize)}: {PageSize}, {nameof(PageIndex)}: {PageIndex}, {nameof(QueryString)}: {QueryString}, {nameof(QueryStringArray)}.Count: {QueryStringArray?.Count ?? 0}, {nameof(ContinuationToken)}: {ContinuationToken}";
+}
\ No newline at end of file
diff --git a/test/Atc.Rest.ApiGenerator.CLI.Tests/Scenarios/Structure1/VerifyClient/WOPD/src/Structure1.ApiClient.Generated/Orders/MyContracts/RequestParameters/PatchOrdersIdParameters.verified.cs b/test/Atc.Rest.ApiGenerator.CLI.Tests/Scenarios/Structure1/VerifyClient/WOPD/src/Structure1.ApiClient.Generated/Orders/MyContracts/RequestParameters/PatchOrdersIdParameters.verified.cs
new file mode 100644
index 000000000..c6d4a513c
--- /dev/null
+++ b/test/Atc.Rest.ApiGenerator.CLI.Tests/Scenarios/Structure1/VerifyClient/WOPD/src/Structure1.ApiClient.Generated/Orders/MyContracts/RequestParameters/PatchOrdersIdParameters.verified.cs
@@ -0,0 +1,56 @@
+//------------------------------------------------------------------------------
+// This code was auto-generated by ApiGenerator x.x.x.x.
+//
+// Changes to this file may cause incorrect behavior and will be lost if
+// the code is regenerated.
+//------------------------------------------------------------------------------
+namespace Structure1.ApiClient.Generated.Orders.MyContracts;
+
+///
+/// Parameters for operation request.
+/// Description: Update part of order by id.
+/// Operation: PatchOrdersId.
+///
+[GeneratedCode("ApiGenerator", "x.x.x.x")]
+public class PatchOrdersIdParameters
+{
+ ///
+ /// The id of the order.
+ ///
+ [Required]
+ public Guid Id { get; set; }
+
+ ///
+ /// The myTestHeader special key.
+ ///
+ [Required]
+ public string MyTestHeader { get; set; }
+
+ ///
+ /// The myTestHeaderBool special key.
+ ///
+ [Required]
+ public bool MyTestHeaderBool { get; set; }
+
+ ///
+ /// The myTestHeaderInt special key.
+ ///
+ [Required]
+ public int MyTestHeaderInt { get; set; }
+
+ ///
+ /// The correlationId.
+ ///
+ [Required]
+ public string CorrelationId { get; set; }
+
+ ///
+ /// Request to update an order.
+ ///
+ [Required]
+ public UpdateOrderRequest Request { get; set; }
+
+ ///
+ public override string ToString()
+ => $"{nameof(Id)}: {Id}, {nameof(MyTestHeader)}: {MyTestHeader}, {nameof(MyTestHeaderBool)}: {MyTestHeaderBool}, {nameof(MyTestHeaderInt)}: {MyTestHeaderInt}, {nameof(CorrelationId)}: {CorrelationId}, {nameof(Request)}: ({Request})";
+}
\ No newline at end of file
diff --git a/test/Atc.Rest.ApiGenerator.CLI.Tests/Scenarios/Structure1/VerifyClient/WOPD/src/Structure1.ApiClient.Generated/Orders/MyContracts/UpdateOrderRequest.verified.cs b/test/Atc.Rest.ApiGenerator.CLI.Tests/Scenarios/Structure1/VerifyClient/WOPD/src/Structure1.ApiClient.Generated/Orders/MyContracts/UpdateOrderRequest.verified.cs
new file mode 100644
index 000000000..37332d188
--- /dev/null
+++ b/test/Atc.Rest.ApiGenerator.CLI.Tests/Scenarios/Structure1/VerifyClient/WOPD/src/Structure1.ApiClient.Generated/Orders/MyContracts/UpdateOrderRequest.verified.cs
@@ -0,0 +1,28 @@
+//------------------------------------------------------------------------------
+// This code was auto-generated by ApiGenerator x.x.x.x.
+//
+// Changes to this file may cause incorrect behavior and will be lost if
+// the code is regenerated.
+//------------------------------------------------------------------------------
+namespace Structure1.ApiClient.Generated.Orders.MyContracts;
+
+///
+/// Request to update an order.
+///
+[GeneratedCode("ApiGenerator", "x.x.x.x")]
+public class UpdateOrderRequest
+{
+ ///
+ /// Undefined description.
+ ///
+ ///
+ /// Email validation being enforced.
+ ///
+ [Required]
+ [EmailAddress]
+ public string MyEmail { get; set; }
+
+ ///
+ public override string ToString()
+ => $"{nameof(MyEmail)}: {MyEmail}";
+}
\ No newline at end of file
diff --git a/test/Atc.Rest.ApiGenerator.CLI.Tests/Scenarios/Structure1/VerifyClient/WOPD/src/Structure1.ApiClient.Generated/Orders/MyEndpoints/GetOrderByIdEndpoint.verified.cs b/test/Atc.Rest.ApiGenerator.CLI.Tests/Scenarios/Structure1/VerifyClient/WOPD/src/Structure1.ApiClient.Generated/Orders/MyEndpoints/GetOrderByIdEndpoint.verified.cs
new file mode 100644
index 000000000..f71f8cf8d
--- /dev/null
+++ b/test/Atc.Rest.ApiGenerator.CLI.Tests/Scenarios/Structure1/VerifyClient/WOPD/src/Structure1.ApiClient.Generated/Orders/MyEndpoints/GetOrderByIdEndpoint.verified.cs
@@ -0,0 +1,48 @@
+//------------------------------------------------------------------------------
+// This code was auto-generated by ApiGenerator x.x.x.x.
+//
+// Changes to this file may cause incorrect behavior and will be lost if
+// the code is regenerated.
+//------------------------------------------------------------------------------
+namespace Structure1.ApiClient.Generated.Orders.MyEndpoints;
+
+///
+/// Client Endpoint.
+/// Description: Get order by id.
+/// Operation: GetOrderById.
+///
+[GeneratedCode("ApiGenerator", "x.x.x.x")]
+public class GetOrderByIdEndpoint : IGetOrderByIdEndpoint
+{
+ private readonly IHttpClientFactory factory;
+ private readonly IHttpMessageFactory httpMessageFactory;
+
+ public GetOrderByIdEndpoint(
+ IHttpClientFactory factory,
+ IHttpMessageFactory httpMessageFactory)
+ {
+ this.factory = factory;
+ this.httpMessageFactory = httpMessageFactory;
+ }
+
+ public async Task ExecuteAsync(
+ GetOrderByIdParameters parameters,
+ string httpClientName = "Structure1-ApiClient",
+ CancellationToken cancellationToken = default)
+ {
+ var client = factory.CreateClient(httpClientName);
+
+ var requestBuilder = httpMessageFactory.FromTemplate("/api/v1/orders/{id}");
+ requestBuilder.WithPathParameter("id", parameters.Id);
+ requestBuilder.WithQueryParameter("myEmail", parameters.MyEmail);
+
+ using var requestMessage = requestBuilder.Build(HttpMethod.Get);
+ using var response = await client.SendAsync(requestMessage, cancellationToken);
+
+ var responseBuilder = httpMessageFactory.FromResponse(response);
+ responseBuilder.AddSuccessResponse(HttpStatusCode.OK);
+ responseBuilder.AddErrorResponse(HttpStatusCode.BadRequest);
+ responseBuilder.AddErrorResponse(HttpStatusCode.NotFound);
+ return await responseBuilder.BuildResponseAsync(x => new GetOrderByIdEndpointResult(x), cancellationToken);
+ }
+}
\ No newline at end of file
diff --git a/test/Atc.Rest.ApiGenerator.CLI.Tests/Scenarios/Structure1/VerifyClient/WOPD/src/Structure1.ApiClient.Generated/Orders/MyEndpoints/GetOrderByIdEndpointResult.verified.cs b/test/Atc.Rest.ApiGenerator.CLI.Tests/Scenarios/Structure1/VerifyClient/WOPD/src/Structure1.ApiClient.Generated/Orders/MyEndpoints/GetOrderByIdEndpointResult.verified.cs
new file mode 100644
index 000000000..ad4c4c5e6
--- /dev/null
+++ b/test/Atc.Rest.ApiGenerator.CLI.Tests/Scenarios/Structure1/VerifyClient/WOPD/src/Structure1.ApiClient.Generated/Orders/MyEndpoints/GetOrderByIdEndpointResult.verified.cs
@@ -0,0 +1,45 @@
+//------------------------------------------------------------------------------
+// This code was auto-generated by ApiGenerator x.x.x.x.
+//
+// Changes to this file may cause incorrect behavior and will be lost if
+// the code is regenerated.
+//------------------------------------------------------------------------------
+namespace Structure1.ApiClient.Generated.Orders.MyEndpoints;
+
+///
+/// Client Endpoint result.
+/// Description: Get order by id.
+/// Operation: GetOrderById.
+///
+[GeneratedCode("ApiGenerator", "x.x.x.x")]
+public class GetOrderByIdEndpointResult : EndpointResponse, IGetOrderByIdEndpointResult
+{
+ public GetOrderByIdEndpointResult(EndpointResponse response)
+ : base(response)
+ {
+ }
+
+ public bool IsOk
+ => StatusCode == HttpStatusCode.OK;
+
+ public bool IsBadRequest
+ => StatusCode == HttpStatusCode.BadRequest;
+
+ public bool IsNotFound
+ => StatusCode == HttpStatusCode.NotFound;
+
+ public Order OkContent
+ => IsOk && ContentObject is Order result
+ ? result
+ : throw new InvalidOperationException("Content is not the expected type - please use the IsOk property first.");
+
+ public string? BadRequestContent
+ => IsBadRequest && ContentObject is string result
+ ? result
+ : throw new InvalidOperationException("Content is not the expected type - please use the IsBadRequest property first.");
+
+ public string? NotFoundContent
+ => IsNotFound && ContentObject is string result
+ ? result
+ : throw new InvalidOperationException("Content is not the expected type - please use the IsNotFound property first.");
+}
\ No newline at end of file
diff --git a/test/Atc.Rest.ApiGenerator.CLI.Tests/Scenarios/Structure1/VerifyClient/WOPD/src/Structure1.ApiClient.Generated/Orders/MyEndpoints/GetOrdersEndpoint.verified.cs b/test/Atc.Rest.ApiGenerator.CLI.Tests/Scenarios/Structure1/VerifyClient/WOPD/src/Structure1.ApiClient.Generated/Orders/MyEndpoints/GetOrdersEndpoint.verified.cs
new file mode 100644
index 000000000..5d5f5f4a9
--- /dev/null
+++ b/test/Atc.Rest.ApiGenerator.CLI.Tests/Scenarios/Structure1/VerifyClient/WOPD/src/Structure1.ApiClient.Generated/Orders/MyEndpoints/GetOrdersEndpoint.verified.cs
@@ -0,0 +1,56 @@
+//------------------------------------------------------------------------------
+// This code was auto-generated by ApiGenerator x.x.x.x.
+//
+// Changes to this file may cause incorrect behavior and will be lost if
+// the code is regenerated.
+//------------------------------------------------------------------------------
+namespace Structure1.ApiClient.Generated.Orders.MyEndpoints;
+
+///
+/// Client Endpoint.
+/// Description: Get orders.
+/// Operation: GetOrders.
+///
+[GeneratedCode("ApiGenerator", "x.x.x.x")]
+public class GetOrdersEndpoint : IGetOrdersEndpoint
+{
+ private readonly IHttpClientFactory factory;
+ private readonly IHttpMessageFactory httpMessageFactory;
+
+ public GetOrdersEndpoint(
+ IHttpClientFactory factory,
+ IHttpMessageFactory httpMessageFactory)
+ {
+ this.factory = factory;
+ this.httpMessageFactory = httpMessageFactory;
+ }
+
+ public async Task ExecuteAsync(
+ GetOrdersParameters parameters,
+ string httpClientName = "Structure1-ApiClient",
+ CancellationToken cancellationToken = default)
+ {
+ var client = factory.CreateClient(httpClientName);
+
+ var requestBuilder = httpMessageFactory.FromTemplate("/api/v1/orders");
+ requestBuilder.WithQueryParameter("pageSize", parameters.PageSize);
+ requestBuilder.WithQueryParameter("pageIndex", parameters.PageIndex);
+ requestBuilder.WithQueryParameter("queryString", parameters.QueryString);
+ if (parameters.QueryStringArray.Any())
+ {
+ requestBuilder.WithQueryParameter("queryStringArray", parameters.QueryStringArray);
+ }
+
+ requestBuilder.WithQueryParameter("continuationToken", parameters.ContinuationToken);
+
+ using var requestMessage = requestBuilder.Build(HttpMethod.Get);
+ using var response = await client.SendAsync(requestMessage, cancellationToken);
+
+ var responseBuilder = httpMessageFactory.FromResponse(response);
+ responseBuilder.AddSuccessResponse>(HttpStatusCode.OK);
+ responseBuilder.AddErrorResponse(HttpStatusCode.BadRequest);
+ responseBuilder.AddErrorResponse(HttpStatusCode.Unauthorized);
+ responseBuilder.AddErrorResponse(HttpStatusCode.NotFound);
+ return await responseBuilder.BuildResponseAsync(x => new GetOrdersEndpointResult(x), cancellationToken);
+ }
+}
\ No newline at end of file
diff --git a/test/Atc.Rest.ApiGenerator.CLI.Tests/Scenarios/Structure1/VerifyClient/WOPD/src/Structure1.ApiClient.Generated/Orders/MyEndpoints/GetOrdersEndpointResult.verified.cs b/test/Atc.Rest.ApiGenerator.CLI.Tests/Scenarios/Structure1/VerifyClient/WOPD/src/Structure1.ApiClient.Generated/Orders/MyEndpoints/GetOrdersEndpointResult.verified.cs
new file mode 100644
index 000000000..782abbcd0
--- /dev/null
+++ b/test/Atc.Rest.ApiGenerator.CLI.Tests/Scenarios/Structure1/VerifyClient/WOPD/src/Structure1.ApiClient.Generated/Orders/MyEndpoints/GetOrdersEndpointResult.verified.cs
@@ -0,0 +1,53 @@
+//------------------------------------------------------------------------------
+// This code was auto-generated by ApiGenerator x.x.x.x.
+//
+// Changes to this file may cause incorrect behavior and will be lost if
+// the code is regenerated.
+//------------------------------------------------------------------------------
+namespace Structure1.ApiClient.Generated.Orders.MyEndpoints;
+
+///
+/// Client Endpoint result.
+/// Description: Get orders.
+/// Operation: GetOrders.
+///
+[GeneratedCode("ApiGenerator", "x.x.x.x")]
+public class GetOrdersEndpointResult : EndpointResponse, IGetOrdersEndpointResult
+{
+ public GetOrdersEndpointResult(EndpointResponse response)
+ : base(response)
+ {
+ }
+
+ public bool IsOk
+ => StatusCode == HttpStatusCode.OK;
+
+ public bool IsBadRequest
+ => StatusCode == HttpStatusCode.BadRequest;
+
+ public bool IsUnauthorized
+ => StatusCode == HttpStatusCode.Unauthorized;
+
+ public bool IsNotFound
+ => StatusCode == HttpStatusCode.NotFound;
+
+ public Pagination OkContent
+ => IsOk && ContentObject is Pagination result
+ ? result
+ : throw new InvalidOperationException("Content is not the expected type - please use the IsOk property first.");
+
+ public string? BadRequestContent
+ => IsBadRequest && ContentObject is string result
+ ? result
+ : throw new InvalidOperationException("Content is not the expected type - please use the IsBadRequest property first.");
+
+ public string? UnauthorizedContent
+ => IsUnauthorized && ContentObject is string result
+ ? result
+ : throw new InvalidOperationException("Content is not the expected type - please use the IsUnauthorized property first.");
+
+ public string? NotFoundContent
+ => IsNotFound && ContentObject is string result
+ ? result
+ : throw new InvalidOperationException("Content is not the expected type - please use the IsNotFound property first.");
+}
\ No newline at end of file
diff --git a/test/Atc.Rest.ApiGenerator.CLI.Tests/Scenarios/Structure1/VerifyClient/WOPD/src/Structure1.ApiClient.Generated/Orders/MyEndpoints/Interfaces/IGetOrderByIdEndpoint.verified.cs b/test/Atc.Rest.ApiGenerator.CLI.Tests/Scenarios/Structure1/VerifyClient/WOPD/src/Structure1.ApiClient.Generated/Orders/MyEndpoints/Interfaces/IGetOrderByIdEndpoint.verified.cs
new file mode 100644
index 000000000..c763a470b
--- /dev/null
+++ b/test/Atc.Rest.ApiGenerator.CLI.Tests/Scenarios/Structure1/VerifyClient/WOPD/src/Structure1.ApiClient.Generated/Orders/MyEndpoints/Interfaces/IGetOrderByIdEndpoint.verified.cs
@@ -0,0 +1,27 @@
+//------------------------------------------------------------------------------
+// This code was auto-generated by ApiGenerator x.x.x.x.
+//
+// Changes to this file may cause incorrect behavior and will be lost if
+// the code is regenerated.
+//------------------------------------------------------------------------------
+namespace Structure1.ApiClient.Generated.Orders.MyEndpoints.Interfaces;
+
+///
+/// Interface for Client Endpoint.
+/// Description: Get order by id.
+/// Operation: GetOrderById.
+///
+[GeneratedCode("ApiGenerator", "x.x.x.x")]
+public interface IGetOrderByIdEndpoint
+{
+ ///
+ /// Execute method.
+ ///
+ /// The parameters.
+ /// The http client name.
+ /// The cancellation token.
+ Task ExecuteAsync(
+ GetOrderByIdParameters parameters,
+ string httpClientName = "Structure1-ApiClient",
+ CancellationToken cancellationToken = default);
+}
\ No newline at end of file
diff --git a/test/Atc.Rest.ApiGenerator.CLI.Tests/Scenarios/Structure1/VerifyClient/WOPD/src/Structure1.ApiClient.Generated/Orders/MyEndpoints/Interfaces/IGetOrderByIdEndpointResult.verified.cs b/test/Atc.Rest.ApiGenerator.CLI.Tests/Scenarios/Structure1/VerifyClient/WOPD/src/Structure1.ApiClient.Generated/Orders/MyEndpoints/Interfaces/IGetOrderByIdEndpointResult.verified.cs
new file mode 100644
index 000000000..a9dce734e
--- /dev/null
+++ b/test/Atc.Rest.ApiGenerator.CLI.Tests/Scenarios/Structure1/VerifyClient/WOPD/src/Structure1.ApiClient.Generated/Orders/MyEndpoints/Interfaces/IGetOrderByIdEndpointResult.verified.cs
@@ -0,0 +1,29 @@
+//------------------------------------------------------------------------------
+// This code was auto-generated by ApiGenerator x.x.x.x.
+//
+// Changes to this file may cause incorrect behavior and will be lost if
+// the code is regenerated.
+//------------------------------------------------------------------------------
+namespace Structure1.ApiClient.Generated.Orders.MyEndpoints.Interfaces;
+
+///
+/// Interface for Client Endpoint Result.
+/// Description: Get order by id.
+/// Operation: GetOrderById.
+///
+[GeneratedCode("ApiGenerator", "x.x.x.x")]
+public interface IGetOrderByIdEndpointResult : IEndpointResponse
+{
+
+ bool IsOk { get; }
+
+ bool IsBadRequest { get; }
+
+ bool IsNotFound { get; }
+
+ Order OkContent { get; }
+
+ string? BadRequestContent { get; }
+
+ string? NotFoundContent { get; }
+}
\ No newline at end of file
diff --git a/test/Atc.Rest.ApiGenerator.CLI.Tests/Scenarios/Structure1/VerifyClient/WOPD/src/Structure1.ApiClient.Generated/Orders/MyEndpoints/Interfaces/IGetOrdersEndpoint.verified.cs b/test/Atc.Rest.ApiGenerator.CLI.Tests/Scenarios/Structure1/VerifyClient/WOPD/src/Structure1.ApiClient.Generated/Orders/MyEndpoints/Interfaces/IGetOrdersEndpoint.verified.cs
new file mode 100644
index 000000000..74aa603c1
--- /dev/null
+++ b/test/Atc.Rest.ApiGenerator.CLI.Tests/Scenarios/Structure1/VerifyClient/WOPD/src/Structure1.ApiClient.Generated/Orders/MyEndpoints/Interfaces/IGetOrdersEndpoint.verified.cs
@@ -0,0 +1,27 @@
+//------------------------------------------------------------------------------
+// This code was auto-generated by ApiGenerator x.x.x.x.
+//
+// Changes to this file may cause incorrect behavior and will be lost if
+// the code is regenerated.
+//------------------------------------------------------------------------------
+namespace Structure1.ApiClient.Generated.Orders.MyEndpoints.Interfaces;
+
+///
+/// Interface for Client Endpoint.
+/// Description: Get orders.
+/// Operation: GetOrders.
+///
+[GeneratedCode("ApiGenerator", "x.x.x.x")]
+public interface IGetOrdersEndpoint
+{
+ ///
+ /// Execute method.
+ ///
+ /// The parameters.
+ /// The http client name.
+ /// The cancellation token.
+ Task ExecuteAsync(
+ GetOrdersParameters parameters,
+ string httpClientName = "Structure1-ApiClient",
+ CancellationToken cancellationToken = default);
+}
\ No newline at end of file
diff --git a/test/Atc.Rest.ApiGenerator.CLI.Tests/Scenarios/Structure1/VerifyClient/WOPD/src/Structure1.ApiClient.Generated/Orders/MyEndpoints/Interfaces/IGetOrdersEndpointResult.verified.cs b/test/Atc.Rest.ApiGenerator.CLI.Tests/Scenarios/Structure1/VerifyClient/WOPD/src/Structure1.ApiClient.Generated/Orders/MyEndpoints/Interfaces/IGetOrdersEndpointResult.verified.cs
new file mode 100644
index 000000000..e101e8f68
--- /dev/null
+++ b/test/Atc.Rest.ApiGenerator.CLI.Tests/Scenarios/Structure1/VerifyClient/WOPD/src/Structure1.ApiClient.Generated/Orders/MyEndpoints/Interfaces/IGetOrdersEndpointResult.verified.cs
@@ -0,0 +1,33 @@
+//------------------------------------------------------------------------------
+// This code was auto-generated by ApiGenerator x.x.x.x.
+//
+// Changes to this file may cause incorrect behavior and will be lost if
+// the code is regenerated.
+//------------------------------------------------------------------------------
+namespace Structure1.ApiClient.Generated.Orders.MyEndpoints.Interfaces;
+
+///
+/// Interface for Client Endpoint Result.
+/// Description: Get orders.
+/// Operation: GetOrders.
+///
+[GeneratedCode("ApiGenerator", "x.x.x.x")]
+public interface IGetOrdersEndpointResult : IEndpointResponse
+{
+
+ bool IsOk { get; }
+
+ bool IsBadRequest { get; }
+
+ bool IsUnauthorized { get; }
+
+ bool IsNotFound { get; }
+
+ Pagination OkContent { get; }
+
+ string? BadRequestContent { get; }
+
+ string? UnauthorizedContent { get; }
+
+ string? NotFoundContent { get; }
+}
\ No newline at end of file
diff --git a/test/Atc.Rest.ApiGenerator.CLI.Tests/Scenarios/Structure1/VerifyClient/WOPD/src/Structure1.ApiClient.Generated/Orders/MyEndpoints/Interfaces/IPatchOrdersIdEndpoint.verified.cs b/test/Atc.Rest.ApiGenerator.CLI.Tests/Scenarios/Structure1/VerifyClient/WOPD/src/Structure1.ApiClient.Generated/Orders/MyEndpoints/Interfaces/IPatchOrdersIdEndpoint.verified.cs
new file mode 100644
index 000000000..a359c4aa4
--- /dev/null
+++ b/test/Atc.Rest.ApiGenerator.CLI.Tests/Scenarios/Structure1/VerifyClient/WOPD/src/Structure1.ApiClient.Generated/Orders/MyEndpoints/Interfaces/IPatchOrdersIdEndpoint.verified.cs
@@ -0,0 +1,27 @@
+//------------------------------------------------------------------------------
+// This code was auto-generated by ApiGenerator x.x.x.x.
+//
+// Changes to this file may cause incorrect behavior and will be lost if
+// the code is regenerated.
+//------------------------------------------------------------------------------
+namespace Structure1.ApiClient.Generated.Orders.MyEndpoints.Interfaces;
+
+///
+/// Interface for Client Endpoint.
+/// Description: Update part of order by id.
+/// Operation: PatchOrdersId.
+///
+[GeneratedCode("ApiGenerator", "x.x.x.x")]
+public interface IPatchOrdersIdEndpoint
+{
+ ///
+ /// Execute method.
+ ///
+ /// The parameters.
+ /// The http client name.
+ /// The cancellation token.
+ Task ExecuteAsync(
+ PatchOrdersIdParameters parameters,
+ string httpClientName = "Structure1-ApiClient",
+ CancellationToken cancellationToken = default);
+}
\ No newline at end of file
diff --git a/test/Atc.Rest.ApiGenerator.CLI.Tests/Scenarios/Structure1/VerifyClient/WOPD/src/Structure1.ApiClient.Generated/Orders/MyEndpoints/Interfaces/IPatchOrdersIdEndpointResult.verified.cs b/test/Atc.Rest.ApiGenerator.CLI.Tests/Scenarios/Structure1/VerifyClient/WOPD/src/Structure1.ApiClient.Generated/Orders/MyEndpoints/Interfaces/IPatchOrdersIdEndpointResult.verified.cs
new file mode 100644
index 000000000..6ad8b26d2
--- /dev/null
+++ b/test/Atc.Rest.ApiGenerator.CLI.Tests/Scenarios/Structure1/VerifyClient/WOPD/src/Structure1.ApiClient.Generated/Orders/MyEndpoints/Interfaces/IPatchOrdersIdEndpointResult.verified.cs
@@ -0,0 +1,45 @@
+//------------------------------------------------------------------------------
+// This code was auto-generated by ApiGenerator x.x.x.x.
+//
+// Changes to this file may cause incorrect behavior and will be lost if
+// the code is regenerated.
+//------------------------------------------------------------------------------
+namespace Structure1.ApiClient.Generated.Orders.MyEndpoints.Interfaces;
+
+///
+/// Interface for Client Endpoint Result.
+/// Description: Update part of order by id.
+/// Operation: PatchOrdersId.
+///
+[GeneratedCode("ApiGenerator", "x.x.x.x")]
+public interface IPatchOrdersIdEndpointResult : IEndpointResponse
+{
+
+ bool IsOk { get; }
+
+ bool IsBadRequest { get; }
+
+ bool IsUnauthorized { get; }
+
+ bool IsForbidden { get; }
+
+ bool IsNotFound { get; }
+
+ bool IsConflict { get; }
+
+ bool IsBadGateway { get; }
+
+ string? OkContent { get; }
+
+ string? BadRequestContent { get; }
+
+ string? UnauthorizedContent { get; }
+
+ string? ForbiddenContent { get; }
+
+ string? NotFoundContent { get; }
+
+ string? ConflictContent { get; }
+
+ string? BadGatewayContent { get; }
+}
\ No newline at end of file
diff --git a/test/Atc.Rest.ApiGenerator.CLI.Tests/Scenarios/Structure1/VerifyClient/WOPD/src/Structure1.ApiClient.Generated/Orders/MyEndpoints/PatchOrdersIdEndpoint.verified.cs b/test/Atc.Rest.ApiGenerator.CLI.Tests/Scenarios/Structure1/VerifyClient/WOPD/src/Structure1.ApiClient.Generated/Orders/MyEndpoints/PatchOrdersIdEndpoint.verified.cs
new file mode 100644
index 000000000..8f35ebbff
--- /dev/null
+++ b/test/Atc.Rest.ApiGenerator.CLI.Tests/Scenarios/Structure1/VerifyClient/WOPD/src/Structure1.ApiClient.Generated/Orders/MyEndpoints/PatchOrdersIdEndpoint.verified.cs
@@ -0,0 +1,56 @@
+//------------------------------------------------------------------------------
+// This code was auto-generated by ApiGenerator x.x.x.x.
+//
+// Changes to this file may cause incorrect behavior and will be lost if
+// the code is regenerated.
+//------------------------------------------------------------------------------
+namespace Structure1.ApiClient.Generated.Orders.MyEndpoints;
+
+///
+/// Client Endpoint.
+/// Description: Update part of order by id.
+/// Operation: PatchOrdersId.
+///
+[GeneratedCode("ApiGenerator", "x.x.x.x")]
+public class PatchOrdersIdEndpoint : IPatchOrdersIdEndpoint
+{
+ private readonly IHttpClientFactory factory;
+ private readonly IHttpMessageFactory httpMessageFactory;
+
+ public PatchOrdersIdEndpoint(
+ IHttpClientFactory factory,
+ IHttpMessageFactory httpMessageFactory)
+ {
+ this.factory = factory;
+ this.httpMessageFactory = httpMessageFactory;
+ }
+
+ public async Task ExecuteAsync(
+ PatchOrdersIdParameters parameters,
+ string httpClientName = "Structure1-ApiClient",
+ CancellationToken cancellationToken = default)
+ {
+ var client = factory.CreateClient(httpClientName);
+
+ var requestBuilder = httpMessageFactory.FromTemplate("/api/v1/orders/{id}");
+ requestBuilder.WithPathParameter("id", parameters.Id);
+ requestBuilder.WithHeaderParameter("myTestHeader", parameters.MyTestHeader);
+ requestBuilder.WithHeaderParameter("myTestHeaderBool", parameters.MyTestHeaderBool);
+ requestBuilder.WithHeaderParameter("myTestHeaderInt", parameters.MyTestHeaderInt);
+ requestBuilder.WithHeaderParameter("x-correlation-id", parameters.CorrelationId);
+ requestBuilder.WithBody(parameters.Request);
+
+ using var requestMessage = requestBuilder.Build(HttpMethod.Patch);
+ using var response = await client.SendAsync(requestMessage, cancellationToken);
+
+ var responseBuilder = httpMessageFactory.FromResponse(response);
+ responseBuilder.AddSuccessResponse(HttpStatusCode.OK);
+ responseBuilder.AddErrorResponse(HttpStatusCode.BadRequest);
+ responseBuilder.AddErrorResponse(HttpStatusCode.Unauthorized);
+ responseBuilder.AddErrorResponse(HttpStatusCode.Forbidden);
+ responseBuilder.AddErrorResponse(HttpStatusCode.NotFound);
+ responseBuilder.AddErrorResponse(HttpStatusCode.Conflict);
+ responseBuilder.AddErrorResponse(HttpStatusCode.BadGateway);
+ return await responseBuilder.BuildResponseAsync(x => new PatchOrdersIdEndpointResult(x), cancellationToken);
+ }
+}
\ No newline at end of file
diff --git a/test/Atc.Rest.ApiGenerator.CLI.Tests/Scenarios/Structure1/VerifyClient/WOPD/src/Structure1.ApiClient.Generated/Orders/MyEndpoints/PatchOrdersIdEndpointResult.verified.cs b/test/Atc.Rest.ApiGenerator.CLI.Tests/Scenarios/Structure1/VerifyClient/WOPD/src/Structure1.ApiClient.Generated/Orders/MyEndpoints/PatchOrdersIdEndpointResult.verified.cs
new file mode 100644
index 000000000..efb7361b3
--- /dev/null
+++ b/test/Atc.Rest.ApiGenerator.CLI.Tests/Scenarios/Structure1/VerifyClient/WOPD/src/Structure1.ApiClient.Generated/Orders/MyEndpoints/PatchOrdersIdEndpointResult.verified.cs
@@ -0,0 +1,77 @@
+//------------------------------------------------------------------------------
+// This code was auto-generated by ApiGenerator x.x.x.x.
+//
+// Changes to this file may cause incorrect behavior and will be lost if
+// the code is regenerated.
+//------------------------------------------------------------------------------
+namespace Structure1.ApiClient.Generated.Orders.MyEndpoints;
+
+///
+/// Client Endpoint result.
+/// Description: Update part of order by id.
+/// Operation: PatchOrdersId.
+///
+[GeneratedCode("ApiGenerator", "x.x.x.x")]
+public class PatchOrdersIdEndpointResult : EndpointResponse, IPatchOrdersIdEndpointResult
+{
+ public PatchOrdersIdEndpointResult(EndpointResponse response)
+ : base(response)
+ {
+ }
+
+ public bool IsOk
+ => StatusCode == HttpStatusCode.OK;
+
+ public bool IsBadRequest
+ => StatusCode == HttpStatusCode.BadRequest;
+
+ public bool IsUnauthorized
+ => StatusCode == HttpStatusCode.Unauthorized;
+
+ public bool IsForbidden
+ => StatusCode == HttpStatusCode.Forbidden;
+
+ public bool IsNotFound
+ => StatusCode == HttpStatusCode.NotFound;
+
+ public bool IsConflict
+ => StatusCode == HttpStatusCode.Conflict;
+
+ public bool IsBadGateway
+ => StatusCode == HttpStatusCode.BadGateway;
+
+ public string? OkContent
+ => IsOk && ContentObject is string result
+ ? result
+ : throw new InvalidOperationException("Content is not the expected type - please use the IsOk property first.");
+
+ public string? BadRequestContent
+ => IsBadRequest && ContentObject is string result
+ ? result
+ : throw new InvalidOperationException("Content is not the expected type - please use the IsBadRequest property first.");
+
+ public string? UnauthorizedContent
+ => IsUnauthorized && ContentObject is string result
+ ? result
+ : throw new InvalidOperationException("Content is not the expected type - please use the IsUnauthorized property first.");
+
+ public string? ForbiddenContent
+ => IsForbidden && ContentObject is string result
+ ? result
+ : throw new InvalidOperationException("Content is not the expected type - please use the IsForbidden property first.");
+
+ public string? NotFoundContent
+ => IsNotFound && ContentObject is string result
+ ? result
+ : throw new InvalidOperationException("Content is not the expected type - please use the IsNotFound property first.");
+
+ public string? ConflictContent
+ => IsConflict && ContentObject is string result
+ ? result
+ : throw new InvalidOperationException("Content is not the expected type - please use the IsConflict property first.");
+
+ public string? BadGatewayContent
+ => IsBadGateway && ContentObject is string result
+ ? result
+ : throw new InvalidOperationException("Content is not the expected type - please use the IsBadGateway property first.");
+}
\ No newline at end of file
diff --git a/test/Atc.Rest.ApiGenerator.CLI.Tests/Scenarios/Structure1/VerifyClient/WOPD/src/Structure1.ApiClient.Generated/RouteWithDash/MyEndpoints/GetRouteWithDashEndpoint.verified.cs b/test/Atc.Rest.ApiGenerator.CLI.Tests/Scenarios/Structure1/VerifyClient/WOPD/src/Structure1.ApiClient.Generated/RouteWithDash/MyEndpoints/GetRouteWithDashEndpoint.verified.cs
new file mode 100644
index 000000000..0925058e2
--- /dev/null
+++ b/test/Atc.Rest.ApiGenerator.CLI.Tests/Scenarios/Structure1/VerifyClient/WOPD/src/Structure1.ApiClient.Generated/RouteWithDash/MyEndpoints/GetRouteWithDashEndpoint.verified.cs
@@ -0,0 +1,43 @@
+//------------------------------------------------------------------------------
+// This code was auto-generated by ApiGenerator x.x.x.x.
+//
+// Changes to this file may cause incorrect behavior and will be lost if
+// the code is regenerated.
+//------------------------------------------------------------------------------
+namespace Structure1.ApiClient.Generated.RouteWithDash.MyEndpoints;
+
+///
+/// Client Endpoint.
+/// Description: Your GET endpoint.
+/// Operation: GetRouteWithDash.
+///
+[GeneratedCode("ApiGenerator", "x.x.x.x")]
+public class GetRouteWithDashEndpoint : IGetRouteWithDashEndpoint
+{
+ private readonly IHttpClientFactory factory;
+ private readonly IHttpMessageFactory httpMessageFactory;
+
+ public GetRouteWithDashEndpoint(
+ IHttpClientFactory factory,
+ IHttpMessageFactory httpMessageFactory)
+ {
+ this.factory = factory;
+ this.httpMessageFactory = httpMessageFactory;
+ }
+
+ public async Task ExecuteAsync(
+ string httpClientName = "Structure1-ApiClient",
+ CancellationToken cancellationToken = default)
+ {
+ var client = factory.CreateClient(httpClientName);
+
+ var requestBuilder = httpMessageFactory.FromTemplate("/api/v1/route-with-dash");
+
+ using var requestMessage = requestBuilder.Build(HttpMethod.Get);
+ using var response = await client.SendAsync(requestMessage, cancellationToken);
+
+ var responseBuilder = httpMessageFactory.FromResponse(response);
+ responseBuilder.AddSuccessResponse(HttpStatusCode.OK);
+ return await responseBuilder.BuildResponseAsync(x => new GetRouteWithDashEndpointResult(x), cancellationToken);
+ }
+}
\ No newline at end of file
diff --git a/test/Atc.Rest.ApiGenerator.CLI.Tests/Scenarios/Structure1/VerifyClient/WOPD/src/Structure1.ApiClient.Generated/RouteWithDash/MyEndpoints/GetRouteWithDashEndpointResult.verified.cs b/test/Atc.Rest.ApiGenerator.CLI.Tests/Scenarios/Structure1/VerifyClient/WOPD/src/Structure1.ApiClient.Generated/RouteWithDash/MyEndpoints/GetRouteWithDashEndpointResult.verified.cs
new file mode 100644
index 000000000..067a9a553
--- /dev/null
+++ b/test/Atc.Rest.ApiGenerator.CLI.Tests/Scenarios/Structure1/VerifyClient/WOPD/src/Structure1.ApiClient.Generated/RouteWithDash/MyEndpoints/GetRouteWithDashEndpointResult.verified.cs
@@ -0,0 +1,29 @@
+//------------------------------------------------------------------------------
+// This code was auto-generated by ApiGenerator x.x.x.x.
+//
+// Changes to this file may cause incorrect behavior and will be lost if
+// the code is regenerated.
+//------------------------------------------------------------------------------
+namespace Structure1.ApiClient.Generated.RouteWithDash.MyEndpoints;
+
+///
+/// Client Endpoint result.
+/// Description: Your GET endpoint.
+/// Operation: GetRouteWithDash.
+///
+[GeneratedCode("ApiGenerator", "x.x.x.x")]
+public class GetRouteWithDashEndpointResult : EndpointResponse, IGetRouteWithDashEndpointResult
+{
+ public GetRouteWithDashEndpointResult(EndpointResponse response)
+ : base(response)
+ {
+ }
+
+ public bool IsOk
+ => StatusCode == HttpStatusCode.OK;
+
+ public string? OkContent
+ => IsOk && ContentObject is string result
+ ? result
+ : throw new InvalidOperationException("Content is not the expected type - please use the IsOk property first.");
+}
\ No newline at end of file
diff --git a/test/Atc.Rest.ApiGenerator.CLI.Tests/Scenarios/Structure1/VerifyClient/WOPD/src/Structure1.ApiClient.Generated/RouteWithDash/MyEndpoints/Interfaces/IGetRouteWithDashEndpoint.verified.cs b/test/Atc.Rest.ApiGenerator.CLI.Tests/Scenarios/Structure1/VerifyClient/WOPD/src/Structure1.ApiClient.Generated/RouteWithDash/MyEndpoints/Interfaces/IGetRouteWithDashEndpoint.verified.cs
new file mode 100644
index 000000000..31584e79f
--- /dev/null
+++ b/test/Atc.Rest.ApiGenerator.CLI.Tests/Scenarios/Structure1/VerifyClient/WOPD/src/Structure1.ApiClient.Generated/RouteWithDash/MyEndpoints/Interfaces/IGetRouteWithDashEndpoint.verified.cs
@@ -0,0 +1,25 @@
+//------------------------------------------------------------------------------
+// This code was auto-generated by ApiGenerator x.x.x.x.
+//
+// Changes to this file may cause incorrect behavior and will be lost if
+// the code is regenerated.
+//------------------------------------------------------------------------------
+namespace Structure1.ApiClient.Generated.RouteWithDash.MyEndpoints.Interfaces;
+
+///
+/// Interface for Client Endpoint.
+/// Description: Your GET endpoint.
+/// Operation: GetRouteWithDash.
+///
+[GeneratedCode("ApiGenerator", "x.x.x.x")]
+public interface IGetRouteWithDashEndpoint
+{
+ ///
+ /// Execute method.
+ ///
+ /// The http client name.
+ /// The cancellation token.
+ Task ExecuteAsync(
+ string httpClientName = "Structure1-ApiClient",
+ CancellationToken cancellationToken = default);
+}
\ No newline at end of file
diff --git a/test/Atc.Rest.ApiGenerator.CLI.Tests/Scenarios/Structure1/VerifyClient/WOPD/src/Structure1.ApiClient.Generated/RouteWithDash/MyEndpoints/Interfaces/IGetRouteWithDashEndpointResult.verified.cs b/test/Atc.Rest.ApiGenerator.CLI.Tests/Scenarios/Structure1/VerifyClient/WOPD/src/Structure1.ApiClient.Generated/RouteWithDash/MyEndpoints/Interfaces/IGetRouteWithDashEndpointResult.verified.cs
new file mode 100644
index 000000000..e3aed0783
--- /dev/null
+++ b/test/Atc.Rest.ApiGenerator.CLI.Tests/Scenarios/Structure1/VerifyClient/WOPD/src/Structure1.ApiClient.Generated/RouteWithDash/MyEndpoints/Interfaces/IGetRouteWithDashEndpointResult.verified.cs
@@ -0,0 +1,21 @@
+//------------------------------------------------------------------------------
+// This code was auto-generated by ApiGenerator x.x.x.x.
+//
+// Changes to this file may cause incorrect behavior and will be lost if
+// the code is regenerated.
+//------------------------------------------------------------------------------
+namespace Structure1.ApiClient.Generated.RouteWithDash.MyEndpoints.Interfaces;
+
+///
+/// Interface for Client Endpoint Result.
+/// Description: Your GET endpoint.
+/// Operation: GetRouteWithDash.
+///
+[GeneratedCode("ApiGenerator", "x.x.x.x")]
+public interface IGetRouteWithDashEndpointResult : IEndpointResponse
+{
+
+ bool IsOk { get; }
+
+ string? OkContent { get; }
+}
\ No newline at end of file
diff --git a/test/Atc.Rest.ApiGenerator.CLI.Tests/Scenarios/Structure1/VerifyClient/WOPD/src/Structure1.ApiClient.Generated/Tasks/MyContracts/Task.verified.cs b/test/Atc.Rest.ApiGenerator.CLI.Tests/Scenarios/Structure1/VerifyClient/WOPD/src/Structure1.ApiClient.Generated/Tasks/MyContracts/Task.verified.cs
new file mode 100644
index 000000000..521cd0c7f
--- /dev/null
+++ b/test/Atc.Rest.ApiGenerator.CLI.Tests/Scenarios/Structure1/VerifyClient/WOPD/src/Structure1.ApiClient.Generated/Tasks/MyContracts/Task.verified.cs
@@ -0,0 +1,22 @@
+//------------------------------------------------------------------------------
+// This code was auto-generated by ApiGenerator x.x.x.x.
+//
+// Changes to this file may cause incorrect behavior and will be lost if
+// the code is regenerated.
+//------------------------------------------------------------------------------
+namespace Structure1.ApiClient.Generated.Tasks.MyContracts;
+
+///
+/// Describes a single task.
+///
+[GeneratedCode("ApiGenerator", "x.x.x.x")]
+public class Task
+{
+ public Guid Id { get; set; }
+
+ public string Name { get; set; }
+
+ ///
+ public override string ToString()
+ => $"{nameof(Id)}: {Id}, {nameof(Name)}: {Name}";
+}
\ No newline at end of file
diff --git a/test/Atc.Rest.ApiGenerator.CLI.Tests/Scenarios/Structure1/VerifyClient/WOPD/src/Structure1.ApiClient.Generated/Tasks/MyContracts/Tasks.verified.cs b/test/Atc.Rest.ApiGenerator.CLI.Tests/Scenarios/Structure1/VerifyClient/WOPD/src/Structure1.ApiClient.Generated/Tasks/MyContracts/Tasks.verified.cs
new file mode 100644
index 000000000..7419a0e92
--- /dev/null
+++ b/test/Atc.Rest.ApiGenerator.CLI.Tests/Scenarios/Structure1/VerifyClient/WOPD/src/Structure1.ApiClient.Generated/Tasks/MyContracts/Tasks.verified.cs
@@ -0,0 +1,23 @@
+//------------------------------------------------------------------------------
+// This code was auto-generated by ApiGenerator x.x.x.x.
+//
+// Changes to this file may cause incorrect behavior and will be lost if
+// the code is regenerated.
+//------------------------------------------------------------------------------
+namespace Structure1.ApiClient.Generated.Tasks.MyContracts;
+
+///
+/// Contains a list of Tasks.
+///
+[GeneratedCode("ApiGenerator", "x.x.x.x")]
+public class Tasks
+{
+ ///
+ /// A list of Task.
+ ///
+ public List TaskList { get; set; } = new List();
+
+ ///
+ public override string ToString()
+ => $"{nameof(TaskList)}.Count: {TaskList?.Count ?? 0}";
+}
\ No newline at end of file
diff --git a/test/Atc.Rest.ApiGenerator.CLI.Tests/Scenarios/Structure1/VerifyClient/WOPD/src/Structure1.ApiClient.Generated/Tasks/MyEndpoints/GetTasksEndpoint.verified.cs b/test/Atc.Rest.ApiGenerator.CLI.Tests/Scenarios/Structure1/VerifyClient/WOPD/src/Structure1.ApiClient.Generated/Tasks/MyEndpoints/GetTasksEndpoint.verified.cs
new file mode 100644
index 000000000..8bd76c064
--- /dev/null
+++ b/test/Atc.Rest.ApiGenerator.CLI.Tests/Scenarios/Structure1/VerifyClient/WOPD/src/Structure1.ApiClient.Generated/Tasks/MyEndpoints/GetTasksEndpoint.verified.cs
@@ -0,0 +1,43 @@
+//------------------------------------------------------------------------------
+// This code was auto-generated by ApiGenerator x.x.x.x.
+//
+// Changes to this file may cause incorrect behavior and will be lost if
+// the code is regenerated.
+//------------------------------------------------------------------------------
+namespace Structure1.ApiClient.Generated.Tasks.MyEndpoints;
+
+///
+/// Client Endpoint.
+/// Description: Returns tasks.
+/// Operation: GetTasks.
+///
+[GeneratedCode("ApiGenerator", "x.x.x.x")]
+public class GetTasksEndpoint : IGetTasksEndpoint
+{
+ private readonly IHttpClientFactory factory;
+ private readonly IHttpMessageFactory httpMessageFactory;
+
+ public GetTasksEndpoint(
+ IHttpClientFactory factory,
+ IHttpMessageFactory httpMessageFactory)
+ {
+ this.factory = factory;
+ this.httpMessageFactory = httpMessageFactory;
+ }
+
+ public async Task ExecuteAsync(
+ string httpClientName = "Structure1-ApiClient",
+ CancellationToken cancellationToken = default)
+ {
+ var client = factory.CreateClient(httpClientName);
+
+ var requestBuilder = httpMessageFactory.FromTemplate("/api/v1/tasks");
+
+ using var requestMessage = requestBuilder.Build(HttpMethod.Get);
+ using var response = await client.SendAsync(requestMessage, cancellationToken);
+
+ var responseBuilder = httpMessageFactory.FromResponse(response);
+ responseBuilder.AddSuccessResponse>(HttpStatusCode.OK);
+ return await responseBuilder.BuildResponseAsync(x => new GetTasksEndpointResult(x), cancellationToken);
+ }
+}
\ No newline at end of file
diff --git a/test/Atc.Rest.ApiGenerator.CLI.Tests/Scenarios/Structure1/VerifyClient/WOPD/src/Structure1.ApiClient.Generated/Tasks/MyEndpoints/GetTasksEndpointResult.verified.cs b/test/Atc.Rest.ApiGenerator.CLI.Tests/Scenarios/Structure1/VerifyClient/WOPD/src/Structure1.ApiClient.Generated/Tasks/MyEndpoints/GetTasksEndpointResult.verified.cs
new file mode 100644
index 000000000..cf0ce55c9
--- /dev/null
+++ b/test/Atc.Rest.ApiGenerator.CLI.Tests/Scenarios/Structure1/VerifyClient/WOPD/src/Structure1.ApiClient.Generated/Tasks/MyEndpoints/GetTasksEndpointResult.verified.cs
@@ -0,0 +1,29 @@
+//------------------------------------------------------------------------------
+// This code was auto-generated by ApiGenerator x.x.x.x.
+//
+// Changes to this file may cause incorrect behavior and will be lost if
+// the code is regenerated.
+//------------------------------------------------------------------------------
+namespace Structure1.ApiClient.Generated.Tasks.MyEndpoints;
+
+///
+/// Client Endpoint result.
+/// Description: Returns tasks.
+/// Operation: GetTasks.
+///
+[GeneratedCode("ApiGenerator", "x.x.x.x")]
+public class GetTasksEndpointResult : EndpointResponse, IGetTasksEndpointResult
+{
+ public GetTasksEndpointResult(EndpointResponse response)
+ : base(response)
+ {
+ }
+
+ public bool IsOk
+ => StatusCode == HttpStatusCode.OK;
+
+ public IEnumerable OkContent
+ => IsOk && ContentObject is IEnumerable result
+ ? result
+ : throw new InvalidOperationException("Content is not the expected type - please use the IsOk property first.");
+}
\ No newline at end of file
diff --git a/test/Atc.Rest.ApiGenerator.CLI.Tests/Scenarios/Structure1/VerifyClient/WOPD/src/Structure1.ApiClient.Generated/Tasks/MyEndpoints/Interfaces/IGetTasksEndpoint.verified.cs b/test/Atc.Rest.ApiGenerator.CLI.Tests/Scenarios/Structure1/VerifyClient/WOPD/src/Structure1.ApiClient.Generated/Tasks/MyEndpoints/Interfaces/IGetTasksEndpoint.verified.cs
new file mode 100644
index 000000000..35f486eed
--- /dev/null
+++ b/test/Atc.Rest.ApiGenerator.CLI.Tests/Scenarios/Structure1/VerifyClient/WOPD/src/Structure1.ApiClient.Generated/Tasks/MyEndpoints/Interfaces/IGetTasksEndpoint.verified.cs
@@ -0,0 +1,25 @@
+//------------------------------------------------------------------------------
+// This code was auto-generated by ApiGenerator x.x.x.x.
+//
+// Changes to this file may cause incorrect behavior and will be lost if
+// the code is regenerated.
+//------------------------------------------------------------------------------
+namespace Structure1.ApiClient.Generated.Tasks.MyEndpoints.Interfaces;
+
+///
+/// Interface for Client Endpoint.
+/// Description: Returns tasks.
+/// Operation: GetTasks.
+///
+[GeneratedCode("ApiGenerator", "x.x.x.x")]
+public interface IGetTasksEndpoint
+{
+ ///
+ /// Execute method.
+ ///
+ /// The http client name.
+ /// The cancellation token.
+ Task ExecuteAsync(
+ string httpClientName = "Structure1-ApiClient",
+ CancellationToken cancellationToken = default);
+}
\ No newline at end of file
diff --git a/test/Atc.Rest.ApiGenerator.CLI.Tests/Scenarios/Structure1/VerifyClient/WOPD/src/Structure1.ApiClient.Generated/Tasks/MyEndpoints/Interfaces/IGetTasksEndpointResult.verified.cs b/test/Atc.Rest.ApiGenerator.CLI.Tests/Scenarios/Structure1/VerifyClient/WOPD/src/Structure1.ApiClient.Generated/Tasks/MyEndpoints/Interfaces/IGetTasksEndpointResult.verified.cs
new file mode 100644
index 000000000..c04e1849a
--- /dev/null
+++ b/test/Atc.Rest.ApiGenerator.CLI.Tests/Scenarios/Structure1/VerifyClient/WOPD/src/Structure1.ApiClient.Generated/Tasks/MyEndpoints/Interfaces/IGetTasksEndpointResult.verified.cs
@@ -0,0 +1,21 @@
+//------------------------------------------------------------------------------
+// This code was auto-generated by ApiGenerator x.x.x.x.
+//
+// Changes to this file may cause incorrect behavior and will be lost if
+// the code is regenerated.
+//------------------------------------------------------------------------------
+namespace Structure1.ApiClient.Generated.Tasks.MyEndpoints.Interfaces;
+
+///
+/// Interface for Client Endpoint Result.
+/// Description: Returns tasks.
+/// Operation: GetTasks.
+///
+[GeneratedCode("ApiGenerator", "x.x.x.x")]
+public interface IGetTasksEndpointResult : IEndpointResponse
+{
+
+ bool IsOk { get; }
+
+ IEnumerable OkContent { get; }
+}
\ No newline at end of file
diff --git a/test/Atc.Rest.ApiGenerator.CLI.Tests/Scenarios/Structure1/VerifyClient/WOPD/src/Structure1.ApiClient.Generated/Users/MyContracts/CreateUserRequest.verified.cs b/test/Atc.Rest.ApiGenerator.CLI.Tests/Scenarios/Structure1/VerifyClient/WOPD/src/Structure1.ApiClient.Generated/Users/MyContracts/CreateUserRequest.verified.cs
new file mode 100644
index 000000000..0fb28fc4a
--- /dev/null
+++ b/test/Atc.Rest.ApiGenerator.CLI.Tests/Scenarios/Structure1/VerifyClient/WOPD/src/Structure1.ApiClient.Generated/Users/MyContracts/CreateUserRequest.verified.cs
@@ -0,0 +1,65 @@
+//------------------------------------------------------------------------------
+// This code was auto-generated by ApiGenerator x.x.x.x.
+//
+// Changes to this file may cause incorrect behavior and will be lost if
+// the code is regenerated.
+//------------------------------------------------------------------------------
+namespace Structure1.ApiClient.Generated.Users.MyContracts;
+
+///
+/// Request to create a user.
+///
+[GeneratedCode("ApiGenerator", "x.x.x.x")]
+public class CreateUserRequest
+{
+ [Required]
+ public string FirstName { get; set; }
+
+ [Required]
+ public string LastName { get; set; }
+
+ public DateTimeOffset? MyNullableDateTime { get; set; }
+
+ [Required]
+ public DateTimeOffset MyDateTime { get; set; }
+
+ ///
+ /// Undefined description.
+ ///
+ ///
+ /// Email validation being enforced.
+ ///
+ [Required]
+ [EmailAddress]
+ public string Email { get; set; }
+
+ ///
+ /// Undefined description.
+ ///
+ ///
+ /// Url validation being enforced.
+ ///
+ [Uri]
+ public Uri Homepage { get; set; }
+
+ ///
+ /// GenderType.
+ ///
+ [Required]
+ public GenderType Gender { get; set; }
+
+ public Address? MyNullableAddress { get; set; }
+
+ [Required]
+ public Dictionary Tags { get; set; }
+
+ public Dictionary DesiredProperties1 { get; set; }
+
+ public Dictionary? DesiredProperties2 { get; set; }
+
+ public Dictionary? DesiredProperties3 { get; set; }
+
+ ///
+ public override string ToString()
+ => $"{nameof(FirstName)}: {FirstName}, {nameof(LastName)}: {LastName}, {nameof(MyNullableDateTime)}: ({MyNullableDateTime}), {nameof(MyDateTime)}: ({MyDateTime}), {nameof(Email)}: {Email}, {nameof(Homepage)}: ({Homepage}), {nameof(Gender)}: {Gender}, {nameof(MyNullableAddress)}: ({MyNullableAddress}), {nameof(Tags)}: ({Tags}), {nameof(DesiredProperties1)}: ({DesiredProperties1}), {nameof(DesiredProperties2)}: ({DesiredProperties2}), {nameof(DesiredProperties3)}: ({DesiredProperties3})";
+}
\ No newline at end of file
diff --git a/test/Atc.Rest.ApiGenerator.CLI.Tests/Scenarios/Structure1/VerifyClient/WOPD/src/Structure1.ApiClient.Generated/Users/MyContracts/RequestParameters/DeleteUserByIdParameters.verified.cs b/test/Atc.Rest.ApiGenerator.CLI.Tests/Scenarios/Structure1/VerifyClient/WOPD/src/Structure1.ApiClient.Generated/Users/MyContracts/RequestParameters/DeleteUserByIdParameters.verified.cs
new file mode 100644
index 000000000..896c27c0b
--- /dev/null
+++ b/test/Atc.Rest.ApiGenerator.CLI.Tests/Scenarios/Structure1/VerifyClient/WOPD/src/Structure1.ApiClient.Generated/Users/MyContracts/RequestParameters/DeleteUserByIdParameters.verified.cs
@@ -0,0 +1,26 @@
+//------------------------------------------------------------------------------
+// This code was auto-generated by ApiGenerator x.x.x.x.
+//
+// Changes to this file may cause incorrect behavior and will be lost if
+// the code is regenerated.
+//------------------------------------------------------------------------------
+namespace Structure1.ApiClient.Generated.Users.MyContracts;
+
+///
+/// Parameters for operation request.
+/// Description: Delete user by id.
+/// Operation: DeleteUserById.
+///
+[GeneratedCode("ApiGenerator", "x.x.x.x")]
+public class DeleteUserByIdParameters
+{
+ ///
+ /// Id of the user.
+ ///
+ [Required]
+ public Guid Id { get; set; }
+
+ ///
+ public override string ToString()
+ => $"{nameof(Id)}: {Id}";
+}
\ No newline at end of file
diff --git a/test/Atc.Rest.ApiGenerator.CLI.Tests/Scenarios/Structure1/VerifyClient/WOPD/src/Structure1.ApiClient.Generated/Users/MyContracts/RequestParameters/GetUserByEmailParameters.verified.cs b/test/Atc.Rest.ApiGenerator.CLI.Tests/Scenarios/Structure1/VerifyClient/WOPD/src/Structure1.ApiClient.Generated/Users/MyContracts/RequestParameters/GetUserByEmailParameters.verified.cs
new file mode 100644
index 000000000..2ad1823cb
--- /dev/null
+++ b/test/Atc.Rest.ApiGenerator.CLI.Tests/Scenarios/Structure1/VerifyClient/WOPD/src/Structure1.ApiClient.Generated/Users/MyContracts/RequestParameters/GetUserByEmailParameters.verified.cs
@@ -0,0 +1,30 @@
+//------------------------------------------------------------------------------
+// This code was auto-generated by ApiGenerator x.x.x.x.
+//
+// Changes to this file may cause incorrect behavior and will be lost if
+// the code is regenerated.
+//------------------------------------------------------------------------------
+namespace Structure1.ApiClient.Generated.Users.MyContracts;
+
+///
+/// Parameters for operation request.
+/// Description: Get user by email.
+/// Operation: GetUserByEmail.
+///
+[GeneratedCode("ApiGenerator", "x.x.x.x")]
+public class GetUserByEmailParameters
+{
+ ///
+ /// The email of the user to retrieve.
+ ///
+ ///
+ /// Email validation being enforced.
+ ///
+ [Required]
+ [EmailAddress]
+ public string Email { get; set; }
+
+ ///
+ public override string ToString()
+ => $"{nameof(Email)}: {Email}";
+}
\ No newline at end of file
diff --git a/test/Atc.Rest.ApiGenerator.CLI.Tests/Scenarios/Structure1/VerifyClient/WOPD/src/Structure1.ApiClient.Generated/Users/MyContracts/RequestParameters/GetUserByIdParameters.verified.cs b/test/Atc.Rest.ApiGenerator.CLI.Tests/Scenarios/Structure1/VerifyClient/WOPD/src/Structure1.ApiClient.Generated/Users/MyContracts/RequestParameters/GetUserByIdParameters.verified.cs
new file mode 100644
index 000000000..8717fdb20
--- /dev/null
+++ b/test/Atc.Rest.ApiGenerator.CLI.Tests/Scenarios/Structure1/VerifyClient/WOPD/src/Structure1.ApiClient.Generated/Users/MyContracts/RequestParameters/GetUserByIdParameters.verified.cs
@@ -0,0 +1,26 @@
+//------------------------------------------------------------------------------
+// This code was auto-generated by ApiGenerator x.x.x.x.
+//
+// Changes to this file may cause incorrect behavior and will be lost if
+// the code is regenerated.
+//------------------------------------------------------------------------------
+namespace Structure1.ApiClient.Generated.Users.MyContracts;
+
+///
+/// Parameters for operation request.
+/// Description: Get user by id.
+/// Operation: GetUserById.
+///
+[GeneratedCode("ApiGenerator", "x.x.x.x")]
+public class GetUserByIdParameters
+{
+ ///
+ /// Id of the user.
+ ///
+ [Required]
+ public Guid Id { get; set; }
+
+ ///
+ public override string ToString()
+ => $"{nameof(Id)}: {Id}";
+}
\ No newline at end of file
diff --git a/test/Atc.Rest.ApiGenerator.CLI.Tests/Scenarios/Structure1/VerifyClient/WOPD/src/Structure1.ApiClient.Generated/Users/MyContracts/RequestParameters/PostUserParameters.verified.cs b/test/Atc.Rest.ApiGenerator.CLI.Tests/Scenarios/Structure1/VerifyClient/WOPD/src/Structure1.ApiClient.Generated/Users/MyContracts/RequestParameters/PostUserParameters.verified.cs
new file mode 100644
index 000000000..0a6b35b46
--- /dev/null
+++ b/test/Atc.Rest.ApiGenerator.CLI.Tests/Scenarios/Structure1/VerifyClient/WOPD/src/Structure1.ApiClient.Generated/Users/MyContracts/RequestParameters/PostUserParameters.verified.cs
@@ -0,0 +1,26 @@
+//------------------------------------------------------------------------------
+// This code was auto-generated by ApiGenerator x.x.x.x.
+//
+// Changes to this file may cause incorrect behavior and will be lost if
+// the code is regenerated.
+//------------------------------------------------------------------------------
+namespace Structure1.ApiClient.Generated.Users.MyContracts;
+
+///
+/// Parameters for operation request.
+/// Description: Create a new user.
+/// Operation: PostUser.
+///
+[GeneratedCode("ApiGenerator", "x.x.x.x")]
+public class PostUserParameters
+{
+ ///
+ /// Request to create a user.
+ ///
+ [Required]
+ public CreateUserRequest Request { get; set; }
+
+ ///
+ public override string ToString()
+ => $"{nameof(Request)}: ({Request})";
+}
\ No newline at end of file
diff --git a/test/Atc.Rest.ApiGenerator.CLI.Tests/Scenarios/Structure1/VerifyClient/WOPD/src/Structure1.ApiClient.Generated/Users/MyContracts/RequestParameters/UpdateMyTestGenderParameters.verified.cs b/test/Atc.Rest.ApiGenerator.CLI.Tests/Scenarios/Structure1/VerifyClient/WOPD/src/Structure1.ApiClient.Generated/Users/MyContracts/RequestParameters/UpdateMyTestGenderParameters.verified.cs
new file mode 100644
index 000000000..78e0deb99
--- /dev/null
+++ b/test/Atc.Rest.ApiGenerator.CLI.Tests/Scenarios/Structure1/VerifyClient/WOPD/src/Structure1.ApiClient.Generated/Users/MyContracts/RequestParameters/UpdateMyTestGenderParameters.verified.cs
@@ -0,0 +1,37 @@
+//------------------------------------------------------------------------------
+// This code was auto-generated by ApiGenerator x.x.x.x.
+//
+// Changes to this file may cause incorrect behavior and will be lost if
+// the code is regenerated.
+//------------------------------------------------------------------------------
+namespace Structure1.ApiClient.Generated.Users.MyContracts;
+
+///
+/// Parameters for operation request.
+/// Description: Update gender on a user.
+/// Operation: UpdateMyTestGender.
+///
+[GeneratedCode("ApiGenerator", "x.x.x.x")]
+public class UpdateMyTestGenderParameters
+{
+ ///
+ /// Id of the user.
+ ///
+ [Required]
+ public Guid Id { get; set; }
+
+ ///
+ /// The gender to set on the user.
+ ///
+ public GenderType? GenderParam { get; set; }
+
+ ///
+ /// Update test-gender Request.
+ ///
+ [Required]
+ public UpdateTestGenderRequest Request { get; set; }
+
+ ///
+ public override string ToString()
+ => $"{nameof(Id)}: {Id}, {nameof(GenderParam)}: {GenderParam}, {nameof(Request)}: ({Request})";
+}
\ No newline at end of file
diff --git a/test/Atc.Rest.ApiGenerator.CLI.Tests/Scenarios/Structure1/VerifyClient/WOPD/src/Structure1.ApiClient.Generated/Users/MyContracts/RequestParameters/UpdateUserByIdParameters.verified.cs b/test/Atc.Rest.ApiGenerator.CLI.Tests/Scenarios/Structure1/VerifyClient/WOPD/src/Structure1.ApiClient.Generated/Users/MyContracts/RequestParameters/UpdateUserByIdParameters.verified.cs
new file mode 100644
index 000000000..4a0e55b3f
--- /dev/null
+++ b/test/Atc.Rest.ApiGenerator.CLI.Tests/Scenarios/Structure1/VerifyClient/WOPD/src/Structure1.ApiClient.Generated/Users/MyContracts/RequestParameters/UpdateUserByIdParameters.verified.cs
@@ -0,0 +1,32 @@
+//------------------------------------------------------------------------------
+// This code was auto-generated by ApiGenerator x.x.x.x.
+//
+// Changes to this file may cause incorrect behavior and will be lost if
+// the code is regenerated.
+//------------------------------------------------------------------------------
+namespace Structure1.ApiClient.Generated.Users.MyContracts;
+
+///
+/// Parameters for operation request.
+/// Description: Update user by id.
+/// Operation: UpdateUserById.
+///
+[GeneratedCode("ApiGenerator", "x.x.x.x")]
+public class UpdateUserByIdParameters
+{
+ ///
+ /// Id of the user.
+ ///
+ [Required]
+ public Guid Id { get; set; }
+
+ ///
+ /// Request to update a user.
+ ///
+ [Required]
+ public UpdateUserRequest Request { get; set; }
+
+ ///
+ public override string ToString()
+ => $"{nameof(Id)}: {Id}, {nameof(Request)}: ({Request})";
+}
\ No newline at end of file
diff --git a/test/Atc.Rest.ApiGenerator.CLI.Tests/Scenarios/Structure1/VerifyClient/WOPD/src/Structure1.ApiClient.Generated/Users/MyContracts/UpdateTestGenderRequest.verified.cs b/test/Atc.Rest.ApiGenerator.CLI.Tests/Scenarios/Structure1/VerifyClient/WOPD/src/Structure1.ApiClient.Generated/Users/MyContracts/UpdateTestGenderRequest.verified.cs
new file mode 100644
index 000000000..b063a57e9
--- /dev/null
+++ b/test/Atc.Rest.ApiGenerator.CLI.Tests/Scenarios/Structure1/VerifyClient/WOPD/src/Structure1.ApiClient.Generated/Users/MyContracts/UpdateTestGenderRequest.verified.cs
@@ -0,0 +1,23 @@
+//------------------------------------------------------------------------------
+// This code was auto-generated by ApiGenerator x.x.x.x.
+//
+// Changes to this file may cause incorrect behavior and will be lost if
+// the code is regenerated.
+//------------------------------------------------------------------------------
+namespace Structure1.ApiClient.Generated.Users.MyContracts;
+
+///
+/// Update test-gender Request.
+///
+[GeneratedCode("ApiGenerator", "x.x.x.x")]
+public class UpdateTestGenderRequest
+{
+ ///
+ /// GenderType.
+ ///
+ public GenderType Gender { get; set; }
+
+ ///
+ public override string ToString()
+ => $"{nameof(Gender)}: {Gender}";
+}
\ No newline at end of file
diff --git a/test/Atc.Rest.ApiGenerator.CLI.Tests/Scenarios/Structure1/VerifyClient/WOPD/src/Structure1.ApiClient.Generated/Users/MyContracts/UpdateUserRequest.verified.cs b/test/Atc.Rest.ApiGenerator.CLI.Tests/Scenarios/Structure1/VerifyClient/WOPD/src/Structure1.ApiClient.Generated/Users/MyContracts/UpdateUserRequest.verified.cs
new file mode 100644
index 000000000..318242b8c
--- /dev/null
+++ b/test/Atc.Rest.ApiGenerator.CLI.Tests/Scenarios/Structure1/VerifyClient/WOPD/src/Structure1.ApiClient.Generated/Users/MyContracts/UpdateUserRequest.verified.cs
@@ -0,0 +1,36 @@
+//------------------------------------------------------------------------------
+// This code was auto-generated by ApiGenerator x.x.x.x.
+//
+// Changes to this file may cause incorrect behavior and will be lost if
+// the code is regenerated.
+//------------------------------------------------------------------------------
+namespace Structure1.ApiClient.Generated.Users.MyContracts;
+
+///
+/// Request to update a user.
+///
+[GeneratedCode("ApiGenerator", "x.x.x.x")]
+public class UpdateUserRequest
+{
+ public string FirstName { get; set; }
+
+ public string LastName { get; set; }
+
+ ///
+ /// Undefined description.
+ ///
+ ///
+ /// Email validation being enforced.
+ ///
+ [EmailAddress]
+ public string Email { get; set; }
+
+ ///
+ /// GenderType.
+ ///
+ public GenderType Gender { get; set; }
+
+ ///
+ public override string ToString()
+ => $"{nameof(FirstName)}: {FirstName}, {nameof(LastName)}: {LastName}, {nameof(Email)}: {Email}, {nameof(Gender)}: {Gender}";
+}
\ No newline at end of file
diff --git a/test/Atc.Rest.ApiGenerator.CLI.Tests/Scenarios/Structure1/VerifyClient/WOPD/src/Structure1.ApiClient.Generated/Users/MyContracts/User.verified.cs b/test/Atc.Rest.ApiGenerator.CLI.Tests/Scenarios/Structure1/VerifyClient/WOPD/src/Structure1.ApiClient.Generated/Users/MyContracts/User.verified.cs
new file mode 100644
index 000000000..54e44db1f
--- /dev/null
+++ b/test/Atc.Rest.ApiGenerator.CLI.Tests/Scenarios/Structure1/VerifyClient/WOPD/src/Structure1.ApiClient.Generated/Users/MyContracts/User.verified.cs
@@ -0,0 +1,62 @@
+//------------------------------------------------------------------------------
+// This code was auto-generated by ApiGenerator x.x.x.x.
+//
+// Changes to this file may cause incorrect behavior and will be lost if
+// the code is regenerated.
+//------------------------------------------------------------------------------
+namespace Structure1.ApiClient.Generated.Users.MyContracts;
+
+///
+/// A single user.
+///
+[GeneratedCode("ApiGenerator", "x.x.x.x")]
+public class User
+{
+ public Guid Id { get; set; }
+
+ ///
+ /// GenderType.
+ ///
+ public GenderType Gender { get; set; }
+
+ public string FirstName { get; set; }
+
+ public string LastName { get; set; }
+
+ ///
+ /// Undefined description.
+ ///
+ ///
+ /// Email validation being enforced.
+ ///
+ [EmailAddress]
+ public string Email { get; set; }
+
+ ///
+ /// Undefined description.
+ ///
+ ///
+ /// Url validation being enforced.
+ ///
+ [Uri]
+ public Uri Homepage { get; set; }
+
+ ///
+ /// ColorType.
+ ///
+ public ColorType Color { get; set; }
+
+ ///
+ /// Address.
+ ///
+ public Address HomeAddress { get; set; }
+
+ ///
+ /// Address.
+ ///
+ public Address CompanyAddress { get; set; }
+
+ ///
+ public override string ToString()
+ => $"{nameof(Id)}: {Id}, {nameof(Gender)}: {Gender}, {nameof(FirstName)}: {FirstName}, {nameof(LastName)}: {LastName}, {nameof(Email)}: {Email}, {nameof(Homepage)}: ({Homepage}), {nameof(Color)}: {Color}, {nameof(HomeAddress)}: ({HomeAddress}), {nameof(CompanyAddress)}: ({CompanyAddress})";
+}
\ No newline at end of file
diff --git a/test/Atc.Rest.ApiGenerator.CLI.Tests/Scenarios/Structure1/VerifyClient/WOPD/src/Structure1.ApiClient.Generated/Users/MyContracts/Users.verified.cs b/test/Atc.Rest.ApiGenerator.CLI.Tests/Scenarios/Structure1/VerifyClient/WOPD/src/Structure1.ApiClient.Generated/Users/MyContracts/Users.verified.cs
new file mode 100644
index 000000000..1373864d4
--- /dev/null
+++ b/test/Atc.Rest.ApiGenerator.CLI.Tests/Scenarios/Structure1/VerifyClient/WOPD/src/Structure1.ApiClient.Generated/Users/MyContracts/Users.verified.cs
@@ -0,0 +1,23 @@
+//------------------------------------------------------------------------------
+// This code was auto-generated by ApiGenerator x.x.x.x.
+//
+// Changes to this file may cause incorrect behavior and will be lost if
+// the code is regenerated.
+//------------------------------------------------------------------------------
+namespace Structure1.ApiClient.Generated.Users.MyContracts;
+
+///
+/// A list of users.
+///
+[GeneratedCode("ApiGenerator", "x.x.x.x")]
+public class Users
+{
+ ///
+ /// A list of User.
+ ///
+ public List UserList { get; set; } = new List();
+
+ ///
+ public override string ToString()
+ => $"{nameof(UserList)}.Count: {UserList?.Count ?? 0}";
+}
\ No newline at end of file
diff --git a/test/Atc.Rest.ApiGenerator.CLI.Tests/Scenarios/Structure1/VerifyClient/WOPD/src/Structure1.ApiClient.Generated/Users/MyEndpoints/DeleteUserByIdEndpoint.verified.cs b/test/Atc.Rest.ApiGenerator.CLI.Tests/Scenarios/Structure1/VerifyClient/WOPD/src/Structure1.ApiClient.Generated/Users/MyEndpoints/DeleteUserByIdEndpoint.verified.cs
new file mode 100644
index 000000000..c6da344e4
--- /dev/null
+++ b/test/Atc.Rest.ApiGenerator.CLI.Tests/Scenarios/Structure1/VerifyClient/WOPD/src/Structure1.ApiClient.Generated/Users/MyEndpoints/DeleteUserByIdEndpoint.verified.cs
@@ -0,0 +1,48 @@
+//------------------------------------------------------------------------------
+// This code was auto-generated by ApiGenerator x.x.x.x.
+//
+// Changes to this file may cause incorrect behavior and will be lost if
+// the code is regenerated.
+//------------------------------------------------------------------------------
+namespace Structure1.ApiClient.Generated.Users.MyEndpoints;
+
+///
+/// Client Endpoint.
+/// Description: Delete user by id.
+/// Operation: DeleteUserById.
+///
+[GeneratedCode("ApiGenerator", "x.x.x.x")]
+public class DeleteUserByIdEndpoint : IDeleteUserByIdEndpoint
+{
+ private readonly IHttpClientFactory factory;
+ private readonly IHttpMessageFactory httpMessageFactory;
+
+ public DeleteUserByIdEndpoint(
+ IHttpClientFactory factory,
+ IHttpMessageFactory httpMessageFactory)
+ {
+ this.factory = factory;
+ this.httpMessageFactory = httpMessageFactory;
+ }
+
+ public async Task ExecuteAsync(
+ DeleteUserByIdParameters parameters,
+ string httpClientName = "Structure1-ApiClient",
+ CancellationToken cancellationToken = default)
+ {
+ var client = factory.CreateClient(httpClientName);
+
+ var requestBuilder = httpMessageFactory.FromTemplate("/api/v1/users/{id}");
+ requestBuilder.WithPathParameter("id", parameters.Id);
+
+ using var requestMessage = requestBuilder.Build(HttpMethod.Delete);
+ using var response = await client.SendAsync(requestMessage, cancellationToken);
+
+ var responseBuilder = httpMessageFactory.FromResponse(response);
+ responseBuilder.AddSuccessResponse(HttpStatusCode.OK);
+ responseBuilder.AddErrorResponse(HttpStatusCode.BadRequest);
+ responseBuilder.AddErrorResponse(HttpStatusCode.NotFound);
+ responseBuilder.AddErrorResponse(HttpStatusCode.Conflict);
+ return await responseBuilder.BuildResponseAsync(x => new DeleteUserByIdEndpointResult(x), cancellationToken);
+ }
+}
\ No newline at end of file
diff --git a/test/Atc.Rest.ApiGenerator.CLI.Tests/Scenarios/Structure1/VerifyClient/WOPD/src/Structure1.ApiClient.Generated/Users/MyEndpoints/DeleteUserByIdEndpointResult.verified.cs b/test/Atc.Rest.ApiGenerator.CLI.Tests/Scenarios/Structure1/VerifyClient/WOPD/src/Structure1.ApiClient.Generated/Users/MyEndpoints/DeleteUserByIdEndpointResult.verified.cs
new file mode 100644
index 000000000..09baa86e8
--- /dev/null
+++ b/test/Atc.Rest.ApiGenerator.CLI.Tests/Scenarios/Structure1/VerifyClient/WOPD/src/Structure1.ApiClient.Generated/Users/MyEndpoints/DeleteUserByIdEndpointResult.verified.cs
@@ -0,0 +1,53 @@
+//------------------------------------------------------------------------------
+// This code was auto-generated by ApiGenerator x.x.x.x.
+//
+// Changes to this file may cause incorrect behavior and will be lost if
+// the code is regenerated.
+//------------------------------------------------------------------------------
+namespace Structure1.ApiClient.Generated.Users.MyEndpoints;
+
+///
+/// Client Endpoint result.
+/// Description: Delete user by id.
+/// Operation: DeleteUserById.
+///
+[GeneratedCode("ApiGenerator", "x.x.x.x")]
+public class DeleteUserByIdEndpointResult : EndpointResponse, IDeleteUserByIdEndpointResult
+{
+ public DeleteUserByIdEndpointResult(EndpointResponse response)
+ : base(response)
+ {
+ }
+
+ public bool IsOk
+ => StatusCode == HttpStatusCode.OK;
+
+ public bool IsBadRequest
+ => StatusCode == HttpStatusCode.BadRequest;
+
+ public bool IsNotFound
+ => StatusCode == HttpStatusCode.NotFound;
+
+ public bool IsConflict
+ => StatusCode == HttpStatusCode.Conflict;
+
+ public string? OkContent
+ => IsOk && ContentObject is string result
+ ? result
+ : throw new InvalidOperationException("Content is not the expected type - please use the IsOk property first.");
+
+ public string? BadRequestContent
+ => IsBadRequest && ContentObject is string result
+ ? result
+ : throw new InvalidOperationException("Content is not the expected type - please use the IsBadRequest property first.");
+
+ public string? NotFoundContent
+ => IsNotFound && ContentObject is string result
+ ? result
+ : throw new InvalidOperationException("Content is not the expected type - please use the IsNotFound property first.");
+
+ public string? ConflictContent
+ => IsConflict && ContentObject is string result
+ ? result
+ : throw new InvalidOperationException("Content is not the expected type - please use the IsConflict property first.");
+}
\ No newline at end of file
diff --git a/test/Atc.Rest.ApiGenerator.CLI.Tests/Scenarios/Structure1/VerifyClient/WOPD/src/Structure1.ApiClient.Generated/Users/MyEndpoints/GetUserByEmailEndpoint.verified.cs b/test/Atc.Rest.ApiGenerator.CLI.Tests/Scenarios/Structure1/VerifyClient/WOPD/src/Structure1.ApiClient.Generated/Users/MyEndpoints/GetUserByEmailEndpoint.verified.cs
new file mode 100644
index 000000000..a4221179a
--- /dev/null
+++ b/test/Atc.Rest.ApiGenerator.CLI.Tests/Scenarios/Structure1/VerifyClient/WOPD/src/Structure1.ApiClient.Generated/Users/MyEndpoints/GetUserByEmailEndpoint.verified.cs
@@ -0,0 +1,48 @@
+//------------------------------------------------------------------------------
+// This code was auto-generated by ApiGenerator x.x.x.x.
+//
+// Changes to this file may cause incorrect behavior and will be lost if
+// the code is regenerated.
+//------------------------------------------------------------------------------
+namespace Structure1.ApiClient.Generated.Users.MyEndpoints;
+
+///
+/// Client Endpoint.
+/// Description: Get user by email.
+/// Operation: GetUserByEmail.
+///
+[GeneratedCode("ApiGenerator", "x.x.x.x")]
+public class GetUserByEmailEndpoint : IGetUserByEmailEndpoint
+{
+ private readonly IHttpClientFactory factory;
+ private readonly IHttpMessageFactory httpMessageFactory;
+
+ public GetUserByEmailEndpoint(
+ IHttpClientFactory factory,
+ IHttpMessageFactory httpMessageFactory)
+ {
+ this.factory = factory;
+ this.httpMessageFactory = httpMessageFactory;
+ }
+
+ public async Task ExecuteAsync(
+ GetUserByEmailParameters parameters,
+ string httpClientName = "Structure1-ApiClient",
+ CancellationToken cancellationToken = default)
+ {
+ var client = factory.CreateClient(httpClientName);
+
+ var requestBuilder = httpMessageFactory.FromTemplate("/api/v1/users/email");
+ requestBuilder.WithQueryParameter("email", parameters.Email);
+
+ using var requestMessage = requestBuilder.Build(HttpMethod.Get);
+ using var response = await client.SendAsync(requestMessage, cancellationToken);
+
+ var responseBuilder = httpMessageFactory.FromResponse(response);
+ responseBuilder.AddSuccessResponse(HttpStatusCode.OK);
+ responseBuilder.AddErrorResponse(HttpStatusCode.BadRequest);
+ responseBuilder.AddErrorResponse(HttpStatusCode.NotFound);
+ responseBuilder.AddErrorResponse(HttpStatusCode.Conflict);
+ return await responseBuilder.BuildResponseAsync(x => new GetUserByEmailEndpointResult(x), cancellationToken);
+ }
+}
\ No newline at end of file
diff --git a/test/Atc.Rest.ApiGenerator.CLI.Tests/Scenarios/Structure1/VerifyClient/WOPD/src/Structure1.ApiClient.Generated/Users/MyEndpoints/GetUserByEmailEndpointResult.verified.cs b/test/Atc.Rest.ApiGenerator.CLI.Tests/Scenarios/Structure1/VerifyClient/WOPD/src/Structure1.ApiClient.Generated/Users/MyEndpoints/GetUserByEmailEndpointResult.verified.cs
new file mode 100644
index 000000000..1351860fb
--- /dev/null
+++ b/test/Atc.Rest.ApiGenerator.CLI.Tests/Scenarios/Structure1/VerifyClient/WOPD/src/Structure1.ApiClient.Generated/Users/MyEndpoints/GetUserByEmailEndpointResult.verified.cs
@@ -0,0 +1,53 @@
+//------------------------------------------------------------------------------
+// This code was auto-generated by ApiGenerator x.x.x.x.
+//
+// Changes to this file may cause incorrect behavior and will be lost if
+// the code is regenerated.
+//------------------------------------------------------------------------------
+namespace Structure1.ApiClient.Generated.Users.MyEndpoints;
+
+///
+/// Client Endpoint result.
+/// Description: Get user by email.
+/// Operation: GetUserByEmail.
+///
+[GeneratedCode("ApiGenerator", "x.x.x.x")]
+public class GetUserByEmailEndpointResult : EndpointResponse, IGetUserByEmailEndpointResult
+{
+ public GetUserByEmailEndpointResult(EndpointResponse response)
+ : base(response)
+ {
+ }
+
+ public bool IsOk
+ => StatusCode == HttpStatusCode.OK;
+
+ public bool IsBadRequest
+ => StatusCode == HttpStatusCode.BadRequest;
+
+ public bool IsNotFound
+ => StatusCode == HttpStatusCode.NotFound;
+
+ public bool IsConflict
+ => StatusCode == HttpStatusCode.Conflict;
+
+ public User OkContent
+ => IsOk && ContentObject is User result
+ ? result
+ : throw new InvalidOperationException("Content is not the expected type - please use the IsOk property first.");
+
+ public string? BadRequestContent
+ => IsBadRequest && ContentObject is string result
+ ? result
+ : throw new InvalidOperationException("Content is not the expected type - please use the IsBadRequest property first.");
+
+ public string? NotFoundContent
+ => IsNotFound && ContentObject is string result
+ ? result
+ : throw new InvalidOperationException("Content is not the expected type - please use the IsNotFound property first.");
+
+ public string? ConflictContent
+ => IsConflict && ContentObject is string result
+ ? result
+ : throw new InvalidOperationException("Content is not the expected type - please use the IsConflict property first.");
+}
\ No newline at end of file
diff --git a/test/Atc.Rest.ApiGenerator.CLI.Tests/Scenarios/Structure1/VerifyClient/WOPD/src/Structure1.ApiClient.Generated/Users/MyEndpoints/GetUserByIdEndpoint.verified.cs b/test/Atc.Rest.ApiGenerator.CLI.Tests/Scenarios/Structure1/VerifyClient/WOPD/src/Structure1.ApiClient.Generated/Users/MyEndpoints/GetUserByIdEndpoint.verified.cs
new file mode 100644
index 000000000..2521584c4
--- /dev/null
+++ b/test/Atc.Rest.ApiGenerator.CLI.Tests/Scenarios/Structure1/VerifyClient/WOPD/src/Structure1.ApiClient.Generated/Users/MyEndpoints/GetUserByIdEndpoint.verified.cs
@@ -0,0 +1,48 @@
+//------------------------------------------------------------------------------
+// This code was auto-generated by ApiGenerator x.x.x.x.
+//
+// Changes to this file may cause incorrect behavior and will be lost if
+// the code is regenerated.
+//------------------------------------------------------------------------------
+namespace Structure1.ApiClient.Generated.Users.MyEndpoints;
+
+///
+/// Client Endpoint.
+/// Description: Get user by id.
+/// Operation: GetUserById.
+///
+[GeneratedCode("ApiGenerator", "x.x.x.x")]
+public class GetUserByIdEndpoint : IGetUserByIdEndpoint
+{
+ private readonly IHttpClientFactory factory;
+ private readonly IHttpMessageFactory httpMessageFactory;
+
+ public GetUserByIdEndpoint(
+ IHttpClientFactory factory,
+ IHttpMessageFactory httpMessageFactory)
+ {
+ this.factory = factory;
+ this.httpMessageFactory = httpMessageFactory;
+ }
+
+ public async Task ExecuteAsync(
+ GetUserByIdParameters parameters,
+ string httpClientName = "Structure1-ApiClient",
+ CancellationToken cancellationToken = default)
+ {
+ var client = factory.CreateClient(httpClientName);
+
+ var requestBuilder = httpMessageFactory.FromTemplate("/api/v1/users/{id}");
+ requestBuilder.WithPathParameter("id", parameters.Id);
+
+ using var requestMessage = requestBuilder.Build(HttpMethod.Get);
+ using var response = await client.SendAsync(requestMessage, cancellationToken);
+
+ var responseBuilder = httpMessageFactory.FromResponse(response);
+ responseBuilder.AddSuccessResponse(HttpStatusCode.OK);
+ responseBuilder.AddErrorResponse(HttpStatusCode.BadRequest);
+ responseBuilder.AddErrorResponse(HttpStatusCode.NotFound);
+ responseBuilder.AddErrorResponse(HttpStatusCode.Conflict);
+ return await responseBuilder.BuildResponseAsync(x => new GetUserByIdEndpointResult(x), cancellationToken);
+ }
+}
\ No newline at end of file
diff --git a/test/Atc.Rest.ApiGenerator.CLI.Tests/Scenarios/Structure1/VerifyClient/WOPD/src/Structure1.ApiClient.Generated/Users/MyEndpoints/GetUserByIdEndpointResult.verified.cs b/test/Atc.Rest.ApiGenerator.CLI.Tests/Scenarios/Structure1/VerifyClient/WOPD/src/Structure1.ApiClient.Generated/Users/MyEndpoints/GetUserByIdEndpointResult.verified.cs
new file mode 100644
index 000000000..485c83ba8
--- /dev/null
+++ b/test/Atc.Rest.ApiGenerator.CLI.Tests/Scenarios/Structure1/VerifyClient/WOPD/src/Structure1.ApiClient.Generated/Users/MyEndpoints/GetUserByIdEndpointResult.verified.cs
@@ -0,0 +1,53 @@
+//------------------------------------------------------------------------------
+// This code was auto-generated by ApiGenerator x.x.x.x.
+//
+// Changes to this file may cause incorrect behavior and will be lost if
+// the code is regenerated.
+//------------------------------------------------------------------------------
+namespace Structure1.ApiClient.Generated.Users.MyEndpoints;
+
+///
+/// Client Endpoint result.
+/// Description: Get user by id.
+/// Operation: GetUserById.
+///
+[GeneratedCode("ApiGenerator", "x.x.x.x")]
+public class GetUserByIdEndpointResult : EndpointResponse, IGetUserByIdEndpointResult
+{
+ public GetUserByIdEndpointResult(EndpointResponse response)
+ : base(response)
+ {
+ }
+
+ public bool IsOk
+ => StatusCode == HttpStatusCode.OK;
+
+ public bool IsBadRequest
+ => StatusCode == HttpStatusCode.BadRequest;
+
+ public bool IsNotFound
+ => StatusCode == HttpStatusCode.NotFound;
+
+ public bool IsConflict
+ => StatusCode == HttpStatusCode.Conflict;
+
+ public User OkContent
+ => IsOk && ContentObject is User result
+ ? result
+ : throw new InvalidOperationException("Content is not the expected type - please use the IsOk property first.");
+
+ public string? BadRequestContent
+ => IsBadRequest && ContentObject is string result
+ ? result
+ : throw new InvalidOperationException("Content is not the expected type - please use the IsBadRequest property first.");
+
+ public string? NotFoundContent
+ => IsNotFound && ContentObject is string result
+ ? result
+ : throw new InvalidOperationException("Content is not the expected type - please use the IsNotFound property first.");
+
+ public string? ConflictContent
+ => IsConflict && ContentObject is string result
+ ? result
+ : throw new InvalidOperationException("Content is not the expected type - please use the IsConflict property first.");
+}
\ No newline at end of file
diff --git a/test/Atc.Rest.ApiGenerator.CLI.Tests/Scenarios/Structure1/VerifyClient/WOPD/src/Structure1.ApiClient.Generated/Users/MyEndpoints/GetUsersEndpoint.verified.cs b/test/Atc.Rest.ApiGenerator.CLI.Tests/Scenarios/Structure1/VerifyClient/WOPD/src/Structure1.ApiClient.Generated/Users/MyEndpoints/GetUsersEndpoint.verified.cs
new file mode 100644
index 000000000..0390b15a2
--- /dev/null
+++ b/test/Atc.Rest.ApiGenerator.CLI.Tests/Scenarios/Structure1/VerifyClient/WOPD/src/Structure1.ApiClient.Generated/Users/MyEndpoints/GetUsersEndpoint.verified.cs
@@ -0,0 +1,44 @@
+//------------------------------------------------------------------------------
+// This code was auto-generated by ApiGenerator x.x.x.x.
+//
+// Changes to this file may cause incorrect behavior and will be lost if
+// the code is regenerated.
+//------------------------------------------------------------------------------
+namespace Structure1.ApiClient.Generated.Users.MyEndpoints;
+
+///
+/// Client Endpoint.
+/// Description: Get all users.
+/// Operation: GetUsers.
+///
+[GeneratedCode("ApiGenerator", "x.x.x.x")]
+public class GetUsersEndpoint : IGetUsersEndpoint
+{
+ private readonly IHttpClientFactory factory;
+ private readonly IHttpMessageFactory httpMessageFactory;
+
+ public GetUsersEndpoint(
+ IHttpClientFactory factory,
+ IHttpMessageFactory httpMessageFactory)
+ {
+ this.factory = factory;
+ this.httpMessageFactory = httpMessageFactory;
+ }
+
+ public async Task ExecuteAsync(
+ string httpClientName = "Structure1-ApiClient",
+ CancellationToken cancellationToken = default)
+ {
+ var client = factory.CreateClient(httpClientName);
+
+ var requestBuilder = httpMessageFactory.FromTemplate("/api/v1/users");
+
+ using var requestMessage = requestBuilder.Build(HttpMethod.Get);
+ using var response = await client.SendAsync(requestMessage, cancellationToken);
+
+ var responseBuilder = httpMessageFactory.FromResponse(response);
+ responseBuilder.AddSuccessResponse>(HttpStatusCode.OK);
+ responseBuilder.AddErrorResponse(HttpStatusCode.Conflict);
+ return await responseBuilder.BuildResponseAsync(x => new GetUsersEndpointResult(x), cancellationToken);
+ }
+}
\ No newline at end of file
diff --git a/test/Atc.Rest.ApiGenerator.CLI.Tests/Scenarios/Structure1/VerifyClient/WOPD/src/Structure1.ApiClient.Generated/Users/MyEndpoints/GetUsersEndpointResult.verified.cs b/test/Atc.Rest.ApiGenerator.CLI.Tests/Scenarios/Structure1/VerifyClient/WOPD/src/Structure1.ApiClient.Generated/Users/MyEndpoints/GetUsersEndpointResult.verified.cs
new file mode 100644
index 000000000..b5a40f6d8
--- /dev/null
+++ b/test/Atc.Rest.ApiGenerator.CLI.Tests/Scenarios/Structure1/VerifyClient/WOPD/src/Structure1.ApiClient.Generated/Users/MyEndpoints/GetUsersEndpointResult.verified.cs
@@ -0,0 +1,37 @@
+//------------------------------------------------------------------------------
+// This code was auto-generated by ApiGenerator x.x.x.x.
+//
+// Changes to this file may cause incorrect behavior and will be lost if
+// the code is regenerated.
+//------------------------------------------------------------------------------
+namespace Structure1.ApiClient.Generated.Users.MyEndpoints;
+
+///
+/// Client Endpoint result.
+/// Description: Get all users.
+/// Operation: GetUsers.
+///
+[GeneratedCode("ApiGenerator", "x.x.x.x")]
+public class GetUsersEndpointResult : EndpointResponse, IGetUsersEndpointResult
+{
+ public GetUsersEndpointResult(EndpointResponse response)
+ : base(response)
+ {
+ }
+
+ public bool IsOk
+ => StatusCode == HttpStatusCode.OK;
+
+ public bool IsConflict
+ => StatusCode == HttpStatusCode.Conflict;
+
+ public IEnumerable OkContent
+ => IsOk && ContentObject is IEnumerable result
+ ? result
+ : throw new InvalidOperationException("Content is not the expected type - please use the IsOk property first.");
+
+ public string? ConflictContent
+ => IsConflict && ContentObject is string result
+ ? result
+ : throw new InvalidOperationException("Content is not the expected type - please use the IsConflict property first.");
+}
\ No newline at end of file
diff --git a/test/Atc.Rest.ApiGenerator.CLI.Tests/Scenarios/Structure1/VerifyClient/WOPD/src/Structure1.ApiClient.Generated/Users/MyEndpoints/Interfaces/IDeleteUserByIdEndpoint.verified.cs b/test/Atc.Rest.ApiGenerator.CLI.Tests/Scenarios/Structure1/VerifyClient/WOPD/src/Structure1.ApiClient.Generated/Users/MyEndpoints/Interfaces/IDeleteUserByIdEndpoint.verified.cs
new file mode 100644
index 000000000..5a4c71446
--- /dev/null
+++ b/test/Atc.Rest.ApiGenerator.CLI.Tests/Scenarios/Structure1/VerifyClient/WOPD/src/Structure1.ApiClient.Generated/Users/MyEndpoints/Interfaces/IDeleteUserByIdEndpoint.verified.cs
@@ -0,0 +1,27 @@
+//------------------------------------------------------------------------------
+// This code was auto-generated by ApiGenerator x.x.x.x.
+//
+// Changes to this file may cause incorrect behavior and will be lost if
+// the code is regenerated.
+//------------------------------------------------------------------------------
+namespace Structure1.ApiClient.Generated.Users.MyEndpoints.Interfaces;
+
+///
+/// Interface for Client Endpoint.
+/// Description: Delete user by id.
+/// Operation: DeleteUserById.
+///
+[GeneratedCode("ApiGenerator", "x.x.x.x")]
+public interface IDeleteUserByIdEndpoint
+{
+ ///
+ /// Execute method.
+ ///
+ /// The parameters.
+ /// The http client name.
+ /// The cancellation token.
+ Task ExecuteAsync(
+ DeleteUserByIdParameters parameters,
+ string httpClientName = "Structure1-ApiClient",
+ CancellationToken cancellationToken = default);
+}
\ No newline at end of file
diff --git a/test/Atc.Rest.ApiGenerator.CLI.Tests/Scenarios/Structure1/VerifyClient/WOPD/src/Structure1.ApiClient.Generated/Users/MyEndpoints/Interfaces/IDeleteUserByIdEndpointResult.verified.cs b/test/Atc.Rest.ApiGenerator.CLI.Tests/Scenarios/Structure1/VerifyClient/WOPD/src/Structure1.ApiClient.Generated/Users/MyEndpoints/Interfaces/IDeleteUserByIdEndpointResult.verified.cs
new file mode 100644
index 000000000..fe771350d
--- /dev/null
+++ b/test/Atc.Rest.ApiGenerator.CLI.Tests/Scenarios/Structure1/VerifyClient/WOPD/src/Structure1.ApiClient.Generated/Users/MyEndpoints/Interfaces/IDeleteUserByIdEndpointResult.verified.cs
@@ -0,0 +1,33 @@
+//------------------------------------------------------------------------------
+// This code was auto-generated by ApiGenerator x.x.x.x.
+//
+// Changes to this file may cause incorrect behavior and will be lost if
+// the code is regenerated.
+//------------------------------------------------------------------------------
+namespace Structure1.ApiClient.Generated.Users.MyEndpoints.Interfaces;
+
+///
+/// Interface for Client Endpoint Result.
+/// Description: Delete user by id.
+/// Operation: DeleteUserById.
+///
+[GeneratedCode("ApiGenerator", "x.x.x.x")]
+public interface IDeleteUserByIdEndpointResult : IEndpointResponse
+{
+
+ bool IsOk { get; }
+
+ bool IsBadRequest { get; }
+
+ bool IsNotFound { get; }
+
+ bool IsConflict { get; }
+
+ string? OkContent { get; }
+
+ string? BadRequestContent { get; }
+
+ string? NotFoundContent { get; }
+
+ string? ConflictContent { get; }
+}
\ No newline at end of file
diff --git a/test/Atc.Rest.ApiGenerator.CLI.Tests/Scenarios/Structure1/VerifyClient/WOPD/src/Structure1.ApiClient.Generated/Users/MyEndpoints/Interfaces/IGetUserByEmailEndpoint.verified.cs b/test/Atc.Rest.ApiGenerator.CLI.Tests/Scenarios/Structure1/VerifyClient/WOPD/src/Structure1.ApiClient.Generated/Users/MyEndpoints/Interfaces/IGetUserByEmailEndpoint.verified.cs
new file mode 100644
index 000000000..6ccc64469
--- /dev/null
+++ b/test/Atc.Rest.ApiGenerator.CLI.Tests/Scenarios/Structure1/VerifyClient/WOPD/src/Structure1.ApiClient.Generated/Users/MyEndpoints/Interfaces/IGetUserByEmailEndpoint.verified.cs
@@ -0,0 +1,27 @@
+//------------------------------------------------------------------------------
+// This code was auto-generated by ApiGenerator x.x.x.x.
+//
+// Changes to this file may cause incorrect behavior and will be lost if
+// the code is regenerated.
+//------------------------------------------------------------------------------
+namespace Structure1.ApiClient.Generated.Users.MyEndpoints.Interfaces;
+
+///
+/// Interface for Client Endpoint.
+/// Description: Get user by email.
+/// Operation: GetUserByEmail.
+///
+[GeneratedCode("ApiGenerator", "x.x.x.x")]
+public interface IGetUserByEmailEndpoint
+{
+ ///
+ /// Execute method.
+ ///
+ /// The parameters.
+ /// The http client name.
+ /// The cancellation token.
+ Task ExecuteAsync(
+ GetUserByEmailParameters parameters,
+ string httpClientName = "Structure1-ApiClient",
+ CancellationToken cancellationToken = default);
+}
\ No newline at end of file
diff --git a/test/Atc.Rest.ApiGenerator.CLI.Tests/Scenarios/Structure1/VerifyClient/WOPD/src/Structure1.ApiClient.Generated/Users/MyEndpoints/Interfaces/IGetUserByEmailEndpointResult.verified.cs b/test/Atc.Rest.ApiGenerator.CLI.Tests/Scenarios/Structure1/VerifyClient/WOPD/src/Structure1.ApiClient.Generated/Users/MyEndpoints/Interfaces/IGetUserByEmailEndpointResult.verified.cs
new file mode 100644
index 000000000..4082b0a3d
--- /dev/null
+++ b/test/Atc.Rest.ApiGenerator.CLI.Tests/Scenarios/Structure1/VerifyClient/WOPD/src/Structure1.ApiClient.Generated/Users/MyEndpoints/Interfaces/IGetUserByEmailEndpointResult.verified.cs
@@ -0,0 +1,33 @@
+//------------------------------------------------------------------------------
+// This code was auto-generated by ApiGenerator x.x.x.x.
+//
+// Changes to this file may cause incorrect behavior and will be lost if
+// the code is regenerated.
+//------------------------------------------------------------------------------
+namespace Structure1.ApiClient.Generated.Users.MyEndpoints.Interfaces;
+
+///
+/// Interface for Client Endpoint Result.
+/// Description: Get user by email.
+/// Operation: GetUserByEmail.
+///
+[GeneratedCode("ApiGenerator", "x.x.x.x")]
+public interface IGetUserByEmailEndpointResult : IEndpointResponse
+{
+
+ bool IsOk { get; }
+
+ bool IsBadRequest { get; }
+
+ bool IsNotFound { get; }
+
+ bool IsConflict { get; }
+
+ User OkContent { get; }
+
+ string? BadRequestContent { get; }
+
+ string? NotFoundContent { get; }
+
+ string? ConflictContent { get; }
+}
\ No newline at end of file
diff --git a/test/Atc.Rest.ApiGenerator.CLI.Tests/Scenarios/Structure1/VerifyClient/WOPD/src/Structure1.ApiClient.Generated/Users/MyEndpoints/Interfaces/IGetUserByIdEndpoint.verified.cs b/test/Atc.Rest.ApiGenerator.CLI.Tests/Scenarios/Structure1/VerifyClient/WOPD/src/Structure1.ApiClient.Generated/Users/MyEndpoints/Interfaces/IGetUserByIdEndpoint.verified.cs
new file mode 100644
index 000000000..f587bebbe
--- /dev/null
+++ b/test/Atc.Rest.ApiGenerator.CLI.Tests/Scenarios/Structure1/VerifyClient/WOPD/src/Structure1.ApiClient.Generated/Users/MyEndpoints/Interfaces/IGetUserByIdEndpoint.verified.cs
@@ -0,0 +1,27 @@
+//------------------------------------------------------------------------------
+// This code was auto-generated by ApiGenerator x.x.x.x.
+//
+// Changes to this file may cause incorrect behavior and will be lost if
+// the code is regenerated.
+//------------------------------------------------------------------------------
+namespace Structure1.ApiClient.Generated.Users.MyEndpoints.Interfaces;
+
+///
+/// Interface for Client Endpoint.
+/// Description: Get user by id.
+/// Operation: GetUserById.
+///
+[GeneratedCode("ApiGenerator", "x.x.x.x")]
+public interface IGetUserByIdEndpoint
+{
+ ///
+ /// Execute method.
+ ///
+ /// The parameters.
+ /// The http client name.
+ /// The cancellation token.
+ Task ExecuteAsync(
+ GetUserByIdParameters parameters,
+ string httpClientName = "Structure1-ApiClient",
+ CancellationToken cancellationToken = default);
+}
\ No newline at end of file
diff --git a/test/Atc.Rest.ApiGenerator.CLI.Tests/Scenarios/Structure1/VerifyClient/WOPD/src/Structure1.ApiClient.Generated/Users/MyEndpoints/Interfaces/IGetUserByIdEndpointResult.verified.cs b/test/Atc.Rest.ApiGenerator.CLI.Tests/Scenarios/Structure1/VerifyClient/WOPD/src/Structure1.ApiClient.Generated/Users/MyEndpoints/Interfaces/IGetUserByIdEndpointResult.verified.cs
new file mode 100644
index 000000000..7e47ed12f
--- /dev/null
+++ b/test/Atc.Rest.ApiGenerator.CLI.Tests/Scenarios/Structure1/VerifyClient/WOPD/src/Structure1.ApiClient.Generated/Users/MyEndpoints/Interfaces/IGetUserByIdEndpointResult.verified.cs
@@ -0,0 +1,33 @@
+//------------------------------------------------------------------------------
+// This code was auto-generated by ApiGenerator x.x.x.x.
+//
+// Changes to this file may cause incorrect behavior and will be lost if
+// the code is regenerated.
+//------------------------------------------------------------------------------
+namespace Structure1.ApiClient.Generated.Users.MyEndpoints.Interfaces;
+
+///
+/// Interface for Client Endpoint Result.
+/// Description: Get user by id.
+/// Operation: GetUserById.
+///
+[GeneratedCode("ApiGenerator", "x.x.x.x")]
+public interface IGetUserByIdEndpointResult : IEndpointResponse
+{
+
+ bool IsOk { get; }
+
+ bool IsBadRequest { get; }
+
+ bool IsNotFound { get; }
+
+ bool IsConflict { get; }
+
+ User OkContent { get; }
+
+ string? BadRequestContent { get; }
+
+ string? NotFoundContent { get; }
+
+ string? ConflictContent { get; }
+}
\ No newline at end of file
diff --git a/test/Atc.Rest.ApiGenerator.CLI.Tests/Scenarios/Structure1/VerifyClient/WOPD/src/Structure1.ApiClient.Generated/Users/MyEndpoints/Interfaces/IGetUsersEndpoint.verified.cs b/test/Atc.Rest.ApiGenerator.CLI.Tests/Scenarios/Structure1/VerifyClient/WOPD/src/Structure1.ApiClient.Generated/Users/MyEndpoints/Interfaces/IGetUsersEndpoint.verified.cs
new file mode 100644
index 000000000..e5713f683
--- /dev/null
+++ b/test/Atc.Rest.ApiGenerator.CLI.Tests/Scenarios/Structure1/VerifyClient/WOPD/src/Structure1.ApiClient.Generated/Users/MyEndpoints/Interfaces/IGetUsersEndpoint.verified.cs
@@ -0,0 +1,25 @@
+//------------------------------------------------------------------------------
+// This code was auto-generated by ApiGenerator x.x.x.x.
+//
+// Changes to this file may cause incorrect behavior and will be lost if
+// the code is regenerated.
+//------------------------------------------------------------------------------
+namespace Structure1.ApiClient.Generated.Users.MyEndpoints.Interfaces;
+
+///
+/// Interface for Client Endpoint.
+/// Description: Get all users.
+/// Operation: GetUsers.
+///
+[GeneratedCode("ApiGenerator", "x.x.x.x")]
+public interface IGetUsersEndpoint
+{
+ ///
+ /// Execute method.
+ ///
+ /// The http client name.
+ /// The cancellation token.
+ Task ExecuteAsync(
+ string httpClientName = "Structure1-ApiClient",
+ CancellationToken cancellationToken = default);
+}
\ No newline at end of file
diff --git a/test/Atc.Rest.ApiGenerator.CLI.Tests/Scenarios/Structure1/VerifyClient/WOPD/src/Structure1.ApiClient.Generated/Users/MyEndpoints/Interfaces/IGetUsersEndpointResult.verified.cs b/test/Atc.Rest.ApiGenerator.CLI.Tests/Scenarios/Structure1/VerifyClient/WOPD/src/Structure1.ApiClient.Generated/Users/MyEndpoints/Interfaces/IGetUsersEndpointResult.verified.cs
new file mode 100644
index 000000000..300a2c657
--- /dev/null
+++ b/test/Atc.Rest.ApiGenerator.CLI.Tests/Scenarios/Structure1/VerifyClient/WOPD/src/Structure1.ApiClient.Generated/Users/MyEndpoints/Interfaces/IGetUsersEndpointResult.verified.cs
@@ -0,0 +1,25 @@
+//------------------------------------------------------------------------------
+// This code was auto-generated by ApiGenerator x.x.x.x.
+//
+// Changes to this file may cause incorrect behavior and will be lost if
+// the code is regenerated.
+//------------------------------------------------------------------------------
+namespace Structure1.ApiClient.Generated.Users.MyEndpoints.Interfaces;
+
+///
+/// Interface for Client Endpoint Result.
+/// Description: Get all users.
+/// Operation: GetUsers.
+///
+[GeneratedCode("ApiGenerator", "x.x.x.x")]
+public interface IGetUsersEndpointResult : IEndpointResponse
+{
+
+ bool IsOk { get; }
+
+ bool IsConflict { get; }
+
+ IEnumerable OkContent { get; }
+
+ string? ConflictContent { get; }
+}
\ No newline at end of file
diff --git a/test/Atc.Rest.ApiGenerator.CLI.Tests/Scenarios/Structure1/VerifyClient/WOPD/src/Structure1.ApiClient.Generated/Users/MyEndpoints/Interfaces/IPostUserEndpoint.verified.cs b/test/Atc.Rest.ApiGenerator.CLI.Tests/Scenarios/Structure1/VerifyClient/WOPD/src/Structure1.ApiClient.Generated/Users/MyEndpoints/Interfaces/IPostUserEndpoint.verified.cs
new file mode 100644
index 000000000..0fe3778fe
--- /dev/null
+++ b/test/Atc.Rest.ApiGenerator.CLI.Tests/Scenarios/Structure1/VerifyClient/WOPD/src/Structure1.ApiClient.Generated/Users/MyEndpoints/Interfaces/IPostUserEndpoint.verified.cs
@@ -0,0 +1,27 @@
+//------------------------------------------------------------------------------
+// This code was auto-generated by ApiGenerator x.x.x.x.
+//
+// Changes to this file may cause incorrect behavior and will be lost if
+// the code is regenerated.
+//------------------------------------------------------------------------------
+namespace Structure1.ApiClient.Generated.Users.MyEndpoints.Interfaces;
+
+///
+/// Interface for Client Endpoint.
+/// Description: Create a new user.
+/// Operation: PostUser.
+///
+[GeneratedCode("ApiGenerator", "x.x.x.x")]
+public interface IPostUserEndpoint
+{
+ ///
+ /// Execute method.
+ ///
+ /// The parameters.
+ /// The http client name.
+ /// The cancellation token.
+ Task ExecuteAsync(
+ PostUserParameters parameters,
+ string httpClientName = "Structure1-ApiClient",
+ CancellationToken cancellationToken = default);
+}
\ No newline at end of file
diff --git a/test/Atc.Rest.ApiGenerator.CLI.Tests/Scenarios/Structure1/VerifyClient/WOPD/src/Structure1.ApiClient.Generated/Users/MyEndpoints/Interfaces/IPostUserEndpointResult.verified.cs b/test/Atc.Rest.ApiGenerator.CLI.Tests/Scenarios/Structure1/VerifyClient/WOPD/src/Structure1.ApiClient.Generated/Users/MyEndpoints/Interfaces/IPostUserEndpointResult.verified.cs
new file mode 100644
index 000000000..5b8a616e3
--- /dev/null
+++ b/test/Atc.Rest.ApiGenerator.CLI.Tests/Scenarios/Structure1/VerifyClient/WOPD/src/Structure1.ApiClient.Generated/Users/MyEndpoints/Interfaces/IPostUserEndpointResult.verified.cs
@@ -0,0 +1,29 @@
+//------------------------------------------------------------------------------
+// This code was auto-generated by ApiGenerator x.x.x.x.
+//
+// Changes to this file may cause incorrect behavior and will be lost if
+// the code is regenerated.
+//------------------------------------------------------------------------------
+namespace Structure1.ApiClient.Generated.Users.MyEndpoints.Interfaces;
+
+///
+/// Interface for Client Endpoint Result.
+/// Description: Create a new user.
+/// Operation: PostUser.
+///
+[GeneratedCode("ApiGenerator", "x.x.x.x")]
+public interface IPostUserEndpointResult : IEndpointResponse
+{
+
+ bool IsCreated { get; }
+
+ bool IsBadRequest { get; }
+
+ bool IsConflict { get; }
+
+ string? CreatedContent { get; }
+
+ string? BadRequestContent { get; }
+
+ string? ConflictContent { get; }
+}
\ No newline at end of file
diff --git a/test/Atc.Rest.ApiGenerator.CLI.Tests/Scenarios/Structure1/VerifyClient/WOPD/src/Structure1.ApiClient.Generated/Users/MyEndpoints/Interfaces/IUpdateMyTestGenderEndpoint.verified.cs b/test/Atc.Rest.ApiGenerator.CLI.Tests/Scenarios/Structure1/VerifyClient/WOPD/src/Structure1.ApiClient.Generated/Users/MyEndpoints/Interfaces/IUpdateMyTestGenderEndpoint.verified.cs
new file mode 100644
index 000000000..1d3bf7535
--- /dev/null
+++ b/test/Atc.Rest.ApiGenerator.CLI.Tests/Scenarios/Structure1/VerifyClient/WOPD/src/Structure1.ApiClient.Generated/Users/MyEndpoints/Interfaces/IUpdateMyTestGenderEndpoint.verified.cs
@@ -0,0 +1,27 @@
+//------------------------------------------------------------------------------
+// This code was auto-generated by ApiGenerator x.x.x.x.
+//
+// Changes to this file may cause incorrect behavior and will be lost if
+// the code is regenerated.
+//------------------------------------------------------------------------------
+namespace Structure1.ApiClient.Generated.Users.MyEndpoints.Interfaces;
+
+///
+/// Interface for Client Endpoint.
+/// Description: Update gender on a user.
+/// Operation: UpdateMyTestGender.
+///
+[GeneratedCode("ApiGenerator", "x.x.x.x")]
+public interface IUpdateMyTestGenderEndpoint
+{
+ ///
+ /// Execute method.
+ ///
+ /// The parameters.
+ /// The http client name.
+ /// The cancellation token.
+ Task ExecuteAsync(
+ UpdateMyTestGenderParameters parameters,
+ string httpClientName = "Structure1-ApiClient",
+ CancellationToken cancellationToken = default);
+}
\ No newline at end of file
diff --git a/test/Atc.Rest.ApiGenerator.CLI.Tests/Scenarios/Structure1/VerifyClient/WOPD/src/Structure1.ApiClient.Generated/Users/MyEndpoints/Interfaces/IUpdateMyTestGenderEndpointResult.verified.cs b/test/Atc.Rest.ApiGenerator.CLI.Tests/Scenarios/Structure1/VerifyClient/WOPD/src/Structure1.ApiClient.Generated/Users/MyEndpoints/Interfaces/IUpdateMyTestGenderEndpointResult.verified.cs
new file mode 100644
index 000000000..deff37592
--- /dev/null
+++ b/test/Atc.Rest.ApiGenerator.CLI.Tests/Scenarios/Structure1/VerifyClient/WOPD/src/Structure1.ApiClient.Generated/Users/MyEndpoints/Interfaces/IUpdateMyTestGenderEndpointResult.verified.cs
@@ -0,0 +1,33 @@
+//------------------------------------------------------------------------------
+// This code was auto-generated by ApiGenerator x.x.x.x.
+//
+// Changes to this file may cause incorrect behavior and will be lost if
+// the code is regenerated.
+//------------------------------------------------------------------------------
+namespace Structure1.ApiClient.Generated.Users.MyEndpoints.Interfaces;
+
+///
+/// Interface for Client Endpoint Result.
+/// Description: Update gender on a user.
+/// Operation: UpdateMyTestGender.
+///
+[GeneratedCode("ApiGenerator", "x.x.x.x")]
+public interface IUpdateMyTestGenderEndpointResult : IEndpointResponse
+{
+
+ bool IsOk { get; }
+
+ bool IsBadRequest { get; }
+
+ bool IsNotFound { get; }
+
+ bool IsConflict { get; }
+
+ string? OkContent { get; }
+
+ string? BadRequestContent { get; }
+
+ string? NotFoundContent { get; }
+
+ string? ConflictContent { get; }
+}
\ No newline at end of file
diff --git a/test/Atc.Rest.ApiGenerator.CLI.Tests/Scenarios/Structure1/VerifyClient/WOPD/src/Structure1.ApiClient.Generated/Users/MyEndpoints/Interfaces/IUpdateUserByIdEndpoint.verified.cs b/test/Atc.Rest.ApiGenerator.CLI.Tests/Scenarios/Structure1/VerifyClient/WOPD/src/Structure1.ApiClient.Generated/Users/MyEndpoints/Interfaces/IUpdateUserByIdEndpoint.verified.cs
new file mode 100644
index 000000000..ae7d21b63
--- /dev/null
+++ b/test/Atc.Rest.ApiGenerator.CLI.Tests/Scenarios/Structure1/VerifyClient/WOPD/src/Structure1.ApiClient.Generated/Users/MyEndpoints/Interfaces/IUpdateUserByIdEndpoint.verified.cs
@@ -0,0 +1,27 @@
+//------------------------------------------------------------------------------
+// This code was auto-generated by ApiGenerator x.x.x.x.
+//
+// Changes to this file may cause incorrect behavior and will be lost if
+// the code is regenerated.
+//------------------------------------------------------------------------------
+namespace Structure1.ApiClient.Generated.Users.MyEndpoints.Interfaces;
+
+///
+/// Interface for Client Endpoint.
+/// Description: Update user by id.
+/// Operation: UpdateUserById.
+///
+[GeneratedCode("ApiGenerator", "x.x.x.x")]
+public interface IUpdateUserByIdEndpoint
+{
+ ///
+ /// Execute method.
+ ///
+ /// The parameters.
+ /// The http client name.
+ /// The cancellation token.
+ Task ExecuteAsync(
+ UpdateUserByIdParameters parameters,
+ string httpClientName = "Structure1-ApiClient",
+ CancellationToken cancellationToken = default);
+}
\ No newline at end of file
diff --git a/test/Atc.Rest.ApiGenerator.CLI.Tests/Scenarios/Structure1/VerifyClient/WOPD/src/Structure1.ApiClient.Generated/Users/MyEndpoints/Interfaces/IUpdateUserByIdEndpointResult.verified.cs b/test/Atc.Rest.ApiGenerator.CLI.Tests/Scenarios/Structure1/VerifyClient/WOPD/src/Structure1.ApiClient.Generated/Users/MyEndpoints/Interfaces/IUpdateUserByIdEndpointResult.verified.cs
new file mode 100644
index 000000000..0c6536cdd
--- /dev/null
+++ b/test/Atc.Rest.ApiGenerator.CLI.Tests/Scenarios/Structure1/VerifyClient/WOPD/src/Structure1.ApiClient.Generated/Users/MyEndpoints/Interfaces/IUpdateUserByIdEndpointResult.verified.cs
@@ -0,0 +1,33 @@
+//------------------------------------------------------------------------------
+// This code was auto-generated by ApiGenerator x.x.x.x.
+//
+// Changes to this file may cause incorrect behavior and will be lost if
+// the code is regenerated.
+//------------------------------------------------------------------------------
+namespace Structure1.ApiClient.Generated.Users.MyEndpoints.Interfaces;
+
+///
+/// Interface for Client Endpoint Result.
+/// Description: Update user by id.
+/// Operation: UpdateUserById.
+///
+[GeneratedCode("ApiGenerator", "x.x.x.x")]
+public interface IUpdateUserByIdEndpointResult : IEndpointResponse
+{
+
+ bool IsOk { get; }
+
+ bool IsBadRequest { get; }
+
+ bool IsNotFound { get; }
+
+ bool IsConflict { get; }
+
+ string? OkContent { get; }
+
+ string? BadRequestContent { get; }
+
+ string? NotFoundContent { get; }
+
+ string? ConflictContent { get; }
+}
\ No newline at end of file
diff --git a/test/Atc.Rest.ApiGenerator.CLI.Tests/Scenarios/Structure1/VerifyClient/WOPD/src/Structure1.ApiClient.Generated/Users/MyEndpoints/PostUserEndpoint.verified.cs b/test/Atc.Rest.ApiGenerator.CLI.Tests/Scenarios/Structure1/VerifyClient/WOPD/src/Structure1.ApiClient.Generated/Users/MyEndpoints/PostUserEndpoint.verified.cs
new file mode 100644
index 000000000..77ee39cd8
--- /dev/null
+++ b/test/Atc.Rest.ApiGenerator.CLI.Tests/Scenarios/Structure1/VerifyClient/WOPD/src/Structure1.ApiClient.Generated/Users/MyEndpoints/PostUserEndpoint.verified.cs
@@ -0,0 +1,47 @@
+//------------------------------------------------------------------------------
+// This code was auto-generated by ApiGenerator x.x.x.x.
+//
+// Changes to this file may cause incorrect behavior and will be lost if
+// the code is regenerated.
+//------------------------------------------------------------------------------
+namespace Structure1.ApiClient.Generated.Users.MyEndpoints;
+
+///
+/// Client Endpoint.
+/// Description: Create a new user.
+/// Operation: PostUser.
+///
+[GeneratedCode("ApiGenerator", "x.x.x.x")]
+public class PostUserEndpoint : IPostUserEndpoint
+{
+ private readonly IHttpClientFactory factory;
+ private readonly IHttpMessageFactory httpMessageFactory;
+
+ public PostUserEndpoint(
+ IHttpClientFactory factory,
+ IHttpMessageFactory httpMessageFactory)
+ {
+ this.factory = factory;
+ this.httpMessageFactory = httpMessageFactory;
+ }
+
+ public async Task ExecuteAsync(
+ PostUserParameters parameters,
+ string httpClientName = "Structure1-ApiClient",
+ CancellationToken cancellationToken = default)
+ {
+ var client = factory.CreateClient(httpClientName);
+
+ var requestBuilder = httpMessageFactory.FromTemplate("/api/v1/users");
+ requestBuilder.WithBody(parameters.Request);
+
+ using var requestMessage = requestBuilder.Build(HttpMethod.Post);
+ using var response = await client.SendAsync(requestMessage, cancellationToken);
+
+ var responseBuilder = httpMessageFactory.FromResponse(response);
+ responseBuilder.AddErrorResponse(HttpStatusCode.Created);
+ responseBuilder.AddErrorResponse(HttpStatusCode.BadRequest);
+ responseBuilder.AddErrorResponse(HttpStatusCode.Conflict);
+ return await responseBuilder.BuildResponseAsync(x => new PostUserEndpointResult(x), cancellationToken);
+ }
+}
\ No newline at end of file
diff --git a/test/Atc.Rest.ApiGenerator.CLI.Tests/Scenarios/Structure1/VerifyClient/WOPD/src/Structure1.ApiClient.Generated/Users/MyEndpoints/PostUserEndpointResult.verified.cs b/test/Atc.Rest.ApiGenerator.CLI.Tests/Scenarios/Structure1/VerifyClient/WOPD/src/Structure1.ApiClient.Generated/Users/MyEndpoints/PostUserEndpointResult.verified.cs
new file mode 100644
index 000000000..48f28ce64
--- /dev/null
+++ b/test/Atc.Rest.ApiGenerator.CLI.Tests/Scenarios/Structure1/VerifyClient/WOPD/src/Structure1.ApiClient.Generated/Users/MyEndpoints/PostUserEndpointResult.verified.cs
@@ -0,0 +1,45 @@
+//------------------------------------------------------------------------------
+// This code was auto-generated by ApiGenerator x.x.x.x.
+//
+// Changes to this file may cause incorrect behavior and will be lost if
+// the code is regenerated.
+//------------------------------------------------------------------------------
+namespace Structure1.ApiClient.Generated.Users.MyEndpoints;
+
+///
+/// Client Endpoint result.
+/// Description: Create a new user.
+/// Operation: PostUser.
+///
+[GeneratedCode("ApiGenerator", "x.x.x.x")]
+public class PostUserEndpointResult : EndpointResponse, IPostUserEndpointResult
+{
+ public PostUserEndpointResult(EndpointResponse response)
+ : base(response)
+ {
+ }
+
+ public bool IsCreated
+ => StatusCode == HttpStatusCode.Created;
+
+ public bool IsBadRequest
+ => StatusCode == HttpStatusCode.BadRequest;
+
+ public bool IsConflict
+ => StatusCode == HttpStatusCode.Conflict;
+
+ public string? CreatedContent
+ => IsCreated && ContentObject is string result
+ ? result
+ : throw new InvalidOperationException("Content is not the expected type - please use the IsCreated property first.");
+
+ public string? BadRequestContent
+ => IsBadRequest && ContentObject is string result
+ ? result
+ : throw new InvalidOperationException("Content is not the expected type - please use the IsBadRequest property first.");
+
+ public string? ConflictContent
+ => IsConflict && ContentObject is string result
+ ? result
+ : throw new InvalidOperationException("Content is not the expected type - please use the IsConflict property first.");
+}
\ No newline at end of file
diff --git a/test/Atc.Rest.ApiGenerator.CLI.Tests/Scenarios/Structure1/VerifyClient/WOPD/src/Structure1.ApiClient.Generated/Users/MyEndpoints/UpdateMyTestGenderEndpoint.verified.cs b/test/Atc.Rest.ApiGenerator.CLI.Tests/Scenarios/Structure1/VerifyClient/WOPD/src/Structure1.ApiClient.Generated/Users/MyEndpoints/UpdateMyTestGenderEndpoint.verified.cs
new file mode 100644
index 000000000..8bed2c7da
--- /dev/null
+++ b/test/Atc.Rest.ApiGenerator.CLI.Tests/Scenarios/Structure1/VerifyClient/WOPD/src/Structure1.ApiClient.Generated/Users/MyEndpoints/UpdateMyTestGenderEndpoint.verified.cs
@@ -0,0 +1,50 @@
+//------------------------------------------------------------------------------
+// This code was auto-generated by ApiGenerator x.x.x.x.
+//
+// Changes to this file may cause incorrect behavior and will be lost if
+// the code is regenerated.
+//------------------------------------------------------------------------------
+namespace Structure1.ApiClient.Generated.Users.MyEndpoints;
+
+///
+/// Client Endpoint.
+/// Description: Update gender on a user.
+/// Operation: UpdateMyTestGender.
+///
+[GeneratedCode("ApiGenerator", "x.x.x.x")]
+public class UpdateMyTestGenderEndpoint : IUpdateMyTestGenderEndpoint
+{
+ private readonly IHttpClientFactory factory;
+ private readonly IHttpMessageFactory httpMessageFactory;
+
+ public UpdateMyTestGenderEndpoint(
+ IHttpClientFactory factory,
+ IHttpMessageFactory httpMessageFactory)
+ {
+ this.factory = factory;
+ this.httpMessageFactory = httpMessageFactory;
+ }
+
+ public async Task ExecuteAsync(
+ UpdateMyTestGenderParameters parameters,
+ string httpClientName = "Structure1-ApiClient",
+ CancellationToken cancellationToken = default)
+ {
+ var client = factory.CreateClient(httpClientName);
+
+ var requestBuilder = httpMessageFactory.FromTemplate("/api/v1/users/{id}/gender");
+ requestBuilder.WithPathParameter("id", parameters.Id);
+ requestBuilder.WithQueryParameter("genderParam", parameters.GenderParam);
+ requestBuilder.WithBody(parameters.Request);
+
+ using var requestMessage = requestBuilder.Build(HttpMethod.Put);
+ using var response = await client.SendAsync(requestMessage, cancellationToken);
+
+ var responseBuilder = httpMessageFactory.FromResponse(response);
+ responseBuilder.AddSuccessResponse(HttpStatusCode.OK);
+ responseBuilder.AddErrorResponse(HttpStatusCode.BadRequest);
+ responseBuilder.AddErrorResponse(HttpStatusCode.NotFound);
+ responseBuilder.AddErrorResponse(HttpStatusCode.Conflict);
+ return await responseBuilder.BuildResponseAsync(x => new UpdateMyTestGenderEndpointResult(x), cancellationToken);
+ }
+}
\ No newline at end of file
diff --git a/test/Atc.Rest.ApiGenerator.CLI.Tests/Scenarios/Structure1/VerifyClient/WOPD/src/Structure1.ApiClient.Generated/Users/MyEndpoints/UpdateMyTestGenderEndpointResult.verified.cs b/test/Atc.Rest.ApiGenerator.CLI.Tests/Scenarios/Structure1/VerifyClient/WOPD/src/Structure1.ApiClient.Generated/Users/MyEndpoints/UpdateMyTestGenderEndpointResult.verified.cs
new file mode 100644
index 000000000..81ffe6b88
--- /dev/null
+++ b/test/Atc.Rest.ApiGenerator.CLI.Tests/Scenarios/Structure1/VerifyClient/WOPD/src/Structure1.ApiClient.Generated/Users/MyEndpoints/UpdateMyTestGenderEndpointResult.verified.cs
@@ -0,0 +1,53 @@
+//------------------------------------------------------------------------------
+// This code was auto-generated by ApiGenerator x.x.x.x.
+//
+// Changes to this file may cause incorrect behavior and will be lost if
+// the code is regenerated.
+//------------------------------------------------------------------------------
+namespace Structure1.ApiClient.Generated.Users.MyEndpoints;
+
+///
+/// Client Endpoint result.
+/// Description: Update gender on a user.
+/// Operation: UpdateMyTestGender.
+///
+[GeneratedCode("ApiGenerator", "x.x.x.x")]
+public class UpdateMyTestGenderEndpointResult : EndpointResponse, IUpdateMyTestGenderEndpointResult
+{
+ public UpdateMyTestGenderEndpointResult(EndpointResponse response)
+ : base(response)
+ {
+ }
+
+ public bool IsOk
+ => StatusCode == HttpStatusCode.OK;
+
+ public bool IsBadRequest
+ => StatusCode == HttpStatusCode.BadRequest;
+
+ public bool IsNotFound
+ => StatusCode == HttpStatusCode.NotFound;
+
+ public bool IsConflict
+ => StatusCode == HttpStatusCode.Conflict;
+
+ public string? OkContent
+ => IsOk && ContentObject is string result
+ ? result
+ : throw new InvalidOperationException("Content is not the expected type - please use the IsOk property first.");
+
+ public string? BadRequestContent
+ => IsBadRequest && ContentObject is string result
+ ? result
+ : throw new InvalidOperationException("Content is not the expected type - please use the IsBadRequest property first.");
+
+ public string? NotFoundContent
+ => IsNotFound && ContentObject is string result
+ ? result
+ : throw new InvalidOperationException("Content is not the expected type - please use the IsNotFound property first.");
+
+ public string? ConflictContent
+ => IsConflict && ContentObject is string result
+ ? result
+ : throw new InvalidOperationException("Content is not the expected type - please use the IsConflict property first.");
+}
\ No newline at end of file
diff --git a/test/Atc.Rest.ApiGenerator.CLI.Tests/Scenarios/Structure1/VerifyClient/WOPD/src/Structure1.ApiClient.Generated/Users/MyEndpoints/UpdateUserByIdEndpoint.verified.cs b/test/Atc.Rest.ApiGenerator.CLI.Tests/Scenarios/Structure1/VerifyClient/WOPD/src/Structure1.ApiClient.Generated/Users/MyEndpoints/UpdateUserByIdEndpoint.verified.cs
new file mode 100644
index 000000000..60f99df46
--- /dev/null
+++ b/test/Atc.Rest.ApiGenerator.CLI.Tests/Scenarios/Structure1/VerifyClient/WOPD/src/Structure1.ApiClient.Generated/Users/MyEndpoints/UpdateUserByIdEndpoint.verified.cs
@@ -0,0 +1,49 @@
+//------------------------------------------------------------------------------
+// This code was auto-generated by ApiGenerator x.x.x.x.
+//
+// Changes to this file may cause incorrect behavior and will be lost if
+// the code is regenerated.
+//------------------------------------------------------------------------------
+namespace Structure1.ApiClient.Generated.Users.MyEndpoints;
+
+///
+/// Client Endpoint.
+/// Description: Update user by id.
+/// Operation: UpdateUserById.
+///
+[GeneratedCode("ApiGenerator", "x.x.x.x")]
+public class UpdateUserByIdEndpoint : IUpdateUserByIdEndpoint
+{
+ private readonly IHttpClientFactory factory;
+ private readonly IHttpMessageFactory httpMessageFactory;
+
+ public UpdateUserByIdEndpoint(
+ IHttpClientFactory factory,
+ IHttpMessageFactory httpMessageFactory)
+ {
+ this.factory = factory;
+ this.httpMessageFactory = httpMessageFactory;
+ }
+
+ public async Task ExecuteAsync(
+ UpdateUserByIdParameters parameters,
+ string httpClientName = "Structure1-ApiClient",
+ CancellationToken cancellationToken = default)
+ {
+ var client = factory.CreateClient(httpClientName);
+
+ var requestBuilder = httpMessageFactory.FromTemplate("/api/v1/users/{id}");
+ requestBuilder.WithPathParameter("id", parameters.Id);
+ requestBuilder.WithBody(parameters.Request);
+
+ using var requestMessage = requestBuilder.Build(HttpMethod.Put);
+ using var response = await client.SendAsync(requestMessage, cancellationToken);
+
+ var responseBuilder = httpMessageFactory.FromResponse(response);
+ responseBuilder.AddSuccessResponse(HttpStatusCode.OK);
+ responseBuilder.AddErrorResponse(HttpStatusCode.BadRequest);
+ responseBuilder.AddErrorResponse(HttpStatusCode.NotFound);
+ responseBuilder.AddErrorResponse(HttpStatusCode.Conflict);
+ return await responseBuilder.BuildResponseAsync(x => new UpdateUserByIdEndpointResult(x), cancellationToken);
+ }
+}
\ No newline at end of file
diff --git a/test/Atc.Rest.ApiGenerator.CLI.Tests/Scenarios/Structure1/VerifyClient/WOPD/src/Structure1.ApiClient.Generated/Users/MyEndpoints/UpdateUserByIdEndpointResult.verified.cs b/test/Atc.Rest.ApiGenerator.CLI.Tests/Scenarios/Structure1/VerifyClient/WOPD/src/Structure1.ApiClient.Generated/Users/MyEndpoints/UpdateUserByIdEndpointResult.verified.cs
new file mode 100644
index 000000000..35da9f366
--- /dev/null
+++ b/test/Atc.Rest.ApiGenerator.CLI.Tests/Scenarios/Structure1/VerifyClient/WOPD/src/Structure1.ApiClient.Generated/Users/MyEndpoints/UpdateUserByIdEndpointResult.verified.cs
@@ -0,0 +1,53 @@
+//------------------------------------------------------------------------------
+// This code was auto-generated by ApiGenerator x.x.x.x.
+//
+// Changes to this file may cause incorrect behavior and will be lost if
+// the code is regenerated.
+//------------------------------------------------------------------------------
+namespace Structure1.ApiClient.Generated.Users.MyEndpoints;
+
+///
+/// Client Endpoint result.
+/// Description: Update user by id.
+/// Operation: UpdateUserById.
+///
+[GeneratedCode("ApiGenerator", "x.x.x.x")]
+public class UpdateUserByIdEndpointResult : EndpointResponse, IUpdateUserByIdEndpointResult
+{
+ public UpdateUserByIdEndpointResult(EndpointResponse response)
+ : base(response)
+ {
+ }
+
+ public bool IsOk
+ => StatusCode == HttpStatusCode.OK;
+
+ public bool IsBadRequest
+ => StatusCode == HttpStatusCode.BadRequest;
+
+ public bool IsNotFound
+ => StatusCode == HttpStatusCode.NotFound;
+
+ public bool IsConflict
+ => StatusCode == HttpStatusCode.Conflict;
+
+ public string? OkContent
+ => IsOk && ContentObject is string result
+ ? result
+ : throw new InvalidOperationException("Content is not the expected type - please use the IsOk property first.");
+
+ public string? BadRequestContent
+ => IsBadRequest && ContentObject is string result
+ ? result
+ : throw new InvalidOperationException("Content is not the expected type - please use the IsBadRequest property first.");
+
+ public string? NotFoundContent
+ => IsNotFound && ContentObject is string result
+ ? result
+ : throw new InvalidOperationException("Content is not the expected type - please use the IsNotFound property first.");
+
+ public string? ConflictContent
+ => IsConflict && ContentObject is string result
+ ? result
+ : throw new InvalidOperationException("Content is not the expected type - please use the IsConflict property first.");
+}
\ No newline at end of file
diff --git a/test/Atc.Rest.ApiGenerator.CLI.Tests/Scenarios/Structure1/VerifyClient/WPD/src/Structure1.ApiClient.Generated/Accounts/MyContracts/RequestParameters/SetAccountNameParameters.verified.cs b/test/Atc.Rest.ApiGenerator.CLI.Tests/Scenarios/Structure1/VerifyClient/WPD/src/Structure1.ApiClient.Generated/Accounts/MyContracts/RequestParameters/SetAccountNameParameters.verified.cs
new file mode 100644
index 000000000..ebd55f30f
--- /dev/null
+++ b/test/Atc.Rest.ApiGenerator.CLI.Tests/Scenarios/Structure1/VerifyClient/WPD/src/Structure1.ApiClient.Generated/Accounts/MyContracts/RequestParameters/SetAccountNameParameters.verified.cs
@@ -0,0 +1,32 @@
+//------------------------------------------------------------------------------
+// This code was auto-generated by ApiGenerator x.x.x.x.
+//
+// Changes to this file may cause incorrect behavior and will be lost if
+// the code is regenerated.
+//------------------------------------------------------------------------------
+namespace Structure1.ApiClient.Generated.Accounts.MyContracts;
+
+///
+/// Parameters for operation request.
+/// Description: Set name of account.
+/// Operation: SetAccountName.
+///
+[GeneratedCode("ApiGenerator", "x.x.x.x")]
+public class SetAccountNameParameters
+{
+ ///
+ /// The accountId.
+ ///
+ [Required]
+ public Guid AccountId { get; set; }
+
+ ///
+ /// UpdateAccountRequest.
+ ///
+ [Required]
+ public UpdateAccountRequest Request { get; set; }
+
+ ///
+ public override string ToString()
+ => $"{nameof(AccountId)}: {AccountId}, {nameof(Request)}: ({Request})";
+}
\ No newline at end of file
diff --git a/test/Atc.Rest.ApiGenerator.CLI.Tests/Scenarios/Structure1/VerifyClient/WPD/src/Structure1.ApiClient.Generated/Accounts/MyContracts/RequestParameters/UpdateAccountNameParameters.verified.cs b/test/Atc.Rest.ApiGenerator.CLI.Tests/Scenarios/Structure1/VerifyClient/WPD/src/Structure1.ApiClient.Generated/Accounts/MyContracts/RequestParameters/UpdateAccountNameParameters.verified.cs
new file mode 100644
index 000000000..8a179d181
--- /dev/null
+++ b/test/Atc.Rest.ApiGenerator.CLI.Tests/Scenarios/Structure1/VerifyClient/WPD/src/Structure1.ApiClient.Generated/Accounts/MyContracts/RequestParameters/UpdateAccountNameParameters.verified.cs
@@ -0,0 +1,31 @@
+//------------------------------------------------------------------------------
+// This code was auto-generated by ApiGenerator x.x.x.x.
+//
+// Changes to this file may cause incorrect behavior and will be lost if
+// the code is regenerated.
+//------------------------------------------------------------------------------
+namespace Structure1.ApiClient.Generated.Accounts.MyContracts;
+
+///
+/// Parameters for operation request.
+/// Description: Update name of account.
+/// Operation: UpdateAccountName.
+///
+[GeneratedCode("ApiGenerator", "x.x.x.x")]
+public class UpdateAccountNameParameters
+{
+ ///
+ /// The accountId.
+ ///
+ [Required]
+ public Guid AccountId { get; set; }
+
+ ///
+ /// The account name.
+ ///
+ public string Name { get; set; }
+
+ ///
+ public override string ToString()
+ => $"{nameof(AccountId)}: {AccountId}, {nameof(Name)}: {Name}";
+}
\ No newline at end of file
diff --git a/test/Atc.Rest.ApiGenerator.CLI.Tests/Scenarios/Structure1/VerifyClient/WPD/src/Structure1.ApiClient.Generated/Accounts/MyContracts/UpdateAccountRequest.verified.cs b/test/Atc.Rest.ApiGenerator.CLI.Tests/Scenarios/Structure1/VerifyClient/WPD/src/Structure1.ApiClient.Generated/Accounts/MyContracts/UpdateAccountRequest.verified.cs
new file mode 100644
index 000000000..892a401ed
--- /dev/null
+++ b/test/Atc.Rest.ApiGenerator.CLI.Tests/Scenarios/Structure1/VerifyClient/WPD/src/Structure1.ApiClient.Generated/Accounts/MyContracts/UpdateAccountRequest.verified.cs
@@ -0,0 +1,20 @@
+//------------------------------------------------------------------------------
+// This code was auto-generated by ApiGenerator x.x.x.x.
+//
+// Changes to this file may cause incorrect behavior and will be lost if
+// the code is regenerated.
+//------------------------------------------------------------------------------
+namespace Structure1.ApiClient.Generated.Accounts.MyContracts;
+
+///
+/// UpdateAccountRequest.
+///
+[GeneratedCode("ApiGenerator", "x.x.x.x")]
+public class UpdateAccountRequest
+{
+ public string Name { get; set; }
+
+ ///
+ public override string ToString()
+ => $"{nameof(Name)}: {Name}";
+}
\ No newline at end of file
diff --git a/test/Atc.Rest.ApiGenerator.CLI.Tests/Scenarios/Structure1/VerifyClient/WPD/src/Structure1.ApiClient.Generated/Accounts/MyEndpoints/Interfaces/ISetAccountNameEndpoint.verified.cs b/test/Atc.Rest.ApiGenerator.CLI.Tests/Scenarios/Structure1/VerifyClient/WPD/src/Structure1.ApiClient.Generated/Accounts/MyEndpoints/Interfaces/ISetAccountNameEndpoint.verified.cs
new file mode 100644
index 000000000..7dd9edc6d
--- /dev/null
+++ b/test/Atc.Rest.ApiGenerator.CLI.Tests/Scenarios/Structure1/VerifyClient/WPD/src/Structure1.ApiClient.Generated/Accounts/MyEndpoints/Interfaces/ISetAccountNameEndpoint.verified.cs
@@ -0,0 +1,27 @@
+//------------------------------------------------------------------------------
+// This code was auto-generated by ApiGenerator x.x.x.x.
+//
+// Changes to this file may cause incorrect behavior and will be lost if
+// the code is regenerated.
+//------------------------------------------------------------------------------
+namespace Structure1.ApiClient.Generated.Accounts.MyEndpoints.Interfaces;
+
+///
+/// Interface for Client Endpoint.
+/// Description: Set name of account.
+/// Operation: SetAccountName.
+///
+[GeneratedCode("ApiGenerator", "x.x.x.x")]
+public interface ISetAccountNameEndpoint
+{
+ ///
+ /// Execute method.
+ ///
+ /// The parameters.
+ /// The http client name.
+ /// The cancellation token.
+ Task ExecuteAsync(
+ SetAccountNameParameters parameters,
+ string httpClientName = "Structure1-ApiClient",
+ CancellationToken cancellationToken = default);
+}
\ No newline at end of file
diff --git a/test/Atc.Rest.ApiGenerator.CLI.Tests/Scenarios/Structure1/VerifyClient/WPD/src/Structure1.ApiClient.Generated/Accounts/MyEndpoints/Interfaces/ISetAccountNameEndpointResult.verified.cs b/test/Atc.Rest.ApiGenerator.CLI.Tests/Scenarios/Structure1/VerifyClient/WPD/src/Structure1.ApiClient.Generated/Accounts/MyEndpoints/Interfaces/ISetAccountNameEndpointResult.verified.cs
new file mode 100644
index 000000000..f91dc6547
--- /dev/null
+++ b/test/Atc.Rest.ApiGenerator.CLI.Tests/Scenarios/Structure1/VerifyClient/WPD/src/Structure1.ApiClient.Generated/Accounts/MyEndpoints/Interfaces/ISetAccountNameEndpointResult.verified.cs
@@ -0,0 +1,25 @@
+//------------------------------------------------------------------------------
+// This code was auto-generated by ApiGenerator x.x.x.x.
+//
+// Changes to this file may cause incorrect behavior and will be lost if
+// the code is regenerated.
+//------------------------------------------------------------------------------
+namespace Structure1.ApiClient.Generated.Accounts.MyEndpoints.Interfaces;
+
+///
+/// Interface for Client Endpoint Result.
+/// Description: Set name of account.
+/// Operation: SetAccountName.
+///
+[GeneratedCode("ApiGenerator", "x.x.x.x")]
+public interface ISetAccountNameEndpointResult : IEndpointResponse
+{
+
+ bool IsOk { get; }
+
+ bool IsBadRequest { get; }
+
+ string? OkContent { get; }
+
+ ValidationProblemDetails BadRequestContent { get; }
+}
\ No newline at end of file
diff --git a/test/Atc.Rest.ApiGenerator.CLI.Tests/Scenarios/Structure1/VerifyClient/WPD/src/Structure1.ApiClient.Generated/Accounts/MyEndpoints/Interfaces/IUpdateAccountNameEndpoint.verified.cs b/test/Atc.Rest.ApiGenerator.CLI.Tests/Scenarios/Structure1/VerifyClient/WPD/src/Structure1.ApiClient.Generated/Accounts/MyEndpoints/Interfaces/IUpdateAccountNameEndpoint.verified.cs
new file mode 100644
index 000000000..ae216ccb0
--- /dev/null
+++ b/test/Atc.Rest.ApiGenerator.CLI.Tests/Scenarios/Structure1/VerifyClient/WPD/src/Structure1.ApiClient.Generated/Accounts/MyEndpoints/Interfaces/IUpdateAccountNameEndpoint.verified.cs
@@ -0,0 +1,27 @@
+//------------------------------------------------------------------------------
+// This code was auto-generated by ApiGenerator x.x.x.x.
+//
+// Changes to this file may cause incorrect behavior and will be lost if
+// the code is regenerated.
+//------------------------------------------------------------------------------
+namespace Structure1.ApiClient.Generated.Accounts.MyEndpoints.Interfaces;
+
+///
+/// Interface for Client Endpoint.
+/// Description: Update name of account.
+/// Operation: UpdateAccountName.
+///
+[GeneratedCode("ApiGenerator", "x.x.x.x")]
+public interface IUpdateAccountNameEndpoint
+{
+ ///
+ /// Execute method.
+ ///
+ /// The parameters.
+ /// The http client name.
+ /// The cancellation token.
+ Task ExecuteAsync(
+ UpdateAccountNameParameters parameters,
+ string httpClientName = "Structure1-ApiClient",
+ CancellationToken cancellationToken = default);
+}
\ No newline at end of file
diff --git a/test/Atc.Rest.ApiGenerator.CLI.Tests/Scenarios/Structure1/VerifyClient/WPD/src/Structure1.ApiClient.Generated/Accounts/MyEndpoints/Interfaces/IUpdateAccountNameEndpointResult.verified.cs b/test/Atc.Rest.ApiGenerator.CLI.Tests/Scenarios/Structure1/VerifyClient/WPD/src/Structure1.ApiClient.Generated/Accounts/MyEndpoints/Interfaces/IUpdateAccountNameEndpointResult.verified.cs
new file mode 100644
index 000000000..f615dd891
--- /dev/null
+++ b/test/Atc.Rest.ApiGenerator.CLI.Tests/Scenarios/Structure1/VerifyClient/WPD/src/Structure1.ApiClient.Generated/Accounts/MyEndpoints/Interfaces/IUpdateAccountNameEndpointResult.verified.cs
@@ -0,0 +1,25 @@
+//------------------------------------------------------------------------------
+// This code was auto-generated by ApiGenerator x.x.x.x.
+//
+// Changes to this file may cause incorrect behavior and will be lost if
+// the code is regenerated.
+//------------------------------------------------------------------------------
+namespace Structure1.ApiClient.Generated.Accounts.MyEndpoints.Interfaces;
+
+///
+/// Interface for Client Endpoint Result.
+/// Description: Update name of account.
+/// Operation: UpdateAccountName.
+///
+[GeneratedCode("ApiGenerator", "x.x.x.x")]
+public interface IUpdateAccountNameEndpointResult : IEndpointResponse
+{
+
+ bool IsOk { get; }
+
+ bool IsBadRequest { get; }
+
+ string? OkContent { get; }
+
+ ValidationProblemDetails BadRequestContent { get; }
+}
\ No newline at end of file
diff --git a/test/Atc.Rest.ApiGenerator.CLI.Tests/Scenarios/Structure1/VerifyClient/WPD/src/Structure1.ApiClient.Generated/Accounts/MyEndpoints/SetAccountNameEndpoint.verified.cs b/test/Atc.Rest.ApiGenerator.CLI.Tests/Scenarios/Structure1/VerifyClient/WPD/src/Structure1.ApiClient.Generated/Accounts/MyEndpoints/SetAccountNameEndpoint.verified.cs
new file mode 100644
index 000000000..1f717bf17
--- /dev/null
+++ b/test/Atc.Rest.ApiGenerator.CLI.Tests/Scenarios/Structure1/VerifyClient/WPD/src/Structure1.ApiClient.Generated/Accounts/MyEndpoints/SetAccountNameEndpoint.verified.cs
@@ -0,0 +1,47 @@
+//------------------------------------------------------------------------------
+// This code was auto-generated by ApiGenerator x.x.x.x.
+//
+// Changes to this file may cause incorrect behavior and will be lost if
+// the code is regenerated.
+//------------------------------------------------------------------------------
+namespace Structure1.ApiClient.Generated.Accounts.MyEndpoints;
+
+///
+/// Client Endpoint.
+/// Description: Set name of account.
+/// Operation: SetAccountName.
+///
+[GeneratedCode("ApiGenerator", "x.x.x.x")]
+public class SetAccountNameEndpoint : ISetAccountNameEndpoint
+{
+ private readonly IHttpClientFactory factory;
+ private readonly IHttpMessageFactory httpMessageFactory;
+
+ public SetAccountNameEndpoint(
+ IHttpClientFactory factory,
+ IHttpMessageFactory httpMessageFactory)
+ {
+ this.factory = factory;
+ this.httpMessageFactory = httpMessageFactory;
+ }
+
+ public async Task ExecuteAsync(
+ SetAccountNameParameters parameters,
+ string httpClientName = "Structure1-ApiClient",
+ CancellationToken cancellationToken = default)
+ {
+ var client = factory.CreateClient(httpClientName);
+
+ var requestBuilder = httpMessageFactory.FromTemplate("/api/v1/accounts/{accountId}/name");
+ requestBuilder.WithPathParameter("accountId", parameters.AccountId);
+ requestBuilder.WithBody(parameters.Request);
+
+ using var requestMessage = requestBuilder.Build(HttpMethod.Post);
+ using var response = await client.SendAsync(requestMessage, cancellationToken);
+
+ var responseBuilder = httpMessageFactory.FromResponse(response);
+ responseBuilder.AddSuccessResponse(HttpStatusCode.OK);
+ responseBuilder.AddErrorResponse(HttpStatusCode.BadRequest);
+ return await responseBuilder.BuildResponseAsync(x => new SetAccountNameEndpointResult(x), cancellationToken);
+ }
+}
\ No newline at end of file
diff --git a/test/Atc.Rest.ApiGenerator.CLI.Tests/Scenarios/Structure1/VerifyClient/WPD/src/Structure1.ApiClient.Generated/Accounts/MyEndpoints/SetAccountNameEndpointResult.verified.cs b/test/Atc.Rest.ApiGenerator.CLI.Tests/Scenarios/Structure1/VerifyClient/WPD/src/Structure1.ApiClient.Generated/Accounts/MyEndpoints/SetAccountNameEndpointResult.verified.cs
new file mode 100644
index 000000000..b11f8a918
--- /dev/null
+++ b/test/Atc.Rest.ApiGenerator.CLI.Tests/Scenarios/Structure1/VerifyClient/WPD/src/Structure1.ApiClient.Generated/Accounts/MyEndpoints/SetAccountNameEndpointResult.verified.cs
@@ -0,0 +1,37 @@
+//------------------------------------------------------------------------------
+// This code was auto-generated by ApiGenerator x.x.x.x.
+//
+// Changes to this file may cause incorrect behavior and will be lost if
+// the code is regenerated.
+//------------------------------------------------------------------------------
+namespace Structure1.ApiClient.Generated.Accounts.MyEndpoints;
+
+///