Class: Gitlab::Triage::NetworkAdapters::HttpartyAdapter
- Inherits:
-
BaseAdapter
- Object
- BaseAdapter
- Gitlab::Triage::NetworkAdapters::HttpartyAdapter
show all
- Defined in:
- lib/gitlab/triage/network_adapters/httparty_adapter.rb
Constant Summary
Constants inherited
from BaseAdapter
BaseAdapter::USER_AGENT
Instance Attribute Summary
Attributes inherited from BaseAdapter
#options
Instance Method Summary
collapse
Methods inherited from BaseAdapter
#initialize
Instance Method Details
#delete(token, url) ⇒ Object
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
|
# File 'lib/gitlab/triage/network_adapters/httparty_adapter.rb', line 58
def delete(token, url)
response = HTTParty.delete(
url,
headers: {
'User-Agent' => USER_AGENT,
'PRIVATE-TOKEN' => token
}
)
raise_on_unauthorized_error!(response)
raise_on_internal_server_error!(response)
raise_on_too_many_requests!(response)
{
results: response.parsed_response,
ratelimit_remaining: response.["ratelimit-remaining"].to_i,
ratelimit_reset_at: Time.at(response.["ratelimit-reset"].to_i)
}
end
|
#get(token, url) ⇒ Object
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
|
# File 'lib/gitlab/triage/network_adapters/httparty_adapter.rb', line 13
def get(token, url)
response = HTTParty.get(
url,
headers: {
'User-Agent' => USER_AGENT,
'Content-type' => 'application/json',
'PRIVATE-TOKEN' => token
}
)
raise_on_unauthorized_error!(response)
raise_on_internal_server_error!(response)
raise_on_too_many_requests!(response)
{
more_pages: (response.["x-next-page"].to_s != ""),
next_page_url: next_page_url(url, response),
results: response.parsed_response,
ratelimit_remaining: response.["ratelimit-remaining"].to_i,
ratelimit_reset_at: Time.at(response.["ratelimit-reset"].to_i)
}
end
|
#next_page_url(url, response) ⇒ Object
104
105
106
107
108
109
110
111
112
113
114
|
# File 'lib/gitlab/triage/network_adapters/httparty_adapter.rb', line 104
def next_page_url(url, response)
return unless response.['x-next-page'].present?
next_page = "&page=#{response.['x-next-page']}"
if url.include?('&page')
url.gsub(/&page=\d+/, next_page)
else
url + next_page
end
end
|
#post(token, url, body) ⇒ Object
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
|
# File 'lib/gitlab/triage/network_adapters/httparty_adapter.rb', line 36
def post(token, url, body)
response = HTTParty.post(
url,
body: body.to_json,
headers: {
'User-Agent' => "GitLab Triage #{Gitlab::Triage::VERSION}",
'Content-type' => 'application/json',
'PRIVATE-TOKEN' => token
}
)
raise_on_unauthorized_error!(response)
raise_on_internal_server_error!(response)
raise_on_too_many_requests!(response)
{
results: response.parsed_response,
ratelimit_remaining: response.["ratelimit-remaining"].to_i,
ratelimit_reset_at: Time.at(response.["ratelimit-reset"].to_i)
}
end
|
#raise_on_internal_server_error!(response) ⇒ Object
88
89
90
91
92
93
94
|
# File 'lib/gitlab/triage/network_adapters/httparty_adapter.rb', line 88
def raise_on_internal_server_error!(response)
return unless response.response.is_a?(Net::HTTPInternalServerError)
puts Gitlab::Triage::UI.debug response.inspect if options.debug
raise Errors::Network::InternalServerError, 'Internal server error encountered!'
end
|
#raise_on_too_many_requests!(response) ⇒ Object
96
97
98
99
100
101
102
|
# File 'lib/gitlab/triage/network_adapters/httparty_adapter.rb', line 96
def raise_on_too_many_requests!(response)
return unless response.response.is_a?(Net::HTTPTooManyRequests)
puts Gitlab::Triage::UI.debug response.inspect if options.debug
raise Errors::Network::TooManyRequests, 'Too many requests made!'
end
|
#raise_on_unauthorized_error!(response) ⇒ Object
80
81
82
83
84
85
86
|
# File 'lib/gitlab/triage/network_adapters/httparty_adapter.rb', line 80
def raise_on_unauthorized_error!(response)
return unless response.response.is_a?(Net::HTTPUnauthorized)
puts Gitlab::Triage::UI.debug response.inspect if options.debug
raise 'The provided token is unauthorized!'
end
|