aws-sdk 1.32.0 → 3.0.2

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 (551) hide show
  1. checksums.yaml +5 -5
  2. data/CHANGELOG.md +100 -0
  3. data/LICENSE.txt +199 -9
  4. data/VERSION +1 -0
  5. data/lib/aws-sdk.rb +2 -14
  6. metadata +22 -591
  7. data/.yardopts +0 -7
  8. data/README.md +0 -291
  9. data/bin/aws-rb +0 -169
  10. data/ca-bundle.crt +0 -3554
  11. data/endpoints.json +0 -1506
  12. data/lib/aws.rb +0 -14
  13. data/lib/aws/api_config/AutoScaling-2011-01-01.yml +0 -869
  14. data/lib/aws/api_config/CloudFormation-2010-05-15.yml +0 -358
  15. data/lib/aws/api_config/CloudFront-2013-05-12.yml +0 -2448
  16. data/lib/aws/api_config/CloudFront-2013-08-26.yml +0 -2599
  17. data/lib/aws/api_config/CloudFront-2013-09-27.yml +0 -2765
  18. data/lib/aws/api_config/CloudFront-2013-11-11.yml +0 -2886
  19. data/lib/aws/api_config/CloudSearch-2011-02-01.yml +0 -681
  20. data/lib/aws/api_config/CloudTrail-2013-11-01.yml +0 -159
  21. data/lib/aws/api_config/CloudWatch-2010-08-01.yml +0 -433
  22. data/lib/aws/api_config/DataPipeline-2012-10-29.yml +0 -422
  23. data/lib/aws/api_config/DirectConnect-2012-10-25.yml +0 -735
  24. data/lib/aws/api_config/DynamoDB-2011-12-05.yml +0 -1168
  25. data/lib/aws/api_config/DynamoDB-2012-08-10.yml +0 -2005
  26. data/lib/aws/api_config/EC2-2013-08-15.yml +0 -4708
  27. data/lib/aws/api_config/EC2-2013-10-01.yml +0 -4726
  28. data/lib/aws/api_config/EC2-2013-10-15.yml +0 -4726
  29. data/lib/aws/api_config/ELB-2012-06-01.yml +0 -632
  30. data/lib/aws/api_config/EMR-2009-03-31.yml +0 -953
  31. data/lib/aws/api_config/ElastiCache-2013-06-15.yml +0 -1188
  32. data/lib/aws/api_config/ElasticBeanstalk-2010-12-01.yml +0 -847
  33. data/lib/aws/api_config/ElasticTranscoder-2012-09-25.yml +0 -2285
  34. data/lib/aws/api_config/Glacier-2012-06-01.yml +0 -649
  35. data/lib/aws/api_config/IAM-2010-05-08.yml +0 -1297
  36. data/lib/aws/api_config/ImportExport-2010-06-01.yml +0 -109
  37. data/lib/aws/api_config/Kinesis-2013-12-02.yml +0 -201
  38. data/lib/aws/api_config/OpsWorks-2013-02-18.yml +0 -1825
  39. data/lib/aws/api_config/RDS-2013-05-15.yml +0 -2464
  40. data/lib/aws/api_config/RDS-2013-09-09.yml +0 -2641
  41. data/lib/aws/api_config/Redshift-2012-12-01.yml +0 -2137
  42. data/lib/aws/api_config/Route53-2012-12-12.yml +0 -547
  43. data/lib/aws/api_config/SNS-2010-03-31.yml +0 -433
  44. data/lib/aws/api_config/SQS-2012-11-05.yml +0 -319
  45. data/lib/aws/api_config/STS-2011-06-15.yml +0 -147
  46. data/lib/aws/api_config/SimpleDB-2009-04-15.yml +0 -306
  47. data/lib/aws/api_config/SimpleEmailService-2010-12-01.yml +0 -346
  48. data/lib/aws/api_config/SimpleWorkflow-2012-01-25.yml +0 -2388
  49. data/lib/aws/api_config/StorageGateway-2012-06-30.yml +0 -748
  50. data/lib/aws/api_config/StorageGateway-2013-06-30.yml +0 -1025
  51. data/lib/aws/api_config/Support-2013-04-15.yml +0 -426
  52. data/lib/aws/auto_scaling.rb +0 -163
  53. data/lib/aws/auto_scaling/activity.rb +0 -102
  54. data/lib/aws/auto_scaling/activity_collection.rb +0 -81
  55. data/lib/aws/auto_scaling/client.rb +0 -48
  56. data/lib/aws/auto_scaling/config.rb +0 -18
  57. data/lib/aws/auto_scaling/errors.rb +0 -22
  58. data/lib/aws/auto_scaling/group.rb +0 -421
  59. data/lib/aws/auto_scaling/group_collection.rb +0 -96
  60. data/lib/aws/auto_scaling/group_options.rb +0 -155
  61. data/lib/aws/auto_scaling/instance.rb +0 -192
  62. data/lib/aws/auto_scaling/instance_collection.rb +0 -63
  63. data/lib/aws/auto_scaling/launch_configuration.rb +0 -162
  64. data/lib/aws/auto_scaling/launch_configuration_collection.rb +0 -160
  65. data/lib/aws/auto_scaling/notification_configuration.rb +0 -89
  66. data/lib/aws/auto_scaling/notification_configuration_collection.rb +0 -183
  67. data/lib/aws/auto_scaling/scaling_policy.rb +0 -142
  68. data/lib/aws/auto_scaling/scaling_policy_collection.rb +0 -72
  69. data/lib/aws/auto_scaling/scaling_policy_options.rb +0 -65
  70. data/lib/aws/auto_scaling/scheduled_action.rb +0 -141
  71. data/lib/aws/auto_scaling/scheduled_action_collection.rb +0 -202
  72. data/lib/aws/auto_scaling/tag.rb +0 -59
  73. data/lib/aws/auto_scaling/tag_collection.rb +0 -114
  74. data/lib/aws/cloud_formation.rb +0 -272
  75. data/lib/aws/cloud_formation/client.rb +0 -48
  76. data/lib/aws/cloud_formation/config.rb +0 -18
  77. data/lib/aws/cloud_formation/errors.rb +0 -22
  78. data/lib/aws/cloud_formation/stack.rb +0 -266
  79. data/lib/aws/cloud_formation/stack_collection.rb +0 -232
  80. data/lib/aws/cloud_formation/stack_event.rb +0 -73
  81. data/lib/aws/cloud_formation/stack_event_collection.rb +0 -47
  82. data/lib/aws/cloud_formation/stack_options.rb +0 -72
  83. data/lib/aws/cloud_formation/stack_output.rb +0 -53
  84. data/lib/aws/cloud_formation/stack_resource.rb +0 -117
  85. data/lib/aws/cloud_formation/stack_resource_collection.rb +0 -83
  86. data/lib/aws/cloud_formation/stack_resource_summary_collection.rb +0 -64
  87. data/lib/aws/cloud_formation/stack_summary_collection.rb +0 -123
  88. data/lib/aws/cloud_front.rb +0 -72
  89. data/lib/aws/cloud_front/client.rb +0 -45
  90. data/lib/aws/cloud_front/config.rb +0 -18
  91. data/lib/aws/cloud_front/errors.rb +0 -22
  92. data/lib/aws/cloud_search.rb +0 -73
  93. data/lib/aws/cloud_search/client.rb +0 -36
  94. data/lib/aws/cloud_search/config.rb +0 -18
  95. data/lib/aws/cloud_search/errors.rb +0 -22
  96. data/lib/aws/cloud_trail.rb +0 -72
  97. data/lib/aws/cloud_trail/client.rb +0 -35
  98. data/lib/aws/cloud_trail/config.rb +0 -18
  99. data/lib/aws/cloud_trail/errors.rb +0 -22
  100. data/lib/aws/cloud_watch.rb +0 -118
  101. data/lib/aws/cloud_watch/alarm.rb +0 -290
  102. data/lib/aws/cloud_watch/alarm_collection.rb +0 -153
  103. data/lib/aws/cloud_watch/alarm_history_item.rb +0 -50
  104. data/lib/aws/cloud_watch/alarm_history_item_collection.rb +0 -84
  105. data/lib/aws/cloud_watch/client.rb +0 -40
  106. data/lib/aws/cloud_watch/config.rb +0 -18
  107. data/lib/aws/cloud_watch/errors.rb +0 -22
  108. data/lib/aws/cloud_watch/metric.rb +0 -135
  109. data/lib/aws/cloud_watch/metric_alarm_collection.rb +0 -160
  110. data/lib/aws/cloud_watch/metric_collection.rb +0 -129
  111. data/lib/aws/cloud_watch/metric_statistics.rb +0 -69
  112. data/lib/aws/core.rb +0 -701
  113. data/lib/aws/core/async_handle.rb +0 -90
  114. data/lib/aws/core/cacheable.rb +0 -77
  115. data/lib/aws/core/client.rb +0 -778
  116. data/lib/aws/core/collection.rb +0 -263
  117. data/lib/aws/core/collection/simple.rb +0 -82
  118. data/lib/aws/core/collection/with_limit_and_next_token.rb +0 -71
  119. data/lib/aws/core/collection/with_next_token.rb +0 -97
  120. data/lib/aws/core/configuration.rb +0 -541
  121. data/lib/aws/core/credential_providers.rb +0 -506
  122. data/lib/aws/core/data.rb +0 -247
  123. data/lib/aws/core/deprecations.rb +0 -84
  124. data/lib/aws/core/endpoints.rb +0 -37
  125. data/lib/aws/core/http/connection_pool.rb +0 -349
  126. data/lib/aws/core/http/curb_handler.rb +0 -148
  127. data/lib/aws/core/http/handler.rb +0 -89
  128. data/lib/aws/core/http/net_http_handler.rb +0 -147
  129. data/lib/aws/core/http/patch.rb +0 -102
  130. data/lib/aws/core/http/request.rb +0 -249
  131. data/lib/aws/core/http/response.rb +0 -81
  132. data/lib/aws/core/indifferent_hash.rb +0 -88
  133. data/lib/aws/core/inflection.rb +0 -56
  134. data/lib/aws/core/json_client.rb +0 -47
  135. data/lib/aws/core/json_parser.rb +0 -76
  136. data/lib/aws/core/json_request_builder.rb +0 -35
  137. data/lib/aws/core/json_response_parser.rb +0 -79
  138. data/lib/aws/core/lazy_error_classes.rb +0 -90
  139. data/lib/aws/core/log_formatter.rb +0 -428
  140. data/lib/aws/core/managed_file.rb +0 -32
  141. data/lib/aws/core/meta_utils.rb +0 -45
  142. data/lib/aws/core/model.rb +0 -57
  143. data/lib/aws/core/naming.rb +0 -30
  144. data/lib/aws/core/option_grammar.rb +0 -738
  145. data/lib/aws/core/options/json_serializer.rb +0 -82
  146. data/lib/aws/core/options/validator.rb +0 -155
  147. data/lib/aws/core/options/xml_serializer.rb +0 -118
  148. data/lib/aws/core/page_result.rb +0 -75
  149. data/lib/aws/core/policy.rb +0 -942
  150. data/lib/aws/core/query_client.rb +0 -41
  151. data/lib/aws/core/query_error_parser.rb +0 -24
  152. data/lib/aws/core/query_request_builder.rb +0 -47
  153. data/lib/aws/core/query_response_parser.rb +0 -35
  154. data/lib/aws/core/region.rb +0 -85
  155. data/lib/aws/core/region_collection.rb +0 -80
  156. data/lib/aws/core/resource.rb +0 -413
  157. data/lib/aws/core/resource_cache.rb +0 -40
  158. data/lib/aws/core/response.rb +0 -211
  159. data/lib/aws/core/response_cache.rb +0 -50
  160. data/lib/aws/core/rest_error_parser.rb +0 -24
  161. data/lib/aws/core/rest_json_client.rb +0 -40
  162. data/lib/aws/core/rest_request_builder.rb +0 -154
  163. data/lib/aws/core/rest_response_parser.rb +0 -66
  164. data/lib/aws/core/rest_xml_client.rb +0 -47
  165. data/lib/aws/core/service_interface.rb +0 -83
  166. data/lib/aws/core/signers/base.rb +0 -46
  167. data/lib/aws/core/signers/cloud_front.rb +0 -56
  168. data/lib/aws/core/signers/s3.rb +0 -159
  169. data/lib/aws/core/signers/version_2.rb +0 -72
  170. data/lib/aws/core/signers/version_3.rb +0 -86
  171. data/lib/aws/core/signers/version_3_https.rb +0 -61
  172. data/lib/aws/core/signers/version_4.rb +0 -228
  173. data/lib/aws/core/signers/version_4/chunk_signed_stream.rb +0 -191
  174. data/lib/aws/core/uri_escape.rb +0 -44
  175. data/lib/aws/core/xml/frame.rb +0 -244
  176. data/lib/aws/core/xml/frame_stack.rb +0 -85
  177. data/lib/aws/core/xml/grammar.rb +0 -306
  178. data/lib/aws/core/xml/parser.rb +0 -70
  179. data/lib/aws/core/xml/root_frame.rb +0 -65
  180. data/lib/aws/core/xml/sax_handlers/libxml.rb +0 -47
  181. data/lib/aws/core/xml/sax_handlers/nokogiri.rb +0 -56
  182. data/lib/aws/core/xml/sax_handlers/ox.rb +0 -41
  183. data/lib/aws/core/xml/sax_handlers/rexml.rb +0 -47
  184. data/lib/aws/core/xml/stub.rb +0 -123
  185. data/lib/aws/data_pipeline.rb +0 -72
  186. data/lib/aws/data_pipeline/client.rb +0 -36
  187. data/lib/aws/data_pipeline/config.rb +0 -18
  188. data/lib/aws/data_pipeline/errors.rb +0 -20
  189. data/lib/aws/direct_connect.rb +0 -73
  190. data/lib/aws/direct_connect/client.rb +0 -36
  191. data/lib/aws/direct_connect/config.rb +0 -18
  192. data/lib/aws/direct_connect/errors.rb +0 -22
  193. data/lib/aws/dynamo_db.rb +0 -214
  194. data/lib/aws/dynamo_db/attribute_collection.rb +0 -456
  195. data/lib/aws/dynamo_db/batch_get.rb +0 -213
  196. data/lib/aws/dynamo_db/batch_write.rb +0 -252
  197. data/lib/aws/dynamo_db/binary.rb +0 -35
  198. data/lib/aws/dynamo_db/client.rb +0 -129
  199. data/lib/aws/dynamo_db/client/v20111205.rb +0 -1266
  200. data/lib/aws/dynamo_db/client/v20120810.rb +0 -1409
  201. data/lib/aws/dynamo_db/client_v2.rb +0 -44
  202. data/lib/aws/dynamo_db/config.rb +0 -24
  203. data/lib/aws/dynamo_db/errors.rb +0 -20
  204. data/lib/aws/dynamo_db/expectations.rb +0 -40
  205. data/lib/aws/dynamo_db/item.rb +0 -133
  206. data/lib/aws/dynamo_db/item_collection.rb +0 -856
  207. data/lib/aws/dynamo_db/item_data.rb +0 -31
  208. data/lib/aws/dynamo_db/keys.rb +0 -41
  209. data/lib/aws/dynamo_db/primary_key_element.rb +0 -48
  210. data/lib/aws/dynamo_db/resource.rb +0 -33
  211. data/lib/aws/dynamo_db/table.rb +0 -496
  212. data/lib/aws/dynamo_db/table_collection.rb +0 -165
  213. data/lib/aws/dynamo_db/types.rb +0 -111
  214. data/lib/aws/ec2.rb +0 -428
  215. data/lib/aws/ec2/attachment.rb +0 -135
  216. data/lib/aws/ec2/attachment_collection.rb +0 -54
  217. data/lib/aws/ec2/availability_zone.rb +0 -86
  218. data/lib/aws/ec2/availability_zone_collection.rb +0 -43
  219. data/lib/aws/ec2/block_device_mappings.rb +0 -53
  220. data/lib/aws/ec2/client.rb +0 -101
  221. data/lib/aws/ec2/collection.rb +0 -36
  222. data/lib/aws/ec2/config.rb +0 -30
  223. data/lib/aws/ec2/customer_gateway.rb +0 -90
  224. data/lib/aws/ec2/customer_gateway_collection.rb +0 -73
  225. data/lib/aws/ec2/dhcp_options.rb +0 -106
  226. data/lib/aws/ec2/dhcp_options_collection.rb +0 -87
  227. data/lib/aws/ec2/elastic_ip.rb +0 -209
  228. data/lib/aws/ec2/elastic_ip_collection.rb +0 -93
  229. data/lib/aws/ec2/errors.rb +0 -32
  230. data/lib/aws/ec2/export_task.rb +0 -120
  231. data/lib/aws/ec2/export_task_collection.rb +0 -67
  232. data/lib/aws/ec2/filtered_collection.rb +0 -87
  233. data/lib/aws/ec2/has_permissions.rb +0 -44
  234. data/lib/aws/ec2/image.rb +0 -270
  235. data/lib/aws/ec2/image_collection.rb +0 -220
  236. data/lib/aws/ec2/instance.rb +0 -803
  237. data/lib/aws/ec2/instance_collection.rb +0 -391
  238. data/lib/aws/ec2/internet_gateway.rb +0 -122
  239. data/lib/aws/ec2/internet_gateway/attachment.rb +0 -78
  240. data/lib/aws/ec2/internet_gateway_collection.rb +0 -54
  241. data/lib/aws/ec2/key_pair.rb +0 -82
  242. data/lib/aws/ec2/key_pair_collection.rb +0 -99
  243. data/lib/aws/ec2/network_acl.rb +0 -256
  244. data/lib/aws/ec2/network_acl/association.rb +0 -56
  245. data/lib/aws/ec2/network_acl/entry.rb +0 -147
  246. data/lib/aws/ec2/network_acl_collection.rb +0 -64
  247. data/lib/aws/ec2/network_interface.rb +0 -237
  248. data/lib/aws/ec2/network_interface/attachment.rb +0 -100
  249. data/lib/aws/ec2/network_interface_collection.rb +0 -103
  250. data/lib/aws/ec2/permission_collection.rb +0 -174
  251. data/lib/aws/ec2/region.rb +0 -106
  252. data/lib/aws/ec2/region_collection.rb +0 -51
  253. data/lib/aws/ec2/reserved_instances.rb +0 -56
  254. data/lib/aws/ec2/reserved_instances_collection.rb +0 -40
  255. data/lib/aws/ec2/reserved_instances_offering.rb +0 -60
  256. data/lib/aws/ec2/reserved_instances_offering_collection.rb +0 -45
  257. data/lib/aws/ec2/resource.rb +0 -161
  258. data/lib/aws/ec2/resource_tag_collection.rb +0 -211
  259. data/lib/aws/ec2/route_table.rb +0 -205
  260. data/lib/aws/ec2/route_table/association.rb +0 -119
  261. data/lib/aws/ec2/route_table/route.rb +0 -119
  262. data/lib/aws/ec2/route_table_collection.rb +0 -72
  263. data/lib/aws/ec2/security_group.rb +0 -482
  264. data/lib/aws/ec2/security_group/ip_permission.rb +0 -135
  265. data/lib/aws/ec2/security_group/ip_permission_collection.rb +0 -82
  266. data/lib/aws/ec2/security_group_collection.rb +0 -133
  267. data/lib/aws/ec2/snapshot.rb +0 -143
  268. data/lib/aws/ec2/snapshot_collection.rb +0 -131
  269. data/lib/aws/ec2/subnet.rb +0 -161
  270. data/lib/aws/ec2/subnet_collection.rb +0 -115
  271. data/lib/aws/ec2/tag.rb +0 -81
  272. data/lib/aws/ec2/tag_collection.rb +0 -107
  273. data/lib/aws/ec2/tagged_collection.rb +0 -53
  274. data/lib/aws/ec2/tagged_item.rb +0 -85
  275. data/lib/aws/ec2/volume.rb +0 -174
  276. data/lib/aws/ec2/volume_collection.rb +0 -98
  277. data/lib/aws/ec2/vpc.rb +0 -166
  278. data/lib/aws/ec2/vpc_collection.rb +0 -70
  279. data/lib/aws/ec2/vpn_connection.rb +0 -99
  280. data/lib/aws/ec2/vpn_connection/telemetry.rb +0 -49
  281. data/lib/aws/ec2/vpn_connection_collection.rb +0 -96
  282. data/lib/aws/ec2/vpn_gateway.rb +0 -123
  283. data/lib/aws/ec2/vpn_gateway/attachment.rb +0 -45
  284. data/lib/aws/ec2/vpn_gateway_collection.rb +0 -77
  285. data/lib/aws/elastic_beanstalk.rb +0 -49
  286. data/lib/aws/elastic_beanstalk/client.rb +0 -36
  287. data/lib/aws/elastic_beanstalk/config.rb +0 -18
  288. data/lib/aws/elastic_beanstalk/errors.rb +0 -22
  289. data/lib/aws/elastic_transcoder.rb +0 -29
  290. data/lib/aws/elastic_transcoder/client.rb +0 -48
  291. data/lib/aws/elastic_transcoder/config.rb +0 -18
  292. data/lib/aws/elastic_transcoder/errors.rb +0 -23
  293. data/lib/aws/elasticache.rb +0 -49
  294. data/lib/aws/elasticache/client.rb +0 -35
  295. data/lib/aws/elasticache/config.rb +0 -18
  296. data/lib/aws/elasticache/errors.rb +0 -22
  297. data/lib/aws/elb.rb +0 -66
  298. data/lib/aws/elb/availability_zone_collection.rb +0 -138
  299. data/lib/aws/elb/backend_server_policy_collection.rb +0 -139
  300. data/lib/aws/elb/client.rb +0 -35
  301. data/lib/aws/elb/config.rb +0 -18
  302. data/lib/aws/elb/errors.rb +0 -26
  303. data/lib/aws/elb/instance_collection.rb +0 -168
  304. data/lib/aws/elb/listener.rb +0 -190
  305. data/lib/aws/elb/listener_collection.rb +0 -113
  306. data/lib/aws/elb/listener_opts.rb +0 -45
  307. data/lib/aws/elb/load_balancer.rb +0 -280
  308. data/lib/aws/elb/load_balancer_collection.rb +0 -146
  309. data/lib/aws/elb/load_balancer_policy.rb +0 -93
  310. data/lib/aws/elb/load_balancer_policy_collection.rb +0 -208
  311. data/lib/aws/emr.rb +0 -87
  312. data/lib/aws/emr/client.rb +0 -35
  313. data/lib/aws/emr/config.rb +0 -18
  314. data/lib/aws/emr/errors.rb +0 -22
  315. data/lib/aws/emr/instance_group.rb +0 -138
  316. data/lib/aws/emr/instance_group_collection.rb +0 -82
  317. data/lib/aws/emr/job_flow.rb +0 -307
  318. data/lib/aws/emr/job_flow_collection.rb +0 -185
  319. data/lib/aws/errors.rb +0 -162
  320. data/lib/aws/glacier.rb +0 -79
  321. data/lib/aws/glacier/archive.rb +0 -56
  322. data/lib/aws/glacier/archive_collection.rb +0 -146
  323. data/lib/aws/glacier/client.rb +0 -49
  324. data/lib/aws/glacier/config.rb +0 -19
  325. data/lib/aws/glacier/errors.rb +0 -22
  326. data/lib/aws/glacier/resource.rb +0 -30
  327. data/lib/aws/glacier/vault.rb +0 -145
  328. data/lib/aws/glacier/vault_collection.rb +0 -75
  329. data/lib/aws/glacier/vault_notification_configuration.rb +0 -29
  330. data/lib/aws/iam.rb +0 -408
  331. data/lib/aws/iam/access_key.rb +0 -185
  332. data/lib/aws/iam/access_key_collection.rb +0 -128
  333. data/lib/aws/iam/account_alias_collection.rb +0 -79
  334. data/lib/aws/iam/client.rb +0 -49
  335. data/lib/aws/iam/collection.rb +0 -83
  336. data/lib/aws/iam/config.rb +0 -18
  337. data/lib/aws/iam/errors.rb +0 -22
  338. data/lib/aws/iam/group.rb +0 -111
  339. data/lib/aws/iam/group_collection.rb +0 -132
  340. data/lib/aws/iam/group_policy_collection.rb +0 -47
  341. data/lib/aws/iam/group_user_collection.rb +0 -84
  342. data/lib/aws/iam/login_profile.rb +0 -99
  343. data/lib/aws/iam/mfa_device.rb +0 -52
  344. data/lib/aws/iam/mfa_device_collection.rb +0 -127
  345. data/lib/aws/iam/policy.rb +0 -46
  346. data/lib/aws/iam/policy_collection.rb +0 -188
  347. data/lib/aws/iam/resource.rb +0 -62
  348. data/lib/aws/iam/server_certificate.rb +0 -141
  349. data/lib/aws/iam/server_certificate_collection.rb +0 -138
  350. data/lib/aws/iam/signing_certificate.rb +0 -174
  351. data/lib/aws/iam/signing_certificate_collection.rb +0 -131
  352. data/lib/aws/iam/user.rb +0 -200
  353. data/lib/aws/iam/user_collection.rb +0 -133
  354. data/lib/aws/iam/user_group_collection.rb +0 -98
  355. data/lib/aws/iam/user_policy.rb +0 -90
  356. data/lib/aws/iam/user_policy_collection.rb +0 -45
  357. data/lib/aws/iam/virtual_mfa_device.rb +0 -139
  358. data/lib/aws/iam/virtual_mfa_device_collection.rb +0 -73
  359. data/lib/aws/import_export.rb +0 -73
  360. data/lib/aws/import_export/client.rb +0 -35
  361. data/lib/aws/import_export/config.rb +0 -19
  362. data/lib/aws/import_export/errors.rb +0 -22
  363. data/lib/aws/kinesis.rb +0 -53
  364. data/lib/aws/kinesis/client.rb +0 -35
  365. data/lib/aws/kinesis/config.rb +0 -18
  366. data/lib/aws/kinesis/errors.rb +0 -20
  367. data/lib/aws/ops_works.rb +0 -29
  368. data/lib/aws/ops_works/client.rb +0 -35
  369. data/lib/aws/ops_works/config.rb +0 -18
  370. data/lib/aws/ops_works/errors.rb +0 -20
  371. data/lib/aws/rails.rb +0 -195
  372. data/lib/aws/rds.rb +0 -70
  373. data/lib/aws/rds/client.rb +0 -42
  374. data/lib/aws/rds/config.rb +0 -18
  375. data/lib/aws/rds/db_instance.rb +0 -216
  376. data/lib/aws/rds/db_instance_collection.rb +0 -75
  377. data/lib/aws/rds/db_snapshot.rb +0 -163
  378. data/lib/aws/rds/db_snapshot_collection.rb +0 -89
  379. data/lib/aws/rds/errors.rb +0 -22
  380. data/lib/aws/record.rb +0 -139
  381. data/lib/aws/record/abstract_base.rb +0 -690
  382. data/lib/aws/record/attributes.rb +0 -388
  383. data/lib/aws/record/conversion.rb +0 -38
  384. data/lib/aws/record/dirty_tracking.rb +0 -287
  385. data/lib/aws/record/errors.rb +0 -143
  386. data/lib/aws/record/exceptions.rb +0 -51
  387. data/lib/aws/record/hash_model.rb +0 -204
  388. data/lib/aws/record/hash_model/attributes.rb +0 -195
  389. data/lib/aws/record/hash_model/finder_methods.rb +0 -172
  390. data/lib/aws/record/hash_model/scope.rb +0 -108
  391. data/lib/aws/record/model.rb +0 -453
  392. data/lib/aws/record/model/attributes.rb +0 -377
  393. data/lib/aws/record/model/finder_methods.rb +0 -232
  394. data/lib/aws/record/model/scope.rb +0 -212
  395. data/lib/aws/record/naming.rb +0 -31
  396. data/lib/aws/record/scope.rb +0 -203
  397. data/lib/aws/record/validations.rb +0 -694
  398. data/lib/aws/record/validator.rb +0 -246
  399. data/lib/aws/record/validators/acceptance.rb +0 -49
  400. data/lib/aws/record/validators/block.rb +0 -36
  401. data/lib/aws/record/validators/confirmation.rb +0 -41
  402. data/lib/aws/record/validators/count.rb +0 -106
  403. data/lib/aws/record/validators/exclusion.rb +0 -41
  404. data/lib/aws/record/validators/format.rb +0 -55
  405. data/lib/aws/record/validators/inclusion.rb +0 -54
  406. data/lib/aws/record/validators/length.rb +0 -105
  407. data/lib/aws/record/validators/method.rb +0 -31
  408. data/lib/aws/record/validators/numericality.rb +0 -136
  409. data/lib/aws/record/validators/presence.rb +0 -43
  410. data/lib/aws/redshift.rb +0 -51
  411. data/lib/aws/redshift/client.rb +0 -35
  412. data/lib/aws/redshift/config.rb +0 -18
  413. data/lib/aws/redshift/errors.rb +0 -22
  414. data/lib/aws/route_53.rb +0 -86
  415. data/lib/aws/route_53/change_batch.rb +0 -161
  416. data/lib/aws/route_53/change_info.rb +0 -72
  417. data/lib/aws/route_53/client.rb +0 -35
  418. data/lib/aws/route_53/config.rb +0 -18
  419. data/lib/aws/route_53/errors.rb +0 -22
  420. data/lib/aws/route_53/hosted_zone.rb +0 -111
  421. data/lib/aws/route_53/hosted_zone_collection.rb +0 -100
  422. data/lib/aws/route_53/resource_record_set.rb +0 -251
  423. data/lib/aws/route_53/resource_record_set_collection.rb +0 -110
  424. data/lib/aws/s3.rb +0 -156
  425. data/lib/aws/s3/access_control_list.rb +0 -265
  426. data/lib/aws/s3/acl_object.rb +0 -264
  427. data/lib/aws/s3/acl_options.rb +0 -204
  428. data/lib/aws/s3/bucket.rb +0 -742
  429. data/lib/aws/s3/bucket_collection.rb +0 -162
  430. data/lib/aws/s3/bucket_lifecycle_configuration.rb +0 -457
  431. data/lib/aws/s3/bucket_tag_collection.rb +0 -111
  432. data/lib/aws/s3/bucket_version_collection.rb +0 -79
  433. data/lib/aws/s3/cipher_io.rb +0 -120
  434. data/lib/aws/s3/client.rb +0 -1919
  435. data/lib/aws/s3/client/xml.rb +0 -259
  436. data/lib/aws/s3/config.rb +0 -48
  437. data/lib/aws/s3/cors_rule.rb +0 -108
  438. data/lib/aws/s3/cors_rule_collection.rb +0 -194
  439. data/lib/aws/s3/data_options.rb +0 -191
  440. data/lib/aws/s3/encryption_utils.rb +0 -146
  441. data/lib/aws/s3/errors.rb +0 -94
  442. data/lib/aws/s3/multipart_upload.rb +0 -351
  443. data/lib/aws/s3/multipart_upload_collection.rb +0 -76
  444. data/lib/aws/s3/object_collection.rb +0 -353
  445. data/lib/aws/s3/object_metadata.rb +0 -103
  446. data/lib/aws/s3/object_upload_collection.rb +0 -77
  447. data/lib/aws/s3/object_version.rb +0 -154
  448. data/lib/aws/s3/object_version_collection.rb +0 -89
  449. data/lib/aws/s3/paginated_collection.rb +0 -75
  450. data/lib/aws/s3/policy.rb +0 -74
  451. data/lib/aws/s3/prefix_and_delimiter_collection.rb +0 -47
  452. data/lib/aws/s3/prefixed_collection.rb +0 -85
  453. data/lib/aws/s3/presign_v4.rb +0 -127
  454. data/lib/aws/s3/presigned_post.rb +0 -554
  455. data/lib/aws/s3/request.rb +0 -62
  456. data/lib/aws/s3/s3_object.rb +0 -1781
  457. data/lib/aws/s3/tree.rb +0 -116
  458. data/lib/aws/s3/tree/branch_node.rb +0 -68
  459. data/lib/aws/s3/tree/child_collection.rb +0 -104
  460. data/lib/aws/s3/tree/leaf_node.rb +0 -94
  461. data/lib/aws/s3/tree/node.rb +0 -22
  462. data/lib/aws/s3/tree/parent.rb +0 -87
  463. data/lib/aws/s3/uploaded_part.rb +0 -82
  464. data/lib/aws/s3/uploaded_part_collection.rb +0 -84
  465. data/lib/aws/s3/website_configuration.rb +0 -102
  466. data/lib/aws/simple_db.rb +0 -218
  467. data/lib/aws/simple_db/attribute.rb +0 -156
  468. data/lib/aws/simple_db/attribute_collection.rb +0 -240
  469. data/lib/aws/simple_db/client.rb +0 -67
  470. data/lib/aws/simple_db/config.rb +0 -20
  471. data/lib/aws/simple_db/consistent_read_option.rb +0 -42
  472. data/lib/aws/simple_db/delete_attributes.rb +0 -62
  473. data/lib/aws/simple_db/domain.rb +0 -123
  474. data/lib/aws/simple_db/domain_collection.rb +0 -86
  475. data/lib/aws/simple_db/domain_metadata.rb +0 -110
  476. data/lib/aws/simple_db/errors.rb +0 -55
  477. data/lib/aws/simple_db/expect_condition_option.rb +0 -45
  478. data/lib/aws/simple_db/item.rb +0 -93
  479. data/lib/aws/simple_db/item_collection.rb +0 -654
  480. data/lib/aws/simple_db/item_data.rb +0 -73
  481. data/lib/aws/simple_db/put_attributes.rb +0 -60
  482. data/lib/aws/simple_email_service.rb +0 -430
  483. data/lib/aws/simple_email_service/client.rb +0 -37
  484. data/lib/aws/simple_email_service/config.rb +0 -18
  485. data/lib/aws/simple_email_service/email_address_collection.rb +0 -69
  486. data/lib/aws/simple_email_service/errors.rb +0 -22
  487. data/lib/aws/simple_email_service/identity.rb +0 -209
  488. data/lib/aws/simple_email_service/identity_collection.rb +0 -81
  489. data/lib/aws/simple_email_service/quotas.rb +0 -66
  490. data/lib/aws/simple_workflow.rb +0 -227
  491. data/lib/aws/simple_workflow/activity_task.rb +0 -178
  492. data/lib/aws/simple_workflow/activity_task_collection.rb +0 -123
  493. data/lib/aws/simple_workflow/activity_type.rb +0 -131
  494. data/lib/aws/simple_workflow/activity_type_collection.rb +0 -93
  495. data/lib/aws/simple_workflow/client.rb +0 -69
  496. data/lib/aws/simple_workflow/config.rb +0 -18
  497. data/lib/aws/simple_workflow/count.rb +0 -49
  498. data/lib/aws/simple_workflow/decision_task.rb +0 -603
  499. data/lib/aws/simple_workflow/decision_task_collection.rb +0 -225
  500. data/lib/aws/simple_workflow/domain.rb +0 -122
  501. data/lib/aws/simple_workflow/domain_collection.rb +0 -169
  502. data/lib/aws/simple_workflow/errors.rb +0 -20
  503. data/lib/aws/simple_workflow/history_event.rb +0 -276
  504. data/lib/aws/simple_workflow/history_event_collection.rb +0 -76
  505. data/lib/aws/simple_workflow/option_formatters.rb +0 -82
  506. data/lib/aws/simple_workflow/resource.rb +0 -94
  507. data/lib/aws/simple_workflow/type.rb +0 -89
  508. data/lib/aws/simple_workflow/type_collection.rb +0 -140
  509. data/lib/aws/simple_workflow/workflow_execution.rb +0 -384
  510. data/lib/aws/simple_workflow/workflow_execution_collection.rb +0 -617
  511. data/lib/aws/simple_workflow/workflow_type.rb +0 -179
  512. data/lib/aws/simple_workflow/workflow_type_collection.rb +0 -91
  513. data/lib/aws/sns.rb +0 -76
  514. data/lib/aws/sns/client.rb +0 -35
  515. data/lib/aws/sns/config.rb +0 -18
  516. data/lib/aws/sns/errors.rb +0 -22
  517. data/lib/aws/sns/has_delivery_policy.rb +0 -68
  518. data/lib/aws/sns/message.rb +0 -194
  519. data/lib/aws/sns/originators/from_auto_scaling.rb +0 -68
  520. data/lib/aws/sns/policy.rb +0 -47
  521. data/lib/aws/sns/subscription.rb +0 -165
  522. data/lib/aws/sns/subscription_collection.rb +0 -78
  523. data/lib/aws/sns/topic.rb +0 -403
  524. data/lib/aws/sns/topic_collection.rb +0 -62
  525. data/lib/aws/sns/topic_subscription_collection.rb +0 -54
  526. data/lib/aws/sqs.rb +0 -80
  527. data/lib/aws/sqs/client.rb +0 -53
  528. data/lib/aws/sqs/config.rb +0 -20
  529. data/lib/aws/sqs/errors.rb +0 -125
  530. data/lib/aws/sqs/policy.rb +0 -48
  531. data/lib/aws/sqs/queue.rb +0 -843
  532. data/lib/aws/sqs/queue_collection.rb +0 -182
  533. data/lib/aws/sqs/received_message.rb +0 -182
  534. data/lib/aws/sqs/received_sns_message.rb +0 -116
  535. data/lib/aws/storage_gateway.rb +0 -72
  536. data/lib/aws/storage_gateway/client.rb +0 -42
  537. data/lib/aws/storage_gateway/config.rb +0 -18
  538. data/lib/aws/storage_gateway/errors.rb +0 -22
  539. data/lib/aws/sts.rb +0 -164
  540. data/lib/aws/sts/client.rb +0 -46
  541. data/lib/aws/sts/config.rb +0 -18
  542. data/lib/aws/sts/errors.rb +0 -22
  543. data/lib/aws/sts/federated_session.rb +0 -56
  544. data/lib/aws/sts/policy.rb +0 -30
  545. data/lib/aws/sts/session.rb +0 -48
  546. data/lib/aws/support.rb +0 -29
  547. data/lib/aws/support/client.rb +0 -35
  548. data/lib/aws/support/config.rb +0 -18
  549. data/lib/aws/support/errors.rb +0 -20
  550. data/lib/aws/version.rb +0 -17
  551. data/rails/init.rb +0 -15
