AWS CLI profile switcher with MFA support
// npm
npm install -g awsx
// yarn
yarn global add awsx
Add the following to your .bash_profile
or .bashrc
:
alias awsx="source _awsx"
Reload your profile by launching a new shell or running source ~/.bash_profile
.
// npm
npm install -g awsx
// yarn
yarn global upgrade awsx --latest
If you don't specify a profile name (or an assume role profile name, if applicable) you will be prompted to choose from one of your existing profiles. If the selected profile has MFA enabled and you want to force a new MFA login use the --force-mfa
flag.
awsx add-profile [profile] [access-key] [secret-key] [key-max-age] [default-region] [output-format] [mfa-arn] [mfa-expiry]
NOTE: If you don't provide inputs you will be prompted for them.
You can find your MFA ARN by logging into the AWS Console, clicking on your name in the menu and then clicking on "My Security Credentials". Under the "Multi-factor authentication (MFA)" section there should be an "Assigned MFA device" heading. The string below that that starts with arn:aws:iam::
is your MFA ARN.
If you don't have MFA set up on your AWS account you can enable it by following these instructions.
NOTE: use 0 days for no maximum age
If you'd like to contribute to awsx we recommend that you first open an issue to discuss your proposed change.
- Fork this repo
- Clone the forked repo
- Install dependencies:
npm install
To clean the build directory run npm run clean
- Update the version in
package.json
- Add a
CHANGELOG
entry - Commit your changes
- Run
npm pack --dry-run
to see what will be published - Run
npm publish
- Create a release on GitHub. Use the version as the tag and release name. For example for version
1.0.0
the tag and release name would bev1.0.0
.
This project was inspired by awsp