scalingo 3.5.0 → 4.0.beta1

Sign up to get free protection for your applications and to get access to all the features.
Files changed (241) hide show
  1. checksums.yaml +4 -4
  2. data/.rubocop.yml +41 -0
  3. data/CHANGELOG.md +14 -1
  4. data/Gemfile +2 -0
  5. data/README.md +13 -62
  6. data/bin/console +11 -1
  7. data/bin/lint +2 -0
  8. data/bin/setup +21 -6
  9. data/bin/specs +2 -0
  10. data/lib/scalingo/api/client.rb +21 -39
  11. data/lib/scalingo/api/endpoint.rb +88 -11
  12. data/lib/scalingo/auth/keys.rb +4 -50
  13. data/lib/scalingo/auth/scm_integrations.rb +4 -51
  14. data/lib/scalingo/auth/tokens.rb +5 -72
  15. data/lib/scalingo/auth/two_factor_auth.rb +4 -55
  16. data/lib/scalingo/auth/user.rb +3 -38
  17. data/lib/scalingo/bearer_token.rb +16 -9
  18. data/lib/scalingo/billing/profile.rb +3 -40
  19. data/lib/scalingo/client.rb +21 -31
  20. data/lib/scalingo/configuration.rb +0 -24
  21. data/lib/scalingo/core_client.rb +9 -29
  22. data/lib/scalingo/database/backups.rb +9 -0
  23. data/lib/scalingo/database/databases.rb +8 -0
  24. data/lib/scalingo/{regional_database.rb → database.rb} +3 -3
  25. data/lib/scalingo/faraday/extract_meta.rb +33 -0
  26. data/lib/scalingo/faraday/extract_root_value.rb +18 -0
  27. data/lib/scalingo/faraday/response.rb +36 -0
  28. data/lib/scalingo/regional/addons.rb +18 -130
  29. data/lib/scalingo/regional/apps.rb +10 -103
  30. data/lib/scalingo/regional/autoscalers.rb +5 -64
  31. data/lib/scalingo/regional/collaborators.rb +4 -51
  32. data/lib/scalingo/regional/containers.rb +4 -51
  33. data/lib/scalingo/regional/deployments.rb +3 -38
  34. data/lib/scalingo/regional/domains.rb +5 -64
  35. data/lib/scalingo/regional/environment.rb +6 -77
  36. data/lib/scalingo/regional/events.rb +5 -50
  37. data/lib/scalingo/regional/logs.rb +10 -28
  38. data/lib/scalingo/regional/metrics.rb +2 -34
  39. data/lib/scalingo/regional/notifiers.rb +7 -90
  40. data/lib/scalingo/regional/operations.rb +5 -18
  41. data/lib/scalingo/regional/scm_repo_links.rb +8 -103
  42. data/lib/scalingo/token_holder.rb +1 -46
  43. data/lib/scalingo/version.rb +1 -1
  44. data/scalingo.gemspec +3 -0
  45. metadata +59 -200
  46. data/lib/scalingo/api/response.rb +0 -69
  47. data/lib/scalingo/regional_database/backups.rb +0 -44
  48. data/lib/scalingo/regional_database/databases.rb +0 -31
  49. data/samples/auth/keys/_meta.json +0 -13
  50. data/samples/auth/keys/all-200.json +0 -62
  51. data/samples/auth/keys/create-201.json +0 -67
  52. data/samples/auth/keys/create-422.json +0 -34
  53. data/samples/auth/keys/destroy-204.json +0 -19
  54. data/samples/auth/keys/destroy-404.json +0 -19
  55. data/samples/auth/keys/show-200.json +0 -60
  56. data/samples/auth/keys/show-404.json +0 -19
  57. data/samples/auth/scm_integrations/_meta.json +0 -14
  58. data/samples/auth/scm_integrations/all-200.json +0 -41
  59. data/samples/auth/scm_integrations/create-201.json +0 -41
  60. data/samples/auth/scm_integrations/create-422.json +0 -36
  61. data/samples/auth/scm_integrations/destroy-204.json +0 -15
  62. data/samples/auth/scm_integrations/destroy-404.json +0 -23
  63. data/samples/auth/scm_integrations/show-200.json +0 -34
  64. data/samples/auth/scm_integrations/show-404.json +0 -23
  65. data/samples/auth/tokens/_meta.json +0 -13
  66. data/samples/auth/tokens/all-200.json +0 -32
  67. data/samples/auth/tokens/create-201.json +0 -37
  68. data/samples/auth/tokens/destroy-204.json +0 -19
  69. data/samples/auth/tokens/destroy-404.json +0 -19
  70. data/samples/auth/tokens/exchange-200.json +0 -25
  71. data/samples/auth/tokens/exchange-401.json +0 -24
  72. data/samples/auth/tokens/renew-200.json +0 -32
  73. data/samples/auth/tokens/renew-404.json +0 -20
  74. data/samples/auth/two_factor_auth/_meta.json +0 -10
  75. data/samples/auth/two_factor_auth/disable-not-initiated.json +0 -23
  76. data/samples/auth/two_factor_auth/disable-success.json +0 -29
  77. data/samples/auth/two_factor_auth/initiate-already-enabled.json +0 -29
  78. data/samples/auth/two_factor_auth/initiate-success.json +0 -36
  79. data/samples/auth/two_factor_auth/initiate-wrong-provider.json +0 -29
  80. data/samples/auth/two_factor_auth/status.json +0 -29
  81. data/samples/auth/two_factor_auth/validate-not-initiated.json +0 -29
  82. data/samples/auth/two_factor_auth/validate-success.json +0 -49
  83. data/samples/auth/two_factor_auth/validate-wrong.json +0 -29
  84. data/samples/auth/user/_meta.json +0 -10
  85. data/samples/auth/user/self.json +0 -54
  86. data/samples/auth/user/stop-free-trial.json +0 -24
  87. data/samples/auth/user/update-200.json +0 -59
  88. data/samples/auth/user/update-422.json +0 -33
  89. data/samples/billing/profile/_meta.json +0 -23
  90. data/samples/billing/profile/create-201.json +0 -50
  91. data/samples/billing/profile/create-400.json +0 -27
  92. data/samples/billing/profile/create-422.json +0 -44
  93. data/samples/billing/profile/show-200.json +0 -41
  94. data/samples/billing/profile/show-404.json +0 -22
  95. data/samples/billing/profile/update-200.json +0 -47
  96. data/samples/billing/profile/update-422.json +0 -32
  97. data/samples/regional/addons/_meta.json +0 -22
  98. data/samples/regional/addons/categories-guest.json +0 -36
  99. data/samples/regional/addons/categories-logged.json +0 -37
  100. data/samples/regional/addons/destroy-204.json +0 -19
  101. data/samples/regional/addons/destroy-404.json +0 -24
  102. data/samples/regional/addons/find-200.json +0 -48
  103. data/samples/regional/addons/find-404.json +0 -24
  104. data/samples/regional/addons/for-200.json +0 -50
  105. data/samples/regional/addons/providers-guest.json +0 -588
  106. data/samples/regional/addons/providers-logged.json +0 -705
  107. data/samples/regional/addons/provision-201.json +0 -58
  108. data/samples/regional/addons/provision-400.json +0 -29
  109. data/samples/regional/addons/sso-200.json +0 -49
  110. data/samples/regional/addons/sso-404.json +0 -24
  111. data/samples/regional/addons/token-200.json +0 -49
  112. data/samples/regional/addons/token-404.json +0 -24
  113. data/samples/regional/addons/update-200.json +0 -58
  114. data/samples/regional/addons/update-404.json +0 -30
  115. data/samples/regional/apps/_meta.json +0 -52
  116. data/samples/regional/apps/all.json +0 -99
  117. data/samples/regional/apps/create-201.json +0 -66
  118. data/samples/regional/apps/create-422.json +0 -34
  119. data/samples/regional/apps/destroy-204.json +0 -19
  120. data/samples/regional/apps/destroy-404.json +0 -24
  121. data/samples/regional/apps/destroy-422.json +0 -27
  122. data/samples/regional/apps/find-200.json +0 -60
  123. data/samples/regional/apps/find-404.json +0 -24
  124. data/samples/regional/apps/logs_url.json +0 -62
  125. data/samples/regional/apps/rename-200.json +0 -65
  126. data/samples/regional/apps/rename-404.json +0 -29
  127. data/samples/regional/apps/rename-422.json +0 -33
  128. data/samples/regional/apps/transfer-200.json +0 -65
  129. data/samples/regional/apps/transfer-404.json +0 -27
  130. data/samples/regional/apps/transfer-422.json +0 -34
  131. data/samples/regional/apps/update-200.json +0 -66
  132. data/samples/regional/apps/update-stack-404.json +0 -30
  133. data/samples/regional/autoscalers/_meta.json +0 -27
  134. data/samples/regional/autoscalers/create-201.json +0 -49
  135. data/samples/regional/autoscalers/create-500.json +0 -32
  136. data/samples/regional/autoscalers/destroy-204.json +0 -20
  137. data/samples/regional/autoscalers/destroy-404.json +0 -25
  138. data/samples/regional/autoscalers/find-200.json +0 -39
  139. data/samples/regional/autoscalers/find-404.json +0 -25
  140. data/samples/regional/autoscalers/for-200.json +0 -41
  141. data/samples/regional/autoscalers/update-200.json +0 -45
  142. data/samples/regional/autoscalers/update-404.json +0 -31
  143. data/samples/regional/autoscalers/update-500.json +0 -30
  144. data/samples/regional/collaborators/_meta.json +0 -17
  145. data/samples/regional/collaborators/accept-200.json +0 -60
  146. data/samples/regional/collaborators/accept-400.json +0 -24
  147. data/samples/regional/collaborators/accept-404.json +0 -24
  148. data/samples/regional/collaborators/destroy-204.json +0 -19
  149. data/samples/regional/collaborators/destroy-404.json +0 -24
  150. data/samples/regional/collaborators/for-200.json +0 -34
  151. data/samples/regional/collaborators/invite-201.json +0 -37
  152. data/samples/regional/collaborators/invite-422.json +0 -34
  153. data/samples/regional/containers/_meta.json +0 -25
  154. data/samples/regional/containers/for-200.json +0 -39
  155. data/samples/regional/containers/restart-202.json +0 -28
  156. data/samples/regional/containers/restart-422.json +0 -33
  157. data/samples/regional/containers/scale-202.json +0 -48
  158. data/samples/regional/containers/scale-422.json +0 -36
  159. data/samples/regional/containers/sizes-guest.json +0 -115
  160. data/samples/regional/containers/sizes-logged.json +0 -116
  161. data/samples/regional/deployments/_meta.json +0 -8
  162. data/samples/regional/deployments/find-200.json +0 -45
  163. data/samples/regional/deployments/find-404.json +0 -24
  164. data/samples/regional/deployments/for-with-paging.json +0 -35
  165. data/samples/regional/deployments/for-without-pages.json +0 -56
  166. data/samples/regional/deployments/logs-200.json +0 -22
  167. data/samples/regional/deployments/logs-404.json +0 -24
  168. data/samples/regional/domains/_meta.json +0 -21
  169. data/samples/regional/domains/create-201.json +0 -44
  170. data/samples/regional/domains/create-422.json +0 -33
  171. data/samples/regional/domains/destroy-204.json +0 -19
  172. data/samples/regional/domains/destroy-404.json +0 -24
  173. data/samples/regional/domains/find-200.json +0 -38
  174. data/samples/regional/domains/find-404.json +0 -24
  175. data/samples/regional/domains/for-200.json +0 -40
  176. data/samples/regional/domains/update-200.json +0 -44
  177. data/samples/regional/domains/update-404.json +0 -30
  178. data/samples/regional/domains/update-422.json +0 -33
  179. data/samples/regional/environment/_meta.json +0 -43
  180. data/samples/regional/environment/bulk-destroy-204.json +0 -19
  181. data/samples/regional/environment/bulk-update-200.json +0 -70
  182. data/samples/regional/environment/create-201.json +0 -36
  183. data/samples/regional/environment/create-422.json +0 -37
  184. data/samples/regional/environment/destroy-204.json +0 -19
  185. data/samples/regional/environment/destroy-404.json +0 -24
  186. data/samples/regional/environment/for-200.json +0 -31
  187. data/samples/regional/environment/update-200.json +0 -35
  188. data/samples/regional/environment/update-404.json +0 -30
  189. data/samples/regional/events/_meta.json +0 -3
  190. data/samples/regional/events/all-200.json +0 -619
  191. data/samples/regional/events/categories-guest.json +0 -66
  192. data/samples/regional/events/categories-logged.json +0 -67
  193. data/samples/regional/events/for-200.json +0 -404
  194. data/samples/regional/events/types-guest.json +0 -288
  195. data/samples/regional/events/types-logged.json +0 -289
  196. data/samples/regional/logs/_meta.json +0 -11
  197. data/samples/regional/logs/archives-200.json +0 -28
  198. data/samples/regional/logs/get-guest-200.json +0 -18
  199. data/samples/regional/logs/get-logged-200.json +0 -19
  200. data/samples/regional/logs/get-with-limit-200.json +0 -18
  201. data/samples/regional/metrics/_meta.json +0 -15
  202. data/samples/regional/metrics/for-invalid-400.json +0 -23
  203. data/samples/regional/metrics/for-valid-cpu-200.json +0 -747
  204. data/samples/regional/metrics/for-valid-router-404.json +0 -23
  205. data/samples/regional/metrics/types-guest.json +0 -66
  206. data/samples/regional/metrics/types-logged.json +0 -67
  207. data/samples/regional/notifiers/_meta.json +0 -23
  208. data/samples/regional/notifiers/create-201.json +0 -55
  209. data/samples/regional/notifiers/create-404.json +0 -30
  210. data/samples/regional/notifiers/create-422.json +0 -36
  211. data/samples/regional/notifiers/destroy-204.json +0 -19
  212. data/samples/regional/notifiers/destroy-404.json +0 -24
  213. data/samples/regional/notifiers/find-200.json +0 -47
  214. data/samples/regional/notifiers/find-404.json +0 -24
  215. data/samples/regional/notifiers/for-200.json +0 -49
  216. data/samples/regional/notifiers/platforms-guest.json +0 -184
  217. data/samples/regional/notifiers/platforms-logged.json +0 -185
  218. data/samples/regional/notifiers/test-200.json +0 -22
  219. data/samples/regional/notifiers/test-404.json +0 -25
  220. data/samples/regional/notifiers/update-200.json +0 -53
  221. data/samples/regional/operations/_meta.json +0 -5
  222. data/samples/regional/operations/find-200.json +0 -31
  223. data/samples/regional/operations/find-404.json +0 -24
  224. data/samples/regional/scm_repo_links/_meta.json +0 -22
  225. data/samples/regional/scm_repo_links/create-201.json +0 -54
  226. data/samples/regional/scm_repo_links/destroy-204.json +0 -15
  227. data/samples/regional/scm_repo_links/manual-deploy-200.json +0 -32
  228. data/samples/regional/scm_repo_links/show-200.json +0 -43
  229. data/samples/regional/scm_repo_links/update-200.json +0 -50
  230. data/samples/regional_database/backups/_meta.json +0 -4
  231. data/samples/regional_database/backups/archive-200.json +0 -24
  232. data/samples/regional_database/backups/archive-400.json +0 -24
  233. data/samples/regional_database/backups/create-201.json +0 -32
  234. data/samples/regional_database/backups/create-400.json +0 -24
  235. data/samples/regional_database/backups/for-200.json +0 -52
  236. data/samples/regional_database/backups/for-400.json +0 -24
  237. data/samples/regional_database/databases/_meta.json +0 -3
  238. data/samples/regional_database/databases/find-200.json +0 -47
  239. data/samples/regional_database/databases/find-400.json +0 -24
  240. data/samples/regional_database/databases/upgrade-202.json +0 -39
  241. data/samples/regional_database/databases/upgrade-400.json +0 -24
