Skip to content

Official client for registering private end-point VPN servers with Encrypt.me.

License

Notifications You must be signed in to change notification settings

encryptme/private-end-points

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

38 Commits
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 

Repository files navigation

Private-end Points

A tool for registering private Encrypt.me VPN endpoints. Requires Python 3.

This is an official client of the Encrypt.me private end-points server API. It's used to register your own servers with your team account so that you can provision them as private Encrypt.me servers.

This tool is embedded within our official Docker-based image to run your own VPN end-points, but using the instructions below can be used manually.

Setup

This tool maintains a configuration file with credentials and a few other bits of state. If you run this tool as root, the default location is /etc/cloak.conf. Otherwise, it will be in ~/.cloak.conf. All commands accept an argument to override the path to the config file.

Warning

This config file will be both read and written to, so it's important to make sure the tool always has access to it. Most likely this means always running it under the same effective uid.

Register

The first step is to register your server with your team. To do this, you will need your Encrypt.me account email and password. Because teams can have multiple targets (representing subsets of your servers), you'll also need a target identifier from your team dashboard.

All parameters can be passed to the registration command, or you can let it prompt you.

cloak-server register

You can view the registration with

cloak-server info [--json]

Pass --json to see the whole server structure returned by the API; otherwise, a subset will be printed in human-readable form.

Selected properties can be updated:

cloak-server update --name new-name.example.com

Certificates

Now that the server is registered, you need to provision it. The first step is to request a server certificate:

cloak-server req --key /path/to/server-key.pem

If the given key does not exist, one will be generated for you. If it does exist, it must be an RSA key of at least 2048 bits.

If the request is sent successfully, it will appear on your team dashboard. An administrator must approve the request, entering the PKI password, if necessary. Once the request has been approved, you can download the server certificate along with all associated PKI information:

cloak-server pki --out /path/to/pki/

This will create several files:

anchor.pem
The anchor certificate for the private PKI.
server.pem
The server certificate followed by intermediates.
client_ca.pem
The intermediate that directly signs client certificates.
crl_urls.txt
A text file with URLs to any certificate revocation lists (CRLs) that we need to know about, one per line.

The response to the PKI request includes a value that we can use to detect changes, similar to an ETag. This tag is saved to our config file and sent in subsequent requests by default. To check for PKI changes, you can periodically run:

cloak-server pki --out /path/to/pki/ --post-hook cloak-pki-updated.sh

If the post-hook is executed, it most likely means that the server certificate has been renewed. The post-hook should restart or reload services for the updated certificates.

The pki command also takes a -f argument to ignore the tag and download a fresh copy of everything.

Revocation

Because CRLs are regenerated frequently, the API returns URLs rather than the contents. As a convenience, we provide a command that will check for updated CRLs in a manner similar to the pki command checking for updated certificates:

cloak-server crls --infile /path/to/crl_urls.txt --out /path/to/crls/ --post-hook cloak-crls-updated.sh

This command uses the config file to store an ETag for each URL, so you can run it frequently.

Development

To set up a development environment for this project, just create a virtualenv with any supported version of Python, cd to the root of the project, and run pip install -e ..

Run tests in a single virtualenv with python setup.py test. To test in all supported environments, install and run tox. This will also run a suite of static analysis tools to detect potential errors and style issues.

About

Official client for registering private end-point VPN servers with Encrypt.me.

Resources

License

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published

Languages