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,72 @@
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 CloudFormation
16
+
17
+ # = Stack Resource Summaries
18
+ #
19
+ # Stack summaries contain information about CloudFormation
20
+ # stack resources. You can enumerate these from a stack.
21
+ #
22
+ # stack = cfm.stacks['stack-name']
23
+ # stack.resource_summaries.each do |summary|
24
+ # puts "#{summary[:physical_resource_id]}: #{summary[:resource_status]}"
25
+ # end
26
+ #
27
+ # Each summary yielded is a hash with the following keys:
28
+ #
29
+ # * +:logical_resource_id+
30
+ # * +:physical_resource_id+
31
+ # * +:resource_type+
32
+ # * +:resource_status+
33
+ # * +:resource_status_reason+
34
+ # * +:last_updated_timestamp+
35
+ #
36
+ class StackResourceSummaryCollection
37
+
38
+ include Core::Collection::Simple
39
+
40
+ # @param [Stack] stack
41
+ # @param [Hash] options
42
+ def initialize stack, options = {}
43
+ @stack = stack
44
+ super
45
+ end
46
+
47
+ # @return [Stack]
48
+ attr_reader :stack
49
+
50
+ protected
51
+
52
+ def _each_item options = {}
53
+ next_token = nil
54
+ begin
55
+
56
+ options = {}
57
+ options[:next_token] = next_token if next_token
58
+ options[:stack_name] = stack.name
59
+ resp = client.list_stack_resources(options)
60
+
61
+ resp.stack_resource_summaries.each do |summary|
62
+ yield(summary.to_hash)
63
+ end
64
+
65
+ next_token = resp.data[:next_token]
66
+
67
+ end while next_token
68
+ end
69
+
70
+ end
71
+ end
72
+ end
@@ -0,0 +1,71 @@
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 CloudFormation
16
+
17
+ # A stack summary contains some information about a stack. You
18
+ # can get summary information on any stack (including stacks
19
+ # deleted within the last 90 days).
20
+ #
21
+ # To get summary information, enumerate the summaries on an
22
+ # AWS::CloudFormation object:
23
+ #
24
+ # cf = AWS::CloudFormation.new
25
+ # cf.stack_summaries.each do |summary|
26
+ # puts "#{summary.stack_name} : #{summary.stack_status}"
27
+ # end
28
+ #
29
+ # You can get the full {Stack} object from a summary by calling
30
+ # {#stack}.
31
+ #
32
+ class StackSummary
33
+
34
+ # @private
35
+ def initialize stack, details
36
+ @stack = stack
37
+ details.each_pair do |attr_name,attr_value|
38
+ instance_variable_set("@#{attr_name}", attr_value)
39
+ end
40
+ end
41
+
42
+ # @return [Stack]
43
+ attr_reader :stack
44
+
45
+ # @return [Time]
46
+ attr_reader :creation_time
47
+
48
+ # @return [Time,nil]
49
+ attr_reader :last_updated_time
50
+
51
+ # @return [String]
52
+ attr_reader :stack_name
53
+
54
+ # @return [String]
55
+ attr_reader :stack_id
56
+
57
+ # @return [String]
58
+ attr_reader :stack_status
59
+
60
+ # @return [String]
61
+ attr_reader :stack_status_reason
62
+
63
+ # @return [Time,nil]
64
+ attr_reader :deletion_time
65
+
66
+ # @return [Strin]
67
+ attr_reader :template_description
68
+
69
+ end
70
+ end
71
+ end
@@ -0,0 +1,127 @@
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 CloudFormation
16
+
17
+ # = Stack Summaries
18
+ #
19
+ # Stack summaries contain information about CloudFormation
20
+ # stacks. You can filter the stacks you want summary information
21
+ # for by one or more statuses. You can even get information
22
+ # about deleted stacks for up to 90 days.
23
+ #
24
+ # == Enumerating Stack Summaries
25
+ #
26
+ # You can enumerate all available summaries using enumerable
27
+ # methods. Yielded summaries are simple hashes.
28
+ #
29
+ # cfm = AWS::CloudFormation.new
30
+ # cfm.stack_summaries.each do |summary|
31
+ # puts summary.to_yaml
32
+ # end
33
+ #
34
+ # == Filtering Stack Summaries
35
+ #
36
+ # You can optionally provide one or more stack stasus values
37
+ # to filter the results by. Only stacks with the given status(es)
38
+ # will be enumerated.
39
+ #
40
+ # cfm.stack_summaries.with_status(:create_failed).each do |summary|
41
+ # # ...
42
+ # end
43
+ #
44
+ # # enumerate stacks with various delete statuses
45
+ # statuses = %w(delete_in_progress delete_failed delete_complete)
46
+ # cf.stack_summaries.with_status(statuses).each do |summary|
47
+ # # ...
48
+ # end
49
+ #
50
+ class StackSummaryCollection
51
+
52
+ include Core::Collection::Simple
53
+
54
+ # @private
55
+ def initialize options = {}
56
+ @filters = options[:filters]
57
+ super
58
+ end
59
+
60
+ # Limits the stacks summaries that are enumerated.
61
+ #
62
+ # cfm.stack_summaries.with_status(:create_complete).each do |summary|
63
+ # puts summary[:stack_name]
64
+ # end
65
+ #
66
+ # You can provide multiple statuses:
67
+ #
68
+ # statuses = [:create_failed, :rollback_failed]
69
+ # cfm.stack_summaries.with_status(statuses).each do |summary|
70
+ # puts summary[:stack_name]
71
+ # end
72
+ #
73
+ # Status names may be symbolized (snake-cased) or upper-cased strings
74
+ # (e.g. :create_in_progress, 'CREATE_IN_PROGRESS').
75
+ #
76
+ # @param [Symbol,String] status_filters One or more statuses to filter
77
+ # stacks with. Valid values include:
78
+ # * +:create_in_progress+
79
+ # * +:create_failed+
80
+ # * +:create_complete+
81
+ # * +:rollback_in_progress+
82
+ # * +:rollback_failed+
83
+ # * +:rollback_complete+
84
+ # * +:delete_in_progress+
85
+ # * +:delete_failed+
86
+ # * +:delete_complete+
87
+ # * +:update_in_progress+
88
+ # * +:update_complete_cleanup_in_progress+
89
+ # * +:update_complete+
90
+ # * +:update_rollback_in_progress+
91
+ # * +:update_rollback_failed+
92
+ # * +:update_rollback_complete_cleanup_in_progress+
93
+ # * +:update_rollback_complete+
94
+ #
95
+ # @return [StackSummaryCollection] Returns a new stack summary
96
+ # collection that restricts what stack summariess will be
97
+ # enumerated.
98
+ #
99
+ def with_status *status_filters
100
+ StackSummaryCollection.new(
101
+ :filters => status_filters.flatten.map(&:to_s).map(&:upcase),
102
+ :config => config)
103
+ end
104
+
105
+ protected
106
+
107
+ def _each_item options = {}
108
+ next_token = nil
109
+ begin
110
+
111
+ client_opts = {}
112
+ client_opts[:next_token] = next_token if next_token
113
+ client_opts[:stack_status_filter] = @filters if @filters
114
+ resp = client.list_stacks(client_opts)
115
+
116
+ resp.stack_summaries.each do |summary|
117
+ yield(summary.to_hash)
118
+ end
119
+
120
+ next_token = resp.data[:next_token]
121
+
122
+ end while next_token
123
+ end
124
+
125
+ end
126
+ end
127
+ end
@@ -0,0 +1,474 @@
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/autoloader'
15
+
16
+ # AWS is the root module for all of the Amazon Web Services. It is also
17
+ # where you can configure you access to AWS.
18
+ #
19
+ # = Supported Services
20
+ #
21
+ # The currently supported services are:
22
+ #
23
+ # * {AWS::AutoScaling}
24
+ # * {AWS::CloudFormation}
25
+ # * {AWS::DynamoDB}
26
+ # * {AWS::EC2}
27
+ # * {AWS::ELB}
28
+ # * {AWS::IAM}
29
+ # * {AWS::S3}
30
+ # * {AWS::SNS}
31
+ # * {AWS::SQS}
32
+ # * {AWS::STS}
33
+ # * {AWS::SimpleDB}
34
+ # * {AWS::SimpleEmailService}
35
+ # * {AWS::SimpleWorkflow}
36
+ #
37
+ # = AWS::Record
38
+ #
39
+ # In addition to the above services, bundled is an ORM based on AWS services
40
+ # See {AWS::Record} for more information.
41
+ #
42
+ # = Configuration
43
+ #
44
+ # You call {AWS.config} with a hash of options to configure your
45
+ # access to the Amazon Web Services.
46
+ #
47
+ # At a minimum you need to set your access credentials. See {AWS.config}
48
+ # for additional configuration options.
49
+ #
50
+ # AWS.config(
51
+ # :access_key_id => 'ACCESS_KEY_ID',
52
+ # :secret_access_key => 'SECRET_ACCESS_KEY')
53
+ #
54
+ # == Rails
55
+ #
56
+ # If you are loading AWS inside a Rails web application, it is recomended to
57
+ # place your configuration inside:
58
+ #
59
+ # config/initializers/aws.rb
60
+ #
61
+ module AWS
62
+
63
+ # Current version of the AWS SDK for Ruby
64
+ VERSION = "1.5.2"
65
+
66
+ register_autoloads(self) do
67
+ autoload :Errors, 'errors'
68
+ end
69
+
70
+ module Core
71
+
72
+ AWS.register_autoloads(self) do
73
+ autoload :AsyncHandle, 'async_handle'
74
+ autoload :Cacheable, 'cacheable'
75
+ autoload :Client, 'client'
76
+ autoload :Collection, 'collection'
77
+ autoload :Configuration, 'configuration'
78
+ autoload :Data, 'data'
79
+ autoload :DefaultSigner, 'default_signer'
80
+ autoload :IndifferentHash, 'indifferent_hash'
81
+ autoload :Inflection, 'inflection'
82
+ autoload :LazyErrorClasses, 'lazy_error_classes'
83
+ autoload :LogFormatter, 'log_formatter'
84
+ autoload :MetaUtils, 'meta_utils'
85
+ autoload :Model, 'model'
86
+ autoload :Naming, 'naming'
87
+ autoload :OptionGrammar, 'option_grammar'
88
+ autoload :PageResult, 'page_result'
89
+ autoload :Policy, 'policy'
90
+ autoload :Resource, 'resource'
91
+ autoload :ResourceCache, 'resource_cache'
92
+ autoload :Response, 'response'
93
+ autoload :ResponseCache, 'response_cache'
94
+ autoload :ServiceInterface, 'service_interface'
95
+ autoload :SessionSigner, 'session_signer'
96
+ autoload :UriEscape, 'uri_escape'
97
+ end
98
+
99
+ module Signature
100
+ AWS.register_autoloads(self) do
101
+ autoload :Version2, 'version_2'
102
+ autoload :Version3, 'version_3'
103
+ autoload :Version4, 'version_4'
104
+ end
105
+ end
106
+
107
+ module XML
108
+ AWS.register_autoloads(self) do
109
+ autoload :Parser, 'parser'
110
+ autoload :Grammar, 'grammar'
111
+ autoload :Stub, 'stub'
112
+ autoload :Frame, 'frame'
113
+ autoload :RootFrame, 'root_frame'
114
+ autoload :FrameStack, 'frame_stack'
115
+ end
116
+
117
+ module SaxHandlers
118
+ AWS.register_autoloads(self, 'aws/core/xml/sax_handlers') do
119
+ autoload :Nokogiri, 'nokogiri'
120
+ autoload :REXML, 'rexml'
121
+ end
122
+ end
123
+
124
+ end
125
+
126
+ module Http
127
+ AWS.register_autoloads(self) do
128
+ autoload :Handler, 'handler'
129
+ autoload :NetHttpHandler, 'net_http_handler'
130
+ autoload :HTTPartyHandler, 'httparty_handler' # non-standard inflection
131
+ autoload :Request, 'request'
132
+ autoload :Response, 'response'
133
+ end
134
+ end
135
+
136
+ end
137
+
138
+ # the http party handler should still be accessible from its old namespace
139
+ module Http
140
+ AWS.register_autoloads(self, 'aws/core/http') do
141
+ autoload :HTTPartyHandler, 'httparty_handler'
142
+ end
143
+ end
144
+
145
+ class << self
146
+
147
+ # @private
148
+ @@config = nil
149
+
150
+ # The global configuration for AWS. Generally you set your prefered
151
+ # configuration operations once after loading the aws-sdk gem.
152
+ #
153
+ # AWS.config({
154
+ # :access_key_id => 'ACCESS_KEY_ID',
155
+ # :secret_access_key => 'SECRET_ACCESS_KEY',
156
+ # :simple_db_endpoint => 'sdb.us-west-1.amazonaws.com',
157
+ # :max_retries => 2,
158
+ # })
159
+ #
160
+ # When using AWS classes they will always default to use configuration
161
+ # values defined in {AWS.config}.
162
+ #
163
+ # AWS.config(:max_retries => 2)
164
+ #
165
+ # sqs = AWS::SQS.new
166
+ # sqs.config.max_retries #=> 2
167
+ #
168
+ # If you want to change a configuration value for a single instance you
169
+ # pass the new configuration value to that object's initializer:
170
+ #
171
+ # AWS::SQS.new(:max_retries => 0)
172
+ #
173
+ # @note Changing the global configuration does not affect objects
174
+ # that have already been constructed.
175
+ #
176
+ # @param [Hash] options
177
+ #
178
+ # @option options [String] :access_key_id (nil) AWS access key id
179
+ # credential.
180
+ #
181
+ # @option options [String] :secret_access_key (nil) AWS secret access
182
+ # key credential.
183
+ #
184
+ # @option options [String,nil] :session_token (nil) AWS secret token
185
+ # credential.
186
+ #
187
+ # @option options [String] :auto_scaling_endpoint ('autoscaling.us-east-1.amazonaws.com')
188
+ # The service endpoint for Auto Scaling.
189
+ #
190
+ # @option options [String] :cloud_formation_endpoint ('cloudformation.us-east-1.amazonaws.com')
191
+ # The service endpoint for AWS CloudFormation.
192
+ #
193
+ # @option options [String] :dynamo_db_endpoint ('dynamodb.amazonaws.com')
194
+ # The service endpoint for Amazon DynamoDB.
195
+ #
196
+ # @option options [String] :dynamo_db_retry_throughput_errors (true) When
197
+ # true, AWS::DynamoDB::Errors::ProvisionedThroughputExceededException
198
+ # errors will be retried.
199
+ #
200
+ # @option options [String] :ec2_endpoint ('ec2.amazonaws.com') The
201
+ # service endpoint for Amazon EC2.
202
+ #
203
+ # @option options [String] :elb_endpoint ('elasticloadbalancing.us-east-1.amazonaws.com')
204
+ # The server endpoint for Elastic Load Balancing.
205
+ #
206
+ # @option options [Object] :http_handler (AWS::HTTPartyHandler) The
207
+ # http handler that sends requests to AWS.
208
+ #
209
+ # @option options [String] :iam_endpoint ('iam.amazonaws.com') The
210
+ # service endpoint for AWS Idenity Access Management (IAM).
211
+ #
212
+ # @option options [Logger,nil] :logger (nil) A logger to send
213
+ # log messages to. Here is an example that logs to standard out.
214
+ #
215
+ # require 'logger'
216
+ # AWS.config(:logger => Logger.new($stdout))
217
+ #
218
+ # @option options [Symbol] :log_level (:info) The level log messages are
219
+ # sent to the logger with (e.g. +:notice+, +:info+, +:warn+,
220
+ # +:debug+, etc).
221
+ #
222
+ # @option options [Object] :log_formatter The log formatter is responsible
223
+ # for building log messages from responses. You can quickly change
224
+ # log formats by providing a canned log formatter.
225
+ #
226
+ # AWS.config(:log_formatter => AWS::Core::LogFormatter.colored)
227
+ #
228
+ # Here is the complete list of canned log formatters:
229
+ #
230
+ # * +AWS::Core::LogFormatter.default+
231
+ # * +AWS::Core::LogFormatter.short+
232
+ # * +AWS::Core::LogFormatter.debug+
233
+ # * +AWS::Core::LogFormatter.colored+
234
+ #
235
+ # You can also create an instance of AWS::Core::LogFormatter
236
+ # with a custom log message pattern. See {Core::LogFormatter} for
237
+ # a complete list of pattern substituions.
238
+ #
239
+ # pattern = "[AWS :operation :duration] :error_message"
240
+ # AWS.config(:log_formatter => AWS::Core::LogFormatter.new(pattern))
241
+ #
242
+ # Lastly you can pass any object that responds to +#format+ accepting
243
+ # and instance of {Core::Response} and returns a string.
244
+ #
245
+ # @option options [Integer] :max_retries (3) The maximum number of times
246
+ # service errors (500) should be retried. There is an exponential
247
+ # backoff in between service request retries, so the more retries the
248
+ # longer it can take to fail.
249
+ #
250
+ # @option options [String, URI, nil] :proxy_uri (nil) The URI of the proxy
251
+ # to send service requests through. You can pass a URI object or a
252
+ # URI string:
253
+ #
254
+ # AWS.config(:proxy_uri => 'https://user:password@my.proxy:443/path?query')
255
+ #
256
+ # @option options [String] :s3_endpoint ('s3.amazonaws.com') The
257
+ # service endpoint for Amazon S3.
258
+ #
259
+ # @option options [Integer] :s3_multipart_max_parts (1000) The maximum
260
+ # number of parts to split a file into when uploading in parts to S3.
261
+ #
262
+ # @option options [Integer] :s3_multipart_threshold (16777216) When
263
+ # uploading data to S3, if the number of bytes to send exceedes
264
+ # +:s3_multipart_threshold+ then a multi part session is automatically
265
+ # started and the data is sent up in chunks. The size of each part
266
+ # is specified by +:s3_multipart_min_part_size+. Defaults to
267
+ # 16777216 (16MB).
268
+ #
269
+ # @option options [Integer] :s3_multipart_min_part_size (5242880) The
270
+ # absolute minimum size (in bytes) each S3 multipart segment should be.
271
+ # Defaults to 5242880 (5MB).
272
+ #
273
+ # @option options [Symbol] :s3_server_side_encryption (nil) The
274
+ # algorithm to use when encrypting object data on the server
275
+ # side. The only valid value is +:aes256+, which specifies that
276
+ # the object should be stored using the AES encryption algorithm
277
+ # with 256 bit keys. Defaults to +nil+, meaning server side
278
+ # encryption is not used unless specified on each individual
279
+ # call to upload an object. This option controls the default
280
+ # behavior for the following methods:
281
+ #
282
+ # * {S3::S3Object#write}
283
+ # * {S3::S3Object#multipart_upload}
284
+ # * {S3::S3Object#copy_from} and {S3::S3Object#copy_to}
285
+ # * {S3::S3Object#presigned_post}
286
+ # * {S3::Bucket#presigned_post}
287
+ #
288
+ # @option options [String] :simple_db_endpoint ('sdb.amazonaws.com') The
289
+ # service endpoint for Amazon SimpleDB.
290
+ #
291
+ # @option options [Boolean] :simple_db_consistent_reads (false) Determines
292
+ # if all SimpleDB read requests should be done consistently.
293
+ # Consistent reads are slower, but reflect all changes to SDB.
294
+ #
295
+ # @option options [String] :simple_email_service_endpoint ('email.us-east-1.amazonaws.com')
296
+ # The service endpoint for Amazon Simple Email Service.
297
+ #
298
+ # @option options [String] :simple_workflow_service ('swf.us-east-1.amazonaws.com')
299
+ # The service endpoint for Amazon Simple Workflow Service.
300
+ #
301
+ # @option options [Object] :signer (AWS::DefaultSigner) The request signer. Defaults to
302
+ # a default request signer implementation.
303
+ #
304
+ # @option options [String] :ssl_ca_file The path to a CA cert bundle in
305
+ # PEM format.
306
+ #
307
+ # If +:ssl_verify_peer+ is +true+ (the default) this bundle will be
308
+ # used to validate the server certificate in each HTTPS request.
309
+ # The AWS SDK for Ruby ships with a CA cert bundle, which is the
310
+ # default value for this option.
311
+ #
312
+ # @option options [String] :ssl_ca_path (nil)
313
+ # The path the a CA cert directory.
314
+ #
315
+ # @option options [Boolean] :ssl_verify_peer (true) When +true+
316
+ # the HTTP handler validate server certificates for HTTPS requests.
317
+ #
318
+ # This option should only be disabled for diagnostic purposes;
319
+ # leaving this option set to +false+ exposes your application to
320
+ # man-in-the-middle attacks and can pose a serious security
321
+ # risk.
322
+ #
323
+ # @option options[Boolean] :stub_requests (false) When +true+ requests
324
+ # are not sent to AWS, instead empty reponses are generated and
325
+ # returned to each service request.
326
+ #
327
+ # @option options [String] :sns_endpoint ('sns.us-east-1.amazonaws.com') The
328
+ # service endpoint for Amazon SNS.
329
+ #
330
+ # @option options [String] :sqs_endpoint ('sqs.us-east-1.amazonaws.com') The
331
+ # service endpoint for Amazon SQS.
332
+ #
333
+ # @option options [String] :sts_endpoint ('sts.amazonaws.com') The
334
+ # service endpoint for AWS Security Token Service.
335
+ #
336
+ # @option options [Boolean] :use_ssl (true) When +true+, all requests
337
+ # to AWS are sent using HTTPS instead vanilla HTTP.
338
+ #
339
+ # @option options [String] :user_agent_prefix (nil) A string prefix to
340
+ # append to all requets against AWS services. This should be set
341
+ # for clients and applications built ontop of the aws-sdk gem.
342
+ #
343
+ # @return [Core::Configuration] Returns the new configuration.
344
+ #
345
+ def config options = {}
346
+ @@config ||= Core::Configuration.new
347
+ @@config = @@config.with(options) unless options.empty?
348
+ @@config
349
+ end
350
+
351
+ # @note Memoization is currently only supported for the EC2 APIs;
352
+ # other APIs are unaffected by the status of memoization. To
353
+ # protect your code from future changes in memoization support,
354
+ # you should not enable memoization while calling non-EC2 APIs.
355
+ #
356
+ # Starts memoizing service requests made in the current thread.
357
+ # See {memoize} for a full discussion of the memoization feature.
358
+ # This has no effect if memoization is already enabled.
359
+ def start_memoizing
360
+ Thread.current[:aws_memoization] ||= {}
361
+ nil
362
+ end
363
+
364
+ # @note Memoization is currently only supported for the EC2 APIs;
365
+ # other APIs are unaffected by the status of memoization. To
366
+ # protect your code from future changes in memoization support,
367
+ # you should not enable memoization while calling non-EC2 APIs.
368
+ #
369
+ # Stops memoizing service requests made in the current thread.
370
+ # See {memoize} for a full discussion of the memoization feature.
371
+ # This has no effect if memoization is already disabled.
372
+ def stop_memoizing
373
+ Thread.current[:aws_memoization] = nil
374
+ end
375
+
376
+ # @note Memoization is currently only supported for the EC2 APIs;
377
+ # other APIs are unaffected by the status of memoization. To
378
+ # protect your code from future changes in memoization support,
379
+ # you should not enable memoization while calling non-EC2 APIs.
380
+ #
381
+ # @return [Boolean] True if memoization is enabled for the current
382
+ # thread. See {memoize} for a full discussion of the
383
+ # memoization feature.
384
+ def memoizing?
385
+ !Thread.current[:aws_memoization].nil?
386
+ end
387
+
388
+ # @note Memoization is currently only supported for the EC2 APIs;
389
+ # other APIs are unaffected by the status of memoization. To
390
+ # protect your code from future changes in memoization support,
391
+ # you should not enable memoization while calling non-EC2 APIs.
392
+ #
393
+ # Enables memoization for the current thread, within a block.
394
+ # Memoization lets you avoid making multiple requests for the same
395
+ # data by reusing the responses which have already been received.
396
+ # For example, consider the following code to get the most
397
+ # recently launched EC2 instance:
398
+ #
399
+ # latest = ec2.instances.sort_by(&:launch_time).last
400
+ #
401
+ # The above code would make N+1 requests (where N is the number of
402
+ # instances in the account); iterating the collection of instances
403
+ # is one request, and +Enumerable#sort_by+ calls
404
+ # {AWS::EC2::Instance#launch_time} for each instance, causing
405
+ # another request per instance. We can rewrite the code as
406
+ # follows to make only one request:
407
+ #
408
+ # latest = AWS.memoize do
409
+ # ec2.instances.sort_by(&:launch_time).last
410
+ # end
411
+ #
412
+ # Iterating the collection still causes a request, but each
413
+ # subsequent call to {AWS::EC2::Instance#launch_time} uses the
414
+ # results from that first request rather than making a new request
415
+ # for the same data.
416
+ #
417
+ # While memoization is enabled, every response that is received
418
+ # from the service is retained in memory. Therefore you should
419
+ # use memoization only for short-lived blocks of code that make
420
+ # relatively small numbers of requests. The cached responses are
421
+ # used in two ways while memoization is enabled:
422
+ #
423
+ # 1. Before making a request, the SDK checks the cache for a
424
+ # response to a request with the same signature (credentials,
425
+ # service endpoint, operation name, and parameters). If such a
426
+ # response is found, it is used instead of making a new
427
+ # request.
428
+ #
429
+ # 2. Before retrieving data for an attribute of a resource
430
+ # (e.g. {AWS::EC2::Instance#launch_time}), the SDK attempts to
431
+ # find a cached response that contains the requested data. If
432
+ # such a response is found, the cached data is returned instead
433
+ # of making a new request.
434
+ #
435
+ # When memoization is disabled, all previously cached responses
436
+ # are discarded.
437
+ def memoize
438
+ return yield if memoizing?
439
+
440
+ begin
441
+ start_memoizing
442
+ yield if block_given?
443
+ ensure
444
+ stop_memoizing
445
+ end
446
+ end
447
+
448
+ # @private
449
+ def resource_cache
450
+ if memoizing?
451
+ Thread.current[:aws_memoization][:resource_cache] ||=
452
+ Core::ResourceCache.new
453
+ end
454
+ end
455
+
456
+ # @private
457
+ def response_cache
458
+ if memoizing?
459
+ Thread.current[:aws_memoization][:response_cache] ||=
460
+ Core::ResponseCache.new
461
+ end
462
+ end
463
+
464
+ # Causes all requests to return empty responses without making any
465
+ # requests against the live services. This does not attempt to
466
+ # mock the services.
467
+ # @return [nil]
468
+ def stub!
469
+ config(:stub_requests => true)
470
+ nil
471
+ end
472
+
473
+ end
474
+ end