aws_sdk 3.1.5

Sign up to get free protection for your applications and to get access to all the features.
Files changed (390) hide show
  1. data/lib/aws-sdk.rb +14 -0
  2. data/lib/aws.rb +49 -0
  3. data/lib/aws/api_config/AutoScaling-2011-01-01.yml +791 -0
  4. data/lib/aws/api_config/CloudFormation-2010-05-15.yml +303 -0
  5. data/lib/aws/api_config/DynamoDB-2011-12-05.yml +540 -0
  6. data/lib/aws/api_config/EC2-2011-12-15.yml +3638 -0
  7. data/lib/aws/api_config/EC2-2012-04-01.yml +3739 -0
  8. data/lib/aws/api_config/ELB-2011-08-15.yml +512 -0
  9. data/lib/aws/api_config/IAM-2010-05-08.yml +1221 -0
  10. data/lib/aws/api_config/SNS-2010-03-31.yml +248 -0
  11. data/lib/aws/api_config/SQS-2011-10-01.yml +314 -0
  12. data/lib/aws/api_config/STS-2011-06-15.yml +54 -0
  13. data/lib/aws/api_config/SimpleDB-2009-04-15.yml +305 -0
  14. data/lib/aws/api_config/SimpleEmailService-2010-12-01.yml +231 -0
  15. data/lib/aws/api_config/SimpleWorkflow-2012-01-25.yml +721 -0
  16. data/lib/aws/auto_scaling.rb +162 -0
  17. data/lib/aws/auto_scaling/activity.rb +102 -0
  18. data/lib/aws/auto_scaling/activity_collection.rb +82 -0
  19. data/lib/aws/auto_scaling/client.rb +765 -0
  20. data/lib/aws/auto_scaling/config.rb +18 -0
  21. data/lib/aws/auto_scaling/errors.rb +22 -0
  22. data/lib/aws/auto_scaling/group.rb +420 -0
  23. data/lib/aws/auto_scaling/group_collection.rb +96 -0
  24. data/lib/aws/auto_scaling/group_options.rb +146 -0
  25. data/lib/aws/auto_scaling/instance.rb +192 -0
  26. data/lib/aws/auto_scaling/instance_collection.rb +63 -0
  27. data/lib/aws/auto_scaling/launch_configuration.rb +150 -0
  28. data/lib/aws/auto_scaling/launch_configuration_collection.rb +144 -0
  29. data/lib/aws/auto_scaling/notification_configuration.rb +89 -0
  30. data/lib/aws/auto_scaling/notification_configuration_collection.rb +184 -0
  31. data/lib/aws/auto_scaling/request.rb +23 -0
  32. data/lib/aws/auto_scaling/scaling_policy.rb +125 -0
  33. data/lib/aws/auto_scaling/scaling_policy_collection.rb +72 -0
  34. data/lib/aws/auto_scaling/scaling_policy_options.rb +61 -0
  35. data/lib/aws/auto_scaling/scheduled_action.rb +145 -0
  36. data/lib/aws/auto_scaling/scheduled_action_collection.rb +195 -0
  37. data/lib/aws/auto_scaling/tag.rb +59 -0
  38. data/lib/aws/auto_scaling/tag_collection.rb +112 -0
  39. data/lib/aws/cloud_formation.rb +270 -0
  40. data/lib/aws/cloud_formation/client.rb +339 -0
  41. data/lib/aws/cloud_formation/config.rb +18 -0
  42. data/lib/aws/cloud_formation/errors.rb +22 -0
  43. data/lib/aws/cloud_formation/request.rb +29 -0
  44. data/lib/aws/cloud_formation/stack.rb +256 -0
  45. data/lib/aws/cloud_formation/stack_collection.rb +206 -0
  46. data/lib/aws/cloud_formation/stack_event.rb +75 -0
  47. data/lib/aws/cloud_formation/stack_event_collection.rb +47 -0
  48. data/lib/aws/cloud_formation/stack_options.rb +72 -0
  49. data/lib/aws/cloud_formation/stack_output.rb +53 -0
  50. data/lib/aws/cloud_formation/stack_resource.rb +117 -0
  51. data/lib/aws/cloud_formation/stack_resource_collection.rb +84 -0
  52. data/lib/aws/cloud_formation/stack_resource_summary_collection.rb +72 -0
  53. data/lib/aws/cloud_formation/stack_summary.rb +71 -0
  54. data/lib/aws/cloud_formation/stack_summary_collection.rb +127 -0
  55. data/lib/aws/core.rb +474 -0
  56. data/lib/aws/core/async_handle.rb +90 -0
  57. data/lib/aws/core/autoloader.rb +64 -0
  58. data/lib/aws/core/cacheable.rb +78 -0
  59. data/lib/aws/core/client.rb +541 -0
  60. data/lib/aws/core/client/query_json.rb +110 -0
  61. data/lib/aws/core/client/query_xml.rb +122 -0
  62. data/lib/aws/core/collection.rb +234 -0
  63. data/lib/aws/core/collection/limitable.rb +99 -0
  64. data/lib/aws/core/collection/simple.rb +90 -0
  65. data/lib/aws/core/configuration.rb +445 -0
  66. data/lib/aws/core/data.rb +242 -0
  67. data/lib/aws/core/default_signer.rb +67 -0
  68. data/lib/aws/core/http/curb_handler.rb +136 -0
  69. data/lib/aws/core/http/handler.rb +77 -0
  70. data/lib/aws/core/http/httparty_handler.rb +114 -0
  71. data/lib/aws/core/http/net_http_handler.rb +85 -0
  72. data/lib/aws/core/http/request.rb +250 -0
  73. data/lib/aws/core/http/response.rb +74 -0
  74. data/lib/aws/core/indifferent_hash.rb +88 -0
  75. data/lib/aws/core/inflection.rb +47 -0
  76. data/lib/aws/core/lazy_error_classes.rb +90 -0
  77. data/lib/aws/core/log_formatter.rb +454 -0
  78. data/lib/aws/core/meta_utils.rb +45 -0
  79. data/lib/aws/core/model.rb +57 -0
  80. data/lib/aws/core/naming.rb +30 -0
  81. data/lib/aws/core/option_grammar.rb +700 -0
  82. data/lib/aws/core/page_result.rb +73 -0
  83. data/lib/aws/core/policy.rb +916 -0
  84. data/lib/aws/core/resource.rb +408 -0
  85. data/lib/aws/core/resource_cache.rb +40 -0
  86. data/lib/aws/core/response.rb +202 -0
  87. data/lib/aws/core/response_cache.rb +50 -0
  88. data/lib/aws/core/service_interface.rb +61 -0
  89. data/lib/aws/core/session_signer.rb +90 -0
  90. data/lib/aws/core/signature/version_2.rb +42 -0
  91. data/lib/aws/core/signature/version_3.rb +73 -0
  92. data/lib/aws/core/signature/version_3_http.rb +72 -0
  93. data/lib/aws/core/signature/version_4.rb +138 -0
  94. data/lib/aws/core/uri_escape.rb +42 -0
  95. data/lib/aws/core/xml/frame.rb +242 -0
  96. data/lib/aws/core/xml/frame_stack.rb +85 -0
  97. data/lib/aws/core/xml/grammar.rb +299 -0
  98. data/lib/aws/core/xml/parser.rb +70 -0
  99. data/lib/aws/core/xml/root_frame.rb +65 -0
  100. data/lib/aws/core/xml/sax_handlers/libxml.rb +47 -0
  101. data/lib/aws/core/xml/sax_handlers/nokogiri.rb +55 -0
  102. data/lib/aws/core/xml/sax_handlers/ox.rb +41 -0
  103. data/lib/aws/core/xml/sax_handlers/rexml.rb +43 -0
  104. data/lib/aws/core/xml/stub.rb +123 -0
  105. data/lib/aws/dynamo_db.rb +213 -0
  106. data/lib/aws/dynamo_db/attribute_collection.rb +460 -0
  107. data/lib/aws/dynamo_db/batch_get.rb +206 -0
  108. data/lib/aws/dynamo_db/batch_write.rb +251 -0
  109. data/lib/aws/dynamo_db/client.rb +888 -0
  110. data/lib/aws/dynamo_db/config.rb +20 -0
  111. data/lib/aws/dynamo_db/errors.rb +20 -0
  112. data/lib/aws/dynamo_db/expectations.rb +40 -0
  113. data/lib/aws/dynamo_db/item.rb +130 -0
  114. data/lib/aws/dynamo_db/item_collection.rb +852 -0
  115. data/lib/aws/dynamo_db/item_data.rb +31 -0
  116. data/lib/aws/dynamo_db/keys.rb +41 -0
  117. data/lib/aws/dynamo_db/primary_key_element.rb +47 -0
  118. data/lib/aws/dynamo_db/request.rb +28 -0
  119. data/lib/aws/dynamo_db/resource.rb +33 -0
  120. data/lib/aws/dynamo_db/table.rb +489 -0
  121. data/lib/aws/dynamo_db/table_collection.rb +165 -0
  122. data/lib/aws/dynamo_db/types.rb +86 -0
  123. data/lib/aws/ec2.rb +431 -0
  124. data/lib/aws/ec2/attachment.rb +140 -0
  125. data/lib/aws/ec2/attachment_collection.rb +54 -0
  126. data/lib/aws/ec2/availability_zone.rb +87 -0
  127. data/lib/aws/ec2/availability_zone_collection.rb +43 -0
  128. data/lib/aws/ec2/block_device_mappings.rb +53 -0
  129. data/lib/aws/ec2/client.rb +4121 -0
  130. data/lib/aws/ec2/collection.rb +36 -0
  131. data/lib/aws/ec2/config.rb +18 -0
  132. data/lib/aws/ec2/config_transform.rb +63 -0
  133. data/lib/aws/ec2/customer_gateway.rb +90 -0
  134. data/lib/aws/ec2/customer_gateway_collection.rb +73 -0
  135. data/lib/aws/ec2/dhcp_options.rb +106 -0
  136. data/lib/aws/ec2/dhcp_options_collection.rb +87 -0
  137. data/lib/aws/ec2/elastic_ip.rb +157 -0
  138. data/lib/aws/ec2/elastic_ip_collection.rb +97 -0
  139. data/lib/aws/ec2/errors.rb +32 -0
  140. data/lib/aws/ec2/filtered_collection.rb +90 -0
  141. data/lib/aws/ec2/has_permissions.rb +44 -0
  142. data/lib/aws/ec2/image.rb +254 -0
  143. data/lib/aws/ec2/image_collection.rb +228 -0
  144. data/lib/aws/ec2/instance.rb +669 -0
  145. data/lib/aws/ec2/instance_collection.rb +346 -0
  146. data/lib/aws/ec2/internet_gateway.rb +122 -0
  147. data/lib/aws/ec2/internet_gateway/attachment.rb +78 -0
  148. data/lib/aws/ec2/internet_gateway_collection.rb +54 -0
  149. data/lib/aws/ec2/key_pair.rb +82 -0
  150. data/lib/aws/ec2/key_pair_collection.rb +99 -0
  151. data/lib/aws/ec2/network_acl.rb +256 -0
  152. data/lib/aws/ec2/network_acl/association.rb +56 -0
  153. data/lib/aws/ec2/network_acl/entry.rb +147 -0
  154. data/lib/aws/ec2/network_acl_collection.rb +64 -0
  155. data/lib/aws/ec2/network_interface.rb +228 -0
  156. data/lib/aws/ec2/network_interface/attachment.rb +100 -0
  157. data/lib/aws/ec2/network_interface_collection.rb +103 -0
  158. data/lib/aws/ec2/permission_collection.rb +174 -0
  159. data/lib/aws/ec2/region.rb +97 -0
  160. data/lib/aws/ec2/region_collection.rb +51 -0
  161. data/lib/aws/ec2/request.rb +22 -0
  162. data/lib/aws/ec2/reserved_instances.rb +53 -0
  163. data/lib/aws/ec2/reserved_instances_collection.rb +40 -0
  164. data/lib/aws/ec2/reserved_instances_offering.rb +58 -0
  165. data/lib/aws/ec2/reserved_instances_offering_collection.rb +39 -0
  166. data/lib/aws/ec2/resource.rb +161 -0
  167. data/lib/aws/ec2/resource_tag_collection.rb +211 -0
  168. data/lib/aws/ec2/route_table.rb +205 -0
  169. data/lib/aws/ec2/route_table/association.rb +119 -0
  170. data/lib/aws/ec2/route_table/route.rb +113 -0
  171. data/lib/aws/ec2/route_table_collection.rb +72 -0
  172. data/lib/aws/ec2/security_group.rb +458 -0
  173. data/lib/aws/ec2/security_group/egress_ip_permission_collection.rb +63 -0
  174. data/lib/aws/ec2/security_group/ingress_ip_permission_collection.rb +61 -0
  175. data/lib/aws/ec2/security_group/ip_permission.rb +128 -0
  176. data/lib/aws/ec2/security_group_collection.rb +135 -0
  177. data/lib/aws/ec2/snapshot.rb +143 -0
  178. data/lib/aws/ec2/snapshot_collection.rb +131 -0
  179. data/lib/aws/ec2/subnet.rb +161 -0
  180. data/lib/aws/ec2/subnet_collection.rb +115 -0
  181. data/lib/aws/ec2/tag.rb +81 -0
  182. data/lib/aws/ec2/tag_collection.rb +107 -0
  183. data/lib/aws/ec2/tagged_collection.rb +53 -0
  184. data/lib/aws/ec2/tagged_item.rb +85 -0
  185. data/lib/aws/ec2/volume.rb +170 -0
  186. data/lib/aws/ec2/volume_collection.rb +97 -0
  187. data/lib/aws/ec2/vpc.rb +166 -0
  188. data/lib/aws/ec2/vpc_collection.rb +70 -0
  189. data/lib/aws/ec2/vpn_connection.rb +99 -0
  190. data/lib/aws/ec2/vpn_connection/telemetry.rb +49 -0
  191. data/lib/aws/ec2/vpn_connection_collection.rb +96 -0
  192. data/lib/aws/ec2/vpn_gateway.rb +123 -0
  193. data/lib/aws/ec2/vpn_gateway/attachment.rb +45 -0
  194. data/lib/aws/ec2/vpn_gateway_collection.rb +77 -0
  195. data/lib/aws/elb.rb +65 -0
  196. data/lib/aws/elb/availability_zone_collection.rb +138 -0
  197. data/lib/aws/elb/backend_server_policy_collection.rb +140 -0
  198. data/lib/aws/elb/client.rb +539 -0
  199. data/lib/aws/elb/config.rb +18 -0
  200. data/lib/aws/elb/errors.rb +26 -0
  201. data/lib/aws/elb/instance_collection.rb +174 -0
  202. data/lib/aws/elb/listener.rb +189 -0
  203. data/lib/aws/elb/listener_collection.rb +119 -0
  204. data/lib/aws/elb/listener_opts.rb +45 -0
  205. data/lib/aws/elb/load_balancer.rb +253 -0
  206. data/lib/aws/elb/load_balancer_collection.rb +113 -0
  207. data/lib/aws/elb/load_balancer_policy.rb +93 -0
  208. data/lib/aws/elb/load_balancer_policy_collection.rb +208 -0
  209. data/lib/aws/elb/request.rb +23 -0
  210. data/lib/aws/errors.rb +122 -0
  211. data/lib/aws/iam.rb +418 -0
  212. data/lib/aws/iam/access_key.rb +180 -0
  213. data/lib/aws/iam/access_key_collection.rb +128 -0
  214. data/lib/aws/iam/account_alias_collection.rb +79 -0
  215. data/lib/aws/iam/client.rb +1609 -0
  216. data/lib/aws/iam/collection.rb +83 -0
  217. data/lib/aws/iam/config.rb +18 -0
  218. data/lib/aws/iam/errors.rb +22 -0
  219. data/lib/aws/iam/group.rb +111 -0
  220. data/lib/aws/iam/group_collection.rb +132 -0
  221. data/lib/aws/iam/group_policy_collection.rb +47 -0
  222. data/lib/aws/iam/group_user_collection.rb +84 -0
  223. data/lib/aws/iam/login_profile.rb +99 -0
  224. data/lib/aws/iam/mfa_device.rb +52 -0
  225. data/lib/aws/iam/mfa_device_collection.rb +127 -0
  226. data/lib/aws/iam/policy.rb +46 -0
  227. data/lib/aws/iam/policy_collection.rb +188 -0
  228. data/lib/aws/iam/request.rb +29 -0
  229. data/lib/aws/iam/resource.rb +71 -0
  230. data/lib/aws/iam/server_certificate.rb +141 -0
  231. data/lib/aws/iam/server_certificate_collection.rb +138 -0
  232. data/lib/aws/iam/signing_certificate.rb +169 -0
  233. data/lib/aws/iam/signing_certificate_collection.rb +131 -0
  234. data/lib/aws/iam/user.rb +205 -0
  235. data/lib/aws/iam/user_collection.rb +133 -0
  236. data/lib/aws/iam/user_group_collection.rb +98 -0
  237. data/lib/aws/iam/user_policy.rb +90 -0
  238. data/lib/aws/iam/user_policy_collection.rb +45 -0
  239. data/lib/aws/iam/virtual_mfa_device.rb +139 -0
  240. data/lib/aws/iam/virtual_mfa_device_collection.rb +73 -0
  241. data/lib/aws/rails.rb +195 -0
  242. data/lib/aws/record.rb +116 -0
  243. data/lib/aws/record/abstract_base.rb +645 -0
  244. data/lib/aws/record/attributes.rb +384 -0
  245. data/lib/aws/record/conversion.rb +38 -0
  246. data/lib/aws/record/dirty_tracking.rb +285 -0
  247. data/lib/aws/record/errors.rb +143 -0
  248. data/lib/aws/record/exceptions.rb +48 -0
  249. data/lib/aws/record/hash_model.rb +161 -0
  250. data/lib/aws/record/hash_model/attributes.rb +182 -0
  251. data/lib/aws/record/hash_model/finder_methods.rb +172 -0
  252. data/lib/aws/record/hash_model/scope.rb +108 -0
  253. data/lib/aws/record/model.rb +427 -0
  254. data/lib/aws/record/model/attributes.rb +379 -0
  255. data/lib/aws/record/model/finder_methods.rb +232 -0
  256. data/lib/aws/record/model/scope.rb +213 -0
  257. data/lib/aws/record/naming.rb +31 -0
  258. data/lib/aws/record/scope.rb +199 -0
  259. data/lib/aws/record/validations.rb +694 -0
  260. data/lib/aws/record/validator.rb +237 -0
  261. data/lib/aws/record/validators/acceptance.rb +51 -0
  262. data/lib/aws/record/validators/block.rb +38 -0
  263. data/lib/aws/record/validators/confirmation.rb +43 -0
  264. data/lib/aws/record/validators/count.rb +108 -0
  265. data/lib/aws/record/validators/exclusion.rb +43 -0
  266. data/lib/aws/record/validators/format.rb +57 -0
  267. data/lib/aws/record/validators/inclusion.rb +56 -0
  268. data/lib/aws/record/validators/length.rb +107 -0
  269. data/lib/aws/record/validators/method.rb +33 -0
  270. data/lib/aws/record/validators/numericality.rb +138 -0
  271. data/lib/aws/record/validators/presence.rb +45 -0
  272. data/lib/aws/s3.rb +135 -0
  273. data/lib/aws/s3/access_control_list.rb +250 -0
  274. data/lib/aws/s3/acl_object.rb +264 -0
  275. data/lib/aws/s3/bucket.rb +393 -0
  276. data/lib/aws/s3/bucket_collection.rb +143 -0
  277. data/lib/aws/s3/bucket_lifecycle_configuration.rb +360 -0
  278. data/lib/aws/s3/bucket_version_collection.rb +77 -0
  279. data/lib/aws/s3/client.rb +1184 -0
  280. data/lib/aws/s3/client/xml.rb +177 -0
  281. data/lib/aws/s3/config.rb +26 -0
  282. data/lib/aws/s3/data_options.rb +100 -0
  283. data/lib/aws/s3/errors.rb +81 -0
  284. data/lib/aws/s3/multipart_upload.rb +317 -0
  285. data/lib/aws/s3/multipart_upload_collection.rb +68 -0
  286. data/lib/aws/s3/object_collection.rb +337 -0
  287. data/lib/aws/s3/object_metadata.rb +96 -0
  288. data/lib/aws/s3/object_upload_collection.rb +77 -0
  289. data/lib/aws/s3/object_version.rb +143 -0
  290. data/lib/aws/s3/object_version_collection.rb +89 -0
  291. data/lib/aws/s3/paginated_collection.rb +75 -0
  292. data/lib/aws/s3/policy.rb +74 -0
  293. data/lib/aws/s3/prefix_and_delimiter_collection.rb +47 -0
  294. data/lib/aws/s3/prefixed_collection.rb +81 -0
  295. data/lib/aws/s3/presigned_post.rb +553 -0
  296. data/lib/aws/s3/request.rb +201 -0
  297. data/lib/aws/s3/s3_object.rb +1037 -0
  298. data/lib/aws/s3/tree.rb +118 -0
  299. data/lib/aws/s3/tree/branch_node.rb +68 -0
  300. data/lib/aws/s3/tree/child_collection.rb +104 -0
  301. data/lib/aws/s3/tree/leaf_node.rb +94 -0
  302. data/lib/aws/s3/tree/node.rb +22 -0
  303. data/lib/aws/s3/tree/parent.rb +87 -0
  304. data/lib/aws/s3/uploaded_part.rb +80 -0
  305. data/lib/aws/s3/uploaded_part_collection.rb +84 -0
  306. data/lib/aws/simple_db.rb +217 -0
  307. data/lib/aws/simple_db/attribute.rb +154 -0
  308. data/lib/aws/simple_db/attribute_collection.rb +231 -0
  309. data/lib/aws/simple_db/client.rb +349 -0
  310. data/lib/aws/simple_db/config.rb +20 -0
  311. data/lib/aws/simple_db/consistent_read_option.rb +42 -0
  312. data/lib/aws/simple_db/delete_attributes.rb +62 -0
  313. data/lib/aws/simple_db/domain.rb +121 -0
  314. data/lib/aws/simple_db/domain_collection.rb +113 -0
  315. data/lib/aws/simple_db/domain_metadata.rb +110 -0
  316. data/lib/aws/simple_db/errors.rb +55 -0
  317. data/lib/aws/simple_db/expect_condition_option.rb +45 -0
  318. data/lib/aws/simple_db/item.rb +93 -0
  319. data/lib/aws/simple_db/item_collection.rb +649 -0
  320. data/lib/aws/simple_db/item_data.rb +73 -0
  321. data/lib/aws/simple_db/put_attributes.rb +60 -0
  322. data/lib/aws/simple_db/request.rb +23 -0
  323. data/lib/aws/simple_email_service.rb +426 -0
  324. data/lib/aws/simple_email_service/client.rb +286 -0
  325. data/lib/aws/simple_email_service/config.rb +19 -0
  326. data/lib/aws/simple_email_service/email_address_collection.rb +69 -0
  327. data/lib/aws/simple_email_service/errors.rb +22 -0
  328. data/lib/aws/simple_email_service/identity.rb +91 -0
  329. data/lib/aws/simple_email_service/identity_collection.rb +81 -0
  330. data/lib/aws/simple_email_service/quotas.rb +64 -0
  331. data/lib/aws/simple_email_service/request.rb +29 -0
  332. data/lib/aws/simple_workflow.rb +226 -0
  333. data/lib/aws/simple_workflow/activity_task.rb +173 -0
  334. data/lib/aws/simple_workflow/activity_task_collection.rb +123 -0
  335. data/lib/aws/simple_workflow/activity_type.rb +131 -0
  336. data/lib/aws/simple_workflow/activity_type_collection.rb +93 -0
  337. data/lib/aws/simple_workflow/client.rb +1434 -0
  338. data/lib/aws/simple_workflow/config.rb +18 -0
  339. data/lib/aws/simple_workflow/count.rb +49 -0
  340. data/lib/aws/simple_workflow/decision_task.rb +601 -0
  341. data/lib/aws/simple_workflow/decision_task_collection.rb +225 -0
  342. data/lib/aws/simple_workflow/domain.rb +122 -0
  343. data/lib/aws/simple_workflow/domain_collection.rb +169 -0
  344. data/lib/aws/simple_workflow/errors.rb +20 -0
  345. data/lib/aws/simple_workflow/history_event.rb +276 -0
  346. data/lib/aws/simple_workflow/history_event_collection.rb +76 -0
  347. data/lib/aws/simple_workflow/option_formatters.rb +82 -0
  348. data/lib/aws/simple_workflow/request.rb +36 -0
  349. data/lib/aws/simple_workflow/resource.rb +94 -0
  350. data/lib/aws/simple_workflow/type.rb +89 -0
  351. data/lib/aws/simple_workflow/type_collection.rb +140 -0
  352. data/lib/aws/simple_workflow/workflow_execution.rb +386 -0
  353. data/lib/aws/simple_workflow/workflow_execution_collection.rb +617 -0
  354. data/lib/aws/simple_workflow/workflow_type.rb +177 -0
  355. data/lib/aws/simple_workflow/workflow_type_collection.rb +91 -0
  356. data/lib/aws/sns.rb +74 -0
  357. data/lib/aws/sns/client.rb +371 -0
  358. data/lib/aws/sns/config.rb +18 -0
  359. data/lib/aws/sns/errors.rb +22 -0
  360. data/lib/aws/sns/has_delivery_policy.rb +68 -0
  361. data/lib/aws/sns/policy.rb +47 -0
  362. data/lib/aws/sns/request.rb +23 -0
  363. data/lib/aws/sns/subscription.rb +144 -0
  364. data/lib/aws/sns/subscription_collection.rb +80 -0
  365. data/lib/aws/sns/topic.rb +403 -0
  366. data/lib/aws/sns/topic_collection.rb +67 -0
  367. data/lib/aws/sns/topic_subscription_collection.rb +55 -0
  368. data/lib/aws/sqs.rb +79 -0
  369. data/lib/aws/sqs/client.rb +360 -0
  370. data/lib/aws/sqs/config.rb +18 -0
  371. data/lib/aws/sqs/errors.rb +101 -0
  372. data/lib/aws/sqs/policy.rb +48 -0
  373. data/lib/aws/sqs/queue.rb +725 -0
  374. data/lib/aws/sqs/queue_collection.rb +170 -0
  375. data/lib/aws/sqs/received_message.rb +181 -0
  376. data/lib/aws/sqs/received_sns_message.rb +112 -0
  377. data/lib/aws/sqs/request.rb +43 -0
  378. data/lib/aws/sts.rb +152 -0
  379. data/lib/aws/sts/client.rb +105 -0
  380. data/lib/aws/sts/config.rb +18 -0
  381. data/lib/aws/sts/errors.rb +22 -0
  382. data/lib/aws/sts/federated_session.rb +56 -0
  383. data/lib/aws/sts/policy.rb +30 -0
  384. data/lib/aws/sts/request.rb +29 -0
  385. data/lib/aws/sts/session.rb +48 -0
  386. data/lib/net/http/connection_pool.rb +210 -0
  387. data/lib/net/http/connection_pool/connection.rb +132 -0
  388. data/lib/net/http/connection_pool/session.rb +93 -0
  389. data/lib/user.rb +49 -0
  390. metadata +433 -0
