微信公众号搜"智元新知"关注
微信扫一扫可直接关注哦!

使用 AWS STS 凭证将 Json 对象重新格式化为 AWS 凭证文件

如何解决使用 AWS STS 凭证将 Json 对象重新格式化为 AWS 凭证文件

我正在为本地机器设置 AWS Code Deploy。我正在关注 this guide 并使用 STS 临时凭据。

我可以通过以下方式成功检索凭据:

aws sts assume-role --role-arn arn:aws:iam::<acct#>:role/<role-name> --role-session-name <session-name>

它们以下列格式返回:

{
    "Credentials": {
        "AccessKeyId": "*****","SecretAccessKey": "*****","SessionToken": "*****","Expiration": "2021-03-05T00:55:32Z"
    },"AssumedRoleUser": {
        "AssumedRoleId": "*****","Arn": "*****"
    }
}

我需要重新格式化为如下所示的 AWS 凭证文件

[default]
aws_access_key_id=*****
aws_secret_access_key=*****
aws_session_token=*****

如何将 json 对象重新格式化为凭据文件

解决方法

您可以使用 jqsed 在一行中检索、转换和写入文件。

aws sts assume-role --role-arn arn:aws:iam::<acct#:role/<role-name> --role-session-name <session-name> \
| jq '.Credentials' \
| jq -c '{aws_access_key_id: .AccessKeyId,aws_secret_access_key: .SecretAccessKey,aws_session_token: .SessionToken}' \
| sed -e 's/[{}]//g' -e 's/":"/=/g' -e 's/",/\n/g' -e 's/"//g' \
> <my-file-path>

版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。