Skip to main content

Centrica Chaim AWS Accounts

Project description

Centrica Chaim AWS Accounts CLI

This is the code for the command line utility cca.

cca is a re-imagining of the chaim cli using the click parameter parsing python module.

<a name='version>

Changelog

v2.5.0 Display role and region when listing managed accounts

v2.4.0 Allow receiving and passing the Slack Workspace Id in the chaim credentials requests.

Install

The chaim-cli is a python 3 application. It is recommended to install into your local, users, python packages using pip. If this is your first local python package then you will need to adjust your path so that the shell can find it.

echo 'export PATH=${HOME}/.local/bin:${PATH}' >>${HOME}/.bashrc

Linux

These instructions are for ubuntu and it's derivatives. For other distributions the process is similiar, though probably with different package names. You will need to have a version of python3 installed and a pip program that is python3 aware.

Install python3

For ubuntu pre 18.04 you will need to install python3 and it's associated pip application. The easiest way to do this is:

sudo apt install python3-pip

which will pull in everything required.

Install cca

To install the chaim-cli:

pip3 install chaim-cli --upgrade --user --no-cache-dir

Update PATH

Once installed you will want to add $HOME/.local/bin to your path, if it isn't already there:

echo 'export PATH=${HOME}/.local/bin:${PATH}' >>${HOME}/.bashrc

Testing

To check that all went well:

cca version

Should give you the current version number of the chaim-cli.

Mac OSX

Install python3

Recently the folks that manage homebrew changed the default python, which conflicts with the python supplied by the OS. See this home brew discussion. So, to get python3 (and keep python2) you now need to do:

brew upgrade python
brew install python2

which will install python3 and the latest released version of python2.

Install cca

To install the chaim-cli:

pip install chaim-cli --upgrade --user --no-cache-dir

Update PATH

Once installed you will want to add $HOME/Library/.Python/3.7/bin to your path, if it isn't already there (adjust the version to suit your circumstances):

echo 'export PATH=${HOME}/Library/Python/3.7/bin:${PATH}' >>${HOME}/.bashrc

Testing

To check that all went well:

cca version

Should give you the current version number of the chaim-cli.

Upgrade

pip3 install chaim-cli --upgrade --user

cca

$ cca --help
Usage: cca [OPTIONS] COMMAND [ARGS]...

Options:
  --help  Show this message and exit.

Commands:
  account       Retrieve credentials for an account
  delete        delete an accounts credentials
  gso           obtains a console session url, logs out of...
  gui           obtains a console session url and opens a...
  init          Initialises the application for use with...
  list          list all registered accounts and their expiry...
  listall       list all accounts available to chaim
  listpark      list of parked accounts
  park          removes account from credentials and parks it...
  renew         Renews all account credentials
  setautorenew  sets the percentage of time remaining before...
  unpark        returns an account from parking to...
  url           obtains a console session url and copies it...
  version

cca sub-commands

account

$ cca account --help
Usage: cca account [OPTIONS] ACCOUNT

  Retrieve credentials for ACCOUNT account

Options:
  -r, --role TEXT         optional the role to assume for this account
                          default: rro
  -d, --duration INTEGER  optional duration must be between 1-12 or 900-43,200
                          default 1
  -a, --alias TEXT        optional alias for the account name, to be used as
                          the profile name
  -D, --default           optional set this account to be the default account
                          profile to use
  -R, --region TEXT       optional region
  -T, --terrible          Add support for Terraform/Ansible to the credentials
                          file
  --help                  Show this message and exit.

The -T|--terrible switch copies the aws_session_token key to the aws_security_token key. This ensures that products such as Ansible and Terraform which still use the aws_security_token will continue to work.

delete

Delete credentials for the named account(s).

gui

This command generates a console session url and opens a browser window to it. The credentials will be automatically renewed first.

gso

This command generates a console session url, attempts to logout of any current session, and opens a browser window to the url. The credentials will be automatically renewed first.

Note: There doesn't seem to be any way to access the browser tab with AWS running in it, so this process first opens a new tab to issue the logout command, then a 2nd new tab to log you into the new account. This will leave you with 2 extra tabs, sorry.

