deltacloud-client 1.1.2 → 1.1.3

Sign up to get free protection for your applications and to get access to all the features.
Files changed (205) hide show
  1. data/README.md +73 -0
  2. data/Rakefile +88 -5
  3. data/lib/deltacloud/client.rb +79 -0
  4. data/lib/deltacloud/client/base_error.rb +80 -0
  5. data/lib/deltacloud/client/connection.rb +139 -0
  6. data/lib/deltacloud/client/helpers/model_helper.rb +69 -0
  7. data/lib/deltacloud/client/helpers/property_helper.rb +103 -0
  8. data/lib/deltacloud/client/helpers/xml_helper.rb +33 -0
  9. data/lib/deltacloud/client/methods.rb +33 -0
  10. data/lib/deltacloud/client/methods/address.rb +67 -0
  11. data/lib/deltacloud/client/methods/api.rb +96 -0
  12. data/lib/deltacloud/client/methods/backward_compatiblity.rb +72 -0
  13. data/lib/deltacloud/client/methods/blob.rb +91 -0
  14. data/lib/deltacloud/client/methods/bucket.rb +55 -0
  15. data/lib/deltacloud/client/methods/common.rb +46 -0
  16. data/lib/deltacloud/client/methods/driver.rb +53 -0
  17. data/lib/deltacloud/client/methods/firewall.rb +67 -0
  18. data/lib/deltacloud/client/methods/hardware_profile.rb +41 -0
  19. data/lib/deltacloud/client/methods/image.rb +61 -0
  20. data/lib/deltacloud/client/methods/instance.rb +141 -0
  21. data/lib/deltacloud/client/methods/instance_state.rb +41 -0
  22. data/lib/deltacloud/client/methods/key.rb +58 -0
  23. data/lib/deltacloud/client/methods/load_balancer.rb +96 -0
  24. data/lib/deltacloud/client/methods/metric.rb +54 -0
  25. data/lib/deltacloud/client/methods/realm.rb +42 -0
  26. data/lib/deltacloud/client/methods/storage_snapshot.rb +61 -0
  27. data/lib/deltacloud/client/methods/storage_volume.rb +94 -0
  28. data/lib/deltacloud/client/models.rb +32 -0
  29. data/lib/deltacloud/client/models/address.rb +57 -0
  30. data/lib/deltacloud/client/models/base.rb +153 -0
  31. data/lib/deltacloud/client/models/blob.rb +56 -0
  32. data/lib/deltacloud/client/models/bucket.rb +65 -0
  33. data/lib/deltacloud/client/models/driver.rb +87 -0
  34. data/lib/deltacloud/client/models/firewall.rb +64 -0
  35. data/lib/deltacloud/client/models/hardware_profile.rb +68 -0
  36. data/lib/deltacloud/client/models/image.rb +60 -0
  37. data/lib/deltacloud/client/models/instance.rb +142 -0
  38. data/lib/deltacloud/client/models/instance_address.rb +40 -0
  39. data/lib/{instance_state.rb → deltacloud/client/models/instance_state.rb} +11 -3
  40. data/lib/deltacloud/client/models/key.rb +52 -0
  41. data/lib/deltacloud/client/models/load_balancer.rb +55 -0
  42. data/lib/deltacloud/client/models/metric.rb +72 -0
  43. data/lib/deltacloud/client/models/realm.rb +29 -0
  44. data/lib/deltacloud/client/models/storage_snapshot.rb +54 -0
  45. data/lib/deltacloud/client/models/storage_volume.rb +96 -0
  46. data/lib/deltacloud/core_ext.rb +19 -0
  47. data/lib/deltacloud/core_ext/element.rb +32 -0
  48. data/lib/deltacloud/core_ext/fixnum.rb +30 -0
  49. data/lib/deltacloud/core_ext/nil.rb +22 -0
  50. data/lib/{string.rb → deltacloud/core_ext/string.rb} +16 -26
  51. data/lib/deltacloud/error_response.rb +93 -0
  52. data/tests/client/client_test.rb +51 -0
  53. data/tests/client/connection_test.rb +77 -0
  54. data/tests/core_ext/element_test.rb +40 -0
  55. data/tests/core_ext/fixnum_test.rb +35 -0
  56. data/tests/core_ext/nil.rb +27 -0
  57. data/tests/core_ext/string_test.rb +47 -0
  58. data/tests/fixtures/instances_cleanup.yml +681 -0
  59. data/tests/fixtures/test_0001_connects_to_Deltacloud_API.yml +60 -0
  60. data/tests/fixtures/test_0001_support_cpu.yml +444 -0
  61. data/tests/fixtures/test_0001_support_original_body.yml +116 -0
  62. data/tests/fixtures/test_0001_supports_addresses.yml +178 -0
  63. data/tests/fixtures/test_0001_supports_api_host.yml +60 -0
  64. data/tests/fixtures/test_0001_supports_attached_.yml +282 -0
  65. data/tests/fixtures/test_0001_supports_blobs.yml +475 -0
  66. data/tests/fixtures/test_0001_supports_bucket.yml +200 -0
  67. data/tests/fixtures/test_0001_supports_buckets.yml +160 -0
  68. data/tests/fixtures/test_0001_supports_drivers.yml +202 -0
  69. data/tests/fixtures/test_0001_supports_firewalls.yml +399 -0
  70. data/tests/fixtures/test_0001_supports_hardware_profiles.yml +262 -0
  71. data/tests/fixtures/test_0001_supports_images.yml +224 -0
  72. data/tests/fixtures/test_0001_supports_instance_states.yml +156 -0
  73. data/tests/fixtures/test_0001_supports_instances.yml +486 -0
  74. data/tests/fixtures/test_0001_supports_keys.yml +198 -0
  75. data/tests/fixtures/test_0001_supports_path.yml +60 -0
  76. data/tests/fixtures/test_0001_supports_realms.yml +152 -0
  77. data/tests/fixtures/test_0001_supports_storage_snapshots.yml +164 -0
  78. data/tests/fixtures/test_0001_supports_storage_volumes.yml +176 -0
  79. data/tests/fixtures/test_0001_supports_to_get_providers.yml +410 -0
  80. data/tests/fixtures/test_0002_support_blob.yml +148 -0
  81. data/tests/fixtures/test_0002_support_instance_state.yml +204 -0
  82. data/tests/fixtures/test_0002_support_memory.yml +444 -0
  83. data/tests/fixtures/test_0002_support_on_Provider.yml +130 -0
  84. data/tests/fixtures/test_0002_supports_api_port.yml +60 -0
  85. data/tests/fixtures/test_0002_supports_api_uri.yml +60 -0
  86. data/tests/fixtures/test_0002_supports_driver.yml +219 -0
  87. data/tests/fixtures/test_0002_supports_extract_xml_body_using_faraday_connection.yml +117 -0
  88. data/tests/fixtures/test_0002_supports_filtering_addresses_by_id_param.yml +156 -0
  89. data/tests/fixtures/test_0002_supports_filtering_buckets_by_id_param.yml +156 -0
  90. data/tests/fixtures/test_0002_supports_filtering_firewalls_by_id_param.yml +207 -0
  91. data/tests/fixtures/test_0002_supports_filtering_hardware_profiles_by_id_param.yml +158 -0
  92. data/tests/fixtures/test_0002_supports_filtering_images_by_id_param.yml +165 -0
  93. data/tests/fixtures/test_0002_supports_filtering_instances_by_id_param.yml +164 -0
  94. data/tests/fixtures/test_0002_supports_filtering_keys_by_id_param.yml +178 -0
  95. data/tests/fixtures/test_0002_supports_filtering_realms_by_id.yml +104 -0
  96. data/tests/fixtures/test_0002_supports_filtering_storage_snapshots_by_id_param.yml +155 -0
  97. data/tests/fixtures/test_0002_supports_filtering_storage_volumes_by_id_param.yml +157 -0
  98. data/tests/fixtures/test_0002_supports_hardware_profiles.yml +262 -0
  99. data/tests/fixtures/test_0002_supports_is_compatible_.yml +116 -0
  100. data/tests/fixtures/test_0002_supports_snapshot_.yml +202 -0
  101. data/tests/fixtures/test_0002_supports_version.yml +60 -0
  102. data/tests/fixtures/test_0003_caches_the_API_entrypoint.yml +60 -0
  103. data/tests/fixtures/test_0003_support_address.yml +197 -0
  104. data/tests/fixtures/test_0003_support_bucket.yml +198 -0
  105. data/tests/fixtures/test_0003_support_create_blob.yml +105 -0
  106. data/tests/fixtures/test_0003_support_create_blob_and_destroy_blob.yml +138 -0
  107. data/tests/fixtures/test_0003_support_firewall.yml +768 -0
  108. data/tests/fixtures/test_0003_support_hardware_profile.yml +199 -0
  109. data/tests/fixtures/test_0003_support_image.yml +207 -0
  110. data/tests/fixtures/test_0003_support_instance.yml +206 -0
  111. data/tests/fixtures/test_0003_support_key.yml +220 -0
  112. data/tests/fixtures/test_0003_support_realm.yml +195 -0
  113. data/tests/fixtures/test_0003_support_storage.yml +444 -0
  114. data/tests/fixtures/test_0003_support_storage_snapshot.yml +196 -0
  115. data/tests/fixtures/test_0003_support_storage_volume.yml +197 -0
  116. data/tests/fixtures/test_0003_support_to_change_driver_with_Client.yml +72 -0
  117. data/tests/fixtures/test_0003_supports_connect.yml +60 -0
  118. data/tests/fixtures/test_0003_supports_extract_xml_body_using_nokogiri_document.yml +117 -0
  119. data/tests/fixtures/test_0003_supports_instance.yml +396 -0
  120. data/tests/fixtures/test_0003_supports_is_compatible_.yml +116 -0
  121. data/tests/fixtures/test_0003_supports_lunch_image.yml +367 -0
  122. data/tests/fixtures/test_0003_supports_providers.yml +102 -0
  123. data/tests/fixtures/test_0003_supports_version.yml +60 -0
  124. data/tests/fixtures/test_0004_support_architecture.yml +444 -0
  125. data/tests/fixtures/test_0004_support_create_address.yml +197 -0
  126. data/tests/fixtures/test_0004_support_create_blob_and_destroy_blob_with_meta_params.yml +139 -0
  127. data/tests/fixtures/test_0004_support_create_bucket.yml +180 -0
  128. data/tests/fixtures/test_0004_support_create_bucket_and_destroy_bucket.yml +180 -0
  129. data/tests/fixtures/test_0004_support_create_firewall_and_destroy_firewall.yml +496 -0
  130. data/tests/fixtures/test_0004_support_create_image_and_destroy_image.yml +1527 -0
  131. data/tests/fixtures/test_0004_support_create_instance.yml +115 -0
  132. data/tests/fixtures/test_0004_support_create_key_and_destroy_key.yml +206 -0
  133. data/tests/fixtures/test_0004_support_create_volume.yml +105 -0
  134. data/tests/fixtures/test_0004_support_create_volume_and_destroy_volume.yml +181 -0
  135. data/tests/fixtures/test_0004_support_to_test_of_valid_DC_connection.yml +60 -0
  136. data/tests/fixtures/test_0004_supports_current_driver.yml +60 -0
  137. data/tests/fixtures/test_0004_supports_extract_xml_body_using_nokogiri_element.yml +117 -0
  138. data/tests/fixtures/test_0004_supports_lunch_image.yml +312 -0
  139. data/tests/fixtures/test_0004_supports_valid_credentials_.yml +215 -0
  140. data/tests/fixtures/test_0004_supports_with_config.yml +129 -0
  141. data/tests/fixtures/test_0005_support_attach_storage_volume.yml +102 -0
  142. data/tests/fixtures/test_0005_support_attach_storage_volume_and_detach_storage_volume.yml +142 -0
  143. data/tests/fixtures/test_0005_support_create_instance_with_hwp_id.yml +115 -0
  144. data/tests/fixtures/test_0005_support_opaque_.yml +152 -0
  145. data/tests/fixtures/test_0005_supports_current_provider.yml +134 -0
  146. data/tests/fixtures/test_0005_supports_id.yml +116 -0
  147. data/tests/fixtures/test_0005_supports_switching_drivers_per_instance.yml +129 -0
  148. data/tests/fixtures/test_0005_supports_use_driver.yml +60 -0
  149. data/tests/fixtures/test_0006_support_create_instance_with_realm_id.yml +115 -0
  150. data/tests/fixtures/test_0006_supports_discovered_.yml +60 -0
  151. data/tests/fixtures/test_0006_supports_supported_collections.yml +60 -0
  152. data/tests/fixtures/test_0006_supports_switching_providers_per_instance.yml +208 -0
  153. data/tests/fixtures/test_0007_support_create_instance_with_name.yml +115 -0
  154. data/tests/fixtures/test_0007_support_switching_provider_without_credentials.yml +208 -0
  155. data/tests/fixtures/test_0007_supports_support_.yml +60 -0
  156. data/tests/fixtures/test_0007_supports_valid_credentials_on_class.yml +370 -0
  157. data/tests/fixtures/test_0008_support_stop_instance.yml +166 -0
  158. data/tests/fixtures/test_0008_supports_must_support_.yml +60 -0
  159. data/tests/fixtures/test_0009_support_start_instance.yml +217 -0
  160. data/tests/fixtures/test_0009_supports_features.yml +60 -0
  161. data/tests/fixtures/test_0010_support_reboot_instance.yml +166 -0
  162. data/tests/fixtures/test_0010_supports_feature_.yml +60 -0
  163. data/tests/helpers/model_test.rb +33 -0
  164. data/tests/helpers/xml_test.rb +56 -0
  165. data/tests/methods/address_test.rb +64 -0
  166. data/tests/methods/api_test.rb +97 -0
  167. data/tests/methods/backward_compatibility_test.rb +87 -0
  168. data/tests/methods/blob_test.rb +64 -0
  169. data/tests/methods/bucket_test.rb +62 -0
  170. data/tests/methods/driver_test.rb +48 -0
  171. data/tests/methods/firewall_test.rb +84 -0
  172. data/tests/methods/hardware_profile_test.rb +53 -0
  173. data/tests/methods/image_test.rb +64 -0
  174. data/tests/methods/instance_state_test.rb +43 -0
  175. data/tests/methods/instance_test.rb +126 -0
  176. data/tests/methods/key_test.rb +63 -0
  177. data/tests/methods/realm_test.rb +50 -0
  178. data/tests/methods/storage_snapshot_test.rb +53 -0
  179. data/tests/methods/storage_volume_test.rb +81 -0
  180. data/tests/models/blob_test.rb +40 -0
  181. data/tests/models/bucket_test.rb +37 -0
  182. data/tests/models/driver_test.rb +42 -0
  183. data/tests/models/hardware_profile_test.rb +80 -0
  184. data/tests/models/image_test.rb +65 -0
  185. data/tests/models/storage_volume_test.rb +52 -0
  186. data/tests/test_helper.rb +59 -11
  187. metadata +392 -41
  188. data/lib/base_object.rb +0 -386
  189. data/lib/client_bucket_methods.rb +0 -69
  190. data/lib/deltacloud.rb +0 -486
  191. data/lib/documentation.rb +0 -59
  192. data/lib/errors.rb +0 -140
  193. data/lib/hwp_properties.rb +0 -61
  194. data/tests/buckets_test.rb +0 -141
  195. data/tests/client_test.rb +0 -59
  196. data/tests/content_negotiation_test.rb +0 -127
  197. data/tests/errors_test.rb +0 -57
  198. data/tests/hardware_profiles_test.rb +0 -75
  199. data/tests/images_test.rb +0 -102
  200. data/tests/instance_states_test.rb +0 -66
  201. data/tests/instances_test.rb +0 -203
  202. data/tests/keys_test.rb +0 -81
  203. data/tests/realms_test.rb +0 -64
  204. data/tests/storage_snapshot_test.rb +0 -76
  205. data/tests/storage_volume_test.rb +0 -86
