fog 1.17.0 → 1.18.0

Sign up to get free protection for your applications and to get access to all the features.
Files changed (386) hide show
  1. data/Rakefile +19 -1
  2. data/changelog.txt +408 -0
  3. data/fog.gemspec +3 -3
  4. data/fogkeytest1.pem +27 -0
  5. data/lib/fog/aws/compute.rb +0 -1
  6. data/lib/fog/aws/data_pipeline.rb +0 -1
  7. data/lib/fog/aws/models/auto_scaling/group.rb +1 -1
  8. data/lib/fog/aws/models/compute/route_table.rb +1 -1
  9. data/lib/fog/aws/models/compute/server.rb +1 -1
  10. data/lib/fog/aws/parsers/compute/describe_internet_gateways.rb +1 -1
  11. data/lib/fog/aws/requests/compute/create_internet_gateway.rb +5 -4
  12. data/lib/fog/aws/requests/compute/create_tags.rb +2 -0
  13. data/lib/fog/aws/requests/compute/create_volume.rb +1 -1
  14. data/lib/fog/aws/requests/compute/delete_internet_gateway.rb +1 -1
  15. data/lib/fog/aws/requests/compute/describe_internet_gateways.rb +1 -1
  16. data/lib/fog/aws/requests/compute/run_instances.rb +1 -1
  17. data/lib/fog/bin/hp.rb +17 -0
  18. data/lib/fog/compute.rb +11 -0
  19. data/lib/fog/ecloud/compute.rb +8 -3
  20. data/lib/fog/ecloud/models/compute/admin_organization.rb +4 -4
  21. data/lib/fog/ecloud/models/compute/catalog_item.rb +1 -1
  22. data/lib/fog/ecloud/models/compute/compute_pool.rb +8 -8
  23. data/lib/fog/ecloud/models/compute/environment.rb +15 -15
  24. data/lib/fog/ecloud/models/compute/firewall_acl.rb +1 -1
  25. data/lib/fog/ecloud/models/compute/internet_service.rb +1 -1
  26. data/lib/fog/ecloud/models/compute/internet_services.rb +1 -1
  27. data/lib/fog/ecloud/models/compute/location.rb +1 -1
  28. data/lib/fog/ecloud/models/compute/monitor.rb +1 -1
  29. data/lib/fog/ecloud/models/compute/network.rb +1 -1
  30. data/lib/fog/ecloud/models/compute/node.rb +1 -1
  31. data/lib/fog/ecloud/models/compute/nodes.rb +1 -1
  32. data/lib/fog/ecloud/models/compute/organization.rb +10 -10
  33. data/lib/fog/ecloud/models/compute/row.rb +1 -1
  34. data/lib/fog/ecloud/models/compute/rows.rb +1 -1
  35. data/lib/fog/ecloud/models/compute/server.rb +9 -9
  36. data/lib/fog/ecloud/models/compute/templates.rb +3 -1
  37. data/lib/fog/ecloud/models/compute/user.rb +2 -2
  38. data/lib/fog/ecloud/models/compute/virtual_machine_assigned_ip.rb +1 -1
  39. data/lib/fog/ecloud/requests/compute/get_virtual_machine_assigned_ips.rb +1 -1
  40. data/lib/fog/google/models/compute/disk.rb +5 -5
  41. data/lib/fog/google/models/compute/disks.rb +9 -2
  42. data/lib/fog/hp.rb +108 -19
  43. data/lib/fog/hp/CHANGELOG.hp +33 -0
  44. data/lib/fog/hp/block_storage.rb +5 -3
  45. data/lib/fog/hp/block_storage_v2.rb +164 -0
  46. data/lib/fog/hp/cdn.rb +3 -2
  47. data/lib/fog/hp/compute.rb +5 -4
  48. data/lib/fog/hp/compute_v2.rb +312 -0
  49. data/lib/fog/hp/dns.rb +135 -0
  50. data/lib/fog/hp/lb.rb +170 -0
  51. data/lib/fog/hp/models/block_storage_v2/snapshot.rb +76 -0
  52. data/lib/fog/hp/models/block_storage_v2/snapshots.rb +43 -0
  53. data/lib/fog/hp/models/block_storage_v2/volume.rb +139 -0
  54. data/lib/fog/hp/models/block_storage_v2/volume_backup.rb +58 -0
  55. data/lib/fog/hp/models/block_storage_v2/volume_backups.rb +42 -0
  56. data/lib/fog/hp/models/block_storage_v2/volumes.rb +42 -0
  57. data/lib/fog/hp/models/compute/image.rb +1 -1
  58. data/lib/fog/hp/models/compute/server.rb +41 -20
  59. data/lib/fog/hp/models/compute_v2/address.rb +70 -0
  60. data/lib/fog/hp/models/compute_v2/addresses.rb +29 -0
  61. data/lib/fog/hp/models/compute_v2/availability_zone.rb +22 -0
  62. data/lib/fog/hp/models/compute_v2/availability_zones.rb +29 -0
  63. data/lib/fog/hp/models/compute_v2/flavor.rb +22 -0
  64. data/lib/fog/hp/models/compute_v2/flavors.rb +42 -0
  65. data/lib/fog/hp/models/compute_v2/image.rb +87 -0
  66. data/lib/fog/hp/models/compute_v2/images.rb +43 -0
  67. data/lib/fog/hp/models/compute_v2/key_pair.rb +54 -0
  68. data/lib/fog/hp/models/compute_v2/key_pairs.rb +31 -0
  69. data/lib/fog/hp/models/compute_v2/meta.rb +29 -0
  70. data/lib/fog/hp/models/compute_v2/meta_parent.rb +33 -0
  71. data/lib/fog/hp/models/compute_v2/metadata.rb +79 -0
  72. data/lib/fog/hp/models/compute_v2/server.rb +339 -0
  73. data/lib/fog/hp/models/compute_v2/servers.rb +56 -0
  74. data/lib/fog/hp/models/compute_v2/volume_attachment.rb +42 -0
  75. data/lib/fog/hp/models/compute_v2/volume_attachments.rb +30 -0
  76. data/lib/fog/hp/models/dns/domain.rb +55 -0
  77. data/lib/fog/hp/models/dns/domains.rb +28 -0
  78. data/lib/fog/hp/models/dns/record.rb +59 -0
  79. data/lib/fog/hp/models/dns/records.rb +32 -0
  80. data/lib/fog/hp/models/lb/algorithm.rb +24 -0
  81. data/lib/fog/hp/models/lb/algorithms.rb +26 -0
  82. data/lib/fog/hp/models/lb/load_balancer.rb +83 -0
  83. data/lib/fog/hp/models/lb/load_balancers.rb +26 -0
  84. data/lib/fog/hp/models/lb/node.rb +53 -0
  85. data/lib/fog/hp/models/lb/nodes.rb +30 -0
  86. data/lib/fog/hp/models/lb/protocol.rb +25 -0
  87. data/lib/fog/hp/models/lb/protocols.rb +26 -0
  88. data/lib/fog/hp/models/lb/virtual_ip.rb +34 -0
  89. data/lib/fog/hp/models/lb/virtual_ips.rb +33 -0
  90. data/lib/fog/hp/models/network/floating_ip.rb +45 -0
  91. data/lib/fog/hp/models/network/floating_ips.rb +36 -0
  92. data/lib/fog/hp/models/network/network.rb +56 -0
  93. data/lib/fog/hp/models/network/networks.rb +36 -0
  94. data/lib/fog/hp/models/network/port.rb +54 -0
  95. data/lib/fog/hp/models/network/ports.rb +36 -0
  96. data/lib/fog/hp/models/network/router.rb +66 -0
  97. data/lib/fog/hp/models/network/routers.rb +36 -0
  98. data/lib/fog/hp/models/network/security_group.rb +30 -0
  99. data/lib/fog/hp/models/network/security_group_rule.rb +35 -0
  100. data/lib/fog/hp/models/network/security_group_rules.rb +36 -0
  101. data/lib/fog/hp/models/network/security_groups.rb +36 -0
  102. data/lib/fog/hp/models/network/subnet.rb +49 -0
  103. data/lib/fog/hp/models/network/subnets.rb +36 -0
  104. data/lib/fog/hp/models/storage/directories.rb +1 -1
  105. data/lib/fog/hp/models/storage/directory.rb +41 -8
  106. data/lib/fog/hp/models/storage/meta.rb +29 -0
  107. data/lib/fog/hp/models/storage/meta_parent.rb +23 -0
  108. data/lib/fog/hp/models/storage/metadata.rb +82 -0
  109. data/lib/fog/hp/network.rb +198 -0
  110. data/lib/fog/hp/requests/block_storage_v2/create_snapshot.rb +76 -0
  111. data/lib/fog/hp/requests/block_storage_v2/create_volume.rb +90 -0
  112. data/lib/fog/hp/requests/block_storage_v2/create_volume_backup.rb +83 -0
  113. data/lib/fog/hp/requests/block_storage_v2/delete_snapshot.rb +38 -0
  114. data/lib/fog/hp/requests/block_storage_v2/delete_volume.rb +38 -0
  115. data/lib/fog/hp/requests/block_storage_v2/delete_volume_backup.rb +38 -0
  116. data/lib/fog/hp/requests/block_storage_v2/get_snapshot_details.rb +54 -0
  117. data/lib/fog/hp/requests/block_storage_v2/get_volume_backup_details.rb +55 -0
  118. data/lib/fog/hp/requests/block_storage_v2/get_volume_details.rb +58 -0
  119. data/lib/fog/hp/requests/block_storage_v2/list_snapshots.rb +57 -0
  120. data/lib/fog/hp/requests/block_storage_v2/list_snapshots_detail.rb +54 -0
  121. data/lib/fog/hp/requests/block_storage_v2/list_volume_backups.rb +52 -0
  122. data/lib/fog/hp/requests/block_storage_v2/list_volume_backups_detail.rb +58 -0
  123. data/lib/fog/hp/requests/block_storage_v2/list_volumes.rb +61 -0
  124. data/lib/fog/hp/requests/block_storage_v2/list_volumes_detail.rb +59 -0
  125. data/lib/fog/hp/requests/block_storage_v2/restore_volume_backup.rb +97 -0
  126. data/lib/fog/hp/requests/block_storage_v2/update_snapshot.rb +69 -0
  127. data/lib/fog/hp/requests/block_storage_v2/update_volume.rb +70 -0
  128. data/lib/fog/hp/requests/compute/get_console_output.rb +0 -2
  129. data/lib/fog/hp/requests/compute/get_vnc_console.rb +45 -0
  130. data/lib/fog/hp/requests/compute_v2/add_security_group.rb +40 -0
  131. data/lib/fog/hp/requests/compute_v2/allocate_address.rb +53 -0
  132. data/lib/fog/hp/requests/compute_v2/associate_address.rb +46 -0
  133. data/lib/fog/hp/requests/compute_v2/attach_volume.rb +80 -0
  134. data/lib/fog/hp/requests/compute_v2/create_image.rb +63 -0
  135. data/lib/fog/hp/requests/compute_v2/create_key_pair.rb +73 -0
  136. data/lib/fog/hp/requests/compute_v2/create_persistent_server.rb +183 -0
  137. data/lib/fog/hp/requests/compute_v2/create_server.rb +168 -0
  138. data/lib/fog/hp/requests/compute_v2/delete_image.rb +44 -0
  139. data/lib/fog/hp/requests/compute_v2/delete_key_pair.rb +38 -0
  140. data/lib/fog/hp/requests/compute_v2/delete_meta.rb +55 -0
  141. data/lib/fog/hp/requests/compute_v2/delete_server.rb +43 -0
  142. data/lib/fog/hp/requests/compute_v2/detach_volume.rb +47 -0
  143. data/lib/fog/hp/requests/compute_v2/disassociate_address.rb +39 -0
  144. data/lib/fog/hp/requests/compute_v2/get_address.rb +48 -0
  145. data/lib/fog/hp/requests/compute_v2/get_console_output.rb +41 -0
  146. data/lib/fog/hp/requests/compute_v2/get_flavor_details.rb +57 -0
  147. data/lib/fog/hp/requests/compute_v2/get_image_details.rb +55 -0
  148. data/lib/fog/hp/requests/compute_v2/get_key_pair.rb +44 -0
  149. data/lib/fog/hp/requests/compute_v2/get_meta.rb +57 -0
  150. data/lib/fog/hp/requests/compute_v2/get_server_details.rb +72 -0
  151. data/lib/fog/hp/requests/compute_v2/get_server_volume_details.rb +47 -0
  152. data/lib/fog/hp/requests/compute_v2/get_vnc_console.rb +45 -0
  153. data/lib/fog/hp/requests/compute_v2/get_windows_password.rb +43 -0
  154. data/lib/fog/hp/requests/compute_v2/list_addresses.rb +44 -0
  155. data/lib/fog/hp/requests/compute_v2/list_availability_zones.rb +47 -0
  156. data/lib/fog/hp/requests/compute_v2/list_flavors.rb +53 -0
  157. data/lib/fog/hp/requests/compute_v2/list_flavors_detail.rb +53 -0
  158. data/lib/fog/hp/requests/compute_v2/list_images.rb +52 -0
  159. data/lib/fog/hp/requests/compute_v2/list_images_detail.rb +66 -0
  160. data/lib/fog/hp/requests/compute_v2/list_key_pairs.rb +42 -0
  161. data/lib/fog/hp/requests/compute_v2/list_limits.rb +62 -0
  162. data/lib/fog/hp/requests/compute_v2/list_metadata.rb +56 -0
  163. data/lib/fog/hp/requests/compute_v2/list_server_addresses.rb +42 -0
  164. data/lib/fog/hp/requests/compute_v2/list_server_addresses_by_network.rb +46 -0
  165. data/lib/fog/hp/requests/compute_v2/list_server_volumes.rb +49 -0
  166. data/lib/fog/hp/requests/compute_v2/list_servers.rb +53 -0
  167. data/lib/fog/hp/requests/compute_v2/list_servers_detail.rb +80 -0
  168. data/lib/fog/hp/requests/compute_v2/reboot_server.rb +34 -0
  169. data/lib/fog/hp/requests/compute_v2/rebuild_server.rb +82 -0
  170. data/lib/fog/hp/requests/compute_v2/release_address.rb +38 -0
  171. data/lib/fog/hp/requests/compute_v2/remove_security_group.rb +37 -0
  172. data/lib/fog/hp/requests/compute_v2/server_action.rb +25 -0
  173. data/lib/fog/hp/requests/compute_v2/set_metadata.rb +60 -0
  174. data/lib/fog/hp/requests/compute_v2/update_meta.rb +61 -0
  175. data/lib/fog/hp/requests/compute_v2/update_metadata.rb +60 -0
  176. data/lib/fog/hp/requests/compute_v2/update_server.rb +73 -0
  177. data/lib/fog/hp/requests/dns/create_domain.rb +66 -0
  178. data/lib/fog/hp/requests/dns/create_record.rb +79 -0
  179. data/lib/fog/hp/requests/dns/delete_domain.rb +37 -0
  180. data/lib/fog/hp/requests/dns/delete_record.rb +36 -0
  181. data/lib/fog/hp/requests/dns/get_domain.rb +43 -0
  182. data/lib/fog/hp/requests/dns/get_record.rb +47 -0
  183. data/lib/fog/hp/requests/dns/get_servers_hosting_domain.rb +62 -0
  184. data/lib/fog/hp/requests/dns/list_domains.rb +38 -0
  185. data/lib/fog/hp/requests/dns/list_records_in_a_domain.rb +55 -0
  186. data/lib/fog/hp/requests/dns/update_domain.rb +62 -0
  187. data/lib/fog/hp/requests/dns/update_record.rb +70 -0
  188. data/lib/fog/hp/requests/lb/create_load_balancer.rb +110 -0
  189. data/lib/fog/hp/requests/lb/create_load_balancer_node.rb +72 -0
  190. data/lib/fog/hp/requests/lb/delete_load_balancer.rb +36 -0
  191. data/lib/fog/hp/requests/lb/delete_load_balancer_node.rb +47 -0
  192. data/lib/fog/hp/requests/lb/get_load_balancer.rb +60 -0
  193. data/lib/fog/hp/requests/lb/get_load_balancer_node.rb +54 -0
  194. data/lib/fog/hp/requests/lb/list_algorithms.rb +32 -0
  195. data/lib/fog/hp/requests/lb/list_limits.rb +40 -0
  196. data/lib/fog/hp/requests/lb/list_load_balancer_nodes.rb +41 -0
  197. data/lib/fog/hp/requests/lb/list_load_balancer_virtual_ips.rb +44 -0
  198. data/lib/fog/hp/requests/lb/list_load_balancers.rb +41 -0
  199. data/lib/fog/hp/requests/lb/list_protocols.rb +34 -0
  200. data/lib/fog/hp/requests/lb/list_versions.rb +27 -0
  201. data/lib/fog/hp/requests/lb/update_load_balancer.rb +47 -0
  202. data/lib/fog/hp/requests/lb/update_load_balancer_node.rb +59 -0
  203. data/lib/fog/hp/requests/network/add_router_interface.rb +75 -0
  204. data/lib/fog/hp/requests/network/associate_floating_ip.rb +71 -0
  205. data/lib/fog/hp/requests/network/create_floating_ip.rb +69 -0
  206. data/lib/fog/hp/requests/network/create_network.rb +68 -0
  207. data/lib/fog/hp/requests/network/create_port.rb +92 -0
  208. data/lib/fog/hp/requests/network/create_router.rb +64 -0
  209. data/lib/fog/hp/requests/network/create_security_group.rb +100 -0
  210. data/lib/fog/hp/requests/network/create_security_group_rule.rb +83 -0
  211. data/lib/fog/hp/requests/network/create_subnet.rb +97 -0
  212. data/lib/fog/hp/requests/network/delete_floating_ip.rb +34 -0
  213. data/lib/fog/hp/requests/network/delete_network.rb +34 -0
  214. data/lib/fog/hp/requests/network/delete_port.rb +34 -0
  215. data/lib/fog/hp/requests/network/delete_router.rb +34 -0
  216. data/lib/fog/hp/requests/network/delete_security_group.rb +36 -0
  217. data/lib/fog/hp/requests/network/delete_security_group_rule.rb +36 -0
  218. data/lib/fog/hp/requests/network/delete_subnet.rb +34 -0
  219. data/lib/fog/hp/requests/network/disassociate_floating_ip.rb +71 -0
  220. data/lib/fog/hp/requests/network/get_floating_ip.rb +47 -0
  221. data/lib/fog/hp/requests/network/get_network.rb +49 -0
  222. data/lib/fog/hp/requests/network/get_port.rb +53 -0
  223. data/lib/fog/hp/requests/network/get_router.rb +46 -0
  224. data/lib/fog/hp/requests/network/get_security_group.rb +56 -0
  225. data/lib/fog/hp/requests/network/get_security_group_rule.rb +51 -0
  226. data/lib/fog/hp/requests/network/get_subnet.rb +52 -0
  227. data/lib/fog/hp/requests/network/list_floating_ips.rb +46 -0
  228. data/lib/fog/hp/requests/network/list_networks.rb +48 -0
  229. data/lib/fog/hp/requests/network/list_ports.rb +52 -0
  230. data/lib/fog/hp/requests/network/list_routers.rb +45 -0
  231. data/lib/fog/hp/requests/network/list_security_group_rules.rb +52 -0
  232. data/lib/fog/hp/requests/network/list_security_groups.rb +57 -0
  233. data/lib/fog/hp/requests/network/list_subnets.rb +51 -0
  234. data/lib/fog/hp/requests/network/remove_router_interface.rb +67 -0
  235. data/lib/fog/hp/requests/network/update_network.rb +62 -0
  236. data/lib/fog/hp/requests/network/update_port.rb +75 -0
  237. data/lib/fog/hp/requests/network/update_router.rb +62 -0
  238. data/lib/fog/hp/requests/network/update_subnet.rb +72 -0
  239. data/lib/fog/hp/requests/storage/post_container.rb +38 -0
  240. data/lib/fog/hp/requests/storage/post_object.rb +56 -0
  241. data/lib/fog/hp/simple_http_instrumentor.rb +59 -0
  242. data/lib/fog/hp/storage.rb +6 -6
  243. data/lib/fog/internet_archive/models/storage/file.rb +1 -1
  244. data/lib/fog/internet_archive/requests/storage/head_object.rb +2 -2
  245. data/lib/fog/openstack/identity.rb +1 -1
  246. data/lib/fog/openstack/models/storage/file.rb +1 -1
  247. data/lib/fog/rackspace.rb +4 -1
  248. data/lib/fog/rackspace/docs/compute_v2.md +2 -2
  249. data/lib/fog/rackspace/docs/storage.md +1 -1
  250. data/lib/fog/rackspace/examples/compute_v2/create_image.rb +1 -1
  251. data/lib/fog/rackspace/examples/compute_v2/delete_image.rb +1 -1
  252. data/lib/fog/rackspace/examples/compute_v2/delete_server.rb +1 -1
  253. data/lib/fog/rackspace/examples/compute_v2/detach_volume.rb +2 -2
  254. data/lib/fog/rackspace/examples/compute_v2/resize_server.rb +1 -1
  255. data/lib/fog/rackspace/examples/compute_v2/server_attachments.rb +1 -1
  256. data/lib/fog/rackspace/examples/storage/create_cdn_directory.rb +1 -1
  257. data/lib/fog/rackspace/examples/storage/delete_directory.rb +1 -1
  258. data/lib/fog/rackspace/examples/storage/delete_file.rb +1 -1
  259. data/lib/fog/rackspace/examples/storage/download_file.rb +1 -1
  260. data/lib/fog/rackspace/models/compute_v2/images.rb +1 -1
  261. data/lib/fog/rackspace/models/compute_v2/metadata.rb +2 -2
  262. data/lib/fog/rackspace/models/compute_v2/server.rb +2 -2
  263. data/lib/fog/rackspace/models/compute_v2/servers.rb +1 -1
  264. data/lib/fog/rackspace/models/storage/file.rb +19 -0
  265. data/lib/fog/rackspace/models/storage/files.rb +25 -0
  266. data/lib/fog/rackspace/monitoring.rb +20 -1
  267. data/lib/fog/rackspace/requests/compute_v2/delete_image.rb +1 -1
  268. data/lib/fog/rackspace/requests/compute_v2/list_metadata.rb +1 -1
  269. data/lib/fog/rackspace/requests/compute_v2/list_servers.rb +1 -1
  270. data/lib/fog/rackspace/requests/compute_v2/resize_server.rb +1 -1
  271. data/lib/fog/rackspace/requests/compute_v2/set_metadata.rb +1 -1
  272. data/lib/fog/rackspace/requests/compute_v2/set_metadata_item.rb +1 -1
  273. data/lib/fog/rackspace/requests/compute_v2/update_metadata.rb +1 -1
  274. data/lib/fog/rackspace/requests/monitoring/get_monitoring_zone.rb +15 -0
  275. data/lib/fog/rackspace/requests/monitoring/list_monitoring_zones.rb +15 -0
  276. data/lib/fog/rackspace/requests/storage/get_object_http_url.rb +30 -0
  277. data/lib/fog/rackspace/requests/storage/get_object_https_url.rb +2 -1
  278. data/lib/fog/rackspace/storage.rb +1 -0
  279. data/lib/fog/vcloud_director/generators/compute/edge_gateway_service_configuration.rb +10 -8
  280. data/lib/fog/vcloud_director/requests/compute/get_edge_gateway.rb +2 -0
  281. data/lib/fog/vcloud_director/requests/compute/get_task.rb +10 -1
  282. data/lib/fog/version.rb +1 -1
  283. data/lib/fog/vsphere/compute.rb +1 -0
  284. data/lib/fog/vsphere/models/compute/server.rb +2 -2
  285. data/lib/fog/vsphere/models/compute/volume.rb +59 -4
  286. data/lib/fog/vsphere/models/compute/volumes.rb +22 -7
  287. data/lib/fog/vsphere/requests/compute/create_vm.rb +9 -3
  288. data/lib/fog/vsphere/requests/compute/list_vm_volumes.rb +3 -1
  289. data/lib/fog/vsphere/requests/compute/modify_vm_volume.rb +26 -0
  290. data/lib/tasks/changelog_task.rb +2 -0
  291. data/tests/aws/requests/compute/internet_gateway_tests.rb +5 -0
  292. data/tests/compute/helper.rb +6 -4
  293. data/tests/ecloud/compute/models/server_tests.rb +34 -41
  294. data/tests/hp/block_storage_tests.rb +47 -0
  295. data/tests/hp/cdn_tests.rb +23 -0
  296. data/tests/hp/compute_tests.rb +22 -0
  297. data/tests/hp/models/block_storage_v2/snapshot_tests.rb +22 -0
  298. data/tests/hp/models/block_storage_v2/snapshots_tests.rb +10 -0
  299. data/tests/hp/models/block_storage_v2/volume_backup_tests.rb +22 -0
  300. data/tests/hp/models/block_storage_v2/volume_backups_tests.rb +9 -0
  301. data/tests/hp/models/block_storage_v2/volume_tests.rb +22 -0
  302. data/tests/hp/models/block_storage_v2/volumes_tests.rb +5 -0
  303. data/tests/hp/models/compute_v2/address_tests.rb +23 -0
  304. data/tests/hp/models/compute_v2/addresses_tests.rb +7 -0
  305. data/tests/hp/models/compute_v2/availability_zone_tests.rb +13 -0
  306. data/tests/hp/models/compute_v2/availability_zones_tests.rb +13 -0
  307. data/tests/hp/models/compute_v2/key_pair_tests.rb +29 -0
  308. data/tests/hp/models/compute_v2/key_pairs_tests.rb +7 -0
  309. data/tests/hp/models/compute_v2/metadata_image_tests.rb +60 -0
  310. data/tests/hp/models/compute_v2/metadata_server_tests.rb +56 -0
  311. data/tests/hp/models/compute_v2/server_tests.rb +45 -0
  312. data/tests/hp/models/compute_v2/servers_tests.rb +9 -0
  313. data/tests/hp/models/compute_v2/volume_attachment_tests.rb +40 -0
  314. data/tests/hp/models/compute_v2/volume_attachments_tests.rb +17 -0
  315. data/tests/hp/models/dns/domain_tests.rb +25 -0
  316. data/tests/hp/models/dns/domains_tests.rb +14 -0
  317. data/tests/hp/models/dns/record_tests.rb +29 -0
  318. data/tests/hp/models/dns/records_tests.rb +9 -0
  319. data/tests/hp/models/lb/algorithms_tests.rb +15 -0
  320. data/tests/hp/models/lb/load_balancer_node_tests.rb +9 -0
  321. data/tests/hp/models/lb/load_balancer_nodes_tests.rb +27 -0
  322. data/tests/hp/models/lb/load_balancer_tests.rb +6 -0
  323. data/tests/hp/models/lb/load_balancer_virtual_ips_tests.rb +22 -0
  324. data/tests/hp/models/lb/load_balancers_tests.rb +22 -0
  325. data/tests/hp/models/lb/protocols_tests.rb +15 -0
  326. data/tests/hp/models/network/floating_ip_tests.rb +37 -0
  327. data/tests/hp/models/network/floating_ips_tests.rb +8 -0
  328. data/tests/hp/models/network/network_tests.rb +25 -0
  329. data/tests/hp/models/network/networks_tests.rb +15 -0
  330. data/tests/hp/models/network/port_tests.rb +30 -0
  331. data/tests/hp/models/network/ports_tests.rb +21 -0
  332. data/tests/hp/models/network/router_tests.rb +55 -0
  333. data/tests/hp/models/network/routers_tests.rb +19 -0
  334. data/tests/hp/models/network/security_group_rule_tests.rb +25 -0
  335. data/tests/hp/models/network/security_group_rules_tests.rb +23 -0
  336. data/tests/hp/models/network/security_group_tests.rb +20 -0
  337. data/tests/hp/models/network/security_groups_tests.rb +20 -0
  338. data/tests/hp/models/network/subnet_tests.rb +30 -0
  339. data/tests/hp/models/network/subnets_tests.rb +22 -0
  340. data/tests/hp/models/storage/directory_tests.rb +70 -0
  341. data/tests/hp/requests/block_storage_v2/snapshot_tests.rb +69 -0
  342. data/tests/hp/requests/block_storage_v2/volume_backup_tests.rb +117 -0
  343. data/tests/hp/requests/block_storage_v2/volume_tests.rb +106 -0
  344. data/tests/hp/requests/compute_v2/address_tests.rb +80 -0
  345. data/tests/hp/requests/compute_v2/availability_zone_tests.rb +19 -0
  346. data/tests/hp/requests/compute_v2/flavor_tests.rb +45 -0
  347. data/tests/hp/requests/compute_v2/image_tests.rb +86 -0
  348. data/tests/hp/requests/compute_v2/key_pair_tests.rb +66 -0
  349. data/tests/hp/requests/compute_v2/metadata_tests.rb +101 -0
  350. data/tests/hp/requests/compute_v2/persistent_server_tests.rb +67 -0
  351. data/tests/hp/requests/compute_v2/server_address_tests.rb +46 -0
  352. data/tests/hp/requests/compute_v2/server_security_group_tests.rb +43 -0
  353. data/tests/hp/requests/compute_v2/server_tests.rb +113 -0
  354. data/tests/hp/requests/compute_v2/server_volume_tests.rb +85 -0
  355. data/tests/hp/requests/dns/domain_tests.rb +72 -0
  356. data/tests/hp/requests/dns/records_tests.rb +65 -0
  357. data/tests/hp/requests/lb/algorithms_tests.rb +15 -0
  358. data/tests/hp/requests/lb/limits_tests.rb +18 -0
  359. data/tests/hp/requests/lb/load_balancer_nodes_tests.rb +47 -0
  360. data/tests/hp/requests/lb/load_balancer_tests.rb +56 -0
  361. data/tests/hp/requests/lb/protocols_tests.rb +15 -0
  362. data/tests/hp/requests/lb/versions_tests.rb +17 -0
  363. data/tests/hp/requests/lb/virtual_ips_tests.rb +34 -0
  364. data/tests/hp/requests/network/floating_ip_tests.rb +70 -0
  365. data/tests/hp/requests/network/network_tests.rb +57 -0
  366. data/tests/hp/requests/network/port_tests.rb +71 -0
  367. data/tests/hp/requests/network/router_tests.rb +108 -0
  368. data/tests/hp/requests/network/security_group_rule_tests.rb +58 -0
  369. data/tests/hp/requests/network/security_group_tests.rb +48 -0
  370. data/tests/hp/requests/network/subnet_tests.rb +71 -0
  371. data/tests/hp/requests/storage/container_tests.rb +9 -1
  372. data/tests/hp/requests/storage/object_tests.rb +15 -1
  373. data/tests/hp/storage_tests.rb +25 -0
  374. data/tests/rackspace/cdn_tests.rb +1 -1
  375. data/tests/rackspace/models/compute_v2/metadata_tests.rb +1 -1
  376. data/tests/rackspace/models/identity/service_catalog_tests.rb +1 -1
  377. data/tests/rackspace/models/storage/file_tests.rb +19 -6
  378. data/tests/rackspace/models/storage/files_tests.rb +44 -0
  379. data/tests/rackspace/requests/monitoring/helper.rb +64 -0
  380. data/tests/rackspace/requests/monitoring/list_tests.rb +14 -2
  381. data/tests/rackspace/requests/storage/large_object_tests.rb +8 -6
  382. data/tests/rackspace/requests/storage/object_tests.rb +11 -0
  383. data/tests/rackspace/storage_tests.rb +4 -4
  384. data/tests/vcloud_director/requests/compute/edge_gateway_tests.rb +48 -44
  385. data/tests/vcloud_director/requests/compute/network_tests.rb +2 -0
  386. metadata +356 -5
