mirror of
https://github.com/usual2970/certimate.git
synced 2025-09-01 05:51:46 +00:00
.github
docker
internal
applicant
aliyun.go
applicant.go
cloudflare.go
godaddy.go
huaweicloud.go
namesilo.go
tencent.go
deployer
domain
domains
notify
utils
migrations
node_modules
ui
.dockerignore
.gitignore
.goreleaser.yml
CHANGELOG.md
CONTRIBUTING.md
CONTRIBUTING_EN.md
Dockerfile_build
LICENSE.md
Makefile
README.md
README_EN.md
go.mod
go.sum
main.go
nixpacks.toml
package-lock.json
package.json
usage.gif
36 lines
691 B
Go
36 lines
691 B
Go
package applicant
|
|
|
|
import (
|
|
"certimate/internal/domain"
|
|
"encoding/json"
|
|
"fmt"
|
|
"os"
|
|
|
|
cf "github.com/go-acme/lego/v4/providers/dns/cloudflare"
|
|
)
|
|
|
|
type cloudflare struct {
|
|
option *ApplyOption
|
|
}
|
|
|
|
func NewCloudflare(option *ApplyOption) Applicant {
|
|
return &cloudflare{
|
|
option: option,
|
|
}
|
|
}
|
|
|
|
func (c *cloudflare) Apply() (*Certificate, error) {
|
|
access := &domain.CloudflareAccess{}
|
|
json.Unmarshal([]byte(c.option.Access), access)
|
|
|
|
os.Setenv("CLOUDFLARE_DNS_API_TOKEN", access.DnsApiToken)
|
|
os.Setenv("CLOUDFLARE_PROPAGATION_TIMEOUT", fmt.Sprintf("%d", c.option.Timeout))
|
|
|
|
provider, err := cf.NewDNSProvider()
|
|
if err != nil {
|
|
return nil, err
|
|
}
|
|
|
|
return apply(c.option, provider)
|
|
}
|