@@ -1,55 +1,10 @@
1
1
  module Scalingo
2
2
  class Regional::Events < API::Endpoint
3
- def all(payload = {}, headers = nil, &block)
4
- data = payload.compact
5
-
6
- response = connection.get(
7
- "events",
8
- data,
9
- headers,
10
- &block
11
- )
12
-
13
- unpack(:events) { response }
14
- end
15
-
16
- def for(app_id, payload = {}, headers = nil, &block)
17
- data = payload.compact
18
-
19
- response = connection.get(
20
- "apps/#{app_id}/events",
21
- data,
22
- headers,
23
- &block
24
- )
25
-
26
- unpack(:events) { response }
27
- end
28
-
29
- def types(headers = nil, &block)
30
- data = nil
31
-
32
- response = connection(fallback_to_guest: true).get(
33
- "event_types",
34
- data,
35
- headers,
36
- &block
37
- )
38
-
39
- unpack(:event_types) { response }
40
- end
41
-
42
- def categories(headers = nil, &block)
43
- data = nil
44
-
45
- response = connection(fallback_to_guest: true).get(
46
- "event_categories",
47
- data,
48
- headers,
49
- &block
50
- )
51
-
52
- unpack(:event_categories) { response }
3
+ get :list, "events{?query*}", optional: [:app_id, :query] do |req, params|
4
+ # Can't rely on URI templates if we need a static part depending on a dynamic one
5
+ req.path = "apps/#{params[:app_id]}/#{req.path}" if params[:app_id]
53
6
  end
