Skip to content

Latest commit

 

History

History
93 lines (64 loc) · 3.62 KB

aws-vault.md

File metadata and controls

93 lines (64 loc) · 3.62 KB

aws-vault

aws-vault

  • stores AWS credentials securely in the macOS keychain rather than in plaintext on disk
  • caches your GetSessionToken credentials so you don't need to repeatedly enter an MFA token
  • can assume roles using short-term (STS) credentials
  • provides easy AWS access key rotation (no need to login to the console)
  • can open a browser tab and sign you into the AWS console
  • provides terminal and graphical prompts (useful when called from vscode) for MFA tokens
  • supports role session names (makes it easier to audit API calls in CloudTrail)

aws-vault exec and aws-vault login will fetch an STS session token on each invocation. By default the session token lasts for 15 mins. When it expires you'll need to rerun aws-vault exec. You can extend this with the --assume-role-ttl flag or the AWS_ASSUME_ROLE_TTL environment variable, eg: export AWS_ASSUME_ROLE_TTL=1h.

By default the aws-vault MFA session lasts for 4 hours. When it expires you'll need re-enter your MFA code.

aws-vault login uses a federation token to login to the web console. A federation token is a typically longer-lived, and older style of token. You can only log into one account at a time. Logging in to a second account will log you out of the first.

By default aws-vault will use stdin/stdout for the MFA token prompt. Use --prompt=osascript to show a macOS window prompt instead.

To store your default profile access key in the aws-vault keychain:

aws-vault add default

To delete existing creds (eg: when the access key expires)

aws-vault remove default

To assume a role

aws-vault exec role -- aws sts get-caller-identity

To use session tags when assuming a role add them to AWS config:

[profile order-dev]
source_profile = root
role_arn=arn:aws:iam::123456789:role/developers
session_tags = key1=value1,key2=value2,key3=value3
transitive_session_tags = key1,key2

To specify the role session name, use env var AWS_ROLE_SESSION_NAME or add it to the AWS config:

[profile order-dev]
source_profile = root
role_arn=arn:aws:iam::123456789:role/developers
session_tags = key1=value1,key2=value2,key3=value3
role_session_name = alice@developers.com

To extract and set env vars in the current shell

aws_vault_export() {
   aws-vault exec $1 -- env | grep AWS | sed -e 's/^/export\ /'
}

Then eval "$(aws_vault_export profile1)" (ref).

aws-vault can also be used as a credential process. This inverts the call stack so that aws-cli calls aws-vault when it needs credentials rather than setting them first using aws-vault.

By default the macOS keychain password prompt will appear after 5 minutes of inactivity. This can be changed.

To extract your access keys (from the default profile):

aws-vault exec -j default --no-session

To rotate your access keys:

aws-vault rotate default

To open a browser tab and sign you into the AWS console (using a federated token). Note, existing sessions will be logged out:

aws-vault login <profile>

Troubleshooting

AccessDenied when assuming a role: check the ARN in ~/.aws/config is correctly formed.