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,213 @@
1
+ # Copyright 2011-2012 Amazon.com, Inc. or its affiliates. All Rights Reserved.
2
+ #
3
+ # Licensed under the Apache License, Version 2.0 (the "License"). You
4
+ # may not use this file except in compliance with the License. A copy of
5
+ # the License is located at
6
+ #
7
+ # http://aws.amazon.com/apache2.0/
8
+ #
9
+ # or in the "license" file accompanying this file. This file is
10
+ # distributed on an "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF
11
+ # ANY KIND, either express or implied. See the License for the specific
12
+ # language governing permissions and limitations under the License.
13
+
14
+ require 'aws/core'
15
+ require 'aws/dynamo_db/config'
16
+
17
+ module AWS
18
+
19
+ # Provides a high-level interface for using DynamoDB.
20
+ #
21
+ # dynamo_db = AWS::DynamoDB.new(
22
+ # :access_key_id => '...',
23
+ # :secret_access_key => '...',
24
+ # :session_token => '...')
25
+ #
26
+ # = Credentials
27
+ #
28
+ # Amazon DynamoDB requires that all requests are made with short-term
29
+ # credentials (e.g. requires a session token).
30
+ #
31
+ # @note If you make a request using AWS::DynamoDB with long-term credentials
32
+ # a request is made to Amazon STS for temproary session credentials.
33
+ # These will be cached in the process and re-used.
34
+ #
35
+ # = Tables
36
+ #
37
+ # Tables contain items, and organize information into discrete
38
+ # areas. All items in the table have the same primary key
39
+ # scheme. You designate the attribute name (or names) to use for the
40
+ # primary key when you create a table, and the table requires each
41
+ # item in the table to have a unique primary key value. The first
42
+ # step in writing data to DynamoDB is to create a table and
43
+ # designate a table name with a primary key.
44
+ #
45
+ # table = dynamo_db.tables.create(
46
+ # "MyTable",
47
+ # :hash_key => { :id => :string }
48
+ # )
49
+ # sleep 1 while table.status == :creating
50
+ #
51
+ # See {Table} and {TableCollection} for more information on creating
52
+ # and managing tables.
53
+ #
54
+ # = Items and Attributes
55
+ #
56
+ # An item is a collection of one or more attributes, where each
57
+ # attribute has a string name and a string, number, string set or
58
+ # number set value.
59
+ #
60
+ # The identity of an item consists of its hash key value and -- if
61
+ # the table's schema includes a range key -- its range key value.
62
+ #
63
+ # item = table.items.put(:id => "abc123")
64
+ # item.hash_value # => "abc123"
65
+ # item.attributes.set(
66
+ # :colors => ["red", "blue"],
67
+ # :numbers => [12, 24]
68
+ # )
69
+ #
70
+ # See {Item} and {ItemCollection} for more information on creating
71
+ # and managing items. For more information on managing attributes,
72
+ # see {AttributeCollection}.
73
+ #
74
+ # = Examples
75
+ #
76
+ # # create a table (10 read and 5 write capacity units) with the
77
+ # # default schema (id string hash key)
78
+ # dynamo_db = AWS::DynamoDB.new
79
+ # table = dynamo_db.tables.create('my-table', 10, 5)
80
+ #
81
+ # sleep 1 while table.status == :creating
82
+ # table.status #=> :active
83
+ #
84
+ # # get an existing table by name and specify its hash key
85
+ # table = dynamo_db.tables['another-table']
86
+ # table.hash_key = [:id, :number]
87
+ #
88
+ # # add an item
89
+ # item = table.items.create('id' => 12345, 'foo' => 'bar')
90
+ #
91
+ # # add attributes to an item
92
+ # item.attributes.add 'category' => %w(demo), 'tags' => %w(sample item)
93
+ #
94
+ # # update an item with mixed add, delete, update
95
+ # item.attributes.update do |u|
96
+ # u.add 'colors' => %w(red)
97
+ # u.set 'category' => 'demo-category'
98
+ # u.delete 'foo'
99
+ # end
100
+ #
101
+ # # delete attributes
102
+ # item.attributes.delete 'colors', 'category'
103
+ #
104
+ # # get attributes
105
+ # item.attributes.to_h
106
+ # #=> {"id"=>#<BigDecimal:10155f5d0,'0.12345E5',9(18)>, "tags"=>#<Set: {"item", "sample"}>}
107
+ #
108
+ # # delete an item and all of its attributes
109
+ # item.delete
110
+ #
111
+ class DynamoDB
112
+
113
+ AWS.register_autoloads(self, 'aws/dynamo_db') do
114
+ autoload :AttributeCollection, 'attribute_collection'
115
+ autoload :BatchGet, 'batch_get'
116
+ autoload :BatchWrite, 'batch_write'
117
+ autoload :Client, 'client'
118
+ autoload :Errors, 'errors'
119
+ autoload :Expectations, 'expectations'
120
+ autoload :Item, 'item'
121
+ autoload :ItemData, 'item_data'
122
+ autoload :ItemCollection, 'item_collection'
123
+ autoload :Keys, 'keys'
124
+ autoload :PrimaryKeyElement, 'primary_key_element'
125
+ autoload :Request, 'request'
126
+ autoload :Resource, 'resource'
127
+ autoload :Table, 'table'
128
+ autoload :TableCollection, 'table_collection'
129
+ autoload :Types, 'types'
130
+ end
131
+
132
+ include Core::ServiceInterface
133
+
134
+ # Returns a collection representing all the tables in your account.
135
+ #
136
+ # @return [TableCollection]
137
+ def tables
138
+ TableCollection.new(:config => config)
139
+ end
140
+
141
+ # Request attributes for items spanning multiple tables. You configure
142
+ # you batch get request using a block:
143
+ #
144
+ # attributes = dynamo_db.batch_get do |batch|
145
+ # # call methods on batch specify tables, attributes and items
146
+ # # ...
147
+ # end
148
+ #
149
+ # The value returned by #batch_get is an enumerable object that yields
150
+ # the table name (as a string) and a hash of attributes. The
151
+ # enumerable yields once per item received in the batch get.
152
+ #
153
+ # == Configuring the batch
154
+ #
155
+ # You can call two methods on the yielded batch object:
156
+ #
157
+ # * #table
158
+ # * #items
159
+ #
160
+ # For more information on these methods, see {BatchGet}.
161
+ #
162
+ # @yield [String, Hash] Yields the table name as a string and a hash
163
+ # of attributes for each item received in the bach get request.
164
+ #
165
+ # @return [Enumerable]
166
+ #
167
+ def batch_get &block
168
+ batch = BatchGet.new(:config => config)
169
+ yield(batch)
170
+ batch.enumerator
171
+ end
172
+
173
+ # Yields a batch for writing (put and delete) items across multiple
174
+ # tables. You can put and delete items in the same batch.
175
+ #
176
+ # @example Putting items across tables
177
+ #
178
+ # # shard data across two tables with batch write
179
+ # items = [
180
+ # { :id => '123', :color => 'red' },
181
+ # { :id => '456', :color => 'blue' },
182
+ # { :id => '789', :color => 'green' },
183
+ # ]
184
+ #
185
+ # ddb.batch_write do |batch|
186
+ # batch.put('table1', items)
187
+ # batch.put('table2', items)
188
+ # end
189
+ #
190
+ # @example Mixing puts and deletes
191
+ #
192
+ # ddb.batch_write do |batch|
193
+ # batch.write('table1', :put => [...], :delete => [...])
194
+ # batch.write('table2', :put => [...], :delete => [...])
195
+ # end
196
+ #
197
+ # @yield [BatchWrite]
198
+ #
199
+ # @return (see BatchWrite#process!)
200
+ #
201
+ # @see BatchWrite
202
+ # @see BatchWrite#put
203
+ # @see BatchWrite#delete
204
+ # @see BatchWrite#write
205
+ #
206
+ def batch_write &block
207
+ batch = BatchWrite.new(:config => config)
208
+ yield(batch)
209
+ batch.process!
210
+ end
211
+
212
+ end
213
+ end
@@ -0,0 +1,460 @@
1
+ # Copyright 2011-2012 Amazon.com, Inc. or its affiliates. All Rights Reserved.
2
+ #
3
+ # Licensed under the Apache License, Version 2.0 (the "License"). You
4
+ # may not use this file except in compliance with the License. A copy of
5
+ # the License is located at
6
+ #
7
+ # http://aws.amazon.com/apache2.0/
8
+ #
9
+ # or in the "license" file accompanying this file. This file is
10
+ # distributed on an "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF
11
+ # ANY KIND, either express or implied. See the License for the specific
12
+ # language governing permissions and limitations under the License.
13
+
14
+ module AWS
15
+ class DynamoDB
16
+
17
+ # Represents the attributes of a DynamoDB item. An attribute is a
18
+ # name-value pair. The name must be a string, but the value can be
19
+ # a string, number, string set, or number set. Attribute values
20
+ # cannot be null or empty.
21
+ #
22
+ # @note The SDK always returns numbers as BigDecimal objects and
23
+ # sets as Set objects; however, on input it accepts any numeric
24
+ # type for number attributes and either Arrays or Sets for set
25
+ # attributes.
26
+ #
27
+ # @example Retrieving specific attributes of an item
28
+ # (title, description) =
29
+ # item.attributes.values_at(:title, :description)
30
+ #
31
+ # @example Retrieving all attributes in hash form
32
+ # item.attributes.to_h
33
+ #
34
+ # @example Replacing the value of an attribute
35
+ # item.attributes[:title] = "Automobiles"
36
+ #
37
+ # @example Doing a mixed update of item attributes in a single operation
38
+ # item.attributes.update do |u|
39
+ #
40
+ # # add 12 to the (numeric) value of "views"
41
+ # u.add(:views => 12)
42
+ #
43
+ # # delete attributes
44
+ # u.delete(:foo, :bar)
45
+ #
46
+ # # delete values out of a set attribute
47
+ # u.delete(:colors => ["red", "blue"])
48
+ #
49
+ # # replace values
50
+ # u.set(:title => "More Automobiles")
51
+ # end
52
+ #
53
+ # @example Returning overwritten values
54
+ # item.attributes.to_h # => { "foo" => "bar",
55
+ # "name" => "fred" }
56
+ # item.attributes.set(
57
+ # { "foo" => "baz" },
58
+ # :return => :updated_old
59
+ # ) # => { "foo" => "bar" }
60
+ #
61
+ # @example Performing a conditional update
62
+ # item.set({ :version => 3 }, :if => { :version => 2 })
63
+ class AttributeCollection
64
+
65
+ include Core::Model
66
+ include Enumerable
67
+ include Types
68
+ include Keys
69
+ include Expectations
70
+
71
+ # @return [Item] The item to which these attributes belong.
72
+ attr_reader :item
73
+
74
+ # @private
75
+ def initialize(item, opts = {})
76
+ @item = item
77
+ super
78
+ end
79
+
80
+ # Behaves like Hash#each; yields each attribute as a name/value
81
+ # pair.
82
+ #
83
+ # attributes.each { |(name, value)| puts "#{name} = #{value}" }
84
+ #
85
+ # attributes.each { |name, value| puts "#{name} = #{value}" }
86
+ #
87
+ # @param (see #to_h)
88
+ #
89
+ # @option options (see #to_h)
90
+ def each(options = {}, &block)
91
+ to_h(options).each(&block)
92
+ end
93
+
94
+ # @yieldparam [String] name Each attribute name.
95
+ def each_key(options = {})
96
+ each(options) { |k, v| yield(k) if block_given? }
97
+ end
98
+
99
+ # @yieldparam value Each attribute value belonging to the item.
100
+ # Values will be of type String, BigDecimal, Set<String> or
101
+ # Set<BigDecimal>.
102
+ def each_value(options = {})
103
+ each(options) { |k, v| yield(v) if block_given? }
104
+ end
105
+
106
+ # Retrieves the value of a single attribute.
107
+ #
108
+ # @param [String, Symbol] attribute The name of the attribute to
109
+ # get.
110
+ #
111
+ # @return The value of the specified attribute, which may be a
112
+ # String, BigDecimal, Set<String> or Set<BigDecimal>.
113
+ def [] attribute
114
+ attribute = attribute.to_s
115
+ response_attributes = get_item(:attributes_to_get => [attribute])
116
+ value_from_response(response_attributes[attribute])
117
+ end
118
+
119
+ # Replaces the value of a single attribute.
120
+ #
121
+ # @param [String, Symbol] attribute The name of the attribute to
122
+ # replace.
123
+ #
124
+ # @param value The new value to set. This may be a String,
125
+ # Numeric, Set or Array of String objects, or Set or Array of
126
+ # Numeric objects. Mixed types are not allowed in sets, and
127
+ # neither String values nor set values may be empty. Setting
128
+ # an attribute to nil is the same as deleting the attribute.
129
+ #
130
+ # @return The new value of the attribute.
131
+ def []= attribute, value
132
+ set(attribute => value)
133
+ value
134
+ end
135
+
136
+ # Replaces the values of one or more attributes.
137
+ #
138
+ # @param [Hash] attributes The attributes to replace. The keys
139
+ # of the hash may be strings or symbols. The values may be of
140
+ # type String, Numeric, Set or Array of String objects, or Set
141
+ # or Array of Numeric objects. Mixed types are not allowed in
142
+ # sets, and neither String values nor set values may be empty.
143
+ # Setting an attribute to nil is the same as deleting the
144
+ # attribute.
145
+ #
146
+ # @param [Hash] options Options for updating the item.
147
+ #
148
+ # @option options (see #update)
149
+ def set attributes, options = {}
150
+ update(options) { |u| u.set(attributes) }
151
+ end
152
+ alias_method :merge!, :set
153
+ alias_method :put, :set
154
+
155
+ # Adds to the values of one or more attributes. Each attribute
156
+ # must be a set or number in the original item, and each input
157
+ # value must have the same type as the value in the original
158
+ # item. For example, it is invalid to add a single number to a
159
+ # set of numbers, but it is valid to add a set containing a
160
+ # single number to another set of numbers.
161
+ #
162
+ # When the original attribute is a set, the values provided to
163
+ # this method are added to that set. When the original
164
+ # attribute is a number, the original value is incremented by
165
+ # the numeric value provided to this method. For example:
166
+ #
167
+ # item = table.items.put(
168
+ # :id => "abc123",
169
+ # :colors => ["red", "white"],
170
+ # :age => 3
171
+ # )
172
+ # item.attributes.add(
173
+ # { :colors => ["muave"],
174
+ # :age => 1 },
175
+ # :return => :updated_new
176
+ # ) # => { "colors" => Set["red", "white", "mauve"],
177
+ # # "age" => 4 }
178
+ #
179
+ # @param [Hash] attributes The attribute values to add. The
180
+ # keys of the hash may be strings or symbols. The values may
181
+ # be of type Numeric, Set or Array of String objects, or Set
182
+ # or Array of Numeric objects. Mixed types are not allowed in
183
+ # sets, and neither String values nor set values may be empty.
184
+ # Single string values are not allowed for this method, since
185
+ # DynamoDB does not currently support adding a string to
186
+ # another string.
187
+ #
188
+ # @param [Hash] options Options for updating the item.
189
+ #
190
+ # @option options (see #update)
191
+ def add attributes, options = {}
192
+ update(options) { |u| u.add(attributes) }
193
+ end
194
+
195
+ # @overload delete *attributes
196
+ #
197
+ # Deletes attributes from the item. Each argument must be a
198
+ # string or symbol specifying the name of the attribute to
199
+ # delete. The last argument may be a hash containing options
200
+ # for the update. See {#update} for more information about
201
+ # what options are accepted.
202
+ #
203
+ # @overload delete attributes, options = {}
204
+ #
205
+ # Deletes specific values from one or more attributes, whose
206
+ # original values must be sets.
207
+ #
208
+ # @param [Hash] attributes The attribute values to delete.
209
+ # The keys of the hash may be strings or symbols. The
210
+ # values must be arrays or Sets of numbers or strings.
211
+ # Mixed types are not allowed in sets. The type of each
212
+ # member in a set must match the type of the members in the
213
+ # original attribute value.
214
+ #
215
+ # @param [Hash] options Options for updating the item.
216
+ #
217
+ # @option options (see #update)
218
+ def delete *args
219
+ if args.first.kind_of?(Hash)
220
+ delete_args = [args.shift]
221
+ else
222
+ delete_args = args
223
+ end
224
+ options = args.pop if args.last.kind_of?(Hash)
225
+ update(options || {}) { |u| u.delete(*delete_args) }
226
+ end
227
+
228
+ # Used to build a batch of updates to an item's attributes. See
229
+ # {AttributeCollection#update} for more information.
230
+ class UpdateBuilder
231
+
232
+ # @private
233
+ attr_reader :updates
234
+
235
+ include Types
236
+
237
+ # @private
238
+ def initialize
239
+ @updates = {}
240
+ end
241
+
242
+ # Replaces the values of one or more attributes. See
243
+ # {AttributeCollection#set} for more information.
244
+ def set attributes
245
+ to_delete = []
246
+ attributes = attributes.inject({}) do |attributes, (name, value)|
247
+ if value == nil
248
+ to_delete << name
249
+ else
250
+ attributes[name] = value
251
+ end
252
+ attributes
253
+ end
254
+ attribute_updates("PUT", attributes)
255
+ delete(*to_delete)
256
+ end
257
+ alias_method :put, :set
258
+ alias_method :merge!, :set
259
+
260
+ # Adds to the values of one or more attributes. See
261
+ # {AttributeCollection#add} for more information.
262
+ def add attributes
263
+ attribute_updates("ADD", attributes)
264
+ end
265
+
266
+
267
+ # Deletes one or more attributes or attribute values. See
268
+ # {AttributeCollection#delete} for more information.
269
+ def delete *args
270
+ if args.first.kind_of?(Hash)
271
+ attribute_updates("DELETE",
272
+ args.shift,
273
+ :setify => true)
274
+ else
275
+ add_updates(args.inject({}) do |u, name|
276
+ u.update(name.to_s => {
277
+ :action => "DELETE"
278
+ })
279
+ end)
280
+ end
281
+ end
282
+
283
+ private
284
+ def attribute_updates(action, attributes, our_opts = {})
285
+ new_updates = attributes.inject({}) do |new_updates, (name, value)|
286
+ name = name.to_s
287
+ context = "in value for attribute #{name}"
288
+ value = [value].flatten if our_opts[:setify]
289
+ new_updates.update(name => {
290
+ :action => action,
291
+ :value =>
292
+ format_attribute_value(value, context)
293
+ })
294
+ end
295
+ add_updates(new_updates)
296
+ end
297
+
298
+ private
299
+ def add_updates(new_updates)
300
+ updates.merge!(new_updates) do |name, old, new|
301
+ raise ArgumentError, "conflicting updates for attribute #{name}"
302
+ end
303
+ end
304
+
305
+ end
306
+
307
+ # Updates multiple attributes in a single operation. This is
308
+ # more efficient than performing each type of update in
309
+ # sequence, and it also allows you to group different kinds of
310
+ # updates into an atomic operation.
311
+ #
312
+ # item.attributes.update do |u|
313
+ #
314
+ # # add 12 to the (numeric) value of "views"
315
+ # u.add(:views => 12)
316
+ #
317
+ # # delete attributes
318
+ # u.delete(:foo, :bar)
319
+ #
320
+ # # delete values out of a set attribute
321
+ # u.delete(:colors => ["red", "blue"])
322
+ #
323
+ # # replace values
324
+ # u.set(:title => "More Automobiles")
325
+ # end
326
+ #
327
+ # @param [Hash] options Options for updating the item.
328
+ #
329
+ # @option options [Hash] :if Designates a conditional update.
330
+ # The operation will fail unless the item exists and has the
331
+ # attributes in the value for this option. For example:
332
+ #
333
+ # # throws DynamoDB::Errors::ConditionalCheckFailedException
334
+ # # unless the item has "color" set to "red"
335
+ # item.attributes.update(:if => { :color => "red" }) do |u|
336
+ # # ...
337
+ # end
338
+ #
339
+ # @option options [String, Symbol, Array] :unless_exists A name
340
+ # or collection of attribute names; if the item already exists
341
+ # and has a value for any of these attributes, this method
342
+ # will raise
343
+ # +DynamoDB::Errors::ConditionalCheckFailedException+. For example:
344
+ #
345
+ # item.attributes.update(:unless_exists => :color) do |u|
346
+ # # ...
347
+ # end
348
+ #
349
+ # @option options [Symbol] :return (+:none+) Changes the return
350
+ # value of the method. Valid values:
351
+ #
352
+ # [+:none+] Return +nil+
353
+ #
354
+ # [+:all_old+] Returns a hash containing all of the original
355
+ # values of the attributes before the update, or
356
+ # +nil+ if the item did not exist at the time of
357
+ # the update.
358
+ #
359
+ # [+:updated_old+] Returns a hash containing the original
360
+ # values of the attributes that were modified
361
+ # as part of this operation. This includes
362
+ # attributes that were deleted, and
363
+ # set-valued attributes whose member values
364
+ # were deleted.
365
+ #
366
+ # [+:updated_new+] Returns a hash containing the new values of
367
+ # the attributes that were modified as part
368
+ # of this operation. This includes
369
+ # set-valued attributes whose member values
370
+ # were deleted.
371
+ #
372
+ # [+:all_new+] Returns a hash containing the new values of all
373
+ # of the attributes.
374
+ #
375
+ # @yieldparam [UpdateBuilder] builder A handle for describing
376
+ # the update.
377
+ #
378
+ # @note DnamoDB allows only one update per attribute in a
379
+ # single operation. This method will raise an ArgumentError
380
+ # if multiple updates are described for a single attribute.
381
+ #
382
+ # @return [nil] See the documentation for the +:return+ option
383
+ # above.
384
+ def update(options = {})
385
+ builder = UpdateBuilder.new
386
+ yield(builder)
387
+ do_updates({ :attribute_updates => builder.updates },
388
+ options)
389
+ end
390
+
391
+ # Retrieves the values of the specified attributes.
392
+ #
393
+ # @param [Array<String, Symbol>] attributes The names of the
394
+ # attributes to retrieve. The last argument may be a hash of
395
+ # options for retrieving attributes from the item. Currently
396
+ # the only supported option is +:consistent_read+; If set to
397
+ # true, then a consistent read is issued, otherwise an
398
+ # eventually consistent read is used.
399
+ #
400
+ # @return [Array] An array in which each member contains the
401
+ # value of the attribute at that index in the argument list.
402
+ # Values may be Strings, BigDecimals, Sets of Strings or Sets
403
+ # or BigDecimals. If a requested attribute does not exist,
404
+ # the corresponding member of the output array will be +nil+.
405
+ def values_at(*attributes)
406
+ options = {}
407
+ options = attributes.pop if attributes.last.kind_of?(Hash)
408
+
409
+ return [] if attributes.empty?
410
+
411
+ attributes.map! { |a| a.to_s }
412
+ response_attributes =
413
+ get_item(options, :attributes_to_get => attributes)
414
+
415
+ values_from_response_hash(response_attributes).
416
+ values_at(*attributes)
417
+ end
418
+
419
+ # @param [Hash] options Options for retrieving attributes from
420
+ # the item.
421
+ #
422
+ # @option options [Boolean] :consistent_read If set to true,
423
+ # then a consistent read is issued, otherwise an eventually
424
+ # consistent read is used.
425
+ def to_h options = {}
426
+ values_from_response_hash(get_item(options))
427
+ end
428
+
429
+ private
430
+ def item_key_options(options = {})
431
+ super(item, options)
432
+ end
433
+
434
+ private
435
+ def get_item(their_options, our_options = {})
436
+ options = their_options.merge(our_options)
437
+ resp = client.get_item(item_key_options(options))
438
+ resp.data['Item'] || {}
439
+ end
440
+
441
+ private
442
+ def do_updates(client_opts, options)
443
+ return nil if client_opts[:attribute_updates].empty?
444
+
445
+ client_opts[:return_values] = options[:return].to_s.upcase if
446
+ options[:return]
447
+
448
+ expected = expect_conditions(options)
449
+ client_opts[:expected] = expected unless expected.empty?
450
+
451
+ resp = client.update_item(item_key_options(client_opts))
452
+
453
+ values_from_response_hash(resp.data["Attributes"]) if
454
+ options[:return] and resp.data["Attributes"]
455
+ end
456
+
457
+ end
458
+
459
+ end
460
+ end