Certy is a Go package that automates the process of obtaining SSL certificates from Let's Encrypt using the ACME protocol. It handles the entire process from generating the account key, registering an ACME account, handling the HTTP-01 challenge, and issuing the certificate.
To install Certy, use go get
:
go get github.com/kintsdev/certy
Here is an example of how to use Certy to issue a Let's Encrypt certificate for a domain:
import "github.com/kintsdev/certy"
package main
import (
"github.com/kintsdev/certy"
"log"
"os"
)
func main() {
email := "your-email@example.com"
domain := "yourdomain.com"
location := "/path/to/save/certificates"
if err := os.Setenv("ACME_ENV", "staging"); err != nil {
log.Fatalf("Failed to set environment variable: %v", err)
}
certy.IssueLetsEncryptCert(email, domain, location)
}
ACME_ENV
: Set this environment variable to "staging" to use the Let's Encrypt staging server. This is useful for testing. If this environment variable is not set, the production server will be used.
The IssueLetsEncryptCert function will generate the following files in the current directory:
- location/yourdomain.com/yourdomain.com-cert.pem: The certificate.
- location/yourdomain.com/yourdomain.com-key.pem: The private key.
- location/yourdomain.com/yourdomain.com-acme.json: The ACME registration information.
This project is licensed under the MIT License - see the LICENSE file for details.
Contributions are welcome! Please open an issue or submit a pull request for any bugs or enhancements.