@@ -26,7 +26,7 @@ module Fog
26
26
  end
27
27
 
28
28
  def create(options)
29
- options[:uri] = "/cloudapi/ecloud/internetServices/publicIps/#{public_ip_id}/action/createInternetService"
29
+ options[:uri] = "#{service.base_path}/internetServices/publicIps/#{public_ip_id}/action/createInternetService"
30
30
  options[:protocol] ||= "TCP"
31
31
  options[:enabled] ||= true
32
32
  options[:description] ||= ""
@@ -11,7 +11,7 @@ module Fog
11
11
  attribute :type, :aliases => :Type
12
12
 
13
13
  def catalog(org_href)
14
- @catalog ||= Fog::Compute::Ecloud::Catalog.new(:service => service, :href => "/cloudapi/ecloud/admin/catalog/organizations/#{org_href.scan(/\d+/)[0]}/locations/#{id}")
14
+ @catalog ||= Fog::Compute::Ecloud::Catalog.new(:service => service, :href => "#{service.base_path}/admin/catalog/organizations/#{org_href.scan(/\d+/)[0]}/locations/#{id}")
15
15
  end
16
16
 
17
17
  def id
@@ -18,7 +18,7 @@ module Fog
18
18
  attribute :receive_string, :aliases => :ReceiveString
