forked from loafle/openapi-generator-original
70 lines
3.6 KiB
Plaintext
70 lines
3.6 KiB
Plaintext
require "uri"
|
|
|
|
module {{moduleName}}
|
|
{{#operations}}
|
|
class {{classname}}
|
|
{{#operation}}
|
|
{{newline}}
|
|
# {{summary}}
|
|
# {{notes}}
|
|
{{#allParams}}{{#required}} # @param {{paramName}} {{description}}
|
|
{{/required}}{{/allParams}} # @param [Hash] opts the optional parameters
|
|
{{#allParams}}{{^required}} # @option opts [{{{dataType}}}] :{{paramName}} {{description}}
|
|
{{/required}}{{/allParams}} # @return [{{#returnType}}{{{returnType}}}{{/returnType}}{{^returnType}}nil{{/returnType}}]
|
|
def self.{{nickname}}({{#allParams}}{{#required}}{{paramName}}, {{/required}}{{/allParams}}opts = {})
|
|
if Swagger.configuration.debug
|
|
Swagger.logger.debug "Calling API: {{classname}}#{{nickname}} ..."
|
|
end
|
|
{{#allParams}}{{#required}}
|
|
# verify the required parameter '{{paramName}}' is set
|
|
raise "Missing the required parameter '{{paramName}}' when calling {{nickname}}" if {{{paramName}}}.nil?
|
|
{{/required}}{{/allParams}}
|
|
|
|
# resource path
|
|
path = "{{path}}".sub('{format}','json'){{#pathParams}}.sub('{' + '{{baseName}}' + '}', {{paramName}}.to_s){{/pathParams}}
|
|
|
|
# query parameters
|
|
query_params = {}{{#queryParams}}{{#required}}
|
|
query_params[:'{{{baseName}}}'] = {{{paramName}}}{{/required}}{{/queryParams}}{{#queryParams}}{{^required}}
|
|
query_params[:'{{{baseName}}}'] = opts[:'{{{paramName}}}'] if opts[:'{{{paramName}}}']{{/required}}{{/queryParams}}
|
|
|
|
# header parameters
|
|
header_params = {}
|
|
|
|
# HTTP header 'Accept' (if needed)
|
|
_header_accept = [{{#produces}}'{{mediaType}}'{{#hasMore}}, {{/hasMore}}{{/produces}}]
|
|
_header_accept_result = Swagger::Request.select_header_accept(_header_accept) and header_params['Accept'] = _header_accept_result
|
|
|
|
# HTTP header 'Content-Type'
|
|
_header_content_type = [{{#consumes}}'{{mediaType}}'{{#hasMore}}, {{/hasMore}}{{/consumes}}]
|
|
header_params['Content-Type'] = Swagger::Request.select_header_content_type(_header_content_type){{#headerParams}}{{#required}}
|
|
header_params[:'{{{baseName}}}'] = {{{paramName}}}{{/required}}{{/headerParams}}{{#headerParams}}{{^required}}
|
|
header_params[:'{{{baseName}}}'] = opts[:'{{{paramName}}}'] if opts[:'{{{paramName}}}']{{/required}}{{/headerParams}}
|
|
|
|
# form parameters
|
|
form_params = {}{{#formParams}}{{#required}}
|
|
form_params["{{baseName}}"] = {{paramName}}{{/required}}{{/formParams}}{{#formParams}}{{^required}}
|
|
form_params["{{baseName}}"] = opts[:'{{paramName}}'] if opts[:'{{paramName}}']{{/required}}{{/formParams}}
|
|
|
|
# http body (model)
|
|
{{^bodyParam}}post_body = nil
|
|
{{/bodyParam}}{{#bodyParam}}post_body = Swagger::Request.object_to_http_body({{#required}}{{{paramName}}}{{/required}}{{^required}}opts[:'{{{paramName}}}']{{/required}})
|
|
{{/bodyParam}}
|
|
|
|
auth_names = [{{#authMethods}}'{{name}}'{{#hasMore}}, {{/hasMore}}{{/authMethods}}]
|
|
{{#returnType}}response = Swagger::Request.new(:{{httpMethod}}, path, {:params => query_params, :headers => header_params, :form_params => form_params, :body => post_body, :auth_names => auth_names}).make
|
|
result = response.deserialize('{{{returnType}}}')
|
|
if Swagger.configuration.debug
|
|
Swagger.logger.debug "API called: {{classname}}#{{nickname}}. Result: #{result.inspect}"
|
|
end
|
|
result{{/returnType}}{{^returnType}}Swagger::Request.new(:{{httpMethod}}, path, {:params => query_params, :headers => header_params, :form_params => form_params, :body => post_body, :auth_names => auth_names}).make
|
|
if Swagger.configuration.debug
|
|
Swagger.logger.debug "API called: {{classname}}#{{nickname}}"
|
|
end
|
|
nil{{/returnType}}
|
|
end
|
|
{{/operation}}
|
|
end
|
|
{{/operations}}
|
|
end
|