class JsonApiClient::Connection

Attributes

faraday[R]

Public Class Methods

new(options = {}) { |self| ... } click to toggle source
# File lib/json_api_client/connection.rb, line 6
def initialize(options = {})
  site = options.fetch(:site)
  connection_options = options.slice(:proxy, :ssl, :request, :headers, :params)
  adapter_options = Array(options.fetch(:adapter, Faraday.default_adapter))
  status_middleware_options = {}
  status_middleware_options[:custom_handlers] = options[:status_handlers] if options[:status_handlers].present?
  @faraday = Faraday.new(site, connection_options) do |builder|
    builder.request :json
    builder.use Middleware::JsonRequest
    builder.use Middleware::Status, status_middleware_options
    builder.response :json
    builder.use ::Faraday::Gzip::Middleware
    builder.adapter(*adapter_options)
  end
  yield(self) if block_given?
end

Public Instance Methods

delete(middleware) click to toggle source
# File lib/json_api_client/connection.rb, line 30
def delete(middleware)
  faraday.builder.delete(middleware)
end
run(request_method, path, params: nil, headers: {}, body: nil) click to toggle source
# File lib/json_api_client/connection.rb, line 34
def run(request_method, path, params: nil, headers: {}, body: nil)
  faraday.run_request(request_method, path, body, headers) do |request|
    request.params.update(params) if params
  end
end
use(middleware, *args, &block) click to toggle source

insert middleware before ParseJson - middleware executed in reverse order -

inserted middleware will run after json parsed
# File lib/json_api_client/connection.rb, line 25
def use(middleware, *args, &block)
  return if faraday.builder.locked?
  faraday.builder.insert_before(::Faraday::Response::Json, middleware, *args, &block)
end