7
+ get :types, "event_types"
8
+ get :categories, "event_categories"
54
9
  end
55
10
  end
@@ -1,38 +1,20 @@
1
1
  module Scalingo
2
2
  class Regional::Logs < API::Endpoint
3
- def get(url, payload = {}, headers = nil, &block)
4
- data = payload.compact
3
+ get :archives, "apps/{app_id}/logs_archives"
5
4
 
6
- response = connection(fallback_to_guest: true).get(
7
- url,
8
- data,
9
- headers,
10
- &block
11
- )
12
-
13
- unpack { response }
14
- end
15
-
16
- def archives(app_id, headers = nil, &block)
17
- data = nil
18
-
19
- response = connection.get(
20
- "apps/#{app_id}/logs_archives",
21
- data,
22
- headers,
23
- &block
24
- )
25
-
26
- unpack(:archives) { response }
5
+ def fetch(url, **params, &block)
6
+ request(:get, url, **params) do |req|
7
+ block&.call(req, params)
8
+ req.params[:n] = params[:n] if params[:n].present?
9
+ end
27
10
  end
28
11
 
29
12
  ## Helper method to avoid having to manually chain two operations
30
- def for(app_id, payload = {}, headers = nil, &block)
31
- logs_response = scalingo.apps.logs_url(app_id)
32
-
33
- return logs_response unless logs_response.successful?
13
+ def find(**params, &block)
14
+ params[:id] = params.delete(:app_id) if params[:app_id].present?
15
+ logs_response = client.apps.logs_url(**params)
34
16
 
