Class: OcxClient::Auth
Instance Method Summary collapse
- #format_params(params) ⇒ Object
-
#initialize(access_key, secret_key) ⇒ Auth
constructor
A new instance of Auth.
- #payload(verb, path, params) ⇒ Object
- #sign(verb, path, params) ⇒ Object
- #signed_challenge(challenge) ⇒ Object
- #signed_params(verb, path, params = {}) ⇒ Object
Constructor Details
#initialize(access_key, secret_key) ⇒ Auth
Returns a new instance of Auth.
6 7 8 9 |
# File 'lib/ocx_client/auth.rb', line 6 def initialize(access_key, secret_key) @access_key = access_key @secret_key = secret_key end |
Instance Method Details
#format_params(params) ⇒ Object
30 31 32 33 34 35 |
# File 'lib/ocx_client/auth.rb', line 30 def format_params(params) params = params.symbolize_keys params[:access_key] ||= @access_key params[:tonce] ||= (Time.now.to_f*1000).to_i params end |
#payload(verb, path, params) ⇒ Object
26 27 28 |
# File 'lib/ocx_client/auth.rb', line 26 def payload(verb, path, params) "#{verb.upcase}|#{path}|#{params}" end |
#sign(verb, path, params) ⇒ Object
22 23 24 |
# File 'lib/ocx_client/auth.rb', line 22 def sign(verb, path, params) OpenSSL::HMAC.hexdigest 'SHA256', @secret_key, payload(verb, path, params) end |
#signed_challenge(challenge) ⇒ Object
11 12 13 14 |
# File 'lib/ocx_client/auth.rb', line 11 def signed_challenge(challenge) signature = OpenSSL::HMAC.hexdigest 'SHA256', @secret_key, "#{@access_key}#{challenge}" {auth: {access_key: @access_key, answer: signature}} end |
#signed_params(verb, path, params = {}) ⇒ Object
16 17 18 19 20 |
# File 'lib/ocx_client/auth.rb', line 16 def signed_params(verb, path, params={}) params = format_params params signature = sign verb, path, URI.unescape(params.to_query) params.merge(signature: signature) end |