19
19
 
20
20
  def edit(options = {})
21
- href = "/cloudapi/ecloud/internetServices/#{internet_service_id}/monitor?type="
21
+ href = "#{service.base_path}/internetServices/#{internet_service_id}/monitor?type="
22
22
  case type
23
23
  when "application/vnd.tmrk.cloud.pingMonitor"
24
24
  options[:uri] = href + "ping"
@@ -14,7 +14,7 @@ module Fog
14
14
  attribute :rnat_address, :aliases => :RnatAddress
15
15
 
16
16
  def rnats
17
- @rnats ||= Fog::Compute::Ecloud::Rnats.new(:service => service, :href => "cloudapi/ecloud/rnats/networks/#{id}")
17
+ @rnats ||= Fog::Compute::Ecloud::Rnats.new(:service => service, :href => "#{service.base_path}/rnats/networks/#{id}")
18
18
  end
19
19
 
20
20
  def ips
@@ -18,7 +18,7 @@ module Fog
18
18
  end
19
19
 
20
20
  def tasks
21
- @tasks ||= Fog::Compute::Ecloud::Tasks.new(:service => service, :href => "/cloudapi/ecloud/tasks/virtualMachines/#{id}")
21
+ @tasks ||= Fog::Compute::Ecloud::Tasks.new(:service => service, :href => "#{service.base_path}/tasks/virtualMachines/#{id}")
22
22
  end
