cert-manager-webhook-example/dns/dns.go
2026-01-25 14:10:17 +00:00

93 lines
2.7 KiB
Go

package dns
import (
"fmt"
"io"
"log"
"net/http"
"net/url"
"strconv"
"strings"
"github.com/MartinWilkerson/cert-manager-webhook-nearlyfreespeech/auth"
)
var (
baseUrl = "https://api.nearlyfreespeech.net"
authHeaderName = "X-NFSN-Authentication"
)
func SetTXTRecord(domain string, dnsName string, key string, login string, apiKey string) error {
urlPath := fmt.Sprintf("/dns/%s/addRR", domain)
requestUrl := fmt.Sprintf("%s%s", baseUrl, urlPath)
log.Printf("Request URL: %v", requestUrl)
values := url.Values{"name": {dnsName}, "type": {"TXT"}, "data": {key}}
body := values.Encode()
return send(login, apiKey, urlPath, body, requestUrl)
}
func ClearTXTRecord(domain string, dnsName string, key string, login string, apiKey string) error {
urlPath := fmt.Sprintf("/dns/%s/removeRR", domain)
requestUrl := fmt.Sprintf("%s%s", baseUrl, urlPath)
values := url.Values{"name": {dnsName}, "type": {"TXT"}, "data": {key}}
body := values.Encode()
return send(login, apiKey, urlPath, body, requestUrl)
}
func SetARecord(domain string, subdomain string, data string, ttl uint32, login string, apiKey string) error {
urlPath := fmt.Sprintf("/dns/%s/addRR", domain)
requestUrl := fmt.Sprintf("%s%s", baseUrl, urlPath)
log.Printf("Request URL: %v", requestUrl)
values := url.Values{"name": {subdomain}, "type": {"A"}, "data": {data}, "ttl": {strconv.FormatUint(uint64(ttl), 10)}}
log.Printf("Body values: %v", values)
body := values.Encode()
return send(login, apiKey, urlPath, body, requestUrl)
}
func ClearARecord(domain string, subdomain string, data string, ttl uint32, login string, apiKey string) error {
urlPath := fmt.Sprintf("/dns/%s/removeRR", domain)
requestUrl := fmt.Sprintf("%s%s", baseUrl, urlPath)
log.Printf("Request URL: %v", requestUrl)
values := url.Values{"name": {subdomain}, "type": {"A"}, "data": {data}}
log.Printf("Body values: %v", values)
body := values.Encode()
return send(login, apiKey, urlPath, body, requestUrl)
}
func send(login string, apiKey string, urlPath string, body string, requestUrl string) error {
authHeader, err := auth.GetAuthHeader(login, apiKey, urlPath, body)
if err != nil {
return err
}
bodyReader := strings.NewReader(body)
req, err := http.NewRequest("POST", requestUrl, bodyReader)
if err != nil {
return err
}
req.Header.Set("Content-Type", "application/x-www-form-urlencoded")
req.Header.Set(authHeaderName, authHeader)
resp, err := http.DefaultClient.Do(req)
if err != nil {
return err
}
defer resp.Body.Close()
if resp.StatusCode < 200 || resp.StatusCode >= 300 {
bytes, err := io.ReadAll(resp.Body)
if err != nil {
return err
}
return fmt.Errorf("HTTP error code %v: %v", resp.StatusCode, string(bytes))
}
return nil
}