fog-xenserver 0.0.1.alpha2 → 0.0.1.beta1
Sign up to get free protection for your applications and to get access to all the features.
- checksums.yaml +4 -4
- data/.hound.yml +27 -0
- data/.travis.yml +19 -0
- data/CONTRIBUTING.md +6 -6
- data/Gemfile +1 -1
- data/LICENSE.md +1 -1
- data/README.md +3 -1
- data/Rakefile +10 -1
- data/fog-xenserver.gemspec +6 -4
- data/gemfiles/Gemfile.1.8.7 +7 -0
- data/gemfiles/Gemfile.1.9.2+ +6 -0
- data/lib/fog.rb +1 -1
- data/lib/fog/collection.rb +37 -0
- data/lib/fog/compute/xen_server.rb +132 -0
- data/lib/fog/compute/xen_server/mock.rb +27 -0
- data/lib/fog/compute/xen_server/models.rb +78 -0
- data/lib/fog/compute/xen_server/models/blob.rb +24 -0
- data/lib/fog/compute/xen_server/models/blobs.rb +11 -0
- data/lib/fog/compute/xen_server/models/bond.rb +26 -0
- data/lib/fog/compute/xen_server/models/bonds.rb +11 -0
- data/lib/fog/compute/xen_server/models/console.rb +23 -0
- data/lib/fog/compute/xen_server/models/consoles.rb +11 -0
- data/lib/fog/compute/xen_server/models/crash_dump.rb +22 -0
- data/lib/fog/compute/xen_server/models/crash_dumps.rb +11 -0
- data/lib/fog/compute/xen_server/models/dr_task.rb +20 -0
- data/lib/fog/compute/xen_server/models/dr_tasks.rb +11 -0
- data/lib/fog/compute/xen_server/models/gpu_group.rb +25 -0
- data/lib/fog/compute/xen_server/models/gpu_groups.rb +11 -0
- data/lib/fog/compute/xen_server/models/guest_metrics.rb +28 -0
- data/lib/fog/compute/xen_server/models/guests_metrics.rb +11 -0
- data/lib/fog/compute/xen_server/models/host.rb +121 -0
- data/lib/fog/compute/xen_server/models/host_cpu.rb +31 -0
- data/lib/fog/compute/xen_server/models/host_cpus.rb +11 -0
- data/lib/fog/compute/xen_server/models/host_crash_dump.rb +23 -0
- data/lib/fog/compute/xen_server/models/host_crash_dumps.rb +11 -0
- data/lib/fog/compute/xen_server/models/host_metrics.rb +28 -0
- data/lib/fog/compute/xen_server/models/host_patch.rb +28 -0
- data/lib/fog/compute/xen_server/models/host_patchs.rb +11 -0
- data/lib/fog/compute/xen_server/models/hosts.rb +11 -0
- data/lib/fog/compute/xen_server/models/hosts_metrics.rb +11 -0
- data/lib/fog/compute/xen_server/models/network.rb +65 -0
- data/lib/fog/compute/xen_server/models/networks.rb +11 -0
- data/lib/fog/compute/xen_server/models/pbd.rb +30 -0
- data/lib/fog/compute/xen_server/models/pbds.rb +11 -0
- data/lib/fog/compute/xen_server/models/pci.rb +25 -0
- data/lib/fog/compute/xen_server/models/pcis.rb +11 -0
- data/lib/fog/compute/xen_server/models/pgpu.rb +23 -0
- data/lib/fog/compute/xen_server/models/pgpus.rb +11 -0
- data/lib/fog/compute/xen_server/models/pif.rb +49 -0
- data/lib/fog/compute/xen_server/models/pif_metrics.rb +30 -0
- data/lib/fog/compute/xen_server/models/pifs.rb +11 -0
- data/lib/fog/compute/xen_server/models/pifs_metrics.rb +9 -0
- data/lib/fog/compute/xen_server/models/pool.rb +47 -0
- data/lib/fog/compute/xen_server/models/pool_patch.rb +27 -0
- data/lib/fog/compute/xen_server/models/pool_patchs.rb +11 -0
- data/lib/fog/compute/xen_server/models/pools.rb +11 -0
- data/lib/fog/compute/xen_server/models/role.rb +22 -0
- data/lib/fog/compute/xen_server/models/roles.rb +11 -0
- data/lib/fog/compute/xen_server/models/server.rb +203 -0
- data/lib/fog/compute/xen_server/models/server_appliance.rb +24 -0
- data/lib/fog/compute/xen_server/models/server_appliances.rb +11 -0
- data/lib/fog/compute/xen_server/models/server_metrics.rb +29 -0
- data/lib/fog/compute/xen_server/models/servers.rb +38 -0
- data/lib/fog/compute/xen_server/models/servers_metrics.rb +11 -0
- data/lib/fog/compute/xen_server/models/storage_manager.rb +30 -0
- data/lib/fog/compute/xen_server/models/storage_managers.rb +11 -0
- data/lib/fog/compute/xen_server/models/storage_repositories.rb +11 -0
- data/lib/fog/compute/xen_server/models/storage_repository.rb +77 -0
- data/lib/fog/compute/xen_server/models/tunnel.rb +23 -0
- data/lib/fog/compute/xen_server/models/tunnels.rb +11 -0
- data/lib/fog/compute/xen_server/models/vbd.rb +64 -0
- data/lib/fog/compute/xen_server/models/vbd_metrics.rb +27 -0
- data/lib/fog/compute/xen_server/models/vbds.rb +11 -0
- data/lib/fog/compute/xen_server/models/vbds_metrics.rb +11 -0
- data/lib/fog/compute/xen_server/models/vdi.rb +75 -0
- data/lib/fog/compute/xen_server/models/vdis.rb +11 -0
- data/lib/fog/compute/xen_server/models/vif.rb +53 -0
- data/lib/fog/compute/xen_server/models/vif_metrics.rb +22 -0
- data/lib/fog/compute/xen_server/models/vifs.rb +11 -0
- data/lib/fog/compute/xen_server/models/vifs_metrics.rb +11 -0
- data/lib/fog/compute/xen_server/models/vlan.rb +65 -0
- data/lib/fog/compute/xen_server/models/vlans.rb +11 -0
- data/lib/fog/compute/xen_server/models/vmpp.rb +38 -0
- data/lib/fog/compute/xen_server/models/vmpps.rb +11 -0
- data/lib/fog/compute/xen_server/models/vtpm.rb +21 -0
- data/lib/fog/compute/xen_server/models/vtpms.rb +11 -0
- data/lib/fog/compute/xen_server/real.rb +36 -0
- data/lib/fog/compute/xen_server/requests/builtin_templates.rb +21 -0
- data/lib/fog/{xenserver/requests/compute → compute/xen_server/requests}/clone_server.rb +1 -5
- data/lib/fog/{xenserver/requests/compute → compute/xen_server/requests}/create_network.rb +1 -6
- data/lib/fog/{xenserver/requests/compute → compute/xen_server/requests}/create_server.rb +1 -14
- data/lib/fog/{xenserver/requests/compute → compute/xen_server/requests}/create_sr.rb +1 -7
- data/lib/fog/{xenserver/requests/compute → compute/xen_server/requests}/create_vbd.rb +1 -6
- data/lib/fog/{xenserver/requests/compute → compute/xen_server/requests}/create_vdi.rb +1 -6
- data/lib/fog/{xenserver/requests/compute → compute/xen_server/requests}/create_vif.rb +1 -6
- data/lib/fog/{xenserver/requests/compute → compute/xen_server/requests}/create_vlan.rb +1 -6
- data/lib/fog/compute/xen_server/requests/custom_templates.rb +21 -0
- data/lib/fog/{xenserver/requests/compute → compute/xen_server/requests}/destroy_network.rb +1 -6
- data/lib/fog/{xenserver/requests/compute → compute/xen_server/requests}/destroy_server.rb +1 -6
- data/lib/fog/{xenserver/requests/compute → compute/xen_server/requests}/destroy_sr.rb +1 -6
- data/lib/fog/{xenserver/requests/compute → compute/xen_server/requests}/destroy_vdi.rb +1 -6
- data/lib/fog/{xenserver/requests/compute → compute/xen_server/requests}/destroy_vif.rb +1 -6
- data/lib/fog/{xenserver/requests/compute → compute/xen_server/requests}/destroy_vlan.rb +1 -6
- data/lib/fog/{xenserver/requests/compute → compute/xen_server/requests}/disable_host.rb +1 -7
- data/lib/fog/{xenserver/requests/compute → compute/xen_server/requests}/eject_vbd.rb +1 -6
- data/lib/fog/{xenserver/requests/compute → compute/xen_server/requests}/enable_host.rb +1 -7
- data/lib/fog/compute/xen_server/requests/get_record.rb +41 -0
- data/lib/fog/{xenserver/requests/compute → compute/xen_server/requests}/get_records.rb +1 -9
- data/lib/fog/{xenserver/requests/compute → compute/xen_server/requests}/insert_vbd.rb +1 -6
- data/lib/fog/{xenserver/requests/compute → compute/xen_server/requests}/provision_server.rb +1 -5
- data/lib/fog/{xenserver/requests/compute → compute/xen_server/requests}/reboot_host.rb +2 -8
- data/lib/fog/{xenserver/requests/compute → compute/xen_server/requests}/reboot_server.rb +2 -8
- data/lib/fog/{xenserver/requests/compute → compute/xen_server/requests}/scan_sr.rb +1 -6
- data/lib/fog/{xenserver/requests/compute → compute/xen_server/requests}/set_affinity.rb +1 -9
- data/lib/fog/{xenserver/requests/compute → compute/xen_server/requests}/set_attribute.rb +1 -9
- data/lib/fog/{xenserver/requests/compute → compute/xen_server/requests}/shutdown_host.rb +2 -8
- data/lib/fog/{xenserver/requests/compute → compute/xen_server/requests}/shutdown_server.rb +2 -8
- data/lib/fog/{xenserver/requests/compute → compute/xen_server/requests}/snapshot_revert.rb +1 -6
- data/lib/fog/{xenserver/requests/compute → compute/xen_server/requests}/snapshot_server.rb +1 -6
- data/lib/fog/{xenserver/requests/compute → compute/xen_server/requests}/start_server.rb +1 -7
- data/lib/fog/{xenserver/requests/compute → compute/xen_server/requests}/start_vm.rb +2 -8
- data/lib/fog/compute/xen_server/requests/templates.rb +21 -0
- data/lib/fog/{xenserver/requests/compute → compute/xen_server/requests}/unplug_pbd.rb +1 -6
- data/lib/fog/{xenserver/requests/compute → compute/xen_server/requests}/unplug_vbd.rb +1 -6
- data/lib/fog/model.rb +48 -0
- data/lib/fog/parsers/xen_server.rb +15 -0
- data/lib/fog/{xenserver/parser.rb → parsers/xen_server/base.rb} +1 -3
- data/lib/fog/{xenserver/parsers → parsers/xen_server}/get_hosts.rb +1 -4
- data/lib/fog/{xenserver/parsers → parsers/xen_server}/get_networks.rb +1 -4
- data/lib/fog/{xenserver/parsers → parsers/xen_server}/get_pools.rb +1 -4
- data/lib/fog/{xenserver/parsers → parsers/xen_server}/get_records.rb +1 -4
- data/lib/fog/{xenserver/parsers → parsers/xen_server}/get_storage_repositories.rb +1 -4
- data/lib/fog/{xenserver/parsers → parsers/xen_server}/get_vbds.rb +2 -5
- data/lib/fog/{xenserver/parsers → parsers/xen_server}/get_vifs.rb +2 -5
- data/lib/fog/{xenserver/parsers → parsers/xen_server}/get_vms.rb +1 -5
- data/lib/fog/{xenserver/utilities.rb → utilities.rb} +0 -0
- data/lib/fog/{xenserver/core.rb → xen_server/connection.rb} +2 -40
- data/lib/fog/xen_server/invalid_login.rb +5 -0
- data/lib/fog/xen_server/nokogiri_stream_parser.rb +20 -0
- data/lib/fog/xen_server/not_found.rb +5 -0
- data/lib/fog/xen_server/request_failed.rb +5 -0
- data/lib/fog/xen_server/version.rb +5 -0
- data/lib/fog/xenserver.rb +27 -1
- data/lib/fog/xenserver/compute.rb +0 -176
- data/test/fog/compute/xen_server/models/blob_test.rb +40 -0
- data/test/fog/compute/xen_server/models/bond_test.rb +42 -0
- data/test/fog/compute/xen_server/models/console_test.rb +38 -0
- data/test/fog/compute/xen_server/models/crash_dump_test.rb +39 -0
- data/test/fog/compute/xen_server/models/dr_task_test.rb +35 -0
- data/test/fog/compute/xen_server/models/gpu_group_test.rb +45 -0
- data/test/fog/compute/xen_server/models/guest_metrics_test.rb +44 -0
- data/test/fog/compute/xen_server/models/host_cpu_test.rb +46 -0
- data/test/fog/compute/xen_server/models/host_crash_dump_test.rb +37 -0
- data/test/fog/compute/xen_server/models/host_metrics_test.rb +38 -0
- data/test/fog/compute/xen_server/models/host_patch_test.rb +45 -0
- data/test/fog/compute/xen_server/models/host_test.rb +102 -0
- data/test/fog/compute/xen_server/models/network_test.rb +51 -0
- data/test/fog/compute/xen_server/models/pbd_test.rb +40 -0
- data/test/fog/compute/xen_server/models/pci_test.rb +40 -0
- data/test/fog/compute/xen_server/models/pgpu_test.rb +41 -0
- data/test/fog/compute/xen_server/models/pif_metrics_test.rb +45 -0
- data/test/fog/compute/xen_server/models/pif_test.rb +81 -0
- data/test/fog/compute/xen_server/models/pool_patch_test.rb +43 -0
- data/test/fog/compute/xen_server/models/pool_test.rb +69 -0
- data/test/fog/compute/xen_server/models/role_test.rb +38 -0
- data/test/fog/compute/xen_server/models/server_appliance_test.rb +41 -0
- data/test/fog/compute/xen_server/models/server_metrics_test.rb +48 -0
- data/test/fog/compute/xen_server/models/server_test.rb +149 -0
- data/test/fog/compute/xen_server/models/storage_manger_test.rb +46 -0
- data/test/fog/compute/xen_server/models/storage_repository_test.rb +56 -0
- data/test/fog/compute/xen_server/models/tunnel_test.rb +40 -0
- data/test/fog/compute/xen_server/models/vbd_metrics_test.rb +37 -0
- data/test/fog/compute/xen_server/models/vbd_test.rb +58 -0
- data/test/fog/compute/xen_server/models/vdi_test.rb +71 -0
- data/test/fog/compute/xen_server/models/vif_metrics_test.rb +37 -0
- data/test/fog/compute/xen_server/models/vif_test.rb +59 -0
- data/test/fog/compute/xen_server/models/vlan_test.rb +40 -0
- data/test/fog/compute/xen_server/models/vmpp_test.rb +55 -0
- data/test/fog/compute/xen_server/models/vtpm_test.rb +36 -0
- data/test/minitest_helper.rb +28 -0
- metadata +239 -120
- data/lib/fog/compute.rb +0 -7
- data/lib/fog/xenserver/examples/README.md +0 -11
- data/lib/fog/xenserver/examples/chage_default_storage_repository.md +0 -99
- data/lib/fog/xenserver/examples/creating_servers.md +0 -168
- data/lib/fog/xenserver/examples/getting_started.md +0 -163
- data/lib/fog/xenserver/examples/networks-and-vlans.rb +0 -45
- data/lib/fog/xenserver/examples/storage_repositories.md +0 -94
- data/lib/fog/xenserver/models/compute/blob.rb +0 -22
- data/lib/fog/xenserver/models/compute/blobs.rb +0 -25
- data/lib/fog/xenserver/models/compute/bond.rb +0 -23
- data/lib/fog/xenserver/models/compute/bonds.rb +0 -25
- data/lib/fog/xenserver/models/compute/console.rb +0 -29
- data/lib/fog/xenserver/models/compute/consoles.rb +0 -25
- data/lib/fog/xenserver/models/compute/crash_dump.rb +0 -19
- data/lib/fog/xenserver/models/compute/crash_dumps.rb +0 -25
- data/lib/fog/xenserver/models/compute/dr_task.rb +0 -17
- data/lib/fog/xenserver/models/compute/dr_tasks.rb +0 -25
- data/lib/fog/xenserver/models/compute/gpu_group.rb +0 -22
- data/lib/fog/xenserver/models/compute/gpu_groups.rb +0 -25
- data/lib/fog/xenserver/models/compute/guest_metrics.rb +0 -29
- data/lib/fog/xenserver/models/compute/host.rb +0 -159
- data/lib/fog/xenserver/models/compute/host_cpu.rb +0 -38
- data/lib/fog/xenserver/models/compute/host_crash_dump.rb +0 -20
- data/lib/fog/xenserver/models/compute/host_crash_dumps.rb +0 -25
- data/lib/fog/xenserver/models/compute/host_metrics.rb +0 -29
- data/lib/fog/xenserver/models/compute/host_patch.rb +0 -25
- data/lib/fog/xenserver/models/compute/host_patchs.rb +0 -25
- data/lib/fog/xenserver/models/compute/hosts.rb +0 -29
- data/lib/fog/xenserver/models/compute/network.rb +0 -92
- data/lib/fog/xenserver/models/compute/networks.rb +0 -33
- data/lib/fog/xenserver/models/compute/pbd.rb +0 -40
- data/lib/fog/xenserver/models/compute/pbds.rb +0 -33
- data/lib/fog/xenserver/models/compute/pci.rb +0 -22
- data/lib/fog/xenserver/models/compute/pcis.rb +0 -25
- data/lib/fog/xenserver/models/compute/pgpu.rb +0 -20
- data/lib/fog/xenserver/models/compute/pgpus.rb +0 -25
- data/lib/fog/xenserver/models/compute/pif.rb +0 -57
- data/lib/fog/xenserver/models/compute/pif_metrics.rb +0 -28
- data/lib/fog/xenserver/models/compute/pifs.rb +0 -33
- data/lib/fog/xenserver/models/compute/pifs_metrics.rb +0 -25
- data/lib/fog/xenserver/models/compute/pool.rb +0 -79
- data/lib/fog/xenserver/models/compute/pool_patch.rb +0 -24
- data/lib/fog/xenserver/models/compute/pool_patchs.rb +0 -25
- data/lib/fog/xenserver/models/compute/pools.rb +0 -33
- data/lib/fog/xenserver/models/compute/role.rb +0 -19
- data/lib/fog/xenserver/models/compute/roles.rb +0 -25
- data/lib/fog/xenserver/models/compute/server.rb +0 -250
- data/lib/fog/xenserver/models/compute/server_appliance.rb +0 -21
- data/lib/fog/xenserver/models/compute/server_appliances.rb +0 -25
- data/lib/fog/xenserver/models/compute/servers.rb +0 -68
- data/lib/fog/xenserver/models/compute/storage_manager.rb +0 -28
- data/lib/fog/xenserver/models/compute/storage_managers.rb +0 -25
- data/lib/fog/xenserver/models/compute/storage_repositories.rb +0 -31
- data/lib/fog/xenserver/models/compute/storage_repository.rb +0 -93
- data/lib/fog/xenserver/models/compute/tunnel.rb +0 -20
- data/lib/fog/xenserver/models/compute/tunnels.rb +0 -25
- data/lib/fog/xenserver/models/compute/vbd.rb +0 -91
- data/lib/fog/xenserver/models/compute/vbd_metrics.rb +0 -27
- data/lib/fog/xenserver/models/compute/vbds.rb +0 -33
- data/lib/fog/xenserver/models/compute/vdi.rb +0 -105
- data/lib/fog/xenserver/models/compute/vdis.rb +0 -29
- data/lib/fog/xenserver/models/compute/vif.rb +0 -60
- data/lib/fog/xenserver/models/compute/vifs.rb +0 -29
- data/lib/fog/xenserver/models/compute/vlan.rb +0 -81
- data/lib/fog/xenserver/models/compute/vlans.rb +0 -39
- data/lib/fog/xenserver/models/compute/vmpp.rb +0 -35
- data/lib/fog/xenserver/models/compute/vmpps.rb +0 -25
- data/lib/fog/xenserver/models/compute/vtpm.rb +0 -18
- data/lib/fog/xenserver/models/compute/vtpms.rb +0 -25
- data/lib/fog/xenserver/requests/compute/get_record.rb +0 -29
- data/lib/fog/xenserver/version.rb +0 -5
@@ -1,25 +1,17 @@
|
|
1
1
|
module Fog
|
2
2
|
module Compute
|
3
3
|
class XenServer
|
4
|
-
|
5
4
|
class Real
|
6
|
-
|
7
|
-
require 'fog/xenserver/parser'
|
8
|
-
|
9
5
|
def set_affinity( host_ref )
|
10
6
|
@connection.request({:parser => Fog::Parsers::XenServer::Base.new, :method => 'VM.set_affinity'}, host_ref)
|
11
7
|
end
|
12
|
-
|
13
8
|
end
|
14
9
|
|
15
10
|
class Mock
|
16
|
-
|
17
11
|
def set_affinity( uuid )
|
18
12
|
Fog::Mock.not_implemented
|
19
13
|
end
|
20
|
-
|
21
14
|
end
|
22
|
-
|
23
15
|
end
|
24
16
|
end
|
25
|
-
end
|
17
|
+
end
|
@@ -1,25 +1,17 @@
|
|
1
1
|
module Fog
|
2
2
|
module Compute
|
3
3
|
class XenServer
|
4
|
-
|
5
4
|
class Real
|
6
|
-
|
7
|
-
require 'fog/xenserver/parser'
|
8
|
-
|
9
5
|
def set_attribute( klass, ref, attr_name, *value )
|
10
6
|
@connection.request({:parser => Fog::Parsers::XenServer::Base.new, :method => "#{klass}.set_#{attr_name.gsub('-','_')}"}, ref, *value)
|
11
7
|
end
|
12
|
-
|
13
8
|
end
|
14
9
|
|
15
10
|
class Mock
|
16
|
-
|
17
11
|
def set_attribute( klass, ref, attr_name, value )
|
18
12
|
Fog::Mock.not_implemented
|
19
13
|
end
|
20
|
-
|
21
14
|
end
|
22
|
-
|
23
15
|
end
|
24
16
|
end
|
25
|
-
end
|
17
|
+
end
|
@@ -1,23 +1,17 @@
|
|
1
1
|
module Fog
|
2
2
|
module Compute
|
3
|
-
class
|
4
|
-
|
3
|
+
class XenServer
|
5
4
|
class Real
|
6
|
-
|
7
5
|
def shutdown_host( ref )
|
8
6
|
@connection.request({:parser => Fog::Parsers::XenServer::Base.new, :method => "host.shutdown"}, ref)
|
9
7
|
end
|
10
|
-
|
11
8
|
end
|
12
9
|
|
13
10
|
class Mock
|
14
|
-
|
15
11
|
def shutdown_host( ref )
|
16
12
|
Fog::Mock.not_implemented
|
17
13
|
end
|
18
|
-
|
19
14
|
end
|
20
|
-
|
21
15
|
end
|
22
16
|
end
|
23
|
-
end
|
17
|
+
end
|
@@ -1,23 +1,17 @@
|
|
1
1
|
module Fog
|
2
2
|
module Compute
|
3
|
-
class
|
4
|
-
|
3
|
+
class XenServer
|
5
4
|
class Real
|
6
|
-
|
7
5
|
def shutdown_server( vm_ref, stype = 'clean' )
|
8
6
|
@connection.request({:parser => Fog::Parsers::XenServer::Base.new, :method => "VM.#{stype}_shutdown"}, vm_ref)
|
9
7
|
end
|
10
|
-
|
11
8
|
end
|
12
9
|
|
13
10
|
class Mock
|
14
|
-
|
15
11
|
def shutdown_server( vm_ref )
|
16
12
|
Fog::Mock.not_implemented
|
17
13
|
end
|
18
|
-
|
19
14
|
end
|
20
|
-
|
21
15
|
end
|
22
16
|
end
|
23
|
-
end
|
17
|
+
end
|
@@ -1,22 +1,17 @@
|
|
1
1
|
module Fog
|
2
2
|
module Compute
|
3
3
|
class XenServer
|
4
|
-
|
5
4
|
class Real
|
6
|
-
|
7
5
|
def snapshot_revert( snapshot_ref, extra_args = {})
|
8
6
|
@connection.request({:parser => Fog::Parsers::XenServer::Base.new, :method => 'VM.revert'}, snapshot_ref)
|
9
7
|
end
|
10
|
-
|
11
8
|
end
|
12
9
|
|
13
10
|
class Mock
|
14
|
-
|
15
11
|
def snapshot_revert()
|
16
12
|
Fog::Mock.not_implemented
|
17
13
|
end
|
18
|
-
|
19
14
|
end
|
20
15
|
end
|
21
16
|
end
|
22
|
-
end
|
17
|
+
end
|
@@ -1,22 +1,17 @@
|
|
1
1
|
module Fog
|
2
2
|
module Compute
|
3
3
|
class XenServer
|
4
|
-
|
5
4
|
class Real
|
6
|
-
|
7
5
|
def snapshot_server( vm_ref , name, extra_args = {})
|
8
6
|
@connection.request({:parser => Fog::Parsers::XenServer::Base.new, :method => 'VM.snapshot'}, vm_ref, name)
|
9
7
|
end
|
10
|
-
|
11
8
|
end
|
12
9
|
|
13
10
|
class Mock
|
14
|
-
|
15
11
|
def snapshot_server()
|
16
12
|
Fog::Mock.not_implemented
|
17
13
|
end
|
18
|
-
|
19
14
|
end
|
20
15
|
end
|
21
16
|
end
|
22
|
-
end
|
17
|
+
end
|
@@ -1,23 +1,17 @@
|
|
1
1
|
module Fog
|
2
2
|
module Compute
|
3
|
-
|
4
3
|
class XenServer
|
5
4
|
class Real
|
6
|
-
|
7
5
|
def start_server( vm_ref )
|
8
6
|
start_vm( vm_ref )
|
9
7
|
end
|
10
|
-
|
11
8
|
end
|
12
9
|
|
13
10
|
class Mock
|
14
|
-
|
15
11
|
def start_server( vm_ref )
|
16
12
|
Fog::Mock.not_implemented
|
17
13
|
end
|
18
|
-
|
19
14
|
end
|
20
|
-
|
21
15
|
end
|
22
16
|
end
|
23
|
-
end
|
17
|
+
end
|
@@ -1,25 +1,19 @@
|
|
1
1
|
module Fog
|
2
2
|
module Compute
|
3
|
-
class
|
4
|
-
|
3
|
+
class XenServer
|
5
4
|
class Real
|
6
|
-
|
7
5
|
# http://bit.ly/8ZPyCN
|
8
6
|
# VM.start( session, VM_ref, start_paused, force)
|
9
7
|
def start_vm( vm_ref )
|
10
8
|
@connection.request({:parser => Fog::Parsers::XenServer::Base.new, :method => 'VM.start'}, vm_ref, false, false)
|
11
9
|
end
|
12
|
-
|
13
10
|
end
|
14
11
|
|
15
12
|
class Mock
|
16
|
-
|
17
13
|
def start_vm( vm_ref )
|
18
14
|
Fog::Mock.not_implemented
|
19
15
|
end
|
20
|
-
|
21
16
|
end
|
22
|
-
|
23
17
|
end
|
24
18
|
end
|
25
|
-
end
|
19
|
+
end
|
@@ -0,0 +1,21 @@
|
|
1
|
+
module Fog
|
2
|
+
module Compute
|
3
|
+
class XenServer
|
4
|
+
class Real
|
5
|
+
def templates
|
6
|
+
data = @connection.request(:parser => Fog::Parsers::XenServer::GetRecords.new, :method => "VM.get_all_records")
|
7
|
+
data.keep_if { |vm| vm[:is_a_template] }
|
8
|
+
servers.load(data)
|
9
|
+
rescue Fog::XenServer::RequestFailed => e
|
10
|
+
[]
|
11
|
+
end
|
12
|
+
end
|
13
|
+
|
14
|
+
class Mock
|
15
|
+
def templates
|
16
|
+
Fog::Mock.not_implemented
|
17
|
+
end
|
18
|
+
end
|
19
|
+
end
|
20
|
+
end
|
21
|
+
end
|
@@ -1,25 +1,20 @@
|
|
1
1
|
module Fog
|
2
2
|
module Compute
|
3
3
|
class XenServer
|
4
|
-
|
5
4
|
class Real
|
6
|
-
|
7
5
|
def unplug_pbd( ref )
|
8
6
|
@connection.request(
|
9
7
|
{:parser => Fog::Parsers::XenServer::Base.new, :method => 'PBD.unplug'},
|
10
8
|
ref
|
11
9
|
)
|
12
10
|
end
|
13
|
-
|
14
11
|
end
|
15
12
|
|
16
13
|
class Mock
|
17
|
-
|
18
14
|
def unplug_pbd( ref )
|
19
15
|
Fog::Mock.not_implemented
|
20
16
|
end
|
21
|
-
|
22
17
|
end
|
23
18
|
end
|
24
19
|
end
|
25
|
-
end
|
20
|
+
end
|
@@ -1,9 +1,7 @@
|
|
1
1
|
module Fog
|
2
2
|
module Compute
|
3
3
|
class XenServer
|
4
|
-
|
5
4
|
class Real
|
6
|
-
|
7
5
|
def unplug_vbd( vbd_ref, extra_args = {})
|
8
6
|
@connection.request({:parser => Fog::Parsers::XenServer::Base.new, :method => 'VBD.unplug'}, vbd_ref)
|
9
7
|
end
|
@@ -11,11 +9,9 @@ module Fog
|
|
11
9
|
def unplug_force_vbd(ref, extra_args = {})
|
12
10
|
@connection.request({:parser => Fog::Parsers::XenServer::Base.new, :method => 'VBD.unplug_force'}, ref)
|
13
11
|
end
|
14
|
-
|
15
12
|
end
|
16
13
|
|
17
14
|
class Mock
|
18
|
-
|
19
15
|
def unplug_vbd(ref, extra_args = {})
|
20
16
|
Fog::Mock.not_implemented
|
21
17
|
end
|
@@ -23,8 +19,7 @@ module Fog
|
|
23
19
|
def unplug_force_vbd(ref, extra_args = {})
|
24
20
|
Fog::Mock.not_implemented
|
25
21
|
end
|
26
|
-
|
27
22
|
end
|
28
23
|
end
|
29
24
|
end
|
30
|
-
end
|
25
|
+
end
|
data/lib/fog/model.rb
ADDED
@@ -0,0 +1,48 @@
|
|
1
|
+
require 'fog/core/model'
|
2
|
+
|
3
|
+
module Fog
|
4
|
+
class Model
|
5
|
+
def self.provider_class(provider_class = nil)
|
6
|
+
return @provider_class if provider_class.nil?
|
7
|
+
@provider_class = provider_class.to_s
|
8
|
+
end
|
9
|
+
|
10
|
+
def provider_class
|
11
|
+
self.class.provider_class
|
12
|
+
end
|
13
|
+
|
14
|
+
def self.has_one(association, collection_name, options = {})
|
15
|
+
options[:aliases] = Array(options[:aliases])
|
16
|
+
options[:aliases] << association.to_sym
|
17
|
+
attribute("__#{association}".to_sym, options)
|
18
|
+
define_method(association) do
|
19
|
+
begin
|
20
|
+
service.send(collection_name).get(send("__#{association}"))
|
21
|
+
rescue Fog::XenServer::RequestFailed => e
|
22
|
+
nil
|
23
|
+
end
|
24
|
+
end
|
25
|
+
end
|
26
|
+
|
27
|
+
def self.has_many(associations, collection_name, options = {})
|
28
|
+
options[:aliases] = Array(options[:aliases])
|
29
|
+
options[:aliases] << associations.to_sym
|
30
|
+
attribute("__#{associations}".to_sym, options)
|
31
|
+
define_method(associations) do
|
32
|
+
send("__#{associations}").collect { |association| service.send(collection_name).get(association) }
|
33
|
+
end
|
34
|
+
end
|
35
|
+
|
36
|
+
def set_attribute(name, *val)
|
37
|
+
service.set_attribute(provider_class, reference, name, *val)
|
38
|
+
end
|
39
|
+
|
40
|
+
def refresh
|
41
|
+
data = service.get_record(identity, provider_class)
|
42
|
+
merge_attributes(data)
|
43
|
+
true
|
44
|
+
end
|
45
|
+
|
46
|
+
alias_method :reload, :refresh
|
47
|
+
end
|
48
|
+
end
|
@@ -0,0 +1,15 @@
|
|
1
|
+
module Fog
|
2
|
+
module Parsers
|
3
|
+
module XenServer
|
4
|
+
autoload :Base, 'fog/parsers/xen_server/base'
|
5
|
+
autoload :GetHosts, 'fog/parsers/xen_server/get_hosts'
|
6
|
+
autoload :GetNetworks, 'fog/parsers/xen_server/get_networks'
|
7
|
+
autoload :GetPools, 'fog/parsers/xen_server/get_pools'
|
8
|
+
autoload :GetRecords, 'fog/parsers/xen_server/get_records'
|
9
|
+
autoload :GetStorageRepositories, 'fog/parsers/xen_server/get_storage_repositories'
|
10
|
+
autoload :GetVbds, 'fog/parsers/xen_server/get_vbds'
|
11
|
+
autoload :GetVifs, 'fog/parsers/xen_server/get_vifs'
|
12
|
+
autoload :GetVms, 'fog/parsers/xen_server/get_vms'
|
13
|
+
end
|
14
|
+
end
|
15
|
+
end
|
@@ -2,7 +2,6 @@ module Fog
|
|
2
2
|
module Parsers
|
3
3
|
module XenServer
|
4
4
|
class GetHosts < Fog::Parsers::XenServer::Base
|
5
|
-
|
6
5
|
def reset
|
7
6
|
@response = []
|
8
7
|
end
|
@@ -11,9 +10,7 @@ module Fog
|
|
11
10
|
parser = Fog::Parsers::XenServer::Base.new
|
12
11
|
data.each_pair {|reference, host_hash| @response << parser.parse( host_hash ).merge(:reference => reference) }
|
13
12
|
end
|
14
|
-
|
15
13
|
end
|
16
|
-
|
17
14
|
end
|
18
15
|
end
|
19
|
-
end
|
16
|
+
end
|
@@ -2,7 +2,6 @@ module Fog
|
|
2
2
|
module Parsers
|
3
3
|
module XenServer
|
4
4
|
class GetNetworks < Fog::Parsers::XenServer::Base
|
5
|
-
|
6
5
|
def reset
|
7
6
|
@response = []
|
8
7
|
end
|
@@ -11,9 +10,7 @@ module Fog
|
|
11
10
|
parser = Fog::Parsers::XenServer::Base.new
|
12
11
|
data.each_pair {|reference, network_hash| @response << parser.parse( network_hash ).merge(:reference => reference) }
|
13
12
|
end
|
14
|
-
|
15
13
|
end
|
16
|
-
|
17
14
|
end
|
18
15
|
end
|
19
|
-
end
|
16
|
+
end
|
@@ -2,7 +2,6 @@ module Fog
|
|
2
2
|
module Parsers
|
3
3
|
module XenServer
|
4
4
|
class GetPools < Fog::Parsers::XenServer::Base
|
5
|
-
|
6
5
|
def reset
|
7
6
|
@response = []
|
8
7
|
end
|
@@ -11,9 +10,7 @@ module Fog
|
|
11
10
|
parser = Fog::Parsers::XenServer::Base.new
|
12
11
|
data.each_pair {|reference, pool_hash| @response << parser.parse( pool_hash ).merge(:reference => reference) }
|
13
12
|
end
|
14
|
-
|
15
13
|
end
|
16
|
-
|
17
14
|
end
|
18
15
|
end
|
19
|
-
end
|
16
|
+
end
|
@@ -2,7 +2,6 @@ module Fog
|
|
2
2
|
module Parsers
|
3
3
|
module XenServer
|
4
4
|
class GetRecords < Fog::Parsers::XenServer::Base
|
5
|
-
|
6
5
|
def reset
|
7
6
|
@response = []
|
8
7
|
end
|
@@ -11,9 +10,7 @@ module Fog
|
|
11
10
|
parser = Fog::Parsers::XenServer::Base.new
|
12
11
|
data.each_pair {|reference, hash| @response << parser.parse( hash ).merge(:reference => reference) }
|
13
12
|
end
|
14
|
-
|
15
13
|
end
|
16
|
-
|
17
14
|
end
|
18
15
|
end
|
19
|
-
end
|
16
|
+
end
|