Sha256: c9ca425f7454066b9637a81499ceafe9d8757ba774c5ce0406da3ea6a96947ee

Contents?: true

Size: 1.25 KB

Versions: 6

Compression:

Stored size: 1.25 KB

Contents

require 'tomograph'
require 'esplanade/request'
require 'esplanade/response'

module Esplanade
  class SafeMiddleware
    def initialize(
      app,
      prefix: Esplanade.configuration.prefix,
      apib_path: Esplanade.configuration.apib_path,
      drafter_yaml_path: Esplanade.configuration.drafter_yaml_path
    )
      @app = app
      @documentation = Tomograph::Tomogram.new(
        prefix: prefix,
        apib_path: apib_path,
        drafter_yaml_path: drafter_yaml_path
      )
    end

    def call(env)
      request = Esplanade::Request.new(@documentation, env)
      check_request(request)

      status, headers, body = @app.call(env)

      response = Esplanade::Response.new(request, status, body)
      check_response(response)

      [status, headers, body]
    end

    def check_request(request)
      request.validation.valid!
      Rails.logger.debug 'ESPLANADE SAYS THAT THE REQUEST IS VALID'
    rescue Esplanade::Request::Error => e
      Rails.logger.debug "ESPLANADE SKIP: #{e.inspect}"
    end

    def check_response(response)
      response.validation.valid!
      Rails.logger.debug 'ESPLANADE SAYS THAT THE RESPONSE IS VALID'
    rescue Esplanade::Response::Error => e
      Rails.logger.debug "ESPLANADE SKIP: #{e.inspect}"
    end
  end
end

Version data entries

6 entries across 6 versions & 1 rubygems

Version Path
esplanade-1.6.0 lib/esplanade/middlewares/safe_middleware.rb
esplanade-1.5.0 lib/esplanade/middlewares/safe_middleware.rb
esplanade-1.4.0 lib/esplanade/middlewares/safe_middleware.rb
esplanade-1.3.0 lib/esplanade/middlewares/safe_middleware.rb
esplanade-1.2.1 lib/esplanade/middlewares/safe_middleware.rb
esplanade-1.2.0 lib/esplanade/middlewares/safe_middleware.rb