fog 1.24.0 → 1.25.0

Sign up to get free protection for your applications and to get access to all the features.
Files changed (304) hide show
  1. checksums.yaml +5 -13
  2. data/CHANGELOG.md +184 -1
  3. data/CONTRIBUTORS.md +23 -0
  4. data/README.md +17 -9
  5. data/Rakefile +4 -0
  6. data/fog.gemspec +18 -6
  7. data/lib/fog.rb +1 -1
  8. data/lib/fog/aws/auto_scaling.rb +12 -12
  9. data/lib/fog/aws/beanstalk.rb +12 -10
  10. data/lib/fog/aws/cdn.rb +0 -1
  11. data/lib/fog/aws/cloud_formation.rb +13 -11
  12. data/lib/fog/aws/cloud_watch.rb +14 -11
  13. data/lib/fog/aws/compute.rb +19 -19
  14. data/lib/fog/aws/core.rb +21 -0
  15. data/lib/fog/aws/dns.rb +0 -1
  16. data/lib/fog/aws/elasticache.rb +13 -9
  17. data/lib/fog/aws/elb.rb +23 -14
  18. data/lib/fog/aws/emr.rb +11 -9
  19. data/lib/fog/aws/iam.rb +14 -11
  20. data/lib/fog/aws/models/compute/security_group.rb +41 -0
  21. data/lib/fog/aws/models/elb/load_balancer.rb +31 -0
  22. data/lib/fog/aws/models/glacier/archive.rb +3 -1
  23. data/lib/fog/aws/models/iam/role.rb +1 -1
  24. data/lib/fog/aws/models/iam/roles.rb +1 -1
  25. data/lib/fog/aws/models/storage/file.rb +1 -1
  26. data/lib/fog/aws/parsers/compute/describe_security_groups.rb +68 -53
  27. data/lib/fog/aws/parsers/elb/describe_load_balancer_attributes.rb +7 -0
  28. data/lib/fog/aws/parsers/elb/describe_tags.rb +26 -0
  29. data/lib/fog/aws/parsers/elb/tag_list_parser.rb +57 -0
  30. data/lib/fog/aws/parsers/storage/get_bucket_website.rb +5 -1
  31. data/lib/fog/aws/rds.rb +13 -11
  32. data/lib/fog/aws/region_methods.rb +1 -1
  33. data/lib/fog/aws/requests/dynamodb/put_item.rb +1 -1
  34. data/lib/fog/aws/requests/elb/add_tags.rb +46 -0
  35. data/lib/fog/aws/requests/elb/create_load_balancer.rb +4 -1
  36. data/lib/fog/aws/requests/elb/describe_load_balancer_attributes.rb +3 -0
  37. data/lib/fog/aws/requests/elb/describe_tags.rb +56 -0
  38. data/lib/fog/aws/requests/elb/modify_load_balancer_attributes.rb +9 -3
  39. data/lib/fog/aws/requests/elb/remove_tags.rb +46 -0
  40. data/lib/fog/aws/requests/storage/copy_object.rb +1 -1
  41. data/lib/fog/aws/requests/storage/delete_object.rb +4 -3
  42. data/lib/fog/aws/requests/storage/post_object_hidden_fields.rb +23 -5
  43. data/lib/fog/aws/requests/storage/post_object_restore.rb +1 -1
  44. data/lib/fog/aws/requests/storage/put_bucket_website.rb +46 -18
  45. data/lib/fog/aws/ses.rb +1 -2
  46. data/lib/fog/aws/signaturev4.rb +62 -15
  47. data/lib/fog/aws/simpledb.rb +0 -1
  48. data/lib/fog/aws/sns.rb +12 -9
  49. data/lib/fog/aws/sqs.rb +14 -10
  50. data/lib/fog/aws/storage.rb +102 -78
  51. data/lib/fog/aws/sts.rb +10 -9
  52. data/lib/fog/bare_metal_cloud/compute.rb +0 -1
  53. data/lib/fog/bin.rb +1 -0
  54. data/lib/fog/bin/brightbox.rb +3 -1
  55. data/lib/fog/bin/rackspace.rb +4 -0
  56. data/lib/fog/bluebox/models/compute/server.rb +1 -0
  57. data/lib/fog/cloudstack/models/compute/server.rb +12 -1
  58. data/lib/fog/cloudstack/models/compute/snapshots.rb +3 -2
  59. data/lib/fog/cloudstack/models/compute/volume.rb +5 -0
  60. data/lib/fog/cloudstack/models/compute/volumes.rb +3 -2
  61. data/lib/fog/core/parser.rb +2 -112
  62. data/lib/fog/dnsmadeeasy/dns.rb +0 -1
  63. data/lib/fog/dynect/core.rb +0 -1
  64. data/lib/fog/dynect/dns.rb +11 -3
  65. data/lib/fog/ecloud/compute.rb +0 -1
  66. data/lib/fog/ecloud/core.rb +1 -1
  67. data/lib/fog/fogdocker/compute.rb +4 -1
  68. data/lib/fog/fogdocker/core.rb +1 -7
  69. data/lib/fog/fogdocker/errors.rb +9 -0
  70. data/lib/fog/fogdocker/models/compute/images.rb +4 -0
  71. data/lib/fog/fogdocker/models/compute/server.rb +18 -1
  72. data/lib/fog/fogdocker/requests/compute/container_action.rb +53 -3
  73. data/lib/fog/fogdocker/requests/compute/container_get.rb +31 -12
  74. data/lib/fog/fogdocker/requests/compute/image_search.rb +29 -0
  75. data/lib/fog/google/dns.rb +46 -12
  76. data/lib/fog/google/examples/dns/project.rb +8 -0
  77. data/lib/fog/google/examples/dns/zones.rb +43 -0
  78. data/lib/fog/google/models/compute/images.rb +2 -1
  79. data/lib/fog/google/models/dns/change.rb +40 -0
  80. data/lib/fog/google/models/dns/changes.rb +52 -0
  81. data/lib/fog/google/models/dns/project.rb +75 -0
  82. data/lib/fog/google/models/dns/projects.rb +25 -0
  83. data/lib/fog/google/models/dns/record.rb +112 -0
  84. data/lib/fog/google/models/dns/records.rb +52 -0
  85. data/lib/fog/google/models/dns/zone.rb +74 -0
  86. data/lib/fog/google/models/dns/zones.rb +34 -0
  87. data/lib/fog/google/models/storage/file.rb +1 -1
  88. data/lib/fog/google/models/storage/files.rb +1 -5
  89. data/lib/fog/google/requests/dns/create_change.rb +64 -0
  90. data/lib/fog/google/requests/dns/create_managed_zone.rb +64 -31
  91. data/lib/fog/google/requests/dns/delete_managed_zone.rb +20 -24
  92. data/lib/fog/google/requests/dns/get_change.rb +42 -0
  93. data/lib/fog/google/requests/dns/get_managed_zone.rb +22 -16
  94. data/lib/fog/google/requests/dns/get_project.rb +42 -0
  95. data/lib/fog/google/requests/dns/list_changes.rb +41 -0
  96. data/lib/fog/google/requests/dns/list_managed_zones.rb +15 -10
  97. data/lib/fog/google/requests/dns/list_resource_record_sets.rb +50 -0
  98. data/lib/fog/google/storage.rb +0 -1
  99. data/lib/fog/hp/storage.rb +1 -1
  100. data/lib/fog/internet_archive/storage.rb +0 -1
  101. data/lib/fog/libvirt/models/compute/server.rb +17 -7
  102. data/lib/fog/opennebula/models/compute/flavor.rb +46 -8
  103. data/lib/fog/opennebula/models/compute/flavors.rb +7 -0
  104. data/lib/fog/opennebula/models/compute/interface.rb +1 -1
  105. data/lib/fog/opennebula/models/compute/network.rb +1 -0
  106. data/lib/fog/opennebula/models/compute/networks.rb +5 -1
  107. data/lib/fog/opennebula/requests/compute/list_networks.rb +34 -25
  108. data/lib/fog/opennebula/requests/compute/template_pool.rb +47 -5
  109. data/lib/fog/openstack/compute.rb +2 -2
  110. data/lib/fog/openstack/docs/storage.md +18 -0
  111. data/lib/fog/openstack/identity.rb +1 -1
  112. data/lib/fog/openstack/image.rb +1 -1
  113. data/lib/fog/openstack/metering.rb +1 -1
  114. data/lib/fog/openstack/models/compute/server.rb +1 -0
  115. data/lib/fog/openstack/models/storage/directory.rb +8 -2
  116. data/lib/fog/openstack/network.rb +1 -1
  117. data/lib/fog/openstack/orchestration.rb +1 -1
  118. data/lib/fog/openstack/requests/compute/create_security_group.rb +1 -1
  119. data/lib/fog/openstack/requests/storage/public_url.rb +28 -0
  120. data/lib/fog/openstack/requests/storage/put_container.rb +1 -0
  121. data/lib/fog/openstack/storage.rb +1 -0
  122. data/lib/fog/openstack/volume.rb +1 -1
  123. data/lib/fog/ovirt/compute.rb +1 -0
  124. data/lib/fog/ovirt/models/compute/server.rb +5 -0
  125. data/lib/fog/ovirt/requests/compute/update_volume.rb +39 -0
  126. data/lib/fog/rackspace.rb +1 -0
  127. data/lib/fog/rackspace/core.rb +1 -0
  128. data/lib/fog/rackspace/docs/networking.md +315 -0
  129. data/lib/fog/rackspace/mock_data.rb +1 -2
  130. data/lib/fog/rackspace/models/dns/zones.rb +2 -1
  131. data/lib/fog/rackspace/models/load_balancers/node.rb +7 -0
  132. data/lib/fog/rackspace/models/networking/network.rb +27 -0
  133. data/lib/fog/rackspace/models/networking/networks.rb +23 -0
  134. data/lib/fog/rackspace/models/networking/virtual_interface.rb +85 -0
  135. data/lib/fog/rackspace/models/networking/virtual_interfaces.rb +45 -0
  136. data/lib/fog/rackspace/models/queues/queue.rb +1 -1
  137. data/lib/fog/rackspace/networking.rb +192 -0
  138. data/lib/fog/rackspace/requests/load_balancers/create_node.rb +3 -0
  139. data/lib/fog/rackspace/requests/load_balancers/update_node.rb +3 -0
  140. data/lib/fog/rackspace/requests/networking/create_network.rb +36 -0
  141. data/lib/fog/rackspace/requests/networking/create_virtual_interface.rb +30 -0
  142. data/lib/fog/rackspace/requests/networking/delete_network.rb +21 -0
  143. data/lib/fog/rackspace/requests/networking/delete_virtual_interface.rb +23 -0
  144. data/lib/fog/rackspace/requests/networking/get_network.rb +21 -0
  145. data/lib/fog/rackspace/requests/networking/list_networks.rb +18 -0
  146. data/lib/fog/rackspace/requests/networking/list_virtual_interfaces.rb +22 -0
  147. data/lib/fog/vcloud/compute.rb +0 -1
  148. data/lib/fog/vcloud/core.rb +1 -0
  149. data/lib/fog/vcloud_director/compute.rb +1 -1
  150. data/lib/fog/version.rb +1 -1
  151. data/lib/fog/vsphere/compute.rb +38 -1
  152. data/lib/fog/vsphere/requests/compute/list_clusters.rb +31 -1
  153. data/lib/fog/vsphere/requests/compute/modify_vm_interface.rb +1 -1
  154. data/lib/fog/zerigo/dns.rb +0 -1
  155. data/lib/tasks/changelog_task.rb +1 -0
  156. data/tests/aws/models/elb/model_tests.rb +6 -0
  157. data/tests/aws/models/elb/tagging_tests.rb +15 -0
  158. data/tests/aws/models/iam/access_keys_tests.rb +1 -1
  159. data/tests/aws/models/iam/policies_tests.rb +2 -1
  160. data/tests/aws/models/iam/users_tests.rb +7 -4
  161. data/tests/aws/models/storage/url_tests.rb +5 -9
  162. data/tests/aws/requests/compute/tag_tests.rb +2 -0
  163. data/tests/aws/requests/elb/load_balancer_tests.rb +5 -1
  164. data/tests/aws/requests/storage/bucket_tests.rb +15 -1
  165. data/tests/aws/signaturev4_tests.rb +47 -0
  166. data/tests/bluebox/requests/compute/block_tests.rb +2 -1
  167. data/tests/compute/helper.rb +0 -10
  168. data/tests/compute/models/flavors_tests.rb +1 -1
  169. data/tests/fogdocker/compute_tests.rb +1 -1
  170. data/tests/fogdocker/models/compute/server_tests.rb +13 -3
  171. data/tests/fogdocker/requests/compute/container_action_tests.rb +19 -8
  172. data/tests/fogdocker/requests/compute/image_search_tests.rb +11 -0
  173. data/tests/google/models/dns/change_tests.rb +28 -0
  174. data/tests/google/models/dns/changes_tests.rb +36 -0
  175. data/tests/google/models/dns/projects_tests.rb +12 -0
  176. data/tests/google/models/dns/record_tests.rb +42 -0
  177. data/tests/google/models/dns/records_tests.rb +36 -0
  178. data/tests/google/models/dns/zone_tests.rb +28 -0
  179. data/tests/google/models/dns/zones_tests.rb +14 -0
  180. data/tests/google/requests/dns/change_tests.rb +86 -0
  181. data/tests/google/requests/dns/managed_zone_tests.rb +1 -1
  182. data/tests/google/requests/dns/project_tests.rb +29 -0
  183. data/tests/google/requests/dns/record_tests.rb +49 -0
  184. data/tests/helper.rb +1 -1
  185. data/tests/helpers/mock_helper.rb +2 -2
  186. data/tests/opennebula/models/compute/flavor_tests.rb +29 -0
  187. data/tests/opennebula/models/compute/flavors_tests.rb +17 -0
  188. data/tests/opennebula/models/compute/network_tests.rb +2 -2
  189. data/tests/opennebula/models/compute/networks_tests.rb +2 -0
  190. data/tests/openstack/requests/storage/object_tests.rb +10 -0
  191. data/tests/ovirt/compute_tests.rb +1 -1
  192. data/tests/ovirt/requests/compute/update_volume_tests.rb +20 -0
  193. data/tests/rackspace/models/networking/network_tests.rb +10 -0
  194. data/tests/rackspace/models/networking/networks_tests.rb +10 -0
  195. data/tests/rackspace/models/networking/virtual_interface_tests.rb +33 -0
  196. data/tests/rackspace/models/networking/virtual_interfaces_tests.rb +24 -0
  197. data/tests/rackspace/models/queues/queue_tests.rb +9 -0
  198. data/tests/rackspace/networking_tests.rb +118 -0
  199. data/tests/rackspace/requests/networking/network_tests.rb +49 -0
  200. data/tests/rackspace/requests/networking/virtual_interface_tests.rb +49 -0
  201. data/tests/vsphere/requests/compute/list_clusters_tests.rb +11 -0
  202. metadata +228 -180
  203. data/lib/fog/bin/terremark.rb +0 -29
  204. data/lib/fog/bin/vmfusion.rb +0 -58
  205. data/lib/fog/bin/voxel.rb +0 -29
  206. data/lib/fog/terremark.rb +0 -11
  207. data/lib/fog/terremark/models/shared/address.rb +0 -25
  208. data/lib/fog/terremark/models/shared/addresses.rb +0 -45
  209. data/lib/fog/terremark/models/shared/image.rb +0 -19
  210. data/lib/fog/terremark/models/shared/images.rb +0 -41
  211. data/lib/fog/terremark/models/shared/internetservice.rb +0 -66
  212. data/lib/fog/terremark/models/shared/internetservices.rb +0 -39
  213. data/lib/fog/terremark/models/shared/network.rb +0 -31
  214. data/lib/fog/terremark/models/shared/networks.rb +0 -48
  215. data/lib/fog/terremark/models/shared/nodeservice.rb +0 -50
  216. data/lib/fog/terremark/models/shared/nodeservices.rb +0 -29
  217. data/lib/fog/terremark/models/shared/server.rb +0 -210
  218. data/lib/fog/terremark/models/shared/servers.rb +0 -50
  219. data/lib/fog/terremark/models/shared/task.rb +0 -46
  220. data/lib/fog/terremark/models/shared/tasks.rb +0 -54
  221. data/lib/fog/terremark/models/shared/vdc.rb +0 -40
  222. data/lib/fog/terremark/models/shared/vdcs.rb +0 -48
  223. data/lib/fog/terremark/parser.rb +0 -18
  224. data/lib/fog/terremark/parsers/shared/get_catalog.rb +0 -33
  225. data/lib/fog/terremark/parsers/shared/get_catalog_item.rb +0 -32
  226. data/lib/fog/terremark/parsers/shared/get_internet_services.rb +0 -57
  227. data/lib/fog/terremark/parsers/shared/get_keys_list.rb +0 -39
  228. data/lib/fog/terremark/parsers/shared/get_network_ips.rb +0 -24
  229. data/lib/fog/terremark/parsers/shared/get_node_services.rb +0 -32
  230. data/lib/fog/terremark/parsers/shared/get_organization.rb +0 -50
  231. data/lib/fog/terremark/parsers/shared/get_organizations.rb +0 -31
  232. data/lib/fog/terremark/parsers/shared/get_public_ips.rb +0 -26
  233. data/lib/fog/terremark/parsers/shared/get_tasks_list.rb +0 -35
  234. data/lib/fog/terremark/parsers/shared/get_vapp_template.rb +0 -31
  235. data/lib/fog/terremark/parsers/shared/get_vdc.rb +0 -87
  236. data/lib/fog/terremark/parsers/shared/instantiate_vapp_template.rb +0 -26
  237. data/lib/fog/terremark/parsers/shared/internet_service.rb +0 -58
  238. data/lib/fog/terremark/parsers/shared/network.rb +0 -39
  239. data/lib/fog/terremark/parsers/shared/node_service.rb +0 -28
  240. data/lib/fog/terremark/parsers/shared/public_ip.rb +0 -22
  241. data/lib/fog/terremark/parsers/shared/task.rb +0 -25
  242. data/lib/fog/terremark/parsers/shared/vapp.rb +0 -61
  243. data/lib/fog/terremark/requests/shared/add_internet_service.rb +0 -54
  244. data/lib/fog/terremark/requests/shared/add_node_service.rb +0 -51
  245. data/lib/fog/terremark/requests/shared/configure_vapp.rb +0 -59
  246. data/lib/fog/terremark/requests/shared/create_internet_service.rb +0 -59
  247. data/lib/fog/terremark/requests/shared/delete_internet_service.rb +0 -21
  248. data/lib/fog/terremark/requests/shared/delete_node_service.rb +0 -21
  249. data/lib/fog/terremark/requests/shared/delete_public_ip.rb +0 -21
  250. data/lib/fog/terremark/requests/shared/delete_vapp.rb +0 -20
  251. data/lib/fog/terremark/requests/shared/deploy_vapp.rb +0 -33
  252. data/lib/fog/terremark/requests/shared/get_catalog.rb +0 -30
  253. data/lib/fog/terremark/requests/shared/get_catalog_item.rb +0 -33
  254. data/lib/fog/terremark/requests/shared/get_internet_services.rb +0 -34
  255. data/lib/fog/terremark/requests/shared/get_keys_list.rb +0 -34
  256. data/lib/fog/terremark/requests/shared/get_network.rb +0 -69
  257. data/lib/fog/terremark/requests/shared/get_network_ips.rb +0 -29
  258. data/lib/fog/terremark/requests/shared/get_node_services.rb +0 -29
  259. data/lib/fog/terremark/requests/shared/get_organization.rb +0 -82
  260. data/lib/fog/terremark/requests/shared/get_organizations.rb +0 -45
  261. data/lib/fog/terremark/requests/shared/get_public_ip.rb +0 -31
  262. data/lib/fog/terremark/requests/shared/get_public_ips.rb +0 -68
  263. data/lib/fog/terremark/requests/shared/get_task.rb +0 -37
  264. data/lib/fog/terremark/requests/shared/get_tasks_list.rb +0 -30
  265. data/lib/fog/terremark/requests/shared/get_vapp.rb +0 -40
  266. data/lib/fog/terremark/requests/shared/get_vapp_template.rb +0 -33
  267. data/lib/fog/terremark/requests/shared/get_vdc.rb +0 -121
  268. data/lib/fog/terremark/requests/shared/instantiate_vapp_template.rb +0 -79
  269. data/lib/fog/terremark/requests/shared/power_off.rb +0 -33
  270. data/lib/fog/terremark/requests/shared/power_on.rb +0 -33
  271. data/lib/fog/terremark/requests/shared/power_reset.rb +0 -33
  272. data/lib/fog/terremark/requests/shared/power_shutdown.rb +0 -22
  273. data/lib/fog/terremark/shared.rb +0 -304
  274. data/lib/fog/terremark/vcloud.rb +0 -129
  275. data/lib/fog/vmfusion.rb +0 -1
  276. data/lib/fog/vmfusion/compute.rb +0 -28
  277. data/lib/fog/vmfusion/core.rb +0 -9
  278. data/lib/fog/vmfusion/models/compute/server.rb +0 -256
  279. data/lib/fog/vmfusion/models/compute/servers.rb +0 -36
  280. data/lib/fog/voxel.rb +0 -1
  281. data/lib/fog/voxel/compute.rb +0 -122
  282. data/lib/fog/voxel/core.rb +0 -16
  283. data/lib/fog/voxel/models/compute/image.rb +0 -13
  284. data/lib/fog/voxel/models/compute/images.rb +0 -27
  285. data/lib/fog/voxel/models/compute/server.rb +0 -73
  286. data/lib/fog/voxel/models/compute/servers.rb +0 -29
  287. data/lib/fog/voxel/parsers/compute/basic.rb +0 -27
  288. data/lib/fog/voxel/parsers/compute/devices_list.rb +0 -107
  289. data/lib/fog/voxel/parsers/compute/images_list.rb +0 -55
  290. data/lib/fog/voxel/parsers/compute/voxcloud_create.rb +0 -36
  291. data/lib/fog/voxel/parsers/compute/voxcloud_delete.rb +0 -27
  292. data/lib/fog/voxel/parsers/compute/voxcloud_status.rb +0 -42
  293. data/lib/fog/voxel/requests/compute/devices_list.rb +0 -22
  294. data/lib/fog/voxel/requests/compute/devices_power.rb +0 -20
  295. data/lib/fog/voxel/requests/compute/images_list.rb +0 -29
  296. data/lib/fog/voxel/requests/compute/voxcloud_create.rb +0 -20
  297. data/lib/fog/voxel/requests/compute/voxcloud_delete.rb +0 -18
  298. data/lib/fog/voxel/requests/compute/voxcloud_status.rb +0 -22
  299. data/lib/fog/xml.rb +0 -4
  300. data/lib/fog/xml/connection.rb +0 -24
  301. data/lib/fog/xml/sax_parser_connection.rb +0 -45
  302. data/tests/core/connection_tests.rb +0 -26
  303. data/tests/voxel/requests/compute/image_tests.rb +0 -52
  304. data/tests/voxel/requests/compute/server_tests.rb +0 -123