init

Initialises the application with a user token obtained from Slack. Either supply the base64 encoded info from Slack as a parameter, or use the command bare to be asked the pertinent questions.

cca init YXBpPTh4eHNDczJmV4cGly...JlZ2lvbj1ldS13ZXN0LTE=
cca has been re-initialised.
Your token will expire in 29 days, 21 hours, 19 minutes and 52 seconds.

or

cca init
api (8xxssu8fs7):
username (chris.allison):
usertoken: ad2f05ed-78d7-xxxx-DDDD-8d90c64f9473
tokenexpires: 1536139015
stage (prod):
region (eu-west-1):
cca has been re-initialised.
Your token will expire in 29 days, 21 hours, 18 minutes and 58 seconds.

list

Current list of accounts that are managed by cca, the role and region and their expiry times. This also shows which is the default account, and the percentage of time left.

listall

Full list of all available accounts.

listpark

List accounts that have been parked.

$ cca listpark
hbetaus
hprodus
hprod
hbeta
hdev7

park

Remove an account from credentials and park it and its definition for later use.

$ cca park extbackup
extbackup account has been parked

renew

This will renew all managed accounts.

$ cca renew
ignoring awsbilling as it is not managed by cca
account: secadmin-prod, alias: secadmin-prod, role: apu, duration: 4
Updated section secadmin-prod with new keys
updated default account
retrieval took 5 seconds.
account: chsre-dev, alias: chsre-dev, role: apu, duration: 4
Updated section chsre-dev with new keys
retrieval took 6 seconds.

unpark

Re-enable an account and automatically renew its session so that it is available for immediate use.

$ cca unpark hdev7
account: honeycomb-dev7, alias: hdev7, role: mpu, duration: 1
Updated section honeycomb-dev7 with new keys
retrieval took 7 seconds.

url

This command generates a console session url and copies it to the clipboard. The credentials will be automatically renewed first.

version

Show the current version of this application.

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

chaim-cli-2.5.3.tar.gz (16.1 kB view details)

Uploaded Source

Built Distribution

If you're not sure about the file name format, learn more about wheel file names.

chaim_cli-2.5.3-py3-none-any.whl (27.0 kB view details)

Uploaded Python 3

File details

Details for the file chaim-cli-2.5.3.tar.gz.

File metadata

  • Download URL: chaim-cli-2.5.3.tar.gz
  • Upload date:
  • Size: 16.1 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/3.1.1 pkginfo/1.5.0.1 requests/2.22.0 setuptools/41.2.0 requests-toolbelt/0.9.1 tqdm/4.41.1 CPython/3.8.1

File hashes

Hashes for chaim-cli-2.5.3.tar.gz
Algorithm Hash digest
SHA256 b9a5367c008e1ce6f7b1db05b32d10b43805244a04d17bf2e59d463f435b2ad2
MD5 f5d2a6557fc999ddfddad62227138094
BLAKE2b-256 faa40b6eca272a35794e4ba2f99dcb93fa0873a2f57863edd77a7cd9eae5a4c7

See more details on using hashes here.

File details

Details for the file chaim_cli-2.5.3-py3-none-any.whl.

File metadata

  • Download URL: chaim_cli-2.5.3-py3-none-any.whl
  • Upload date:
  • Size: 27.0 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/3.1.1 pkginfo/1.5.0.1 requests/2.22.0 setuptools/41.2.0 requests-toolbelt/0.9.1 tqdm/4.41.1 CPython/3.8.1

File hashes

Hashes for chaim_cli-2.5.3-py3-none-any.whl
Algorithm Hash digest
SHA256 751b621d7227611f18d3797da1ede9421aa872208e75bb6af2f21111e90c0cdd
MD5 5f8c67277d604b842bf66e4a96da8c54
BLAKE2b-256 3c4223d5ebdb17e642b60dc23464eacf0cab7b5b905e44dbd1ea7c4605743d2a

See more details on using hashes here.

Supported by

AWS Cloud computing and Security Sponsor Datadog Monitoring Depot Continuous Integration Fastly CDN Google Download Analytics Pingdom Monitoring Sentry Error logging StatusPage Status page