mirror of
https://github.com/go-acme/lego.git
synced 2024-12-13 21:55:28 +02:00
42941ccea6
- Packages - Isolate code used by the CLI into the package `cmd` - (experimental) Add e2e tests for HTTP01, TLS-ALPN-01 and DNS-01, use [Pebble](https://github.com/letsencrypt/pebble) and [challtestsrv](https://github.com/letsencrypt/boulder/tree/master/test/challtestsrv) - Support non-ascii domain name (punnycode) - Check all challenges in a predictable order - No more global exported variables - Archive revoked certificates - Fixes revocation for subdomains and non-ascii domains - Disable pending authorizations - use pointer for RemoteError/ProblemDetails - Poll authz URL instead of challenge URL - The ability for a DNS provider to solve the challenge sequentially - Check all nameservers in a predictable order - Option to disable the complete propagation Requirement - CLI, support for renew with CSR - CLI, add SAN on renew - Add command to list certificates. - Logs every iteration of waiting for the propagation - update DNSimple client - update github.com/miekg/dns
92 lines
2.2 KiB
Go
92 lines
2.2 KiB
Go
package glesys
|
|
|
|
import (
|
|
"bytes"
|
|
"encoding/json"
|
|
"fmt"
|
|
"net/http"
|
|
|
|
"github.com/xenolf/lego/log"
|
|
)
|
|
|
|
// types for JSON method calls, parameters, and responses
|
|
|
|
type addRecordRequest struct {
|
|
DomainName string `json:"domainname"`
|
|
Host string `json:"host"`
|
|
Type string `json:"type"`
|
|
Data string `json:"data"`
|
|
TTL int `json:"ttl,omitempty"`
|
|
}
|
|
|
|
type deleteRecordRequest struct {
|
|
RecordID int `json:"recordid"`
|
|
}
|
|
|
|
type responseStruct struct {
|
|
Response struct {
|
|
Status struct {
|
|
Code int `json:"code"`
|
|
} `json:"status"`
|
|
Record deleteRecordRequest `json:"record"`
|
|
} `json:"response"`
|
|
}
|
|
|
|
func (d *DNSProvider) addTXTRecord(fqdn string, domain string, name string, value string, ttl int) (int, error) {
|
|
response, err := d.sendRequest(http.MethodPost, "addrecord", addRecordRequest{
|
|
DomainName: domain,
|
|
Host: name,
|
|
Type: "TXT",
|
|
Data: value,
|
|
TTL: ttl,
|
|
})
|
|
|
|
if response != nil && response.Response.Status.Code == http.StatusOK {
|
|
log.Infof("[%s]: Successfully created record id %d", fqdn, response.Response.Record.RecordID)
|
|
return response.Response.Record.RecordID, nil
|
|
}
|
|
return 0, err
|
|
}
|
|
|
|
func (d *DNSProvider) deleteTXTRecord(fqdn string, recordid int) error {
|
|
response, err := d.sendRequest(http.MethodPost, "deleterecord", deleteRecordRequest{
|
|
RecordID: recordid,
|
|
})
|
|
if response != nil && response.Response.Status.Code == 200 {
|
|
log.Infof("[%s]: Successfully deleted record id %d", fqdn, recordid)
|
|
}
|
|
return err
|
|
}
|
|
|
|
func (d *DNSProvider) sendRequest(method string, resource string, payload interface{}) (*responseStruct, error) {
|
|
url := fmt.Sprintf("%s/%s", defaultBaseURL, resource)
|
|
|
|
body, err := json.Marshal(payload)
|
|
if err != nil {
|
|
return nil, err
|
|
}
|
|
|
|
req, err := http.NewRequest(method, url, bytes.NewReader(body))
|
|
if err != nil {
|
|
return nil, err
|
|
}
|
|
|
|
req.Header.Set("Content-Type", "application/json")
|
|
req.SetBasicAuth(d.config.APIUser, d.config.APIKey)
|
|
|
|
resp, err := d.config.HTTPClient.Do(req)
|
|
if err != nil {
|
|
return nil, err
|
|
}
|
|
defer resp.Body.Close()
|
|
|
|
if resp.StatusCode >= 400 {
|
|
return nil, fmt.Errorf("request failed with HTTP status code %d", resp.StatusCode)
|
|
}
|
|
|
|
var response responseStruct
|
|
err = json.NewDecoder(resp.Body).Decode(&response)
|
|
|
|
return &response, err
|
|
}
|