@@ -28,6 +28,13 @@ module Fog
28
28
  nil
29
29
  end
30
30
 
31
+ def get_by_filter(flavor_filter)
32
+ data = service.template_pool(flavor_filter)
33
+ load(data)
34
+ rescue Fog::Compute::OpenNebula::NotFound
35
+ nil
36
+ end
37
+
31
38
  end
32
39
 
33
40
  end
@@ -16,7 +16,7 @@ module Fog
16
16
  end
17
17
 
18
18
  def vnetid
19
- return ""
19
+ return vnet
20
20
  end
21
21
 
22
22
  def persisted?
@@ -7,6 +7,7 @@ module Fog
7
7
 
8
8
  identity :id
9
9
  attribute :name
10
+ attribute :uname
10
11
  attribute :uid
11
12
  attribute :gid
12
13
  attribute :description
@@ -8,13 +8,17 @@ module Fog
8
8
  model Fog::Compute::OpenNebula::Network
9
9
 
10
10
  def all(filter={})
11
- load(service.list_networks(filter))
11
+ self.get_by_filter(filter)
12
12
  end
13
13
 
14
14
  def get(id)
15
15
  self.all({:id => id}).first
16
16
  end
17
17
 
18
+ def get_by_filter(filter)
19
+ load(service.list_networks(filter))
20
+ end
21
+
18
22
  end
