fog-aws 3.11.0 → 3.14.0

Sign up to get free protection for your applications and to get access to all the features.
Files changed (285) hide show
  1. checksums.yaml +4 -4
  2. data/CHANGELOG.md +53 -3
  3. data/README.md +43 -0
  4. data/fog-aws.gemspec +3 -4
  5. data/lib/fog/aws/compute.rb +6 -3
  6. data/lib/fog/aws/credential_fetcher.rb +22 -8
  7. data/lib/fog/aws/iam/default_policies.json +1574 -0
  8. data/lib/fog/aws/iam/default_policy_versions.json +3373 -0
  9. data/lib/fog/aws/models/compute/security_group.rb +13 -5
  10. data/lib/fog/aws/models/storage/directories.rb +1 -0
  11. data/lib/fog/aws/models/storage/file.rb +8 -7
  12. data/lib/fog/aws/parsers/compute/describe_security_groups.rb +18 -4
  13. data/lib/fog/aws/requests/compute/authorize_security_group_ingress.rb +15 -0
  14. data/lib/fog/aws/requests/compute/create_network_interface.rb +7 -4
  15. data/lib/fog/aws/requests/compute/create_subnet.rb +3 -3
  16. data/lib/fog/aws/requests/compute/describe_security_groups.rb +2 -0
  17. data/lib/fog/aws/requests/rds/add_tags_to_resource.rb +12 -10
  18. data/lib/fog/aws/requests/rds/list_tags_for_resource.rb +10 -7
  19. data/lib/fog/aws/requests/rds/remove_tags_from_resource.rb +9 -8
  20. data/lib/fog/aws/storage.rb +5 -1
  21. data/lib/fog/aws/version.rb +1 -1
  22. metadata +5 -280
  23. data/tests/credentials_tests.rb +0 -149
  24. data/tests/helper.rb +0 -29
  25. data/tests/helpers/collection_helper.rb +0 -90
  26. data/tests/helpers/compute/flavors_helper.rb +0 -28
  27. data/tests/helpers/compute/server_helper.rb +0 -23
  28. data/tests/helpers/compute/servers_helper.rb +0 -8
  29. data/tests/helpers/dns_helper.rb +0 -56
  30. data/tests/helpers/formats_helper.rb +0 -100
  31. data/tests/helpers/formats_helper_tests.rb +0 -107
  32. data/tests/helpers/mock_helper.rb +0 -109
  33. data/tests/helpers/model_helper.rb +0 -30
  34. data/tests/helpers/responds_to_helper.rb +0 -11
  35. data/tests/helpers/schema_validator_tests.rb +0 -104
  36. data/tests/helpers/succeeds_helper.rb +0 -9
  37. data/tests/lorem.txt +0 -1
  38. data/tests/models/auto_scaling/activities_tests.rb +0 -6
  39. data/tests/models/auto_scaling/configuration_test.rb +0 -13
  40. data/tests/models/auto_scaling/configurations_tests.rb +0 -11
  41. data/tests/models/auto_scaling/groups_test.rb +0 -27
  42. data/tests/models/auto_scaling/helper.rb +0 -0
  43. data/tests/models/auto_scaling/instance_tests.rb +0 -15
  44. data/tests/models/auto_scaling/instances_tests.rb +0 -6
  45. data/tests/models/beanstalk/application_tests.rb +0 -69
  46. data/tests/models/beanstalk/applications_tests.rb +0 -7
  47. data/tests/models/beanstalk/environment_tests.rb +0 -131
  48. data/tests/models/beanstalk/environments_tests.rb +0 -34
  49. data/tests/models/beanstalk/template_tests.rb +0 -47
  50. data/tests/models/beanstalk/templates_tests.rb +0 -62
  51. data/tests/models/beanstalk/version_tests.rb +0 -66
  52. data/tests/models/beanstalk/versions_tests.rb +0 -60
  53. data/tests/models/cdn/distribution_tests.rb +0 -15
  54. data/tests/models/cdn/distributions_tests.rb +0 -15
  55. data/tests/models/cdn/invalidation_tests.rb +0 -31
  56. data/tests/models/cdn/invalidations_tests.rb +0 -14
  57. data/tests/models/cdn/streaming_distribution_tests.rb +0 -15
  58. data/tests/models/cdn/streaming_distributions_tests.rb +0 -15
  59. data/tests/models/cloud_watch/alarm_data_tests.rb +0 -42
  60. data/tests/models/cloud_watch/alarm_history_tests.rb +0 -22
  61. data/tests/models/cloud_watch/metric_statistics_tests.rb +0 -51
  62. data/tests/models/cloud_watch/metrics_tests.rb +0 -32
  63. data/tests/models/compute/address_tests.rb +0 -43
  64. data/tests/models/compute/addresses_tests.rb +0 -5
  65. data/tests/models/compute/dhcp_option_tests.rb +0 -3
  66. data/tests/models/compute/dhcp_options_tests.rb +0 -3
  67. data/tests/models/compute/internet_gateway_tests.rb +0 -3
  68. data/tests/models/compute/internet_gateways_tests.rb +0 -3
  69. data/tests/models/compute/key_pair_tests.rb +0 -26
  70. data/tests/models/compute/key_pairs_tests.rb +0 -5
  71. data/tests/models/compute/network_acl_tests.rb +0 -109
  72. data/tests/models/compute/network_acls_tests.rb +0 -20
  73. data/tests/models/compute/network_interfaces_test.rb +0 -12
  74. data/tests/models/compute/security_group_tests.rb +0 -98
  75. data/tests/models/compute/security_groups_tests.rb +0 -5
  76. data/tests/models/compute/server_tests.rb +0 -94
  77. data/tests/models/compute/snapshot_tests.rb +0 -10
  78. data/tests/models/compute/snapshots_tests.rb +0 -10
  79. data/tests/models/compute/subnet_tests.rb +0 -13
  80. data/tests/models/compute/subnets_tests.rb +0 -5
  81. data/tests/models/compute/volume_tests.rb +0 -65
  82. data/tests/models/compute/volumes_tests.rb +0 -5
  83. data/tests/models/compute/vpc_tests.rb +0 -26
  84. data/tests/models/compute/vpcs_tests.rb +0 -19
  85. data/tests/models/data_pipeline/pipeline_tests.rb +0 -8
  86. data/tests/models/data_pipeline/pipelines_tests.rb +0 -8
  87. data/tests/models/dns/record_tests.rb +0 -33
  88. data/tests/models/dns/records_tests.rb +0 -41
  89. data/tests/models/dns/zone_tests.rb +0 -4
  90. data/tests/models/dns/zones_tests.rb +0 -4
  91. data/tests/models/efs/file_system_tests.rb +0 -12
  92. data/tests/models/efs/mount_target_tests.rb +0 -45
  93. data/tests/models/efs/mount_targets_tests.rb +0 -30
  94. data/tests/models/elasticache/cluster_tests.rb +0 -30
  95. data/tests/models/elasticache/parameter_groups_tests.rb +0 -15
  96. data/tests/models/elasticache/security_groups_tests.rb +0 -52
  97. data/tests/models/elasticache/subnet_groups_tests.rb +0 -43
  98. data/tests/models/elb/model_tests.rb +0 -360
  99. data/tests/models/elb/tagging_tests.rb +0 -15
  100. data/tests/models/glacier/model_tests.rb +0 -47
  101. data/tests/models/iam/access_keys_tests.rb +0 -53
  102. data/tests/models/iam/groups_tests.rb +0 -59
  103. data/tests/models/iam/instance_profile_tests.rb +0 -18
  104. data/tests/models/iam/managed_policies_tests.rb +0 -89
  105. data/tests/models/iam/policies_tests.rb +0 -57
  106. data/tests/models/iam/roles_tests.rb +0 -71
  107. data/tests/models/iam/users_tests.rb +0 -119
  108. data/tests/models/rds/cluster_tests.rb +0 -54
  109. data/tests/models/rds/clusters_tests.rb +0 -5
  110. data/tests/models/rds/event_subscription_tests.rb +0 -9
  111. data/tests/models/rds/event_subscriptions_tests.rb +0 -6
  112. data/tests/models/rds/helper.rb +0 -25
  113. data/tests/models/rds/instance_option_tests.rb +0 -14
  114. data/tests/models/rds/parameter_group_tests.rb +0 -24
  115. data/tests/models/rds/parameter_groups_tests.rb +0 -8
  116. data/tests/models/rds/security_group_tests.rb +0 -77
  117. data/tests/models/rds/security_groups_tests.rb +0 -5
  118. data/tests/models/rds/server_tests.rb +0 -131
  119. data/tests/models/rds/servers_tests.rb +0 -24
  120. data/tests/models/rds/snapshot_tests.rb +0 -12
  121. data/tests/models/rds/snapshots_tests.rb +0 -12
  122. data/tests/models/rds/tagging_tests.rb +0 -20
  123. data/tests/models/sns/topic_tests.rb +0 -15
  124. data/tests/models/sns/topics_tests.rb +0 -6
  125. data/tests/models/storage/directory_tests.rb +0 -202
  126. data/tests/models/storage/file_tests.rb +0 -129
  127. data/tests/models/storage/files_tests.rb +0 -90
  128. data/tests/models/storage/url_tests.rb +0 -25
  129. data/tests/models/storage/version_tests.rb +0 -52
  130. data/tests/models/storage/versions_tests.rb +0 -51
  131. data/tests/models/support/trusted_advisor_tests.rb +0 -25
  132. data/tests/parsers/compute/describe_images_tests.rb +0 -33
  133. data/tests/parsers/elb/describe_load_balancers.rb +0 -65
  134. data/tests/parsers/elbv2/create_load_balancer_tests.rb +0 -48
  135. data/tests/parsers/elbv2/describe_listeners_tests.rb +0 -76
  136. data/tests/parsers/elbv2/describe_load_balancers_tests.rb +0 -54
  137. data/tests/parsers/elbv2/describe_tags_tests.rb +0 -35
  138. data/tests/requests/auto_scaling/auto_scaling_tests.rb +0 -111
  139. data/tests/requests/auto_scaling/describe_types_tests.rb +0 -102
  140. data/tests/requests/auto_scaling/helper.rb +0 -229
  141. data/tests/requests/auto_scaling/model_tests.rb +0 -235
  142. data/tests/requests/auto_scaling/notification_configuration_tests.rb +0 -124
  143. data/tests/requests/auto_scaling/tag_tests.rb +0 -63
  144. data/tests/requests/beanstalk/application_tests.rb +0 -140
  145. data/tests/requests/beanstalk/solution_stack_tests.rb +0 -22
  146. data/tests/requests/cdn/cdn_tests.rb +0 -252
  147. data/tests/requests/cloud_formation/stack_tests.rb +0 -167
  148. data/tests/requests/cloud_watch/get_metric_statistics_tests.rb +0 -28
  149. data/tests/requests/cloud_watch/list_metrics_test.rb +0 -64
  150. data/tests/requests/cloud_watch/put_metric_data_tests.rb +0 -36
  151. data/tests/requests/compute/address_tests.rb +0 -144
  152. data/tests/requests/compute/assign_private_ip_tests.rb +0 -55
  153. data/tests/requests/compute/availability_zone_tests.rb +0 -25
  154. data/tests/requests/compute/client_tests.rb +0 -25
  155. data/tests/requests/compute/dhcp_options_tests.rb +0 -39
  156. data/tests/requests/compute/helper.rb +0 -27
  157. data/tests/requests/compute/image_tests.rb +0 -169
  158. data/tests/requests/compute/instance_attrib_tests.rb +0 -168
  159. data/tests/requests/compute/instance_tests.rb +0 -338
  160. data/tests/requests/compute/internet_gateway_tests.rb +0 -49
  161. data/tests/requests/compute/key_pair_tests.rb +0 -67
  162. data/tests/requests/compute/network_acl_tests.rb +0 -112
  163. data/tests/requests/compute/network_interface_tests.rb +0 -239
  164. data/tests/requests/compute/placement_group_tests.rb +0 -48
  165. data/tests/requests/compute/region_tests.rb +0 -52
  166. data/tests/requests/compute/route_tests.rb +0 -341
  167. data/tests/requests/compute/security_group_tests.rb +0 -446
  168. data/tests/requests/compute/snapshot_tests.rb +0 -77
  169. data/tests/requests/compute/spot_datafeed_subscription_tests.rb +0 -47
  170. data/tests/requests/compute/spot_instance_tests.rb +0 -55
  171. data/tests/requests/compute/spot_price_history_tests.rb +0 -23
  172. data/tests/requests/compute/subnet_tests.rb +0 -87
  173. data/tests/requests/compute/tag_tests.rb +0 -101
  174. data/tests/requests/compute/volume_tests.rb +0 -263
  175. data/tests/requests/compute/vpc_tests.rb +0 -222
  176. data/tests/requests/data_pipeline/helper.rb +0 -78
  177. data/tests/requests/data_pipeline/pipeline_tests.rb +0 -80
  178. data/tests/requests/dns/change_resource_record_sets_tests.rb +0 -34
  179. data/tests/requests/dns/dns_tests.rb +0 -240
  180. data/tests/requests/dns/health_check_tests.rb +0 -159
  181. data/tests/requests/dns/helper.rb +0 -21
  182. data/tests/requests/dynamodb/item_tests.rb +0 -137
  183. data/tests/requests/dynamodb/table_tests.rb +0 -99
  184. data/tests/requests/ecs/cluster_tests.rb +0 -112
  185. data/tests/requests/ecs/container_instance_tests.rb +0 -119
  186. data/tests/requests/ecs/helper.rb +0 -276
  187. data/tests/requests/ecs/sample_task_definition1.json +0 -56
  188. data/tests/requests/ecs/service_tests.rb +0 -132
  189. data/tests/requests/ecs/task_definitions_tests.rb +0 -97
  190. data/tests/requests/ecs/task_tests.rb +0 -145
  191. data/tests/requests/efs/file_system_tests.rb +0 -152
  192. data/tests/requests/efs/helper.rb +0 -44
  193. data/tests/requests/elasticache/cache_cluster_tests.rb +0 -137
  194. data/tests/requests/elasticache/describe_events.rb +0 -17
  195. data/tests/requests/elasticache/describe_reserved_cache_nodes.rb +0 -17
  196. data/tests/requests/elasticache/helper.rb +0 -103
  197. data/tests/requests/elasticache/parameter_group_tests.rb +0 -105
  198. data/tests/requests/elasticache/security_group_tests.rb +0 -108
  199. data/tests/requests/elasticache/subnet_group_tests.rb +0 -52
  200. data/tests/requests/elb/helper.rb +0 -91
  201. data/tests/requests/elb/listener_tests.rb +0 -68
  202. data/tests/requests/elb/load_balancer_tests.rb +0 -89
  203. data/tests/requests/elb/policy_tests.rb +0 -132
  204. data/tests/requests/elbv2/helper.rb +0 -66
  205. data/tests/requests/elbv2/load_balancer_tests.rb +0 -50
  206. data/tests/requests/emr/helper.rb +0 -167
  207. data/tests/requests/emr/instance_group_tests.rb +0 -106
  208. data/tests/requests/emr/job_flow_tests.rb +0 -88
  209. data/tests/requests/federation/get_signin_token_tests.rb +0 -11
  210. data/tests/requests/glacier/archive_tests.rb +0 -13
  211. data/tests/requests/glacier/multipart_upload_tests.rb +0 -29
  212. data/tests/requests/glacier/tree_hash_tests.rb +0 -91
  213. data/tests/requests/glacier/vault_tests.rb +0 -35
  214. data/tests/requests/iam/access_key_tests.rb +0 -53
  215. data/tests/requests/iam/account_policy_tests.rb +0 -20
  216. data/tests/requests/iam/account_tests.rb +0 -34
  217. data/tests/requests/iam/group_policy_tests.rb +0 -48
  218. data/tests/requests/iam/group_tests.rb +0 -44
  219. data/tests/requests/iam/helper.rb +0 -154
  220. data/tests/requests/iam/instance_profile_tests.rb +0 -44
  221. data/tests/requests/iam/login_profile_tests.rb +0 -62
  222. data/tests/requests/iam/managed_policy_tests.rb +0 -110
  223. data/tests/requests/iam/mfa_tests.rb +0 -23
  224. data/tests/requests/iam/role_tests.rb +0 -156
  225. data/tests/requests/iam/server_certificate_tests.rb +0 -130
  226. data/tests/requests/iam/user_policy_tests.rb +0 -45
  227. data/tests/requests/iam/user_tests.rb +0 -78
  228. data/tests/requests/iam/versioned_managed_policy_tests.rb +0 -105
  229. data/tests/requests/kinesis/helper.rb +0 -111
  230. data/tests/requests/kinesis/stream_tests.rb +0 -169
  231. data/tests/requests/kms/helper.rb +0 -27
  232. data/tests/requests/kms/key_tests.rb +0 -23
  233. data/tests/requests/lambda/function_sample_1.js +0 -9
  234. data/tests/requests/lambda/function_sample_2.js +0 -9
  235. data/tests/requests/lambda/function_tests.rb +0 -460
  236. data/tests/requests/lambda/helper.rb +0 -81
  237. data/tests/requests/rds/cluster_snapshot_tests.rb +0 -43
  238. data/tests/requests/rds/cluster_tests.rb +0 -37
  239. data/tests/requests/rds/db_engine_versions.rb +0 -7
  240. data/tests/requests/rds/db_snapshot_tests.rb +0 -62
  241. data/tests/requests/rds/describe_events.rb +0 -16
  242. data/tests/requests/rds/event_subscription_tests.rb +0 -30
  243. data/tests/requests/rds/helper.rb +0 -406
  244. data/tests/requests/rds/instance_option_tests.rb +0 -27
  245. data/tests/requests/rds/instance_tests.rb +0 -149
  246. data/tests/requests/rds/log_file_tests.rb +0 -19
  247. data/tests/requests/rds/parameter_group_tests.rb +0 -62
  248. data/tests/requests/rds/parameter_request_tests.rb +0 -32
  249. data/tests/requests/rds/security_group_tests.rb +0 -101
  250. data/tests/requests/rds/subnet_groups_tests.rb +0 -52
  251. data/tests/requests/rds/tagging_tests.rb +0 -78
  252. data/tests/requests/redshift/cluster_parameter_group_tests.rb +0 -76
  253. data/tests/requests/redshift/cluster_security_group_tests.rb +0 -42
  254. data/tests/requests/redshift/cluster_snapshot_tests.rb +0 -73
  255. data/tests/requests/redshift/cluster_tests.rb +0 -80
  256. data/tests/requests/ses/helper.rb +0 -9
  257. data/tests/requests/ses/verified_domain_identity_tests.rb +0 -16
  258. data/tests/requests/ses/verified_email_address_tests.rb +0 -27
  259. data/tests/requests/simpledb/attributes_tests.rb +0 -86
  260. data/tests/requests/simpledb/domain_tests.rb +0 -51
  261. data/tests/requests/simpledb/helper.rb +0 -10
  262. data/tests/requests/sns/helper.rb +0 -9
  263. data/tests/requests/sns/subscription_tests.rb +0 -86
  264. data/tests/requests/sns/topic_tests.rb +0 -53
  265. data/tests/requests/sqs/helper.rb +0 -9
  266. data/tests/requests/sqs/message_tests.rb +0 -51
  267. data/tests/requests/sqs/queue_tests.rb +0 -50
  268. data/tests/requests/storage/acl_utils_tests.rb +0 -209
  269. data/tests/requests/storage/bucket_tests.rb +0 -416
  270. data/tests/requests/storage/cors_utils_tests.rb +0 -108
  271. data/tests/requests/storage/delete_multiple_objects_tests.rb +0 -12
  272. data/tests/requests/storage/multipart_copy_tests.rb +0 -93
  273. data/tests/requests/storage/multipart_upload_tests.rb +0 -121
  274. data/tests/requests/storage/object_tests.rb +0 -269
  275. data/tests/requests/storage/versioning_tests.rb +0 -300
  276. data/tests/requests/sts/assume_role_tests.rb +0 -19
  277. data/tests/requests/sts/assume_role_with_saml_tests.rb +0 -18
  278. data/tests/requests/sts/assume_role_with_web_identity_tests.rb +0 -28
  279. data/tests/requests/sts/get_federation_token_tests.rb +0 -20
  280. data/tests/requests/sts/session_token_tests.rb +0 -16
  281. data/tests/requests/support/helper.rb +0 -43
  282. data/tests/requests/support/trusted_advisor_check_tests.rb +0 -16
  283. data/tests/signaturev4_tests.rb +0 -106
  284. data/tests/signed_params_tests.rb +0 -17
  285. data/tests/storage_tests.rb +0 -7
