Skip to main content

A minimal utility for managing cli authentication with openstack more securely and conveniently

Project description

os-mfa

Convenient and secure OpenStack authentication and credential management inspired by broamski/aws-mfa

What problem does os-mfa solve?

First some quick background. OpenStack provides two main methods of setting credentials for programmatic authentication:

A) Environment variables set via 'openrc.sh' files

  • ๐Ÿ›ก๏ธ Avoids storing passwords in plaintext on disk ๐Ÿ‘
  • ๐Ÿคฆ Session credentials are lost if you close or restart your terminal window ๐Ÿ‘Ž
  • ๐Ÿ”’ Sessions can't be shared/accessed across multiple terminal sessions ๐Ÿ‘Ž
  • ๐Ÿ’” Not compatible with windows clients ๐Ÿ‘Ž

B) clouds.yaml configuration files

  • ๐Ÿ’ช Session tokens are durable to terminal restarts/shutdowns ๐Ÿ‘
  • ๐Ÿ’— Compatible and consistent user experience across platforms ๐Ÿ‘
  • ๐ŸŒ OpenStack sessions are accessible in from any terminal session ๐Ÿ‘
  • ๐Ÿ™ˆ Encourages credentials to be stored in plain text ๐Ÿ‘Ž
  • โŒ› Tokens that expire after 12 hours need to be manually refreshed and updated in clouds.yaml ๐Ÿ‘Ž

As we can see both have advantages and disadvantages. But what if we could have the best parts of both options?

๐ŸŒˆ os-mfa ๐Ÿฆ„ leverages the convenience and durability of using clouds.yaml and automates the secure management of credentials and tokens

  • ๐Ÿ›ก๏ธ Avoids storing passwords in plaintext on disk ๐Ÿ‘
  • ๐Ÿ’ช Session tokens are durable to terminal restarts/shutdowns ๐Ÿ‘
  • ๐Ÿ’— Compatible and consistent user experience across platforms ๐Ÿ‘
  • ๐ŸŒ OpenStack sessions are accessible in from any terminal session ๐Ÿ‘
  • ๐Ÿ”€ Trivially switch between multiple authenticated OpenStack sessions ๐Ÿ‘
  • ๐Ÿค Ensured compatibility with the OpenStack ecosystem ๐Ÿ‘

Quick start

Install os-mfa

pip install -U os-mfa

Download clouds.yaml file from your OpenStack dashboard. For example

  1. Click API Access from the top left of the dashboard
  2. Click Download OpenStack RC File on the top right
  3. Select OpenStack clouds.yaml File from the drop down

Place the file in your current working directory (.) or an alternate location described by the docs

Linux

  • ~/.config/openstack/clouds.yaml
  • /etc/openstack/clouds.yaml

Windows

  • C:\Users\<username>\.config\openstack\clouds.yaml
  • C:\ProgramData\openstack\clouds.yaml

E.g.

# /home/john/clouds.yaml
clouds:
  catalystcloud:
    auth:
      auth_url: https://api.nz-hlz-1.catalystcloud.io:5000
      project_id: 33735662374f4b7a9621631f2e7e5e15
      project_name: acme-incorporated
      user_domain_name: Default
      username: john.smith@acme.com
      password: 1ns3curE123!
    identity_api_version: 3
    interface: public
    region_name: nz-hlz-1

Set $OS_CLOUD in your environment.

$ export OS_CLOUD=catalystcloud

Run os-mfa

$ os-mfa
Authenticating 'john.smith@example.com' in project 'john-smith'
Enter Password:
MFA Code (Press enter to skip): 654321
Getting token...
$ openstack network list
+--------------------------------------+------------+--------------------------------------------+
| ID                                   | Name       | Subnets                                    |
+--------------------------------------+------------+--------------------------------------------+
| f10ad6de-a26d-4c29-8c64-2a7418d47f8f | public-net | 5063aab1-aa08-48b2-b81d-730ac732fc51,      |
|                                      |            | 8a7fe804-7fbe-43d0-aa1d-cfa03034ef22,      |
|                                      |            | a1549e09-4176-4322-860c-cadc68608b48       |
+--------------------------------------+------------+--------------------------------------------+

Now if you close/restart or start a new terminal window, resume your existing OpenStack session simply by exporting $OS_CLOUD again.

export OS_CLOUD=catalystcloud

What happened when we ran os-mfa?

The first time we run os-mfa is creates a "long-term" configuration in our clouds.yaml without any passwords or secrets.

Long term configurations contain the minimum information required for os-mfa to use to initialize a token based authentication.

  • They should not contain any secrets such as tokens or passwords.
  • They are distinguished by a suffix of -long-term

os-mfa will then use the -long-term configuration to create a token based configuration as follows.

  1. Prompts the user for their password and MFA code
  2. Swaps the password and MFA code for an OpenStack auth token
  3. Updates the original configuration to use the new token for authentication

The resulting clouds.yaml should look like this

# /home/john/clouds.yaml
clouds:
  catalystcloud:
    auth:
      auth_url: https://api.nz-hlz-1.catalystcloud.io:5000
      project_id: 33735662374f4b7a9621631f2e7e5e15
      project_name: acme-incorporated
      token: gAAAAABkTkGx4Dah37lkiGTSEe3-r[...]9dQCVTBRsKjg6NFIYgMYRdAk7TTvIPOaaOE
    identity_api_version: 3
    interface: public
    region_name: nz-hlz-1
  catalystcloud-long-term:
    auth:
      auth_url: https://api.nz-hlz-1.catalystcloud.io:5000
      project_id: 33735662374f4b7a9621631f2e7e5e15
      project_name: acme-incorporated
      user_domain_name: Default
      username: john.smith@acme.com
    identity_api_version: 3
    interface: public
    region_name: nz-hlz-1

Going further

Multiple projects, users and sessions

Since clouds.yaml supports multiple configurations, you can create configurations for any combination of

  • user
  • project
  • region
  • openstack cloud
clouds:
  project1:
    region: nz-hlz-1
    auth:
        project_name: project1
        username: john.smith@acme.com
        # ...
  project2:
    region: nz-por-1
    auth:
        project_name: project2
        username: john.smith@acme.com
        # ...

After initializing a token based authentication for each configuration using os-mfa, you can change between sessions at will

OS_CLOUD=project1
OS_CLOUD=project2

Contributing

Nothing special to report, just raise a PR

Run tests

python -m unittest discover

Building Package

Source: https://realpython.com/pypi-publish-python-package/

python -m pip install pip-tools twine
pip-compile pyproject.toml
rm -rf dist/*
python -m build
twine check dist/*
twine upload -r testpypi dist/*
twine upload dist/*

TODO

  • โ˜‘๏ธ TBH I am probably going to port this back to python
  • โ˜‘๏ธ Alert if no clouds.yaml found
  • โ˜‘๏ธ Better error message if OS_CLOUD not set
  • ๐ŸŸฆ CI/CD
  • ๐ŸŸฆ Optionally disable prompt for MFA token
  • ๐ŸŸฆ Store and check expiry of token
  • ๐ŸŸฆ Only reauthenticate if token is not valid
  • ๐ŸŸฆ -f, --force cli option to force authentication
  • ๐ŸŸฆ more unit and integration tests

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

os-mfa-0.4.2.tar.gz (8.7 kB view hashes)

Uploaded Source

Built Distribution

os_mfa-0.4.2-py3-none-any.whl (8.6 kB view hashes)

Uploaded Python 3

Supported by

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