Sha256: d72cf6590099d2030afe89b3b1f63ccb6e70477d7bb1df688d851e94e4cb2bdb
Contents?: true
Size: 1.55 KB
Versions: 3
Compression:
Stored size: 1.55 KB
Contents
module ActiveZuora class Connection attr_reader :soap_client attr_accessor :custom_header WSDL = File.expand_path('../../../wsdl/zuora.wsdl', __FILE__) def initialize(configuration={}) # Store login credentials and create SOAP client. @username = configuration[:username] @password = configuration[:password] @session_timeout = configuration[:session_timeout] || 15.minutes @soap_client = Savon::Client.new do wsdl.document = configuration[:wsdl] || WSDL http.proxy = configuration[:http_proxy] if configuration[:http_proxy] end end def login # Returns a session_id upon success, raises an exception on failure. # Instance variables aren't available within the soap request block. body = { :username => @username, :password => @password } header = @custom_header @soap_client.request(:login) do soap.body = body soap.header = header end[:login_response][:result][:session] end def request(*args, &block) # instance variables aren't available within the soap request block for some reason. header = { 'SessionHeader' => { 'session' => @session_id } } header.merge!(@custom_header) if @custom_header @soap_client.request(*args) do soap.header = header yield(soap) end rescue Savon::SOAP::Fault => exception # Catch invalid sessions, and re-issue the request. raise unless exception.message =~ /INVALID_SESSION/ @session_id = login request(*args, &block) end end end
Version data entries
3 entries across 3 versions & 1 rubygems
Version | Path |
---|---|
active_zuora-2.4.0 | lib/active_zuora/connection.rb |
active_zuora-2.3.1 | lib/active_zuora/connection.rb |
active_zuora-2.3.0 | lib/active_zuora/connection.rb |