checksums.yaml CHANGED
@@ -1,7 +1,7 @@
1
1
  ---
2
2
  SHA256:
3
- metadata.gz: db78eac28d74ef1522933e294d0528ecf4f99d072594629f6befeb75927f63e6
4
- data.tar.gz: 9496a31776f748834e82525bebf26a157208d7fec58f273d21508bc1c6d25062
3
+ metadata.gz: c8af574874772df5b7a7e51819b23f554543472c6cef0b4ff86addac3b0c24b7
4
+ data.tar.gz: f5171df32eec2c204d27ce7ac7ef361d5b7bc9c0761b6b95efd347b977deb97c
5
5
  SHA512:
6
- metadata.gz: 0a6c79d3d5598348a49a3c1bff6b4e89804900d851a9a6e1cd328f98e2877b6ff6a66fe1703e5276f46f434d39adc3ad8d00dcef6905308168f34993278c52a5
7
- data.tar.gz: d7a32f8b0df5f0f439662d8917e1eaf7ef5cc74433f48653162d74a6ae725d3fdf9a2bfe64e81f59abf8d3470c1cb44631476cd514d145249b99ca95d09615ad
6
+ metadata.gz: 0526c83e1825435460136d7afa5f2467e88de9171ed64fcbe0fc75871ffd2564435b310f54585de0e24e2dbb38d36fa969952c0da98787e6d43fb8128950ad36
7
+ data.tar.gz: b9282f04b1b59446ab5781154932461d9230e6ef58dde2d573dd8bc488722faa02e54b77a376bda9e1ab8391a673c44bd975f24be9e1ade9ec7b30f1b817c70f
data/CHANGELOG.md CHANGED
@@ -1,8 +1,58 @@
1
1
  # Changelog
