Skip to main content

A short-lived certificate tool based on the Zero Trust network mode

Project description

Mutual TLS Client (mtls)

Known Vulnerabilities CircleCI PyPI AUR version

Runtime Dependencies

  • python >= 3.7
  • gnupg2
  • libnss3 (linux/windows)
  • security (MacOS)

Overview

A mutual TLS (mTLS) system for authenticating users to services that need to be on the internet, but should only be accessible to users that specifically need it. This should be used as a initial security measure on top of normal login to handle multi-factor authentication.

The client generates a Certificate Signing Request (CSR) and use web of trust to ensure user has authentication to recieve a short-lived client certificate. Short-lived certificates have a default timeout of 18 hours, but can be expanded per need.

This system uses some of the base NSS primitives found in base tools for the associted operating systems.

This project currently works in the following OSes:

  • Linux (Arch/Debian/Ubuntu tested)
  • MacOS

This project is based on the whitepapers for Beyond Corp, which is Googles Zero Trust Security Model.

Background

What is Mutual TLS?

Mutual TLS is a sub-category of Mutual Authentication, where the client and server, or server and server are verifying the identity of one another to ensure that both parties should be allowed to access the requested information.

What is this Good For?

Creating services that inheritely trust no one unless specifically authorized. This provides the basis for a zero trust, multi-factor authentication scheme while also timeboxing access to the requested service in case of compromise or loss of access keys.

What parts of my system are affected by this?

This uses 2 certificate stores within your system. The primary is held at ~/.pki/nssdb which is the default nssdb that most of the OS trusts. A secondary nssdb will exist within .mozilla/firefox/ which is a firefox specific nssdb and is required to interface with any mozilla products. There are slightly different commands that are required depending on the operating system.

To list certificates via the commandline on Linux: certutil -L -d ~/.pki/nssdb

To verify a certificate via the commandline on Linux: certutil -V -u C -d ~/.pki/nssdb -n '<Server> - <name>@<host>'

A Root certificate is required for this. The CLI will by default pull the Root CA and install it into your Trust Store as a Trusted Root Certificate.

Installation

Building From Source

$ git clone https://github.com/drGrove/mtls-cli
$ make build
# If you'd like to install directly into ~/.local/bin you can also use
$ make install

Using The Latest Release

There are signed binaries that are shipped along with each release. To use a binary you can do the following:

$ VERSION=<version> (ex. VERSION=v0.8.0)
$ wget https://github.com/drGrove/mtls-cli/releases/download/$VERSION/mtls-$VERSION.tar.gz
$ tar zxvf mtls-$VERSION.tar.gz
$ cd mtls
$ sha256sum mtls && cat mtls.sha256sum
$ gpg --recv-keys C92FE5A3FBD58DD3EC5AA26BB10116B8193F2DBD
$ gpg --verify --trust-model always mtls.sig
# From there you can install the binary wherever you'd like in your path

Configuration

Configuring mtls is done via a config.ini. There is an example in the repo here.

You'll need a similar base configuration:

[DEFAULT]
name=John Doe
email=johndoe@example.com
; PGP Fingerprint
fingerprint=XXXXXXXX
country=US
state=CA
locality=Mountain View
organization=myhost

Then for each server you'd like to connect to you can create a section for that service.

[myserver]
email=johndoe@myserver.com
url=https://certauth.myserver.com

The url should match the base URL of the Certificate Authority you'll connect to. This will allow mtls to make the requests to generate your client certificate.

Usage

Once configured and provided access by a Certificate Authority Administrator you will be able to begin creating certificates for yourself. By default the lifetime of your certificate is 18 hours. But Certificate Authorities are able to set their own minimum and maximum lifetime. Speak to a certificate authority administrator about their settings.

Creating A Certificate

$ mtls -s myserver certificate create

Revoking A Certificate

If you're certificate has become compromised you can revoke your certificate prior to it's expiration. Certificate Authority Administrators can also expire certificates if they feel that you've been compromised or if they belive you should no longer have access to the services.

You have a few options as far a certificate revoke goes.

By Serial Number

$ mtls -s myserver certificate revoke --serial <Certificate Serial Number>

By Certificate Name

To get a certificate name, it will follow the following convention: ISSUER - USER@HOSTNAME. On the first connection to a Certificate Authority, you're ~/.config/mtls/config.ini for a particular server will be updated to provide the issuer name as found in the Root CA Certificate. You can also find this by running certutil -L -d ~/.pki/nssdb or viewing the certificate in chrome or firefox

