A wrapper for executing a command with AWS CLI v2 and SSO
Project description
aws2-wrap
This is a simple script to make it easier to use AWS Single Sign On credentials with tools that don't understand the sso
entries in an AWS profile.
The script provides the following capabilities:
- Running a specified command with the retrieved AWS SSO credentials.
- Exporting the AWS SSO credentials.
- Supporting
credential_process
within an AWS profile - Supporting assuming roles within an AWS profile
Please note that the script is called aws2-wrap
to show that it works with AWS CLI v2, even though the CLI tool is no longer called aws2
.
Install using pip
https://pypi.org/project/aws2-wrap
pip install aws2-wrap==1.1.0
Run a command using AWS SSO credentials
aws2-wrap [--profile <awsprofilename>] [--exec] <command>
Note that if you are using --exec
and <command>
contains spaces, it must be surrouned with double-quotation marks.
You can also specify the profile to be used via AWS_PROFILE which then allows the same profile to be used by subsequent tools and commands.
Examples:
aws2-wrap --profile MySSOProfile terraform plan
aws2-wrap --profile MySSOProfile --exec "terraform plan"
AWS_PROFILE=MySSOProfile aws2-wrap terraform plan
Export the credentials
There may be circumstances when it is easier/better to set the appropriate environment variables so that they can be re-used by any aws
command.
Since the script cannot directly set the environment variables in the calling shell process, it is necessary to use the following syntax:
eval "$(aws2-wrap [--profile <awsprofilename>] --export)"
For example:
eval "$(aws2-wrap --profile MySSOProfile --export)"
Assuming a role via AWS SSO
Your .aws/config
file can look like this:
[default]
sso_start_url = xxxxxxxxxxxx
sso_region = us-west-2
sso_account_id = xxxxxxxxxxxx
sso_role_name = SSORoleName
[profile account1]
role_arn = arn:aws:iam::xxxxxxxxxxxx:role/role-to-be-assumed
source_profile = default
region = ap-northeast-1
allowing you to then run:
aws2-wrap --profile account1 <command>
and <command>
will be run under role-to-be-assumed
.
Use the credentials via .aws/config
If you are using a tool that works with normal AWS credentials but doesn't understand the new AWS SSO credentials, another option is to add a profile to .aws/config
that calls the aws2-wrap
script.
For example, add the following block to .aws/config
:
[profile Wrapped]
credential_process = aws2-wrap --process --profile <awsprofilename>
then, after authentication, you can run any command that uses AWS credentials by specifying the "Wrapped" profile:
aws sso login --profile <awsprofilename>
export AWS_PROFILE=Wrapped
export AWS_SDK_LOAD_CONFIG=1
terraform plan
Note that because the profile is being specified via AWS_PROFILE
, it is sometimes necessary (as shown above) to set AWS_SDK_LOAD_CONFIG
in order to get tools like terraform
to successfully retrieve the credentials.
Credits
Thanks to @flyinprogrammer, @abeluck, @topu, @bigwheel, @krabbit, @jscook2345, @hieki, @blazdivjak and @fukushun1994 for their contributions.
Project details
Release history Release notifications | RSS feed
Download files
Download the file for your platform. If you're not sure which to choose, learn more about installing packages.
Source Distribution
Built Distribution
Hashes for aws2_wrap-1.1.0-py3-none-any.whl
Algorithm | Hash digest | |
---|---|---|
SHA256 | 723ad859f8176c6ac5025828c97e5ad3c8d63bbe7e5ce5181e5693216ed6d5b5 |
|
MD5 | c9db82c18928811fa09a667c29c4ba16 |
|
BLAKE2b-256 | f2d389867f6fb7aa2c9ef80de1944cdd5d04689f3f1d82fb5accc5da5420d22a |