Class: QboApi
- Inherits:
-
Object
show all
- Extended by:
- Configuration
- Includes:
- All, Attachment, Builder, Entity, Finder, Setter, Supporting, Util
- Defined in:
- lib/qbo_api/error.rb,
lib/qbo_api.rb,
lib/qbo_api/all.rb,
lib/qbo_api/util.rb,
lib/qbo_api/entity.rb,
lib/qbo_api/finder.rb,
lib/qbo_api/setter.rb,
lib/qbo_api/builder.rb,
lib/qbo_api/version.rb,
lib/qbo_api/attachment.rb,
lib/qbo_api/supporting.rb,
lib/qbo_api/configuration.rb
Overview
200 OK The request succeeded. However, the response body may contain a <Fault> element, indicating an error. 400 Bad request Generally, the request cannot be fulfilled due to bad syntax. In some cases, this response code is returned for a request with bad authorization data. 401 Unauthorized Authentication or authorization has failed. 403 Forbidden The resource is forbidden. 404 Not Found The resource is not found. 429 Too Many Requests API Throttling/ Rate limiting 500 Internal Server Error An error occurred on the server while processing the request. Resubmit request once; if it persists, contact developer support. 503 Service Unavailable The service is temporarily unavailable. Custom error class for rescuing from all QuickBooks Online errors
Defined Under Namespace
Modules: All, Attachment, Builder, Configuration, Entity, Finder, Setter, Supporting, Util
Classes: BadRequest, Error, Forbidden, InternalServerError, NotFound, NotImplementedError, ServiceUnavailable, TooManyRequests, Unauthorized
Constant Summary
collapse
- REQUEST_TOKEN_URL =
'https://oauth.intuit.com/oauth/v1/get_request_token'
- ACCESS_TOKEN_URL =
'https://oauth.intuit.com/oauth/v1/get_access_token'
- APP_CENTER_BASE =
'https://appcenter.intuit.com'
- APP_CENTER_URL =
APP_CENTER_BASE + '/Connect/Begin?oauth_token='
- V3_ENDPOINT_BASE_URL =
'https://sandbox-quickbooks.api.intuit.com/v3/company/'
- PAYMENTS_API_BASE_URL =
'https://sandbox.api.intuit.com/quickbooks/v4/payments'
- APP_CONNECTION_URL =
APP_CENTER_BASE + '/api/v1/connection'
- VERSION =
"1.7.0"
Instance Attribute Summary collapse
Attributes included from Util
#minor_version
Instance Method Summary
collapse
-
#connection(url: get_endpoint) ⇒ Object
-
#create(entity, payload:, params: nil) ⇒ Object
-
#deactivate(entity, id:) ⇒ Object
-
#delete(entity, id:) ⇒ Object
-
#disconnect ⇒ Object
-
#initialize(token: nil, token_secret: nil, access_token: nil, realm_id:, consumer_key: nil, consumer_secret: nil, endpoint: :accounting) ⇒ QboApi
constructor
A new instance of QboApi.
-
#reconnect ⇒ Object
-
#request(method, path:, entity: nil, payload: nil, params: nil) ⇒ Object
-
#response(resp, entity: nil) ⇒ Object
-
#update(entity, id:, payload:, params: nil) ⇒ Object
log, log=, logger, logger=, minor_version, minor_version=, production, production=, request_id, request_id=
Methods included from All
#all
Methods included from Finder
#get, #query, #to_quote_or_not
Methods included from Attachment
#upload_attachment
Methods included from Util
#add_minor_version_to, #add_params_to_path, #add_request_id_to, #build_all_query, #cdc_time, #esc, #finalize_path, #join_or_start_where_clause!, #uuid
Methods included from Entity
#entity_path, #extract_entity_from_query, #is_name_list_entity?, #is_transaction_entity?, #name_list_entities, #singular, #snake_to_camel, #supporting_entities, #transaction_entities
Methods included from Supporting
#batch, #cdc, #reports
Constructor Details
#initialize(token: nil, token_secret: nil, access_token: nil, realm_id:, consumer_key: nil, consumer_secret: nil, endpoint: :accounting) ⇒ QboApi
Returns a new instance of QboApi.
42
43
44
45
46
47
48
49
50
51
|
# File 'lib/qbo_api.rb', line 42
def initialize(token: nil, token_secret: nil, access_token: nil, realm_id:,
consumer_key: nil, consumer_secret: nil, endpoint: :accounting)
@consumer_key = consumer_key || (defined?(CONSUMER_KEY) ? CONSUMER_KEY : nil)
@consumer_secret = consumer_secret || (defined?(CONSUMER_SECRET) ? CONSUMER_SECRET : nil)
@token = token
@token_secret = token_secret
@access_token = access_token
@realm_id = realm_id
@endpoint = endpoint
end
|
Instance Attribute Details
#realm_id ⇒ Object
Returns the value of attribute realm_id.
32
33
34
|
# File 'lib/qbo_api.rb', line 32
def realm_id
@realm_id
end
|
Instance Method Details
#connection(url: get_endpoint) ⇒ Object
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
|
# File 'lib/qbo_api.rb', line 53
def connection(url: get_endpoint)
@connection ||= Faraday.new(url: url) do |faraday|
faraday.['Content-Type'] = 'application/json;charset=UTF-8'
faraday.['Accept'] = 'application/json'
if @token != nil
faraday.request :oauth, oauth_data
elsif @access_token != nil
faraday.request :oauth2, @access_token, token_type: 'bearer'
else
raise QboApi::Error.new error_body: 'Must set either the token or access_token'
end
faraday.request :url_encoded
faraday.use FaradayMiddleware::RaiseHttpException
faraday.response :detailed_logger, QboApi.logger if QboApi.log
faraday.adapter Faraday.default_adapter
end
end
|
#create(entity, payload:, params: nil) ⇒ Object
71
72
73
|
# File 'lib/qbo_api.rb', line 71
def create(entity, payload:, params: nil)
request(:post, entity: entity, path: entity_path(entity), payload: payload, params: params)
end
|
#deactivate(entity, id:) ⇒ Object
88
89
90
91
92
93
|
# File 'lib/qbo_api.rb', line 88
def deactivate(entity, id:)
err_msg = "Deactivate is only for name list entities. Use .delete instead"
raise QboApi::NotImplementedError.new, err_msg unless is_name_list_entity?(entity)
payload = set_deactivate(entity, id)
request(:post, entity: entity, path: entity_path(entity), payload: payload)
end
|
#delete(entity, id:) ⇒ Object
80
81
82
83
84
85
86
|
# File 'lib/qbo_api.rb', line 80
def delete(entity, id:)
err_msg = "Delete is only for transaction entities. Use .deactivate instead"
raise QboApi::NotImplementedError.new, err_msg unless is_transaction_entity?(entity)
path = add_params_to_path(path: entity_path(entity), params: { operation: :delete })
payload = set_update(entity, id)
request(:post, entity: entity, path: path, payload: payload)
end
|
#disconnect ⇒ Object
96
97
98
99
|
# File 'lib/qbo_api.rb', line 96
def disconnect
path = "#{APP_CONNECTION_URL}/disconnect"
request(:get, path: path)
end
|
#reconnect ⇒ Object
101
102
103
104
|
# File 'lib/qbo_api.rb', line 101
def reconnect
path = "#{APP_CONNECTION_URL}/reconnect"
request(:get, path: path)
end
|
#request(method, path:, entity: nil, payload: nil, params: nil) ⇒ Object
106
107
108
109
110
111
112
113
114
115
116
117
118
|
# File 'lib/qbo_api.rb', line 106
def request(method, path:, entity: nil, payload: nil, params: nil)
raw_response = connection.send(method) do |req|
path = finalize_path(path, method: method, params: params)
case method
when :get, :delete
req.url path
when :post, :put
req.url path
req.body = payload.to_json
end
end
response(raw_response, entity: entity)
end
|
#response(resp, entity: nil) ⇒ Object
120
121
122
123
124
125
126
127
128
129
130
|
# File 'lib/qbo_api.rb', line 120
def response(resp, entity: nil)
data = JSON.parse(resp.body)
if entity
entity_response(data, entity)
else
data
end
rescue => e
data
end
|
#update(entity, id:, payload:, params: nil) ⇒ Object
75
76
77
78
|
# File 'lib/qbo_api.rb', line 75
def update(entity, id:, payload:, params: nil)
payload.merge!(set_update(entity, id))
request(:post, entity: entity, path: entity_path(entity), payload: payload, params: params)
end
|