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