Sha256: 2c65cdc97a2155d39be7bac6156349fd97d86d7b65c227cda3e41a85639d1582

Contents?: true

Size: 1.97 KB

Versions: 3

Compression:

Stored size: 1.97 KB

Contents

class Apipie::Generator::Swagger::MethodDescription::ResponseService
  # @param [Apipie::Generator::Swagger::MethodDescription::Decorator] method_description
  # @param [Symbol] http_method
  def initialize(method_description, http_method:, language:)
    @method_description = method_description
    @http_method = http_method
    @language = language
  end

  # @return [Hash]
  def call
    result = {}
    result.merge!(errors)
    result.merge!(responses)
    result.merge!(empty_returns)

    result
  end

  private

  # @return [Hash]
  def errors
    @errors ||= @method_description.errors.each_with_object({}) do |error, errors|
      errors[error.code] = {
        description: Apipie.app.translate(error.description, @language)
      }
    end
  end

  # @return [Hash]
  def responses
    @responses ||=
      @method_description.returns.each_with_object({}) do |response, responses_schema|
        responses_schema[response.code] = {
          description: Apipie.app.translate(response.description, @language),
          schema: Apipie::Generator::Swagger::MethodDescription::ResponseSchemaService.new(
            response,
            allow_null: false,
            http_method: @http_method,
            controller_method: @method_description
          ).to_swagger,
          headers: response_headers(response.headers)
        }.compact
      end
  end

  # @return [Hash]
  def empty_returns
    return {} if errors.present? || responses.present?

    Apipie::Generator::Swagger::Warning.for_code(
      Apipie::Generator::Swagger::Warning::NO_RETURN_CODES_SPECIFIED_CODE,
      @method_description.ruby_name
    ).warn_through_writer

    { 200 => { description: 'ok' } }
  end

  # @param [Array<Hash>] headers
  #
  # https://swagger.io/specification/v2/#header-object
  def response_headers(headers)
    headers.each_with_object({}) do |header, result|
      result[header[:name].to_s] = {
        description: header[:description],
        type: header[:validator]
      }
    end
  end
end

Version data entries

3 entries across 3 versions & 1 rubygems

Version Path
apipie-rails-1.4.2 lib/apipie/generator/swagger/method_description/response_service.rb
apipie-rails-1.4.1 lib/apipie/generator/swagger/method_description/response_service.rb
apipie-rails-1.4.0 lib/apipie/generator/swagger/method_description/response_service.rb