35
- get(logs_response.data, payload, headers, &block)
17
+ fetch(logs_response.body, **params, &block)
36
18
  end
37
19
  end
38
20
  end
@@ -4,39 +4,7 @@ require "active_support/core_ext/hash/indifferent_access"
4
4
 
5
5
  module Scalingo
6
6
  class Regional::Metrics < API::Endpoint
7
- def for(app_id, payload = {}, headers = nil, &block)
8
- payload = payload.with_indifferent_access
9
- data = payload.except(:metric, :container_type, :container_index).compact
10
-
11
- metric = payload[:metric]
12
- url = "apps/#{app_id}/stats/#{metric}"
13
-
14
- if payload[:container_type]
15
- url = "#{url}/#{payload[:container_type]}"
16
- url = "#{url}/#{payload[:container_index]}" if payload[:container_index]
17
- end
18
-
19
- response = connection.get(
20
- url,
21
- data,
22
- headers,
23
- &block
24
- )
25
-
26
- unpack { response }
27
- end
28
-
29
- def types(headers = nil, &block)
30
- data = nil
31
-
32
- response = connection(fallback_to_guest: true).get(
33
- "features/metrics",
34
- data,
35
- headers,
36
- &block
37
- )
38
-
39
- unpack(:metrics) { response }
40
- end
7
+ get :list, "/apps/{app_id}/stats/{metric}{/container_type}{/container_index}", optional: [:container_type, :container_index]
8
+ get :types, "/features/metrics"
41
9
  end
