forked from loafle/openapi-generator-original
128 lines
5.6 KiB
Plaintext
128 lines
5.6 KiB
Plaintext
using System;
|
|
using System.IO;
|
|
using System.Collections.Generic;
|
|
using RestSharp;
|
|
using {{packageName}}.Client;
|
|
{{#hasImport}}using {{packageName}}.Model;
|
|
{{/hasImport}}
|
|
|
|
namespace {{packageName}}.Api
|
|
{
|
|
{{#operations}}
|
|
public interface I{{classname}}
|
|
{
|
|
{{#operation}}
|
|
/// <summary>
|
|
/// {{summary}} {{notes}}
|
|
/// </summary>
|
|
{{#allParams}}/// <param name="{{paramName}}">{{description}}</param>
|
|
{{/allParams}}/// <returns>{{#returnType}}{{{returnType}}}{{/returnType}}</returns>
|
|
{{#returnType}}{{{returnType}}}{{/returnType}}{{^returnType}}void{{/returnType}} {{nickname}} ({{#allParams}}{{{dataType}}} {{paramName}}{{#hasMore}}, {{/hasMore}}{{/allParams}});
|
|
{{/operation}}
|
|
}
|
|
|
|
/// <summary>
|
|
/// Represents a collection of functions to interact with the API endpoints
|
|
/// </summary>
|
|
public class {{classname}} : I{{classname}}
|
|
{
|
|
/// <summary>
|
|
/// Initializes a new instance of the <see cref="{{classname}}"/> class.
|
|
/// </summary>
|
|
/// <param name="apiClient"> an instance of ApiClient (optional)</param>
|
|
/// <returns></returns>
|
|
public {{classname}}(ApiClient apiClient = null)
|
|
{
|
|
if (apiClient == null) // use the default one in Configuration
|
|
this.ApiClient = Configuration.DefaultApiClient;
|
|
else
|
|
this.ApiClient = apiClient;
|
|
}
|
|
|
|
/// <summary>
|
|
/// Initializes a new instance of the <see cref="{{classname}}"/> class.
|
|
/// </summary>
|
|
/// <returns></returns>
|
|
public {{classname}}(String basePath)
|
|
{
|
|
this.ApiClient = new ApiClient(basePath);
|
|
}
|
|
|
|
/// <summary>
|
|
/// Sets the base path of the API client.
|
|
/// </summary>
|
|
/// <param name="basePath">The base path</param>
|
|
/// <value>The base path</value>
|
|
public void SetBasePath(String basePath)
|
|
{
|
|
this.ApiClient.BasePath = basePath;
|
|
}
|
|
|
|
/// <summary>
|
|
/// Gets the base path of the API client.
|
|
/// </summary>
|
|
/// <param name="basePath">The base path</param>
|
|
/// <value>The base path</value>
|
|
public String GetBasePath(String basePath)
|
|
{
|
|
return this.ApiClient.BasePath;
|
|
}
|
|
|
|
/// <summary>
|
|
/// Gets or sets the API client.
|
|
/// </summary>
|
|
/// <value>An instance of the ApiClient</param>
|
|
public ApiClient ApiClient {get; set;}
|
|
|
|
{{#operation}}
|
|
/// <summary>
|
|
/// {{summary}} {{notes}}
|
|
/// </summary>
|
|
{{#allParams}}/// <param name="{{paramName}}">{{description}}</param>
|
|
{{/allParams}}/// <returns>{{#returnType}}{{{returnType}}}{{/returnType}}</returns>
|
|
public {{#returnType}}{{{returnType}}}{{/returnType}}{{^returnType}}void{{/returnType}} {{nickname}} ({{#allParams}}{{{dataType}}} {{paramName}}{{#hasMore}}, {{/hasMore}}{{/allParams}})
|
|
{
|
|
{{#allParams}}{{#required}}
|
|
// verify the required parameter '{{paramName}}' is set
|
|
if ({{paramName}} == null) throw new ApiException(400, "Missing required parameter '{{paramName}}' when calling {{nickname}}");
|
|
{{/required}}{{/allParams}}
|
|
|
|
var path = "{{path}}";
|
|
path = path.Replace("{format}", "json");
|
|
{{#pathParams}}path = path.Replace("{" + "{{baseName}}" + "}", ApiClient.ParameterToString({{{paramName}}}));
|
|
{{/pathParams}}
|
|
|
|
var queryParams = new Dictionary<String, String>();
|
|
var headerParams = new Dictionary<String, String>();
|
|
var formParams = new Dictionary<String, String>();
|
|
var fileParams = new Dictionary<String, FileParameter>();
|
|
String postBody = null;
|
|
|
|
{{#queryParams}} if ({{paramName}} != null) queryParams.Add("{{baseName}}", ApiClient.ParameterToString({{paramName}})); // query parameter
|
|
{{/queryParams}}
|
|
{{#headerParams}} if ({{paramName}} != null) headerParams.Add("{{baseName}}", ApiClient.ParameterToString({{paramName}})); // header parameter
|
|
{{/headerParams}}
|
|
{{#formParams}}if ({{paramName}} != null) {{#isFile}}fileParams.Add("{{baseName}}", ApiClient.ParameterToFile("{{baseName}}", {{paramName}}));{{/isFile}}{{^isFile}}formParams.Add("{{baseName}}", ApiClient.ParameterToString({{paramName}})); // form parameter{{/isFile}}
|
|
{{/formParams}}
|
|
{{#bodyParam}}postBody = ApiClient.Serialize({{paramName}}); // http body (model) parameter
|
|
{{/bodyParam}}
|
|
|
|
// authentication setting, if any
|
|
String[] authSettings = new String[] { {{#authMethods}}"{{name}}"{{#hasMore}}, {{/hasMore}}{{/authMethods}} };
|
|
|
|
// make the HTTP request
|
|
IRestResponse response = (IRestResponse) ApiClient.CallApi(path, Method.{{httpMethod}}, queryParams, postBody, headerParams, formParams, fileParams, authSettings);
|
|
|
|
if (((int)response.StatusCode) >= 400)
|
|
throw new ApiException ((int)response.StatusCode, "Error calling {{nickname}}: " + response.Content, response.Content);
|
|
else if (((int)response.StatusCode) == 0)
|
|
throw new ApiException ((int)response.StatusCode, "Error calling {{nickname}}: " + response.ErrorMessage, response.ErrorMessage);
|
|
|
|
{{#returnType}}return ({{{returnType}}}) ApiClient.Deserialize(response.Content, typeof({{{returnType}}}), response.Headers);{{/returnType}}{{^returnType}}return;{{/returnType}}
|
|
}
|
|
|
|
{{/operation}}
|
|
}
|
|
{{/operations}}
|
|
}
|