AWSSecretsManager无法设置权限。
创始人
2024-09-27 05:30:37
0

可能会出现不能设置AWS Secrets Manager中的权限的情况。以下是一个示例代码,说明如何解决这个问题:

import boto3
from botocore.exceptions import ClientError

def add_secret_permissions(secret_name, role_name, region_name, permission):
    """
    Adds permission to a secret for a specific AWS IAM role.

    :param secret_name: The name of the secret.
    :param role_name: The name of the AWS IAM role to grant access to the secret.
    :param region_name: The AWS region where the secret is stored.
    :param permission: The permission to grant. Can be 'ReadWrite' or 'ReadOnly'.
    :return: True if permission was granted, False otherwise.
    """

    # Create a new Secrets Manager client
    client = boto3.client('secretsmanager', region_name=region_name)

    # Define the policy to grant permission to the specified role
    policy = {
        "Version": "2012-10-17",
        "Statement": [
            {
                "Effect": "Allow",
                "Action": [
                    "secretsmanager:GetResourcePolicy",
                    "secretsmanager:GetSecretValue",
                    "secretsmanager:DescribeSecret",
                    "secretsmanager:ListSecretVersionIds"
                ],
                "Resource": "*"
            },
            {
                "Effect": "Allow",
                "Action": [
                    "secretsmanager:GetSecretValue"
                ],
                "Resource": "*",
                "Condition": {
                    "ForAnyValue:StringEquals": {
                        "secretsmanager:VersionStage": [
                            "AWSCURRENT",
                        ]
                    }
                }
            }
        ]
    }

    # Grant permission based on the specified type
    if permission == 'ReadWrite':
        try:
            response = client.put_secret_policy(
                SecretId=secret_name,
                ResourcePolicy=policy,
                BlockPublicPolicy=True
            )
        except ClientError as e:
            print("Error occurred while adding secret permission: ", e)
            return False
    elif permission == 'ReadOnly':
        try:
            response = client.add_resource_permission(
                SecretId=secret_name,
                Principal=role_name,
                ResourcePolicy=policy,
                BlockPublicPolicy=True,
                SecretPermission='ReadOnly'
            )

相关内容

热门资讯

第八分钟技法!智星德州插件最新... 第八分钟技法!智星德州插件最新版本更新内容详解(透视)真是是真的有辅助脚本(哔哩哔哩)1、这是跨平台...
第九分钟学习!epoker免费... 第九分钟学习!epoker免费透视脚本(透视)竟然真的有辅助脚本(哔哩哔哩)1、金币登录送、破产送、...
六分钟手筋!pokemmo免费... 六分钟手筋!pokemmo免费脚本(透视)确实是有辅助下载(哔哩哔哩)1、进入到pokemmo免费脚...
第二分钟举措!pokerrrr... 第二分钟举措!pokerrrr2辅助(透视)本来真的是有辅助脚本(哔哩哔哩)1、点击下载安装,pok...
第八分钟积累!wejoker辅... 第八分钟积累!wejoker辅助软件价格(透视)一贯真的有辅助安装(哔哩哔哩)wejoker辅助软件...
一分钟方针!wepoker国外... 一分钟方针!wepoker国外版透视(透视)原来是有辅助下载(哔哩哔哩)1、游戏颠覆性的策略玩法,独...
第8分钟窍门!pokemmo脚... 第8分钟窍门!pokemmo脚本辅助(透视)原来真的是有辅助教程(哔哩哔哩)进入游戏-大厅左侧-新手...
六分钟要领!pokernow辅... 六分钟要领!pokernow辅助控制(透视)果然是有辅助工具(哔哩哔哩)1)pokernow辅助控制...
八分钟演示!大菠萝手游辅助(透... 八分钟演示!大菠萝手游辅助(透视)竟然真的有辅助脚本(哔哩哔哩)亲,关键说明,大菠萝手游辅助透视脚本...
9分钟秘籍!wpk真的有透视嘛... 9分钟秘籍!wpk真的有透视嘛(透视)都是真的有辅助辅助(哔哩哔哩)1、完成wpk真的有透视嘛辅助器...