19
23
  end
20
24
  end
@@ -6,36 +6,44 @@ module Fog
6
6
  class OpenNebula
7
7
  class Real
8
8
  def list_networks(filter = { })
9
-
10
9
  networks=[]
11
- netpool = ::OpenNebula::VirtualNetworkPool.new(client)
12
- if filter[:id].nil?
13
- netpool.info!(-2,-1,-1)
14
- elsif filter[:id]
15
- filter[:id] = filter[:id].to_i if filter[:id].is_a?(String)
16
- netpool.info!(-2, filter[:id], filter[:id])
17
- end # if filter[:id].nil?
18
-
10
+ netpool = ::OpenNebula::VirtualNetworkPool.new(client)
11
+ if filter[:id].nil?
12
+ netpool.info!(-2,-1,-1)
13
+ elsif filter[:id]
14
+ filter[:id] = filter[:id].to_i if filter[:id].is_a?(String)
15
+ netpool.info!(-2, filter[:id], filter[:id])
16
+ end # if filter[:id].nil?
17
+
19
18
  netpool.each do |network|
20
- networks << network_to_attributes(network.to_hash)
21
- end
19
+ if filter[:network] && filter[:network].is_a?(String) && !filter[:network].empty?
20
+ next if network.to_hash["VNET"]["NAME"] != filter[:network]
21
+ end
22
+ if filter[:network_uname] && filter[:network_uname].is_a?(String) && !filter[:network_uname].empty?
23
+ next if network.to_hash["VNET"]["UNAME"] != filter[:network_uname]
24
+ end
25
+ if filter[:network_uid] && filter[:network_uid].is_a?(String) && !filter[:network_uid].empty?
26
+ next if network.to_hash["VNET"]["UID"] != filter[:network_uid]
27
+ end
28
+ networks << network_to_attributes(network.to_hash)
29
+ end
22
30
  networks
