lego/providers/dns/iijdpf/wrapper.go

97 lines
2.4 KiB
Go
Raw Normal View History

package iijdpf
import (
"context"
"errors"
"fmt"
dpfzones "github.com/mimuret/golang-iij-dpf/pkg/apis/dpf/v1/zones"
dpfapiutils "github.com/mimuret/golang-iij-dpf/pkg/apiutils"
dpftypes "github.com/mimuret/golang-iij-dpf/pkg/types"
)
func (d *DNSProvider) addTxtRecord(ctx context.Context, zoneID, fqdn, rdata string) error {
r, err := dpfapiutils.GetRecordFromZoneID(ctx, d.client, zoneID, fqdn, dpfzones.TypeTXT)
if err != nil && !errors.Is(err, dpfapiutils.ErrRecordNotFound) {
return err
}
if r != nil {
r.RData = append(r.RData, dpfzones.RecordRDATA{Value: rdata})
_, _, err = dpfapiutils.SyncUpdate(ctx, d.client, r, nil)
if err != nil {
return fmt.Errorf("failed to update record: %w", err)
}
return nil
}
record := &dpfzones.Record{
AttributeMeta: dpfzones.AttributeMeta{ZoneID: zoneID},
Name: fqdn,
TTL: dpftypes.NullablePositiveInt32(d.config.TTL),
RRType: dpfzones.TypeTXT,
RData: dpfzones.RecordRDATASlice{dpfzones.RecordRDATA{Value: rdata}},
Description: "ACME",
}
_, _, err = dpfapiutils.SyncCreate(ctx, d.client, record, nil)
if err != nil {
return fmt.Errorf("failed to create record: %w", err)
}
return nil
}
func (d *DNSProvider) deleteTxtRecord(ctx context.Context, zoneID, fqdn, rdata string) error {
r, err := dpfapiutils.GetRecordFromZoneID(ctx, d.client, zoneID, fqdn, dpfzones.TypeTXT)
if err != nil {
if errors.Is(err, dpfapiutils.ErrRecordNotFound) {
// empty target rrset
return nil
}
return err
}
if len(r.RData) == 1 {
// delete rrset
_, _, err = dpfapiutils.SyncDelete(ctx, d.client, r)
if err != nil {
return fmt.Errorf("failed to delete record: %w", err)
}
return nil
}
// delete rdata
rdataSlice := dpfzones.RecordRDATASlice{}
for _, v := range r.RData {
if v.Value != rdata {
rdataSlice = append(rdataSlice, v)
}
}
r.RData = rdataSlice
_, _, err = dpfapiutils.SyncUpdate(ctx, d.client, r, nil)
if err != nil {
return fmt.Errorf("failed to update record: %w", err)
}
return nil
}
func (d *DNSProvider) commit(ctx context.Context, zoneID string) error {
apply := &dpfzones.ZoneApply{
AttributeMeta: dpfzones.AttributeMeta{ZoneID: zoneID},
Description: "ACME Processing",
}
_, _, err := dpfapiutils.SyncApply(ctx, d.client, apply, nil)
if err != nil {
return fmt.Errorf("failed to apply zone: %w", err)
}
return nil
}