@@ -0,0 +1,32 @@
1
+ # Licensed to the Apache Software Foundation (ASF) under one or more
2
+ # contributor license agreements. See the NOTICE file distributed with
3
+ # this work for additional information regarding copyright ownership. The
4
+ # ASF licenses this file to you under the Apache License, Version 2.0 (the
5
+ # "License"); you may not use this file except in compliance with the
6
+ # License. You may obtain a copy of the License at
7
+ #
8
+ # http://www.apache.org/licenses/LICENSE-2.0
9
+ #
10
+ # Unless required by applicable law or agreed to in writing, software
11
+ # distributed under the License is distributed on an "AS IS" BASIS, WITHOUT
12
+ # WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. See the
13
+ # License for the specific language governing permissions and limitations
14
+ # under the License.
15
+
16
+ require_relative './models/base'
17
+ require_relative './models/address'
18
+ require_relative './models/blob'
19
+ require_relative './models/bucket'
20
+ require_relative './models/driver'
21
+ require_relative './models/firewall'
22
+ require_relative './models/hardware_profile'
23
+ require_relative './models/image'
24
+ require_relative './models/instance_address'
25
+ require_relative './models/instance'
26
+ require_relative './models/instance_state'
27
+ require_relative './models/key'
28
+ require_relative './models/realm'
29
+ require_relative './models/storage_volume'
30
+ require_relative './models/storage_snapshot'
31
+ require_relative './models/load_balancer'
32
+ require_relative './models/metric'
@@ -0,0 +1,57 @@
1
+ # Licensed to the Apache Software Foundation (ASF) under one or more
2
+ # contributor license agreements. See the NOTICE file distributed with
3
+ # this work for additional information regarding copyright ownership. The
4
+ # ASF licenses this file to you under the Apache License, Version 2.0 (the
5
+ # "License"); you may not use this file except in compliance with the
6
+ # License. You may obtain a copy of the License at
7
+ #
8
+ # http://www.apache.org/licenses/LICENSE-2.0
9
+ #
10
+ # Unless required by applicable law or agreed to in writing, software
11
+ # distributed under the License is distributed on an "AS IS" BASIS, WITHOUT
12
+ # WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. See the
13
+ # License for the specific language governing permissions and limitations
14
+ # under the License.
15
+
16
+ module Deltacloud::Client
17
+ class Address < Base
18
+ include Deltacloud::Client::Methods::Address
19
+
20
+ # Inherited attributes: :_id, :name, :description
21
+
22
+ # Custom attributes:
23
+ #
24
+ attr_reader :ip
25
+ attr_reader :instance_id
26
+
27
+ # Address model methods
28
+ #
29
+
30
+ # Associate the IP address to the +Instance+
31
+ #
32
+ def associate(instance_id)
33
+ associate_address(_id, instance_id)
34
+ end
35
+
36
+ # Disassociate the IP address from +Instance+
37
+ #
38
+ def disassociate
39
+ disassociate_address(_id)
40
+ end
41
+
42
+ def destroy!
43
+ destroy_address(_id)
44
+ end
45
+
46
+ # Parse the Address entity from XML body
47
+ #
48
+ # - xml_body -> Deltacloud API XML representation of the address
49
+ #
50
+ def self.parse(xml_body)
51
+ {
52
+ :ip => xml_body.text_at(:ip),
53
+ :instance_id => xml_body.attr_at('instance', :id)
54
+ }
55
+ end
56
+ end
57
+ end
@@ -0,0 +1,153 @@
1
+ # Licensed to the Apache Software Foundation (ASF) under one or more
2
+ # contributor license agreements. See the NOTICE file distributed with
3
+ # this work for additional information regarding copyright ownership. The
4
+ # ASF licenses this file to you under the Apache License, Version 2.0 (the
5
+ # "License"); you may not use this file except in compliance with the
6
+ # License. You may obtain a copy of the License at
7
+ #
8
+ # http://www.apache.org/licenses/LICENSE-2.0
9
+ #
10
+ # Unless required by applicable law or agreed to in writing, software
11
+ # distributed under the License is distributed on an "AS IS" BASIS, WITHOUT
12
+ # WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. See the
13
+ # License for the specific language governing permissions and limitations
14
+ # under the License.
15
+
16
+ module Deltacloud::Client
17
+
18
+ class Base
19
+
20
+ extend Helpers::XmlHelper
21
+
22
+ include Deltacloud::Client::Helpers::Model
23
+ include Deltacloud::Client::Methods::Api
24
+
25
+ # These attributes are common for all models
26
+ #
27
+ # - obj_id -> The :id of Deltacloud API model (eg. instance ID)
28
+ #
29
+ attr_reader :obj_id
30
+ attr_reader :url
31
+ attr_reader :name
32
+ attr_reader :description
33
+
34
+ # The Base class that other models should inherit from
35
+ # To initialize, you need to supply these mandatory params:
36
+ #
37
+ # - :_client -> Reference to Client instance
38
+ # - :_id -> The 'id' of resource. The '_' is there to avoid conflicts
39
+ #
40
+ def initialize(opts={})
41
+ @options = opts
42
+ @obj_id = @options.delete(:_id)
43
+ # Do not allow to modify the object#base_id
44
+ @obj_id.freeze
45
+ @client = @options.delete(:_client)
46
+ @original_body = @options.delete(:original_body)
47
+ update_instance_variables!(@options)
48
+ end
49
+
50
+ alias_method :_id, :obj_id
51
+
52
+ # Populate instance variables in model
53
+ # This method could also be used to update the variables for already
54
+ # initialized models. Look at +Instance#reload!+ method.
55
+ #
56
+ def update_instance_variables!(opts={})
57
+ @options.merge!(opts)
58
+ @options.each { |key, val| self.instance_variable_set("@#{key}", val) unless val.nil? }
59
+ self
60
+ end
61
+
62
+ # Eye-candy representation of model, without ugly @client representation
63
+ #
64
+ def to_s
65
+ "#<#{self.class.name}> #{@options.merge(:_id => @obj_id).inspect}"
66
+ end
67
+
68
+ # An internal reference to the current Deltacloud::Client::Connection
69
+ # instance. Used for implementing the model methods
70
+ #
71
+ def client
72
+ @client
73
+ end
74
+
75
+ # Shorthand for +client+.connection
76
+ #
77
+ # Return Faraday connection object.
78
+ #
79
+ def connection
80
+ client.connection
81
+ end
82
+
83
+ # Return the cached version of Deltacloud API entrypoint
84
+ #
85
+ def entrypoint
86
+ client.entrypoint
87
+ end
88
+
89
+ # Return the original XML body model was constructed from
90
+ # This might help debugging broken XML
91
+ #
92
+ def original_body
93
+ @original_body
94
+ end
95
+
96
+ # The model#id is the old way for getting the Deltacloud API resource
97
+ # 'id'. However this collide with the Ruby Object#id.
98
+ #
99
+ def id
100
+ warn '[DEPRECATION] `id` is deprecated because of a possible conflict with Object#id. Use `_id` instead.'
101
+ _id
102
+ end
103
+
104
+ class << self
105
+
106
+ # Parse the XML response body from Deltacloud API
107
+ # to +Hash+. Result is then used to create an instance of Deltacloud model
108
+ #
109
+ # NOTE: Children classes **must** implement this class method
110
+ #
111
+ def parse(client_ref, inst)
112
+ warn "The self#parse method **must** be defined in #{self.class.name}"
113
+ {}
114
+ end
115
+
116
+ # Convert the parsed +Hash+ from +parse+ method to instance of Deltacloud model
117
+ #
118
+ # - client_ref -> Reference to the Client instance
119
+ # - obj -> Might be a Nokogiri::Element or Response
120
+ #
121
+ def convert(client_ref, obj)
122
+ body = extract_xml_body(obj).to_xml.root
123
+ attrs = parse(body)
124
+ attrs.merge!({
125
+ :_id => body['id'],
126
+ :url => body['href'],
127
+ :_client => client_ref,
128
+ :name => body.text_at(:name),
129
+ :description => body.text_at(:description)
130
+ })
131
+ validate_attrs!(attrs)
132
+ new(attrs.merge(:original_body => obj))
133
+ end
134
+
135
+ # Convert response for the collection responses.
136
+ #
137
+ def from_collection(client_ref, response)
138
+ response.body.to_xml.xpath('/*/*').map do |entity|
139
+ convert(client_ref, entity)
140
+ end
141
+ end
142
+
143
+ # The :_id and :_client attributes are mandotory
144
+ # to construct a Base model object.
145
+ #
146
+ def validate_attrs!(attrs)
147
+ raise error.new('The :_id must not be nil.') if attrs[:_id].nil?
148
+ raise error.new('The :_client reference is missing.') if attrs[:_client].nil?
149
+ end
150
+
151
+ end
152
+ end
153
+ end
@@ -0,0 +1,56 @@
1
+ # Licensed to the Apache Software Foundation (ASF) under one or more
2
+ # contributor license agreements. See the NOTICE file distributed with
3
+ # this work for additional information regarding copyright ownership. The
4
+ # ASF licenses this file to you under the Apache License, Version 2.0 (the
5
+ # "License"); you may not use this file except in compliance with the
6
+ # License. You may obtain a copy of the License at
7
+ #
8
+ # http://www.apache.org/licenses/LICENSE-2.0
9
+ #
10
+ # Unless required by applicable law or agreed to in writing, software
11
+ # distributed under the License is distributed on an "AS IS" BASIS, WITHOUT
12
+ # WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. See the
13
+ # License for the specific language governing permissions and limitations
14
+ # under the License.
15
+
16
+ module Deltacloud::Client
17
+ class Blob < Base
18
+
19
+ include Deltacloud::Client::Methods::Blob
20
+ include Deltacloud::Client::Methods::Bucket
21
+
22
+ # Inherited attributes: :_id, :name, :description
23
+
24
+ # Custom attributes:
25
+ #
26
+ attr_reader :bucket_id
27
+ attr_reader :content_length
28
+ attr_reader :content_type
29
+ attr_reader :last_modified
30
+ attr_reader :user_metadata
31
+
32
+ # Blob model methods
33
+ #
34
+
35
+ def bucket
36
+ super(bucket_id)
37
+ end
38
+
39
+ # Parse the Blob entity from XML body
40
+ #
41
+ # - xml_body -> Deltacloud API XML representation of the blob
42
+ #
43
+ def self.parse(xml_body)
44
+ {
45
+ :bucket_id => xml_body.text_at(:bucket_id) || xml_body.text_at(:bucket), # FIXME: DC bug
46
+ :content_length => xml_body.text_at(:content_length),
47
+ :content_type => xml_body.text_at(:content_type),
48
+ :last_modified => xml_body.text_at(:last_modified),
49
+ :user_metadata => xml_body.xpath('user_metadata/entry').inject({}) { |r,e|
50
+ r[e['key']] = e.text.strip
51
+ r
52
+ }
53
+ }
54
+ end
55
+ end
56
+ end
@@ -0,0 +1,65 @@
1
+ # Licensed to the Apache Software Foundation (ASF) under one or more
2
+ # contributor license agreements. See the NOTICE file distributed with
3
+ # this work for additional information regarding copyright ownership. The
4
+ # ASF licenses this file to you under the Apache License, Version 2.0 (the
5
+ # "License"); you may not use this file except in compliance with the
6
+ # License. You may obtain a copy of the License at
7
+ #
8
+ # http://www.apache.org/licenses/LICENSE-2.0
9
+ #
10
+ # Unless required by applicable law or agreed to in writing, software
11
+ # distributed under the License is distributed on an "AS IS" BASIS, WITHOUT
12
+ # WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. See the
13
+ # License for the specific language governing permissions and limitations
14
+ # under the License.
15
+
16
+ module Deltacloud::Client
17
+ class Bucket < Base
18
+
19
+ include Deltacloud::Client::Methods::Bucket
20
+ include Deltacloud::Client::Methods::Blob
21
+
22
+ # Inherited attributes: :_id, :name, :description
23
+
24
+ # Custom attributes:
25
+ #
26
+ attr_reader :size
27
+ attr_reader :blob_ids
28
+
29
+ # Bucket model methods
30
+ #
31
+ #
32
+
33
+ # All blobs associated with the current bucket
34
+ # The 'bucket_id' should not be set in this case.
35
+ #
36
+ def blobs(bucket_id=nil)
37
+ super(_id)
38
+ end
39
+
40
+ # Add a new blob to the bucket.
41
+ # See: methods/blob.rb +create_blob+
42
+ #
43
+ def add_blob(blob_name, blob_data, blob_create_opts={})
44
+ create_blob(_id, blob_name, blob_data, create_opts)
45
+ end
46
+
47
+ # Remove a blob from the bucket
48
+ # See: methods/blob.rb +destroy_blob+
49
+ #
50
+ def remove_blob(blob_id)
51
+ destroy_blob(_id, blob_id)
52
+ end
53
+
54
+ # Parse the Bucket entity from XML body
55
+ #
56
+ # - xml_body -> Deltacloud API XML representation of the bucket
57
+ #
58
+ def self.parse(xml_body)
59
+ {
60
+ :size => xml_body.text_at(:size),
61
+ :blob_ids => xml_body.xpath('blob').map { |b| b['id'] }
62
+ }
63
+ end
64
+ end
65
+ end
@@ -0,0 +1,87 @@
1
+ # Licensed to the Apache Software Foundation (ASF) under one or more
2
+ # contributor license agreements. See the NOTICE file distributed with
3
+ # this work for additional information regarding copyright ownership. The
4
+ # ASF licenses this file to you under the Apache License, Version 2.0 (the
5
+ # "License"); you may not use this file except in compliance with the
6
+ # License. You may obtain a copy of the License at
7
+ #
8
+ # http://www.apache.org/licenses/LICENSE-2.0
9
+ #
10
+ # Unless required by applicable law or agreed to in writing, software
11
+ # distributed under the License is distributed on an "AS IS" BASIS, WITHOUT
12
+ # WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. See the
13
+ # License for the specific language governing permissions and limitations
14
+ # under the License.
15
+
16
+ module Deltacloud::Client
17
+
18
+ class Driver < Base
19
+
20
+ attr_reader :providers
21
+
22
+ # Syntax sugar for returning provider from Driver
23
+ # instance:
24
+ #
25
+ # client.driver(:ec2)['us-west-1'] # => List of endpoints
26
+ #
27
+ # - provider_id -> Provider ID, like 'us-west-1'
28
+ #
29
+ def [](provider_id)
30
+ @providers ||= []
31
+ prov = @providers.find { |p| p.name == provider_id }
32
+ prov.instance_variable_set('@client', @client)
33
+ prov
34
+ end
35
+
36
+ def self.parse(xml_body)
37
+ {
38
+ :providers => xml_body.xpath('provider').map { |p| Provider.parse(p) }
39
+ }
40
+ end
41
+
42
+ class Provider
43
+
44
+ attr_reader :name
45
+ attr_reader :entrypoints
46
+
47
+ def initialize(name, entrypoints=[])
48
+ @name = name
49
+ @entrypoints = entrypoints
50
+ end
51
+
52
+ # Syntax sugar for retrieving list of endpoints available for the
53
+ # provider
54
+ #
55
+ # - entrypoint_id -> Entrypoint ID, like 's3'
56
+ #
57
+ def [](entrypoint_id)
58
+ @entrypoints ||= []
59
+ ent_point = @entrypoints.find { |name, _| name == entrypoint_id }
60
+ ent_point ? ent_point.last : nil
61
+ end
62
+
63
+ # Method to check if given credentials can be used to authorize
64
+ # connection to current provider:
65
+ #
66
+ # client.driver(:ec2)['us-west-1'].valid_credentials? 'user', 'password'
67
+ #
68
+ # - api_user -> API key
69
+ # - api_password -> API secret
70
+ #
71
+ def valid_credentials?(api_user, api_password)
72
+ unless @client
73
+ raise error.new('Please use driver("ec2")[API_PROVIDER].valid_credentials?')
74
+ end
75
+ @client.use(@client.current_driver, api_user, api_password, @name).valid_credentials?
76
+ end
77
+
78
+ def self.parse(p)
79
+ new(
80
+ p['id'],
81
+ p.xpath('entrypoint').inject({}) { |r, e| r[e['kind']] = e.text.strip; r }
82
+ )
83
+ end
84
+ end
85
+
86
+ end
87
+ end