aws_sdk 3.1.5

Sign up to get free protection for your applications and to get access to all the features.
Files changed (390) hide show
  1. data/lib/aws-sdk.rb +14 -0
  2. data/lib/aws.rb +49 -0
  3. data/lib/aws/api_config/AutoScaling-2011-01-01.yml +791 -0
  4. data/lib/aws/api_config/CloudFormation-2010-05-15.yml +303 -0
  5. data/lib/aws/api_config/DynamoDB-2011-12-05.yml +540 -0
  6. data/lib/aws/api_config/EC2-2011-12-15.yml +3638 -0
  7. data/lib/aws/api_config/EC2-2012-04-01.yml +3739 -0
  8. data/lib/aws/api_config/ELB-2011-08-15.yml +512 -0
  9. data/lib/aws/api_config/IAM-2010-05-08.yml +1221 -0
  10. data/lib/aws/api_config/SNS-2010-03-31.yml +248 -0
  11. data/lib/aws/api_config/SQS-2011-10-01.yml +314 -0
  12. data/lib/aws/api_config/STS-2011-06-15.yml +54 -0
  13. data/lib/aws/api_config/SimpleDB-2009-04-15.yml +305 -0
  14. data/lib/aws/api_config/SimpleEmailService-2010-12-01.yml +231 -0
  15. data/lib/aws/api_config/SimpleWorkflow-2012-01-25.yml +721 -0
  16. data/lib/aws/auto_scaling.rb +162 -0
  17. data/lib/aws/auto_scaling/activity.rb +102 -0
  18. data/lib/aws/auto_scaling/activity_collection.rb +82 -0
  19. data/lib/aws/auto_scaling/client.rb +765 -0
  20. data/lib/aws/auto_scaling/config.rb +18 -0
  21. data/lib/aws/auto_scaling/errors.rb +22 -0
  22. data/lib/aws/auto_scaling/group.rb +420 -0
  23. data/lib/aws/auto_scaling/group_collection.rb +96 -0
  24. data/lib/aws/auto_scaling/group_options.rb +146 -0
  25. data/lib/aws/auto_scaling/instance.rb +192 -0
  26. data/lib/aws/auto_scaling/instance_collection.rb +63 -0
  27. data/lib/aws/auto_scaling/launch_configuration.rb +150 -0
  28. data/lib/aws/auto_scaling/launch_configuration_collection.rb +144 -0
  29. data/lib/aws/auto_scaling/notification_configuration.rb +89 -0
  30. data/lib/aws/auto_scaling/notification_configuration_collection.rb +184 -0
  31. data/lib/aws/auto_scaling/request.rb +23 -0
  32. data/lib/aws/auto_scaling/scaling_policy.rb +125 -0
  33. data/lib/aws/auto_scaling/scaling_policy_collection.rb +72 -0
  34. data/lib/aws/auto_scaling/scaling_policy_options.rb +61 -0
  35. data/lib/aws/auto_scaling/scheduled_action.rb +145 -0
  36. data/lib/aws/auto_scaling/scheduled_action_collection.rb +195 -0
  37. data/lib/aws/auto_scaling/tag.rb +59 -0
  38. data/lib/aws/auto_scaling/tag_collection.rb +112 -0
  39. data/lib/aws/cloud_formation.rb +270 -0
  40. data/lib/aws/cloud_formation/client.rb +339 -0
  41. data/lib/aws/cloud_formation/config.rb +18 -0
  42. data/lib/aws/cloud_formation/errors.rb +22 -0
  43. data/lib/aws/cloud_formation/request.rb +29 -0
  44. data/lib/aws/cloud_formation/stack.rb +256 -0
  45. data/lib/aws/cloud_formation/stack_collection.rb +206 -0
  46. data/lib/aws/cloud_formation/stack_event.rb +75 -0
  47. data/lib/aws/cloud_formation/stack_event_collection.rb +47 -0
  48. data/lib/aws/cloud_formation/stack_options.rb +72 -0
  49. data/lib/aws/cloud_formation/stack_output.rb +53 -0
  50. data/lib/aws/cloud_formation/stack_resource.rb +117 -0
  51. data/lib/aws/cloud_formation/stack_resource_collection.rb +84 -0
  52. data/lib/aws/cloud_formation/stack_resource_summary_collection.rb +72 -0
  53. data/lib/aws/cloud_formation/stack_summary.rb +71 -0
  54. data/lib/aws/cloud_formation/stack_summary_collection.rb +127 -0
  55. data/lib/aws/core.rb +474 -0
  56. data/lib/aws/core/async_handle.rb +90 -0
  57. data/lib/aws/core/autoloader.rb +64 -0
  58. data/lib/aws/core/cacheable.rb +78 -0
  59. data/lib/aws/core/client.rb +541 -0
  60. data/lib/aws/core/client/query_json.rb +110 -0
  61. data/lib/aws/core/client/query_xml.rb +122 -0
  62. data/lib/aws/core/collection.rb +234 -0
  63. data/lib/aws/core/collection/limitable.rb +99 -0
  64. data/lib/aws/core/collection/simple.rb +90 -0
  65. data/lib/aws/core/configuration.rb +445 -0
  66. data/lib/aws/core/data.rb +242 -0
  67. data/lib/aws/core/default_signer.rb +67 -0
  68. data/lib/aws/core/http/curb_handler.rb +136 -0
  69. data/lib/aws/core/http/handler.rb +77 -0
  70. data/lib/aws/core/http/httparty_handler.rb +114 -0
  71. data/lib/aws/core/http/net_http_handler.rb +85 -0
  72. data/lib/aws/core/http/request.rb +250 -0
  73. data/lib/aws/core/http/response.rb +74 -0
  74. data/lib/aws/core/indifferent_hash.rb +88 -0
  75. data/lib/aws/core/inflection.rb +47 -0
  76. data/lib/aws/core/lazy_error_classes.rb +90 -0
  77. data/lib/aws/core/log_formatter.rb +454 -0
  78. data/lib/aws/core/meta_utils.rb +45 -0
  79. data/lib/aws/core/model.rb +57 -0
  80. data/lib/aws/core/naming.rb +30 -0
  81. data/lib/aws/core/option_grammar.rb +700 -0
  82. data/lib/aws/core/page_result.rb +73 -0
  83. data/lib/aws/core/policy.rb +916 -0
  84. data/lib/aws/core/resource.rb +408 -0
  85. data/lib/aws/core/resource_cache.rb +40 -0
  86. data/lib/aws/core/response.rb +202 -0
  87. data/lib/aws/core/response_cache.rb +50 -0
  88. data/lib/aws/core/service_interface.rb +61 -0
  89. data/lib/aws/core/session_signer.rb +90 -0
  90. data/lib/aws/core/signature/version_2.rb +42 -0
  91. data/lib/aws/core/signature/version_3.rb +73 -0
  92. data/lib/aws/core/signature/version_3_http.rb +72 -0
  93. data/lib/aws/core/signature/version_4.rb +138 -0
  94. data/lib/aws/core/uri_escape.rb +42 -0
  95. data/lib/aws/core/xml/frame.rb +242 -0
  96. data/lib/aws/core/xml/frame_stack.rb +85 -0
  97. data/lib/aws/core/xml/grammar.rb +299 -0
  98. data/lib/aws/core/xml/parser.rb +70 -0
  99. data/lib/aws/core/xml/root_frame.rb +65 -0
  100. data/lib/aws/core/xml/sax_handlers/libxml.rb +47 -0
  101. data/lib/aws/core/xml/sax_handlers/nokogiri.rb +55 -0
  102. data/lib/aws/core/xml/sax_handlers/ox.rb +41 -0
  103. data/lib/aws/core/xml/sax_handlers/rexml.rb +43 -0
  104. data/lib/aws/core/xml/stub.rb +123 -0
  105. data/lib/aws/dynamo_db.rb +213 -0
  106. data/lib/aws/dynamo_db/attribute_collection.rb +460 -0
  107. data/lib/aws/dynamo_db/batch_get.rb +206 -0
  108. data/lib/aws/dynamo_db/batch_write.rb +251 -0
  109. data/lib/aws/dynamo_db/client.rb +888 -0
  110. data/lib/aws/dynamo_db/config.rb +20 -0
  111. data/lib/aws/dynamo_db/errors.rb +20 -0
  112. data/lib/aws/dynamo_db/expectations.rb +40 -0
  113. data/lib/aws/dynamo_db/item.rb +130 -0
  114. data/lib/aws/dynamo_db/item_collection.rb +852 -0
  115. data/lib/aws/dynamo_db/item_data.rb +31 -0
  116. data/lib/aws/dynamo_db/keys.rb +41 -0
  117. data/lib/aws/dynamo_db/primary_key_element.rb +47 -0
  118. data/lib/aws/dynamo_db/request.rb +28 -0
  119. data/lib/aws/dynamo_db/resource.rb +33 -0
  120. data/lib/aws/dynamo_db/table.rb +489 -0
  121. data/lib/aws/dynamo_db/table_collection.rb +165 -0
  122. data/lib/aws/dynamo_db/types.rb +86 -0
  123. data/lib/aws/ec2.rb +431 -0
  124. data/lib/aws/ec2/attachment.rb +140 -0
  125. data/lib/aws/ec2/attachment_collection.rb +54 -0
  126. data/lib/aws/ec2/availability_zone.rb +87 -0
  127. data/lib/aws/ec2/availability_zone_collection.rb +43 -0
  128. data/lib/aws/ec2/block_device_mappings.rb +53 -0
  129. data/lib/aws/ec2/client.rb +4121 -0
  130. data/lib/aws/ec2/collection.rb +36 -0
  131. data/lib/aws/ec2/config.rb +18 -0
  132. data/lib/aws/ec2/config_transform.rb +63 -0
  133. data/lib/aws/ec2/customer_gateway.rb +90 -0
  134. data/lib/aws/ec2/customer_gateway_collection.rb +73 -0
  135. data/lib/aws/ec2/dhcp_options.rb +106 -0
  136. data/lib/aws/ec2/dhcp_options_collection.rb +87 -0
  137. data/lib/aws/ec2/elastic_ip.rb +157 -0
  138. data/lib/aws/ec2/elastic_ip_collection.rb +97 -0
  139. data/lib/aws/ec2/errors.rb +32 -0
  140. data/lib/aws/ec2/filtered_collection.rb +90 -0
  141. data/lib/aws/ec2/has_permissions.rb +44 -0
  142. data/lib/aws/ec2/image.rb +254 -0
  143. data/lib/aws/ec2/image_collection.rb +228 -0
  144. data/lib/aws/ec2/instance.rb +669 -0
  145. data/lib/aws/ec2/instance_collection.rb +346 -0
  146. data/lib/aws/ec2/internet_gateway.rb +122 -0
  147. data/lib/aws/ec2/internet_gateway/attachment.rb +78 -0
  148. data/lib/aws/ec2/internet_gateway_collection.rb +54 -0
  149. data/lib/aws/ec2/key_pair.rb +82 -0
  150. data/lib/aws/ec2/key_pair_collection.rb +99 -0
  151. data/lib/aws/ec2/network_acl.rb +256 -0
  152. data/lib/aws/ec2/network_acl/association.rb +56 -0
  153. data/lib/aws/ec2/network_acl/entry.rb +147 -0
  154. data/lib/aws/ec2/network_acl_collection.rb +64 -0
  155. data/lib/aws/ec2/network_interface.rb +228 -0
  156. data/lib/aws/ec2/network_interface/attachment.rb +100 -0
  157. data/lib/aws/ec2/network_interface_collection.rb +103 -0
  158. data/lib/aws/ec2/permission_collection.rb +174 -0
  159. data/lib/aws/ec2/region.rb +97 -0
  160. data/lib/aws/ec2/region_collection.rb +51 -0
  161. data/lib/aws/ec2/request.rb +22 -0
  162. data/lib/aws/ec2/reserved_instances.rb +53 -0
  163. data/lib/aws/ec2/reserved_instances_collection.rb +40 -0
  164. data/lib/aws/ec2/reserved_instances_offering.rb +58 -0
  165. data/lib/aws/ec2/reserved_instances_offering_collection.rb +39 -0
  166. data/lib/aws/ec2/resource.rb +161 -0
  167. data/lib/aws/ec2/resource_tag_collection.rb +211 -0
  168. data/lib/aws/ec2/route_table.rb +205 -0
  169. data/lib/aws/ec2/route_table/association.rb +119 -0
  170. data/lib/aws/ec2/route_table/route.rb +113 -0
  171. data/lib/aws/ec2/route_table_collection.rb +72 -0
  172. data/lib/aws/ec2/security_group.rb +458 -0
  173. data/lib/aws/ec2/security_group/egress_ip_permission_collection.rb +63 -0
  174. data/lib/aws/ec2/security_group/ingress_ip_permission_collection.rb +61 -0
  175. data/lib/aws/ec2/security_group/ip_permission.rb +128 -0
  176. data/lib/aws/ec2/security_group_collection.rb +135 -0
  177. data/lib/aws/ec2/snapshot.rb +143 -0
  178. data/lib/aws/ec2/snapshot_collection.rb +131 -0
  179. data/lib/aws/ec2/subnet.rb +161 -0
  180. data/lib/aws/ec2/subnet_collection.rb +115 -0
  181. data/lib/aws/ec2/tag.rb +81 -0
  182. data/lib/aws/ec2/tag_collection.rb +107 -0
  183. data/lib/aws/ec2/tagged_collection.rb +53 -0
  184. data/lib/aws/ec2/tagged_item.rb +85 -0
  185. data/lib/aws/ec2/volume.rb +170 -0
  186. data/lib/aws/ec2/volume_collection.rb +97 -0
  187. data/lib/aws/ec2/vpc.rb +166 -0
  188. data/lib/aws/ec2/vpc_collection.rb +70 -0
  189. data/lib/aws/ec2/vpn_connection.rb +99 -0
  190. data/lib/aws/ec2/vpn_connection/telemetry.rb +49 -0
  191. data/lib/aws/ec2/vpn_connection_collection.rb +96 -0
  192. data/lib/aws/ec2/vpn_gateway.rb +123 -0
  193. data/lib/aws/ec2/vpn_gateway/attachment.rb +45 -0
  194. data/lib/aws/ec2/vpn_gateway_collection.rb +77 -0
  195. data/lib/aws/elb.rb +65 -0
  196. data/lib/aws/elb/availability_zone_collection.rb +138 -0
  197. data/lib/aws/elb/backend_server_policy_collection.rb +140 -0
  198. data/lib/aws/elb/client.rb +539 -0
  199. data/lib/aws/elb/config.rb +18 -0
  200. data/lib/aws/elb/errors.rb +26 -0
  201. data/lib/aws/elb/instance_collection.rb +174 -0
  202. data/lib/aws/elb/listener.rb +189 -0
  203. data/lib/aws/elb/listener_collection.rb +119 -0
  204. data/lib/aws/elb/listener_opts.rb +45 -0
  205. data/lib/aws/elb/load_balancer.rb +253 -0
  206. data/lib/aws/elb/load_balancer_collection.rb +113 -0
  207. data/lib/aws/elb/load_balancer_policy.rb +93 -0
  208. data/lib/aws/elb/load_balancer_policy_collection.rb +208 -0
  209. data/lib/aws/elb/request.rb +23 -0
  210. data/lib/aws/errors.rb +122 -0
  211. data/lib/aws/iam.rb +418 -0
  212. data/lib/aws/iam/access_key.rb +180 -0
  213. data/lib/aws/iam/access_key_collection.rb +128 -0
  214. data/lib/aws/iam/account_alias_collection.rb +79 -0
  215. data/lib/aws/iam/client.rb +1609 -0
  216. data/lib/aws/iam/collection.rb +83 -0
  217. data/lib/aws/iam/config.rb +18 -0
  218. data/lib/aws/iam/errors.rb +22 -0
  219. data/lib/aws/iam/group.rb +111 -0
  220. data/lib/aws/iam/group_collection.rb +132 -0
  221. data/lib/aws/iam/group_policy_collection.rb +47 -0
  222. data/lib/aws/iam/group_user_collection.rb +84 -0
  223. data/lib/aws/iam/login_profile.rb +99 -0
  224. data/lib/aws/iam/mfa_device.rb +52 -0
  225. data/lib/aws/iam/mfa_device_collection.rb +127 -0
  226. data/lib/aws/iam/policy.rb +46 -0
  227. data/lib/aws/iam/policy_collection.rb +188 -0
  228. data/lib/aws/iam/request.rb +29 -0
  229. data/lib/aws/iam/resource.rb +71 -0
  230. data/lib/aws/iam/server_certificate.rb +141 -0
  231. data/lib/aws/iam/server_certificate_collection.rb +138 -0
  232. data/lib/aws/iam/signing_certificate.rb +169 -0
  233. data/lib/aws/iam/signing_certificate_collection.rb +131 -0
  234. data/lib/aws/iam/user.rb +205 -0
  235. data/lib/aws/iam/user_collection.rb +133 -0
  236. data/lib/aws/iam/user_group_collection.rb +98 -0
  237. data/lib/aws/iam/user_policy.rb +90 -0
  238. data/lib/aws/iam/user_policy_collection.rb +45 -0
  239. data/lib/aws/iam/virtual_mfa_device.rb +139 -0
  240. data/lib/aws/iam/virtual_mfa_device_collection.rb +73 -0
  241. data/lib/aws/rails.rb +195 -0
  242. data/lib/aws/record.rb +116 -0
  243. data/lib/aws/record/abstract_base.rb +645 -0
  244. data/lib/aws/record/attributes.rb +384 -0
  245. data/lib/aws/record/conversion.rb +38 -0
  246. data/lib/aws/record/dirty_tracking.rb +285 -0
  247. data/lib/aws/record/errors.rb +143 -0
  248. data/lib/aws/record/exceptions.rb +48 -0
  249. data/lib/aws/record/hash_model.rb +161 -0
  250. data/lib/aws/record/hash_model/attributes.rb +182 -0
  251. data/lib/aws/record/hash_model/finder_methods.rb +172 -0
  252. data/lib/aws/record/hash_model/scope.rb +108 -0
  253. data/lib/aws/record/model.rb +427 -0
  254. data/lib/aws/record/model/attributes.rb +379 -0
  255. data/lib/aws/record/model/finder_methods.rb +232 -0
  256. data/lib/aws/record/model/scope.rb +213 -0
  257. data/lib/aws/record/naming.rb +31 -0
  258. data/lib/aws/record/scope.rb +199 -0
  259. data/lib/aws/record/validations.rb +694 -0
  260. data/lib/aws/record/validator.rb +237 -0
  261. data/lib/aws/record/validators/acceptance.rb +51 -0
  262. data/lib/aws/record/validators/block.rb +38 -0
  263. data/lib/aws/record/validators/confirmation.rb +43 -0
  264. data/lib/aws/record/validators/count.rb +108 -0
  265. data/lib/aws/record/validators/exclusion.rb +43 -0
  266. data/lib/aws/record/validators/format.rb +57 -0
  267. data/lib/aws/record/validators/inclusion.rb +56 -0
  268. data/lib/aws/record/validators/length.rb +107 -0
  269. data/lib/aws/record/validators/method.rb +33 -0
  270. data/lib/aws/record/validators/numericality.rb +138 -0
  271. data/lib/aws/record/validators/presence.rb +45 -0
  272. data/lib/aws/s3.rb +135 -0
  273. data/lib/aws/s3/access_control_list.rb +250 -0
  274. data/lib/aws/s3/acl_object.rb +264 -0
  275. data/lib/aws/s3/bucket.rb +393 -0
  276. data/lib/aws/s3/bucket_collection.rb +143 -0
  277. data/lib/aws/s3/bucket_lifecycle_configuration.rb +360 -0
  278. data/lib/aws/s3/bucket_version_collection.rb +77 -0
  279. data/lib/aws/s3/client.rb +1184 -0
  280. data/lib/aws/s3/client/xml.rb +177 -0
  281. data/lib/aws/s3/config.rb +26 -0
  282. data/lib/aws/s3/data_options.rb +100 -0
  283. data/lib/aws/s3/errors.rb +81 -0
  284. data/lib/aws/s3/multipart_upload.rb +317 -0
  285. data/lib/aws/s3/multipart_upload_collection.rb +68 -0
  286. data/lib/aws/s3/object_collection.rb +337 -0
  287. data/lib/aws/s3/object_metadata.rb +96 -0
  288. data/lib/aws/s3/object_upload_collection.rb +77 -0
  289. data/lib/aws/s3/object_version.rb +143 -0
  290. data/lib/aws/s3/object_version_collection.rb +89 -0
  291. data/lib/aws/s3/paginated_collection.rb +75 -0
  292. data/lib/aws/s3/policy.rb +74 -0
  293. data/lib/aws/s3/prefix_and_delimiter_collection.rb +47 -0
  294. data/lib/aws/s3/prefixed_collection.rb +81 -0
  295. data/lib/aws/s3/presigned_post.rb +553 -0
  296. data/lib/aws/s3/request.rb +201 -0
  297. data/lib/aws/s3/s3_object.rb +1037 -0
  298. data/lib/aws/s3/tree.rb +118 -0
  299. data/lib/aws/s3/tree/branch_node.rb +68 -0
  300. data/lib/aws/s3/tree/child_collection.rb +104 -0
  301. data/lib/aws/s3/tree/leaf_node.rb +94 -0
  302. data/lib/aws/s3/tree/node.rb +22 -0
  303. data/lib/aws/s3/tree/parent.rb +87 -0
  304. data/lib/aws/s3/uploaded_part.rb +80 -0
  305. data/lib/aws/s3/uploaded_part_collection.rb +84 -0
  306. data/lib/aws/simple_db.rb +217 -0
  307. data/lib/aws/simple_db/attribute.rb +154 -0
  308. data/lib/aws/simple_db/attribute_collection.rb +231 -0
  309. data/lib/aws/simple_db/client.rb +349 -0
  310. data/lib/aws/simple_db/config.rb +20 -0
  311. data/lib/aws/simple_db/consistent_read_option.rb +42 -0
  312. data/lib/aws/simple_db/delete_attributes.rb +62 -0
  313. data/lib/aws/simple_db/domain.rb +121 -0
  314. data/lib/aws/simple_db/domain_collection.rb +113 -0
  315. data/lib/aws/simple_db/domain_metadata.rb +110 -0
  316. data/lib/aws/simple_db/errors.rb +55 -0
  317. data/lib/aws/simple_db/expect_condition_option.rb +45 -0
  318. data/lib/aws/simple_db/item.rb +93 -0
  319. data/lib/aws/simple_db/item_collection.rb +649 -0
  320. data/lib/aws/simple_db/item_data.rb +73 -0
  321. data/lib/aws/simple_db/put_attributes.rb +60 -0
  322. data/lib/aws/simple_db/request.rb +23 -0
  323. data/lib/aws/simple_email_service.rb +426 -0
  324. data/lib/aws/simple_email_service/client.rb +286 -0
  325. data/lib/aws/simple_email_service/config.rb +19 -0
  326. data/lib/aws/simple_email_service/email_address_collection.rb +69 -0
  327. data/lib/aws/simple_email_service/errors.rb +22 -0
  328. data/lib/aws/simple_email_service/identity.rb +91 -0
  329. data/lib/aws/simple_email_service/identity_collection.rb +81 -0
  330. data/lib/aws/simple_email_service/quotas.rb +64 -0
  331. data/lib/aws/simple_email_service/request.rb +29 -0
  332. data/lib/aws/simple_workflow.rb +226 -0
  333. data/lib/aws/simple_workflow/activity_task.rb +173 -0
  334. data/lib/aws/simple_workflow/activity_task_collection.rb +123 -0
  335. data/lib/aws/simple_workflow/activity_type.rb +131 -0
  336. data/lib/aws/simple_workflow/activity_type_collection.rb +93 -0
  337. data/lib/aws/simple_workflow/client.rb +1434 -0
  338. data/lib/aws/simple_workflow/config.rb +18 -0
  339. data/lib/aws/simple_workflow/count.rb +49 -0
  340. data/lib/aws/simple_workflow/decision_task.rb +601 -0
  341. data/lib/aws/simple_workflow/decision_task_collection.rb +225 -0
  342. data/lib/aws/simple_workflow/domain.rb +122 -0
  343. data/lib/aws/simple_workflow/domain_collection.rb +169 -0
  344. data/lib/aws/simple_workflow/errors.rb +20 -0
  345. data/lib/aws/simple_workflow/history_event.rb +276 -0
  346. data/lib/aws/simple_workflow/history_event_collection.rb +76 -0
  347. data/lib/aws/simple_workflow/option_formatters.rb +82 -0
  348. data/lib/aws/simple_workflow/request.rb +36 -0
  349. data/lib/aws/simple_workflow/resource.rb +94 -0
  350. data/lib/aws/simple_workflow/type.rb +89 -0
  351. data/lib/aws/simple_workflow/type_collection.rb +140 -0
  352. data/lib/aws/simple_workflow/workflow_execution.rb +386 -0
  353. data/lib/aws/simple_workflow/workflow_execution_collection.rb +617 -0
  354. data/lib/aws/simple_workflow/workflow_type.rb +177 -0
  355. data/lib/aws/simple_workflow/workflow_type_collection.rb +91 -0
  356. data/lib/aws/sns.rb +74 -0
  357. data/lib/aws/sns/client.rb +371 -0
  358. data/lib/aws/sns/config.rb +18 -0
  359. data/lib/aws/sns/errors.rb +22 -0
  360. data/lib/aws/sns/has_delivery_policy.rb +68 -0
  361. data/lib/aws/sns/policy.rb +47 -0
  362. data/lib/aws/sns/request.rb +23 -0
  363. data/lib/aws/sns/subscription.rb +144 -0
  364. data/lib/aws/sns/subscription_collection.rb +80 -0
  365. data/lib/aws/sns/topic.rb +403 -0
  366. data/lib/aws/sns/topic_collection.rb +67 -0
  367. data/lib/aws/sns/topic_subscription_collection.rb +55 -0
  368. data/lib/aws/sqs.rb +79 -0
  369. data/lib/aws/sqs/client.rb +360 -0
  370. data/lib/aws/sqs/config.rb +18 -0
  371. data/lib/aws/sqs/errors.rb +101 -0
  372. data/lib/aws/sqs/policy.rb +48 -0
  373. data/lib/aws/sqs/queue.rb +725 -0
  374. data/lib/aws/sqs/queue_collection.rb +170 -0
  375. data/lib/aws/sqs/received_message.rb +181 -0
  376. data/lib/aws/sqs/received_sns_message.rb +112 -0
  377. data/lib/aws/sqs/request.rb +43 -0
  378. data/lib/aws/sts.rb +152 -0
  379. data/lib/aws/sts/client.rb +105 -0
  380. data/lib/aws/sts/config.rb +18 -0
  381. data/lib/aws/sts/errors.rb +22 -0
  382. data/lib/aws/sts/federated_session.rb +56 -0
  383. data/lib/aws/sts/policy.rb +30 -0
  384. data/lib/aws/sts/request.rb +29 -0
  385. data/lib/aws/sts/session.rb +48 -0
  386. data/lib/net/http/connection_pool.rb +210 -0
  387. data/lib/net/http/connection_pool/connection.rb +132 -0
  388. data/lib/net/http/connection_pool/session.rb +93 -0
  389. data/lib/user.rb +49 -0
  390. metadata +433 -0