23
31
  end
24
32
 
25
33
  def network_to_attributes(net)
26
34
  return if net.nil?
27
- #{"VNET"=>{"ID"=>"155", "UID"=>"0", "GID"=>"1", "UNAME"=>"oneadmin", "GNAME"=>"users", "NAME"=>"vlan99-2", "PERMISSIONS"=>{"OWNER_U"=>"1", "OWNER_M"=>"1", "OWNER_A"=>"0", "GROUP_U"=>"1", "GROUP_M"=>"0", "GROUP_A"=>"0", "OTHER_U"=>"0", "OTHER_M"=>"0", "OTHER_A"=>"0"}, "CLUSTER_ID"=>"-1", "CLUSTER"=>{}, "TYPE"=>"0", "BRIDGE"=>"ovsbr", "VLAN"=>"1", "PHYDEV"=>{}, "VLAN_ID"=>"99", "GLOBAL_PREFIX"=>{}, "SITE_PREFIX"=>{}, "RANGE"=>{"IP_START"=>"10.10.99.127", "IP_END"=>"10.10.99.249"}, "TOTAL_LEASES"=>"0", "TEMPLATE"=>{"DESCRIPTION"=>"test", "NETWORK_ADDRESS"=>"10.10.99.0", "NETWORK_MASK"=>"255.255.255.0"}}}
28
35
  h = {
29
- :id => net["VNET"]["ID"],
30
- :name => net["VNET"]["NAME"],
31
- :uid => net["VNET"]["UID"],
32
- :gid => net["VNET"]["GID"],
36
+ :id => net["VNET"]["ID"],
37
+ :name => net["VNET"]["NAME"],
38
+ :uid => net["VNET"]["UID"],
39
+ :uname => net["VNET"]["UNAME"],
40
+ :gid => net["VNET"]["GID"],
33
41
  }
