Sha256: 27d7a74df41bb69a2dc07fc1f72b9eef92aad7de0596b3b6d73a17ff81ba0248

Contents?: true

Size: 1.57 KB

Versions: 1

Compression:

Stored size: 1.57 KB

Contents

module SoapyCake
  class Client
    HEADERS = { 'Content-Type' => 'application/soap+xml;charset=UTF-8' }.freeze

    def initialize(opts = {})
      @domain = opts.fetch(:domain, ENV['CAKE_DOMAIN']) || fail(Error, 'Cake domain missing')
      @api_key = opts.fetch(:api_key, ENV['CAKE_API_KEY']) || fail(Error, 'Cake API key missing')

      time_offset = opts.fetch(:time_offset, ENV['CAKE_TIME_OFFSET'])
      time_zone = opts.fetch(:time_zone, ENV['CAKE_TIME_ZONE'])
      @time_converter = TimeConverter.new(time_zone, time_offset)

      @opts = opts
    end

    def xml_response?
      opts[:xml_response] == true
    end

    protected

    attr_reader :domain, :api_key, :time_converter, :opts, :logger

    def run(request)
      request.api_key = api_key
      request.time_converter = time_converter

      response = Response.new(response_body(request), request.short_response?, time_converter)
      xml_response? ? response.to_xml : response.to_enum
    end

    private

    def logger
      @logger ||= opts[:logger] || (defined?(::Rails) && ::Rails.logger)
    end

    def response_body(request)
      request.opts[:response].presence || http_response(request)
    end

    def http_response(request)
      logger.info("soapy_cake:request #{request}") if logger

      url = "https://#{domain}#{request.path}"
      http_response = HTTParty.post(url, headers: HEADERS, body: request.xml, timeout: NET_TIMEOUT)

      fail RequestFailed, "Request failed with HTTP #{http_response.code}: " \
        "#{http_response.body}" unless http_response.success?

      http_response
    end
  end
end

Version data entries

1 entries across 1 versions & 1 rubygems

Version Path
soapy_cake-1.19.0 lib/soapy_cake/client.rb