2019-10-21 02:52:19 +07:00
|
|
|
package main
|
|
|
|
|
2022-01-26 05:26:45 +07:00
|
|
|
import (
|
|
|
|
"context"
|
|
|
|
"github.com/mholt/acmez/acme"
|
|
|
|
)
|
2019-10-21 02:52:19 +07:00
|
|
|
|
|
|
|
// ChallengeProvider implements go-acme/lego Provider interface which is used for ACME DNS challenge handling
|
|
|
|
type ChallengeProvider struct {
|
|
|
|
servers []*DNSServer
|
|
|
|
}
|
|
|
|
|
|
|
|
// NewChallengeProvider creates a new instance of ChallengeProvider
|
|
|
|
func NewChallengeProvider(servers []*DNSServer) ChallengeProvider {
|
|
|
|
return ChallengeProvider{servers: servers}
|
|
|
|
}
|
|
|
|
|
|
|
|
// Present is used for making the ACME DNS challenge token available for DNS
|
2022-01-26 05:26:45 +07:00
|
|
|
func (c *ChallengeProvider) Present(ctx context.Context, challenge acme.Challenge) error {
|
2019-10-21 02:52:19 +07:00
|
|
|
for _, s := range c.servers {
|
2022-01-26 05:26:45 +07:00
|
|
|
s.PersonalKeyAuth = challenge.DNS01KeyAuthorization()
|
2019-10-21 02:52:19 +07:00
|
|
|
}
|
|
|
|
return nil
|
|
|
|
}
|
|
|
|
|
|
|
|
// CleanUp is called after the run to remove the ACME DNS challenge tokens from DNS records
|
2022-01-26 05:26:45 +07:00
|
|
|
func (c *ChallengeProvider) CleanUp(ctx context.Context, _ acme.Challenge) error {
|
2019-10-21 02:52:19 +07:00
|
|
|
for _, s := range c.servers {
|
|
|
|
s.PersonalKeyAuth = ""
|
|
|
|
}
|
|
|
|
return nil
|
|
|
|
}
|
2022-01-26 05:26:45 +07:00
|
|
|
|
|
|
|
// Wait is a dummy function as we are just going to be ready to answer the challenge from the get-go
|
|
|
|
func (c *ChallengeProvider) Wait(_ context.Context, _ acme.Challenge) error {
|
|
|
|
return nil
|
|
|
|
}
|