34
42
 
35
- h[:description] = net["VNET"]["TEMPLATE"]["DESCRIPTION"] unless net["VNET"]["TEMPLATE"]["DESCRIPTION"].nil?
36
- h[:vlan] = net["VNET"]["VLAN_ID"] unless (net["VNET"]["VLAN_ID"].nil? || net["VNET"]["VLAN_ID"].empty?)
43
+ h[:description] = net["VNET"]["TEMPLATE"]["DESCRIPTION"] unless net["VNET"]["TEMPLATE"]["DESCRIPTION"].nil?
44
+ h[:vlan] = net["VNET"]["VLAN_ID"] unless (net["VNET"]["VLAN_ID"].nil? || net["VNET"]["VLAN_ID"].empty?)
37
45
 
38
- return h
46
+ return h
39
47
  end
40
48
 
41
49
  end
@@ -49,12 +57,13 @@ module Fog
49
57
 
50
58
  def mock_network name
51
59
  {
52
- :id => "5",
53
- :name => name,
54
- :uid => "5",
55
- :gid => "5",
56
- :description => "netDescription",
57
- :vlan => "5"
60
+ :id => "5",
61
+ :name => name,
62
+ :uid => "5",
63
+ :uname => "mock",
64
+ :gid => "5",
65
+ :description => "netDescription",
66
+ :vlan => "5"
58
67
  }
