Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/soulteary/certs-maker
100% Coverage! Lightweight self-signed certificate generator, size between 1.5MB (executable) and 5MB (docker image).
https://github.com/soulteary/certs-maker
certificate certs docker openssl self-hosted ssl time-saver
Last synced: 7 days ago
JSON representation
100% Coverage! Lightweight self-signed certificate generator, size between 1.5MB (executable) and 5MB (docker image).
- Host: GitHub
- URL: https://github.com/soulteary/certs-maker
- Owner: soulteary
- License: mit
- Created: 2021-02-03T14:29:24.000Z (almost 4 years ago)
- Default Branch: main
- Last Pushed: 2024-12-24T05:37:23.000Z (29 days ago)
- Last Synced: 2025-01-08T16:08:18.591Z (14 days ago)
- Topics: certificate, certs, docker, openssl, self-hosted, ssl, time-saver
- Language: Go
- Homepage: https://soulteary.com/2022/10/22/make-docker-tools-image-with-only-3md-self-signed-certificate-certs-maker.html
- Size: 902 KB
- Stars: 204
- Watchers: 5
- Forks: 34
- Open Issues: 0
-
Metadata Files:
- Readme: README.md
- License: LICENSE
- Security: SECURITY.md
Awesome Lists containing this project
README
# Certs Maker
[![CodeQL](https://github.com/soulteary/certs-maker/actions/workflows/github-code-scanning/codeql/badge.svg)](https://github.com/soulteary/certs-maker/actions/workflows/github-code-scanning/codeql) [![Release](https://github.com/soulteary/certs-maker/actions/workflows/release.yaml/badge.svg)](https://github.com/soulteary/certs-maker/actions/workflows/release.yaml) [![Docker Image](https://img.shields.io/docker/pulls/soulteary/certs-maker.svg)](https://hub.docker.com/r/soulteary/certs-maker) [![codecov](https://codecov.io/gh/soulteary/certs-maker/branch/main/graph/badge.svg?token=K12L34CSA4)](https://codecov.io/gh/soulteary/certs-maker)
**Lightweight self-signed certificate generator, size between 1.5MB (executable) and 5MB (docker image).**
Generate self-hosted or development certificates through simple configuration.
## Quick Start
Create self-signed certificates supporting `*.lab.com` and `*.data.lab.com` domains with just **"One Click"**:
```bash
docker run --rm -it -v `pwd`/ssl:/ssl soulteary/certs-maker:v3.7.0 "--CERT_DNS=lab.com,*.lab.com,*.data.lab.com"
# OR use environment:
# docker run --rm -it -v `pwd`/ssl:/ssl -e "CERT_DNS=lab.com,*.lab.com,*.data.lab.com" soulteary/certs-maker:v3.7.0
```The generated certificates will be stored in the `ssl` directory within the execution directory:
```bash
ssl
├── lab.com.conf
├── lab.com.der.crt
├── lab.com.der.key
├── lab.com.pem.crt
└── lab.com.pem.key
```You can use PEM or DER format certificates according to your preference.
For those who prefer file-based configuration, you can use a `docker-compose.yml` file like this:
```yaml
version: '2'
services:certs-maker:
image: soulteary/certs-maker:v3.7.0
environment:
- CERT_DNS=lab.com,*.lab.com,*.data.lab.com
volumes:
- ./ssl:/ssl
```Then, run the following command:
```bash
docker-compose up
# OR
# docker compose up
```To make the certificate more Kubernetes-friendly, add the `FOR_K8S` parameter:
```bash
docker run --rm -it -v `pwd`/ssl:/ssl soulteary/certs-maker:v3.7.0 "--CERT_DNS=lab.com,*.lab.com,*.data.lab.com --FOR_K8S=ON"
# OR
# docker run --rm -it -v `pwd`/ssl:/ssl -e "CERT_DNS=lab.com,*.lab.com,*.data.lab.com" -e "FOR_K8S=ON" soulteary/certs-maker:v3.7.0
```Here's a K8s-friendly `docker-compose.yml` file:
```yaml
version: '2'
services:certs-maker:
image: soulteary/certs-maker:v3.7.0
environment:
- CERT_DNS=lab.com,*.lab.com,*.data.lab.com
- FOR_K8S=ON
volumes:
- ./ssl:/ssl
```To enhance compatibility with Firefox, include the `FOR_FIREFOX` parameter:
```bash
docker run --rm -it -v `pwd`/ssl:/ssl soulteary/certs-maker:v3.7.0 "--CERT_DNS=lab.com,*.lab.com,*.data.lab.com --FOR_FIREFOX=ON"
# OR
# docker run --rm -it -v `pwd`/ssl:/ssl -e "CERT_DNS=lab.com,*.lab.com,*.data.lab.com" -e "FOR_FIREFOX=ON" soulteary/certs-maker:v3.7.0
```And here's a Firefox-friendly `docker-compose.yml` file:
```yaml
version: '2'
services:certs-maker:
image: soulteary/certs-maker:v3.7.0
environment:
- CERT_DNS=lab.com,*.lab.com,*.data.lab.com
- FOR_FIREFOX=ON
volumes:
- ./ssl:/ssl
```For more granular control over certificate details, such as issuing country, province, street, and organization name, refer to the following section on manually adding parameters.
## SSL Certificate Parameters
Customize your generated certificate by setting environment variables or using Docker CLI arguments.
Using environment variables:
| Parameter | Name | Use in environment variables |
| ------ | ------ | ------ |
| Country Name | CERT_C | `CERT_C=CN` |
| State Or Province Name | CERT_ST | `CERT_ST=BJ` |
| Locality Name | CERT_L | `CERT_L=HD` |
| Organization Name | CERT_O | `CERT_O=Lab` |
| Organizational Unit Name | CERT_OU | `CERT_OU=Dev` |
| Common Name | CERT_CN | `CERT_CN=Hello World` |
| Domains | CERT_DNS | `CERT_DNS=lab.com,*.lab.com,*.data.lab.com` |
| Issue for K8s | FOR_K8S | `FOR_K8S=ON` |
| Issue for Firefox | FOR_FIREFOX | `FOR_FIREFOX=ON` |
| File Owner User | USER | `USER=ubuntu` |
| File Owner UID | UID | `UID=1234` |
| File Owner GID | GID | `GID=2345` |
| Custom certs output dir | DIR | `DIR=./ssl` |
| Custom certs filename | CUSTOM_FILE_NAME | `CUSTOM_FILE_NAME=filename` |
| Expire Days | EXPIRE_DAYS | `EXPIRE_DAYS=3650` |Using program CLI arguments:
| Parameter | Name | Use in CLI arguments |
| ------ | ------ | ------ |
| Country Name | CERT_C | `--CERT_C=CN` |
| State Or Province Name | CERT_ST | `--CERT_ST=BJ` |
| Locality Name | CERT_L | `--CERT_L=HD` |
| Organization Name | CERT_O | `--CERT_O=Lab` |
| Organizational Unit Name | CERT_OU | `--CERT_OU=Dev` |
| Common Name | CERT_CN | `--CERT_CN=Hello World` |
| Domains | CERT_DNS | `--CERT_DNS=lab.com,*.lab.com,*.data.lab.com` |
| Issue for K8s | FOR_K8S | `--FOR_K8S=ON` |
| Issue for Firefox | FOR_FIREFOX | `--FOR_FIREFOX=ON` |
| File Owner User | USER | `--USER=ubuntu` |
| File Owner UID | UID | `--UID=1234` |
| File Owner GID | GID | `--GID=2345` |
| Custom certs output dir | DIR | `--DIR=./ssl` |
| Custom certs filename | CUSTOM_FILE_NAME | `--CUSTOM_FILE_NAME=filename` |
| Expire Days | EXPIRE_DAYS | `--EXPIRE_DAYS=3650` |## Docker Image
[soulteary/certs-maker](https://hub.docker.com/r/soulteary/certs-maker)
## Related Documentation and Tutorials
- [Creating a Lightweight 3MB Docker Image for Self-Signed Certificates: Introducing Certs Maker](https://soulteary.com/2022/10/22/make-docker-tools-image-with-only-3md-self-signed-certificate-certs-maker.html)
- [A Comprehensive Guide to Creating and Implementing Self-Signed Certificates](https://soulteary.com/2021/02/06/how-to-make-and-use-a-self-signed-certificate.html)