Class: Io::Flow::V0::Clients::Tokens
- Inherits:
-
Object
- Object
- Io::Flow::V0::Clients::Tokens
- Defined in:
- lib/flow_commerce/flow_api_v0_client.rb
Instance Method Summary collapse
- #delete_by_id(id) ⇒ Object
-
#get(incoming = {}) ⇒ Object
Get all tokens that you are authorized to view.
-
#get_by_id(id) ⇒ Object
Get metadata for the token with this ID.
-
#get_cleartext_by_id(id) ⇒ Object
Retrieves the token with the actual string token in cleartext.
-
#initialize(client) ⇒ Tokens
constructor
A new instance of Tokens.
-
#post(token_form) ⇒ Object
Create a new token for the requesting user.
-
#post_authentications(token_authentication_form) ⇒ Object
Preferred method to validate a token, obtaining specific information if the token is valid (or a 404 if the token does not exist).
Constructor Details
#initialize(client) ⇒ Tokens
Returns a new instance of Tokens.
4336 4337 4338 |
# File 'lib/flow_commerce/flow_api_v0_client.rb', line 4336 def initialize(client) @client = HttpClient::Preconditions.assert_class('client', client, ::Io::Flow::V0::Client) end |
Instance Method Details
#delete_by_id(id) ⇒ Object
4372 4373 4374 4375 4376 |
# File 'lib/flow_commerce/flow_api_v0_client.rb', line 4372 def delete_by_id(id) HttpClient::Preconditions.assert_class('id', id, String) r = @client.request("/tokens/#{CGI.escape(id)}").delete nil end |
#get(incoming = {}) ⇒ Object
Get all tokens that you are authorized to view. Note that the cleartext token value is never sent. To view the API token itself, see the resource path /tokens/:id/cleartext
4343 4344 4345 4346 4347 4348 4349 4350 4351 4352 4353 4354 4355 4356 |
# File 'lib/flow_commerce/flow_api_v0_client.rb', line 4343 def get(incoming={}) opts = HttpClient::Helper.symbolize_keys(incoming) query = { :id => (x = opts.delete(:id); x.nil? ? nil : HttpClient::Preconditions.assert_class('id', x, Array).map { |v| HttpClient::Preconditions.assert_class('id', v, String) }), :organization => (x = opts.delete(:organization); x.nil? ? nil : HttpClient::Preconditions.assert_class('organization', x, String)), :partner => (x = opts.delete(:partner); x.nil? ? nil : HttpClient::Preconditions.assert_class('partner', x, String)), :mine => (x = opts.delete(:mine); x.nil? ? nil : HttpClient::Preconditions.assert_boolean('mine', x)), :limit => HttpClient::Preconditions.assert_class('limit', (x = opts.delete(:limit); x.nil? ? 25 : x), Integer), :offset => HttpClient::Preconditions.assert_class('offset', (x = opts.delete(:offset); x.nil? ? 0 : x), Integer), :sort => HttpClient::Preconditions.assert_class('sort', (x = opts.delete(:sort); x.nil? ? "-created_at" : x), String) }.delete_if { |k, v| v.nil? } r = @client.request("/tokens").with_query(query).get r.map { |x| ::Io::Flow::V0::Models::Token.from_json(x) } end |
#get_by_id(id) ⇒ Object
Get metadata for the token with this ID
4366 4367 4368 4369 4370 |
# File 'lib/flow_commerce/flow_api_v0_client.rb', line 4366 def get_by_id(id) HttpClient::Preconditions.assert_class('id', id, String) r = @client.request("/tokens/#{CGI.escape(id)}").get ::Io::Flow::V0::Models::Token.from_json(r) end |
#get_cleartext_by_id(id) ⇒ Object
Retrieves the token with the actual string token in cleartext
4379 4380 4381 4382 4383 |
# File 'lib/flow_commerce/flow_api_v0_client.rb', line 4379 def get_cleartext_by_id(id) HttpClient::Preconditions.assert_class('id', id, String) r = @client.request("/tokens/#{CGI.escape(id)}/cleartext").get ::Io::Flow::V0::Models::Cleartext.new(r) end |
#post(token_form) ⇒ Object
Create a new token for the requesting user
4359 4360 4361 4362 4363 |
# File 'lib/flow_commerce/flow_api_v0_client.rb', line 4359 def post(token_form) (x = token_form; x.is_a?(::Io::Flow::V0::Models::TokenForm) ? x : ::Io::Flow::V0::Models::TokenForm.from_json(x)) r = @client.request("/tokens").with_json(token_form.to_json).post ::Io::Flow::V0::Models::Token.from_json(r) end |
#post_authentications(token_authentication_form) ⇒ Object
Preferred method to validate a token, obtaining specific information if the token is valid (or a 404 if the token does not exist). We use an HTTP POST with a form body to enusre that the token itself is not logged in the request logs.
4389 4390 4391 4392 4393 |
# File 'lib/flow_commerce/flow_api_v0_client.rb', line 4389 def post_authentications(token_authentication_form) (x = token_authentication_form; x.is_a?(::Io::Flow::V0::Models::TokenAuthenticationForm) ? x : ::Io::Flow::V0::Models::TokenAuthenticationForm.new(x)) r = @client.request("/tokens/authentications").with_json(token_authentication_form.to_json).post ::Io::Flow::V0::Models::TokenReference.from_json(r) end |