23
23
 
24
24
  def delete
@@ -26,7 +26,7 @@ module Fog
26
26
  end
27
27
 
28
28
  def create(options)
29
- options[:uri] = "/cloudapi/ecloud/nodeServices/internetServices/#{internet_service_id}/action/createNodeService"
29
+ options[:uri] = "#{service.base_path}/nodeServices/internetServices/#{internet_service_id}/action/createNodeService"
30
30
  options[:protocol] ||= "TCP"
31
31
  options[:enabled] ||= true
32
32
  options[:description] ||= ""
@@ -20,51 +20,51 @@ module Fog
20
20
  end
21
21
 
22
22
  def tags
23
- @tags ||= self.service.tags(:href => "/cloudapi/ecloud/deviceTags/organizations/#{id}")
23
+ @tags ||= self.service.tags(:href => "#{service.base_path}/deviceTags/organizations/#{id}")
24
24
  end
25
25
 
26
26
  def admin
27
- @admin ||= self.service.admin_organizations.new(:href => "/cloudapi/ecloud/admin/organizations/#{id}")
27
+ @admin ||= self.service.admin_organizations.new(:href => "#{service.base_path}/admin/organizations/#{id}")
28
28
  end
29
29
 
30
30
  def users
31
- @users ||= self.service.users(:href => "/cloudapi/ecloud/admin/users/organizations/#{id}")
31
+ @users ||= self.service.users(:href => "#{service.base_path}/admin/users/organizations/#{id}")
32
32
  end
