ibm-cloud-sdk 0.1.9 → 0.1.10
Sign up to get free protection for your applications and to get access to all the features.
- checksums.yaml +4 -4
- data/CHANGELOG.md +6 -1
- data/ibm-cloud-sdk.gemspec +1 -1
- data/lib/ibm/cloud/sdk.rb +2 -1
- data/lib/ibm/cloud/sdk/iam.rb +5 -0
- data/lib/ibm/cloud/sdk/resource_controller.rb +4 -0
- data/lib/ibm/cloud/sdk/tags.rb +28 -0
- data/lib/ibm/cloud/sdk/tags/http.rb +5 -0
- data/lib/ibm/cloud/sdk/tags/http/tag_collection.rb +99 -0
- data/lib/ibm/cloud/sdk/version.rb +1 -1
- data/lib/ibm/cloud/sdk/vpc.rb +8 -7
- data/lib/ibm/cloud/sdk/vpc/floatingips.rb +2 -2
- data/lib/ibm/cloud/sdk/vpc/flowlogcollectors.rb +2 -2
- data/lib/ibm/cloud/sdk/vpc/http.rb +7 -0
- data/lib/ibm/cloud/sdk/vpc/http/vpc_collection.rb +82 -0
- data/lib/ibm/cloud/sdk/vpc/http/vpc_http.rb +29 -0
- data/lib/ibm/cloud/sdk/vpc/http/vpc_instance.rb +30 -0
- data/lib/ibm/cloud/sdk/vpc/ike_policies.rb +2 -2
- data/lib/ibm/cloud/sdk/vpc/images.rb +2 -2
- data/lib/ibm/cloud/sdk/vpc/instance/actions.rb +1 -1
- data/lib/ibm/cloud/sdk/vpc/instance/floating_ips.rb +2 -2
- data/lib/ibm/cloud/sdk/vpc/instance/network_interfaces.rb +2 -2
- data/lib/ibm/cloud/sdk/vpc/instance/volume_attachments.rb +2 -2
- data/lib/ibm/cloud/sdk/vpc/instance_profiles.rb +3 -3
- data/lib/ibm/cloud/sdk/vpc/instances.rb +2 -2
- data/lib/ibm/cloud/sdk/vpc/ipsec_policies.rb +2 -2
- data/lib/ibm/cloud/sdk/vpc/keys.rb +2 -24
- data/lib/ibm/cloud/sdk/vpc/load_balancer.rb +1 -1
- data/lib/ibm/cloud/sdk/vpc/load_balancer/listeners.rb +2 -2
- data/lib/ibm/cloud/sdk/vpc/load_balancer/members.rb +2 -2
- data/lib/ibm/cloud/sdk/vpc/load_balancer/policies.rb +2 -2
- data/lib/ibm/cloud/sdk/vpc/load_balancer/pools.rb +2 -2
- data/lib/ibm/cloud/sdk/vpc/load_balancer/rules.rb +2 -2
- data/lib/ibm/cloud/sdk/vpc/load_balancers.rb +1 -1
- data/lib/ibm/cloud/sdk/vpc/network_acls.rb +4 -4
- data/lib/ibm/cloud/sdk/vpc/operating_systems.rb +2 -2
- data/lib/ibm/cloud/sdk/vpc/public_gateways.rb +2 -2
- data/lib/ibm/cloud/sdk/vpc/regions.rb +4 -4
- data/lib/ibm/cloud/sdk/vpc/security_groups.rb +6 -6
- data/lib/ibm/cloud/sdk/vpc/subnets.rb +2 -2
- data/lib/ibm/cloud/sdk/vpc/volume_profiles.rb +2 -2
- data/lib/ibm/cloud/sdk/vpc/volumes.rb +2 -2
- data/lib/ibm/cloud/sdk/vpc/vpcs.rb +6 -6
- data/lib/ibm/cloud/sdk/vpc/vpn_gateway/connections.rb +2 -2
- data/lib/ibm/cloud/sdk/vpc/vpn_gateway/local_cidrs.rb +2 -2
- data/lib/ibm/cloud/sdk/vpc/vpn_gateway/peer_cidrs.rb +2 -2
- data/lib/ibm/cloud/sdk/vpc/vpn_gateways.rb +2 -2
- data/lib/ibm/cloud/sdk_http.rb +16 -0
- data/lib/ibm/cloud/sdk_http/base_collection.rb +121 -0
- data/lib/ibm/cloud/sdk_http/base_http_mixin.rb +63 -0
- data/lib/ibm/cloud/sdk_http/base_instance.rb +55 -0
- data/lib/ibm/cloud/sdk_http/connection.rb +32 -0
- data/lib/ibm/cloud/sdk_http/exceptions.rb +31 -0
- data/lib/ibm/cloud/{sdk/vpc/base_mixins → sdk_http}/has_child.rb +3 -7
- data/lib/ibm/cloud/sdk_http/iam_token.rb +53 -0
- data/lib/ibm/cloud/sdk_http/sdk_response.rb +132 -0
- data/lib/ibm/cloud_sdk.rb +39 -0
- metadata +21 -12
- data/lib/ibm/cloud/sdk/vpc/base_collection.rb +0 -107
- data/lib/ibm/cloud/sdk/vpc/base_instance.rb +0 -23
- data/lib/ibm/cloud/sdk/vpc/base_vpc.rb +0 -61
- data/lib/ibm/cloud/sdk/vpc/cloud_sdk.rb +0 -33
- data/lib/ibm/cloud/sdk/vpc/exceptions.rb +0 -33
- data/lib/ibm/cloud/sdk/vpc/helpers/connection.rb +0 -96
- data/lib/ibm/cloud/sdk/vpc/helpers/response.rb +0 -134
@@ -1,23 +0,0 @@
|
|
1
|
-
# typed: true
|
2
|
-
# frozen_string_literal: true
|
3
|
-
|
4
|
-
module IBM
|
5
|
-
module Cloud
|
6
|
-
module SDK
|
7
|
-
# Container that encapsulates the VPC API.
|
8
|
-
class BaseInstance < BaseVPC
|
9
|
-
def details
|
10
|
-
get.hash_response
|
11
|
-
end
|
12
|
-
|
13
|
-
def update(payload)
|
14
|
-
patch(payload)
|
15
|
-
end
|
16
|
-
|
17
|
-
def remove
|
18
|
-
delete
|
19
|
-
end
|
20
|
-
end
|
21
|
-
end
|
22
|
-
end
|
23
|
-
end
|
@@ -1,61 +0,0 @@
|
|
1
|
-
# typed: true
|
2
|
-
# frozen_string_literal: true
|
3
|
-
|
4
|
-
module IBM
|
5
|
-
module Cloud
|
6
|
-
module SDK
|
7
|
-
# Container that encapsulates the VPC API.
|
8
|
-
class BaseVPC
|
9
|
-
def initialize(parent, endpoint = nil)
|
10
|
-
@endpoint = parent.url(endpoint)
|
11
|
-
@connection = parent.connection
|
12
|
-
@logger = parent.logger
|
13
|
-
end
|
14
|
-
|
15
|
-
attr_reader :endpoint, :connection, :logger
|
16
|
-
|
17
|
-
def adhoc(method: 'get', path: nil, params: {}, payload_type: 'json', payload: {})
|
18
|
-
@connection.adhoc(method.to_sym, url(path), metadata(params, payload_type, payload))
|
19
|
-
end
|
20
|
-
|
21
|
-
def get(path: nil, params: {})
|
22
|
-
adhoc(method: 'get', path: path, params: params)
|
23
|
-
end
|
24
|
-
|
25
|
-
def post(payload = {}, path: nil, params: {}, type: 'json')
|
26
|
-
adhoc(method: 'post', path: path, params: params, payload: payload, payload_type: type)
|
27
|
-
end
|
28
|
-
|
29
|
-
def put(payload = {}, path: nil, params: {})
|
30
|
-
adhoc(method: 'put', path: path, params: params, payload: payload)
|
31
|
-
end
|
32
|
-
|
33
|
-
def patch(payload = {}, path: nil, params: {})
|
34
|
-
adhoc(method: 'patch', path: path, params: params, payload: payload)
|
35
|
-
end
|
36
|
-
|
37
|
-
def delete(path: nil, params: {})
|
38
|
-
adhoc(method: 'delete', path: path, params: params)
|
39
|
-
end
|
40
|
-
|
41
|
-
def url(path = nil)
|
42
|
-
return endpoint unless path
|
43
|
-
|
44
|
-
"#{endpoint}/#{path}"
|
45
|
-
end
|
46
|
-
|
47
|
-
private
|
48
|
-
|
49
|
-
def metadata(params = {}, payload_type = 'json', payload = {})
|
50
|
-
params ||= {}
|
51
|
-
pt = {
|
52
|
-
params: { version: '2020-08-01', generation: 2 }.merge(params)
|
53
|
-
}
|
54
|
-
|
55
|
-
pt[payload_type.to_sym] = payload unless payload.empty?
|
56
|
-
pt
|
57
|
-
end
|
58
|
-
end
|
59
|
-
end
|
60
|
-
end
|
61
|
-
end
|
@@ -1,33 +0,0 @@
|
|
1
|
-
# frozen_string_literal: true
|
2
|
-
|
3
|
-
require 'http'
|
4
|
-
require 'ibm/cloud/sdk/vpc/helpers/connection'
|
5
|
-
require 'ibm/cloud/sdk/vpc'
|
6
|
-
|
7
|
-
module IBM
|
8
|
-
# Holds the SDK pieces.
|
9
|
-
class CloudSDK
|
10
|
-
def initialize(api_key, logger: nil, options: {})
|
11
|
-
@logger = logger
|
12
|
-
@logger ||= Logger.new($stdout, level: :warn)
|
13
|
-
|
14
|
-
@client = HTTP.use(http_options(options))
|
15
|
-
@connection = IBM::Cloud::SDK::VPC::Connection.new(api_key, logger: @logger, client: @client)
|
16
|
-
end
|
17
|
-
|
18
|
-
def http_options(options = {})
|
19
|
-
options.merge(
|
20
|
-
{
|
21
|
-
logging: { logger: @logger },
|
22
|
-
auto_deflate: {}
|
23
|
-
}
|
24
|
-
)
|
25
|
-
end
|
26
|
-
|
27
|
-
attr_reader :logger, :connection
|
28
|
-
|
29
|
-
def vpc(region = 'us-east')
|
30
|
-
IBM::Cloud::SDK::Vpc.new(region, @connection, logger: @logger)
|
31
|
-
end
|
32
|
-
end
|
33
|
-
end
|
@@ -1,33 +0,0 @@
|
|
1
|
-
# frozen_string_literal: true
|
2
|
-
|
3
|
-
module IBM
|
4
|
-
module Cloud
|
5
|
-
module SDK
|
6
|
-
module VPC
|
7
|
-
# Module to contain all custom exception classes.
|
8
|
-
module Exceptions
|
9
|
-
# An exception for http with a response attribute.
|
10
|
-
# @param response [IBM::Cloud::SDK::VPC::Response] The original response object.
|
11
|
-
# @param msg [String] A human readable message.
|
12
|
-
class ExceptionWithResponse < RuntimeError
|
13
|
-
def initialize(response, msg)
|
14
|
-
@response = response
|
15
|
-
super(msg)
|
16
|
-
end
|
17
|
-
# @return [IBM::Cloud::SDK::VPC::Response] The response
|
18
|
-
attr_reader :response
|
19
|
-
end
|
20
|
-
|
21
|
-
# An exception for http status errors with a response attribute.
|
22
|
-
# @param response [IBM::Cloud::SDK::VPC::Response] The original response object.
|
23
|
-
class HttpStatusError < ExceptionWithResponse
|
24
|
-
def initialize(response)
|
25
|
-
msg = "Invalid status #{response.code} for url \"#{response.url}\", #{response.reason}. #{response.body}"
|
26
|
-
super(response, msg)
|
27
|
-
end
|
28
|
-
end
|
29
|
-
end
|
30
|
-
end
|
31
|
-
end
|
32
|
-
end
|
33
|
-
end
|
@@ -1,96 +0,0 @@
|
|
1
|
-
# frozen_string_literal: true
|
2
|
-
|
3
|
-
require 'time'
|
4
|
-
require 'http'
|
5
|
-
require_relative 'response'
|
6
|
-
|
7
|
-
module IBM
|
8
|
-
module Cloud
|
9
|
-
module SDK
|
10
|
-
module VPC
|
11
|
-
# The Connection object to be used for all HTTP requests.
|
12
|
-
# @param api_key [String] The API Key to be used for this account.
|
13
|
-
# @param logger [Logger] An instantiated logger instance.
|
14
|
-
# @param client [HTTP::Client] An instantiated HTTP client.
|
15
|
-
class Connection
|
16
|
-
def initialize(api_key, logger: nil, client: nil)
|
17
|
-
@api_key = api_key
|
18
|
-
@logger = logger
|
19
|
-
@client = client
|
20
|
-
@token = Token.new(api_key, logger: logger, client: client)
|
21
|
-
end
|
22
|
-
|
23
|
-
attr_reader :client
|
24
|
-
|
25
|
-
# Send a HTTP request. Checks the validity of the response.
|
26
|
-
# @param verb [String] THe HTTP verb to use for this request.
|
27
|
-
# @param uri [String] The Full URL to send.
|
28
|
-
# @option opts [Hash] :params Parameters for URL encoding parameters.
|
29
|
-
# @option opts [Hash] :json Used when sending a hash as application/json content type.
|
30
|
-
# @option opts [Hash] :form Used when sending a hash as a form.
|
31
|
-
# @option opts [Hash] :headers Used to modify headers for request.
|
32
|
-
# @return [IBM::Cloud::SDK::VPC::Response] Wrapped response to query.
|
33
|
-
# @raise [IBM::Cloud::SDK::VPC::Exceptions::HttpStatusError] Response code is not either in 200-series or 404.
|
34
|
-
def adhoc(verb, uri, opts = {})
|
35
|
-
unverified_request(verb, uri, opts).raise_for_status?
|
36
|
-
end
|
37
|
-
|
38
|
-
# Send a HTTP request. Don't do any validation checks.
|
39
|
-
# @see :adhoc for options.
|
40
|
-
def unverified_request(verb, uri, opts = {})
|
41
|
-
response = @client.auth(@token.authorization_header).request(verb.to_s.downcase.to_sym, uri, opts)
|
42
|
-
Response.new(response)
|
43
|
-
end
|
44
|
-
|
45
|
-
# Get bearer token string for clients not using the adhoc method.
|
46
|
-
def authorization_header
|
47
|
-
@token.authorization_header
|
48
|
-
end
|
49
|
-
end
|
50
|
-
|
51
|
-
# The IAM token manager.
|
52
|
-
# @param api_key [String] The API Key to be used for this account.
|
53
|
-
# @param logger [Logger] An instantiated logger instance.
|
54
|
-
# @param client [HTTP::Client] An instantiated HTTP client.
|
55
|
-
class Token
|
56
|
-
def initialize(api_key, logger: nil, client: nil)
|
57
|
-
@api_key = api_key
|
58
|
-
@logger = logger
|
59
|
-
@client = client
|
60
|
-
@data = fetch
|
61
|
-
end
|
62
|
-
|
63
|
-
# Retrieve a new access_token from IAM.
|
64
|
-
# @return [IBM::Cloud::SDK::VPC::Response] Wrapped response to query.
|
65
|
-
# @raise [IBM::Cloud::SDK::VPC::Exceptions::HttpStatusError] Response code is not either in 200-series or 404.
|
66
|
-
def fetch
|
67
|
-
payload = {
|
68
|
-
form: {
|
69
|
-
grant_type: 'urn:ibm:params:oauth:grant-type:apikey',
|
70
|
-
apikey: @api_key
|
71
|
-
}
|
72
|
-
}
|
73
|
-
response = HTTP.post('https://iam.cloud.ibm.com/identity/token', payload)
|
74
|
-
@data = Response.new(response).raise_for_status?.json
|
75
|
-
end
|
76
|
-
|
77
|
-
# Check to see if the access_token is expired. Fetch a new token if none exists.
|
78
|
-
# @return [IBM::Cloud::SDK::VPC::Response] Wrapped response to query.
|
79
|
-
# @raise [IBM::Cloud::SDK::VPC::Exceptions::HttpStatusError] Response code is not either in 200-series or 404.
|
80
|
-
def expired?
|
81
|
-
fetch unless @data
|
82
|
-
@data.fetch(:expiration).to_i <= Time.now.to_i + 600
|
83
|
-
end
|
84
|
-
|
85
|
-
# Get a Bearer token string. Before returning check to see if token is expired.
|
86
|
-
# @return [String] The Bearer token header used in subsequent requests.
|
87
|
-
# @raise [IBM::Cloud::SDK::VPC::Exceptions::HttpStatusError] Response code is not either in 200-series or 404.
|
88
|
-
def authorization_header
|
89
|
-
fetch if expired?
|
90
|
-
"#{@data.fetch(:token_type)} #{@data.fetch(:access_token)}"
|
91
|
-
end
|
92
|
-
end
|
93
|
-
end
|
94
|
-
end
|
95
|
-
end
|
96
|
-
end
|
@@ -1,134 +0,0 @@
|
|
1
|
-
# frozen_string_literal: true
|
2
|
-
|
3
|
-
require 'time'
|
4
|
-
require 'http'
|
5
|
-
|
6
|
-
module IBM
|
7
|
-
module Cloud
|
8
|
-
module SDK
|
9
|
-
module VPC
|
10
|
-
# Encapsulate the HTTP response.
|
11
|
-
# @param response [HTTP::Response] The HTTP response object.
|
12
|
-
class Response
|
13
|
-
def initialize(response)
|
14
|
-
@response = response
|
15
|
-
end
|
16
|
-
|
17
|
-
# The raw HTTP response.
|
18
|
-
# @return [HTTP::Response]
|
19
|
-
attr_reader :response
|
20
|
-
|
21
|
-
# Return the response in a hash or array.
|
22
|
-
# @return [Hash] When response is a hash.
|
23
|
-
# @return [Array] When response is an array.
|
24
|
-
# @raise [Exceptions::ExceptionWithResponse] Contents of body is not properly formatted json.
|
25
|
-
def json
|
26
|
-
JSON.parse(body, symbolize_names: true)
|
27
|
-
rescue StandardError
|
28
|
-
raise Exceptions::ExceptionWithResponse.new(self, "#{url} Error while parsing response body. #{response.body}")
|
29
|
-
end
|
30
|
-
|
31
|
-
# Return the raw response string.
|
32
|
-
# @return [String]
|
33
|
-
# @return [nil] Response does not have body method.
|
34
|
-
def body
|
35
|
-
response&.body.to_s
|
36
|
-
end
|
37
|
-
|
38
|
-
# Return the response code.
|
39
|
-
# @return [Integer] Response has code method.
|
40
|
-
# @return [nil] Response does not have code method.
|
41
|
-
def code
|
42
|
-
response&.code
|
43
|
-
end
|
44
|
-
|
45
|
-
alias status code
|
46
|
-
|
47
|
-
# Return the raw connection object.
|
48
|
-
# @return [HTTP::Connection]
|
49
|
-
# @return [nil] Response does not have a connection method.
|
50
|
-
def connection
|
51
|
-
response&.connection
|
52
|
-
end
|
53
|
-
|
54
|
-
# Chainable method to verify the status code. Raise an exception for non 200-series or 404 status codes.
|
55
|
-
# @return [Response] Allows for method to be chainable.
|
56
|
-
# @raise [Exceptions::HttpStatusError] Raise if status checks failed.
|
57
|
-
def raise_for_status?
|
58
|
-
return self if (200..299).include?(code)
|
59
|
-
return self if code == 404
|
60
|
-
|
61
|
-
raise Exceptions::HttpStatusError.new(self)
|
62
|
-
end
|
63
|
-
|
64
|
-
# Return the content type of the response.
|
65
|
-
# @return [String] The mimetype of the response.
|
66
|
-
# @return [nil] Response does not have response method that responds to mime_type.
|
67
|
-
def content_type
|
68
|
-
response&.response&.mime_type
|
69
|
-
end
|
70
|
-
|
71
|
-
# Return the textual reason.
|
72
|
-
# @return [String] HTTP Reason
|
73
|
-
# @return [nil] Response does not have reaspn method that responds.
|
74
|
-
def reason
|
75
|
-
response&.reason
|
76
|
-
end
|
77
|
-
|
78
|
-
# Return the sent url as a string.
|
79
|
-
# @return [String] Full URL sent
|
80
|
-
# @return [nil] Response does not have response method that responds to mime_type.
|
81
|
-
def url
|
82
|
-
response&.uri.to_s
|
83
|
-
end
|
84
|
-
|
85
|
-
# Return the sent url as a URI class.
|
86
|
-
# @see https://github.com/httprb/http/blob/master/lib/http/uri.rb URI Class doc.
|
87
|
-
# @return [HTTP::URI]
|
88
|
-
# @return [nil] Response does not have response method that responds to mime_type.
|
89
|
-
def uri
|
90
|
-
response&.uri
|
91
|
-
end
|
92
|
-
|
93
|
-
# Verify that the json response is a hash.
|
94
|
-
# @return [Hash] Response from JSON
|
95
|
-
# @raise [RuntimeError] JSON object is not a Hash.
|
96
|
-
def hash_response
|
97
|
-
check_object(Hash)
|
98
|
-
end
|
99
|
-
|
100
|
-
# Verify that the json response is an array.
|
101
|
-
# @return [Array] Response from JSON
|
102
|
-
# @raise [RuntimeError] JSON object is not a Array.
|
103
|
-
def array_response
|
104
|
-
check_object(Array)
|
105
|
-
end
|
106
|
-
|
107
|
-
# Find a subkey within the returned response.
|
108
|
-
# @param key [String] Name of a first level key.
|
109
|
-
# @return [Any] Response from JSON
|
110
|
-
# @raise [RuntimeError] JSON object is not a Array.
|
111
|
-
def subkey(key)
|
112
|
-
ret = hash_response
|
113
|
-
sym_key = key.to_sym
|
114
|
-
return ret.fetch(sym_key) if ret.key?(sym_key)
|
115
|
-
|
116
|
-
msg = "Key #{key} not found in #{ret}."
|
117
|
-
raise Exceptions::ExceptionWithResponse.new(self, msg)
|
118
|
-
end
|
119
|
-
|
120
|
-
# Check to see if the returned object is the expected object.
|
121
|
-
# @param obj [Object] The object to test the response against.
|
122
|
-
# @raise [Exceptions::ExceptionWithResponse] Parsed JSON is not the expecte class.
|
123
|
-
def check_object(obj)
|
124
|
-
ret = json
|
125
|
-
return ret if ret.instance_of?(obj)
|
126
|
-
|
127
|
-
msg = "Expected #{obj} in response for #{url}. The returned object is a #{ret.class}."
|
128
|
-
raise Exceptions::ExceptionWithResponse.new(self, msg)
|
129
|
-
end
|
130
|
-
end
|
131
|
-
end
|
132
|
-
end
|
133
|
-
end
|
134
|
-
end
|