59
68
  end
60
69
  end
@@ -41,13 +41,20 @@ module Fog
41
41
  # filtering by name
42
42
  # done here, because OpenNebula:TemplatePool does not support something like .delete_if
43
43
  if filter[:name] && filter[:name].is_a?(String) && !filter[:name].empty?
44
- next if t.to_hash["VMTEMPLATE"]["NAME"] != filter[:name]
44
+ next if t.to_hash["VMTEMPLATE"]["NAME"] != filter[:name]
45
+ end
46
+ if filter[:uname] && filter[:uname].is_a?(String) && !filter[:uname].empty?
47
+ next if t.to_hash["VMTEMPLATE"]["UNAME"] != filter[:uname]
48
+ end
49
+ if filter[:uid] && filter[:uid].is_a?(String) && !filter[:uid].empty?
50
+ next if t.to_hash["VMTEMPLATE"]["UID"] != filter[:uid]
45
51
  end
46
52
 
47
53
  h = Hash[
48
54
  :id => t.to_hash["VMTEMPLATE"]["ID"],
49
55
  :name => t.to_hash["VMTEMPLATE"]["NAME"],
50
- :content => t.template_str
56
+ :content => t.template_str,
57
+ :USER_VARIABLES => "" # Default if not set in template
51
58
  ]
52
59
  h.merge! t.to_hash["VMTEMPLATE"]["TEMPLATE"]
53
60
 
@@ -62,8 +69,16 @@ module Fog
62
69
  end
63
70
  elsif nics.is_a? Hash
64
71
  nics["model"] = "virtio" if nics["model"].nil?
65
- nics["uuid"] = "0" if nics["uuid"].nil? # is it better is to remove this NIC?
66
- h["NIC"] << interfaces.new({ :vnet => networks.get(nics["uuid"]), :model => nics["model"]})
72
+ #nics["uuid"] = "0" if nics["uuid"].nil? # is it better is to remove this NIC?
73
+ n = networks.get_by_filter({
74
+ :id => nics["NETWORK_ID"],
75
+ :network => nics["NETWORK"],
76
+ :network_uname => nics["NETWORK_UNAME"],
77
+ :network_uid => nics["NETWORK_UID"]
78
+ })
79
+ n.each do |i|
80
+ h["NIC"] << interfaces.new({ :vnet => i })
81
+ end
67
82
  else
68
83
  # should i break?
69
84
  end
@@ -85,7 +100,34 @@ module Fog
85
100
 
86
101
  class Mock
87
102
  def template_pool(filter = { })
