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
@@ -0,0 +1,65 @@
|
|
1
|
+
module Fog
|
2
|
+
module Compute
|
3
|
+
class XenServer
|
4
|
+
module Models
|
5
|
+
class Vlan < Fog::Model
|
6
|
+
# API Reference here:
|
7
|
+
# @see http://docs.vmd.citrix.com/XenServer/6.2.0/1.0/en_gb/api/?c=VLAN
|
8
|
+
|
9
|
+
provider_class :VLAN
|
10
|
+
|
11
|
+
identity :reference
|
12
|
+
|
13
|
+
attribute :other_config
|
14
|
+
attribute :tag, :type => :integer
|
15
|
+
attribute :uuid
|
16
|
+
|
17
|
+
has_one :tagged_pif, :pifs, :aliases => :tagged_PIF
|
18
|
+
has_one :untagged_pif, :pifs, :aliases => :untagged_PIF
|
19
|
+
|
20
|
+
# Creates a new VLAN.
|
21
|
+
#
|
22
|
+
# service = Fog::Compute[:xenserver]
|
23
|
+
#
|
24
|
+
# # create a network 'foo-net'
|
25
|
+
# net = service.networks.create :name => 'foo-net'
|
26
|
+
#
|
27
|
+
# # get the eth0 physical interface where the
|
28
|
+
# # VLAN subinterface will be added
|
29
|
+
# pif = service.pifs.find { |p| p.device == 'eth0' and p.physical }
|
30
|
+
#
|
31
|
+
# Fog::Compute[:xenserver].vlans.create :tag => 123,
|
32
|
+
# :network => net,
|
33
|
+
# :pif => pif
|
34
|
+
def save
|
35
|
+
requires :tag
|
36
|
+
pif = attributes[:pif]
|
37
|
+
net = attributes[:network]
|
38
|
+
unless pif and net
|
39
|
+
raise Fog::Error.new 'save requires :pif and :network attributes'
|
40
|
+
end
|
41
|
+
ref = service.create_vlan attributes[:pif].reference,
|
42
|
+
tag,
|
43
|
+
attributes[:network].reference
|
44
|
+
data = service.get_record ref, 'VLAN'
|
45
|
+
merge_attributes data
|
46
|
+
true
|
47
|
+
end
|
48
|
+
|
49
|
+
# Destroys a VLAN.
|
50
|
+
#
|
51
|
+
# service = Fog::Compute[:xenserver]
|
52
|
+
#
|
53
|
+
# # Find VLAN 123 and destroy it
|
54
|
+
# (service.vlans.find { |v| v.tag == 123 }).destroy
|
55
|
+
#
|
56
|
+
def destroy
|
57
|
+
requires :reference
|
58
|
+
service.destroy_vlan reference
|
59
|
+
true
|
60
|
+
end
|
61
|
+
end
|
62
|
+
end
|
63
|
+
end
|
64
|
+
end
|
65
|
+
end
|
@@ -0,0 +1,38 @@
|
|
1
|
+
module Fog
|
2
|
+
module Compute
|
3
|
+
class XenServer
|
4
|
+
module Models
|
5
|
+
class Vmpp < Fog::Model
|
6
|
+
# API Reference here:
|
7
|
+
# http://docs.vmd.citrix.com/XenServer/6.2.0/1.0/en_gb/api/?c=VMPP
|
8
|
+
|
9
|
+
provider_class :VMPP
|
10
|
+
|
11
|
+
identity :reference
|
12
|
+
|
13
|
+
attribute :alarm_config
|
14
|
+
attribute :archive_frequency
|
15
|
+
attribute :archive_last_run_time
|
16
|
+
attribute :archive_schedule
|
17
|
+
attribute :archive_target_config
|
18
|
+
attribute :archive_target_type
|
19
|
+
attribute :backup_frequency
|
20
|
+
attribute :backup_last_run_time
|
21
|
+
attribute :backup_retention_value
|
22
|
+
attribute :backup_schedule
|
23
|
+
attribute :backup_type
|
24
|
+
attribute :description, :aliases => :name_description
|
25
|
+
attribute :is_alarm_enabled
|
26
|
+
attribute :is_archive_running
|
27
|
+
attribute :is_backup_running
|
28
|
+
attribute :is_policy_enabled
|
29
|
+
attribute :name, :aliases => :name_label
|
30
|
+
attribute :recent_alerts
|
31
|
+
attribute :uuid
|
32
|
+
|
33
|
+
has_many :vms, :servers, :aliases => :VMs
|
34
|
+
end
|
35
|
+
end
|
36
|
+
end
|
37
|
+
end
|
38
|
+
end
|
@@ -0,0 +1,21 @@
|
|
1
|
+
module Fog
|
2
|
+
module Compute
|
3
|
+
class XenServer
|
4
|
+
module Models
|
5
|
+
class Vtpm < Fog::Model
|
6
|
+
# API Reference here:
|
7
|
+
# http://docs.vmd.citrix.com/XenServer/6.2.0/1.0/en_gb/api/?c=VTPM
|
8
|
+
|
9
|
+
provider_class :VTPM
|
10
|
+
|
11
|
+
identity :reference
|
12
|
+
|
13
|
+
attribute :uuid
|
14
|
+
|
15
|
+
has_one :backend, :servers
|
16
|
+
has_one :vm, :servers
|
17
|
+
end
|
18
|
+
end
|
19
|
+
end
|
20
|
+
end
|
21
|
+
end
|
@@ -0,0 +1,36 @@
|
|
1
|
+
module Fog
|
2
|
+
module Compute
|
3
|
+
class XenServer
|
4
|
+
class Real
|
5
|
+
def initialize(options={})
|
6
|
+
@host = options[:xenserver_url]
|
7
|
+
@username = options[:xenserver_username]
|
8
|
+
@password = options[:xenserver_password]
|
9
|
+
@defaults = options[:xenserver_defaults] || {}
|
10
|
+
@timeout = options[:xenserver_timeout] || 30
|
11
|
+
@connection = Fog::XenServer::Connection.new(@host, @timeout)
|
12
|
+
@connection.authenticate(@username, @password)
|
13
|
+
end
|
14
|
+
|
15
|
+
def reload
|
16
|
+
@connection.authenticate(@username, @password)
|
17
|
+
end
|
18
|
+
|
19
|
+
def default_template=(name)
|
20
|
+
@defaults[:template] = name
|
21
|
+
end
|
22
|
+
|
23
|
+
def default_template
|
24
|
+
return nil if @defaults[:template].nil?
|
25
|
+
(servers.custom_templates + servers.builtin_templates).find do |s|
|
26
|
+
(s.name == @defaults[:template]) or (s.uuid == @defaults[:template])
|
27
|
+
end
|
28
|
+
end
|
29
|
+
|
30
|
+
def default_network
|
31
|
+
networks.find { |n| n.name == (@defaults[:network] || "Pool-wide network associated with eth0") }
|
32
|
+
end
|
33
|
+
end
|
34
|
+
end
|
35
|
+
end
|
36
|
+
end
|
@@ -0,0 +1,21 @@
|
|
1
|
+
module Fog
|
2
|
+
module Compute
|
3
|
+
class XenServer
|
4
|
+
class Real
|
5
|
+
def builtin_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] && !vm[:other_config]['default_template'].nil? }
|
8
|
+
servers.load(data)
|
9
|
+
rescue Fog::XenServer::RequestFailed => e
|
10
|
+
[]
|
11
|
+
end
|
12
|
+
end
|
13
|
+
|
14
|
+
class Mock
|
15
|
+
def builtin_templates
|
16
|
+
Fog::Mock.not_implemented
|
17
|
+
end
|
18
|
+
end
|
19
|
+
end
|
20
|
+
end
|
21
|
+
end
|
@@ -2,7 +2,6 @@ module Fog
|
|
2
2
|
module Compute
|
3
3
|
class XenServer
|
4
4
|
class Real
|
5
|
-
|
6
5
|
def clone_server( server_name, template_ref )
|
7
6
|
# Clone the VM template
|
8
7
|
if template_ref.kind_of? Fog::Compute::XenServer::Server
|
@@ -16,16 +15,13 @@ module Fog
|
|
16
15
|
template_ref, server_name
|
17
16
|
)
|
18
17
|
end
|
19
|
-
|
20
18
|
end
|
21
19
|
|
22
20
|
class Mock
|
23
|
-
|
24
21
|
def clone_server( server_name, template_ref )
|
25
22
|
Fog::Mock.not_implemented
|
26
23
|
end
|
27
24
|
end
|
28
|
-
|
29
25
|
end
|
30
26
|
end
|
31
|
-
end
|
27
|
+
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
|
# Create a Network
|
8
6
|
#
|
9
7
|
# @see http://docs.vmd.citrix.com/XenServer/6.0.0/1.0/en_gb/api/?c=network
|
@@ -30,13 +28,10 @@ module Fog
|
|
30
28
|
end
|
31
29
|
|
32
30
|
class Mock
|
33
|
-
|
34
31
|
def create_network( name, description = '', config = {} )
|
35
32
|
Fog::Mock.not_implemented
|
36
33
|
end
|
37
|
-
|
38
34
|
end
|
39
|
-
|
40
35
|
end
|
41
36
|
end
|
42
|
-
end
|
37
|
+
end
|
@@ -2,15 +2,6 @@ module Fog
|
|
2
2
|
module Compute
|
3
3
|
class XenServer
|
4
4
|
class Real
|
5
|
-
|
6
|
-
def get_vm_by_name(label)
|
7
|
-
@connection.request({:parser => Fog::Parsers::XenServer::Base.new, :method => 'VM.get_by_name_label' }, label)
|
8
|
-
end
|
9
|
-
|
10
|
-
def get_vm_by_uuid(uuid)
|
11
|
-
@connection.request({:parser => Fog::Parsers::XenServer::Base.new, :method => 'VM.get_by_uuid' }, uuid)
|
12
|
-
end
|
13
|
-
|
14
5
|
def create_server_raw(config = {})
|
15
6
|
config[:name_label] = config[:name] if config[:name]
|
16
7
|
config.delete :name
|
@@ -110,11 +101,9 @@ module Fog
|
|
110
101
|
|
111
102
|
ref
|
112
103
|
end
|
113
|
-
|
114
104
|
end
|
115
105
|
|
116
106
|
class Mock
|
117
|
-
|
118
107
|
def create_server( name_label, template = nil, network = nil, extra_args = {})
|
119
108
|
Fog::Mock.not_implemented
|
120
109
|
end
|
@@ -122,9 +111,7 @@ module Fog
|
|
122
111
|
def create_server_raw(config = {})
|
123
112
|
Fog::Mock.not_implemented
|
124
113
|
end
|
125
|
-
|
126
114
|
end
|
127
|
-
|
128
115
|
end
|
129
116
|
end
|
130
|
-
end
|
117
|
+
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
|
#
|
8
6
|
# Create a storage repository (SR)
|
9
7
|
#
|
@@ -48,11 +46,9 @@ module Fog
|
|
48
46
|
sm_config || {}
|
49
47
|
)
|
50
48
|
end
|
51
|
-
|
52
49
|
end
|
53
50
|
|
54
51
|
class Mock
|
55
|
-
|
56
52
|
def create_sr( host_ref,
|
57
53
|
name_label,
|
58
54
|
type,
|
@@ -64,9 +60,7 @@ module Fog
|
|
64
60
|
sm_config = {} )
|
65
61
|
Fog::Mock.not_implemented
|
66
62
|
end
|
67
|
-
|
68
63
|
end
|
69
|
-
|
70
64
|
end
|
71
65
|
end
|
72
|
-
end
|
66
|
+
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 create_vbd( vm_ref, vdi_ref, config = {} )
|
8
6
|
raise ArgumentError.new('Invalid config') if config.nil?
|
9
7
|
vm_ref = vm_ref.reference if vm_ref.kind_of? Fog::Compute::XenServer::Server
|
@@ -28,13 +26,10 @@ module Fog
|
|
28
26
|
end
|
29
27
|
|
30
28
|
class Mock
|
31
|
-
|
32
29
|
def create_vbd( config )
|
33
30
|
Fog::Mock.not_implemented
|
34
31
|
end
|
35
|
-
|
36
32
|
end
|
37
|
-
|
38
33
|
end
|
39
34
|
end
|
40
|
-
end
|
35
|
+
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 create_vdi( config )
|
8
6
|
raise ArgumentError.new('Invalid config') if config.nil?
|
9
7
|
raise ArgumentError.new('Missing virtual_size attribute') if config[:virtual_size].nil?
|
@@ -21,13 +19,10 @@ module Fog
|
|
21
19
|
end
|
22
20
|
|
23
21
|
class Mock
|
24
|
-
|
25
22
|
def create_vdi( ref )
|
26
23
|
Fog::Mock.not_implemented
|
27
24
|
end
|
28
|
-
|
29
25
|
end
|
30
|
-
|
31
26
|
end
|
32
27
|
end
|
33
|
-
end
|
28
|
+
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 create_vif( vm_ref, network_ref, device = -1)
|
8
6
|
raise ArgumentError.new('Invalid vm_ref') if vm_ref.nil?
|
9
7
|
raise ArgumentError.new('Invalid network_ref') if network_ref.nil?
|
@@ -45,13 +43,10 @@ module Fog
|
|
45
43
|
end
|
46
44
|
|
47
45
|
class Mock
|
48
|
-
|
49
46
|
def create_vif( vm_ref, network_ref )
|
50
47
|
Fog::Mock.not_implemented
|
51
48
|
end
|
52
|
-
|
53
49
|
end
|
54
|
-
|
55
50
|
end
|
56
51
|
end
|
57
|
-
end
|
52
|
+
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
|
#
|
8
6
|
# Create a VLAN
|
9
7
|
#
|
@@ -23,13 +21,10 @@ module Fog
|
|
23
21
|
end
|
24
22
|
|
25
23
|
class Mock
|
26
|
-
|
27
24
|
def create_vlan( pif_ref, vlan_id, network_ref )
|
28
25
|
Fog::Mock.not_implemented
|
29
26
|
end
|
30
|
-
|
31
27
|
end
|
32
|
-
|
33
28
|
end
|
34
29
|
end
|
35
|
-
end
|
30
|
+
end
|