周玉环 d906a41c2e first commit 2 dni temu
..
.gitignore d906a41c2e first commit 2 dni temu
LICENSE d906a41c2e first commit 2 dni temu
Makefile d906a41c2e first commit 2 dni temu
README.md d906a41c2e first commit 2 dni temu
THIRD-PARTY d906a41c2e first commit 2 dni temu
account.go d906a41c2e first commit 2 dni temu
acme.go d906a41c2e first commit 2 dni temu
ari.go d906a41c2e first commit 2 dni temu
authorization.go d906a41c2e first commit 2 dni temu
autocert.go d906a41c2e first commit 2 dni temu
certificate.go d906a41c2e first commit 2 dni temu
challenge.go d906a41c2e first commit 2 dni temu
docker-compose.boulder-temp.yml d906a41c2e first commit 2 dni temu
jws.go d906a41c2e first commit 2 dni temu
nonce.go d906a41c2e first commit 2 dni temu
options.go d906a41c2e first commit 2 dni temu
order.go d906a41c2e first commit 2 dni temu
problem.go d906a41c2e first commit 2 dni temu
types.go d906a41c2e first commit 2 dni temu

README.md

eggsampler/acme

GoDoc Build Status Coverage Status

About

eggsampler/acme is a Go client library implementation for RFC8555 (previously ACME v2). This library can be used with the Let's Encrypt Certificate Authority (CA), but also other ACME compliant CA's such as ZeroSSL.

The library is designed to provide a zero external dependency wrapper over exposed directory endpoints and provide objects in easy to use structures.

Requirements

A Go version of at least 1.11 is required as this repository is designed to be imported as a Go module.

Usage

Simply import the module into a project,

import "github.com/eggsampler/acme/v3"

Note the /v3 major version at the end. Due to the way modules function, this is the major version as represented in the go.mod file and latest git repo semver tag. All functions are still exported and called using the acme package name.

Examples

A simple certbot-like example is provided in the examples/certbot directory. This code demonstrates account registration, new order submission, fulfilling challenges, finalising an order and fetching the issued certificate chain.

An example of how to use the autocert package is also provided in examples/autocert.

Tests

The tests can be run against an instance of boulder or pebble.

Challenge fulfilment is designed to use the new challtestsrv server present inside boulder and pebble which responds to dns queries and challenges as required.

To run tests against an already running instance of boulder or pebble, use the test target in the Makefile.

Some convenience targets for launching pebble/boulder using their respective docker compose files have also been included in the Makefile.