42
10
  end
@@ -2,95 +2,12 @@ require "scalingo/api/endpoint"
2
2
 
3
3
  module Scalingo
4
4
  class Regional::Notifiers < API::Endpoint
5
- def for(app_id, headers = nil, &block)
6
- data = nil
7
-
8
- response = connection.get(
9
- "apps/#{app_id}/notifiers",
10
- data,
11
- headers,
12
- &block
13
- )
14
-
15
- unpack(:notifiers) { response }
16
- end
17
-
18
- def find(app_id, notifier_id, headers = nil, &block)
19
- data = nil
20
-
21
- response = connection.get(
22
- "apps/#{app_id}/notifiers/#{notifier_id}",
23
- data,
24
- headers,
25
- &block
26
- )
27
-
28
- unpack(:notifier) { response }
29
- end
30
-
31
- def create(app_id, payload = {}, headers = nil, &block)
32
- data = {notifier: payload}
33
-
34
- response = connection.post(
35
- "apps/#{app_id}/notifiers",
36
- data,
37
- headers,
38
- &block
39
- )
40
-
41
- unpack(:notifier) { response }
42
- end
43
-
44
- def update(app_id, notifier_id, payload = {}, headers = nil, &block)
45
- data = {notifier: payload}
46
-
47
- response = connection.patch(
48
- "apps/#{app_id}/notifiers/#{notifier_id}",
49
- data,
50
- headers,
51
- &block
52
- )
53
-
54
- unpack(:notifier) { response }
55
- end
56
-
57
- def destroy(app_id, notifier_id, headers = nil, &block)
58
- data = nil
59
-
60
- response = connection.delete(
61
- "apps/#{app_id}/notifiers/#{notifier_id}",
62
- data,
63
- headers,
64
- &block
65
- )
66
-
67
- unpack { response }
68
- end
69
-
70
- def test(app_id, notifier_id, headers = nil, &block)
71
- data = nil
72
-
73
- response = connection.post(
74
- "apps/#{app_id}/notifiers/#{notifier_id}/test",
75
- data,
76
- headers,
77
- &block
78
- )
79
-
80
- unpack { response }
81
- end
82
-
83
- def platforms(headers = nil, &block)
84
- data = nil
85
-
86
- response = connection(fallback_to_guest: true).get(
87
- "notification_platforms",
88
- data,
89
- headers,
90
- &block
91
- )
92
-
93
- unpack(:notification_platforms) { response }
94
- end
5
+ get :list, "/apps/{app_id}/notifiers"
6
+ get :find, "/apps/{app_id}/notifiers/{id}"
7
+ post :create, "/apps/{app_id}/notifiers", root_key: :notifier
8
+ put :update, "/apps/{app_id}/notifiers/{id}", root_key: :notifier
9
+ delete :delete, "/apps/{app_id}/notifiers/{id}"
10
+ get :platforms, "/notification_platforms"
11
+ post :test, "/apps/{app_id}/notifiers/{id}/test"
95
12
  end
