aws_sdk 3.1.5

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
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