aws-sdk-v1-reinteractive 1.67.1

Sign up to get free protection for your applications and to get access to all the features.
Files changed (569) hide show
  1. checksums.yaml +7 -0
  2. data/.yardopts +9 -0
  3. data/LICENSE.txt +12 -0
  4. data/README.md +364 -0
  5. data/bin/aws-rb +179 -0
  6. data/ca-bundle.crt +3554 -0
  7. data/endpoints.json +1838 -0
  8. data/lib/aws-sdk-v1.rb +2 -0
  9. data/lib/aws.rb +14 -0
  10. data/lib/aws/api_config/AutoScaling-2011-01-01.yml +1083 -0
  11. data/lib/aws/api_config/CloudFormation-2010-05-15.yml +372 -0
  12. data/lib/aws/api_config/CloudFront-2013-05-12.yml +2448 -0
  13. data/lib/aws/api_config/CloudFront-2013-08-26.yml +2599 -0
  14. data/lib/aws/api_config/CloudFront-2013-09-27.yml +2765 -0
  15. data/lib/aws/api_config/CloudFront-2013-11-11.yml +2886 -0
  16. data/lib/aws/api_config/CloudFront-2013-11-22.yml +2918 -0
  17. data/lib/aws/api_config/CloudFront-2014-01-31.yml +2934 -0
  18. data/lib/aws/api_config/CloudFront-2014-05-31.yml +3100 -0
  19. data/lib/aws/api_config/CloudFront-2014-10-21.yml +3290 -0
  20. data/lib/aws/api_config/CloudFront-2014-11-06.yml +3547 -0
  21. data/lib/aws/api_config/CloudSearch-2011-02-01.yml +681 -0
  22. data/lib/aws/api_config/CloudSearch-2013-01-01.yml +1184 -0
  23. data/lib/aws/api_config/CloudTrail-2013-11-01.yml +130 -0
  24. data/lib/aws/api_config/CloudWatch-2010-08-01.yml +433 -0
  25. data/lib/aws/api_config/DataPipeline-2012-10-29.yml +422 -0
  26. data/lib/aws/api_config/DirectConnect-2012-10-25.yml +735 -0
  27. data/lib/aws/api_config/DynamoDB-2011-12-05.yml +1168 -0
  28. data/lib/aws/api_config/DynamoDB-2012-08-10.yml +2105 -0
  29. data/lib/aws/api_config/EC2-2013-08-15.yml +4708 -0
  30. data/lib/aws/api_config/EC2-2013-10-01.yml +4726 -0
  31. data/lib/aws/api_config/EC2-2013-10-15.yml +4651 -0
  32. data/lib/aws/api_config/EC2-2014-02-01.yml +4755 -0
  33. data/lib/aws/api_config/EC2-2014-05-01.yml +4812 -0
  34. data/lib/aws/api_config/EC2-2014-09-01.yml +4826 -0
  35. data/lib/aws/api_config/EC2-2014-10-01.yml +4969 -0
  36. data/lib/aws/api_config/ELB-2012-06-01.yml +785 -0
  37. data/lib/aws/api_config/EMR-2009-03-31.yml +972 -0
  38. data/lib/aws/api_config/ElastiCache-2013-06-15.yml +1188 -0
  39. data/lib/aws/api_config/ElastiCache-2014-03-24.yml +1375 -0
  40. data/lib/aws/api_config/ElastiCache-2014-07-15.yml +1385 -0
  41. data/lib/aws/api_config/ElastiCache-2014-09-30.yml +1426 -0
  42. data/lib/aws/api_config/ElasticBeanstalk-2010-12-01.yml +854 -0
  43. data/lib/aws/api_config/ElasticTranscoder-2012-09-25.yml +4179 -0
  44. data/lib/aws/api_config/Glacier-2012-06-01.yml +649 -0
  45. data/lib/aws/api_config/IAM-2010-05-08.yml +1912 -0
  46. data/lib/aws/api_config/ImportExport-2010-06-01.yml +109 -0
  47. data/lib/aws/api_config/Kinesis-2013-12-02.yml +275 -0
  48. data/lib/aws/api_config/OpsWorks-2013-02-18.yml +2324 -0
  49. data/lib/aws/api_config/RDS-2013-05-15.yml +2464 -0
  50. data/lib/aws/api_config/RDS-2013-09-09.yml +2640 -0
  51. data/lib/aws/api_config/RDS-2014-09-01.yml +2796 -0
  52. data/lib/aws/api_config/Redshift-2012-12-01.yml +2577 -0
  53. data/lib/aws/api_config/Route53-2012-12-12.yml +547 -0
  54. data/lib/aws/api_config/Route53-2013-04-01.yml +1093 -0
  55. data/lib/aws/api_config/SNS-2010-03-31.yml +448 -0
  56. data/lib/aws/api_config/SQS-2012-11-05.yml +404 -0
  57. data/lib/aws/api_config/STS-2011-06-15.yml +151 -0
  58. data/lib/aws/api_config/SimpleDB-2009-04-15.yml +306 -0
  59. data/lib/aws/api_config/SimpleEmailService-2010-12-01.yml +346 -0
  60. data/lib/aws/api_config/SimpleWorkflow-2012-01-25.yml +2426 -0
  61. data/lib/aws/api_config/StorageGateway-2012-06-30.yml +748 -0
  62. data/lib/aws/api_config/StorageGateway-2013-06-30.yml +1025 -0
  63. data/lib/aws/api_config/Support-2013-04-15.yml +489 -0
  64. data/lib/aws/auto_scaling.rb +163 -0
  65. data/lib/aws/auto_scaling/activity.rb +102 -0
  66. data/lib/aws/auto_scaling/activity_collection.rb +81 -0
  67. data/lib/aws/auto_scaling/client.rb +48 -0
  68. data/lib/aws/auto_scaling/config.rb +18 -0
  69. data/lib/aws/auto_scaling/errors.rb +22 -0
  70. data/lib/aws/auto_scaling/group.rb +421 -0
  71. data/lib/aws/auto_scaling/group_collection.rb +96 -0
  72. data/lib/aws/auto_scaling/group_options.rb +155 -0
  73. data/lib/aws/auto_scaling/instance.rb +192 -0
  74. data/lib/aws/auto_scaling/instance_collection.rb +63 -0
  75. data/lib/aws/auto_scaling/launch_configuration.rb +179 -0
  76. data/lib/aws/auto_scaling/launch_configuration_collection.rb +177 -0
  77. data/lib/aws/auto_scaling/notification_configuration.rb +89 -0
  78. data/lib/aws/auto_scaling/notification_configuration_collection.rb +183 -0
  79. data/lib/aws/auto_scaling/scaling_policy.rb +142 -0
  80. data/lib/aws/auto_scaling/scaling_policy_collection.rb +72 -0
  81. data/lib/aws/auto_scaling/scaling_policy_options.rb +65 -0
  82. data/lib/aws/auto_scaling/scheduled_action.rb +141 -0
  83. data/lib/aws/auto_scaling/scheduled_action_collection.rb +202 -0
  84. data/lib/aws/auto_scaling/tag.rb +59 -0
  85. data/lib/aws/auto_scaling/tag_collection.rb +114 -0
  86. data/lib/aws/cloud_formation.rb +272 -0
  87. data/lib/aws/cloud_formation/client.rb +48 -0
  88. data/lib/aws/cloud_formation/config.rb +18 -0
  89. data/lib/aws/cloud_formation/errors.rb +22 -0
  90. data/lib/aws/cloud_formation/stack.rb +266 -0
  91. data/lib/aws/cloud_formation/stack_collection.rb +232 -0
  92. data/lib/aws/cloud_formation/stack_event.rb +73 -0
  93. data/lib/aws/cloud_formation/stack_event_collection.rb +47 -0
  94. data/lib/aws/cloud_formation/stack_options.rb +72 -0
  95. data/lib/aws/cloud_formation/stack_output.rb +53 -0
  96. data/lib/aws/cloud_formation/stack_resource.rb +117 -0
  97. data/lib/aws/cloud_formation/stack_resource_collection.rb +83 -0
  98. data/lib/aws/cloud_formation/stack_resource_summary_collection.rb +64 -0
  99. data/lib/aws/cloud_formation/stack_summary_collection.rb +123 -0
  100. data/lib/aws/cloud_front.rb +72 -0
  101. data/lib/aws/cloud_front/client.rb +65 -0
  102. data/lib/aws/cloud_front/config.rb +18 -0
  103. data/lib/aws/cloud_front/errors.rb +22 -0
  104. data/lib/aws/cloud_search.rb +73 -0
  105. data/lib/aws/cloud_search/client.rb +40 -0
  106. data/lib/aws/cloud_search/config.rb +18 -0
  107. data/lib/aws/cloud_search/errors.rb +22 -0
  108. data/lib/aws/cloud_trail.rb +72 -0
  109. data/lib/aws/cloud_trail/client.rb +35 -0
  110. data/lib/aws/cloud_trail/config.rb +18 -0
  111. data/lib/aws/cloud_trail/errors.rb +22 -0
  112. data/lib/aws/cloud_watch.rb +118 -0
  113. data/lib/aws/cloud_watch/alarm.rb +293 -0
  114. data/lib/aws/cloud_watch/alarm_collection.rb +153 -0
  115. data/lib/aws/cloud_watch/alarm_history_item.rb +50 -0
  116. data/lib/aws/cloud_watch/alarm_history_item_collection.rb +84 -0
  117. data/lib/aws/cloud_watch/client.rb +40 -0
  118. data/lib/aws/cloud_watch/config.rb +18 -0
  119. data/lib/aws/cloud_watch/errors.rb +22 -0
  120. data/lib/aws/cloud_watch/metric.rb +135 -0
  121. data/lib/aws/cloud_watch/metric_alarm_collection.rb +160 -0
  122. data/lib/aws/cloud_watch/metric_collection.rb +129 -0
  123. data/lib/aws/cloud_watch/metric_statistics.rb +69 -0
  124. data/lib/aws/core.rb +698 -0
  125. data/lib/aws/core/async_handle.rb +90 -0
  126. data/lib/aws/core/cacheable.rb +77 -0
  127. data/lib/aws/core/client.rb +787 -0
  128. data/lib/aws/core/collection.rb +263 -0
  129. data/lib/aws/core/collection/simple.rb +82 -0
  130. data/lib/aws/core/collection/with_limit_and_next_token.rb +71 -0
  131. data/lib/aws/core/collection/with_next_token.rb +97 -0
  132. data/lib/aws/core/configuration.rb +528 -0
  133. data/lib/aws/core/credential_providers.rb +662 -0
  134. data/lib/aws/core/data.rb +252 -0
  135. data/lib/aws/core/deprecations.rb +84 -0
  136. data/lib/aws/core/endpoints.rb +37 -0
  137. data/lib/aws/core/http/connection_pool.rb +375 -0
  138. data/lib/aws/core/http/curb_handler.rb +151 -0
  139. data/lib/aws/core/http/handler.rb +89 -0
  140. data/lib/aws/core/http/net_http_handler.rb +145 -0
  141. data/lib/aws/core/http/patch.rb +98 -0
  142. data/lib/aws/core/http/request.rb +259 -0
  143. data/lib/aws/core/http/response.rb +81 -0
  144. data/lib/aws/core/indifferent_hash.rb +88 -0
  145. data/lib/aws/core/inflection.rb +56 -0
  146. data/lib/aws/core/ini_parser.rb +42 -0
  147. data/lib/aws/core/json_client.rb +47 -0
  148. data/lib/aws/core/json_parser.rb +76 -0
  149. data/lib/aws/core/json_request_builder.rb +35 -0
  150. data/lib/aws/core/json_response_parser.rb +79 -0
  151. data/lib/aws/core/lazy_error_classes.rb +108 -0
  152. data/lib/aws/core/log_formatter.rb +428 -0
  153. data/lib/aws/core/managed_file.rb +32 -0
  154. data/lib/aws/core/meta_utils.rb +45 -0
  155. data/lib/aws/core/model.rb +62 -0
  156. data/lib/aws/core/naming.rb +30 -0
  157. data/lib/aws/core/option_grammar.rb +738 -0
  158. data/lib/aws/core/options/json_serializer.rb +82 -0
  159. data/lib/aws/core/options/validator.rb +155 -0
  160. data/lib/aws/core/options/xml_serializer.rb +118 -0
  161. data/lib/aws/core/page_result.rb +75 -0
  162. data/lib/aws/core/policy.rb +941 -0
  163. data/lib/aws/core/query_client.rb +41 -0
  164. data/lib/aws/core/query_error_parser.rb +24 -0
  165. data/lib/aws/core/query_request_builder.rb +47 -0
  166. data/lib/aws/core/query_response_parser.rb +35 -0
  167. data/lib/aws/core/region.rb +85 -0
  168. data/lib/aws/core/region_collection.rb +80 -0
  169. data/lib/aws/core/resource.rb +413 -0
  170. data/lib/aws/core/resource_cache.rb +40 -0
  171. data/lib/aws/core/response.rb +215 -0
  172. data/lib/aws/core/response_cache.rb +50 -0
  173. data/lib/aws/core/rest_error_parser.rb +24 -0
  174. data/lib/aws/core/rest_json_client.rb +40 -0
  175. data/lib/aws/core/rest_request_builder.rb +154 -0
  176. data/lib/aws/core/rest_response_parser.rb +66 -0
  177. data/lib/aws/core/rest_xml_client.rb +47 -0
  178. data/lib/aws/core/service_interface.rb +83 -0
  179. data/lib/aws/core/signers/base.rb +46 -0
  180. data/lib/aws/core/signers/cloud_front.rb +56 -0
  181. data/lib/aws/core/signers/s3.rb +159 -0
  182. data/lib/aws/core/signers/version_2.rb +72 -0
  183. data/lib/aws/core/signers/version_3.rb +86 -0
  184. data/lib/aws/core/signers/version_3_https.rb +61 -0
  185. data/lib/aws/core/signers/version_4.rb +228 -0
  186. data/lib/aws/core/signers/version_4/chunk_signed_stream.rb +191 -0
  187. data/lib/aws/core/uri_escape.rb +44 -0
  188. data/lib/aws/core/xml/frame.rb +246 -0
  189. data/lib/aws/core/xml/frame_stack.rb +85 -0
  190. data/lib/aws/core/xml/grammar.rb +307 -0
  191. data/lib/aws/core/xml/parser.rb +70 -0
  192. data/lib/aws/core/xml/root_frame.rb +65 -0
  193. data/lib/aws/core/xml/sax_handlers/libxml.rb +47 -0
  194. data/lib/aws/core/xml/sax_handlers/nokogiri.rb +56 -0
  195. data/lib/aws/core/xml/sax_handlers/ox.rb +41 -0
  196. data/lib/aws/core/xml/sax_handlers/rexml.rb +47 -0
  197. data/lib/aws/core/xml/stub.rb +123 -0
  198. data/lib/aws/data_pipeline.rb +72 -0
  199. data/lib/aws/data_pipeline/client.rb +36 -0
  200. data/lib/aws/data_pipeline/config.rb +18 -0
  201. data/lib/aws/data_pipeline/errors.rb +20 -0
  202. data/lib/aws/direct_connect.rb +73 -0
  203. data/lib/aws/direct_connect/client.rb +36 -0
  204. data/lib/aws/direct_connect/config.rb +18 -0
  205. data/lib/aws/direct_connect/errors.rb +22 -0
  206. data/lib/aws/dynamo_db.rb +230 -0
  207. data/lib/aws/dynamo_db/attribute_collection.rb +456 -0
  208. data/lib/aws/dynamo_db/batch_get.rb +213 -0
  209. data/lib/aws/dynamo_db/batch_write.rb +254 -0
  210. data/lib/aws/dynamo_db/binary.rb +35 -0
  211. data/lib/aws/dynamo_db/client.rb +129 -0
  212. data/lib/aws/dynamo_db/client/v20111205.rb +1266 -0
  213. data/lib/aws/dynamo_db/client/v20120810.rb +1409 -0
  214. data/lib/aws/dynamo_db/client_v2.rb +44 -0
  215. data/lib/aws/dynamo_db/config.rb +24 -0
  216. data/lib/aws/dynamo_db/errors.rb +20 -0
  217. data/lib/aws/dynamo_db/expectations.rb +40 -0
  218. data/lib/aws/dynamo_db/item.rb +133 -0
  219. data/lib/aws/dynamo_db/item_collection.rb +856 -0
  220. data/lib/aws/dynamo_db/item_data.rb +31 -0
  221. data/lib/aws/dynamo_db/keys.rb +41 -0
  222. data/lib/aws/dynamo_db/primary_key_element.rb +48 -0
  223. data/lib/aws/dynamo_db/resource.rb +33 -0
  224. data/lib/aws/dynamo_db/table.rb +492 -0
  225. data/lib/aws/dynamo_db/table_collection.rb +165 -0
  226. data/lib/aws/dynamo_db/types.rb +111 -0
  227. data/lib/aws/ec2.rb +428 -0
  228. data/lib/aws/ec2/attachment.rb +135 -0
  229. data/lib/aws/ec2/attachment_collection.rb +54 -0
  230. data/lib/aws/ec2/availability_zone.rb +86 -0
  231. data/lib/aws/ec2/availability_zone_collection.rb +43 -0
  232. data/lib/aws/ec2/block_device_mappings.rb +53 -0
  233. data/lib/aws/ec2/client.rb +162 -0
  234. data/lib/aws/ec2/collection.rb +36 -0
  235. data/lib/aws/ec2/config.rb +21 -0
  236. data/lib/aws/ec2/customer_gateway.rb +90 -0
  237. data/lib/aws/ec2/customer_gateway_collection.rb +73 -0
  238. data/lib/aws/ec2/dhcp_options.rb +106 -0
  239. data/lib/aws/ec2/dhcp_options_collection.rb +87 -0
  240. data/lib/aws/ec2/elastic_ip.rb +209 -0
  241. data/lib/aws/ec2/elastic_ip_collection.rb +93 -0
  242. data/lib/aws/ec2/errors.rb +32 -0
  243. data/lib/aws/ec2/export_task.rb +120 -0
  244. data/lib/aws/ec2/export_task_collection.rb +67 -0
  245. data/lib/aws/ec2/filtered_collection.rb +87 -0
  246. data/lib/aws/ec2/has_permissions.rb +44 -0
  247. data/lib/aws/ec2/image.rb +274 -0
  248. data/lib/aws/ec2/image_collection.rb +219 -0
  249. data/lib/aws/ec2/instance.rb +803 -0
  250. data/lib/aws/ec2/instance_collection.rb +403 -0
  251. data/lib/aws/ec2/internet_gateway.rb +122 -0
  252. data/lib/aws/ec2/internet_gateway/attachment.rb +78 -0
  253. data/lib/aws/ec2/internet_gateway_collection.rb +54 -0
  254. data/lib/aws/ec2/key_pair.rb +82 -0
  255. data/lib/aws/ec2/key_pair_collection.rb +99 -0
  256. data/lib/aws/ec2/network_acl.rb +256 -0
  257. data/lib/aws/ec2/network_acl/association.rb +56 -0
  258. data/lib/aws/ec2/network_acl/entry.rb +147 -0
  259. data/lib/aws/ec2/network_acl_collection.rb +64 -0
  260. data/lib/aws/ec2/network_interface.rb +237 -0
  261. data/lib/aws/ec2/network_interface/attachment.rb +100 -0
  262. data/lib/aws/ec2/network_interface_collection.rb +103 -0
  263. data/lib/aws/ec2/permission_collection.rb +174 -0
  264. data/lib/aws/ec2/region.rb +106 -0
  265. data/lib/aws/ec2/region_collection.rb +51 -0
  266. data/lib/aws/ec2/reserved_instances.rb +57 -0
  267. data/lib/aws/ec2/reserved_instances_collection.rb +40 -0
  268. data/lib/aws/ec2/reserved_instances_offering.rb +60 -0
  269. data/lib/aws/ec2/reserved_instances_offering_collection.rb +45 -0
  270. data/lib/aws/ec2/resource.rb +161 -0
  271. data/lib/aws/ec2/resource_tag_collection.rb +211 -0
  272. data/lib/aws/ec2/route_table.rb +210 -0
  273. data/lib/aws/ec2/route_table/association.rb +119 -0
  274. data/lib/aws/ec2/route_table/route.rb +121 -0
  275. data/lib/aws/ec2/route_table_collection.rb +72 -0
  276. data/lib/aws/ec2/security_group.rb +482 -0
  277. data/lib/aws/ec2/security_group/ip_permission.rb +135 -0
  278. data/lib/aws/ec2/security_group/ip_permission_collection.rb +82 -0
  279. data/lib/aws/ec2/security_group_collection.rb +133 -0
  280. data/lib/aws/ec2/snapshot.rb +143 -0
  281. data/lib/aws/ec2/snapshot_collection.rb +131 -0
  282. data/lib/aws/ec2/subnet.rb +161 -0
  283. data/lib/aws/ec2/subnet_collection.rb +119 -0
  284. data/lib/aws/ec2/tag.rb +81 -0
  285. data/lib/aws/ec2/tag_collection.rb +107 -0
  286. data/lib/aws/ec2/tagged_collection.rb +67 -0
  287. data/lib/aws/ec2/tagged_item.rb +85 -0
  288. data/lib/aws/ec2/volume.rb +185 -0
  289. data/lib/aws/ec2/volume_collection.rb +102 -0
  290. data/lib/aws/ec2/vpc.rb +224 -0
  291. data/lib/aws/ec2/vpc_collection.rb +70 -0
  292. data/lib/aws/ec2/vpc_peering_connection.rb +47 -0
  293. data/lib/aws/ec2/vpc_peering_connection_collection.rb +57 -0
  294. data/lib/aws/ec2/vpn_connection.rb +99 -0
  295. data/lib/aws/ec2/vpn_connection/telemetry.rb +49 -0
  296. data/lib/aws/ec2/vpn_connection_collection.rb +96 -0
  297. data/lib/aws/ec2/vpn_gateway.rb +123 -0
  298. data/lib/aws/ec2/vpn_gateway/attachment.rb +45 -0
  299. data/lib/aws/ec2/vpn_gateway_collection.rb +77 -0
  300. data/lib/aws/elastic_beanstalk.rb +49 -0
  301. data/lib/aws/elastic_beanstalk/client.rb +36 -0
  302. data/lib/aws/elastic_beanstalk/config.rb +18 -0
  303. data/lib/aws/elastic_beanstalk/errors.rb +22 -0
  304. data/lib/aws/elastic_transcoder.rb +29 -0
  305. data/lib/aws/elastic_transcoder/client.rb +48 -0
  306. data/lib/aws/elastic_transcoder/config.rb +18 -0
  307. data/lib/aws/elastic_transcoder/errors.rb +23 -0
  308. data/lib/aws/elasticache.rb +49 -0
  309. data/lib/aws/elasticache/client.rb +45 -0
  310. data/lib/aws/elasticache/config.rb +18 -0
  311. data/lib/aws/elasticache/errors.rb +22 -0
  312. data/lib/aws/elb.rb +66 -0
  313. data/lib/aws/elb/availability_zone_collection.rb +138 -0
  314. data/lib/aws/elb/backend_server_policy_collection.rb +139 -0
  315. data/lib/aws/elb/client.rb +35 -0
  316. data/lib/aws/elb/config.rb +18 -0
  317. data/lib/aws/elb/errors.rb +26 -0
  318. data/lib/aws/elb/instance_collection.rb +168 -0
  319. data/lib/aws/elb/listener.rb +190 -0
  320. data/lib/aws/elb/listener_collection.rb +113 -0
  321. data/lib/aws/elb/listener_opts.rb +45 -0
  322. data/lib/aws/elb/load_balancer.rb +280 -0
  323. data/lib/aws/elb/load_balancer_collection.rb +148 -0
  324. data/lib/aws/elb/load_balancer_policy.rb +93 -0
  325. data/lib/aws/elb/load_balancer_policy_collection.rb +208 -0
  326. data/lib/aws/emr.rb +87 -0
  327. data/lib/aws/emr/client.rb +35 -0
  328. data/lib/aws/emr/config.rb +18 -0
  329. data/lib/aws/emr/errors.rb +22 -0
  330. data/lib/aws/emr/instance_group.rb +138 -0
  331. data/lib/aws/emr/instance_group_collection.rb +82 -0
  332. data/lib/aws/emr/job_flow.rb +307 -0
  333. data/lib/aws/emr/job_flow_collection.rb +183 -0
  334. data/lib/aws/errors.rb +162 -0
  335. data/lib/aws/glacier.rb +79 -0
  336. data/lib/aws/glacier/archive.rb +56 -0
  337. data/lib/aws/glacier/archive_collection.rb +146 -0
  338. data/lib/aws/glacier/client.rb +49 -0
  339. data/lib/aws/glacier/config.rb +19 -0
  340. data/lib/aws/glacier/errors.rb +22 -0
  341. data/lib/aws/glacier/resource.rb +30 -0
  342. data/lib/aws/glacier/vault.rb +145 -0
  343. data/lib/aws/glacier/vault_collection.rb +75 -0
  344. data/lib/aws/glacier/vault_notification_configuration.rb +29 -0
  345. data/lib/aws/iam.rb +408 -0
  346. data/lib/aws/iam/access_key.rb +185 -0
  347. data/lib/aws/iam/access_key_collection.rb +128 -0
  348. data/lib/aws/iam/account_alias_collection.rb +79 -0
  349. data/lib/aws/iam/client.rb +49 -0
  350. data/lib/aws/iam/collection.rb +83 -0
  351. data/lib/aws/iam/config.rb +18 -0
  352. data/lib/aws/iam/errors.rb +22 -0
  353. data/lib/aws/iam/group.rb +111 -0
  354. data/lib/aws/iam/group_collection.rb +132 -0
  355. data/lib/aws/iam/group_policy_collection.rb +47 -0
  356. data/lib/aws/iam/group_user_collection.rb +84 -0
  357. data/lib/aws/iam/login_profile.rb +111 -0
  358. data/lib/aws/iam/mfa_device.rb +52 -0
  359. data/lib/aws/iam/mfa_device_collection.rb +127 -0
  360. data/lib/aws/iam/policy.rb +46 -0
  361. data/lib/aws/iam/policy_collection.rb +188 -0
  362. data/lib/aws/iam/resource.rb +62 -0
  363. data/lib/aws/iam/server_certificate.rb +148 -0
  364. data/lib/aws/iam/server_certificate_collection.rb +138 -0
  365. data/lib/aws/iam/signing_certificate.rb +186 -0
  366. data/lib/aws/iam/signing_certificate_collection.rb +131 -0
  367. data/lib/aws/iam/user.rb +200 -0
  368. data/lib/aws/iam/user_collection.rb +133 -0
  369. data/lib/aws/iam/user_group_collection.rb +98 -0
  370. data/lib/aws/iam/user_policy.rb +90 -0
  371. data/lib/aws/iam/user_policy_collection.rb +45 -0
  372. data/lib/aws/iam/virtual_mfa_device.rb +139 -0
  373. data/lib/aws/iam/virtual_mfa_device_collection.rb +73 -0
  374. data/lib/aws/import_export.rb +73 -0
  375. data/lib/aws/import_export/client.rb +35 -0
  376. data/lib/aws/import_export/config.rb +19 -0
  377. data/lib/aws/import_export/errors.rb +22 -0
  378. data/lib/aws/kinesis.rb +53 -0
  379. data/lib/aws/kinesis/client.rb +35 -0
  380. data/lib/aws/kinesis/config.rb +18 -0
  381. data/lib/aws/kinesis/errors.rb +20 -0
  382. data/lib/aws/ops_works.rb +29 -0
  383. data/lib/aws/ops_works/client.rb +35 -0
  384. data/lib/aws/ops_works/config.rb +18 -0
  385. data/lib/aws/ops_works/errors.rb +20 -0
  386. data/lib/aws/rails.rb +195 -0
  387. data/lib/aws/rds.rb +70 -0
  388. data/lib/aws/rds/client.rb +48 -0
  389. data/lib/aws/rds/config.rb +18 -0
  390. data/lib/aws/rds/db_instance.rb +215 -0
  391. data/lib/aws/rds/db_instance_collection.rb +75 -0
  392. data/lib/aws/rds/db_snapshot.rb +163 -0
  393. data/lib/aws/rds/db_snapshot_collection.rb +89 -0
  394. data/lib/aws/rds/errors.rb +22 -0
  395. data/lib/aws/record.rb +139 -0
  396. data/lib/aws/record/abstract_base.rb +689 -0
  397. data/lib/aws/record/attributes.rb +388 -0
  398. data/lib/aws/record/conversion.rb +38 -0
  399. data/lib/aws/record/dirty_tracking.rb +287 -0
  400. data/lib/aws/record/errors.rb +143 -0
  401. data/lib/aws/record/exceptions.rb +51 -0
  402. data/lib/aws/record/hash_model.rb +204 -0
  403. data/lib/aws/record/hash_model/attributes.rb +195 -0
  404. data/lib/aws/record/hash_model/finder_methods.rb +172 -0
  405. data/lib/aws/record/hash_model/scope.rb +108 -0
  406. data/lib/aws/record/model.rb +453 -0
  407. data/lib/aws/record/model/attributes.rb +377 -0
  408. data/lib/aws/record/model/finder_methods.rb +232 -0
  409. data/lib/aws/record/model/scope.rb +212 -0
  410. data/lib/aws/record/naming.rb +31 -0
  411. data/lib/aws/record/scope.rb +203 -0
  412. data/lib/aws/record/validations.rb +694 -0
  413. data/lib/aws/record/validator.rb +246 -0
  414. data/lib/aws/record/validators/acceptance.rb +49 -0
  415. data/lib/aws/record/validators/block.rb +36 -0
  416. data/lib/aws/record/validators/confirmation.rb +41 -0
  417. data/lib/aws/record/validators/count.rb +106 -0
  418. data/lib/aws/record/validators/exclusion.rb +41 -0
  419. data/lib/aws/record/validators/format.rb +55 -0
  420. data/lib/aws/record/validators/inclusion.rb +54 -0
  421. data/lib/aws/record/validators/length.rb +105 -0
  422. data/lib/aws/record/validators/method.rb +31 -0
  423. data/lib/aws/record/validators/numericality.rb +136 -0
  424. data/lib/aws/record/validators/presence.rb +43 -0
  425. data/lib/aws/redshift.rb +51 -0
  426. data/lib/aws/redshift/client.rb +35 -0
  427. data/lib/aws/redshift/config.rb +18 -0
  428. data/lib/aws/redshift/errors.rb +22 -0
  429. data/lib/aws/route_53.rb +86 -0
  430. data/lib/aws/route_53/change_batch.rb +162 -0
  431. data/lib/aws/route_53/change_info.rb +72 -0
  432. data/lib/aws/route_53/client.rb +38 -0
  433. data/lib/aws/route_53/config.rb +18 -0
  434. data/lib/aws/route_53/errors.rb +22 -0
  435. data/lib/aws/route_53/hosted_zone.rb +159 -0
  436. data/lib/aws/route_53/hosted_zone_collection.rb +101 -0
  437. data/lib/aws/route_53/resource_record_set.rb +258 -0
  438. data/lib/aws/route_53/resource_record_set_collection.rb +110 -0
  439. data/lib/aws/s3.rb +160 -0
  440. data/lib/aws/s3/access_control_list.rb +265 -0
  441. data/lib/aws/s3/acl_object.rb +264 -0
  442. data/lib/aws/s3/acl_options.rb +204 -0
  443. data/lib/aws/s3/bucket.rb +743 -0
  444. data/lib/aws/s3/bucket_collection.rb +162 -0
  445. data/lib/aws/s3/bucket_lifecycle_configuration.rb +473 -0
  446. data/lib/aws/s3/bucket_region_cache.rb +51 -0
  447. data/lib/aws/s3/bucket_tag_collection.rb +111 -0
  448. data/lib/aws/s3/bucket_version_collection.rb +79 -0
  449. data/lib/aws/s3/cipher_io.rb +120 -0
  450. data/lib/aws/s3/client.rb +2089 -0
  451. data/lib/aws/s3/client/xml.rb +266 -0
  452. data/lib/aws/s3/config.rb +61 -0
  453. data/lib/aws/s3/cors_rule.rb +108 -0
  454. data/lib/aws/s3/cors_rule_collection.rb +194 -0
  455. data/lib/aws/s3/data_options.rb +191 -0
  456. data/lib/aws/s3/encryption_utils.rb +146 -0
  457. data/lib/aws/s3/errors.rb +94 -0
  458. data/lib/aws/s3/multipart_upload.rb +353 -0
  459. data/lib/aws/s3/multipart_upload_collection.rb +76 -0
  460. data/lib/aws/s3/object_collection.rb +356 -0
  461. data/lib/aws/s3/object_metadata.rb +103 -0
  462. data/lib/aws/s3/object_upload_collection.rb +77 -0
  463. data/lib/aws/s3/object_version.rb +154 -0
  464. data/lib/aws/s3/object_version_collection.rb +89 -0
  465. data/lib/aws/s3/paginated_collection.rb +75 -0
  466. data/lib/aws/s3/policy.rb +74 -0
  467. data/lib/aws/s3/prefix_and_delimiter_collection.rb +47 -0
  468. data/lib/aws/s3/prefixed_collection.rb +85 -0
  469. data/lib/aws/s3/presign_v4.rb +136 -0
  470. data/lib/aws/s3/presigned_post.rb +554 -0
  471. data/lib/aws/s3/region_detection.rb +75 -0
  472. data/lib/aws/s3/request.rb +62 -0
  473. data/lib/aws/s3/s3_object.rb +1795 -0
  474. data/lib/aws/s3/tree.rb +116 -0
  475. data/lib/aws/s3/tree/branch_node.rb +68 -0
  476. data/lib/aws/s3/tree/child_collection.rb +104 -0
  477. data/lib/aws/s3/tree/leaf_node.rb +94 -0
  478. data/lib/aws/s3/tree/node.rb +22 -0
  479. data/lib/aws/s3/tree/parent.rb +87 -0
  480. data/lib/aws/s3/uploaded_part.rb +82 -0
  481. data/lib/aws/s3/uploaded_part_collection.rb +84 -0
  482. data/lib/aws/s3/website_configuration.rb +102 -0
  483. data/lib/aws/simple_db.rb +218 -0
  484. data/lib/aws/simple_db/attribute.rb +156 -0
  485. data/lib/aws/simple_db/attribute_collection.rb +240 -0
  486. data/lib/aws/simple_db/client.rb +67 -0
  487. data/lib/aws/simple_db/config.rb +20 -0
  488. data/lib/aws/simple_db/consistent_read_option.rb +42 -0
  489. data/lib/aws/simple_db/delete_attributes.rb +62 -0
  490. data/lib/aws/simple_db/domain.rb +123 -0
  491. data/lib/aws/simple_db/domain_collection.rb +86 -0
  492. data/lib/aws/simple_db/domain_metadata.rb +110 -0
  493. data/lib/aws/simple_db/errors.rb +55 -0
  494. data/lib/aws/simple_db/expect_condition_option.rb +45 -0
  495. data/lib/aws/simple_db/item.rb +93 -0
  496. data/lib/aws/simple_db/item_collection.rb +654 -0
  497. data/lib/aws/simple_db/item_data.rb +73 -0
  498. data/lib/aws/simple_db/put_attributes.rb +60 -0
  499. data/lib/aws/simple_email_service.rb +443 -0
  500. data/lib/aws/simple_email_service/client.rb +37 -0
  501. data/lib/aws/simple_email_service/config.rb +18 -0
  502. data/lib/aws/simple_email_service/email_address_collection.rb +69 -0
  503. data/lib/aws/simple_email_service/errors.rb +22 -0
  504. data/lib/aws/simple_email_service/identity.rb +230 -0
  505. data/lib/aws/simple_email_service/identity_collection.rb +81 -0
  506. data/lib/aws/simple_email_service/quotas.rb +66 -0
  507. data/lib/aws/simple_workflow.rb +227 -0
  508. data/lib/aws/simple_workflow/activity_task.rb +178 -0
  509. data/lib/aws/simple_workflow/activity_task_collection.rb +123 -0
  510. data/lib/aws/simple_workflow/activity_type.rb +140 -0
  511. data/lib/aws/simple_workflow/activity_type_collection.rb +102 -0
  512. data/lib/aws/simple_workflow/client.rb +69 -0
  513. data/lib/aws/simple_workflow/config.rb +18 -0
  514. data/lib/aws/simple_workflow/count.rb +49 -0
  515. data/lib/aws/simple_workflow/decision_task.rb +617 -0
  516. data/lib/aws/simple_workflow/decision_task_collection.rb +223 -0
  517. data/lib/aws/simple_workflow/domain.rb +122 -0
  518. data/lib/aws/simple_workflow/domain_collection.rb +169 -0
  519. data/lib/aws/simple_workflow/errors.rb +20 -0
  520. data/lib/aws/simple_workflow/history_event.rb +280 -0
  521. data/lib/aws/simple_workflow/history_event_collection.rb +76 -0
  522. data/lib/aws/simple_workflow/option_formatters.rb +86 -0
  523. data/lib/aws/simple_workflow/resource.rb +94 -0
  524. data/lib/aws/simple_workflow/type.rb +89 -0
  525. data/lib/aws/simple_workflow/type_collection.rb +140 -0
  526. data/lib/aws/simple_workflow/workflow_execution.rb +391 -0
  527. data/lib/aws/simple_workflow/workflow_execution_collection.rb +617 -0
  528. data/lib/aws/simple_workflow/workflow_type.rb +186 -0
  529. data/lib/aws/simple_workflow/workflow_type_collection.rb +100 -0
  530. data/lib/aws/sns.rb +76 -0
  531. data/lib/aws/sns/client.rb +35 -0
  532. data/lib/aws/sns/config.rb +18 -0
  533. data/lib/aws/sns/errors.rb +22 -0
  534. data/lib/aws/sns/has_delivery_policy.rb +68 -0
  535. data/lib/aws/sns/message.rb +204 -0
  536. data/lib/aws/sns/originators/from_auto_scaling.rb +68 -0
  537. data/lib/aws/sns/policy.rb +47 -0
  538. data/lib/aws/sns/subscription.rb +165 -0
  539. data/lib/aws/sns/subscription_collection.rb +78 -0
  540. data/lib/aws/sns/topic.rb +403 -0
  541. data/lib/aws/sns/topic_collection.rb +62 -0
  542. data/lib/aws/sns/topic_subscription_collection.rb +54 -0
  543. data/lib/aws/sqs.rb +80 -0
  544. data/lib/aws/sqs/client.rb +53 -0
  545. data/lib/aws/sqs/config.rb +20 -0
  546. data/lib/aws/sqs/errors.rb +125 -0
  547. data/lib/aws/sqs/policy.rb +48 -0
  548. data/lib/aws/sqs/queue.rb +856 -0
  549. data/lib/aws/sqs/queue_collection.rb +186 -0
  550. data/lib/aws/sqs/received_message.rb +190 -0
  551. data/lib/aws/sqs/received_sns_message.rb +116 -0
  552. data/lib/aws/storage_gateway.rb +72 -0
  553. data/lib/aws/storage_gateway/client.rb +42 -0
  554. data/lib/aws/storage_gateway/config.rb +18 -0
  555. data/lib/aws/storage_gateway/errors.rb +22 -0
  556. data/lib/aws/sts.rb +164 -0
  557. data/lib/aws/sts/client.rb +55 -0
  558. data/lib/aws/sts/config.rb +18 -0
  559. data/lib/aws/sts/errors.rb +22 -0
  560. data/lib/aws/sts/federated_session.rb +56 -0
  561. data/lib/aws/sts/policy.rb +30 -0
  562. data/lib/aws/sts/session.rb +48 -0
  563. data/lib/aws/support.rb +29 -0
  564. data/lib/aws/support/client.rb +35 -0
  565. data/lib/aws/support/config.rb +18 -0
  566. data/lib/aws/support/errors.rb +20 -0
  567. data/lib/aws/version.rb +17 -0
  568. data/rails/init.rb +15 -0
  569. metadata +645 -0
