s3.tf 2.3 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104
  1. resource "aws_s3_bucket" "tfstate" {
  2. bucket = var.bucket_name
  3. depends_on = [var.module_depends_on]
  4. }
  5. resource "aws_s3_bucket_acl" "s3_acl_tfstate" {
  6. bucket = aws_s3_bucket.tfstate.id
  7. acl = "private"
  8. }
  9. resource "aws_s3_bucket_versioning" "s3_version_tfstate" {
  10. bucket = aws_s3_bucket.tfstate.id
  11. versioning_configuration {
  12. status = "Enabled"
  13. }
  14. }
  15. # FIXME: Does this keep a cross-account dependency?
  16. #logging {
  17. #target_bucket = "dps-s3-logs"
  18. #target_prefix = "aws_terraform_s3_state_access_logs/"
  19. #}
  20. resource "aws_s3_bucket_lifecycle_configuration" "s3_lifecyle_tfstate" {
  21. bucket = aws_s3_bucket.tfstate.id
  22. rule {
  23. status = "Enabled"
  24. abort_incomplete_multipart_upload {
  25. days_after_initiation = 7
  26. }
  27. noncurrent_version_transition {
  28. noncurrent_days = 30
  29. storage_class = "STANDARD_IA"
  30. }
  31. noncurrent_version_expiration {
  32. noncurrent_days = 730
  33. }
  34. }
  35. }
  36. resource "aws_s3_bucket_server_side_encryption_configuration" "s3_sse_tfstate" {
  37. bucket = aws_s3_bucket.tfstate.id
  38. rule {
  39. apply_server_side_encryption_by_default {
  40. kms_master_key_id = aws_kms_key.tfstate.arn
  41. sse_algorithm = "aws:kms"
  42. }
  43. }
  44. }
  45. resource "aws_s3_bucket_public_access_block" "tfstate" {
  46. bucket = aws_s3_bucket.tfstate.id
  47. block_public_acls = true
  48. block_public_policy = true
  49. ignore_public_acls = true
  50. restrict_public_buckets = true
  51. }
  52. //AWS Provider outdated arguments <4.4.0
  53. /*resource "aws_s3_bucket" "tfstate" {
  54. bucket = var.bucket_name
  55. acl = "private"
  56. depends_on = [ var.module_depends_on ]
  57. versioning {
  58. enabled = true
  59. }
  60. # FIXME: Does this keep a cross-account dependency?
  61. #logging {
  62. #target_bucket = "dps-s3-logs"
  63. #target_prefix = "aws_terraform_s3_state_access_logs/"
  64. #}
  65. lifecycle_rule {
  66. enabled = true
  67. prefix = ""
  68. abort_incomplete_multipart_upload_days = 7
  69. noncurrent_version_transition {
  70. days = 30
  71. storage_class = "STANDARD_IA"
  72. }
  73. noncurrent_version_expiration {
  74. days = 730
  75. }
  76. }
  77. server_side_encryption_configuration {
  78. rule {
  79. apply_server_side_encryption_by_default {
  80. kms_master_key_id = aws_kms_key.tfstate.arn
  81. sse_algorithm = "aws:kms"
  82. }
  83. }
  84. }
  85. }
  86. */