33
33
 
34
34
  def support_tickets(type = :open)
35
35
  case type
36
36
  when :open
37
- @support_tickets ||= Fog::Compute::Ecloud::SupportTickets.new(:service => service, :href => "/cloudapi/ecloud/admin/tickets/organizations/#{id}/active")
37
+ @support_tickets ||= Fog::Compute::Ecloud::SupportTickets.new(:service => service, :href => "#{service.base_path}/admin/tickets/organizations/#{id}/active")
38
38
  when :closed
39
- @support_tickets ||= Fog::Compute::Ecloud::SupportTickets.new(:service => service, :href => "/cloudapi/ecloud/admin/tickets/organizations/#{id}/closed")
39
+ @support_tickets ||= Fog::Compute::Ecloud::SupportTickets.new(:service => service, :href => "#{service.base_path}/admin/tickets/organizations/#{id}/closed")
40
40
  end
41
41
  end
42
42
 
43
43
  def edit_authentication_levels(options = {})
44
- options[:uri] = "/cloudapi/ecloud/admin/organizations/#{id}/authenticationLevels"
44
+ options[:uri] = "#{service.base_path}/admin/organizations/#{id}/authenticationLevels"
45
45
  data = service.admin_edit_authentication_levels(options).body
46
46
  level = Fog::Compute::Ecloud::AdminOrganizations.new(:service => service, :href => data[:href])[0]
