Terraformを使ってdev環境でのみリソースを作成する

Terraformを使ってdev環境でのみリソースを作成する:


はじめに

Terraformで複数環境を管理しているときに、CircleCIデプロイ用のIAMユーザーの作成もTerraform管理に含めたい!… ということで、dev環境でのみリソースを作成する方法です。

Terraformのバージョンは0.11.9で検証しています。


やり方

count = "${terraform.workspace == "dev" ? "1" : "0"}"

countは0のときは作成せず、1のときは一つ作成するという仕組みを利用します

terraform env new dev 
terraform env select dev # これすることでterraform.workspaceがdevになります 
  • 以下は全体のコードです
deployer_iam_user.tf
esource "aws_iam_user" "user" { 
  count = "${terraform.workspace == "dev" ? "1" : "0"}" 
  name = "${var.name}-deployer" 
} 
 
data "aws_iam_policy_document" "deployer_policy_document" { 
  statement { 
    actions = [ 
      "s3:ListBucket" 
    ] 
 
    resources = [ 
      "arn:aws:s3:::${var.bucket}" 
    ] 
 
    condition { 
      test     = "StringEquals" 
      variable = "s3:prefix" 
 
      values = [ 
        "" 
      ] 
    } 
  } 
 
  statement { 
    actions = [ 
      "s3:ListBucket", 
    ] 
 
    resources = [ 
      "arn:aws:s3:::${var.bucket}", 
    ] 
 
    condition { 
      test     = "StringLike" 
      variable = "s3:prefix" 
 
      values = [ 
        "dev", 
        "dev/*", 
        "stg", 
        "stg/*", 
        "pro", 
        "pro/*" 
      ] 
    } 
  } 
 
  statement { 
    actions = [ 
      "s3:*", 
    ] 
 
    resources = [ 
      "arn:aws:s3:::${var.bucket}/dev/*", 
      "arn:aws:s3:::${var.bucket}/stg/*", 
      "arn:aws:s3:::${var.bucket}/pro/*", 
    ] 
  } 
} 
 
resource "aws_iam_policy" "deployer_policy" { 
  count = "${terraform.workspace == "dev" ? "1" : "0"}" 
  name        = "${var.name}-deployer-policy" 
  description = "${var.name} deployer policy" 
  policy = "${data.aws_iam_policy_document.deployer_policy_document.json}" 
} 
 
resource "aws_iam_policy_attachment" "deployer-attach" { 
  count = "${terraform.workspace == "dev" ? "1" : "0"}" 
  name       = "${var.name}-deployer-attachment" 
  users      = ["${aws_iam_user.user.id}"] 
  policy_arn = "${aws_iam_policy.deployer_policy.arn}" 
} 
 
resource "aws_iam_access_key" "key" { 
  count = "${terraform.workspace == "dev" ? "1" : "0"}" 
  user = "${aws_iam_user.user.name}" 
} 
variables.tf
variable "name" { 
  default = "sample" 
} 
 
variable "bucket" { 
  default = "sample" 
} 


最後に

terraform env selectで環境を選択するだけでお手軽にCircleCIデプロイ用のIAMユーザーを作成することができました。

こんな感じですべてのリソースをTerraformで管理したいですね!

コメント

このブログの人気の投稿

投稿時間:2021-06-17 05:05:34 RSSフィード2021-06-17 05:00 分まとめ(1274件)

投稿時間:2021-06-20 02:06:12 RSSフィード2021-06-20 02:00 分まとめ(3871件)

投稿時間:2020-12-01 09:41:49 RSSフィード2020-12-01 09:00 分まとめ(69件)