data/lib/aws/sqs/queue.rb DELETED
@@ -1,843 +0,0 @@
1
- # Copyright 2011-2013 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 'digest'
15
-
16
- module AWS
17
- class SQS
18
-
19
- # Represents an Amazon SQS Queue.
20
- #
21
- # @example Sending a message
22
- #
23
- # msg = queue.send_message("HELLO")
24
- # puts "Sent message: #{msg.id}"
25
- #
26
- # @example Polling for messages indefinitely
27
- #
28
- # queue.poll do |msg|
29
- # puts "Got message: #{msg.body}"
30
- # end
31
- #
32
- class Queue
33
-
34
- # The default number of seconds to wait between polling requests for
35
- # new messages.
36
- # @deprecated No longer used by {#poll}
37
- DEFAULT_POLL_INTERVAL = 1
38
-
39
- # The default number of seconds to pass in as the SQS long polling
40
- # value (`:wait_time_seconds`) in {#receive_message}.
41
- #
42
- # @since 1.8.0
43
- DEFAULT_WAIT_TIME_SECONDS = 15
44
-
45
- include Core::Model
46
-
47
- # @return [String] The queue URL.
48
- attr_reader :url
49
-
50
- # @api private
51
- def initialize(url, opts = {})
52
- @url = url
53
- super
54
- end
55
-
56
- # Deletes the queue, regardless of whether it is empty.
57
- #
58
- # When you delete a queue, the deletion process takes up to 60
59
- # seconds. Requests you send involving that queue during the
60
- # 60 seconds might succeed. For example, calling
61
- # {#send_message} might succeed, but after the 60 seconds, the
62
- # queue and that message you sent no longer exist.
63
- #
64
- # Also, when you delete a queue, you must wait at least 60 seconds
65
- # before creating a queue with the same name.
66
- # @return [nil]
67
- def delete
68
- client.delete_queue(:queue_url => url)
69
- nil
70
- end
71
-
72
- # Represents a message sent using {Queue#send_message}.
73
- class SentMessage
74
-
75
- # @return [String] Returns the message ID.
76
- attr_accessor :message_id
77
-
78
- alias_method :id, :message_id
79
-
80
- # @return [String] Returns an MD5 digest of the message body
81
- # string. You can use this to verify that SQS received your
82
- # message correctly.
83
- attr_accessor :md5
84
-
85
- end
86
-
87
- # Delivers a message to this queue.
88
- #
89
- # @param [String] body The message to send. The maximum
90
- # allowed message size is 64 KB. The message may only
91
- # contain Unicode characters from the following list,
92
- # according to the W3C XML specification (for more
93
- # information, go to
94
- # http://www.w3.org/TR/REC-xml/#charsets). If you send any
95
- # characters not included in the list, your request will be
96
- # rejected.
97
- #
98
- # * #x9
99
- # * #xA
100
- # * #xD
101
- # * #x20 to #xD7FF
102
- # * #xE000 to #xFFFD
103
- # * #x10000 to #x10FFFF
104
- #
105
- # @param [Hash] options
106
- #
107
- # @option options [Integer] :delay_seconds The number of seconds to
108
- # delay the message. The message will become available for
109
- # processing after the delay time has passed.
110
- # If you don't specify a value, the default value for the
111
- # queue applies. Should be from 0 to 900 (15 mins).
112
- #
113
- # @return [SentMessage] An object containing information about
114
- # the message that was sent.
115
- #
116
- def send_message body, options = {}
117
-
118
- client_opts = options.dup
119
- client_opts[:queue_url] = url
120
- client_opts[:message_body] = body
121
-
122
- response = client.send_message(client_opts)
123
-
124
- msg = SentMessage.new
125
- msg.message_id = response[:message_id]
126
- msg.md5 = response[:md5_of_message_body]
127
-
128
- verify_send_message_checksum body, msg.md5
129
-
130
- msg
131
-
132
- end
133
-
134
- # Retrieves one or more messages. When a block is given, each
135
- # message is yielded to the block and then deleted as long as
136
- # the block exits normally. When no block is given, you must
137
- # delete the message yourself using {ReceivedMessage#delete}.
138
- #
139
- # @note Due to the distributed nature of the queue, a weighted
140
- # random set of machines is sampled on a ReceiveMessage
141
- # call. That means only the messages on the sampled machines
142
- # are returned. If the number of messages in the queue is
143
- # small (less than 1000), it is likely you will get fewer
144
- # messages than you requested per call to
145
- # {#receive_message}. If the number of messages in the queue
146
- # is extremely small, you might not receive any messages.
147
- # To poll continually for messages, use the {#poll} method,
148
- # which automatically retries the request after a
149
- # configurable delay.
150
- #
151
- # @param [Hash] opts Options for receiving messages.
152
- #
153
- # @option opts [Integer] :limit The maximum number of messages
154
- # to receive. By default this is 1, and the return value is
155
- # a single message object. If this options is specified and
156
- # is not 1, the return value is an array of message objects;
157
- # however, the array may contain fewer objects than you
158
- # requested. Valid values: integers from 1 to 10.
159
- #
160
- # Not necessarily all the messages in the queue are returned
161
- # (for more information, see the preceding note about
162
- # machine sampling).
163
- #
164
- # @option opts [Integer] :wait_time_seconds The number of seconds
165
- # the service should wait for a response when requesting a new message.
166
- # Defaults to the {#wait_time_seconds} attribute defined on the queue.
167
- # See {#wait_time_seconds} to set the global long poll setting
168
- # on the queue.
169
- #
170
- # @option opts [Integer] :visibility_timeout The duration (in
171
- # seconds) that the received messages are hidden from
172
- # subsequent retrieve requests. Valid values: integer from
173
- # 0 to 43200 (maximum 12 hours)
174
- #
175
- # @option opts [Array<Symbol, String>] :attributes The
176
- # attributes to populate in each received message. Valid values:
177
- #
178
- # * `:all` (to populate all attributes)
179
- # * `:sender_id`
180
- # * `:sent_at`
181
- # * `:receive_count`
182
- # * `:first_received_at`
183
- #
184
- # See {ReceivedMessage} for documentation on each
185
- # attribute's meaning.
186
- #
187
- # @yieldparam [ReceivedMessage] message Each message that was received.
188
- #
189
- # @return [ReceivedMessage] Returns the received message (or messages)
190
- # only if a block is not given to this method.
191
- #
192
- def receive_message(opts = {}, &block)
193
- resp = client.receive_message(receive_opts(opts))
194
-
195
- failed = verify_receive_message_checksum resp
196
-
197
- raise Errors::ChecksumError.new(failed) unless failed.empty?
198
-
199
- messages = resp[:messages].map do |m|
200
- ReceivedMessage.new(self, m[:message_id], m[:receipt_handle],
201
- :body => m[:body],
202
- :md5 => m[:md5_of_body],
203
- :attributes => m[:attributes])
204
- end
205
-
206
- if block
207
- call_message_block(messages, block)
208
- elsif opts[:limit] && opts[:limit] != 1
209
- messages
210
- else
211
- messages.first
212
- end
213
- end
214
- alias_method :receive_messages, :receive_message
215
-
216
- # Polls continually for messages. For example, you can use
217
- # this to poll indefinitely:
218
- #
219
- # queue.poll { |msg| puts msg.body }
220
- #
221
- # Or, to poll indefinitely for the first message and then
222
- # continue polling until no message is received for a period
223
- # of at least ten seconds:
224
- #
225
- # queue.poll(:initial_timeout => false,
226
- # :idle_timeout => 10) { |msg| puts msg.body }
227
- #
228
- # As with the block form of {#receive_message}, this method
229
- # automatically deletes the message then the block exits
230
- # normally.
231
- #
232
- # @yieldparam [ReceivedMessage] message Each message that was received.
233
- #
234
- # @param [Hash] opts Options for polling.
235
- #
236
- # @option opts [Integer] :wait_time_seconds The number of seconds
237
- # the service should wait for a response when requesting a new message.
238
- # Defaults to {DEFAULT_WAIT_TIME_SECONDS}. Use `nil` to
239
- # use the queue's global long polling wait time setting.
240
- # See {#wait_time_seconds} to set the global long poll setting
241
- # on the queue.
242
- #
243
- # @option opts [Integer] :idle_timeout The maximum number of
244
- # seconds to spend polling while no messages are being
245
- # returned. By default this method polls indefinitely
246
- # whether messages are received or not.
247
- #
248
- # @option opts [Integer] :initial_timeout The maximum number
249
- # of seconds to spend polling before the first message is
250
- # received. This option defaults to the value of
251
- # `:idle_timeout`. You can specify `false` to poll
252
- # indefinitely for the first message when `:idle_timeout` is
253
- # set.
254
- #
255
- # @option opts [Integer] :batch_size The maximum number of
256
- # messages to retrieve in a single request. By default
257
- # messages are received one at a time. Valid values:
258
- # integers from 1 to 10.
259
- #
260
- # @option opts [Integer] :visibility_timeout The duration (in
261
- # seconds) that the received messages are hidden from
262
- # subsequent retrieve requests. Valid values: integer from
263
- # 0 to 43200 (maximum 12 hours)
264
- #
265
- # @option opts [Array<Symbol, String>] :attributes The
266
- # attributes to populate in each received message. Valid values:
267
- #
268
- # * `:all` (to populate all attributes)
269
- # * `:sender_id`
270
- # * `:sent_at`
271
- # * `:receive_count`
272
- # * `:first_received_at`
273
- #
274
- # See {ReceivedMessage} for documentation on each
275
- # attribute's meaning.
276
- #
277
- # @option opts [Float, Integer] :poll_interval As of
278
- # v1.7.2, this option is no longer used. See the
279
- # `:wait_time_seconds` option for long polling instead.
280
- #
281
- # @return [nil]
282
- def poll(opts = {}, &block)
283
- opts[:limit] = opts.delete(:batch_size) if
284
- opts.key?(:batch_size)
285
-
286
- opts[:wait_time_seconds] = DEFAULT_WAIT_TIME_SECONDS unless
287
- opts.has_key?(:wait_time_seconds)
288
-
289
- last_message_at = Time.now
290
- got_first = false
291
- loop do
292
- got_msg = false
293
- receive_messages(opts) do |message|
294
- got_msg = got_first = true
295
- last_message_at = Time.now
296
- yield(message)
297
- end
298
- unless got_msg
299
- return if hit_timeout?(got_first, last_message_at, opts)
300
- end
301
- end
302
- nil
303
- end
304
-
305
- # @return [Integer] The approximate number of visible messages
306
- # in a queue. For more information, see
307
- # [Resources Required to Process Messages](http://docs.amazonwebservices.com/AWSSimpleQueueService/latest/SQSDeveloperGuide/IntroductionArticle.html#ApproximateNumber)
308
- # in the Amazon SQS Developer Guide.
309
- def approximate_number_of_messages
310
- get_attribute("ApproximateNumberOfMessages").to_i
311
- end
312
- alias_method :visible_messages, :approximate_number_of_messages
313
-
314
- # @return [Integer] The approximate number of messages that
315
- # are not timed-out and not deleted. For more information,
316
- # see [Resources Required to Process Messages](http://docs.amazonwebservices.com/AWSSimpleQueueService/latest/SQSDeveloperGuide/IntroductionArticle.html#ApproximateNumber)
317
- # in the Amazon SQS Developer Guide.
318
- def approximate_number_of_messages_not_visible
319
- get_attribute("ApproximateNumberOfMessagesNotVisible").to_i
320
- end
321
- alias_method :invisible_messages, :approximate_number_of_messages_not_visible
322
-
323
- # @return [Integer] Returns the visibility timeout for the
324
- # queue. For more information about visibility timeout, see
325
- # [Visibility Timeout](http://docs.amazonwebservices.com/AWSSimpleQueueService/latest/SQSDeveloperGuide/IntroductionArticle.html#AboutVT)
326
- # in the Amazon SQS Developer Guide.
327
- def visibility_timeout
328
- get_attribute("VisibilityTimeout").to_i
329
- end
330
-
331
- # Sets the visibility timeout for the queue.
332
- #
333
- # @param [Integer] timeout The length of time (in seconds)
334
- # that a message received from a queue will be invisible to
335
- # other receiving components when they ask to receive
336
- # messages. Valid values: integers from 0 to 43200 (12
337
- # hours).
338
- #
339
- # @return Returns the value passed as a timeout.
340
- def visibility_timeout=(timeout)
341
- set_attribute("VisibilityTimeout", timeout.to_s)
342
- timeout
343
- end
344
-
345
- # @return [Time] The time when the queue was created.
346
- def created_timestamp
347
- Time.at(get_attribute("CreatedTimestamp").to_i)
348
- end
349
-
350
- # @return [Time] The time when the queue was last changed.
351
- def last_modified_timestamp
352
- Time.at(get_attribute("LastModifiedTimestamp").to_i)
353
- end
354
-
355
- # @return [Integer] The limit of how many bytes a message can
356
- # contain before Amazon SQS rejects it.
357
- def maximum_message_size
358
- get_attribute("MaximumMessageSize").to_i
359
- end
360
-
361
- # Sets the maximum message size for the queue.
362
- #
363
- # @param [Integer] size The limit of how many bytes a message
364
- # can contain before Amazon SQS rejects it. This must be an
365
- # integer from 1024 bytes (1KB) up to 65536 bytes
366
- # (64KB). The default for this attribute is 8192 (8KB).
367
- # @return Retuns the passed size argument.
368
- def maximum_message_size=(size)
369
- set_attribute("MaximumMessageSize", size.to_s)
370
- end
371
-
372
- # @return [Integer] The number of seconds Amazon SQS retains a
373
- # message.
374
- def message_retention_period
375
- get_attribute("MessageRetentionPeriod").to_i
376
- end
377
-
378
- # Sets the message retention period for the queue
379
- #
380
- # @param [Integer] period The number of seconds Amazon SQS
381
- # retains a message. Must be an integer from 3600 (1 hour)
382
- # to 1209600 (14 days). The default for this attribute is
383
- # 345600 (4 days).
384
- # @return Returns the passed period argument.
385
- def message_retention_period=(period)
386
- set_attribute("MessageRetentionPeriod", period.to_s)
387
- period
388
- end
389
-
390
- # @return [Integer] Gets the current default delay for messages sent
391
- # to the queue.
392
- def delay_seconds
393
- get_attribute("DelaySeconds").to_i
394
- end
395
-
396
- # Sets the default delay for messages sent to the queue.
397
- # @param [Integer] seconds How many seconds a message will be delayed.
398
- def delay_seconds= seconds
399
- set_attribute("DelaySeconds", seconds.to_s)
400
- end
401
-
402
- # @return [Integer] Gets the number of seconds the service will wait
403
- # for a response when requesting a new message
404
- # @since 1.8.0
405
- def wait_time_seconds
406
- get_attribute("ReceiveMessageWaitTimeSeconds").to_i
407
- end
408
-
409
- # Sets the number of seconds that the service should wait for a response
410
- # when requesting a new message
411
- # @param [Integer] seconds How many seconds to wait for a response
412
- # @since 1.8.0
413
- def wait_time_seconds= seconds
414
- set_attribute("ReceiveMessageWaitTimeSeconds", seconds.to_s)
415
- end
416
-
417
- # @return [Integer] Returns an approximate count of messages delayed.
418
- def approximate_number_of_messages_delayed
419
- get_attribute("ApproximateNumberOfMessagesDelayed").to_i
420
- end
421
-
422
- # @return [String] The queue's Amazon resource name (ARN).
423
- def arn
424
- @arn ||= get_attribute("QueueArn")
425
- end
426
-
427
- # @return [Boolean] True if the queue exists.
428
- #
429
- # @note This may raise an exception if you don't have
430
- # permission to access the queue attributes. Also, it may
431
- # return true for up to 60 seconds after a queue has been
432
- # deleted.
433
- def exists?
434
- client.get_queue_attributes(:queue_url => url,
435
- :attribute_names => ["QueueArn"])
436
- rescue Errors::NonExistentQueue, Errors::InvalidAddress
437
- false
438
- else
439
- true
440
- end
441
-
442
- # @api private
443
- module PolicyProxy
444
-
445
- attr_accessor :queue
446
-
447
- def change
448
- yield(self)
449
- queue.policy = self
450
- end
451
-
452
- def delete
453
- queue.client.send(:set_attribute, 'Policy', '')
454
- end
455
-
456
- end
457
-
458
- # @return [Policy] Returns the current queue policy if there is one.
459
- # Returns `nil` otherwise.
460
- def policy
461
- if policy_json = get_attribute('Policy')
462
- policy = SQS::Policy.from_json(policy_json)
463
- policy.extend(PolicyProxy)
464
- policy.queue = self
465
- policy
466
- else
467
- nil
468
- end
469
- end
470
-
471
- # Set the policy on this queue.
472
- #
473
- # If you pass nil or an empty string then it will have the same
474
- # effect as deleting the policy.
475
- #
476
- # @param policy The policy to set. This policy can be a {Policy} object,
477
- # a json policy string, or any other object that responds with a policy
478
- # string when it received #to_json.
479
- #
480
- # @return [nil]
481
- #
482
- def policy= policy
483
- policy_string = case policy
484
- when nil, '' then ''
485
- when String then policy
486
- else policy.to_json
487
- end
488
- set_attribute('Policy', policy_string)
489
- nil
490
- end
491
-
492
- # Sends a batch of up to 10 messages in a single request.
493
- #
494
- # queue.send_messages('message-1', 'message-2')
495
- #
496
- # You can also set an optional delay for all of the messages:
497
- #
498
- # # delay all messages 15 minutes
499
- # queue.batch_send(msg1, msg2, :delay_seconds => 900)
500
- #
501
- # If you need to set a custom delay for each message you can pass
502
- # hashes:
503
- #
504
- # messages = []
505
- # messages << { :message_body => 'msg1', :delay_seconds => 60 }
506
- # messages << { :message_body => 'msg2', :delay_seconds => 30 }
507
- #
508
- # queue.batch_send(messages)
509
- #
510
- # @param [String,Hash] messages A list of messages. Each message
511
- # should be a string, or a hash with a `:message_body`,
512
- # and optionally `:delay_seconds`.
513
- #
514
- # @raise [Errors::BatchSendError] Raises this error when one or more
515
- # of the messages failed to send, but others did. On the raised
516
- # object you can access a list of the messages that failed, and
517
- # a list of messages that succeeded.
518
- #
519
- # @return [Array<SentMessage>] Returns an array of sent message objects.
520
- # Each object responds to #message_id and #md5_of_message_body.
521
- # The message id is generated by Amazon SQS.
522
- #
523
- def batch_send *messages
524
-
525
- entries = messages.flatten
526
-
527
- unless entries.first.is_a?(Hash)
528
- options = entries.last.is_a?(Hash) ? entries.pop : {}
529
- entries = entries.collect{|msg| { :message_body => msg } }
530
- if delay = options[:delay_seconds]
531
- entries.each {|entry| entry[:delay_seconds] = delay }
532
- end
533
- end
534
-
535
- entries.each_with_index {|entry,n| entry[:id] = n.to_s }
536
-
537
- client_opts = {}
538
- client_opts[:queue_url] = url
539
- client_opts[:entries] = entries
540
-
541
- response = client.send_message_batch(client_opts)
542
-
543
- failed = batch_failures(entries, response, true)
544
-
545
- checksum_failed = verify_send_message_batch_checksum entries, response
546
-
547
- sent = response[:successful].collect do |sent|
548
- msg = SentMessage.new
549
- msg.message_id = sent[:message_id]
550
- msg.md5 = sent[:md5_of_message_body]
551
- msg
552
- end
553
-
554
- if !failed.empty? && !checksum_failed.empty?
555
- send_error = Errors::BatchSendError.new(sent, failed)
556
- checksum_error = Errors::ChecksumError.new(checksum_failed)
557
- raise Errors::BatchSendMultiError.new send_error, checksum_error
558
- elsif !failed.empty?
559
- raise Errors::BatchSendError.new(sent, failed) unless failed.empty?
560
- elsif !checksum_failed.empty?
561
- raise Errors::ChecksumError.new(checksum_failed)
562
- end
563
-
564
- sent
565
-
566
- end
567
-
568
- # @param [ReceivedMessage,String] messages A list of up to 10 messages
569
- # to delete. Each message should be a {ReceivedMessage} object
570
- # or a received message handle (string).
571
- #
572
- # @raise [Errors::BatchDeleteSend] Raised when one or more of the
573
- # messages failed to delete. The raised error has a list
574
- # of the failures.
575
- #
576
- # @return [nil]
577
- #
578
- def batch_delete *messages
579
-
580
- entries = []
581
- messages.flatten.each_with_index do |msg,n|
582
- handle = msg.is_a?(ReceivedMessage) ? msg.handle : msg
583
- entries << { :id => n.to_s, :receipt_handle => handle }
584
- end
585
-
586
- response = client.delete_message_batch(
587
- :queue_url => url, :entries => entries)
588
-
589
- failures = batch_failures(entries, response)
590
-
591
- raise Errors::BatchDeleteError.new(failures) unless failures.empty?
592
-
593
- nil
594
-
595
- end
596
-
597
- # @overload batch_change_visibility(visibility_timeout, *messages)
598
- #
599
- # Accepts a single `:visibility_timeout` value and a list of
600
- # messages ({ReceivedMessage} objects or receipt handle strings).
601
- # This form of the method is useful when you want to set the same
602
- # timeout value for each message.
603
- #
604
- # queue.batch_change_visibility(10, messages)
605
- #
606
- # @param [Integer] visibility_timeout The new value for the message's
607
- # visibility timeout (in seconds).
608
- #
609
- # @param [ReceivedMessage,String] message A list of up to 10 messages
610
- # to change the visibility timeout for.
611
- #
612
- # @raise [BatchChangeVisibilityError] Raises this error when one
613
- # or more of the messages failed the visibility update.
614
- #
615
- # @return [nil]
616
- #
617
- # @overload batch_change_visibility(*messages_with_timeouts)
618
- #
619
- # Accepts a list of hashes. Each hash should provide the visibility
620
- # timeout and message (a {ReceivedMessage} object or the recipt handle
621
- # string).
622
- #
623
- # Use this form when each message needs a different visiblity timeout.
624
- #
625
- # messages = []
626
- # messages << { :message => 'handle1', :visibility_timeout => 5 }
627
- # messages << { :message => 'handle2', :visibility_timeout => 10 }
628
- #
629
- # queue.batch_change_visibility(*messages)
630
- #
631
- # @param [Hash] message A list hashes, each with a `:visibility_timeout`
632
- # and a `:message`.
633
- #
634
- # @raise [BatchChangeVisibilityError] Raises this error when one
635
- # or more of the messages failed the visibility update.
636
- #
637
- # @return [nil]
638
- #
639
- def batch_change_visibility *args
640
-
641
- args = args.flatten
642
-
643
- if args.first.is_a?(Integer)
644
- timeout = args.shift
645
- messages = args.collect{|m| [m, timeout] }
646
- else
647
- messages = args.collect{|m| [m[:message], m[:visibility_timeout]] }
648
- end
649
-
650
- entries = []
651
- messages.each do |msg,timeout|
652
- handle = msg.is_a?(ReceivedMessage) ? msg.handle : msg
653
- entries << {
654
- :id => entries.size.to_s,
655
- :receipt_handle => handle,
656
- :visibility_timeout => timeout,
657
- }
658
- end
659
-
660
- response = client.change_message_visibility_batch(
661
- :queue_url => url, :entries => entries)
662
-
663
- failures = batch_failures(entries, response)
664
-
665
- raise Errors::BatchChangeVisibilityError.new(failures) unless
666
- failures.empty?
667
-
668
- nil
669
-
670
- end
671
-
672
- # @return [Boolean] Returns true if the other queue has the same
673
- # url.
674
- def ==(other)
675
- other.kind_of?(Queue) and other.url == url
676
- end
677
- alias_method :eql?, :==
678
-
679
- # @api private
680
- def inspect
681
- "<#{self.class}:#{url}>"
682
- end
683
-
684
- protected
685
- def batch_failures entries, response, include_batch_index=false
686
- response[:failed].inject([]) do |failures, failure|
687
-
688
- entry = entries.find{|e| e[:id] == failure[:id] }
689
-
690
- details = {
691
- :error_code => failure[:code],
692
- :error_message => failure[:message],
693
- :sender_fault => failure[:sender_fault],
694
- }
695
-
696
- if include_batch_index
697
- details[:batch_index] = failure[:id].to_i
698
- end
699
-
700
- if message_body = entry[:message_body]
701
- details[:message_body] = message_body
702
- end
703
-
704
- if handle = entry[:receipt_handle]
705
- details[:receipt_handle] = handle
706
- end
707
-
708
- failures << details
709
-
710
- end
711
- end
712
-
713
- # @api private
714
- protected
715
- def hit_timeout?(got_first, last_message_at, opts)
716
- initial_timeout = opts[:initial_timeout]
717
- idle_timeout = opts[:idle_timeout]
718
-
719
- timeout = (got_first ||
720
- # if initial_timeout is false (as opposed
721
- # to nil) then we skip the branch and poll
722
- # indefinitely until the first message
723
- # comes
724
- (!initial_timeout && initial_timeout != false) ?
725
- idle_timeout :
726
- initial_timeout) and
727
- Time.now - last_message_at > timeout
728
- end
729
-
730
- # @api private
731
- protected
732
- def receive_opts(opts)
733
- receive_opts = { :queue_url => url }
734
- receive_opts[:visibility_timeout] = opts[:visibility_timeout] if
735
- opts[:visibility_timeout]
736
- receive_opts[:max_number_of_messages] = opts[:limit] if
737
- opts[:limit]
738
- receive_opts[:wait_time_seconds] = opts[:wait_time_seconds] if
739
- opts[:wait_time_seconds]
740
-
741
- if names = opts[:attributes]
742
- receive_opts[:attribute_names] = names.map do |name|
743
- name = ReceivedMessage::ATTRIBUTE_ALIASES[name.to_sym] if
744
- ReceivedMessage::ATTRIBUTE_ALIASES.key?(name.to_sym)
745
- name = Core::Inflection.class_name(name.to_s) if name.kind_of?(Symbol)
746
- name
747
- end
748
- end
749
- receive_opts
750
- end
751
-
752
- # @api private
753
- protected
754
- def call_message_block(messages, block)
755
- result = nil
756
- messages.each do |message|
757
- begin
758
- result = block.call(message)
759
- rescue Exception => e
760
- raise
761
- else
762
- message.delete
763
- end
764
- end
765
- result
766
- end
767
-
768
- # @api private
769
- protected
770
- def get_attribute(name)
771
- resp = client.get_queue_attributes(:queue_url => url,
772
- :attribute_names =>
773
- [name, "QueueArn"].uniq)
774
- @arn ||= resp.attributes["QueueArn"]
775
- resp.attributes[name]
776
- end
777
-
778
- # @api private
779
- protected
780
- def set_attribute(name, value)
781
- client.set_queue_attributes({
782
- :queue_url => url,
783
- :attributes => { name => value },
784
- })
785
- end
786
-
787
- # @api private
788
- protected
789
- def is_checksum_valid checksum, data
790
- if config.sqs_verify_checksums?
791
- calculate_checksum(data) == checksum
792
- else
793
- true
794
- end
795
- end
796
-
797
- # @api private
798
- protected
799
- def calculate_checksum data
800
- Digest::MD5.hexdigest data
801
- end
802
-
803
- # @api private
804
- protected
805
- def verify_send_message_checksum body, md5
806
- unless is_checksum_valid md5, body
807
- raise Errors::ChecksumError.new "Invalid MD5 #{md5} for message body #{body}"
808
- end
809
- end
810
-
811
- # @api private
812
- protected
813
- def verify_send_message_batch_checksum entries, response
814
- failed = []
815
-
816
- response[:successful].each do |msg|
817
- entry = entries.find{ |e| e[:id] == msg[:id] }
818
- failed << msg unless is_checksum_valid msg[:md5_of_message_body], entry[:message_body]
819
- end
820
-
821
- failed
822
- end
823
-
824
- # @api private
825
- protected
826
- def verify_receive_message_checksum response
827
- return [] if response[:messages].nil?
828
-
829
- invalid_msgs = []
830
-
831
- response[:messages].each do |msg|
832
- md5 = msg[:md5_of_body]
833
- body = msg[:body]
834
- invalid_msgs << msg unless is_checksum_valid md5, body
835
- end
836
-
837
- invalid_msgs
838
- end
839
-
840
- end
841
-
842
- end
843
- end