47
47
  end
48
48
 
49
49
  def edit_password_complexity_rules(options = {})
50
- options[:uri] = "/cloudapi/ecloud/admin/organizations/#{id}/passwordComplexityRules"
50
+ options[:uri] = "#{service.base_path}/admin/organizations/#{id}/passwordComplexityRules"
51
51
  data = service.admin_edit_password_complexity_rules(options).body
52
52
  level = Fog::Compute::Ecloud::PasswordComplexityRules.new(:service => service, :href => data[:href])[0]
53
53
  end
54
54
 
55
55
  def edit_login_banner(options = {})
56
- options[:uri] = "/cloudapi/ecloud/admin/organizations/#{id}/loginBanner"
56
+ options[:uri] = "#{service.base_path}/admin/organizations/#{id}/loginBanner"
57
57
  data = service.admin_edit_login_banner(options).body
58
58
  banner = Fog::Compute::Ecloud::LoginBanners.new(:service => service, :href => data[:href])[0]
59
59
  end
60
60
 
61
61
  def enable_support_access(options = {})
62
- options[:uri] = "/cloudapi/ecloud/admin/organizations/#{id}/action/enableSupportAccess"
62
+ options[:uri] = "#{service.base_path}/admin/organizations/#{id}/action/enableSupportAccess"
63
63
  service.admin_enable_support_access(options[:uri])
64
64
  end
65
65
 
66
66
  def disable_support_access(options = {})
67
- options[:uri] = "/cloudapi/ecloud/admin/organizations/#{id}/action/disableSupportAccess"
67
+ options[:uri] = "#{service.base_path}/admin/organizations/#{id}/action/disableSupportAccess"
68
68
  service.admin_disable_support_access(options[:uri])
69
69
  end
70
70
 
@@ -33,7 +33,7 @@ module Fog
33
33
  end
34
34
 
35
35
  def create_group(options = {})
36
- options[:uri] = "/cloudapi/ecloud/layoutGroups/environments/#{environment_id}/action/createLayoutGroup"
36
+ options[:uri] = "#{service.base_path}/layoutGroups/environments/#{environment_id}/action/createLayoutGroup"
37
37
  options[:row_name] = name
38
38
  options[:href] = href
39
39
  data = service.groups_create(options).body
@@ -26,7 +26,7 @@ module Fog
26
26
  end
27
27
 
28
28
  def create(options = {})
29
- options[:uri] = "/cloudapi/ecloud/layoutRows/environments/#{environment_id}/action/createLayoutRow"
29
+ options[:uri] = "#{service.base_path}/layoutRows/environments/#{environment_id}/action/createLayoutRow"
30
30
  data = service.rows_create(options).body
31
31
  new(data)
32
32
  end
@@ -39,11 +39,11 @@ module Fog
39
39
  end
40
40
 
41
41
  def tasks
42
- @tasks ||= self.service.tasks(:href => "/cloudapi/ecloud/tasks/virtualMachines/#{id}")
42
+ @tasks ||= self.service.tasks(:href => "#{service.base_path}/tasks/virtualMachines/#{id}")
43
43
  end
44
44
 
45
45
  def processes
46
- @processes ||= Fog::Compute::Ecloud::GuestProcesses.new(:service, service, :href => "/cloudapi/ecloud/virtualMachines/#{id}/guest/processes")
46
+ @processes ||= Fog::Compute::Ecloud::GuestProcesses.new(:service, service, :href => "#{service.base_path}/virtualMachines/#{id}/guest/processes")
47
47
  end
48
48
 
49
49
  def hardware_configuration=(hardware_configuration)
@@ -51,12 +51,12 @@ module Fog
51
51
  end
52
52
 
53
53
  def hardware_configuration
54
- @hardware_configuration ||= self.service.hardware_configurations.new(:href => "/cloudapi/ecloud/virtualMachines/#{id}/hardwareConfiguration")
54
+ @hardware_configuration ||= self.service.hardware_configurations.new(:href => "#{service.base_path}/virtualMachines/#{id}/hardwareConfiguration")
55
55
  @hardware_configuration.reload
56
56
  end
57
57
 
58
58
  def configuration
59
- @configuration ||= Fog::Compute::Ecloud::ServerConfigurationOptions.new(:service => service, :href => "/cloudapi/ecloud/virtualMachines/#{id}/configurationOptions")[0]
59
+ @configuration ||= Fog::Compute::Ecloud::ServerConfigurationOptions.new(:service => service, :href => "#{service.base_path}/virtualMachines/#{id}/configurationOptions")[0]
60
60
  end
61
61
 
62
62
  def ips
@@ -64,7 +64,7 @@ module Fog
64
64
  end
65
65
 
66
66
  def networks
67
- @networks ||= self.service.networks(:href => "/cloudapi/ecloud/virtualMachines/#{id}/assignedIps")
67
+ @networks ||= self.service.networks(:href => "#{service.base_path}/virtualMachines/#{id}/assignedIps")
68
68
  end
69
69
 
70
70
  def power_on
@@ -108,16 +108,16 @@ module Fog
108
108
  options[:ips][index] = ip