96
13
  end
@@ -2,25 +2,12 @@ require "scalingo/api/endpoint"
2
2
 
3
3
  module Scalingo
4
4
  class Regional::Operations < API::Endpoint
5
- def find(app_id, operation_id, headers = nil, &block)
6
- get(
7
- "apps/#{app_id}/operations/#{operation_id}",
8
- headers,
9
- &block
10
- )
11
- end
12
-
13
- def get(url, headers = nil, &block)
14
- data = nil
15
-
16
- response = connection.get(
17
- url,
18
- data,
19
- headers,
20
- &block
21
- )
5
+ get :find, "/apps/{app_id}/operations/{id}"
22
6
 
23
- unpack(:operation) { response }
7
+ def fetch(url, **params, &block)
8
+ request(:get, url, **params) do |req|
9
+ block&.call(req, params)
10
+ end
24
11
  end
25
12
  end
26
13
  end
@@ -2,108 +2,13 @@ require "scalingo/api/endpoint"
2
2
 
3
3
  module Scalingo
4
4
  class Regional::ScmRepoLinks < API::Endpoint
5
- def show(app_id, headers = nil, &block)
6
- data = nil
7
-
8
- response = connection.get(
9
- "apps/#{app_id}/scm_repo_link",
10
- data,
11
- headers,
12
- &block
13
- )
14
-
15
- unpack(:scm_repo_link) { response }
16
- end
17
-
18
- def create(app_id, payload = {}, headers = nil, &block)
19
- data = {scm_repo_link: payload}
20
-
21
- response = connection.post(
22
- "apps/#{app_id}/scm_repo_link",
23
- data,
24
- headers,
25
- &block
26
- )
27
-
28
- unpack(:scm_repo_link) { response }
29
- end
30
-
31
- def update(app_id, payload = {}, headers = nil, &block)
32
- data = {scm_repo_link: payload}
33
-
34
- response = connection.patch(
35
- "apps/#{app_id}/scm_repo_link",
36
- data,
37
- headers,
38
- &block
39
- )
40
-
41
- unpack(:scm_repo_link) { response }
42
- end
43
-
44
- def destroy(app_id, headers = nil, &block)
45
- data = nil
46
-
47
- response = connection.delete(
48
- "apps/#{app_id}/scm_repo_link",
49
- data,
50
- headers,
51
- &block
52
- )
53
-
54
- unpack(:scm_repo_link) { response }
55
- end
56
-
57
- def deploy(app_id, branch, headers = nil, &block)
58
- data = {branch: branch}
59
-
60
- response = connection.post(
61
- "apps/#{app_id}/scm_repo_link/manual_deploy",
62
- data,
63
- headers,
64
- &block
65
- )
66
-
67
- unpack(:deployment) { response }
68
- end
69
-
70
- def review_app(review_app, pull_request_id, headers = nil, &block)
71
- data = {pull_request_id: pull_request_id}
72
-
73
- response = connection.post(
74
- "apps/#{app_id}/scm_repo_link/manual_review_app",
75
- data,
76
- headers,
77
- &block
78
- )
79
-
80
- unpack(:review_app) { response }
81
- end
82
-
83
- def branches(app_id, headers = nil, &block)
84
- data = nil
85
-
86
- response = connection.get(
87
- "apps/#{app_id}/scm_repo_link/branches",
88
- data,
89
- headers,
90
- &block
91
- )
92
-
93
- unpack(:branches) { response }
94
- end
95
-
96
- def pulls(app_id, headers = nil, &block)
97
- data = nil
98
-
99
- response = connection.get(
100
- "apps/#{app_id}/scm_repo_link/pulls",
101
- data,
102
- headers,
103
- &block
104
- )
105
-
106
- unpack(:pulls) { response }
107
- end
5
+ get :find, "/apps/{app_id}/scm_repo_link"
6
+ post :create, "/apps/{app_id}/scm_repo_link", root_key: :scm_repo_link
7
+ put :update, "/apps/{app_id}/scm_repo_link", root_key: :scm_repo_link
8
+ delete :delete, "/apps/{app_id}/scm_repo_link"
9
+ get :branches, "/apps/{app_id}/scm_repo_link/branches"
10
+ get :pulls, "/apps/{app_id}/scm_repo_link/pulls"
11
+ post :deploy, "/apps/{app_id}/scm_repo_link/manual_deploy"
12
+ post :review_app, "/apps/{app_id}/scm_repo_link/manual_review_app"
108
13
  end
