awsx
Project description
AWS Profile Switcher Readme
Overview
The script is a handy tool to help AWS users switch between different AWS CLI profiles quickly. This can be particularly useful if you manage multiple AWS accounts or if you have different roles within an AWS account. After you've switched profiles, the script allows you to set the AWS profile in your environment variables or retrieve user details for that profile.
Features:
- List AWS CLI Profiles: Displays a list of AWS CLI profiles stored in
~/.aws/credentials
. - Switch Profile Interactively: Allows the user to select an AWS profile from a list.
- Set Environment Variable: Once a profile is chosen, the script will generate a command to set the
AWS_PROFILE
environment variable in the user's shell. This command is copied to the clipboard for easy pasting. - Display User Details: Once a profile is chosen, the script displays the User ID, ARN, Access Key, and Secret Key for the selected profile.
Instructions
- Running without parameters will directly output the default configured identity information:
awsx
- Using the
--profile
flag, the tool will prompt you to select an AWS CLI profile. If you already know the profile name you want to use, you can pass it as theprofilename
parameter:
awsx --profile
or
awsx --profile your_profilename
- Use the
--region
flag to specify the AWS region:
awsx --region us-west-1
Detailed code explanation
Here is a brief explanation of some code snippets:
get_identity()
: Get AWS identity information.get_parent_process_name()
: Gets the name of the parent process, which is used to determine whether it is running inpowershell
orcmd
.copy_env_command_to_clipboard()
: Based on the operating system and process name, generate a command to set theAWS_PROFILE
environment variable and copy it to the clipboard.list_aws_profiles()
: List all AWS CLI profiles.get_region_from_profile()
: Get the default region from the given AWS CLI profile.switch_aws_profile_interactive()
: Interactively prompts the user to select an AWS CLI profile and returns its name and default region.
The tool uses the click
library to parse command line arguments, the boto3
library to interact with AWS, the pyperclip
library to copy text to the clipboard, and several other libraries to obtain system information and read configuration document.
Features:
- List AWS CLI Profiles: Displays a list of AWS CLI profiles stored in
~/.aws/credentials
. - Switch Profile Interactively: Allows the user to select an AWS profile from a list.
- Set Environment Variable: Once a profile is chosen, the script will generate a command to set the
AWS_PROFILE
environment variable in the user's shell. This command is copied to the clipboard for easy pasting. - Display User Details: Once a profile is chosen, the script displays the User ID, ARN, Access Key, and Secret Key for the selected profile.
Notes:
- The script determines the user's operating system to generate the appropriate command to set environment variables. It supports Windows (both cmd and PowerShell), Linux, and macOS.
- If there's an issue connecting to the specified region, the script defaults to connecting to the "us-east-1" region.
Recommendations:
- Always be cautious about where and how you display AWS Access and Secret keys. Avoid logging these details or exposing them to unintended audiences.
- It's advisable to have a backup of your AWS CLI configuration files (
~/.aws/credentials
and~/.aws/config
) before using any scripts or tools that modify or interact with them.
Feedback and Contributions:
Please raise any issues or suggestions on the repository or contact the maintainers directly. Contributions to enhance the script or fix any bugs are always welcome!
Project details
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
File details
Details for the file awsx-2.0.0.tar.gz
.
File metadata
- Download URL: awsx-2.0.0.tar.gz
- Upload date:
- Size: 5.0 kB
- Tags: Source
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/4.0.2 CPython/3.9.18
File hashes
Algorithm | Hash digest | |
---|---|---|
SHA256 | cd1995559b9b27b7b07f744161b959ff0db6d2d65ee8e68c3d1700fb28619222 |
|
MD5 | 33879f7fc94fc66423237bc44ef55916 |
|
BLAKE2b-256 | 72559f657b026f9e9663098747ee367a62ae3c2b649a04546446deb637ffadd6 |
File details
Details for the file awsx-2.0.0-py3-none-any.whl
.
File metadata
- Download URL: awsx-2.0.0-py3-none-any.whl
- Upload date:
- Size: 5.6 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/4.0.2 CPython/3.9.18
File hashes
Algorithm | Hash digest | |
---|---|---|
SHA256 | a166a135f47eee59e1f0828768f044cefca5ab0e13da6323536e43c231274a01 |
|
MD5 | c4993612d090fdd6f57edb3658bedb50 |
|
BLAKE2b-256 | 667f896f6550d620e9df0f969cf961074737c8e2c53cefb4b23dc594ac7ea4ee |