mirror of
https://github.com/SnowMB/traefik-certificate-extractor.git
synced 2025-04-03 18:49:30 +08:00
Compare commits
6 Commits
Author | SHA1 | Date | |
---|---|---|---|
|
0f4cab45f2 | ||
|
55c8204f42 | ||
|
39c7664bd6 | ||
|
5cf49be470 | ||
|
c82fdb9c5c | ||
|
f9cb61f645 |
@ -15,4 +15,4 @@ RUN pip3 install -r requirements.txt
|
||||
COPY . /app
|
||||
|
||||
# Define entrypoint of the app
|
||||
ENTRYPOINT ["python3", "-u", "extractor.py"]
|
||||
ENTRYPOINT ["python3", "-u", "extractor.py", "-c", "data/acme.json", "-d", "certs"]
|
||||
|
48
README.md
48
README.md
@ -5,31 +5,65 @@ Forked from [DanielHuisman/traefik-certificate-extractor](https://github.com/Dan
|
||||
Tool to extract Let's Encrypt certificates from Traefik's ACME storage file. Can automatically restart containers using the docker API.
|
||||
|
||||
## Installation
|
||||
```
|
||||
```shell
|
||||
git clone https://github.com/snowmb/traefik-certificate-extractor
|
||||
cd traefik-certificate-extractor
|
||||
```
|
||||
|
||||
## Usage
|
||||
```
|
||||
python3 extractor.py [FILE]
|
||||
```shell
|
||||
usage: extractor.py [-h] [-c CERTIFICATE] [-d DIRECTORY] [-f] [-r] [--dry-run]
|
||||
[--include [INCLUDE [INCLUDE ...]] | --exclude
|
||||
[EXCLUDE [EXCLUDE ...]]]
|
||||
|
||||
Extract traefik letsencrypt certificates.
|
||||
|
||||
optional arguments:
|
||||
-h, --help show this help message and exit
|
||||
-c CERTIFICATE, --certificate CERTIFICATE
|
||||
file that contains the traefik certificates (default
|
||||
acme.json)
|
||||
-d DIRECTORY, --directory DIRECTORY
|
||||
output folder
|
||||
-f, --flat outputs all certificates into one folder
|
||||
-r, --restart_container
|
||||
uses the docker API to restart containers that are
|
||||
labeled accordingly
|
||||
--dry-run Don't write files and do not start docker containers.
|
||||
--include [INCLUDE [INCLUDE ...]]
|
||||
--exclude [EXCLUDE [EXCLUDE ...]]
|
||||
```
|
||||
Default file is `./data/acme.json`. The output directories are `./certs` and `./certs_flat`.
|
||||
|
||||
## Docker
|
||||
There is a Docker image available for this tool: [snowmb/traefik-certificate-extractor](https://hub.docker.com/r/snowmb/traefik-certificate-extractor/).
|
||||
Example run:
|
||||
```
|
||||
```shell
|
||||
docker run --name extractor -d \
|
||||
-v /opt/traefik:/app/data \
|
||||
-v ./certs:/app/certs \
|
||||
-v /var/run/docker.socket:/var/run/docker.socket \
|
||||
snowmb/traefik-certificate-extractor
|
||||
-v /var/run/docker.socket:/var/run/docker.sock \
|
||||
snowmb/traefik-certificate-extractor -r
|
||||
```
|
||||
Mount the whole folder containing the traefik certificate file as `/app/data`. The extracted certificates are going to be written to `/app/certs`.
|
||||
Mount the whole folder containing the traefik certificate file (`acme.json`) as `/app/data`. The extracted certificates are going to be written to `/app/certs`.
|
||||
The docker socket is used to find any containers with this label: `com.github.SnowMB.traefik-certificate-extractor.restart_domain=<DOMAIN>`.
|
||||
If the domains of an extracted certificate and the restart domain matches, the container is restarted. Multiple domains can be given seperated by `,`.
|
||||
|
||||
You can easily use `docker-compose` to integrate this container into your setup:
|
||||
|
||||
```yaml
|
||||
...
|
||||
services:
|
||||
certs:
|
||||
image: snowmb/traefik-certificate-extractor
|
||||
volumes:
|
||||
- path/to/acme.json:/app/data/acme.json:ro
|
||||
- certs:/app/certs:rw
|
||||
- /var/run/docker.sock:/var/run/docker.sock
|
||||
command: -r --include example.com
|
||||
restart: always
|
||||
```
|
||||
|
||||
|
||||
## Output
|
||||
```
|
||||
|
@ -217,7 +217,7 @@ if __name__ == "__main__":
|
||||
parser.add_argument('-f', '--flat', action='store_true',
|
||||
help='outputs all certificates into one folder')
|
||||
parser.add_argument('-r', '--restart_container', action='store_true',
|
||||
help='uses the docker API to restart containers that are labeled accordingly')
|
||||
help="uses the docker API to restart containers that are labeled with 'com.github.SnowMB.traefik-certificate-extractor.restart_domain=<DOMAIN>' if the domain name of a generated certificates matches. Multiple domains can be seperated by ','")
|
||||
parser.add_argument('--dry-run', action='store_true', dest='dry',
|
||||
help="Don't write files and do not start docker containers.")
|
||||
group = parser.add_mutually_exclusive_group()
|
||||
|
Loading…
x
Reference in New Issue
Block a user