README
¶
DNSPOD for libdns
This package implements the libdns interfaces for the DNSPOD API (using the Go implementation from: https://github.com/nrdcg/dnspod-go)
Authenticating
To authenticate you need to supply a DNSPOD API token.
Example
Here's a minimal example of how to get all your DNS records using this libdns
provider (see _example/main.go
)
package main
import (
"context"
"fmt"
"os"
"time"
dnspod "github.com/libdns/dnspod"
"github.com/libdns/libdns"
)
func main() {
token := os.Getenv("DNSPOD_TOKEN")
if token == "" {
fmt.Printf("DNSPOD_TOKEN not set\n")
return
}
zone := os.Getenv("ZONE")
if zone == "" {
fmt.Printf("ZONE not set\n")
return
}
provider := dnspod.Provider{APIToken: token}
records, err := provider.GetRecords(context.TODO(), zone)
if err != nil {
fmt.Printf("ERROR: %s\n", err.Error())
}
testName := "libdns-test"
testID := ""
for _, record := range records {
fmt.Printf("%s (.%s): %s, %s\n", record.Name, zone, record.Value, record.Type)
if record.Name == testName {
testID = record.ID
}
}
if testID != "" {
// fmt.Printf("Delete entry for %s (id:%s)\n", testName, testID)
// _, err = provider.DeleteRecords(context.TODO(), zone, []libdns.Record{libdns.Record{
// ID: testID,
// }})
// if err != nil {
// fmt.Printf("ERROR: %s\n", err.Error())
// }
// Set only works if we have a record.ID
fmt.Printf("Replacing entry for %s\n", testName)
_, err = provider.SetRecords(context.TODO(), zone, []libdns.Record{libdns.Record{
Type: "TXT",
Name: testName,
Value: fmt.Sprintf("Replacement test entry created by libdns %s", time.Now()),
TTL: time.Duration(600) * time.Second,
ID: testID,
}})
if err != nil {
fmt.Printf("ERROR: %s\n", err.Error())
}
} else {
fmt.Printf("Creating new entry for %s\n", testName)
_, err = provider.AppendRecords(context.TODO(), zone, []libdns.Record{libdns.Record{
Type: "TXT",
Name: testName,
Value: fmt.Sprintf("This is a test entry created by libdns %s", time.Now()),
TTL: time.Duration(600) * time.Second,
}})
if err != nil {
fmt.Printf("ERROR: %s\n", err.Error())
}
}
}
Documentation
¶
Index ¶
- type Client
- type Provider
- func (p *Provider) AppendRecords(ctx context.Context, zone string, records []libdns.Record) ([]libdns.Record, error)
- func (p *Provider) DeleteRecords(ctx context.Context, zone string, records []libdns.Record) ([]libdns.Record, error)
- func (p *Provider) GetRecords(ctx context.Context, zone string) ([]libdns.Record, error)
- func (p *Provider) SetRecords(ctx context.Context, zone string, records []libdns.Record) ([]libdns.Record, error)
Constants ¶
This section is empty.
Variables ¶
This section is empty.
Functions ¶
This section is empty.
Types ¶
type Provider ¶
type Provider struct { Client // APIToken is the DNSPOD API token - see https://www.dnspod.cn/docs/info.html#common-parameters APIToken string `json:"auth_token"` }
Provider implements the libdns interfaces for DNSPOD
func (*Provider) AppendRecords ¶
func (p *Provider) AppendRecords(ctx context.Context, zone string, records []libdns.Record) ([]libdns.Record, error)
AppendRecords adds records to the zone. It returns the records that were added.
func (*Provider) DeleteRecords ¶
func (p *Provider) DeleteRecords(ctx context.Context, zone string, records []libdns.Record) ([]libdns.Record, error)
DeleteRecords deletes the records from the zone.
func (*Provider) GetRecords ¶
GetRecords lists all the records in the zone.
Click to show internal directories.
Click to hide internal directories.