109
109
  end
110
110
  end
111
- data = service.virtual_machine_copy("/cloudapi/ecloud/virtualMachines/computePools/#{compute_pool_id}/action/copyVirtualMachine", options).body
111
+ data = service.virtual_machine_copy("#{service.base_path}/virtualMachines/computePools/#{compute_pool_id}/action/copyVirtualMachine", options).body
112
112
  elsif options[:type] == :identical
113
- data = service.virtual_machine_copy_identical("/cloudapi/ecloud/virtualMachines/computePools/#{compute_pool_id}/action/copyIdenticalVirtualMachine", options).body
113
+ data = service.virtual_machine_copy_identical("#{service.base_path}/virtualMachines/computePools/#{compute_pool_id}/action/copyIdenticalVirtualMachine", options).body
114
114
  end
115
115
  vm = collection.from_data(data)
116
116
  vm
117
117
  end
118
118
 
119
119
  def rnats
120
- rnats = Fog::Compute::Ecloud::Rnats.new(:service => service, :href => "/cloudapi/ecloud/rnats/environments/#{environment_id}")
120
+ rnats = Fog::Compute::Ecloud::Rnats.new(:service => service, :href => "#{service.base_path}/rnats/environments/#{environment_id}")
121
121
  associations = nil
122
122
  rnats.each do |rnat|
123
123
  if rnats.index(rnat) == 0
@@ -148,7 +148,7 @@ module Fog
148
148
 
149
149
  def create_rnat(options)
150
150
  options[:host_ip_href] ||= ips.first.href
151
- options[:uri] = "/cloudapi/ecloud/rnats/environments/#{environment_id}/action/createAssociation"
151
+ options[:uri] = "#{service.base_path}/rnats/environments/#{environment_id}/action/createAssociation"
152
152
  data = service.rnat_associations_create_device(options).body
153
153
  rnat = Fog::Compute::Ecloud::Associations.new(:service => service, :href => data[:href])[0]
154
154
  end
@@ -14,7 +14,9 @@ module Fog
14
14
  data = service.get_templates(href).body[:Families]
15
15
  data[:Family].is_a?(Hash) ? data = [data[:Family]] : data = data[:Family]
16
16
  data.each do |d|
17
- d[:Categories][:Category].each do |cat|
17
+ cats = d[:Categories][:Category]
18
+ cats = [cats] if cats.is_a?(Hash)
19
+ cats.each do |cat|
18
20
  cat[:OperatingSystems][:OperatingSystem].is_a?(Hash) ? cat = [cat[:OperatingSystems][:OperatingSystem]] : cat = cat[:OperatingSystems][:OperatingSystem]
19
21
  cat.each do |os|
20
22
  os[:Templates][:Template].is_a?(Hash) ? os = [os[:Templates][:Template]] : os = os[:Templates][:Template]
@@ -19,11 +19,11 @@ module Fog
19
19
  attribute :is_multifactor_authentication_enabled, :aliases => :IsMultifactorAuthenticationEnabled, :type => :boolean
20
20
 
21
21
  def roles
22
- @roles = Fog::Compute::Ecloud::Roles.new(:service => service, :href => "/cloudapi/ecloud/admin/roles/users/#{id}")
22
+ @roles = Fog::Compute::Ecloud::Roles.new(:service => service, :href => "#{service.base_path}/admin/roles/users/#{id}")
23
23
  end
24
24
 
25
25
  def api_keys
26
- @api_keys = Fog::Compute::Ecloud::ApiKeys.new(:service => service, :href => "/cloudapi/ecloud/admin/apiKeys/users/#{id}")
26
+ @api_keys = Fog::Compute::Ecloud::ApiKeys.new(:service => service, :href => "#{service.base_path}/admin/apiKeys/users/#{id}")
27
27
  end
28
28
 
29
29
  def id
@@ -18,7 +18,7 @@ module Fog
18
18
  network_id = @network.href.match(/(\d+)$/)[1]
19
19
  address_ip = network_address[:IpAddresses][:IpAddress]
20
20
  @address = self.service.ip_addresses.new(
21
- :href => "/cloudapi/ecloud/ipaddresses/networks/#{network_id}/#{address_ip}",
21
+ :href => "#{service.base_path}/ipaddresses/networks/#{network_id}/#{address_ip}",
22
22
  :name => address_ip
23
23
  )
24
24
  end
@@ -5,7 +5,7 @@ module Fog
5
5
  class Real
6
6
  def get_virtual_machine_assigned_ips(virtual_machine_id)
7
7
  request(
8
- :uri => "/cloudapi/ecloud/virtualmachines/#{virtual_machine_id}/assignedips",
8
+ :uri => "#{base_path}/virtualmachines/#{virtual_machine_id}/assignedips",
9
9
  :parse => true
10
10
  )
11
11
  end
@@ -84,7 +84,7 @@ module Fog
84
84
  self
85
85
  end
86
86
 
87
- def create_snapshot(snap_name, snap_desc)
87
+ def create_snapshot(snapshot_name, snapshot_description="")
88
88
  requires :name
89
89
  requires :zone_name
90
90
 
@@ -93,18 +93,18 @@ module Fog
93
93
  end
94
94
 
95
95
  options = {
96
- 'name' => snap_name,
97
- 'description' => snap_desc,
96
+ 'name' => snapshot_name,
97
+ 'description' => snapshot_description,
98
98
  }
99
99
 
100
100
  service.insert_snapshot(name, self.zone, service.project, options)
101
101
  data = service.backoff_if_unfound {
102
- service.get_snapshot(snap_name, service.project).body
102
+ service.get_snapshot(snapshot_name, service.project).body
103
103
  }
104
104
  service.snapshots.merge_attributes(data)
105
105
 
106
106
  # Try to return the representation of the snapshot we created
107
- service.snapshots.get(snap_name)
107
+ service.snapshots.get(snapshot_name)
108
108
  end
109
109
 
110
110
  RUNNING_STATE = "READY"
@@ -9,8 +9,15 @@ module Fog
9
9
 
10
10
  model Fog::Compute::Google::Disk
11
11
 
12
- def all(zone)
13
- data = service.list_disks(zone).body["items"] || []
12
+ def all(filters={})
13
+ if filters['zone'].nil?
14
+ data = []
15
+ service.list_zones.body['items'].each do |zone|
16
+ data += service.list_disks(zone['name']).body["items"] || []
17
+ end
18
+ else
19
+ data = service.list_disks(filters['zone']).body["items"] || []
20
+ end
14
21
  load(data)
15
22
  end
16
23
 
@@ -1,11 +1,12 @@
1
1
  require 'fog/core'
2
+ require 'fog/hp/simple_http_instrumentor'
2
3
 
3
4
  module Fog
4
5
  module HP
5
6
 
6
7
  # define a specific version for the HP Provider
7
8
  unless const_defined?(:VERSION)
8
- VERSION = '0.0.20'
9
+ VERSION = '0.0.22'
9
10
  end
10
11
 
11
12
  extend Fog::Provider
@@ -55,10 +56,14 @@ module Fog
55
56
  end
56
57
  end
57
58
 