@@ -0,0 +1,165 @@
1
+ # Copyright 2011-2012 Amazon.com, Inc. or its affiliates. All Rights Reserved.
2
+ #
3
+ # Licensed under the Apache License, Version 2.0 (the "License"). You
4
+ # may not use this file except in compliance with the License. A copy of
5
+ # the License is located at
6
+ #
7
+ # http://aws.amazon.com/apache2.0/
8
+ #
9
+ # or in the "license" file accompanying this file. This file is
10
+ # distributed on an "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF
11
+ # ANY KIND, either express or implied. See the License for the specific
12
+ # language governing permissions and limitations under the License.
13
+
14
+ module AWS
15
+ class DynamoDB
16
+
17
+ # Represents the tables in your account. Each table is
18
+ # represented by an instance of the {Table} class.
19
+ #
20
+ # == Schemas
21
+ #
22
+ # Before you can operate on items in a table you must specify the schema.
23
+ # You do this by calling #hash_key= (and optionally #range_key=) on
24
+ # a table.
25
+ #
26
+ # table = dynamo_db.tables['mytable']
27
+ # table.hash_key = [:id, :string]
28
+ #
29
+ # @example Creating a Table
30
+ # table = dynamo_db.tables.create('mytable', 10, 10, :hash_key => { :id => :string })
31
+ #
32
+ # @example Enumerating Tables
33
+ # dynamo_db.tables.each {|table| puts table.name }
34
+ #
35
+ # @example Getting a Table by Name
36
+ # table = dynamo_db.tables['mytable']
37
+ #
38
+ class TableCollection
39
+
40
+ include Core::Collection::Limitable
41
+
42
+ # Creates a new table.
43
+ #
44
+ # table = dynamo_db.tables.create('mytable', 25, 25,
45
+ # :hash_key => { :id => :string })
46
+ #
47
+ # @note Creating a table is an eventualy consistent operation. You
48
+ # can not interact with the table until its status
49
+ # ({Table#status}) is +:active+.
50
+ #
51
+ # @param [String] name The name of the table.
52
+ #
53
+ # @param [Integer] read_capacity_units Sets the minimum
54
+ # number of reads supported before read requests are throttled.
55
+ #
56
+ # @param [Integer] write_capacity_units Sets the minimum
57
+ # number of writes supported before writes requests are throttled.
58
+ #
59
+ # @param [Hash] options
60
+ #
61
+ # @option options [Hash] :hash_key A hash key is a combination
62
+ # of an attribute name and type. If you want to have the
63
+ # hash key on the string attribute username you would call #create
64
+ # with:
65
+ #
66
+ # :hash_key => { :username => :string }
67
+ #
68
+ # The other supported type is +:number+. If you wanted to
69
+ # set the hash key on a numeric (integer) attribute then you
70
+ # could call #create with:
71
+ #
72
+ # :hash_key => { :id => :number }
73
+ #
74
+ # All tables require a hash key. If +:hash_key+ is not provided
75
+ # then a default hash key will be provided. The default hash
76
+ # key is:
77
+ #
78
+ # :hash_key => { :id => :string }
79
+ #
80
+ # @option options [String] :range_key You can setup a table to use
81
+ # composite keys by providing a +:range_key+. Range keys are
82
+ # configured the same way as hash keys. They are useful
83
+ # for ordering items that share the same hash key.
84
+ #
85
+ # @return [Table] The newly created table.
86
+ #
87
+ def create name, read_capacity_units, write_capacity_units, options = {}
88
+
89
+ client_opts = {
90
+ :table_name => name.to_s,
91
+ :key_schema => key_schema(options),
92
+ :provisioned_throughput => {
93
+ :read_capacity_units => read_capacity_units,
94
+ :write_capacity_units => write_capacity_units,
95
+ },
96
+ }
97
+
98
+ response = client.create_table(client_opts)
99
+
100
+ Table.new(name, :config => config)
101
+
102
+ end
103
+
104
+ # References a table by name.
105
+ #
106
+ # dynamo_db.tables["MyTable"]
107
+ #
108
+ # @param [String] name
109
+ # @return [Table] Returns the table with the given name.
110
+ def [] name
111
+ Table.new(name, :config => config)
112
+ end
113
+
114
+ # @private
115
+ protected
116
+ def _each_item next_token, limit, options = {}, &block
117
+
118
+ options[:limit] = limit if limit
119
+ options[:exclusive_start_table_name] = next_token if next_token
120
+
121
+ response = client.list_tables(options)
122
+ response.data['TableNames'].each do |name|
123
+ yield Table.new(name, :config => config)
124
+ end
125
+
126
+ response.data['LastEvaluatedTableName']
127
+
128
+ end
129
+
130
+ private
131
+ def key_schema options
132
+
133
+ hash_key, range_key = options.values_at(:hash_key, :range_key)
134
+
135
+ # default options for :hash_key
136
+ hash_key ||= { :id => :string }
137
+
138
+ schema = {}
139
+ schema[:hash_key_element] = schema_element(hash_key, "hash")
140
+ if range_key
141
+ schema[:range_key_element] = schema_element(range_key, "range")
142
+ end
143
+ schema
144
+
145
+ end
146
+
147
+ private
148
+ def schema_element desc, key_type
149
+
150
+ (name, type) = desc.to_a.first
151
+
152
+ unless type == :string or type == :number
153
+ msg = "invalid #{key_type} key type, expected :string or :number"
154
+ raise ArgumentError, msg
155
+ end
156
+
157
+ { :attribute_name => name.to_s,
158
+ :attribute_type => type.to_s[0,1].upcase }
159
+
160
+ end
161
+
162
+ end
163
+
164
+ end
165
+ end
@@ -0,0 +1,86 @@
1
+ # Copyright 2011-2012 Amazon.com, Inc. or its affiliates. All Rights Reserved.
2
+ #
3
+ # Licensed under the Apache License, Version 2.0 (the "License"). You
4
+ # may not use this file except in compliance with the License. A copy of
5
+ # the License is located at
6
+ #
7
+ # http://aws.amazon.com/apache2.0/
8
+ #
9
+ # or in the "license" file accompanying this file. This file is
10
+ # distributed on an "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF
11
+ # ANY KIND, either express or implied. See the License for the specific
12
+ # language governing permissions and limitations under the License.
13
+
14
+ require 'bigdecimal'
15
+ require 'set'
16
+
17
+ module AWS
18
+ class DynamoDB
19
+
20
+ # @private
21
+ module Types
22
+
23
+ def value_from_response(hash)
24
+ (type, value) = hash.to_a.first
25
+ case type
26
+ when "S", :s
27
+ value
28
+ when "SS", :ss
29
+ Set[*value]
30
+ when "N", :n
31
+ BigDecimal(value.to_s)
32
+ when "NS", :ns
33
+ Set[*value.map { |v| BigDecimal(v.to_s) }]
34
+ end
35
+ end
36
+
37
+ def values_from_response_hash(hash)
38
+ hash.inject({}) do |h, (key, value_hash)|
39
+ h.update(key => value_from_response(value_hash))
40
+ end
41
+ end
42
+
43
+ def format_attribute_value(value, context = nil)
44
+ indicator = type_indicator(value, context)
45
+
46
+ value = [] if value == :empty_number_set
47
+ value = value.to_s if indicator == :n
48
+ value = value.map(&:to_s) if indicator == :ns
49
+
50
+ Hash[[[indicator, value]]]
51
+ end
52
+
53
+ protected
54
+ def type_indicator(value, context)
55
+ case
56
+ when value.respond_to?(:to_str) then :s
57
+ when value.kind_of?(Numeric) then :n
58
+ when value.respond_to?(:each)
59
+ indicator = nil
60
+ value.each do |v|
61
+ member_indicator = type_indicator(v, context)
62
+ raise_error("nested collections", context) if
63
+ member_indicator.to_s.size > 1
64
+ raise_error("mixed types", context) if
65
+ indicator and member_indicator != indicator
66
+ indicator = member_indicator
67
+ end
68
+ indicator ||= :s
69
+ :"#{indicator}s"
70
+ when value == :empty_number_set
71
+ :ns
72
+ else
73
+ raise_error("unsupported attribute type #{value.class}", context)
74
+ end
75
+ end
76
+
77
+ protected
78
+ def raise_error(msg, context)
79
+ msg = "#{msg} in #{context}" if context
80
+ raise ArgumentError, msg
81
+ end
82
+
83
+ end
84
+
85
+ end
86
+ end
@@ -0,0 +1,431 @@
1
+ # Copyright 2011-2012 Amazon.com, Inc. or its affiliates. All Rights Reserved.
2
+ #
3
+ # Licensed under the Apache License, Version 2.0 (the "License"). You
4
+ # may not use this file except in compliance with the License. A copy of
5
+ # the License is located at
6
+ #
7
+ # http://aws.amazon.com/apache2.0/
8
+ #
9
+ # or in the "license" file accompanying this file. This file is
10
+ # distributed on an "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF
11
+ # ANY KIND, either express or implied. See the License for the specific
12
+ # language governing permissions and limitations under the License.
13
+
14
+ require 'aws/core'
15
+ require 'aws/ec2/config'
16
+
17
+ module AWS
18
+
19
+ # Provides an expressive, object-oriented interface to Amazon EC2.
20
+ #
21
+ # == Credentials
22
+ #
23
+ # You can setup default credentials for all AWS services via
24
+ # AWS.config:
25
+ #
26
+ # AWS.config(
27
+ # :access_key_id => 'YOUR_ACCESS_KEY_ID',
28
+ # :secret_access_key => 'YOUR_SECRET_ACCESS_KEY')
29
+ #
30
+ # Or you can set them directly on the EC2 interface:
31
+ #
32
+ # ec2 = AWS::EC2.new(
33
+ # :access_key_id => 'YOUR_ACCESS_KEY_ID',
34
+ # :secret_access_key => 'YOUR_SECRET_ACCESS_KEY')
35
+ #
36
+ # == Instances
37
+ #
38
+ # EC2 uses instances to run your software.
39
+ #
40
+ # To run an instance:
41
+ #
42
+ # ec2.instances.create(:image_id => "ami-8c1fece5")
43
+ #
44
+ # To get an instance by ID:
45
+ #
46
+ # i = ec2.instances["i-12345678"]
47
+ # i.exists?
48
+ #
49
+ # To get a list of instances:
50
+ #
51
+ # ec2.instances.inject({}) { |m, i| m[i.id] = i.status; m }
52
+ # # => { "i-12345678" => :running, "i-87654321" => :shutting_down }
53
+ #
54
+ # == Security Groups
55
+ #
56
+ # A security group is a named collection of access rules. These access
57
+ # rules specify which ingress (i.e., incoming) network traffic should be
58
+ # delivered to your instance. All other ingress traffic will be discarded.
59
+ #
60
+ # To create a security group:
61
+ #
62
+ # websvr = ec2.security_groups.create('webservers')
63
+ #
64
+ # Then you can add ingress authorizations. In the following example
65
+ # we add a rule that allows web traffic from the entire internet.
66
+ #
67
+ # # web traffic
68
+ # websvr.authorize_ingress(:tcp, 80)
69
+ #
70
+ # You can also specify a port range. Here we are opening FTP traffic:
71
+ #
72
+ # # ftp traffic
73
+ # websvr.authorize_ingress(:tcp, 20..21)
74
+ #
75
+ # If you want to limit an authorization to a particular CIDR IP address or
76
+ # list of address, just add them to the #authorize_ingress call.
77
+ #
78
+ # # ssh access
79
+ # websrvr.authorize_ingress(:tcp, 22, '1.1.1.1/0', '2.2.2.2/0')
80
+ #
81
+ # You can also provide another security group instead of CIDR IP addresses.
82
+ # This allows incoming traffic from EC2 instances in the given security
83
+ # group(s).
84
+ #
85
+ # # get two existing security groups
86
+ # dbsvrs = ec2.security_groups.filter('group-name', 'db-servers').first
87
+ # websvrs = ec2.security_groups.filter('group-name', 'web-servers').first
88
+ #
89
+ # # allow instances in the 'web-servers' security group to connect
90
+ # # to instances in the 'db-servers' security group over tcp port 3306
91
+ # dbsvrs.authorize_ingress(:tcp, 3306, websvrs)
92
+ #
93
+ # There are a few handy shortcuts for allowing pings:
94
+ #
95
+ # wbsvrs.allow_ping
96
+ #
97
+ # Just like with authorize_ingress you can pass a security group or a list
98
+ # of CIDR IP addresses to allow ping to limit where you can ping from.
99
+ #
100
+ # You can also use the same parameters from the examples above to
101
+ # {SecurityGroup#revoke_ingress} and {SecurityGroup#disallow_ping}.
102
+ #
103
+ # You can specify other protocols than +:tcp+, like :udp and :icmp.
104
+ #
105
+ # == Elastic IPs
106
+ #
107
+ # You can allocate up to 5 elastic IP addresses for each account.
108
+ # You can associate those elastic IP addresses with EC2 instances:
109
+ #
110
+ # instance = ec2.instances['i-12345678']
111
+ # ip = ec2.elastic_ips.allocate
112
+ #
113
+ # instance.ip_address # 1.1.1.1
114
+ # ip.ip_address # 2.2.2.2
115
+ #
116
+ # instance.associate_elastic_ip(ip)
117
+ # instance.ip_address # 2.2.2.2
118
+ #
119
+ # instance.disassociate_elastic_ip
120
+ # instance.ip_address # 1.1.1.1
121
+ #
122
+ # When you are done with an elastic IP address you should release it.
123
+ # In the following example we release all elastic IP addresses that are
124
+ # not currently associated with an instance:
125
+ #
126
+ # ec2.select{|ip| !ip.associated? }.each(&:release)
127
+ #
128
+ # == Key Pairs
129
+ #
130
+ # Public Amazon Machine Image (AMI) instances have no password, and you need a
131
+ # public/private key pair to log in to them. The public key half
132
+ # of this pair is embedded in your instance, allowing you to use
133
+ # the private key to log in securely without a password.
134
+ #
135
+ # You can generate a key pair yourself and then send the public
136
+ # part to EC2 using {KeyPairCollection#import}. For example:
137
+ #
138
+ # key_pair =
139
+ # ec2.key_pairs.import("mykey", File.read("~/.ssh/identity.pub"))
140
+ #
141
+ # You can also ask EC2 to generate a key pair for you. For
142
+ # example:
143
+ #
144
+ # key_pair = ec2.key_pairs.create("mykey")
145
+ # File.open("~/.ssh/ec2", "w") do |f|
146
+ # f.write(key_pair.private_key)
147
+ # end
148
+ #
149
+ # == Filtering and Tagging
150
+ #
151
+ # Any of the collections in the interface may be filtered by a
152
+ # number of different parameters. For example, to get all the
153
+ # windows images owned by amazon where the description includes
154
+ # the string "linux", you can do this:
155
+ #
156
+ # ec2.images.with_owner("amazon").
157
+ # filter("platform", "windows").
158
+ # filter("description", "*linux*")
159
+ #
160
+ # Similarly, you can tag images, instances, security groups,
161
+ # snapshots, and volumes with free-form key-value metadata and
162
+ # filter on that metadata. For example:
163
+ #
164
+ # ec2.images["ami-123"].tags << "myapp"
165
+ # ec2.images.tagged("myapp") # will include ami-123
166
+ #
167
+ # == Regions
168
+ #
169
+ # Amazon has data centers in different areas of the world (e.g.,
170
+ # North America, Europe, Asia, etc.). Correspondingly, EC2 is
171
+ # available to use in different Regions. By launching instances in
172
+ # separate Regions, you can design your application to be closer
173
+ # to specific customers or to meet legal or other
174
+ # requirements. Prices for Amazon EC2 usage vary by Region (for
175
+ # more information about pricing by Region, go to the {Amazon EC2
176
+ # Pricing page}[http://aws.amazon.com/ec2/pricing]). You can use
177
+ # the Ruby SDK to see which regions are available for your
178
+ # account:
179
+ #
180
+ # ec2.regions.map(&:name) # => ["us-east-1", ...]
181
+ #
182
+ # The default region is +us-east-1+; you can access other regions
183
+ # like this:
184
+ #
185
+ # ec2_us_west = ec2.regions["us-west-1"]
186
+ # # starts an instance in eu-west-1
187
+ # ec2_us_west.instances.create(:image_id => 'ami-3bc9997e')
188
+ #
189
+ # This makes a call to EC2's DescribeRegions API to find the
190
+ # endpoint for "us-west-1" -- if you just want to configure a
191
+ # different endpoint without making a call to EC2, you can do it
192
+ # like this:
193
+ #
194
+ # ec2 = AWS::EC2.new(:ec2_endpoint =>
195
+ # "ec2.us-west-1.amazonaws.com")
196
+ #
197
+ # == Availability Zones
198
+ #
199
+ # Each Region contains multiple distinct locations called
200
+ # Availability Zones. Each Availability Zone is engineered to be
201
+ # isolated from failures in other Availability zones and to
202
+ # provide inexpensive, low-latency network connectivity to other
203
+ # zones in the same Region. By launching instances in separate
204
+ # Availability Zones, you can protect your applications from the
205
+ # failure of a single location.
206
+ #
207
+ # You can use the {#availability_zones} collection to get information
208
+ # about the available zones available to your account. For
209
+ # example:
210
+ #
211
+ # ec2.availability_zones.map(&:name) # => ["us-east-1a", ...]
212
+ #
213
+ # == Images
214
+ #
215
+ # An Amazon Machine Image (AMI) contains all information necessary
216
+ # to boot instances of your software. For example, an AMI might
217
+ # contain all the software to act as a web server (e.g., Linux,
218
+ # Apache, and your web site) or it might contain all the software
219
+ # to act as a Hadoop node (e.g., Linux, Hadoop, and a custom
220
+ # application).
221
+ #
222
+ # You can use the {#images} collection to get information about
223
+ # the images available to your account. For example:
224
+ #
225
+ # ec2.images.with_owner("amazon").map(&:name)
226
+ #
227
+ # You can also use the images collection to create new images:
228
+ #
229
+ # ec2.images.create(:image_location => "mybucket/manifest.xml",
230
+ # :name => "my-image")
231
+ #
232
+ class EC2
233
+
234
+ AWS.register_autoloads(self) do
235
+ autoload :Attachment, 'attachment'
236
+ autoload :AttachmentCollection, 'attachment_collection'
237
+ autoload :AvailabilityZone, 'availability_zone'
238
+ autoload :AvailabilityZoneCollection, 'availability_zone_collection'
239
+ autoload :BlockDeviceMappings, 'block_device_mappings'
240
+ autoload :Client, 'client'
241
+ autoload :Collection, 'collection'
242
+ autoload :ConfigTransform, 'config_transform'
243
+ autoload :CustomerGateway, 'customer_gateway'
244
+ autoload :CustomerGatewayCollection, 'customer_gateway_collection'
245
+ autoload :DHCPOptions, 'dhcp_options'
246
+ autoload :DHCPOptionsCollection, 'dhcp_options_collection'
247
+ autoload :ElasticIp, 'elastic_ip'
248
+ autoload :ElasticIpCollection, 'elastic_ip_collection'
249
+ autoload :Errors, 'errors'
250
+ autoload :FilteredCollection, 'filtered_collection'
251
+ autoload :HasPermissions, 'has_permissions'
252
+ autoload :Image, 'image'
253
+ autoload :ImageCollection, 'image_collection'
254
+ autoload :Instance, 'instance'
255
+ autoload :InstanceCollection, 'instance_collection'
256
+ autoload :InternetGateway, 'internet_gateway'
257
+ autoload :InternetGatewayCollection, 'internet_gateway_collection'
258
+ autoload :KeyPair, 'key_pair'
259
+ autoload :KeyPairCollection, 'key_pair_collection'
260
+ autoload :NetworkACL, 'network_acl'
261
+ autoload :NetworkACLCollection, 'network_acl_collection'
262
+ autoload :NetworkInterface, 'network_interface'
263
+ autoload :NetworkInterfaceCollection, 'network_interface_collection'
264
+ autoload :PermissionCollection, 'permission_collection'
265
+ autoload :Region, 'region'
266
+ autoload :RegionCollection, 'region_collection'
267
+ autoload :Request, 'request'
268
+ autoload :ReservedInstances, 'reserved_instances'
269
+ autoload :ReservedInstancesCollection, 'reserved_instances_collection'
270
+ autoload :ReservedInstancesOffering, 'reserved_instances_offering'
271
+ autoload :ReservedInstancesOfferingCollection,
272
+ 'reserved_instances_offering_collection'
273
+ autoload :Resource, 'resource'
274
+ autoload :ResourceObject, 'tag_collection'
275
+ autoload :ResourceTagCollection, 'resource_tag_collection'
276
+ autoload :RouteTable, 'route_table'
277
+ autoload :RouteTableCollection, 'route_table_collection'
278
+ autoload :SecurityGroup, 'security_group'
279
+ autoload :SecurityGroupCollection, 'security_group_collection'
280
+ autoload :Snapshot, 'snapshot'
281
+ autoload :SnapshotCollection, 'snapshot_collection'
282
+ autoload :Subnet, 'subnet'
283
+ autoload :SubnetCollection, 'subnet_collection'
284
+ autoload :Tag, 'tag'
285
+ autoload :TagCollection, 'tag_collection'
286
+ autoload :TaggedCollection, 'tagged_collection'
287
+ autoload :TaggedItem, 'tagged_item'
288
+ autoload :Volume, 'volume'
289
+ autoload :VolumeCollection, 'volume_collection'
290
+ autoload :VPC, 'vpc'
291
+ autoload :VPCCollection, 'vpc_collection'
292
+ autoload :VPNConnection, 'vpn_connection'
293
+ autoload :VPNConnectionCollection, 'vpn_connection_collection'
294
+ autoload :VPNGateway, 'vpn_gateway'
295
+ autoload :VPNGatewayCollection, 'vpn_gateway_collection'
296
+ end
297
+
298
+ include Core::ServiceInterface
299
+
300
+ # @return [InstanceCollection] A collection representing all instances
301
+ def instances
302
+ InstanceCollection.new(:config => config)
303
+ end
304
+
305
+ # @return [SecurityGroupCollection] A collection representing all security
306
+ # groups.
307
+ def security_groups
308
+ SecurityGroupCollection.new(:config => config)
309
+ end
310
+
311
+ # @return [ElasticIpCollection] A collection representing all
312
+ # elastic IP addresses for this account.
313
+ def elastic_ips
314
+ ElasticIpCollection.new(:config => config)
315
+ end
316
+
317
+ # @return [KeyPairCollection] A collection representing all key pairs.
318
+ def key_pairs
319
+ KeyPairCollection.new(:config => config)
320
+ end
321
+
322
+ # @return [TagCollection] A collection representing all EC2 tags for
323
+ # all resource types.
324
+ def tags
325
+ TagCollection.new(:config => config)
326
+ end
327
+
328
+ # @return [RegionCollection] A collection representing all EC2
329
+ # regions.
330
+ def regions
331
+ RegionCollection.new(:config => config)
332
+ end
333
+
334
+ # @return [AvailabilityZoneCollection] A collection representing
335
+ # all EC2 availability zones.
336
+ def availability_zones
337
+ AvailabilityZoneCollection.new(:config => config)
338
+ end
339
+
340
+ # @return [ImageCollection] A collection representing
341
+ # all Amazon Machine Images available to your account.
342
+ def images
343
+ ImageCollection.new(:config => config)
344
+ end
345
+
346
+ # @return [VolumeCollection] A collection representing
347
+ # all EBS volumes available to your account.
348
+ def volumes
349
+ VolumeCollection.new(:config => config)
350
+ end
351
+
352
+ # @return [ReservedInstancesCollection] A collection representing all
353
+ # purchased reserved instance offerings.
354
+ def reserved_instances
355
+ ReservedInstancesCollection.new(:config => config)
356
+ end
357
+
358
+ # @return [ReservedInstancesOfferingCollection] A collection representing all
359
+ # reserved instance offerings that may be purchased.
360
+ def reserved_instances_offerings
361
+ ReservedInstancesOfferingCollection.new(:config => config)
362
+ end
363
+
364
+ # @return [SnapshotCollection] A collection representing
365
+ # all EBS snapshots available to your account.
366
+ def snapshots
367
+ SnapshotCollection.new(:config => config)
368
+ end
369
+
370
+ # @return [VPCCollection] A collection representing
371
+ # all VPCs in your account.
372
+ def vpcs
373
+ VPCCollection.new(:config => config)
374
+ end
375
+
376
+ # @return [SubnetCollection] Returns a collection that represents all
377
+ # of the subnets associated with this account (across all VPCs).
378
+ def subnets
379
+ SubnetCollection.new(:config => config)
380
+ end
381
+
382
+ # @return [NetworkACLCollection] Returns a collection that represents
383
+ # all of the network ACLs for this account.
384
+ def network_acls
385
+ NetworkACLCollection.new(:config => config)
386
+ end
387
+
388
+ # @return [RouteTableCollection] Returns a collection that represents
389
+ # all of the route tables for this account.
390
+ def route_tables
391
+ RouteTableCollection.new(:config => config)
392
+ end
393
+
394
+ # @return [NetworkInterfaceCollection] Returns a collection that
395
+ # represents all of the network interfaces for this account.
396
+ def network_interfaces
397
+ NetworkInterfaceCollection.new(:config => config)
398
+ end
399
+
400
+ # @return [InternetGatewayCollection] Returns a collection that
401
+ # represents all of the internet gateways for this account.
402
+ def internet_gateways
403
+ InternetGatewayCollection.new(:config => config)
404
+ end
405
+
406
+ # @return [CustomerGatewayCollection] Returns a collection that
407
+ # represents all of the customer gateways for this account.
408
+ def customer_gateways
409
+ CustomerGatewayCollection.new(:config => config)
410
+ end
411
+
412
+ # @return [VPNGatewayCollection] Returns a collection that
413
+ # represents all of the vpn gateways for this account.
414
+ def vpn_gateways
415
+ VPNGatewayCollection.new(:config => config)
416
+ end
417
+
418
+ # @return [DHCPOptionsCollection] Returns a collection that
419
+ # represents all of the dhcp options for this account.
420
+ def dhcp_options
421
+ DHCPOptionsCollection.new(:config => config)
422
+ end
423
+
424
+ # @return [VPNConnections] Returns a collection that
425
+ # represents all of vpn connections for this account.
426
+ def vpn_connections
427
+ VPNConnectionCollection.new(:config => config)
428
+ end
429
+
430
+ end
431
+ end