@@ -0,0 +1,743 @@
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
+ module AWS
15
+ class S3
16
+
17
+ # Represents a bucket in S3.
18
+ #
19
+ # # Creating Buckets
20
+ #
21
+ # You create a bucket by name. Bucket names must be globally unique
22
+ # and must be DNS compatible.
23
+ #
24
+ # s3 = AWS::S3.new
25
+ # bucket = s3.buckets.create('dns-compat-bucket-name')
26
+ #
27
+ # # Getting a Bucket
28
+ #
29
+ # You can create a reference to a bucket, given its name.
30
+ #
31
+ # bucket = s3.buckets['bucket-name'] # makes no request
32
+ # bucket.exists? #=> returns true/false
33
+ #
34
+ # # Enumerating Buckets
35
+ #
36
+ # The {BucketCollection} class is enumerable.
37
+ #
38
+ # s3.buckets.each do |bucket|
39
+ # puts bucket.name
40
+ # end
41
+ #
42
+ # # Deleting a Bucket
43
+ #
44
+ # You can delete an empty bucket you own.
45
+ #
46
+ # bucket = s3.buckets.create('my-temp-bucket')
47
+ # bucket.objects['abc'].write('xyz')
48
+ #
49
+ # bucket.clear! # deletes all object versions in batches
50
+ # bucket.delete
51
+ #
52
+ # You can alternatively call {#delete!} which will clear
53
+ # the bucket for your first.
54
+ #
55
+ # bucket.delete!
56
+ #
57
+ # # Objects
58
+ #
59
+ # Given a bucket you can access its objects, either by key or by
60
+ # enumeration.
61
+ #
62
+ # bucket.objects['key'] #=> makes no request, returns an S3Object
63
+ #
64
+ # bucket.objects.each do |obj|
65
+ # puts obj.key
66
+ # end
67
+ #
68
+ # See {ObjectCollection} and {S3Object} for more information on working
69
+ # with objects.
70
+ #
71
+ # # Website Configuration
72
+ #
73
+ # It is easy to enable website hosting for a bucket.
74
+ #
75
+ # bucket.configure_website
76
+ #
77
+ # You can specify the index and error documents by passing a block.
78
+ # If your bucket is already configured as a website, the current
79
+ # configuration will be yielded. If you bucket it not currently
80
+ # configured as a website, a new configuration will be yielded
81
+ # with default values.
82
+ #
83
+ # bucket.configure_website do |cfg|
84
+ # cfg.index_document_suffix = 'index.html'
85
+ # cfg.error_document_key = 'error.html'
86
+ # end
87
+ #
88
+ # You can disable website hosting two ways:
89
+ #
90
+ # bucket.remove_website_configuration
91
+ # bucket.website_configuration = nil
92
+ #
93
+ # You can use {#website_configuration=} to copy a website configuration
94
+ # from one bucket to another.
95
+ #
96
+ # bucket.website_configuration = other_bucket.website_configuration
97
+ #
98
+ # # Bucket Policies and ACLs
99
+ #
100
+ # You can control access to your bucket and its contents a number
101
+ # of ways. You can specify a bucket ACL (access control list)
102
+ # or a bucket policy.
103
+ #
104
+ # ## ACLs
105
+ #
106
+ # ACLs control access to your bucket and its contents via a list of
107
+ # grants and grantees.
108
+ #
109
+ # ### Canned ACLs
110
+ #
111
+ # The simplest way to specify an ACL is to use one of Amazon's "canned"
112
+ # ACLs. Amazon accepts the following canned ACLs:
113
+ #
114
+ # * `:private`
115
+ # * `:public_read`
116
+ # * `:public_read_write`
117
+ # * `:authenticated_read`
118
+ # * `:bucket_owner_read`
119
+ # * `:bucket_owner_full_control`
120
+ #
121
+ # You can specify a the ACL at bucket creation or later update a bucket.
122
+ #
123
+ # # at create time, defaults to :private when not specified
124
+ # bucket = s3.buckets.create('name', :acl => :public_read)
125
+ #
126
+ # # replacing an existing bucket ACL
127
+ # bucket.acl = :private
128
+ #
129
+ # ### Grants
130
+ #
131
+ # Alternatively you can specify a hash of grants. Each entry in the
132
+ # `:grant` hash has a grant (key) and a list of grantees (values).
133
+ # Valid grant keys are:
134
+ #
135
+ # * `:grant_read`
136
+ # * `:grant_write`
137
+ # * `:grant_read_acp`
138
+ # * `:grant_write_acp`
139
+ # * `:grant_full_control`
140
+ #
141
+ # Each grantee can be a String, Hash or array of strings or hashes.
142
+ # The following example uses grants to provide public read
143
+ # to everyone while providing full control to a user by email address
144
+ # and to another by their account id (cannonical user id).
145
+ #
146
+ # bucket = s3.buckets.create('name', :grants => {
147
+ # :grant_read => [
148
+ # { :uri => "http://acs.amazonaws.com/groups/global/AllUsers" },
149
+ # ],
150
+ # :grant_full_control => [
151
+ # { :id => 'abc...mno' } # cannonical user id
152
+ # { :email_address => 'foo@bar.com' }, # email address
153
+ # ]
154
+ # })
155
+ #
156
+ # ### ACL Object
157
+ #
158
+ # Lastly, you can build an ACL object and use a Ruby DSL to specify grants
159
+ # and grantees. See {ACLObject} for more information.
160
+ #
161
+ # # updating an existing bucket acl using ACLObject
162
+ # bucket.acl.change do |acl|
163
+ # acl.grants.reject! do |g|
164
+ # g.grantee.canonical_user_id != bucket.owner.id
165
+ # end
166
+ # end
167
+ #
168
+ # ## Policies
169
+ #
170
+ # You can also work with bucket policies.
171
+ #
172
+ # policy = AWS::S3::Policy.new
173
+ # policy.allow(
174
+ # :actions => [:put_object, :get_object]
175
+ # :resources => [bucket]
176
+ # :principals => :any)
177
+ #
178
+ # bucket.policy = policy
179
+ #
180
+ # See {Core::Policy} and {S3::Policy} for more information on build
181
+ # policy objects.
182
+ #
183
+ # # Versioned Buckets
184
+ #
185
+ # You can enable versioning on a bucket you control. When versioning
186
+ # is enabled, S3 will keep track of each version of each object you
187
+ # write to the bucket (even deletions).
188
+ #
189
+ # bucket.versioning_enabled? #=> false
190
+ # bucket.enable_versioning
191
+ # # there is also a #suspend_versioning method
192
+ #
193
+ # obj = bucket.objects['my-obj']
194
+ # obj.write('a')
195
+ # obj.write('b')
196
+ # obj.delete
197
+ # obj.write('c')
198
+ #
199
+ # obj.versions.each do |obj_version|
200
+ # if obj_version.delete_marker?
201
+ # puts obj_version.read
202
+ # else
203
+ # puts "- DELETE MARKER"
204
+ # end
205
+ # end
206
+ #
207
+ # Alternatively you can enumerate all versions of all objects in your
208
+ # bucket.
209
+ #
210
+ # bucket.versions.each do |obj_version|
211
+ # puts obj_version.key ` " : " ` obj_version.version_id
212
+ # end
213
+ #
214
+ # See {BucketVersionCollection}, {ObjectVersionCollection} and
215
+ # {ObjectVersion} for more information on working with objects in
216
+ # a versioned bucket. Also see the S3 documentation for information
217
+ # on object versioning.
218
+ #
219
+ class Bucket
220
+
221
+ include Core::Model
222
+ include ACLOptions
223
+
224
+ # @param [String] name
225
+ # @param [Hash] options
226
+ # @option options [String] :owner (nil) The owner id of this bucket.
227
+ def initialize(name, options = {})
228
+ # the S3 docs disagree with what the service allows,
229
+ # so it's not safe to toss out invalid bucket names
230
+ # S3::Client.validate_bucket_name!(name)
231
+ @name = name
232
+ @owner = options[:owner]
233
+ super
234
+ end
235
+
236
+ # @return [String] The bucket name
237
+ attr_reader :name
238
+
239
+ # Returns the url for this bucket.
240
+ # @return [String] url to the bucket
241
+ def url(options = {})
242
+ protocol = options.fetch(:secure, false) ? "https://" : "http://"
243
+ if client.dns_compatible_bucket_name?(name)
244
+ "#{protocol}#{name}.s3.amazonaws.com/"
245
+ else
246
+ "#{protocol}s3.amazonaws.com/#{name}/"
247
+ end
248
+ end
249
+
250
+ # @return [Boolean] Returns true if the bucket has no objects
251
+ # (this includes versioned objects that are delete markers).
252
+ def empty?
253
+ versions.first ? false : true
254
+ end
255
+
256
+ # @return [String,nil] Returns the location constraint for a bucket
257
+ # (if it has one), nil otherwise.
258
+ def location_constraint
259
+ client.get_bucket_location(:bucket_name => name).location_constraint
260
+ end
261
+
262
+ # Configure the current bucket as a website.
263
+ #
264
+ # bucket.configure_website
265
+ #
266
+ # If you pass a block, the website configuration object
267
+ # will be yielded. You can modify it before it is saved.
268
+ #
269
+ # bucket.configure_website do |cfg|
270
+ # cfg.index_document_suffix = 'index.html'
271
+ # cfg.error_document_key = 'error.html'
272
+ # end
273
+ #
274
+ # If the bucket already has a website configuration, it will be loaded
275
+ # and yielded. This makes it possible to modify an existing
276
+ # configuration.
277
+ #
278
+ # # only rename the error document
279
+ # bucket.configure_website do |cfg|
280
+ # cfg.error_document_key = 'oops.html'
281
+ # end
282
+ #
283
+ # @yieldparam [WebsiteConfiguration] website_config
284
+ # @return [WebsiteConfiguration]
285
+ # @see #website_configuration
286
+ # @see #website_configuration=
287
+ # @see #remove_website_configuration
288
+ # @see #website?
289
+ def configure_website &block
290
+ website_config = self.website_configuration
291
+ website_config ||= WebsiteConfiguration.new
292
+ yield(website_config) if block_given?
293
+ self.website_configuration = website_config
294
+ end
295
+
296
+ # Returns the bucket website configuration. Returns `nil` if the bucket
297
+ # is not configured as a website.
298
+ # @return [WebsiteConfiguration,nil]
299
+ # @see #configure_website
300
+ # @see #website_configuration=
301
+ # @see #remove_website_configuration
302
+ # @see #website?
303
+ def website_configuration
304
+ resp = client.get_bucket_website(:bucket_name => name)
305
+ WebsiteConfiguration.new(resp.data)
306
+ rescue Errors::NoSuchWebsiteConfiguration
307
+ nil
308
+ end
309
+
310
+ # Sets the website configuration. Deletes the configuration if
311
+ # `nil` is passed.
312
+ # @param [WebsiteConfiguration,nil] website_configuration
313
+ # @see #configure_website
314
+ # @see #website_configuration
315
+ # @see #remove_website_configuration
316
+ # @see #website?
317
+ def website_configuration= website_configuration
318
+ if website_configuration
319
+ client_opts = website_configuration.to_hash
320
+ client_opts[:bucket_name] = name
321
+ client.put_bucket_website(client_opts)
322
+ else
323
+ remove_website_configuration
324
+ end
325
+ end
326
+
327
+ # @return [nil] Deletes the bucket website configuration.
328
+ # @see #configure_website
329
+ # @see #website_configuration
330
+ # @see #website_configuration=
331
+ # @see #website?
332
+ def remove_website_configuration
333
+ client.delete_bucket_website(:bucket_name => name)
334
+ @website_configuration = false
335
+ nil
336
+ end
337
+
338
+ # @return [Boolean] Returns `true` if this bucket is configured as
339
+ # a website.
340
+ # @see #configure_website
341
+ # @see #website_configuration
342
+ # @see #website_configuration=
343
+ # @see #remove_website_configuration
344
+ def website?
345
+ !!website_configuration
346
+ end
347
+
348
+ # Returns the tags for this bucket.
349
+ #
350
+ # tags = bucket.tags
351
+ # #=> <AWS::S3::BucketTagCollection>
352
+ #
353
+ # # adds a tag to the bucket
354
+ # tags['foo'] = 'abc'
355
+ #
356
+ # # replaces all tags
357
+ # tags.set('new' => 'tags')
358
+ #
359
+ # # removes all tags from the bucket
360
+ # tags.clear
361
+ #
362
+ # # returns tags as a hash
363
+ # tags.to_h
364
+ #
365
+ # @return [BucketTagCollection] Returns a collection that represents
366
+ # the tags for this bucket.
367
+ #
368
+ def tags
369
+ BucketTagCollection.new(self)
370
+ end
371
+
372
+ # Sets the tags for this bucket.
373
+ #
374
+ # bucket.tags = { 'contents' => 'photots' }
375
+ #
376
+ # You can remove all tags for the bucket by passing an empty
377
+ # hash or `nil`.
378
+ #
379
+ # bucket.tags = nil # {} also deletes all tags
380
+ # bucket.tags
381
+ # #=> {}
382
+ #
383
+ # @param [Hash,nil] tags The tags to set on this bucket.
384
+ #
385
+ def tags= tags
386
+ self.tags.set(tags)
387
+ end
388
+
389
+ # @return [CORSRuleCollection] Returns a collection that can be
390
+ # used to manage (add, edit and delete) CORS rules for this bucket.
391
+ def cors
392
+ CORSRuleCollection.new(self)
393
+ end
394
+
395
+ # Sets the bucket CORS rules.
396
+ # @param (see CORSRuleCollection#set)
397
+ # @see CORSRuleCollection#set
398
+ def cors= *rules
399
+ self.cors.set(*rules)
400
+ end
401
+
402
+ # Enables versioning on this bucket.
403
+ #
404
+ # @option opts [String] :mfa_delete Set to 'Enabled' or 'Disabled'
405
+ # to control the state of MFA delete on the bucket versioning.
406
+ # Setting this option requires the :mfa option to also be set.
407
+ #
408
+ # @option opts [String] :mfa The serial number and current token code of
409
+ # the Multi-Factor Authentication (MFA) device for the user. Format
410
+ # is "SERIAL TOKEN" - with a space between the serial and token.
411
+ #
412
+ # @return [nil]
413
+ def enable_versioning(opts = {})
414
+ client.set_bucket_versioning(
415
+ :bucket_name => @name,
416
+ :state => :enabled,
417
+ :mfa_delete => opts[:mfa_delete],
418
+ :mfa => opts[:mfa])
419
+ nil
420
+ end
421
+
422
+ # Suspends versioning on this bucket.
423
+ #
424
+ # @option opts [String] :mfa_delete Set to 'Enabled' or 'Disabled'
425
+ # to control the state of MFA delete on the bucket versioning.
426
+ # Setting this option requires the :mfa option to also be set.
427
+ #
428
+ # @option opts [String] :mfa The serial number and current token code of
429
+ # the Multi-Factor Authentication (MFA) device for the user. Format
430
+ # is "SERIAL TOKEN" - with a space between the serial and token.
431
+ #
432
+ # @return [nil]
433
+ def suspend_versioning(opts = {})
434
+ client.set_bucket_versioning(
435
+ :bucket_name => @name,
436
+ :state => :suspended,
437
+ :mfa_delete => opts[:mfa_delete],
438
+ :mfa => opts[:mfa])
439
+ nil
440
+ end
441
+
442
+ # @return [Boolean] returns `true` if version is enabled on this bucket.
443
+ def versioning_enabled?
444
+ versioning_state == :enabled
445
+ end
446
+ alias_method :versioned?, :versioning_enabled?
447
+
448
+ # Returns the versioning status for this bucket. States include:
449
+ #
450
+ # * `:enabled` - currently enabled
451
+ # * `:suspended` - currently suspended
452
+ # * `:unversioned` - versioning has never been enabled
453
+ #
454
+ # @return [Symbol] the versioning state
455
+ def versioning_state
456
+ client.get_bucket_versioning(:bucket_name => @name).status
457
+ end
458
+
459
+ # Deletes all objects from this bucket.
460
+ # @return [nil]
461
+ def clear!
462
+ versions.each_batch do |versions|
463
+ objects.delete(versions)
464
+ end
465
+ end
466
+
467
+ # Deletes the current bucket. An error will be raised if the
468
+ # bucket is not empty.
469
+ # @return [nil]
470
+ def delete
471
+ client.delete_bucket(:bucket_name => @name)
472
+ nil
473
+ end
474
+
475
+ # Deletes all objects in a bucket and then deletes the bucket.
476
+ # @return [nil]
477
+ def delete!
478
+ clear!
479
+ delete
480
+ end
481
+
482
+ # @return [String] bucket owner id
483
+ def owner
484
+ @owner || client.list_buckets.owner
485
+ end
486
+
487
+ # @api private
488
+ def inspect
489
+ "#<AWS::S3::Bucket:#{name}>"
490
+ end
491
+
492
+ # @return [Boolean] Returns true if the two buckets have the same name.
493
+ def ==(other)
494
+ other.kind_of?(Bucket) && other.name == name
495
+ end
496
+
497
+ # @return [Boolean] Returns true if the two buckets have the same name
498
+ def eql?(other_bucket)
499
+ self == other_bucket
500
+ end
501
+
502
+ # @note This method only indicates if there is a bucket in S3, not
503
+ # if you have permissions to work with the bucket or not.
504
+ # @return [Boolean] Returns true if the bucket exists in S3.
505
+ def exists?
506
+ begin
507
+ versioned? # makes a get bucket request without listing contents
508
+ # raises a client error if the bucket doesn't exist or
509
+ # if you don't have permission to get the bucket
510
+ # versioning status.
511
+ true
512
+ rescue Errors::NoSuchBucket => e
513
+ false # bucket does not exist
514
+ rescue Errors::AccessDenied => e
515
+ true # bucket exists
516
+ end
517
+ end
518
+
519
+ # @return [ObjectCollection] Represents all objects(keys) in
520
+ # this bucket.
521
+ def objects
522
+ ObjectCollection.new(self)
523
+ end
524
+
525
+ # @return [BucketVersionCollection] Represents all of the versioned
526
+ # objects stored in this bucket.
527
+ def versions
528
+ BucketVersionCollection.new(self)
529
+ end
530
+
531
+ # @return [MultipartUploadCollection] Represents all of the
532
+ # multipart uploads that are in progress for this bucket.
533
+ def multipart_uploads
534
+ MultipartUploadCollection.new(self)
535
+ end
536
+
537
+ # @api private
538
+ module ACLProxy
539
+
540
+ attr_accessor :bucket
541
+
542
+ def change
543
+ yield(self)
544
+ bucket.acl = self
545
+ end
546
+
547
+ end
548
+
549
+ # Returns the bucket's access control list. This will be an
550
+ # instance of AccessControlList, plus an additional `change`
551
+ # method:
552
+ #
553
+ # bucket.acl.change do |acl|
554
+ # acl.grants.reject! do |g|
555
+ # g.grantee.canonical_user_id != bucket.owner.id
556
+ # end
557
+ # end
558
+ #
559
+ # @return [AccessControlList]
560
+ def acl
561
+
562
+ resp = client.get_bucket_acl(:bucket_name => name)
563
+
564
+ acl = AccessControlList.new(resp.data)
565
+ acl.extend ACLProxy
566
+ acl.bucket = self
567
+ acl
568
+
569
+ end
570
+
571
+ # Sets the bucket's ACL (access control list). You can provide an ACL
572
+ # in a number of different formats.
573
+ # @param (see ACLOptions#acl_options)
574
+ # @return [nil]
575
+ def acl= acl
576
+ client.set_bucket_acl(acl_options(acl).merge(:bucket_name => name))
577
+ nil
578
+ end
579
+
580
+ # @api private
581
+ module PolicyProxy
582
+
583
+ attr_accessor :bucket
584
+
585
+ def change
586
+ yield(self)
587
+ bucket.policy = self
588
+ end
589
+
590
+ def delete
591
+ bucket.client.delete_bucket_policy(:bucket_name => bucket.name)
592
+ end
593
+
594
+ end
595
+
596
+ # Returns the bucket policy. This will be an instance of
597
+ # Policy. The returned policy will also have the methods of
598
+ # PolicyProxy mixed in, so you can use it to change the
599
+ # current policy or delete it, for example:
600
+ #
601
+ # if policy = bucket.policy
602
+ # # add a statement
603
+ # policy.change do |p|
604
+ # p.allow(...)
605
+ # end
606
+ #
607
+ # # delete the policy
608
+ # policy.delete
609
+ # end
610
+ #
611
+ # Note that changing the policy is not an atomic operation; it
612
+ # fetches the current policy, yields it to the block, and then
613
+ # sets it again. Therefore, it's possible that you may
614
+ # overwrite a concurrent update to the policy using this
615
+ # method.
616
+ #
617
+ # @return [Policy,nil] Returns the bucket policy (if it has one),
618
+ # or it returns `nil` otherwise.
619
+ def policy
620
+ resp = client.get_bucket_policy(:bucket_name => name)
621
+ policy = Policy.from_json(resp.data[:policy])
622
+ policy.extend(PolicyProxy)
623
+ policy.bucket = self
624
+ policy
625
+ rescue Errors::NoSuchBucketPolicy => e
626
+ nil
627
+ end
628
+
629
+ # Sets the bucket's policy.
630
+ #
631
+ # @param policy The new policy. This can be a string (which
632
+ # is assumed to contain a valid policy expressed in JSON), a
633
+ # Policy object or any object that responds to `to_json`.
634
+ # @see Policy
635
+ # @return [nil]
636
+ def policy=(policy)
637
+ client.set_bucket_policy(:bucket_name => name, :policy => policy)
638
+ nil
639
+ end
640
+
641
+ # The primary interface for editing the lifecycle configuration.
642
+ # See {BucketLifecycleConfiguration} for more information.
643
+ #
644
+ # @example Adding rules to a bucket's lifecycle configuration
645
+ #
646
+ # bucket.lifecycle_configuration.update do
647
+ # add_rule 'cache-1/', 30
648
+ # add_rule 'cache-2/', 30
649
+ # end
650
+ #
651
+ # @example Deleting the lifecycle configuration
652
+ #
653
+ # bucket.lifecycle_configuration.clear
654
+ #
655
+ # @return [BucketLifecycleConfiguration]
656
+ #
657
+ def lifecycle_configuration
658
+ @lifecycle_cfg ||= BucketLifecycleConfiguration.new(self)
659
+ end
660
+
661
+ # You can call this method if you prefer to build your own
662
+ # lifecycle configuration.
663
+ #
664
+ # bucket.lifecycle_configuration = <<-XML
665
+ # <LifecycleConfiguration>
666
+ # ...
667
+ # </LifecycleConfiguration>
668
+ # XML
669
+ #
670
+ # You can also use this method to copy a lifecycle configuration
671
+ # from another bucket.
672
+ #
673
+ # bucket.lifecycle_configuration = other_bucket.lifecycle_configuration
674
+ #
675
+ # If you call this method, passing nil, the lifecycle configuration
676
+ # for this bucket will be deleted.
677
+ #
678
+ # @param [String,Object] config You can pass an xml string or any
679
+ # other object that responds to #to_xml (e.g.
680
+ # BucketLifecycleConfiguration).
681
+ #
682
+ # @return [nil]
683
+ #
684
+ def lifecycle_configuration= config
685
+
686
+ if config.nil?
687
+
688
+ client_opts = {}
689
+ client_opts[:bucket_name] = name
690
+ client.delete_bucket_lifecycle_configuration(client_opts)
691
+
692
+ @lifecycle_cfg = BucketLifecycleConfiguration.new(self, :empty => true)
693
+
694
+ else
695
+
696
+ xml = config.is_a?(String) ? config : config.to_xml
697
+
698
+ client_opts = {}
699
+ client_opts[:bucket_name] = name
700
+ client_opts[:lifecycle_configuration] = xml
701
+ client.set_bucket_lifecycle_configuration(client_opts)
702
+
703
+ @lifecycle_cfg = BucketLifecycleConfiguration.new(self, :xml => xml)
704
+
705
+ end
706
+
707
+ nil
708
+
709
+ end
710
+
711
+ # Returns a tree that allows you to expose the bucket contents
712
+ # like a directory structure.
713
+ #
714
+ # @see Tree
715
+ # @param [Hash] options
716
+ # @option options [String] :prefix (nil) Set prefix to choose where
717
+ # the top of the tree will be. A value of `nil` means
718
+ # that the tree will include all objects in the collection.
719
+ #
720
+ # @option options [String] :delimiter ('/') The string that separates
721
+ # each level of the tree. This is usually a directory separator.
722
+ #
723
+ # @option options [Boolean] :append (true) If true, the delimiter is
724
+ # appended to the prefix when the prefix does not already end
725
+ # with the delimiter.
726
+ #
727
+ # @return [Tree]
728
+ def as_tree options = {}
729
+ objects.as_tree(options)
730
+ end
731
+
732
+ # Generates fields for a presigned POST to this object. All
733
+ # options are sent to the PresignedPost constructor.
734
+ #
735
+ # @see PresignedPost
736
+ def presigned_post(options = {})
737
+ PresignedPost.new(self, options)
738
+ end
739
+
740
+ end
741
+
742
+ end
743
+ end