2
2
 
3
- ## [Unreleased](https://github.com/fog/fog-aws/tree/HEAD)
3
+ ## [v3.14.0](https://github.com/fog/fog-aws/tree/v3.14.0) (2022-05-09)
4
4
 
5
- [Full Changelog](https://github.com/fog/fog-aws/compare/v3.10.0...HEAD)
5
+ [Full Changelog](https://github.com/fog/fog-aws/compare/v3.13.0...HEAD)
6
+
7
+ **Closed issues:**
8
+
9
+ - Add a special note to the documentation around the danger of using directory.get [\#633](https://github.com/fog/fog-aws/issues/633)
10
+
11
+ **Merged pull requests:**
12
+
13
+ - RDD tags issue in AWS GovCloud Account regions. [\#643](https://github.com/fog/fog-aws/pull/643) ([svavhal](https://github.com/svavhal))
14
+ - Create codeql.yml [\#641](https://github.com/fog/fog-aws/pull/641) ([naveensrinivasan](https://github.com/naveensrinivasan))
15
+ - chore\(deps\): Included dependency review [\#640](https://github.com/fog/fog-aws/pull/640) ([naveensrinivasan](https://github.com/naveensrinivasan))
16
+ - Bump actions/stale from 4 to 5 [\#639](https://github.com/fog/fog-aws/pull/639) ([dependabot[bot]](https://github.com/apps/dependabot))
17
+ - Set permissions for GitHub actions [\#638](https://github.com/fog/fog-aws/pull/638) ([naveensrinivasan](https://github.com/naveensrinivasan))
18
+ - Add option to control IAM credential refresh [\#637](https://github.com/fog/fog-aws/pull/637) ([gl-gh-hchouraria](https://github.com/gl-gh-hchouraria))
19
+ - Add warning messages around directories.get [\#636](https://github.com/fog/fog-aws/pull/636) ([orrin-naylor-instacart](https://github.com/orrin-naylor-instacart))
20
+ - Bump actions/checkout from 2.4.0 to 3 [\#632](https://github.com/fog/fog-aws/pull/632) ([dependabot[bot]](https://github.com/apps/dependabot))
21
+ - Add Ruby 3.1 to the CI matrix [\#631](https://github.com/fog/fog-aws/pull/631) ([petergoldstein](https://github.com/petergoldstein))
22
+
23
+ ## [v3.13.0](https://github.com/fog/fog-aws/tree/v3.13.0) (2022-02-13)
24
+
25
+ [Full Changelog](https://github.com/fog/fog-aws/compare/v3.12.0...v3.13.0)
26
+
27
+ **Closed issues:**
28
+
29
+ - Please include all files required for running tests in the gem [\#625](https://github.com/fog/fog-aws/issues/625)
30
+ - Using Hitachi compatible S3 and still see the AWS S3 host [\#624](https://github.com/fog/fog-aws/issues/624)
31
+ - Spawn compute node with Elastic Inference [\#617](https://github.com/fog/fog-aws/issues/617)
32
+
33
+ **Merged pull requests:**
34
+
35
+ - Drop ipaddress dependency in favor of built in ipaddr [\#630](https://github.com/fog/fog-aws/pull/630) ([ekohl](https://github.com/ekohl))
36
+ - Exclude test files from gem [\#629](https://github.com/fog/fog-aws/pull/629) ([ursm](https://github.com/ursm))
37
+ - Add Truffleruby head to CI [\#628](https://github.com/fog/fog-aws/pull/628) ([gogainda](https://github.com/gogainda))
38
+ - Bump actions/checkout from 2.3.5 to 2.4.0 [\#627](https://github.com/fog/fog-aws/pull/627) ([dependabot[bot]](https://github.com/apps/dependabot))
39
+ - Update Fog::AWS::Storage::File\#body [\#626](https://github.com/fog/fog-aws/pull/626) ([10io](https://github.com/10io))
40
+ - Bump actions/checkout from 2.3.4 to 2.3.5 [\#623](https://github.com/fog/fog-aws/pull/623) ([dependabot[bot]](https://github.com/apps/dependabot))
41
+ - Add json files to the gem file [\#622](https://github.com/fog/fog-aws/pull/622) ([acant](https://github.com/acant))
42
+
43
+ ## [v3.12.0](https://github.com/fog/fog-aws/tree/v3.12.0) (2021-08-23)
44
+
45
+ [Full Changelog](https://github.com/fog/fog-aws/compare/v3.11.0...v3.12.0)
46
+
47
+ **Merged pull requests:**
48
+
49
+ - Add support for regional STS endpoints [\#620](https://github.com/fog/fog-aws/pull/620) ([stanhu](https://github.com/stanhu))
50
+ - Add IPv6 support for Ingress Security Groups [\#619](https://github.com/fog/fog-aws/pull/619) ([p8](https://github.com/p8))
51
+ - Separate CHANGELOG entry for 3.11.0 [\#618](https://github.com/fog/fog-aws/pull/618) ([sunny](https://github.com/sunny))
52
+
53
+ ## [v3.11.0](https://github.com/fog/fog-aws/tree/v3.11.0) (2021-08-05)
54
+
55
+ [Full Changelog](https://github.com/fog/fog-aws/compare/v3.10.0...v3.11.0)
6
56
 
7
57
  **Closed issues:**
8
58
 
@@ -136,7 +186,7 @@
136
186
 
137
187
  **Merged pull requests:**
138
188
 
139
- - Handle multiple versions of objects in multiple delete request [\#600](https://github.com/fog/fog-aws/pull/600) ([shanu-idrive](https://github.com/shanu-idrive))
189
+ - Handle multiple versions of objects in multiple delete request [\#600](https://github.com/fog/fog-aws/pull/600) ([shanu-kr](https://github.com/shanu-kr))
140
190
  - Add Truffleruby head to CI [\#596](https://github.com/fog/fog-aws/pull/596) ([gogainda](https://github.com/gogainda))
141
191
  - Fixes domain name duplication in url [\#593](https://github.com/fog/fog-aws/pull/593) ([midhunkrishna](https://github.com/midhunkrishna))
142
192
 
data/README.md CHANGED
@@ -98,6 +98,7 @@ file = directory.files.create(key: 'user/1/Gemfile', body: File.open('Gemfile'),
98
98
  directory = s3.directories.get('gaudi-portal-dev', prefix: 'user/1/')
99
99
  directory.files
100
100
  ```
101
+ **Warning!** `s3.directories.get` retrieves and caches meta data for the first 10,000 objects in the bucket, which can be very expensive. When possible use `s3.directories.new`.
101
102
 
102
103
  #### Generating a URL for a file:
103
104
 
@@ -105,6 +106,48 @@ directory.files
105
106
  directory.files.new(key: 'user/1/Gemfile').url(Time.now + 60)
106
107
  ```
107
108
 
109
+ ##### Controlling credential refresh time with IAM authentication
110
+
111
+ When using IAM authentication with
112
+ [temporary security credentials](https://docs.aws.amazon.com/STS/latest/APIReference/API_AssumeRoleWithWebIdentity.html),
113
+ generated S3 pre-signed URLs
114
+ [only last as long as the temporary credential](https://docs.aws.amazon.com/AmazonS3/latest/userguide/ShareObjectPreSignedURL.html).
115
+
116
+ Generating the URLs in the following manner will return a URL
117
+ that will not last as long as its requested expiration time if
118
+ the remainder of the authentication token lifetime was shorter.
119
+
120
+ ```ruby
121
+ s3 = Fog::Storage.new(provider: 'AWS', use_iam_auth: true)
122
+ directory = s3.directories.get('gaudi-portal-dev', prefix: 'user/1/')
123
+
124
+ directory.files.new(key: 'user/1/Gemfile').url(Time.now + 60)
125
+ ```
126
+
127
+ By default the temporary credentials in use are refreshed only within the last
128
+ 15 seconds of its expiration time. The URL requested with 60 seconds lifetime
129
+ using the above example will only remain valid for 15 seconds in the worst case.
130
+
131
+ The problem can be avoided by refreshing the token early and often,
132
+ by setting configuration `aws_credentials_refresh_threshold_seconds` (default: 15)
133
+ which controls the time when the refresh must occur. It is expressed in seconds
134
+ before the temporary credential's expiration time.
135
+
136
+ The following example can ensure pre-signed URLs last as long as 60 seconds
137
+ by automatically refreshing the credentials when its remainder lifetime
138
+ is lower than 60 seconds:
139
+
140
+ ```ruby
141
+ s3 = Fog::Storage.new(
142
+ provider: 'AWS',
143
+ use_iam_auth: true,
144
+ aws_credentials_refresh_threshold_seconds: 60
145
+ )
146
+ directory = s3.directories.get('gaudi-portal-dev', prefix: 'user/1/')
147
+
148
+ directory.files.new(key: 'user/1/Gemfile').url(Time.now + 60)
149
+ ```
150
+
108
151
  #### Copying a file
109
152
 
110
153
  ```ruby
data/fog-aws.gemspec CHANGED
@@ -14,10 +14,10 @@ Gem::Specification.new do |spec|
14
14
  spec.homepage = "https://github.com/fog/fog-aws"
15
15
  spec.license = "MIT"
16
16
 
17
- spec.files = Dir['lib/**/*.rb', 'tests/**/*', 'CHANGELOG.md', 'CONTRIBUTING.md',
18
- 'CONTRIBUTORS.md', 'LICENSE.md', 'README.md', 'fog-aws.gemspec',]
17
+ spec.files = Dir['lib/**/*.{rb,json}',
18
+ 'CHANGELOG.md', 'CONTRIBUTING.md', 'CONTRIBUTORS.md',
19
+ 'LICENSE.md', 'README.md', 'fog-aws.gemspec',]
19
20
  spec.executables = spec.files.grep(%r{^exe/}) { |f| File.basename(f) }
20
- spec.test_files = spec.files.grep(%r{^(test|spec|features)/})
21
21
  spec.require_paths = ["lib"]
22
22
 
23
23
  spec.required_ruby_version = '>= 2.0.0'
@@ -31,5 +31,4 @@ Gem::Specification.new do |spec|
31
31
  spec.add_dependency 'fog-core', '~> 2.1'
32
32
  spec.add_dependency 'fog-json', '~> 1.1'
33
33
  spec.add_dependency 'fog-xml', '~> 0.1'
34
- spec.add_dependency 'ipaddress', '~> 0.8'
35
34
  end
@@ -233,21 +233,24 @@ module Fog
233
233
  'fromPort' => -1,
234
234
  'toPort' => -1,
235
235
  'ipProtocol' => 'icmp',
236
- 'ipRanges' => []
236
+ 'ipRanges' => [],
237
+ 'ipv6Ranges' => []
237
238
  },
238
239
  {
239
240
  'groups' => [{'groupName' => 'default', 'userId' => owner_id, 'groupId' => security_group_id}],
240
241
  'fromPort' => 0,
241
242
  'toPort' => 65535,
242
243
  'ipProtocol' => 'tcp',
243
- 'ipRanges' => []
244
+ 'ipRanges' => [],
245
+ 'ipv6Ranges' => []
244
246
  },
245
247
  {
246
248
  'groups' => [{'groupName' => 'default', 'userId' => owner_id, 'groupId' => security_group_id}],
247
249
  'fromPort' => 0,
248
250
  'toPort' => 65535,
249
251
  'ipProtocol' => 'udp',
250
- 'ipRanges' => []
252
+ 'ipRanges' => [],
253
+ 'ipv6Ranges' => []
251
254
  }
252
255
  ],
253
256
  'ownerId' => owner_id
@@ -13,8 +13,6 @@ module Fog
13
13
 
14
14
  CONTAINER_CREDENTIALS_HOST = "http://169.254.170.2"
15
15
 
16
- STS_GLOBAL_ENDPOINT = "https://sts.amazonaws.com"
17
-
18
16
  module ServiceMethods
19
17
  def fetch_credentials(options)
20
18
  if options[:use_iam_profile] && Fog.mocking?
@@ -23,7 +21,7 @@ module Fog
23
21
  if options[:use_iam_profile]
24
22
  begin
25
23
  role_data = nil
26
- region = options[:region]
24
+ region = options[:region] || ENV["AWS_DEFAULT_REGION"]
27
25
 
28
26
  if ENV["AWS_CONTAINER_CREDENTIALS_RELATIVE_URI"]
29
27
  connection = options[:connection] || Excon.new(CONTAINER_CREDENTIALS_HOST)
@@ -44,7 +42,15 @@ module Fog
44
42
  :WebIdentityToken => File.read(options[:aws_web_identity_token_file] || ENV.fetch("AWS_WEB_IDENTITY_TOKEN_FILE")),
45
43
  :Version => "2011-06-15",
46
44
  }
47
- connection = options[:connection] || Excon.new(STS_GLOBAL_ENDPOINT, :query => params)
45
+
46
+ sts_endpoint =
47
+ if ENV["AWS_STS_REGIONAL_ENDPOINTS"] == "regional" && region
48
+ "https://sts.#{region}.amazonaws.com"
49
+ else
50
+ "https://sts.amazonaws.com"
51
+ end
52
+
53
+ connection = options[:connection] || Excon.new(sts_endpoint, :query => params)
48
54
  document = Nokogiri::XML(connection.get(:idempotent => true, :expects => 200).body)
49
55
 
50
56
  session = {
@@ -65,18 +71,19 @@ module Fog
65
71
  role_name = connection.get(:path => INSTANCE_METADATA_PATH, :idempotent => true, :expects => 200, :headers => token_header).body
66
72
  role_data = connection.get(:path => INSTANCE_METADATA_PATH+role_name, :idempotent => true, :expects => 200, :headers => token_header).body
67
73
  session = Fog::JSON.decode(role_data)
68
-
74
+
69
75
  region ||= connection.get(:path => INSTANCE_METADATA_AZ, :idempotent => true, :expects => 200, :headers => token_header).body[0..-2]
70
76
  end
71
-
77
+
72
78
  credentials = {}
73
79
  credentials[:aws_access_key_id] = session['AccessKeyId']
74
80
  credentials[:aws_secret_access_key] = session['SecretAccessKey']
75
81
  credentials[:aws_session_token] = session['Token']
76
82
  credentials[:aws_credentials_expire_at] = Time.xmlschema session['Expiration']
77
-
83
+
78
84
  # set region by default to the one the instance is in.
79
85
  credentials[:region] = region
86
+ credentials[:sts_endpoint] = sts_endpoint if sts_endpoint
80
87
  #these indicate the metadata service is unavailable or has no profile setup
81
88
  credentials
82
89
  rescue Excon::Error => e
@@ -116,10 +123,17 @@ module Fog
116
123
 
117
124
  private
118
125
 
126
+ # When defined, 'aws_credentials_refresh_threshold_seconds' controls
127
+ # when the credential needs to be refreshed, expressed in seconds before
128
+ # the current credential's expiration time
129
+ def credentials_refresh_threshold
130
+ @aws_credentials_refresh_threshold_seconds || 15
131
+ end
132
+
119
133
  def credentials_expired?
120
134
  @use_iam_profile &&
121
135
  (!@aws_credentials_expire_at ||
122
- (@aws_credentials_expire_at && Fog::Time.now > @aws_credentials_expire_at - 15)) #new credentials become available from around 5 minutes before expiration time
136
+ (@aws_credentials_expire_at && Fog::Time.now > @aws_credentials_expire_at - credentials_refresh_threshold)) #new credentials become available from around 5 minutes before expiration time
123
137
  end
124
138
 
125
139
  def refresh_credentials