59
+ service(:block_storage, 'hp/block_storage', 'BlockStorage')
60
+ service(:block_storage_v2, 'hp/block_storage_v2', 'BlockStorageV2')
58
61
  service(:cdn, 'hp/cdn', 'CDN')
59
62
  service(:compute, 'hp/compute', 'Compute')
63
+ service(:dns, 'hp/dns', 'DNS')
64
+ service(:lb, 'hp/lb', 'LB')
65
+ service(:network, 'hp/network', 'Network')
60
66
  service(:storage, 'hp/storage', 'Storage')
61
- service(:block_storage, 'hp/block_storage', 'BlockStorage')
62
67
 
63
68
  # legacy swauth 1.0/1.1 style authentication
64
69
  def self.authenticate_v1(options, connection_options = {})
@@ -99,8 +104,43 @@ module Fog
99
104
  }
100
105
  end
101
106
 
107
+ def self.service_catalog(options, connection_options = {})
108
+ creds = authenticate_v2(options, connection_options)
109
+ return {} if creds.nil?
110
+ return {} if creds[:service_catalog].nil?
111
+ return creds[:service_catalog]
112
+ end
113
+
102
114
  # keystone based control services style authentication
103
115
  def self.authenticate_v2(options, connection_options = {})
116
+ unless options[:credentials].nil?
117
+ expires = true
118
+ begin
119
+ expire = DateTime.parse(options[:credentials][:expires])
120
+ expires = false if expire > DateTime.now
121
+ rescue
122
+ end
123
+ if expires
124
+ options = options.clone
125
+ options.delete(:credentials)
126
+ else
127
+ service_catalog = options[:credentials][:service_catalog]
128
+ type = options[:hp_service_type]
129
+ zone = options[:hp_avl_zone]
130
+ begin
131
+ creds = options[:credentials].clone
132
+ creds[:endpoint_url] = get_endpoint_url(service_catalog, type, zone)
133
+ begin
134
+ creds[:cdn_endpoint_url] = get_endpoint_url(service_catalog, "CDN", zone)
135
+ rescue
136
+ end
137
+ return creds
138
+ rescue
139
+ end
140
+ options = options.clone
141
+ options.delete(:credentials)
142
+ end
143
+ end
104
144
  hp_auth_uri = options[:hp_auth_uri] || "https://region-a.geo-1.identity.hpcloudsvc.com:35357/v2.0/tokens"
105
145
  # append /tokens if missing from auth uri
106
146
  @hp_auth_uri = hp_auth_uri.include?('tokens')? hp_auth_uri : hp_auth_uri + "tokens"
@@ -170,18 +210,22 @@ module Fog
170
210
 
171
211
  ### fish out auth_token and endpoint for the service
172
212
  auth_token = body['access']['token']['id']
173
- endpoint_url = get_endpoint_from_catalog(body['access']['serviceCatalog'], @hp_service_type, @hp_avl_zone)
174
- # If service is Storage, then get the CDN endpoint as well. 'Name' is unique instead of 'Type'
175
- if @hp_service_type == "Object Storage"
176
- cdn_endpoint_url = get_endpoint_from_catalog(body['access']['serviceCatalog'], "CDN", @hp_avl_zone)
213
+ expires = body['access']['token']['expires']
214
+ service_catalog = get_service_catalog(body['access']['serviceCatalog'])
215
+ endpoint_url = get_endpoint_url(service_catalog, @hp_service_type, @hp_avl_zone)
216
+ begin
217
+ cdn_endpoint_url = get_endpoint_url(service_catalog, "CDN", @hp_avl_zone)
218
+ rescue
177
219
  end
178
220
 
179
- return {
221
+ creds = {
180
222
  :auth_token => auth_token,
223
+ :expires => expires,
224
+ :service_catalog => service_catalog,
181
225
  :endpoint_url => endpoint_url,
182
226
  :cdn_endpoint_url => cdn_endpoint_url
183
227
  }
184
-
228
+ return creds
185
229
  end
186
230
 
187
231
  # CGI.escape, but without special treatment on spaces
@@ -191,22 +235,50 @@ module Fog
191
235
  end
192
236
  end
193
237
 
238
+ # converts any attributes hash from aliased keys to original attribute keys
239
+ def self.convert_aliased_attributes_to_original(model, attributes)
240
+ original_attributes = {}
241
+ attributes.each do |k, v|
242
+ if orig_key = model.aliases.invert[k]
243
+ original_attributes[orig_key] = v
244
+ else
245
+ original_attributes[k] = v
246
+ end
247
+ end
248
+ original_attributes
249
+ end
250
+
194
251
  private
195
252
 
196
- def self.get_endpoint_from_catalog(service_catalog, service_type, avl_zone)
197
- raise "Unable to parse service catalog." unless service_catalog
198
- service_item = service_catalog.detect do |s|
199
- # 'Name' is unique instead of 'Type'
200
- s["name"] == service_type
253
+ def self.get_service_catalog(body)
254
+ raise "Unable to parse service catalog." unless body
255
+ service_catalog = {}
256
+ body.each do |s|
257
+ name = s["name"]
258
+ next if name.nil?
259
+ name = name.to_sym
260
+ next if s['endpoints'].nil?
261
+ service_catalog[name] = {}
262
+ s['endpoints'].each do |ep|
263
+ next if ep['region'].nil?
264
+ next if ep['publicURL'].nil?
265
+ next if ep['publicURL'].empty?
266
+ service_catalog[name][ep['region'].to_sym] = ep['publicURL']
267
+ end
201
268
  end
202
- if service_item and service_item['endpoints']
203
- endpoint = service_item['endpoints'].detect do |ep|
204
- ep['region'] == avl_zone
269
+ return service_catalog
270
+ end
271
+
272
+ def self.get_endpoint_url(service_catalog, service_type, avl_zone)
273
+ return nil if service_type.nil?
274
+ service_type = service_type.to_sym
275
+ avl_zone = avl_zone.to_sym
276
+ unless service_catalog[service_type].nil?
277
+ unless service_catalog[service_type][avl_zone].nil?
278
+ return service_catalog[service_type][avl_zone]
205
279
  end
206
- endpoint_url = endpoint['publicURL'] if endpoint
207
- raise "Unable to retrieve endpoint service url for availability zone '#{avl_zone}' from service catalog. " if endpoint_url.nil?
208
- return endpoint_url
209
280
  end
281
+ raise "Unable to retrieve endpoint service url for availability zone '#{avl_zone}' from service catalog. "
210
282
  end
211
283
 
212
284
  def self.set_user_agent_header(conn_opts, base_str, client_str)
@@ -257,6 +329,23 @@ module Fog
257
329
  ip.join('.')
258
330
  end
259
331
 
332
+ def self.uuid
333
+ # pattern of 8-4-4-4-12 hexadecimal digits
334
+ uuid = []
335
+ [8,4,4,4,12].each do |x|
336
+ uuid << Fog::Mock.random_hex(x)
337
+ end
338
+ uuid.join('-')
339
+ end
340
+
341
+ def self.mac_address
342
+ mac_add = []
343
+ 6.times do
344
+ mac_add << Fog::Mock.random_hex(2)
345
+ end
346
+ mac_add.join(':')
347
+ end
348
+
260
349
  end
261
350
 
262
351
  end