109
14
  end
@@ -4,59 +4,14 @@ module Scalingo
4
4
  module TokenHolder
5
5
  def self.included(base)
6
6
  base.attr_reader :token
7
- base.attr_reader :database_tokens
8
7
  end
9
8
 
10
9
  def token=(input)
11
- @token = bearer_token(input)
12
- end
13
-
14
- def add_database_token(database_id, token)
15
- @database_tokens ||= {}
16
- @database_tokens[database_id] = bearer_token(token)
10
+ @token = input.is_a?(BearerToken) ? input : BearerToken.new(input.to_s)
17
11
  end
18
12
 
19
13
  def authenticated?
20
- valid?(token)
21
- end
22
-
23
- def authenticated_for_database?(database_id)
24
- return false if database_tokens.nil?
25
- return false unless database_tokens.has_key?(database_id)
26
-
27
- valid?(database_tokens[database_id])
28
- end
29
-
30
- def authenticate_with_bearer_token(bearer_token, expires_at:, raise_on_expired_token:)
31
- self.token = build_bearer_token(bearer_token, expires_at: expires_at, raise_on_expired_token: raise_on_expired_token)
32
- end
33
-
34
- def authenticate_database_with_bearer_token(database_id, bearer_token, expires_at:, raise_on_expired_token:)
35
- bearer_token = build_bearer_token(bearer_token, expires_at: expires_at, raise_on_expired_token: raise_on_expired_token)
36
-
37
- add_database_token(database_id, bearer_token)
38
- end
39
-
40
- private
41
-
42
- def valid?(token)
43
14
  token.present? && !token.expired?
