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.
- data/README.md +73 -0
- data/Rakefile +88 -5
- data/lib/deltacloud/client.rb +79 -0
- data/lib/deltacloud/client/base_error.rb +80 -0
- data/lib/deltacloud/client/connection.rb +139 -0
- data/lib/deltacloud/client/helpers/model_helper.rb +69 -0
- data/lib/deltacloud/client/helpers/property_helper.rb +103 -0
- data/lib/deltacloud/client/helpers/xml_helper.rb +33 -0
- data/lib/deltacloud/client/methods.rb +33 -0
- data/lib/deltacloud/client/methods/address.rb +67 -0
- data/lib/deltacloud/client/methods/api.rb +96 -0
- data/lib/deltacloud/client/methods/backward_compatiblity.rb +72 -0
- data/lib/deltacloud/client/methods/blob.rb +91 -0
- data/lib/deltacloud/client/methods/bucket.rb +55 -0
- data/lib/deltacloud/client/methods/common.rb +46 -0
- data/lib/deltacloud/client/methods/driver.rb +53 -0
- data/lib/deltacloud/client/methods/firewall.rb +67 -0
- data/lib/deltacloud/client/methods/hardware_profile.rb +41 -0
- data/lib/deltacloud/client/methods/image.rb +61 -0
- data/lib/deltacloud/client/methods/instance.rb +141 -0
- data/lib/deltacloud/client/methods/instance_state.rb +41 -0
- data/lib/deltacloud/client/methods/key.rb +58 -0
- data/lib/deltacloud/client/methods/load_balancer.rb +96 -0
- data/lib/deltacloud/client/methods/metric.rb +54 -0
- data/lib/deltacloud/client/methods/realm.rb +42 -0
- data/lib/deltacloud/client/methods/storage_snapshot.rb +61 -0
- data/lib/deltacloud/client/methods/storage_volume.rb +94 -0
- data/lib/deltacloud/client/models.rb +32 -0
- data/lib/deltacloud/client/models/address.rb +57 -0
- data/lib/deltacloud/client/models/base.rb +153 -0
- data/lib/deltacloud/client/models/blob.rb +56 -0
- data/lib/deltacloud/client/models/bucket.rb +65 -0
- data/lib/deltacloud/client/models/driver.rb +87 -0
- data/lib/deltacloud/client/models/firewall.rb +64 -0
- data/lib/deltacloud/client/models/hardware_profile.rb +68 -0
- data/lib/deltacloud/client/models/image.rb +60 -0
- data/lib/deltacloud/client/models/instance.rb +142 -0
- data/lib/deltacloud/client/models/instance_address.rb +40 -0
- data/lib/{instance_state.rb → deltacloud/client/models/instance_state.rb} +11 -3
- data/lib/deltacloud/client/models/key.rb +52 -0
- data/lib/deltacloud/client/models/load_balancer.rb +55 -0
- data/lib/deltacloud/client/models/metric.rb +72 -0
- data/lib/deltacloud/client/models/realm.rb +29 -0
- data/lib/deltacloud/client/models/storage_snapshot.rb +54 -0
- data/lib/deltacloud/client/models/storage_volume.rb +96 -0
- data/lib/deltacloud/core_ext.rb +19 -0
- data/lib/deltacloud/core_ext/element.rb +32 -0
- data/lib/deltacloud/core_ext/fixnum.rb +30 -0
- data/lib/deltacloud/core_ext/nil.rb +22 -0
- data/lib/{string.rb → deltacloud/core_ext/string.rb} +16 -26
- data/lib/deltacloud/error_response.rb +93 -0
- data/tests/client/client_test.rb +51 -0
- data/tests/client/connection_test.rb +77 -0
- data/tests/core_ext/element_test.rb +40 -0
- data/tests/core_ext/fixnum_test.rb +35 -0
- data/tests/core_ext/nil.rb +27 -0
- data/tests/core_ext/string_test.rb +47 -0
- data/tests/fixtures/instances_cleanup.yml +681 -0
- data/tests/fixtures/test_0001_connects_to_Deltacloud_API.yml +60 -0
- data/tests/fixtures/test_0001_support_cpu.yml +444 -0
- data/tests/fixtures/test_0001_support_original_body.yml +116 -0
- data/tests/fixtures/test_0001_supports_addresses.yml +178 -0
- data/tests/fixtures/test_0001_supports_api_host.yml +60 -0
- data/tests/fixtures/test_0001_supports_attached_.yml +282 -0
- data/tests/fixtures/test_0001_supports_blobs.yml +475 -0
- data/tests/fixtures/test_0001_supports_bucket.yml +200 -0
- data/tests/fixtures/test_0001_supports_buckets.yml +160 -0
- data/tests/fixtures/test_0001_supports_drivers.yml +202 -0
- data/tests/fixtures/test_0001_supports_firewalls.yml +399 -0
- data/tests/fixtures/test_0001_supports_hardware_profiles.yml +262 -0
- data/tests/fixtures/test_0001_supports_images.yml +224 -0
- data/tests/fixtures/test_0001_supports_instance_states.yml +156 -0
- data/tests/fixtures/test_0001_supports_instances.yml +486 -0
- data/tests/fixtures/test_0001_supports_keys.yml +198 -0
- data/tests/fixtures/test_0001_supports_path.yml +60 -0
- data/tests/fixtures/test_0001_supports_realms.yml +152 -0
- data/tests/fixtures/test_0001_supports_storage_snapshots.yml +164 -0
- data/tests/fixtures/test_0001_supports_storage_volumes.yml +176 -0
- data/tests/fixtures/test_0001_supports_to_get_providers.yml +410 -0
- data/tests/fixtures/test_0002_support_blob.yml +148 -0
- data/tests/fixtures/test_0002_support_instance_state.yml +204 -0
- data/tests/fixtures/test_0002_support_memory.yml +444 -0
- data/tests/fixtures/test_0002_support_on_Provider.yml +130 -0
- data/tests/fixtures/test_0002_supports_api_port.yml +60 -0
- data/tests/fixtures/test_0002_supports_api_uri.yml +60 -0
- data/tests/fixtures/test_0002_supports_driver.yml +219 -0
- data/tests/fixtures/test_0002_supports_extract_xml_body_using_faraday_connection.yml +117 -0
- data/tests/fixtures/test_0002_supports_filtering_addresses_by_id_param.yml +156 -0
- data/tests/fixtures/test_0002_supports_filtering_buckets_by_id_param.yml +156 -0
- data/tests/fixtures/test_0002_supports_filtering_firewalls_by_id_param.yml +207 -0
- data/tests/fixtures/test_0002_supports_filtering_hardware_profiles_by_id_param.yml +158 -0
- data/tests/fixtures/test_0002_supports_filtering_images_by_id_param.yml +165 -0
- data/tests/fixtures/test_0002_supports_filtering_instances_by_id_param.yml +164 -0
- data/tests/fixtures/test_0002_supports_filtering_keys_by_id_param.yml +178 -0
- data/tests/fixtures/test_0002_supports_filtering_realms_by_id.yml +104 -0
- data/tests/fixtures/test_0002_supports_filtering_storage_snapshots_by_id_param.yml +155 -0
- data/tests/fixtures/test_0002_supports_filtering_storage_volumes_by_id_param.yml +157 -0
- data/tests/fixtures/test_0002_supports_hardware_profiles.yml +262 -0
- data/tests/fixtures/test_0002_supports_is_compatible_.yml +116 -0
- data/tests/fixtures/test_0002_supports_snapshot_.yml +202 -0
- data/tests/fixtures/test_0002_supports_version.yml +60 -0
- data/tests/fixtures/test_0003_caches_the_API_entrypoint.yml +60 -0
- data/tests/fixtures/test_0003_support_address.yml +197 -0
- data/tests/fixtures/test_0003_support_bucket.yml +198 -0
- data/tests/fixtures/test_0003_support_create_blob.yml +105 -0
- data/tests/fixtures/test_0003_support_create_blob_and_destroy_blob.yml +138 -0
- data/tests/fixtures/test_0003_support_firewall.yml +768 -0
- data/tests/fixtures/test_0003_support_hardware_profile.yml +199 -0
- data/tests/fixtures/test_0003_support_image.yml +207 -0
- data/tests/fixtures/test_0003_support_instance.yml +206 -0
- data/tests/fixtures/test_0003_support_key.yml +220 -0
- data/tests/fixtures/test_0003_support_realm.yml +195 -0
- data/tests/fixtures/test_0003_support_storage.yml +444 -0
- data/tests/fixtures/test_0003_support_storage_snapshot.yml +196 -0
- data/tests/fixtures/test_0003_support_storage_volume.yml +197 -0
- data/tests/fixtures/test_0003_support_to_change_driver_with_Client.yml +72 -0
- data/tests/fixtures/test_0003_supports_connect.yml +60 -0
- data/tests/fixtures/test_0003_supports_extract_xml_body_using_nokogiri_document.yml +117 -0
- data/tests/fixtures/test_0003_supports_instance.yml +396 -0
- data/tests/fixtures/test_0003_supports_is_compatible_.yml +116 -0
- data/tests/fixtures/test_0003_supports_lunch_image.yml +367 -0
- data/tests/fixtures/test_0003_supports_providers.yml +102 -0
- data/tests/fixtures/test_0003_supports_version.yml +60 -0
- data/tests/fixtures/test_0004_support_architecture.yml +444 -0
- data/tests/fixtures/test_0004_support_create_address.yml +197 -0
- data/tests/fixtures/test_0004_support_create_blob_and_destroy_blob_with_meta_params.yml +139 -0
- data/tests/fixtures/test_0004_support_create_bucket.yml +180 -0
- data/tests/fixtures/test_0004_support_create_bucket_and_destroy_bucket.yml +180 -0
- data/tests/fixtures/test_0004_support_create_firewall_and_destroy_firewall.yml +496 -0
- data/tests/fixtures/test_0004_support_create_image_and_destroy_image.yml +1527 -0
- data/tests/fixtures/test_0004_support_create_instance.yml +115 -0
- data/tests/fixtures/test_0004_support_create_key_and_destroy_key.yml +206 -0
- data/tests/fixtures/test_0004_support_create_volume.yml +105 -0
- data/tests/fixtures/test_0004_support_create_volume_and_destroy_volume.yml +181 -0
- data/tests/fixtures/test_0004_support_to_test_of_valid_DC_connection.yml +60 -0
- data/tests/fixtures/test_0004_supports_current_driver.yml +60 -0
- data/tests/fixtures/test_0004_supports_extract_xml_body_using_nokogiri_element.yml +117 -0
- data/tests/fixtures/test_0004_supports_lunch_image.yml +312 -0
- data/tests/fixtures/test_0004_supports_valid_credentials_.yml +215 -0
- data/tests/fixtures/test_0004_supports_with_config.yml +129 -0
- data/tests/fixtures/test_0005_support_attach_storage_volume.yml +102 -0
- data/tests/fixtures/test_0005_support_attach_storage_volume_and_detach_storage_volume.yml +142 -0
- data/tests/fixtures/test_0005_support_create_instance_with_hwp_id.yml +115 -0
- data/tests/fixtures/test_0005_support_opaque_.yml +152 -0
- data/tests/fixtures/test_0005_supports_current_provider.yml +134 -0
- data/tests/fixtures/test_0005_supports_id.yml +116 -0
- data/tests/fixtures/test_0005_supports_switching_drivers_per_instance.yml +129 -0
- data/tests/fixtures/test_0005_supports_use_driver.yml +60 -0
- data/tests/fixtures/test_0006_support_create_instance_with_realm_id.yml +115 -0
- data/tests/fixtures/test_0006_supports_discovered_.yml +60 -0
- data/tests/fixtures/test_0006_supports_supported_collections.yml +60 -0
- data/tests/fixtures/test_0006_supports_switching_providers_per_instance.yml +208 -0
- data/tests/fixtures/test_0007_support_create_instance_with_name.yml +115 -0
- data/tests/fixtures/test_0007_support_switching_provider_without_credentials.yml +208 -0
- data/tests/fixtures/test_0007_supports_support_.yml +60 -0
- data/tests/fixtures/test_0007_supports_valid_credentials_on_class.yml +370 -0
- data/tests/fixtures/test_0008_support_stop_instance.yml +166 -0
- data/tests/fixtures/test_0008_supports_must_support_.yml +60 -0
- data/tests/fixtures/test_0009_support_start_instance.yml +217 -0
- data/tests/fixtures/test_0009_supports_features.yml +60 -0
- data/tests/fixtures/test_0010_support_reboot_instance.yml +166 -0
- data/tests/fixtures/test_0010_supports_feature_.yml +60 -0
- data/tests/helpers/model_test.rb +33 -0
- data/tests/helpers/xml_test.rb +56 -0
- data/tests/methods/address_test.rb +64 -0
- data/tests/methods/api_test.rb +97 -0
- data/tests/methods/backward_compatibility_test.rb +87 -0
- data/tests/methods/blob_test.rb +64 -0
- data/tests/methods/bucket_test.rb +62 -0
- data/tests/methods/driver_test.rb +48 -0
- data/tests/methods/firewall_test.rb +84 -0
- data/tests/methods/hardware_profile_test.rb +53 -0
- data/tests/methods/image_test.rb +64 -0
- data/tests/methods/instance_state_test.rb +43 -0
- data/tests/methods/instance_test.rb +126 -0
- data/tests/methods/key_test.rb +63 -0
- data/tests/methods/realm_test.rb +50 -0
- data/tests/methods/storage_snapshot_test.rb +53 -0
- data/tests/methods/storage_volume_test.rb +81 -0
- data/tests/models/blob_test.rb +40 -0
- data/tests/models/bucket_test.rb +37 -0
- data/tests/models/driver_test.rb +42 -0
- data/tests/models/hardware_profile_test.rb +80 -0
- data/tests/models/image_test.rb +65 -0
- data/tests/models/storage_volume_test.rb +52 -0
- data/tests/test_helper.rb +59 -11
- metadata +392 -41
- data/lib/base_object.rb +0 -386
- data/lib/client_bucket_methods.rb +0 -69
- data/lib/deltacloud.rb +0 -486
- data/lib/documentation.rb +0 -59
- data/lib/errors.rb +0 -140
- data/lib/hwp_properties.rb +0 -61
- data/tests/buckets_test.rb +0 -141
- data/tests/client_test.rb +0 -59
- data/tests/content_negotiation_test.rb +0 -127
- data/tests/errors_test.rb +0 -57
- data/tests/hardware_profiles_test.rb +0 -75
- data/tests/images_test.rb +0 -102
- data/tests/instance_states_test.rb +0 -66
- data/tests/instances_test.rb +0 -203
- data/tests/keys_test.rb +0 -81
- data/tests/realms_test.rb +0 -64
- data/tests/storage_snapshot_test.rb +0 -76
- data/tests/storage_volume_test.rb +0 -86
@@ -0,0 +1,41 @@
|
|
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
|
+
module Methods
|
18
|
+
module InstanceState
|
19
|
+
|
20
|
+
# Representation of the current driver state machine
|
21
|
+
#
|
22
|
+
def instance_states
|
23
|
+
r = connection.get(api_uri("instance_states"))
|
24
|
+
r.body.to_xml.root.xpath('state').map do |se|
|
25
|
+
state = model(:instance_state).new_state(se['name'])
|
26
|
+
se.xpath('transition').each do |te|
|
27
|
+
state.transitions << model(:instance_state).new_transition(
|
28
|
+
te['to'], te['action']
|
29
|
+
)
|
30
|
+
end
|
31
|
+
state
|
32
|
+
end
|
33
|
+
end
|
34
|
+
|
35
|
+
def instance_state(name)
|
36
|
+
instance_states.find { |s| s.name.to_s.eql?(name.to_s) }
|
37
|
+
end
|
38
|
+
|
39
|
+
end
|
40
|
+
end
|
41
|
+
end
|
@@ -0,0 +1,58 @@
|
|
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
|
+
module Methods
|
18
|
+
module Key
|
19
|
+
|
20
|
+
# Retrieve list of all key entities
|
21
|
+
#
|
22
|
+
# - filter_opts:
|
23
|
+
# - :id -> Filter entities using 'id' attribute
|
24
|
+
#
|
25
|
+
def keys(filter_opts={})
|
26
|
+
from_collection :keys,
|
27
|
+
connection.get(api_uri('keys'), filter_opts)
|
28
|
+
end
|
29
|
+
|
30
|
+
# Retrieve the single key entity
|
31
|
+
#
|
32
|
+
# - key_id -> Key entity to retrieve
|
33
|
+
#
|
34
|
+
def key(key_id)
|
35
|
+
from_resource :key,
|
36
|
+
connection.get(api_uri("keys/#{key_id}"))
|
37
|
+
end
|
38
|
+
|
39
|
+
# Create a new credentials to use with authentication
|
40
|
+
# to an +Instance+
|
41
|
+
#
|
42
|
+
# - key_name -> The name of the key
|
43
|
+
# - create_opts
|
44
|
+
# : public_key -> Your SSH public key (eg. ~/.ssh/id_rsa.pub)
|
45
|
+
#
|
46
|
+
def create_key(key_name, create_opts={})
|
47
|
+
create_resource :key, create_opts.merge(:name => key_name)
|
48
|
+
end
|
49
|
+
|
50
|
+
# Destroy the SSH key
|
51
|
+
#
|
52
|
+
def destroy_key(key_id)
|
53
|
+
destroy_resource :key, key_id
|
54
|
+
end
|
55
|
+
|
56
|
+
end
|
57
|
+
end
|
58
|
+
end
|
@@ -0,0 +1,96 @@
|
|
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
|
+
module Methods
|
18
|
+
module LoadBalancer
|
19
|
+
|
20
|
+
# Retrieve list of all load_balancer entities
|
21
|
+
#
|
22
|
+
# Filter options:
|
23
|
+
#
|
24
|
+
# - :id -> Filter entities using 'id' attribute
|
25
|
+
#
|
26
|
+
def load_balancers(filter_opts={})
|
27
|
+
from_collection :load_balancers,
|
28
|
+
connection.get(api_uri('load_balancers'), filter_opts)
|
29
|
+
end
|
30
|
+
|
31
|
+
# Retrieve the single load_balancer entity
|
32
|
+
#
|
33
|
+
# - load_balancer_id -> LoadBalancer entity to retrieve
|
34
|
+
#
|
35
|
+
def load_balancer(load_balancer_id)
|
36
|
+
from_resource :load_balancer,
|
37
|
+
connection.get(api_uri("load_balancers/#{load_balancer_id}"))
|
38
|
+
end
|
39
|
+
|
40
|
+
# Destroy load balancer
|
41
|
+
# Returns 'true' if the response was 204 No Content
|
42
|
+
#
|
43
|
+
# - load_balancer_id -> The 'id' of the LoadBalancer to destroy
|
44
|
+
#
|
45
|
+
def destroy_load_balancer(load_balancer_id)
|
46
|
+
destroy_resource :load_balancer, load_balancer_id
|
47
|
+
end
|
48
|
+
|
49
|
+
# Create a new load_balancer
|
50
|
+
#
|
51
|
+
# - create_opts
|
52
|
+
# :name - Load Balancer name
|
53
|
+
# :realm_id - Load Balancer realm id
|
54
|
+
# :listener_protocol - Protocol to use for LB listener (HTTP or TCP)
|
55
|
+
# :listener_balancer_port - Load Balancer port (like. 80)
|
56
|
+
# :listener_instance_port - Instances port (like, 8080)
|
57
|
+
#
|
58
|
+
# Example:
|
59
|
+
#
|
60
|
+
# client.create_load_balancer(:name => 'test2', :realm_id => 'us-east-1a', :listener_protocol => 'HTTP', :listener_balancer_port => '80', :listener_instance_port => '8080')
|
61
|
+
#
|
62
|
+
def create_load_balancer(create_opts={})
|
63
|
+
must_support! :load_balancers
|
64
|
+
response = connection.post(api_uri('load_balancers')) do |request|
|
65
|
+
request.params = create_opts
|
66
|
+
end
|
67
|
+
model(:load_balancer).convert(self, response.body)
|
68
|
+
end
|
69
|
+
|
70
|
+
# Register an Instance to given Load Balancer
|
71
|
+
#
|
72
|
+
# load_balancer_id - Load Balancer to use
|
73
|
+
# instance_id - Instance to register to load balancer
|
74
|
+
#
|
75
|
+
def register_instance(load_balancer_id, instance_id)
|
76
|
+
response = connection.post(api_uri("/load_balancers/#{load_balancer_id}/register")) do |request|
|
77
|
+
request.params = { 'instance_id' => instance_id }
|
78
|
+
end
|
79
|
+
model(:load_balancer).convert(self, response.body)
|
80
|
+
end
|
81
|
+
|
82
|
+
# Unregister an Instance from given Load Balancer
|
83
|
+
#
|
84
|
+
# load_balancer_id - Load Balancer to use
|
85
|
+
# instance_id - Instance to unregister from load balancer
|
86
|
+
#
|
87
|
+
def unregister_instance(load_balancer_id, instance_id)
|
88
|
+
response = connection.post(api_uri("/load_balancers/#{load_balancer_id}/unregister")) do |request|
|
89
|
+
request.params = { 'instance_id' => instance_id }
|
90
|
+
end
|
91
|
+
model(:load_balancer).convert(self, response.body)
|
92
|
+
end
|
93
|
+
|
94
|
+
end
|
95
|
+
end
|
96
|
+
end
|
@@ -0,0 +1,54 @@
|
|
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
|
+
module Methods
|
18
|
+
module Metric
|
19
|
+
|
20
|
+
# Retrieve list of all metric entities
|
21
|
+
#
|
22
|
+
# Filter options:
|
23
|
+
#
|
24
|
+
# - :id -> Filter entities using 'id' attribute
|
25
|
+
#
|
26
|
+
def metrics(filter_opts={})
|
27
|
+
from_collection :metrics,
|
28
|
+
connection.get(api_uri('metrics'), filter_opts)
|
29
|
+
end
|
30
|
+
|
31
|
+
# Retrieve the single metric entity
|
32
|
+
#
|
33
|
+
# - metric_id -> Metric entity to retrieve
|
34
|
+
#
|
35
|
+
def metric(metric_id)
|
36
|
+
from_resource :metric,
|
37
|
+
connection.get(api_uri("metrics/#{metric_id}"))
|
38
|
+
end
|
39
|
+
|
40
|
+
# Create a new metric
|
41
|
+
#
|
42
|
+
# - create_opts
|
43
|
+
#
|
44
|
+
# def create_metric(create_opts={})
|
45
|
+
# must_support! :metrics
|
46
|
+
# response = connection.post(api_uri('metrics')) do |request|
|
47
|
+
# request.params = create_opts
|
48
|
+
# end
|
49
|
+
# model(:metric).convert(self, response.body)
|
50
|
+
# end
|
51
|
+
|
52
|
+
end
|
53
|
+
end
|
54
|
+
end
|
@@ -0,0 +1,42 @@
|
|
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
|
+
module Methods
|
18
|
+
module Realm
|
19
|
+
|
20
|
+
# Retrieve list of all realms
|
21
|
+
#
|
22
|
+
# - filter_opts:
|
23
|
+
# - :id -> Filter realms using their 'id'
|
24
|
+
# - :state -> Filter realms by their 'state'
|
25
|
+
#
|
26
|
+
def realms(filter_opts={})
|
27
|
+
from_collection :realms,
|
28
|
+
connection.get(api_uri("realms"), filter_opts)
|
29
|
+
end
|
30
|
+
|
31
|
+
# Retrieve the given realm
|
32
|
+
#
|
33
|
+
# - realm_id -> Instance to retrieve
|
34
|
+
#
|
35
|
+
def realm(realm_id)
|
36
|
+
from_resource :realm,
|
37
|
+
connection.get(api_uri("realms/#{realm_id}"))
|
38
|
+
end
|
39
|
+
|
40
|
+
end
|
41
|
+
end
|
42
|
+
end
|
@@ -0,0 +1,61 @@
|
|
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
|
+
module Methods
|
18
|
+
module StorageSnapshot
|
19
|
+
|
20
|
+
# Retrieve list of all storage_snapshot entities
|
21
|
+
#
|
22
|
+
# - filter_options:
|
23
|
+
# - :id -> Filter entities using 'id' attribute
|
24
|
+
#
|
25
|
+
def storage_snapshots(filter_opts={})
|
26
|
+
from_collection :storage_snapshots,
|
27
|
+
connection.get(api_uri('storage_snapshots'), filter_opts)
|
28
|
+
end
|
29
|
+
|
30
|
+
# Retrieve the single storage_snapshot entity
|
31
|
+
#
|
32
|
+
# - storage_snapshot_id -> StorageSnapshot entity to retrieve
|
33
|
+
#
|
34
|
+
def storage_snapshot(storage_snapshot_id)
|
35
|
+
from_resource :storage_snapshot,
|
36
|
+
connection.get(api_uri("storage_snapshots/#{storage_snapshot_id}"))
|
37
|
+
end
|
38
|
+
|
39
|
+
# Create a new StorageSnapshot based on +volume_id+
|
40
|
+
#
|
41
|
+
# - volume_id -> ID of the +StorageVolume+ to create snapshot from
|
42
|
+
# - create_opts ->
|
43
|
+
# - :name -> Name of the StorageSnapshot
|
44
|
+
# - :description -> Description of the StorageSnapshot
|
45
|
+
#
|
46
|
+
def create_storage_snapshot(volume_id, create_opts={})
|
47
|
+
create_resource :storage_snapshot, create_opts.merge(:volume_id => volume_id)
|
48
|
+
end
|
49
|
+
|
50
|
+
# Destroy the current +StorageSnapshot+
|
51
|
+
# Returns 'true' if the response was 204 No Content
|
52
|
+
#
|
53
|
+
# - snapshot_id -> The 'id' of the snapshot to destroy
|
54
|
+
#
|
55
|
+
def destroy_storage_snapshot(snapshot_id)
|
56
|
+
destroy_resource :storage_snapshot, snapshot_id
|
57
|
+
end
|
58
|
+
|
59
|
+
end
|
60
|
+
end
|
61
|
+
end
|
@@ -0,0 +1,94 @@
|
|
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
|
+
module Methods
|
18
|
+
module StorageVolume
|
19
|
+
|
20
|
+
# Retrieve list of all storage_volumes
|
21
|
+
#
|
22
|
+
# - filter_opts:
|
23
|
+
# - :id -> Filter storage_volumes using their 'id'
|
24
|
+
# - :state -> Filter storage_volumes by their 'state'
|
25
|
+
#
|
26
|
+
def storage_volumes(filter_opts={})
|
27
|
+
from_collection :storage_volumes,
|
28
|
+
connection.get(api_uri("storage_volumes"), filter_opts)
|
29
|
+
end
|
30
|
+
|
31
|
+
# Retrieve the given storage_volume
|
32
|
+
#
|
33
|
+
# - storage_volume_id -> Instance to retrieve
|
34
|
+
#
|
35
|
+
def storage_volume(storage_volume_id)
|
36
|
+
from_resource :storage_volume,
|
37
|
+
connection.get(api_uri("storage_volumes/#{storage_volume_id}"))
|
38
|
+
end
|
39
|
+
|
40
|
+
# Create new storage volume
|
41
|
+
#
|
42
|
+
# - :snapshot_id -> Snapshot to use for creating a new volume
|
43
|
+
# - :capacity -> Initial Volume capacity
|
44
|
+
# - :realm_id -> Create volume in this realm
|
45
|
+
# - :name -> Volume name
|
46
|
+
# - :description -> Volume description
|
47
|
+
#
|
48
|
+
# NOTE: Some create options might not be supported by backend cloud
|
49
|
+
#
|
50
|
+
def create_storage_volume(create_opts={})
|
51
|
+
create_resource :storage_volume, create_opts
|
52
|
+
end
|
53
|
+
|
54
|
+
# Destroy the current +StorageVolume+
|
55
|
+
# Returns 'true' if the response was 204 No Content
|
56
|
+
#
|
57
|
+
# - volume_id -> The 'id' of the volume to destroy
|
58
|
+
#
|
59
|
+
def destroy_storage_volume(volume_id)
|
60
|
+
destroy_resource :storage_volume, volume_id
|
61
|
+
end
|
62
|
+
|
63
|
+
# Attach the Storage Volume to the Instance
|
64
|
+
# The +device+ parameter could be used if supported.
|
65
|
+
#
|
66
|
+
# - volume_id -> Volume ID (eg. 'vol1')
|
67
|
+
# - instance_id -> Target Instance ID (eg. 'inst1')
|
68
|
+
# - device -> Target device in Instance (eg. '/dev/sda2')
|
69
|
+
#
|
70
|
+
def attach_storage_volume(volume_id, instance_id, device=nil)
|
71
|
+
must_support! :storage_volumes
|
72
|
+
result = connection.post(api_uri("/storage_volumes/#{volume_id}/attach")) do |r|
|
73
|
+
r.params = { :instance_id => instance_id, :device => device }
|
74
|
+
end
|
75
|
+
if result.status.is_ok?
|
76
|
+
from_resource(:storage_volume, result)
|
77
|
+
end
|
78
|
+
end
|
79
|
+
|
80
|
+
# Detach the Storage Volume from the Instance
|
81
|
+
#
|
82
|
+
# -volume_id -> Volume to detach
|
83
|
+
#
|
84
|
+
def detach_storage_volume(volume_id)
|
85
|
+
must_support! :storage_volumes
|
86
|
+
result = connection.post(api_uri("/storage_volumes/#{volume_id}/detach"))
|
87
|
+
if result.status.is_ok?
|
88
|
+
from_resource(:storage_volume, result)
|
89
|
+
end
|
90
|
+
end
|
91
|
+
|
92
|
+
end
|
93
|
+
end
|
94
|
+
end
|