An aws-adfs spinoff that fits BYU's needs
Project description
Python script for CLI and SDK access to AWS via ADFS while requiring MFA access using https://duo.com/
Installation
Install Python 3.x using your preferred method.
See https://www.python.org/downloads/ for a windows installation method.
In linux you may be able to use apt, rpm or https://www.python.org/downloads/.
In Mac you can use homebrew, macports or https://www.python.org/downloads/.
Run pip3 install byu-awslogin
Usage
Run awslogin and it will prompt you for the AWS account and role to use.
Run awslogin --account <account name> --role <role name> to skip the prompting for account and name. You could specify just one of the arcuments as well.
Deploying changes
Make sure you have python 3 installed.
awslogin only works with python 3.
Enter your virtualenv using python 3.
Install twine by running pip install twine
Make sure you have a ‘~/.pypirc’ as defined here. See Paul for the login credentials.
Run python deploy.py
TODO
gracefully handle the error case when the duo push is rejected
Add support for profiles
Authenticate once for 8 hours and rerun awslogin to relogin
Simplify the adfs authentication code
cache netid after subsequent logins ie default to last used
Write tests
(David) adfs_auth.py
(Nate) index.py
roles.py
assume_role.py
Make a handel-codepipeline CI/CD pipeline with automated tests. If they pass automatically deploy to pypi.
[BUG] README.md and LICENSE get left over in /usr/local when pip install to mac
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 byu_awslogin-0.9.8-py3-none-any.whl
Algorithm | Hash digest | |
---|---|---|
SHA256 | d35d3ddd795c824ff57c511e93baacf23fb44c1714e6b6e18b29f46c46145041 |
|
MD5 | 24898d218d2f90124c8b206f3adeb1cc |
|
BLAKE2b-256 | 858b7e4b0962200e4cd71e8373b64b7e5debe86a060c038563dbf984d6d16f6f |