@@ -0,0 +1,74 @@
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
+ module Core
16
+ module Http
17
+
18
+ # Represents the http response from a service request.
19
+ #
20
+ # Responses have:
21
+ #
22
+ # * status (200, 404, 500, etc)
23
+ # * headers (hash of response headers)
24
+ # * body (the response body)
25
+ class Response
26
+
27
+ # @return [Integer] (200) response http status code
28
+ attr_accessor :status
29
+
30
+ # @return [Hash] ({}) response http headers
31
+ attr_accessor :headers
32
+
33
+ # @return [String] ('') response http body
34
+ attr_accessor :body
35
+
36
+ # @return [Boolean] (false) set to true if the client gives up
37
+ # before getting a response from the service.
38
+ attr_accessor :timeout
39
+
40
+ alias_method :timeout?, :timeout
41
+
42
+ # @param [Hash] options
43
+ # @option options [Integer] :status (200) HTTP status code
44
+ # @option options [Hash] :headers ({}) HTTP response headers
45
+ # @option options [String] :body ('') HTTP response body
46
+ def initialize options = {}, &block
47
+ @status = options[:status] || 200
48
+ @headers = options[:headers] || {}
49
+ @body = options[:body] || ''
50
+ yield(self) if block_given?
51
+ self
52
+ end
53
+
54
+ # Returns the header value with the given name.
55
+ #
56
+ # The value is matched case-insensitively so if the headers hash
57
+ # contains a key like 'Date' and you request the value for
58
+ # 'date' the 'Date' value will be returned.
59
+ #
60
+ # @param [String,Symbol] name The name of the header to fetch a value for.
61
+ # @return [String,nil] The value of the given header
62
+ def header name
63
+ headers.each_pair do |header_name, header_value|
64
+ if header_name.downcase == name.to_s.downcase
65
+ return header_value.is_a?(Array) ? header_value.first : header_value
66
+ end
67
+ end
68
+ nil
69
+ end
70
+
71
+ end
72
+ end
73
+ end
74
+ end
@@ -0,0 +1,88 @@
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
+ module Core
16
+
17
+ # A utility class to provide indifferent access to hash data.
18
+ #
19
+ # Inspired by ActiveSupport's HashWithIndifferentAccess, this class
20
+ # has a few notable differences:
21
+ #
22
+ # * ALL keys are converted to strings (via #to_s)
23
+ # * It does not deep merge/convert hashes indifferently, good for fla
24
+ # * It will not perserve default value behaviours
25
+ #
26
+ # These features were omitted because our primary use for this class is to
27
+ # wrap a 1-level hash as a return value, but we want the user to access
28
+ # the values with string or symbol keys.
29
+ #
30
+ # @private
31
+ class IndifferentHash < Hash
32
+
33
+ def initialize *args
34
+ if args.first.is_a?(Hash)
35
+ super()
36
+ merge!(*args)
37
+ else
38
+ super(*args)
39
+ end
40
+ end
41
+
42
+ alias_method :_getter, :[]
43
+ alias_method :_setter, :[]=
44
+
45
+ def []=(key, value)
46
+ _setter(_convert_key(key), value)
47
+ end
48
+ alias_method :store, :[]=
49
+
50
+ def [] key
51
+ _getter(_convert_key(key))
52
+ end
53
+
54
+ def merge! hash
55
+ hash.each_pair do |key,value|
56
+ self[key] = value
57
+ end
58
+ self
59
+ end
60
+ alias_method :update, :merge!
61
+
62
+ def merge hash
63
+ self.dup.merge!(hash)
64
+ end
65
+
66
+ def has_key? key
67
+ super(_convert_key(key))
68
+ end
69
+ alias_method :key?, :has_key?
70
+ alias_method :member?, :has_key?
71
+ alias_method :include?, :has_key?
72
+
73
+ def fetch key, *extras, &block
74
+ super(_convert_key(key), *extras, &block)
75
+ end
76
+
77
+ def delete key
78
+ super(_convert_key(key))
79
+ end
80
+
81
+ private
82
+ def _convert_key key
83
+ key.is_a?(String) ? key : key.to_s
84
+ end
85
+
86
+ end
87
+ end
88
+ end
@@ -0,0 +1,47 @@
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
+ module Core
16
+
17
+ # @private
18
+ module Inflection
19
+
20
+ def ruby_name(aws_name)
21
+
22
+ #aws_name.sub(/^.*:/, '').
23
+ # gsub(/[A-Z]+[a-z]+/){|str| "_#{str.downcase}_" }.
24
+ # gsub(/(^_|_$)/, '').
25
+ # gsub(/__/, '_').
26
+ # downcase
27
+
28
+ return 'etag' if aws_name == 'ETag'
29
+
30
+ aws_name.
31
+ sub(/^.*:/, ''). # strip namespace
32
+ gsub(/([A-Z0-9]+)([A-Z][a-z])/, '\1_\2'). # split acronyms from words
33
+ scan(/[a-z]+|\d+|[A-Z0-9]+[a-z]*/). # split remaining words
34
+ join('_').downcase # join parts _ and downcase
35
+
36
+ end
37
+ module_function :ruby_name
38
+
39
+ def class_name(name)
40
+ name.sub(/^(.)/) { |m| m.upcase }.
41
+ gsub(/[-_]([a-z])/i) { |m| m[1,1].upcase }
42
+ end
43
+ module_function :class_name
44
+
45
+ end
46
+ end
47
+ end
@@ -0,0 +1,90 @@
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 'thread'
15
+
16
+ module AWS
17
+ module Core
18
+
19
+ # Provides lazy creation of error classes via {#const_missing}.
20
+ #
21
+ # Extend this module provides 3 benefits to another module:
22
+ #
23
+ # * A method that accepts strings and returns error classes.
24
+ # * Thread-safe dynamic error class creation via {#const_missing}
25
+ # * An error grammar for parsing AWS xml errors
26
+ #
27
+ # Here is an example of how it works:
28
+ #
29
+ # Class Foo
30
+ # module Errors
31
+ # extend AWS::Core::LazyErrorClasses
32
+ # end
33
+ # end
34
+ #
35
+ # Foo::Errors.error_class('NoSuchKey')
36
+ # #=> Foo::Errors::NoSuckKey
37
+ #
38
+ # Foo::Errors.error_class('Nested.Error.Klasses')
39
+ # #=> Foo::Errors::Nested::Error::Klasses
40
+ #
41
+ # The errors returned from {#error_class} are subclasses
42
+ # of {AWS::Errors::Base}.
43
+ #
44
+ module LazyErrorClasses
45
+
46
+ # This grammar parses the defualt AWS XML error format
47
+ BASE_ERROR_GRAMMAR = XML::Grammar.customize do
48
+ element("Error") do
49
+ ignore
50
+ end
51
+ end
52
+
53
+ # @private
54
+ def self.extended base
55
+
56
+ unless base.const_defined?(:GRAMMAR)
57
+ base.const_set(:GRAMMAR, BASE_ERROR_GRAMMAR)
58
+ end
59
+
60
+ mutex = Mutex.new
61
+ MetaUtils.extend_method(base, :const_missing_mutex) { mutex }
62
+
63
+ end
64
+
65
+ # Defines a new error class.
66
+ # @param [String,Symbol] constant
67
+ # @return [nil]
68
+ def const_missing constant
69
+ const_missing_mutex.synchronize do
70
+ const_set(constant, Class.new(Errors::Base) { extend LazyErrorClasses })
71
+ end
72
+ end
73
+
74
+ # Converts the error code into an error class constant.
75
+ #
76
+ # AWS::EC2::Errors.error_class('Non.Existent.Error')
77
+ # #=> AWS::EC2::Errors::Non::Existent::Error
78
+ #
79
+ # @param [String] code An AWS error code.
80
+ #
81
+ # @return [Class] Returns the error class defiend by the error code.
82
+ #
83
+ def error_class code
84
+ module_eval("#{self}::#{code.gsub('.Range','Range').gsub(".","::")}")
85
+ end
86
+
87
+ end
88
+
89
+ end
90
+ end
@@ -0,0 +1,454 @@
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
+ module Core
16
+
17
+ # = Log Formatters
18
+ #
19
+ # Log formatters receive a {AWS::Core::Response} object and return
20
+ # a log message. When you construct a {LogFormatter}, you provide
21
+ # a pattern string with substitutions.
22
+ #
23
+ # pattern = '[REQUEST :http_status_code] :service :operation :duration'
24
+ # formatter = AWS::Core::LogFormatter.new(pattern)
25
+ # formatter.format(response)
26
+ # #=> '[AWS 200] EC2 get_bucket 0.0352'
27
+ #
28
+ # = AWS Configuration
29
+ #
30
+ # AWS.config provides a {LogFormatter.default} log formatter. You can
31
+ # repace this formatter by building your own and then passing it
32
+ # to {AWS.config}.
33
+ #
34
+ # pattern = '[REQUEST :http_status_code] :service :operation :duration'
35
+ # AWS.config(:log_formatter => AWS::Core::LogFormatter.new(pattern)
36
+ #
37
+ # == Canned Formatters
38
+ #
39
+ # Instead of providing your own pattern, you can choose a canned log
40
+ # formatter.
41
+ #
42
+ # AWS.config(:log_formatter => AWS::Core::LogFormatter.colored)
43
+ #
44
+ # Here is the list of canned formatters.
45
+ #
46
+ # * {LogFormatter.default}
47
+ # * {LogFormatter.short}
48
+ # * {LogFormatter.debug}
49
+ # * {LogFormatter.colored}
50
+ #
51
+ # = Pattern Substitutions
52
+ #
53
+ # You can put any of these placeholders into you pattern.
54
+ #
55
+ # [+:service+]
56
+ # The AWS service name (e.g. 'S3', 'EC2', 'SimpleDB', etc)
57
+ #
58
+ # [+:region+]
59
+ # The AWS region name (e.g. 'us-east-1', 'us-west-1', etc)
60
+ #
61
+ # [+:operation+]
62
+ # The name of the client request method. This maps to the name of
63
+ # the serivce API operation (e.g. :describe_instances).
64
+ #
65
+ # [+:options+]
66
+ # The hash of options passed to the client request method.
67
+ # Long strings are truncated/summarized if they excede the log
68
+ # formatters {#max_string_size}. Other objects are inspected.
69
+ #
70
+ # [+:retry_count+]
71
+ # The number of times a client request was retried.
72
+ # Throttlings and service errors trigger the automatic retry logic.
73
+ # This value indicates how many extra attempts were made before
74
+ # getting a successful response or giving up.
75
+ #
76
+ # [+:duration+]
77
+ # The time it took to generate a response, expressed
78
+ # in decimal seconds. This time includes everything from
79
+ # calling the client request method, until that method returns
80
+ # a value (event retries and retry delays).
81
+ #
82
+ # [+:error_class+]
83
+ # The class name of the error returned by the
84
+ # service. If no error was returned, this will be replcaed by
85
+ # an empty string.
86
+ #
87
+ # [+:error_message+]
88
+ # The message of the error returned. If
89
+ # no error was returned by the service, this will be an empty
90
+ # string.
91
+ #
92
+ # [+:http_request_method+]
93
+ # The HTTP request verb (e.g. 'POST', 'PUT', 'GET', etc).
94
+ #
95
+ # [+:http_request_protocol+]
96
+ # This is replaced by 'http' or 'https'.
97
+ #
98
+ # [+:http_request_host+]
99
+ # The host name of the http request endpoint (e.g. 's3.amazon.com').
100
+ #
101
+ # [+:http_request_port+]
102
+ # The port number (e.g. '443' or '80').
103
+ #
104
+ # [+:http_request_uri+]
105
+ # The http request uri folling the host (e.g.
106
+ # '/bucket_name/objects/key?versions').
107
+ #
108
+ # [+:http_request_body+]
109
+ # The http request payload.
110
+ #
111
+ # [+:http_request_headers+]
112
+ # The http request headers, inspected.
113
+ #
114
+ # [+:http_request_proxy_uri+]
115
+ # The proxy uri used, or an empty string.
116
+ #
117
+ # [+:http_response_status+]
118
+ # The http response status code (e.g. '200', '404', '500', etc).
119
+ #
120
+ # [+:http_response_headers+]
121
+ # The http response headers, inspected.
122
+ #
123
+ # [+:http_response_body+]
124
+ # The http response body contents.
125
+ #
126
+ class LogFormatter
127
+
128
+ # @param [String] pattern The log format pattern should be a string
129
+ # and may contain any of the following placeholders:
130
+ #
131
+ # * +:service+
132
+ # * +:region+
133
+ # * +:operation+
134
+ # * +:options+
135
+ # * +:retry_count
136
+ # * +:duration+
137
+ # * +:error_class+
138
+ # * +:error_message+
139
+ # * +:http_request_method+
140
+ # * +:http_request_protocol+
141
+ # * +:http_request_host+
142
+ # * +:http_request_port+
143
+ # * +:http_request_uri+
144
+ # * +:http_request_body+
145
+ # * +:http_request_headers+
146
+ # * +:http_request_proxy_uri+
147
+ # * +:http_response_status+
148
+ # * +:http_response_headers+
149
+ # * +:http_response_body+
150
+ #
151
+ # @param [Hash] options
152
+ #
153
+ # @option options [Integer] :max_string_size (1000)
154
+ #
155
+ def initialize pattern, options = {}
156
+ @pattern = pattern
157
+ @max_string_size = options[:max_string_size] || 1000
158
+ end
159
+
160
+ # @return [String]
161
+ attr_reader :pattern
162
+
163
+ # @return [Integer]
164
+ attr_reader :max_string_size
165
+
166
+ # @param [Response] response
167
+ # @return [String]
168
+ def format response
169
+ pattern.gsub(/:(\w+)/) {|sym| send("_#{sym[1..-1]}", response) }
170
+ end
171
+
172
+ protected
173
+
174
+ def method_missing method_name, *args
175
+ if method_name.to_s.chars.first == '_'
176
+ ":#{method_name.to_s[1..-1]}"
177
+ else
178
+ super
179
+ end
180
+ end
181
+
182
+ def _service response
183
+ response.http_request.class.name.split('::')[1]
184
+ end
185
+
186
+ def _region response
187
+ response.http_request.region
188
+ end
189
+
190
+ def _operation response
191
+ response.request_type
192
+ end
193
+
194
+ def _options response
195
+ summarize_hash(response.request_options) if response.request_options
196
+ end
197
+
198
+ def _retry_count response
199
+ response.retry_count
200
+ end
201
+
202
+ def _duration response
203
+ ("%.06f" % response.duration).sub(/0+$/, '')
204
+ end
205
+
206
+ def _error_class response
207
+ response.error.class.name if response.error
208
+ end
209
+
210
+ def _error_message response
211
+ response.error.message if response.error
212
+ end
213
+
214
+ def _http_request_method response
215
+ response.http_request.http_method
216
+ end
217
+
218
+ def _http_request_protocol response
219
+ response.http_request.use_ssl? ? 'https' : 'http'
220
+ end
221
+
222
+ def _http_request_host response
223
+ response.http_request.host
224
+ end
225
+
226
+ def _http_request_port response
227
+ response.http_request.port
228
+ end
229
+
230
+ def _http_request_uri response
231
+ response.http_request.uri
232
+ end
233
+
234
+ def _http_request_headers response
235
+ response.http_request.headers.inspect
236
+ end
237
+
238
+ def _http_request_body response
239
+ response.http_request.body
240
+ end
241
+
242
+ def _http_request_proxy_uri response
243
+ response.http_request.proxy_uri
244
+ end
245
+
246
+ def _http_response_status response
247
+ response.http_response.status
248
+ end
249
+
250
+ def _http_response_headers response
251
+ response.http_response.headers.inspect
252
+ end
253
+
254
+ def _http_response_body response
255
+ response.http_response.body
256
+ end
257
+
258
+ # The following methods are for summarizing request options that have
259
+ # symbolized keys and a mix of values. The summarizing is important
260
+ # because large request options (e.g. s3 data) can cause memory usage
261
+ # to spike if it is inspected.
262
+
263
+ # @param [Hash] hash
264
+ # @return [String]
265
+ def summarize_hash hash
266
+ hash.map do |key,v|
267
+ ":#{key}=>#{summarize_value(v)}"
268
+ end.sort.join(",")
269
+ end
270
+
271
+ # @param [Object] value
272
+ # @return [String]
273
+ def summarize_value value
274
+ case value
275
+ when String then summarize_string(value)
276
+ when Hash then '{' + summarize_hash(value) + '}'
277
+ when Array then summarize_array(value)
278
+ when File then summarize_file(value.path)
279
+ when Pathname then summarize_file(value)
280
+ else value.inspect
281
+ end
282
+ end
283
+
284
+ # @param [String] str
285
+ # @return [String]
286
+ def summarize_string str
287
+ max = max_string_size
288
+ if str.size > max
289
+ "#<String #{str[0...max].inspect} ... (#{str.size} bytes)>"
290
+ else
291
+ str.inspect
292
+ end
293
+ end
294
+
295
+ # Given the path to a file on disk, this method returns a summarized
296
+ # inspecton string that includes the file size.
297
+ # @param [String] path
298
+ # @return [String]
299
+ def summarize_file path
300
+ "#<File:#{path} (#{File.size(path)} bytes)>"
301
+ end
302
+
303
+ # @param [Array] array
304
+ # @return [String]
305
+ def summarize_array array
306
+ "[" + array.map{|v| summarize_value(v) }.join(",") + "]"
307
+ end
308
+
309
+ class << self
310
+
311
+ # The default log format.
312
+ #
313
+ # @example A sample of the default format.
314
+ #
315
+ # [AWS SimpleEmailService 200 0.580066 0 retries] list_verified_email_addresses()
316
+ #
317
+ # @return [LogFormatter]
318
+ #
319
+ def default
320
+
321
+ pattern = []
322
+ pattern << "[AWS"
323
+ pattern << ":service"
324
+ pattern << ":http_response_status"
325
+ pattern << ":duration"
326
+ pattern << ":retry_count retries]"
327
+ pattern << ":operation(:options)"
328
+ pattern << ":error_class"
329
+ pattern << ":error_message"
330
+
331
+ LogFormatter.new(pattern.join(' ') + "\n")
332
+
333
+ end
334
+
335
+ # The short log format. Similar to default, but it does not
336
+ # inspect the request params or report on retries.
337
+ #
338
+ # @example A sample of the short format
339
+ #
340
+ # [AWS SimpleEmailService 200 0.494532] list_verified_email_addresses
341
+ #
342
+ # @return [LogFormatter]
343
+ #
344
+ def short
345
+
346
+ pattern = []
347
+ pattern << "[AWS"
348
+ pattern << ":service"
349
+ pattern << ":http_response_status"
350
+ pattern << ":duration]"
351
+ pattern << ":operation"
352
+ pattern << ":error_class"
353
+
354
+ LogFormatter.new(pattern.join(' ') + "\n")
355
+
356
+ end
357
+
358
+ # A debug format that dumps most of the http request and response
359
+ # data.
360
+ #
361
+ # @example A truncated sample of the debug format.
362
+ #
363
+ # +-------------------------------------------------------------------------------
364
+ # | AWS us-east-1 SimpleEmailService list_verified_email_addresses 0.429189 0 retries
365
+ # +-------------------------------------------------------------------------------
366
+ # | REQUEST
367
+ # +-------------------------------------------------------------------------------
368
+ # | METHOD: POST
369
+ # | URL: https://email.us-east-1.amazonaws.com::443:/
370
+ # | HEADERS: {"content-type"=>"application/x-www-form-urlencoded" ...
371
+ # | BODY: Action=ListVerifiedEmailAddresses&Timestamp= ...
372
+ # +-------------------------------------------------------------------------------
373
+ # | RESPONSE
374
+ # +-------------------------------------------------------------------------------
375
+ # | STATUS: 200
376
+ # | HEADERS: {"x-amzn-requestid"=>["..."], ...
377
+ # | BODY: <ListVerifiedEmailAddressesResponse ...
378
+ #
379
+ # @return [LogFormatter]
380
+ #
381
+ def debug
382
+
383
+ sig_pattern = []
384
+ sig_pattern << ':region'
385
+ sig_pattern << ':service'
386
+ sig_pattern << ':operation'
387
+ sig_pattern << ':duration'
388
+ sig_pattern << ':retry_count retries'
389
+
390
+ uri_pattern = []
391
+ uri_pattern << ':http_request_protocol'
392
+ uri_pattern << '://'
393
+ uri_pattern << ':http_request_host'
394
+ uri_pattern << '::'
395
+ uri_pattern << ':http_request_port'
396
+ uri_pattern << ':'
397
+ uri_pattern << ':http_request_uri'
398
+
399
+ line = "+" + '-' * 79
400
+
401
+ pattern = []
402
+ pattern << line
403
+ pattern << "| AWS #{sig_pattern.join(' ')}"
404
+ pattern << line
405
+ pattern << "| REQUEST"
406
+ pattern << line
407
+ pattern << "| METHOD: :http_request_method"
408
+ pattern << "| URL: #{uri_pattern.join}"
409
+ pattern << "| HEADERS: :http_request_headers"
410
+ pattern << "| BODY: :http_request_body"
411
+ pattern << line
412
+ pattern << "| RESPONSE"
413
+ pattern << line
414
+ pattern << "| STATUS: :http_response_status"
415
+ pattern << "| HEADERS: :http_response_headers"
416
+ pattern << "| BODY: :http_response_body"
417
+
418
+ LogFormatter.new(pattern.join("\n") + "\n")
419
+
420
+ end
421
+
422
+ # The default log format with ANSI colors.
423
+ #
424
+ # @example A sample of the colored format (sans the ansi colors).
425
+ #
426
+ # [AWS SimpleEmailService 200 0.580066 0 retries] list_verified_email_addresses()
427
+ #
428
+ # @return [LogFormatter]
429
+ #
430
+ def colored
431
+
432
+ bold = "\x1b[1m"
433
+ color = "\x1b[34m"
434
+ reset = "\x1b[0m"
435
+
436
+ pattern = []
437
+ pattern << "#{bold}#{color}[AWS"
438
+ pattern << ":service"
439
+ pattern << ":http_response_status"
440
+ pattern << ":duration"
441
+ pattern << ":retry_count retries]#{reset}#{bold}"
442
+ pattern << ":operation(:options)"
443
+ pattern << ":error_class"
444
+ pattern << ":error_message#{reset}"
445
+
446
+ LogFormatter.new(pattern.join(' ') + "\n")
447
+
448
+ end
449
+
450
+ end
451
+
452
+ end
453
+ end
454
+ end