44
15
  end
45
-
46
- def bearer_token(token)
47
- token.is_a?(BearerToken) ? token : BearerToken.new(token.to_s, raise_on_expired: config.raise_on_expired_token)
48
- end
49
-
50
- def build_bearer_token(bearer_token, expires_at:, raise_on_expired_token:)
51
- return bearer_token unless expires_at
52
-
53
- token = bearer_token.is_a?(BearerToken) ? bearer_token.value : bearer_token.to_s
54
-
55
- BearerToken.new(
56
- token,
57
- expires_at: expires_at,
58
- raise_on_expired: raise_on_expired_token
59
- )
60
- end
61
16
  end
62
17
  end
@@ -1,3 +1,3 @@
1
1
  module Scalingo
2
- VERSION = "3.5.0"
2
+ VERSION = "4.0.beta1"
3
3
  end
data/scalingo.gemspec CHANGED
@@ -32,11 +32,14 @@ Gem::Specification.new do |s|
32
32
  s.executables = s.files.grep(%r{^exe/}) { |f| File.basename(f) }
33
33
  s.require_paths = ["lib"]
34
34
 
35
+ s.add_dependency "addressable", [">= 2.8.0", "< 3"]
35
36
  s.add_dependency "activesupport", [">= 5", "< 8"]
36
37
  s.add_dependency "faraday", "~> 2.0"
37
38
  s.add_dependency "multi_json", ">= 1.0.3", "~> 1.0"
39
+ s.add_dependency "jwt"
38
40
 
39
41
  s.add_development_dependency "bundler", "~> 2.0"
42
+ s.add_development_dependency "dotenv"
40
43
  s.add_development_dependency "rake", "~> 13.0"
41
44
  s.add_development_dependency "rspec", "~> 3.0"
42
45
  s.add_development_dependency "standard", "~> 1.32"