$ mtls -s myserver certicate revoke --name <name>

By Fingerprint

NOTE: This will revoke all certificates related to a particular fingerprint

$ mtls -s myserver certificate revoke --fingerprint <fingerprint>

Administration

Administration of the mtls can be done via the CLI as well. Administrators can add and remove users as they see fit but currently an administator needs to be removed individually from both trust stores.

Users

Adding Users

By Fingerprint
$ mtls -s myserver user add --fingeprint FINGERPRINT
By Email

This will poll pgp.mit.edu by default and return a list of PGP keys if more than 1 valid PGP key is returned. You can query any keyserver via the --keyserver KEYSERVER_URL flag

$ mtls -s myserver user add --email johndoe@example.com

Removing Users

By Fingerprint
$ mtls -s myserver user remove --fingeprint FINGERPRINT
By Email

This will poll pgp.mit.edu by default and return a list of PGP keys if more than 1 valid PGP key is returned. You can query any keyserver via the --keyserver KEYSERVER_URL flag

$ mtls -s myserver user remove --email johndoe@example.com

Administrators

Adding Admins

By Fingerprint
$ mtls -s myserver user add --fingeprint FINGERPRINT --admin
By Email

This will poll pgp.mit.edu by default and return a list of PGP keys if more than 1 valid PGP key is returned. You can query any keyserver via the --keyserver KEYSERVER_URL flag

$ mtls -s myserver user add --email johndoe@example.com --admin

Removing Users

By Fingerprint
$ mtls -s myserver user remove --fingeprint FINGERPRINT --admin
By Email

This will poll pgp.mit.edu by default and return a list of PGP keys if more than 1 valid PGP key is returned. You can query any keyserver via the --keyserver KEYSERVER_URL flag

$ mtls -s myserver user remove --email johndoe@example.com --admin

Development

Dependencies

  • make
  • pip
  • pipenv
  • gnupg
  • libnss (certutil/pk12util on linux/windows, security on MacOS)

Getting Started

To begin development run the following commands:

make setup
mkdir ~/.config/mtls
cp config.ini.example config.ini

NOTE: You will need to add a server to communicate with. The URL must have a scheme.

You can run without compiling by using:

make run SERVICE=myservice

To build a binary:

make build

NOTE: This will output to an mtls folder within the root of the project. This folder has been gitignored and only artifacts of the build belong in this directory

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

mtls-0.14.2.tar.gz (333.0 kB view details)

Uploaded Source

Built Distribution

mtls-0.14.2-py3-none-any.whl (308.6 kB view details)

Uploaded Python 3

File details

Details for the file mtls-0.14.2.tar.gz.

File metadata

  • Download URL: mtls-0.14.2.tar.gz
  • Upload date:
  • Size: 333.0 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/3.2.0 pkginfo/1.6.0 requests/2.24.0 setuptools/50.3.2 requests-toolbelt/0.9.1 tqdm/4.50.2 CPython/3.8.6

File hashes

Hashes for mtls-0.14.2.tar.gz
Algorithm Hash digest
SHA256 be8e53ff04b1d47e2a28369bee668da6886cceea035e82d1f4cd2fc5e008f20b
MD5 9b4da4a0c362d6a3f1c5724aebc4191e
BLAKE2b-256 1939ff5131748c2e6d6eceef12dafa3de0502fb23b9647a0fcc67470c43c7bca

See more details on using hashes here.

File details

Details for the file mtls-0.14.2-py3-none-any.whl.

File metadata

  • Download URL: mtls-0.14.2-py3-none-any.whl
  • Upload date:
  • Size: 308.6 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/3.2.0 pkginfo/1.6.0 requests/2.24.0 setuptools/50.3.2 requests-toolbelt/0.9.1 tqdm/4.50.2 CPython/3.8.6

File hashes

Hashes for mtls-0.14.2-py3-none-any.whl
Algorithm Hash digest
SHA256 366969c80147c5398a70c0db26b8bace68452acb88431c0efcae72ea45a44bb7
MD5 0f6064b5d0e603de8f69b9d6871bd4aa
BLAKE2b-256 d5ede0f1b969a2a8f34f566c67de9c7d61308ea5e18817656a666b7a52221a87

See more details on using hashes here.

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