2015-05-11 17:32:58 +00:00
# Advanced Client Management
2015-03-12 23:32:40 +00:00
2015-05-11 17:32:58 +00:00
## Client Configuration Mode
2015-03-12 23:32:40 +00:00
2015-03-14 12:22:28 +00:00
The [`ovpn_getclient` ](/bin/ovpn_getclient ) can produce two different versions of the configuration.
2015-03-12 23:32:40 +00:00
2015-03-14 12:22:28 +00:00
1. combined (default): All needed configuration and cryptographic material is in one file (Use "combined-save" to write the configuration file in the same path as the separated parameter does).
2015-03-12 23:32:40 +00:00
2. separated: Separated files.
2015-03-13 01:00:04 +00:00
Note that some client software might be picky about which configuration format it accepts.
2015-03-12 23:32:40 +00:00
2016-05-11 22:35:00 +00:00
## Client List
2016-12-31 06:34:01 +00:00
See an overview of the configured clients, including revocation status:
2016-05-11 22:35:00 +00:00
2016-09-03 23:08:49 +00:00
docker run --rm -it -v $OVPN_DATA:/etc/openvpn kylemanna/openvpn ovpn_listclients
2016-05-11 22:35:00 +00:00
2015-05-11 17:32:58 +00:00
## Batch Mode
2015-03-12 23:32:40 +00:00
2015-03-14 12:22:28 +00:00
If you have more than a few clients, you will want to generate and update your client configuration in batch. For this task the script [`ovpn_getclient_all` ](/bin/ovpn_getclient_all ) was written, which writes out the configuration for each client to a separate directory called `clients/$cn` .
2015-03-12 23:32:40 +00:00
Execute the following to generate the configuration for all clients:
2016-09-03 23:08:49 +00:00
docker run --rm -it -v $OVPN_DATA:/etc/openvpn --volume /tmp/openvpn_clients:/etc/openvpn/clients kylemanna/openvpn ovpn_getclient_all
2015-03-12 23:32:40 +00:00
After doing so, you will find the following files in each of the `$cn` directories:
ca.crt
2015-03-14 12:22:28 +00:00
$cn-combined.ovpn # Combined configuration file format. If your client recognices this file then only this file is needed.
2015-03-12 23:32:40 +00:00
$cn.ovpn # Separated configuration. This configuration file requires the other files ca.crt dh.pem $cn.crt $cn.key ta.key
$cn.crt
$cn.key
ta.key
2015-05-11 17:33:56 +00:00
## Revoking Client Certificates
Revoke `client1` 's certificate and generate the certificate revocation list (CRL):
2016-09-03 23:08:49 +00:00
docker run --rm -it -v $OVPN_DATA:/etc/openvpn kylemanna/openvpn easyrsa revoke client1
docker run --rm -it -v $OVPN_DATA:/etc/openvpn kylemanna/openvpn easyrsa gen-crl
2015-05-11 17:33:56 +00:00
2015-08-25 10:40:02 +00:00
The OpenVPN server will read this change every time a client connects (no need to restart server) and deny clients access using revoked certificates.