Class: WolfCore::ApplicationService
Instance Method Summary
collapse
Methods included from HashUtils
#deep_to_h
#log_object
#get_event_params, #invoke_lambda, #parse_lambda_response, #result_to_response, #validate_lambda_response
#base64_encoded?, #camelcase_to_spaces, #clean_phone_number, #deep_parse_json, #hash_str_to_json, #remove_blank_spaces, #remove_non_alphanumeric_chars, #split_address, #split_name, #to_kebab_case, #to_snake_case, #valid_json?, #valid_url?
#raise_service_error
#async_http_get, #async_http_patch, #async_http_post, #async_http_put, #http_get, #http_patch, #http_post, #http_put, #parse_http_response, #parsed_http_get, #parsed_http_patch, #parsed_http_post, #parsed_http_put, #response_success?, #safe_http_get, #safe_http_patch, #safe_http_post, #safe_http_put, #validate_http_response
Methods included from AsyncUtils
#run_async
Instance Method Details
#call ⇒ Object
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
|
# File 'lib/wolf_core/application/application_service.rb', line 9
def call
process
rescue StandardError => e
on_error(e) if respond_to?(:on_error, true)
on_timeout(e) if is_timeout_error?(e) && respond_to?(:on_timeout, true)
common_data = { backtrace: e.backtrace }
common_data.merge!(build_result_data) if respond_to?(:build_result_data, true)
if e.instance_of?(WolfCore::ServiceException)
return Result.failure(
error: e.error.to_h.merge(common_data)
)
end
Honeybadger.notify(e, sync: true)
Result.failure(error: { message: e.message }.merge(common_data))
end
|
#get_salesforce_access_token ⇒ Object
54
55
56
57
58
|
# File 'lib/wolf_core/application/application_service.rb', line 54
def get_salesforce_access_token
result = WolfCore::SalesforceOauthService.new.call
raise_failed_result(result)
result.data.access_token
end
|
#get_salesforce_foreign_object(salesforce_access_token:, record_id:) ⇒ Object
60
61
62
63
64
65
66
67
|
# File 'lib/wolf_core/application/application_service.rb', line 60
def get_salesforce_foreign_object(salesforce_access_token:, record_id:)
foreign_object = salesforce_http_get(
salesforce_access_token: salesforce_access_token,
query: { calltype: 'getRecord', RecordId: record_id }
)
log_object foreign_object, title: 'foreign object is'
foreign_object
end
|
#get_wolf_token ⇒ Object
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
|
# File 'lib/wolf_core/application/application_service.rb', line 85
def get_wolf_token
response = http_post(
query: { tenant: ENV['TENANT'] },
url: "#{ENV['WOLF_PLATFORM_URL']}/api/v1/sign_in",
body: {
email: ENV['WOLF_ADMIN_EMAIL'],
password: ENV['WOLF_ADMIN_PASSWORD']
}
)
validate_http_response(
response: response, message: 'Failed to get wolf token'
)
response_body = JSON.parse(response.body)
wolf_token = response_body.dig('user', 'authentication_token')
puts "wolf token is #{wolf_token}"
wolf_token
end
|
#process ⇒ Object
27
28
29
|
# File 'lib/wolf_core/application/application_service.rb', line 27
def process
raise NotImplementedError
end
|
#raise_failed_result(result) ⇒ Object
31
32
33
34
35
|
# File 'lib/wolf_core/application/application_service.rb', line 31
def raise_failed_result(result)
return if result.success?
raise_service_error(result.error.to_h)
end
|
#remove_non_permitted_parameters(params, allowed_params) ⇒ Object
46
47
48
49
50
51
52
|
# File 'lib/wolf_core/application/application_service.rb', line 46
def remove_non_permitted_parameters(params, allowed_params)
permitted = params.slice(*allowed_params)
if permitted.blank?
raise_service_error({ message: "There are not permitted parameters"})
end
return permitted
end
|
#salesforce_http_get(salesforce_access_token:, query: nil) ⇒ Object
69
70
71
72
73
74
75
76
77
|
# File 'lib/wolf_core/application/application_service.rb', line 69
def salesforce_http_get(salesforce_access_token:, query: nil)
response = http_get(
url: ENV['SALESFORCE_URL'],
headers: { 'Authorization' => "Bearer #{salesforce_access_token}" },
query: query
)
validate_salesforce_response(response)
JSON.parse(response.parsed_response)
end
|
#validate_presence(object, message, error_data: {}) ⇒ Object
37
38
39
40
41
42
43
44
|
# File 'lib/wolf_core/application/application_service.rb', line 37
def validate_presence(object, message, error_data: {})
return if object.present?
error_data ||= {}
error_data = error_data.merge({ message: message })
raise_service_error(error_data)
end
|
#validate_salesforce_response(response) ⇒ Object
79
80
81
82
83
|
# File 'lib/wolf_core/application/application_service.rb', line 79
def validate_salesforce_response(response)
return if response.code == 200
message = JSON.parse(response.body).first['message']
raise_service_error({ message: message, response: response })
end
|