gpt4 book ai didi

amazon-web-services - Cognito身份池授权/未授权角色的Terraform定义

转载 作者:行者123 更新时间:2023-12-04 18:57:38 26 4
gpt4 key购买 nike

我一直在尝试创建一个Terraform脚本,以创建具有链接的auth和unauth角色的cognito用户池和身份池,但是我找不到执行此操作的好示例。这是我到目前为止的内容:

cognito.tf:

resource "aws_cognito_user_pool" "pool" {
name = "Sample User Pool"
admin_create_user_config {
allow_admin_create_user_only = false
}

/* More stuff here, not included*/
}

resource "aws_cognito_user_pool_client" "client" {
name = "client"
user_pool_id = "${aws_cognito_user_pool.pool.id}"

generate_secret = true
explicit_auth_flows = ["ADMIN_NO_SRP_AUTH"]
}

resource "aws_cognito_identity_pool" "main" {
identity_pool_name = "SampleIdentityPool"
allow_unauthenticated_identities = false

cognito_identity_providers {
client_id = "${aws_cognito_user_pool_client.id}"
provider_name = ""
server_side_token_check = true
}
}


因此,我想为此添加一个auth角色和一个unauth角色,但是我仍在设法了解如何在terraform中定义和链接IAM角色,但这是到目前为止的内容:

 resource "aws_cognito_identity_pool_roles_attachment" "main" {
identity_pool_id = "${aws_cognito_identity_pool.main.id}"

roles {
"authenticated" = <<EOF
{
actions = ["sts:AssumeRoleWithWebIdentity"]

principals {
type = "Federated"
identifiers = ["cognito-identity.amazonaws.com"]
}

condition {
test = "StringEquals"
variable = "cognito-identity.amazonaws.com:aud"
values = ["${aws_cognito_identity_pool.main.id}"]
}

condition {
test = "ForAnyValue:StringLike"
variable = "cognito-identity.amazonaws.com:amr"
values = ["authenticated"]
}
}
EOF
"unauthenticated" = <<EOF
{
actions = ["sts:AssumeRoleWithWebIdentity"]

principals {
type = "Federated"
identifiers = ["cognito-identity.amazonaws.com"]
}

condition {
test = "StringEquals"
variable = "cognito-identity.amazonaws.com:aud"
values = ["${aws_cognito_identity_pool.main.id}"]
}
}
EOF
}
}


但是,这不起作用。它会正确创建池和客户端,但不会将任何内容附加到auth / unauth角色。除了无法使用AWS控制台之外,我无法弄清丢失的内容,也找不到如何正确执行此操作的任何示例。感谢您在Terraform中正确解决此问题的任何帮助!

最佳答案

经过几天的讨论,我终于弄明白了。我只是对“承担角色策略”和“政策”感到困惑。一旦我解决了这个问题,它就会起作用。这(大致)是我现在所拥有的。我将其放在此处,希望这可以避免有人第一次尝试解决此问题,从而避免很多麻烦。

对于用户池:

 resource "aws_cognito_user_pool" "pool" {
name = "Sample Pool"
/* ... Lots more attributes */
}


对于用户池客户端:

 resource "aws_cognito_user_pool_client" "client" {
name = "client"
user_pool_id = "${aws_cognito_user_pool.pool.id}"
generate_secret = true
explicit_auth_flows = ["ADMIN_NO_SRP_AUTH"]
}


对于身份池:

 resource "aws_cognito_identity_pool" "main" {
identity_pool_name = "SampleIdentities"
allow_unauthenticated_identities = false

cognito_identity_providers {
client_id = "${aws_cognito_user_pool_client.client.id}"
provider_name = "..."
server_side_token_check = true
}
}


将角色附加到身份池:

 resource "aws_cognito_identity_pool_roles_attachment" "main" {
identity_pool_id = "${aws_cognito_identity_pool.main.id}"

roles = {
authenticated = "${aws_iam_role.auth_iam_role.arn}"
unauthenticated = "${aws_iam_role.unauth_iam_role.arn}"
}
}


最后,角色和政策:

 resource "aws_iam_role" "auth_iam_role" {
name = "auth_iam_role"
assume_role_policy = <<EOF
{
"Version": "2012-10-17",
"Statement": [
{
"Action": "sts:AssumeRole",
"Principal": {
"Federated": "cognito-identity.amazonaws.com"
},
"Effect": "Allow",
"Sid": ""
}
]
}
EOF
}

resource "aws_iam_role" "unauth_iam_role" {
name = "unauth_iam_role"
assume_role_policy = <<EOF
{
"Version": "2012-10-17",
"Statement": [
{
"Action": "sts:AssumeRole",
"Principal": {
"Federated": "cognito-identity.amazonaws.com"
},
"Effect": "Allow",
"Sid": ""
}
]
}
EOF
}

resource "aws_iam_role_policy" "web_iam_unauth_role_policy" {
name = "web_iam_unauth_role_policy"
role = "${aws_iam_role.unauth_iam_role.id}"
policy = <<EOF
{
"Version": "2012-10-17",
"Statement": [
{
"Sid": "",
"Action": "*",
"Effect": "Deny",
"Resource": "*"
}
]
}
EOF
}

关于amazon-web-services - Cognito身份池授权/未授权角色的Terraform定义,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/48451755/

26 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com