deltacloud-core 0.5.0 → 1.0.0
Sign up to get free protection for your applications and to get access to all the features.
- data/NOTICE +1 -1
- data/Rakefile +63 -21
- data/bin/deltacloudd +10 -6
- data/config.ru +62 -6
- data/config/drivers/ec2.yaml +8 -0
- data/config/drivers/fgcp.yaml +13 -0
- data/deltacloud-core.gemspec +10 -2
- data/lib/cimi/collections.rb +58 -0
- data/lib/cimi/collections/address_templates.rb +49 -0
- data/lib/cimi/collections/addresses.rb +74 -0
- data/lib/cimi/collections/cloud_entry_point.rb +37 -0
- data/lib/{deltacloud/helpers/conversion_helper.rb → cimi/collections/entity_metadata.rb} +24 -16
- data/lib/cimi/collections/machine_admins.rb +74 -0
- data/lib/cimi/collections/machine_configurations.rb +49 -0
- data/lib/cimi/collections/machine_images.rb +50 -0
- data/lib/cimi/collections/machines.rb +157 -0
- data/lib/cimi/collections/network_configurations.rb +47 -0
- data/lib/cimi/collections/network_templates.rb +48 -0
- data/lib/cimi/collections/networks.rb +125 -0
- data/lib/cimi/collections/routing_group_templates.rb +47 -0
- data/lib/cimi/collections/routing_groups.rb +48 -0
- data/lib/cimi/collections/volume_configurations.rb +48 -0
- data/lib/cimi/collections/volume_images.rb +50 -0
- data/lib/cimi/collections/volumes.rb +80 -0
- data/lib/cimi/collections/vsp_configurations.rb +48 -0
- data/lib/cimi/collections/vsp_templates.rb +50 -0
- data/lib/cimi/collections/vsps.rb +108 -0
- data/lib/cimi/dependencies.rb +1 -0
- data/lib/cimi/helpers.rb +116 -0
- data/lib/cimi/helpers/cimi_helper.rb +6 -2
- data/lib/cimi/models.rb +72 -0
- data/lib/cimi/{model → models}/action.rb +1 -1
- data/lib/cimi/models/address.rb +72 -0
- data/lib/cimi/models/address_collection.rb +34 -0
- data/lib/cimi/models/address_template.rb +54 -0
- data/lib/cimi/models/address_template_collection.rb +34 -0
- data/lib/cimi/{model → models}/base.rb +2 -2
- data/lib/cimi/{model → models}/cloud_entry_point.rb +3 -5
- data/lib/cimi/{model → models}/entity_metadata.rb +7 -6
- data/lib/cimi/{model → models}/entity_metadata_collection.rb +2 -2
- data/lib/cimi/{model → models}/errors.rb +8 -0
- data/lib/cimi/{model → models}/machine.rb +10 -10
- data/lib/cimi/{model → models}/machine_admin.rb +1 -1
- data/lib/cimi/{model → models}/machine_admin_collection.rb +2 -2
- data/lib/cimi/{model → models}/machine_collection.rb +2 -2
- data/lib/cimi/{model → models}/machine_configuration.rb +9 -6
- data/lib/cimi/{model → models}/machine_configuration_collection.rb +2 -2
- data/lib/cimi/{model → models}/machine_image.rb +1 -1
- data/lib/cimi/{model → models}/machine_image_collection.rb +2 -2
- data/lib/cimi/{model → models}/machine_template.rb +0 -0
- data/lib/cimi/{model → models}/machine_template_collection.rb +2 -2
- data/lib/cimi/models/network.rb +109 -0
- data/lib/cimi/{model → models}/network_collection.rb +2 -2
- data/lib/cimi/{model → models}/network_configuration.rb +3 -4
- data/lib/cimi/{model → models}/network_configuration_collection.rb +2 -2
- data/lib/cimi/models/network_template.rb +36 -0
- data/lib/cimi/models/network_template_collection.rb +35 -0
- data/lib/cimi/models/routing_group.rb +34 -0
- data/lib/cimi/models/routing_group_collection.rb +34 -0
- data/lib/cimi/models/routing_group_template.rb +34 -0
- data/lib/cimi/models/routing_group_template_collection.rb +35 -0
- data/lib/cimi/{model → models}/schema.rb +0 -0
- data/lib/cimi/{model → models}/volume.rb +4 -4
- data/lib/cimi/{model → models}/volume_collection.rb +2 -2
- data/lib/cimi/{model → models}/volume_configuration.rb +1 -1
- data/lib/cimi/{model → models}/volume_configuration_collection.rb +2 -2
- data/lib/cimi/{model → models}/volume_image.rb +1 -1
- data/lib/cimi/{model → models}/volume_image_collection.rb +2 -2
- data/lib/cimi/{model → models}/volume_template.rb +0 -0
- data/lib/cimi/{model → models}/volume_template_collection.rb +2 -2
- data/lib/cimi/models/vsp.rb +102 -0
- data/lib/cimi/models/vsp_collection.rb +34 -0
- data/lib/cimi/models/vsp_configuration.rb +40 -0
- data/lib/cimi/models/vsp_configuration_collection.rb +34 -0
- data/lib/cimi/models/vsp_template.rb +34 -0
- data/lib/cimi/models/vsp_template_collection.rb +34 -0
- data/lib/cimi/server.rb +27 -549
- data/lib/deltacloud/api.rb +79 -0
- data/lib/deltacloud/collections.rb +54 -0
- data/lib/deltacloud/collections/addresses.rb +91 -0
- data/lib/deltacloud/collections/buckets.rb +273 -0
- data/lib/deltacloud/collections/drivers.rb +51 -0
- data/lib/deltacloud/collections/firewalls.rb +116 -0
- data/lib/deltacloud/collections/hardware_profiles.rb +29 -0
- data/lib/deltacloud/collections/images.rb +73 -0
- data/lib/deltacloud/collections/instance_states.rb +59 -0
- data/lib/deltacloud/collections/instances.rb +113 -0
- data/lib/deltacloud/collections/keys.rb +61 -0
- data/lib/deltacloud/collections/load_balancers.rb +102 -0
- data/lib/deltacloud/collections/metrics.rb +28 -0
- data/lib/deltacloud/collections/realms.rb +28 -0
- data/lib/deltacloud/collections/storage_snapshots.rb +51 -0
- data/lib/deltacloud/collections/storage_volumes.rb +99 -0
- data/lib/deltacloud/core_ext.rb +14 -6
- data/lib/deltacloud/core_ext/string.rb +17 -5
- data/lib/deltacloud/drivers.rb +6 -42
- data/lib/deltacloud/drivers/azure/azure_driver.rb +0 -4
- data/lib/deltacloud/{base_driver → drivers}/base_driver.rb +56 -18
- data/lib/deltacloud/drivers/condor/condor_driver.rb +1 -8
- data/lib/deltacloud/drivers/ec2/ec2_driver.rb +142 -33
- data/lib/deltacloud/drivers/eucalyptus/eucalyptus_driver.rb +2 -6
- data/lib/deltacloud/{base_driver → drivers}/exceptions.rb +25 -2
- data/lib/deltacloud/drivers/features.rb +154 -0
- data/lib/deltacloud/drivers/fgcp/fgcp_client.rb +387 -0
- data/lib/deltacloud/drivers/fgcp/fgcp_driver.rb +1435 -0
- data/lib/deltacloud/drivers/gogrid/gogrid_driver.rb +8 -11
- data/lib/deltacloud/drivers/google/google_driver.rb +2 -5
- data/lib/deltacloud/drivers/mock/data/keys/test-key.yml +28 -0
- data/lib/deltacloud/drivers/mock/mock_client.rb +2 -2
- data/lib/deltacloud/drivers/mock/mock_driver.rb +58 -40
- data/lib/deltacloud/drivers/mock/mock_driver_cimi_methods.rb +145 -0
- data/lib/deltacloud/drivers/opennebula/cloud_client.rb +107 -73
- data/lib/deltacloud/drivers/opennebula/occi_client.rb +285 -145
- data/lib/deltacloud/drivers/opennebula/opennebula_driver.rb +189 -126
- data/lib/deltacloud/drivers/openstack/openstack_driver.rb +427 -8
- data/lib/deltacloud/drivers/rackspace/rackspace_driver.rb +7 -9
- data/lib/deltacloud/drivers/rhevm/rhevm_driver.rb +48 -66
- data/lib/deltacloud/drivers/rimuhosting/rimuhosting_client.rb +44 -51
- data/lib/deltacloud/drivers/rimuhosting/rimuhosting_driver.rb +7 -8
- data/lib/deltacloud/drivers/sbc/sbc_client.rb +1 -1
- data/lib/deltacloud/drivers/sbc/sbc_driver.rb +3 -3
- data/lib/deltacloud/drivers/terremark/terremark_driver.rb +8 -8
- data/lib/deltacloud/drivers/vsphere/vsphere_driver.rb +39 -13
- data/lib/deltacloud/drivers/vsphere/vsphere_filemanager.rb +1 -0
- data/lib/deltacloud/helpers.rb +79 -7
- data/lib/{sinatra/lazy_auth.rb → deltacloud/helpers/auth_helper.rb} +5 -9
- data/lib/deltacloud/helpers/{blob_stream.rb → blob_stream_helper.rb} +7 -7
- data/lib/deltacloud/helpers/deltacloud_helper.rb +286 -0
- data/lib/deltacloud/helpers/driver_helper.rb +58 -0
- data/lib/deltacloud/helpers/rabbit_helper.rb +34 -0
- data/lib/{sinatra/url_for.rb → deltacloud/helpers/url_helper.rb} +31 -9
- data/lib/deltacloud/models.rb +19 -17
- data/lib/deltacloud/models/bucket.rb +4 -0
- data/lib/deltacloud/{hardware_profile.rb → models/hardware_profile.rb} +4 -2
- data/lib/deltacloud/models/image.rb +1 -0
- data/lib/deltacloud/models/instance.rb +4 -2
- data/lib/deltacloud/models/instance_address.rb +4 -0
- data/lib/deltacloud/models/key.rb +4 -0
- data/lib/deltacloud/models/metric.rb +40 -0
- data/lib/deltacloud/{state_machine.rb → models/state_machine.rb} +18 -1
- data/lib/deltacloud/server.rb +41 -1222
- data/lib/deltacloud_rack.rb +79 -0
- data/lib/{cimi/model/network_template.rb → ec2/helpers.rb} +7 -10
- data/lib/{deltacloud/backend_capability.rb → ec2/helpers/errors.rb} +24 -29
- data/lib/ec2/helpers/result.rb +31 -0
- data/lib/ec2/query_parser.rb +152 -0
- data/lib/ec2/server.rb +70 -0
- data/lib/{deltacloud.rb → sinatra.rb} +7 -12
- data/lib/sinatra/rack_accept.rb +13 -7
- data/lib/sinatra/rack_driver_select.rb +1 -1
- data/lib/sinatra/rack_matrix_params.rb +1 -3
- data/public/images/metric.png +0 -0
- data/public/javascripts/jquery.mobile-1.0.1.min.js +177 -0
- data/public/stylesheets/jquery.mobile-1.0.1.min.css +2 -0
- data/public/stylesheets/new.css +10 -0
- data/support/fedora/deltacloud-core.spec +1 -1
- data/tests/api/common.rb +1 -0
- data/tests/api/driver_test.rb +79 -0
- data/tests/api/library_test.rb +48 -0
- data/tests/cimi/features/step_definitions/common_steps.rb +2 -2
- data/tests/cimi/features/step_definitions/machines_steps.rb +5 -4
- data/tests/cimi/features/step_definitions/volumes_steps.rb +8 -8
- data/tests/cimi/features/support/env.rb +33 -11
- data/tests/common.rb +7 -8
- data/tests/drivers/ec2/api_test.rb +19 -0
- data/tests/drivers/ec2/common.rb +23 -0
- data/tests/drivers/ec2/drivers_test.rb +120 -0
- data/tests/drivers/ec2/hardware_profiles_test.rb +224 -0
- data/tests/drivers/ec2/images_test.rb +230 -0
- data/tests/drivers/ec2/instances_test.rb +356 -0
- data/tests/drivers/ec2/keys_test.rb +181 -0
- data/tests/drivers/ec2/realms_test.rb +146 -0
- data/tests/drivers/fgcp/api_test.rb +47 -0
- data/tests/drivers/fgcp/hardware_profiles_test.rb +54 -0
- data/tests/drivers/fgcp/realms_test.rb +42 -0
- data/tests/drivers/{rackspace → fgcp}/setup.rb +5 -6
- data/tests/drivers/google/api_test.rb +10 -26
- data/tests/drivers/google/buckets_test.rb +79 -95
- data/tests/drivers/google/common.rb +54 -0
- data/tests/drivers/mock/api_test.rb +4 -127
- data/tests/drivers/mock/buckets_test.rb +195 -0
- data/tests/drivers/mock/common.rb +7 -0
- data/tests/drivers/mock/drivers_test.rb +123 -0
- data/tests/drivers/mock/hardware_profiles_test.rb +190 -100
- data/tests/drivers/mock/images_test.rb +162 -103
- data/tests/drivers/mock/instances_test.rb +310 -220
- data/tests/drivers/mock/keys_test.rb +161 -0
- data/tests/drivers/mock/realms_test.rb +109 -70
- data/tests/drivers/mock/storage_snapshots_test.rb +114 -0
- data/tests/drivers/mock/storage_volumes_test.rb +122 -0
- data/tests/drivers/openstack/api_test.rb +8 -3
- data/tests/drivers/openstack/common.rb +21 -0
- data/tests/drivers/openstack/hardware_profiles_test.rb +20 -9
- data/tests/drivers/openstack/images_test.rb +11 -5
- data/tests/drivers/openstack/instances_test.rb +61 -16
- data/tests/drivers/openstack/realms_test.rb +11 -7
- data/tests/drivers/rackspace/api_test.rb +7 -2
- data/tests/drivers/rackspace/buckets_test.rb +7 -2
- data/tests/drivers/rackspace/common.rb +16 -0
- data/tests/drivers/rackspace/hardware_profiles_test.rb +7 -2
- data/tests/drivers/rackspace/images_test.rb +7 -2
- data/tests/drivers/rackspace/instances_test.rb +10 -5
- data/tests/drivers/rackspace/realms_test.rb +7 -2
- data/tests/drivers/rhevm/api_test.rb +12 -6
- data/tests/drivers/rhevm/{setup.rb → common.rb} +8 -1
- data/tests/drivers/rhevm/hardware_profiles_test.rb +7 -2
- data/tests/drivers/rhevm/images_test.rb +8 -2
- data/tests/drivers/rhevm/instances_test.rb +7 -2
- data/tests/drivers/rhevm/realms_test.rb +7 -2
- data/tests/minitest_common.rb +58 -0
- data/tests/minitest_common_api_test.rb +115 -0
- data/views/addresses/associate.html.haml +1 -1
- data/views/addresses/index.html.haml +1 -1
- data/views/addresses/show.html.haml +2 -3
- data/views/api/show.html.haml +22 -9
- data/views/api/show.xml.haml +8 -7
- data/views/blobs/show.xml.haml +7 -4
- data/views/buckets/new.html.haml +2 -2
- data/views/cimi/errors/401.xml.haml +1 -1
- data/views/error.html.haml +3 -3
- data/views/errors/400.html.haml +1 -1
- data/views/errors/400.xml.haml +1 -2
- data/views/errors/401.html.haml +8 -7
- data/views/errors/401.xml.haml +1 -1
- data/views/errors/404.xml.haml +1 -0
- data/views/errors/500.xml.haml +4 -2
- data/views/{cimi/errors/403.html.haml → errors/501.html.haml} +4 -2
- data/views/errors/501.xml.haml +1 -0
- data/views/errors/502.xml.haml +1 -7
- data/views/{cimi/errors/500.html.haml → errors/504.html.haml} +0 -0
- data/views/errors/504.xml.haml +1 -0
- data/views/firewalls/new.html.haml +2 -2
- data/views/firewalls/new_rule.html.haml +1 -1
- data/views/firewalls/show.html.haml +1 -1
- data/views/hardware_profiles/index.html.haml +3 -1
- data/views/hardware_profiles/index.xml.haml +2 -2
- data/views/hardware_profiles/show.html.haml +3 -3
- data/views/hardware_profiles/show.xml.haml +3 -3
- data/views/images/show.html.haml +5 -0
- data/views/images/show.xml.haml +6 -1
- data/views/instance_states/show.html.haml +1 -1
- data/views/instances/index.html.haml +1 -1
- data/views/instances/new.html.haml +54 -39
- data/views/instances/run_command.html.haml +24 -15
- data/views/instances/show.html.haml +7 -3
- data/views/instances/show.xml.haml +2 -2
- data/views/keys/show.xml.haml +1 -0
- data/views/layout.html.haml +5 -9
- data/views/load_balancers/show.html.haml +12 -6
- data/views/metrics/index.html.haml +13 -0
- data/views/metrics/index.xml.haml +5 -0
- data/views/metrics/show.html.haml +23 -0
- data/views/metrics/show.xml.haml +9 -0
- data/views/realms/show.xml.haml +2 -1
- data/views/root/index.html.haml +1 -1
- data/views/storage_snapshots/show.html.haml +1 -1
- data/views/storage_snapshots/show.xml.haml +1 -0
- data/views/storage_volumes/attach.html.haml +1 -2
- data/views/storage_volumes/index.html.haml +1 -1
- data/views/storage_volumes/new.html.haml +22 -16
- data/views/storage_volumes/show.html.haml +10 -4
- data/views/storage_volumes/show.xml.haml +3 -4
- metadata +547 -519
- data/DISCLAIMER +0 -8
- data/lib/cimi/model.rb +0 -52
- data/lib/cimi/model/network.rb +0 -69
- data/lib/deltacloud/base_driver.rb +0 -18
- data/lib/deltacloud/base_driver/features.rb +0 -262
- data/lib/deltacloud/base_driver/mock_driver.rb +0 -78
- data/lib/deltacloud/drivers/ec2/ec2_mock_driver.rb +0 -186
- data/lib/deltacloud/drivers/rhevm/rhevm_client.rb +0 -521
- data/lib/deltacloud/helpers/application_helper.rb +0 -267
- data/lib/deltacloud/helpers/hardware_profiles_helper.rb +0 -50
- data/lib/deltacloud/helpers/json_helper.rb +0 -31
- data/lib/deltacloud/method_serializer.rb +0 -83
- data/lib/deltacloud/validation.rb +0 -107
- data/lib/sinatra/rabbit.rb +0 -441
- data/lib/sinatra/rack_runtime.rb +0 -47
- data/lib/sinatra/rack_syslog.rb +0 -86
- data/lib/sinatra/sinatra_verbose.rb +0 -73
- data/lib/sinatra/static_assets.rb +0 -99
- data/public/javascripts/jquery.mobile-1.0rc1.min.js +0 -170
- data/public/stylesheets/jquery.mobile-1.0rc1.min.css +0 -12
- data/tests/drivers/google/setup.rb +0 -38
- data/tests/drivers/mock/instance_states_test.rb +0 -71
- data/tests/drivers/mock/setup.rb +0 -3
- data/tests/drivers/mock/url_for_test.rb +0 -67
- data/tests/drivers/openstack/setup.rb +0 -20
- data/views/cimi/errors/400.html.haml +0 -41
- data/views/cimi/errors/401.html.haml +0 -41
- data/views/cimi/errors/404.html.haml +0 -29
- data/views/cimi/errors/405.html.haml +0 -29
- data/views/cimi/errors/502.html.haml +0 -43
- data/views/cimi/errors/backend_capability_failure.html.haml +0 -29
data/NOTICE
CHANGED
data/Rakefile
CHANGED
@@ -71,30 +71,10 @@ begin
|
|
71
71
|
rescue LoadError
|
72
72
|
end
|
73
73
|
|
74
|
-
namespace :test do
|
75
|
-
%w(mock rackspace rhevm openstack google).each do |driver|
|
76
|
-
desc "Run #{driver} unit tests"
|
77
|
-
Rake::TestTask.new(driver) { |t|
|
78
|
-
t.test_files = ['tests/common.rb', "tests/drivers/#{driver}/setup.rb"] + FileList.new("tests/drivers/#{driver}/*_test.rb") + FileList.new('tests/rabbit_test.rb')
|
79
|
-
t.options = "-v -v"
|
80
|
-
t.verbose = true
|
81
|
-
t.warning = false
|
82
|
-
}
|
83
|
-
end
|
84
|
-
|
85
|
-
desc "Run CIMI frontend tests"
|
86
|
-
Rake::TestTask.new "cimi" do |t|
|
87
|
-
t.test_files = ["tests/cimi/cimi.rb", "tests/cimi/common/*_test.rb"]
|
88
|
-
t.options = "-v -v"
|
89
|
-
t.verbose = true
|
90
|
-
t.warning = false
|
91
|
-
end
|
92
|
-
|
93
|
-
end
|
94
74
|
|
95
75
|
desc "Call our Test::Unit suite"
|
96
76
|
task :test do
|
97
|
-
%w(mock rackspace rhevm openstack google).each do |driver|
|
77
|
+
%w(mock rackspace rhevm openstack google fgcp).each do |driver|
|
98
78
|
Rake::Task["test:#{driver}"].reenable
|
99
79
|
Rake::Task["test:#{driver}"].invoke
|
100
80
|
end
|
@@ -193,3 +173,65 @@ namespace :mock do
|
|
193
173
|
|
194
174
|
end
|
195
175
|
end
|
176
|
+
|
177
|
+
namespace :openshift do
|
178
|
+
|
179
|
+
desc "Deploy Deltacloud API to OpenShift"
|
180
|
+
task :deploy do
|
181
|
+
print "RHN or OpenShift login with OpenShift Express access: "
|
182
|
+
STDOUT.flush
|
183
|
+
login = STDIN.gets.chomp
|
184
|
+
print "Password: "
|
185
|
+
system "stty -echo"
|
186
|
+
password = STDIN.gets.chomp
|
187
|
+
system "stty echo"
|
188
|
+
puts `rhc-create-app --rhlogin #{login} --app deltacloudtest --password '#{password}' --type ruby-1.8`
|
189
|
+
end
|
190
|
+
end
|
191
|
+
|
192
|
+
namespace :rabbit do
|
193
|
+
load File.join(File.dirname(__FILE__), 'config.ru')
|
194
|
+
|
195
|
+
desc "List the routes defined by Rabbit"
|
196
|
+
task :routes do
|
197
|
+
Deltacloud.collections.each do |c|
|
198
|
+
puts "\033[1;32;m#{c.name}\33[0m"
|
199
|
+
c.operations.each do |o|
|
200
|
+
puts "\033[1;37m%6s\033[0m :%-10s %-30s (%s)" % [
|
201
|
+
o.http_method.to_s.upcase,
|
202
|
+
o.operation_name,
|
203
|
+
o.full_path,
|
204
|
+
o.description[0..100]
|
205
|
+
]
|
206
|
+
end
|
207
|
+
unless c.collections.empty?
|
208
|
+
puts
|
209
|
+
c.collections.each do |s|
|
210
|
+
puts "\033[1;32;m#{s.name}\33[0m"
|
211
|
+
s.operations.each do |o|
|
212
|
+
puts "\033[1;37m%6s\033[0m :%-10s %-30s (%s)" % [
|
213
|
+
o.http_method.to_s.upcase,
|
214
|
+
o.operation_name,
|
215
|
+
o.full_path,
|
216
|
+
o.description[0..100]
|
217
|
+
]
|
218
|
+
end
|
219
|
+
end
|
220
|
+
end
|
221
|
+
puts
|
222
|
+
end
|
223
|
+
end
|
224
|
+
|
225
|
+
end
|
226
|
+
|
227
|
+
namespace :test do
|
228
|
+
|
229
|
+
%w(mock rackspace rhevm openstack google fgcp ec2).each do |driver|
|
230
|
+
desc "Run #{driver} unit tests"
|
231
|
+
Rake::TestTask.new(driver) { |t|
|
232
|
+
t.test_files = FileList.new("tests/drivers/#{driver}/*_test.rb")
|
233
|
+
t.verbose = true
|
234
|
+
t.warning = false
|
235
|
+
}
|
236
|
+
end
|
237
|
+
end
|
data/bin/deltacloudd
CHANGED
@@ -37,7 +37,8 @@ end
|
|
37
37
|
DEFAULT_CONFIG = "~/.deltacloud/config"
|
38
38
|
|
39
39
|
options = {
|
40
|
-
:env => 'development'
|
40
|
+
:env => 'development',
|
41
|
+
:logdir => "/var/log/deltacloud-core"
|
41
42
|
}
|
42
43
|
optparse = OptionParser.new do |opts|
|
43
44
|
|
@@ -60,8 +61,8 @@ BANNER
|
|
60
61
|
opts.on( '-P', '--provider PROVIDER', 'Use PROVIDER (default is set in the driver)') do |provider|
|
61
62
|
ENV['API_PROVIDER'] = provider
|
62
63
|
end
|
63
|
-
opts.on('--
|
64
|
-
ENV['API_FRONTEND'] =
|
64
|
+
opts.on('-f', '--frontends FRONTENDS', 'Enable different frontends (cimi, ec2, deltacloud)') do |frontend|
|
65
|
+
ENV['API_FRONTEND'] = frontend
|
65
66
|
end
|
66
67
|
opts.on( '-c', '--config [FILE]', 'Read provider and other config from FILE (default: ~/.deltacloud/config)') do |config|
|
67
68
|
options[:config] = File::expand_path(config || DEFAULT_CONFIG)
|
@@ -86,6 +87,9 @@ BANNER
|
|
86
87
|
opts.on( nil, '--webrick', 'Force the use of WEBRick as a server') do |opt|
|
87
88
|
options[:webrick] = true
|
88
89
|
end
|
90
|
+
opts.on('--logdir LOGDIR', "Directory for log files, defaults to #{options[:logdir]}") do |opt|
|
91
|
+
options[:logdir] = opt
|
92
|
+
end
|
89
93
|
opts.on( '-h', '--help', '') { options[:help] = true }
|
90
94
|
|
91
95
|
opts.separator <<EOS
|
@@ -124,9 +128,9 @@ end
|
|
124
128
|
if options[:drivers]
|
125
129
|
$:.unshift File.join($top_srcdir, 'lib')
|
126
130
|
server_dir = ENV['API_FRONTEND'] == 'cimi' ? 'cimi' : 'deltacloud'
|
127
|
-
load File.join($top_srcdir, 'lib', server_dir, '
|
131
|
+
load File.join($top_srcdir, 'lib', server_dir, 'api.rb')
|
128
132
|
puts "Available drivers:\n\n"
|
129
|
-
puts
|
133
|
+
puts Deltacloud.drivers.keys.join("\n")
|
130
134
|
puts
|
131
135
|
exit(0)
|
132
136
|
end
|
@@ -219,7 +223,7 @@ else
|
|
219
223
|
argv_opts << [ "--daemonize", "--user", options[:user] || 'nobody', "--tag", "deltacloud-#{ENV['API_DRIVER']}"]
|
220
224
|
argv_opts << [ "--pid", options[:pid]] if options[:pid]
|
221
225
|
argv_opts << [ "--group", options[:group] || 'nobody' ]
|
222
|
-
argv_opts << [ "--log", File.join(
|
226
|
+
argv_opts << [ "--log", File.join(options[:logdir], "#{ENV['API_DRIVER']}.log")]
|
223
227
|
end
|
224
228
|
argv_opts.flatten!
|
225
229
|
|
data/config.ru
CHANGED
@@ -14,14 +14,70 @@
|
|
14
14
|
# License for the specific language governing permissions and limitations
|
15
15
|
# under the License.
|
16
16
|
|
17
|
-
|
17
|
+
# The default URL prefix (where to mount Deltacloud API)
|
18
18
|
|
19
|
-
|
19
|
+
# The default driver is 'mock'
|
20
|
+
ENV['API_DRIVER'] ||= 'mock'
|
21
|
+
ENV['API_FRONTEND'] ||= 'deltacloud'
|
20
22
|
|
21
|
-
|
23
|
+
load File.join(File.dirname(__FILE__), 'lib', 'deltacloud_rack.rb')
|
22
24
|
|
23
|
-
|
25
|
+
Deltacloud::configure do |server|
|
26
|
+
server.root_url '/api'
|
27
|
+
server.version '1.0.0'
|
28
|
+
server.klass 'Deltacloud::API'
|
29
|
+
end
|
24
30
|
|
25
|
-
|
31
|
+
Deltacloud::configure(:cimi) do |server|
|
32
|
+
server.root_url '/cimi'
|
33
|
+
server.version '1.0.0'
|
34
|
+
server.klass 'CIMI::API'
|
35
|
+
end
|
26
36
|
|
27
|
-
|
37
|
+
Deltacloud::configure(:ec2) do |server|
|
38
|
+
server.root_url '/'
|
39
|
+
server.version '2012-04-01'
|
40
|
+
server.klass 'Deltacloud::EC2::API'
|
41
|
+
end
|
42
|
+
|
43
|
+
routes = {}
|
44
|
+
|
45
|
+
# If user wants to launch multiple frontends withing a single instance of DC API
|
46
|
+
# then require them and prepare the routes for Rack
|
47
|
+
#
|
48
|
+
# NOTE: The '/' will not be generated, since multiple frontends could have
|
49
|
+
# different root_url's
|
50
|
+
#
|
51
|
+
if ENV['API_FRONTEND'].split(',').size > 1
|
52
|
+
|
53
|
+
ENV['API_FRONTEND'].split(',').each do |frontend|
|
54
|
+
Deltacloud.require_frontend!(frontend)
|
55
|
+
routes.merge!({
|
56
|
+
Deltacloud[frontend].root_url => Deltacloud[frontend].klass
|
57
|
+
})
|
58
|
+
end
|
59
|
+
|
60
|
+
else
|
61
|
+
Deltacloud.require_frontend!(ENV['API_FRONTEND'])
|
62
|
+
class IndexEntrypoint < Sinatra::Base
|
63
|
+
get "/" do
|
64
|
+
redirect Deltacloud[ENV['API_FRONTEND']].root_url, 301
|
65
|
+
end
|
66
|
+
end
|
67
|
+
routes['/'] = IndexEntrypoint.new
|
68
|
+
routes[Deltacloud[ENV['API_FRONTEND']].root_url] = Deltacloud[ENV['API_FRONTEND']].klass
|
69
|
+
end
|
70
|
+
|
71
|
+
|
72
|
+
run Rack::Builder.new {
|
73
|
+
use Rack::MatrixParams
|
74
|
+
use Rack::DriverSelect
|
75
|
+
|
76
|
+
routes.merge!({
|
77
|
+
"/stylesheets" => Rack::Directory.new( File.join(File.dirname(__FILE__), "public", "stylesheets") ),
|
78
|
+
"/javascripts" => Rack::Directory.new( File.join(File.dirname(__FILE__), "public", "javascripts") )
|
79
|
+
})
|
80
|
+
|
81
|
+
run Rack::URLMap.new(routes)
|
82
|
+
|
83
|
+
} if respond_to? :run
|
data/config/drivers/ec2.yaml
CHANGED
@@ -25,4 +25,12 @@
|
|
25
25
|
eu-west-1: ec2.eu-west-1.amazonaws.com
|
26
26
|
us-east-1: ec2.us-east-1.amazonaws.com
|
27
27
|
sa-east-1: ec2.sa-east-1.amazonaws.com
|
28
|
+
mon:
|
29
|
+
us-west-1: monitoring.us-west-1.amazonaws.com
|
30
|
+
us-west-2: monitoring.us-west-2.amazonaws.com
|
31
|
+
ap-southeast-1: monitoring.ap-southeast-1.amazonaws.com
|
32
|
+
ap-northeast-1: monitoring.ap-northeast-1.amazonaws.com
|
33
|
+
eu-west-1: monitoring.eu-west-1.amazonaws.com
|
34
|
+
us-east-1: monitoring.us-east-1.amazonaws.com
|
35
|
+
sa-east-1: monitoring.sa-east-1.amazonaws.com
|
28
36
|
:name: EC2
|
@@ -0,0 +1,13 @@
|
|
1
|
+
---
|
2
|
+
:fgcp:
|
3
|
+
:name: FGCP
|
4
|
+
:username: Username
|
5
|
+
:password: Secret Key Password of User Certificate
|
6
|
+
:entrypoints:
|
7
|
+
default:
|
8
|
+
jp: https://api.oviss.jp.fujitsu.com/ovissapi/endpoint
|
9
|
+
au: https://api.globalcloud.fujitsu.com.au/ovissapi/endpoint
|
10
|
+
sg: https://api.globalcloud.sg.fujitsu.com/ovissapi/endpoint
|
11
|
+
uk: https://api.globalcloud.uk.fujitsu.com/ovissapi/endpoint
|
12
|
+
us: https://api.globalcloud.us.fujitsu.com/ovissapi/endpoint
|
13
|
+
de: https://api.globalcloud.de.fujitsu.com/ovissapi/endpoint
|
data/deltacloud-core.gemspec
CHANGED
@@ -29,7 +29,7 @@ Gem::Specification.new do |s|
|
|
29
29
|
which implements the REST interface.
|
30
30
|
EOF
|
31
31
|
|
32
|
-
s.version = '0.
|
32
|
+
s.version = '1.0.0'
|
33
33
|
s.date = Time.now
|
34
34
|
s.summary = %q{Deltacloud REST API}
|
35
35
|
s.files = FileList[
|
@@ -64,10 +64,12 @@ Gem::Specification.new do |s|
|
|
64
64
|
s.test_files= Dir.glob("tests/*_test.rb")
|
65
65
|
s.extra_rdoc_files = Dir["LICENSE", "DISCLAIMER", "NOTICE"]
|
66
66
|
s.required_ruby_version = '>= 1.8.1'
|
67
|
-
|
67
|
+
s.has_rdoc = 'false'
|
68
68
|
s.add_dependency('rake', '>= 0.8.7')
|
69
69
|
s.add_dependency('haml', '>= 2.2.17')
|
70
70
|
s.add_dependency('sinatra', '>= 0.9.4')
|
71
|
+
s.add_dependency('sinatra-rabbit', '>= 1.0.5')
|
72
|
+
s.add_dependency('crack')
|
71
73
|
s.add_dependency('rack', '>= 1.0.0')
|
72
74
|
s.add_dependency('rack-accept')
|
73
75
|
s.add_dependency('json', '>= 1.1.9')
|
@@ -76,6 +78,9 @@ Gem::Specification.new do |s|
|
|
76
78
|
s.add_dependency('nokogiri', '>= 1.4.3')
|
77
79
|
|
78
80
|
# dependencies for various cloud providers:
|
81
|
+
# RHEV-M
|
82
|
+
s.add_dependency('rbovirt', '>=0.0.6')
|
83
|
+
|
79
84
|
# Amazon EC2 S3
|
80
85
|
s.add_dependency('aws', '>=2.5.4')
|
81
86
|
# Microsoft Azure
|
@@ -95,4 +100,7 @@ Gem::Specification.new do |s|
|
|
95
100
|
# Condor Cloud
|
96
101
|
s.add_dependency('uuidtools', '>= 2.1.1')
|
97
102
|
|
103
|
+
# Openstack Compute and Object-Storage
|
104
|
+
s.add_dependency('openstack')
|
105
|
+
|
98
106
|
end
|
@@ -0,0 +1,58 @@
|
|
1
|
+
#
|
2
|
+
# Licensed to the Apache Software Foundation (ASF) under one or more
|
3
|
+
# contributor license agreements. See the NOTICE file distributed with
|
4
|
+
# this work for additional information regarding copyright ownership. The
|
5
|
+
# ASF licenses this file to you under the Apache License, Version 2.0 (the
|
6
|
+
# "License"); you may not use this file except in compliance with the
|
7
|
+
# License. You may obtain a copy of the License at
|
8
|
+
#
|
9
|
+
# http://www.apache.org/licenses/LICENSE-2.0
|
10
|
+
#
|
11
|
+
# Unless required by applicable law or agreed to in writing, software
|
12
|
+
# distributed under the License is distributed on an "AS IS" BASIS, WITHOUT
|
13
|
+
# WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. See the
|
14
|
+
# License for the specific language governing permissions and limitations
|
15
|
+
# under the License.
|
16
|
+
|
17
|
+
module CIMI
|
18
|
+
|
19
|
+
def self.collection_names
|
20
|
+
@collections.map { |c| c.collection_name }
|
21
|
+
end
|
22
|
+
|
23
|
+
def self.collections
|
24
|
+
@collections ||= []
|
25
|
+
end
|
26
|
+
|
27
|
+
module Collections
|
28
|
+
|
29
|
+
def self.collection(name)
|
30
|
+
CIMI.collections.find { |c| c.collection_name == name }
|
31
|
+
end
|
32
|
+
|
33
|
+
def self.cimi_modules
|
34
|
+
@cimi_modules ||= []
|
35
|
+
end
|
36
|
+
|
37
|
+
Dir[File.join(File::dirname(__FILE__), "collections", "*.rb")].each do |collection|
|
38
|
+
require collection
|
39
|
+
base_collection_name = File.basename(collection).gsub('.rb', '')
|
40
|
+
cimi_module_class = CIMI::Collections.const_get(base_collection_name.camelize)
|
41
|
+
cimi_modules << cimi_module_class
|
42
|
+
unless cimi_module_class.collections.nil?
|
43
|
+
cimi_module_class.collections.each do |c|
|
44
|
+
CIMI.collections << c
|
45
|
+
end
|
46
|
+
else
|
47
|
+
warn "WARNING: File %s placed in collections directory but does not have any collections defined" % base_collection_name
|
48
|
+
end
|
49
|
+
end
|
50
|
+
|
51
|
+
def self.included(klass)
|
52
|
+
klass.class_eval do
|
53
|
+
CIMI::Collections.cimi_modules.each { |c| use c }
|
54
|
+
end
|
55
|
+
end
|
56
|
+
|
57
|
+
end
|
58
|
+
end
|
@@ -0,0 +1,49 @@
|
|
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 CIMI::Collections
|
17
|
+
class AddressTemplates < Base
|
18
|
+
|
19
|
+
check_capability :for => lambda { |m| driver.respond_to? m }
|
20
|
+
|
21
|
+
collection :address_templates do
|
22
|
+
|
23
|
+
operation :index do
|
24
|
+
description 'List all AddressTemplates in the AddressTemplateCollection'
|
25
|
+
param :CIMISelect, :string, :optional
|
26
|
+
control do
|
27
|
+
address_templates = AddressTemplateCollection.default(self).filter_by(params[:CIMISelect])
|
28
|
+
respond_to do |format|
|
29
|
+
format.xml {address_templates.to_xml}
|
30
|
+
format.json {address_templates.to_json}
|
31
|
+
end
|
32
|
+
end
|
33
|
+
end
|
34
|
+
|
35
|
+
operation :show do
|
36
|
+
description 'Show a specific AddressTemplate'
|
37
|
+
control do
|
38
|
+
address_template = CIMI::Model::AddressTemplate.find(params[:id], self)
|
39
|
+
respond_to do |format|
|
40
|
+
format.xml {address_template.to_xml}
|
41
|
+
format.json {address_template.to_json}
|
42
|
+
end
|
43
|
+
end
|
44
|
+
end
|
45
|
+
|
46
|
+
end
|
47
|
+
|
48
|
+
end
|
49
|
+
end
|
@@ -0,0 +1,74 @@
|
|
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 CIMI::Collections
|
17
|
+
class Addresses < Base
|
18
|
+
|
19
|
+
check_capability :for => lambda { |m| driver.respond_to? m }
|
20
|
+
collection :addresses do
|
21
|
+
|
22
|
+
description 'An Address represents an IP address, and its associated metdata, for a particular Network.'
|
23
|
+
|
24
|
+
operation :index do
|
25
|
+
description 'List all Addresses in the AddressCollection'
|
26
|
+
param :CIMISelect, :string, :optional
|
27
|
+
control do
|
28
|
+
addresses = AddressCollection.default(self).filter_by(params[:CIMISelect])
|
29
|
+
respond_to do |format|
|
30
|
+
format.xml {addresses.to_xml}
|
31
|
+
format.json {addresses.to_json}
|
32
|
+
end
|
33
|
+
end
|
34
|
+
end
|
35
|
+
|
36
|
+
operation :show do
|
37
|
+
description 'Show a specific Address'
|
38
|
+
control do
|
39
|
+
address = CIMI::Model::Address.find(params[:id], self)
|
40
|
+
respond_to do |format|
|
41
|
+
format.xml {address.to_xml}
|
42
|
+
format.json {address.to_json}
|
43
|
+
end
|
44
|
+
end
|
45
|
+
end
|
46
|
+
|
47
|
+
operation :create do
|
48
|
+
description "Create a new Address"
|
49
|
+
control do
|
50
|
+
if request.content_type.end_with?("json")
|
51
|
+
address = CIMI::Model::Address.create(request.body.read, self, :json)
|
52
|
+
else
|
53
|
+
address = CIMI::Model::Address.create(request.body.read, self, :xml)
|
54
|
+
end
|
55
|
+
respond_to do |format|
|
56
|
+
format.xml { address.to_xml }
|
57
|
+
format.json { address.to_json }
|
58
|
+
end
|
59
|
+
end
|
60
|
+
end
|
61
|
+
|
62
|
+
operation :destroy do
|
63
|
+
description "Delete a specified Address"
|
64
|
+
param :id, :string, :required
|
65
|
+
control do
|
66
|
+
CIMI::Model::Address.delete!(params[:id], self)
|
67
|
+
no_content_with_status(200)
|
68
|
+
end
|
69
|
+
end
|
70
|
+
|
71
|
+
end
|
72
|
+
|
73
|
+
end
|
74
|
+
end
|