88
- [ {}, {} ]
103
+ [
104
+ {
105
+ :content => %Q{
106
+ NAME = mock-vm
107
+ MEMORY = 512
108
+ VCPU = 1
109
+ CPU = 1
110
+ },
111
+ :id => 1,
112
+ :name => 'mock',
113
+ :cpu => 1,
114
+ :vcpu => 1,
115
+ :memory => 512,
116
+ :sched_requirements => 'CPUSPEED > 1000',
117
+ :sched_rank => 'FREECPU',
118
+ :sched_ds_requirements => "NAME=mock",
119
+ :sched_ds_rank => "FREE_MB",
120
+ :disk => {},
121
+ :nic => {},
122
+ :os => {
123
+ 'ARCH' => 'x86_64'
124
+ },
125
+ :graphics => {},
126
+ :raw => {},
127
+ :context => {},
128
+ :user_variables => {}
129
+ }
130
+ ]
89
131
  end
90
132
  end #class Mock
91
133
  end #class OpenNebula
@@ -203,7 +203,7 @@ module Fog
203
203
  :servers => {},
204
204
  :key_pairs => {},
205
205
  :security_groups => {
206
- 0 => {
206
+ '0' => {
207
207
  "id" => 0,
208
208
  "tenant_id" => Fog::Mock.random_hex(8),
209
209
  "name" => "default",
@@ -380,7 +380,7 @@ module Fog
380
380
  options = {
381
381
  :openstack_api_key => @openstack_api_key,
382
382
  :openstack_username => @openstack_username,
383
- :openstack_auth_token => @auth_token,
383
+ :openstack_auth_token => @openstack_must_reauthenticate ? nil : @auth_token,
384
384
  :openstack_auth_uri => @openstack_auth_uri,
385
385
  :openstack_region => @openstack_region,
386
386
  :openstack_tenant => @openstack_tenant,
@@ -268,6 +268,15 @@ directory.destroy
268
268
 
269
269
  **Note**: Directory must be empty before it can be deleted.
270
270
 
271
+
272
+ ## Directory URL
273
+
274
+ To get a directory's URL:
275
+
276
+ ```ruby
277
+ directory.public_url
278
+ ```
279
+
271
280
  ## List Files
272
281
 
273
282
  To list files in a directory:
@@ -384,6 +393,14 @@ File.open('germany.jpg', 'w') {|f| f.write(file_object.body) }
384
393
  **Note**: This method is more memory intensive as the entire object is loaded into memory before saving the file as in the example above.
385
394
 
386
395
 
396
+ ## File URL
397
+
398
+ To get a file's URL:
399
+
400
+ ```ruby
401
+ file.public_url
402
+ ```
403
+
387
404
  ## Metadata
388
405
 
389
406
  You can access metadata as an attribute on `Fog::Storage::Rackspace::File`.
@@ -439,3 +456,4 @@ file.destroy
439
456
  ## Support and Feedback
440
457
 
441
458
  Your feedback is appreciated! If you have specific issues with the **fog** SDK, you should file an [issue via Github](https://github.com/fog/fog/issues).
459
+
@@ -255,7 +255,7 @@ module Fog
255
255
  options = {
256
256
  :openstack_api_key => @openstack_api_key,
257
257
  :openstack_username => @openstack_username,
258
- :openstack_auth_token => @openstack_auth_token,
258
+ :openstack_auth_token => @openstack_must_reauthenticate ? nil : @openstack_auth_token,
259
259
  :openstack_auth_uri => @openstack_auth_uri,
260
260
  :openstack_tenant => @openstack_tenant,
261
261
  :openstack_service_type => @openstack_service_type,
@@ -179,7 +179,7 @@ module Fog
179
179
  :openstack_username => @openstack_username,
180
180
  :openstack_auth_uri => @openstack_auth_uri,
181
181
  :openstack_region => @openstack_region,
182
- :openstack_auth_token => @openstack_auth_token,
182
+ :openstack_auth_token => @openstack_must_reauthenticate ? nil : @openstack_auth_token,
183
183
  :openstack_service_type => @openstack_service_type,
184
184
  :openstack_service_name => @openstack_service_name,
185
185
  :openstack_endpoint_type => @openstack_endpoint_type
@@ -172,7 +172,7 @@ module Fog
172
172
  :openstack_api_key => @openstack_api_key,
173
173
  :openstack_username => @openstack_username,
174
174
  :openstack_auth_uri => @openstack_auth_uri,
175
- :openstack_auth_token => @openstack_auth_token,
175
+ :openstack_auth_token => @openstack_must_reauthenticate ? nil : @openstack_auth_token,
176
176
  :openstack_service_type => @openstack_service_type,
177
177
  :openstack_service_name => @openstack_service_name,
178
178
  :openstack_endpoint_type => @openstack_endpoint_type
@@ -131,6 +131,7 @@ module Fog
131
131
  1
132
132
  else 0 end
133
133
  }
134
+ all_floating.empty? ? manual : all_floating
134
135
  end
135
136
 
136
137
  alias_method :public_ip_addresses, :floating_ip_addresses
@@ -9,7 +9,7 @@ module Fog
9
9
 
10
10
  attribute :bytes, :aliases => 'X-Container-Bytes-Used'
11
11
  attribute :count, :aliases => 'X-Container-Object-Count'
12
-
12
+
13
13
  attr_writer :public
14
14
 
15
15
  def destroy
@@ -30,7 +30,13 @@ module Fog
30
30
  end
31
31
 
32
32
  def public_url
33
- raise NotImplementedError
33
+ requires :key
34
+
35
+ @public_url ||= begin
36
+ service.public_url(key)
37
+ rescue Fog::Storage::OpenStack::NotFound => err
38
+ nil
39
+ end
34
40
  end
35
41
 
36
42
  def save
@@ -314,7 +314,7 @@ module Fog
314
314
  :openstack_api_key => @openstack_api_key,
315
315
  :openstack_username => @openstack_username,
316
316
  :openstack_auth_uri => @openstack_auth_uri,
317
- :openstack_auth_token => @openstack_auth_token,
317
+ :openstack_auth_token => @openstack_must_reauthenticate ? nil : @openstack_auth_token,
318
318
  :openstack_service_type => @openstack_service_type,
319
319
  :openstack_service_name => @openstack_service_name,
320
320
  :openstack_endpoint_type => @openstack_endpoint_type,
@@ -176,7 +176,7 @@ module Fog
176
176
  options = {
177
177
  :openstack_api_key => @openstack_api_key,
178
178
  :openstack_username => @openstack_username,
179
- :openstack_auth_token => @auth_token,
179
+ :openstack_auth_token => @openstack_must_reauthenticate ? nil : @auth_token,
180
180
  :openstack_auth_uri => @openstack_auth_uri,
181
181
  :openstack_region => @openstack_region,
182
182
  :openstack_tenant => @openstack_tenant,
@@ -23,7 +23,7 @@ module Fog
23
23
  def create_security_group(name, description)
24
24
  Fog::Identity::OpenStack.new(:openstack_auth_url => credentials[:openstack_auth_url])
25
25
  tenant_id = Fog::Identity::OpenStack::Mock.data[current_tenant][:tenants].keys.first
26
- security_group_id = Fog::Mock.random_numbers(2).to_i
26
+ security_group_id = Fog::Mock.random_numbers(2).to_i + 1
27
27
  self.data[:security_groups][security_group_id.to_s] = {
28
28
  'tenant_id' => tenant_id,
29
29
  'rules' => [],
@@ -0,0 +1,28 @@
1
+ module Fog
2
+ module Storage
3
+ class OpenStack
4
+ class Real
5
+
6
+ # Get public_url for an object
7
+ #
8
+ # ==== Parameters
9
+ # * container<~String> - Name of container to look in
10
+ # * object<~String> - Name of object to look for
11
+ #
12
+ def public_url(container=nil, object=nil)
13
+ return nil if container.nil?
14
+ u = "#{url}/#{Fog::OpenStack.escape(container)}"
15
+ u << "/#{Fog::OpenStack.escape(object)}" unless object.nil?
16
+ u
17
+ end
18
+
19
+ private
20
+
21
+ def url
22
+ "#{@scheme}://#{@host}:#{@port}#{@path}"
23
+ end
24
+
25
+ end
26
+ end
27
+ end
28
+ end
@@ -10,6 +10,7 @@ module Fog
10
10
  def put_container(name, options={})
11
11
  headers = options[:headers] || {}
12
12
  headers['X-Container-Read'] = '.r:*' if options[:public]
13
+ headers['X-Remove-Container-Read'] = 'x' if options[:public] == false
13
14
  request(
14
15
  :expects => [201, 202],
15
16
  :method => 'PUT',
@@ -36,6 +36,7 @@ module Fog
36
36
  request :put_dynamic_obj_manifest
37
37
  request :put_static_obj_manifest
38
38
  request :post_set_meta_temp_url_key
39
+ request :public_url
39
40
 
40
41
  class Mock
41
42
  def self.data
@@ -193,7 +193,7 @@ module Fog
193
193
  :openstack_api_key => @openstack_api_key,
194
194
  :openstack_username => @openstack_username,
195
195
  :openstack_auth_uri => @openstack_auth_uri,
196
- :openstack_auth_token => @openstack_auth_token,
196
+ :openstack_auth_token => @openstack_must_reauthenticate ? nil : @openstack_auth_token,
197
197
  :openstack_service_type => @openstack_service_type,
198
198
  :openstack_service_name => @openstack_service_name,
199
199
  :openstack_endpoint_type => @openstack_endpoint_type
@@ -46,6 +46,7 @@ module Fog
46
46
  request :list_template_volumes
47
47
  request :add_volume
48
48
  request :destroy_volume
49
+ request :update_volume
49
50
  request :get_api_version
50
51
  request :list_quotas
51
52
  request :get_quota
@@ -79,6 +79,11 @@ module Fog
79
79
  service.add_volume(id, attrs)
80
80
  end
81
81
 
82
+ def update_volume attrs
83
+ wait_for { stopped? } if attrs[:blocking]
84
+ service.update_volume(id, attrs)
85
+ end
86
+
82
87
  def destroy_volume attrs
83
88
  wait_for { stopped? } if attrs[:blocking]
84
89
  service.destroy_volume(id, attrs)
@@ -0,0 +1,39 @@
1
+ module Fog
2
+ module Compute
3
+ class Ovirt
4
+
5
+ module Shared
6
+ def check_arguments(id, options)
7
+ raise ArgumentError, "instance id is a required parameter" unless id
8
+ raise ArgumentError, "disk id is a required parameter for update-volume" unless options.has_key? :id
9
+ end
10
+ end
11
+
12
+
13
+ class Real
14
+ extend ::Fog::Compute::Ovirt::Shared
15
+
16
+ def update_volume(id, options)
17
+ check_arguments(id, options)
18
+
19
+ disk_id = options[:id]
20
+ options.delete(:id)
21
+
22
+ client.update_volume(id, disk_id, options)
23
+ true # If we come here, expect success and return true
24
+ end
25
+
26
+ end
27
+
28
+ class Mock
29
+ extend ::Fog::Compute::Ovirt::Shared
30
+
31
+ def update_volume(id, options)
32
+ check_arguments(id, options)
33
+ true
34
+ end
35
+ end
36
+
37
+ end
38
+ end
39
+ end