selectel

package
v1.2.0 Latest Latest
Warning

This package is not in the latest version of its module.

Go to latest
Published: Nov 5, 2018 License: MIT Imports: 9 Imported by: 69

Documentation

Overview

Package selectel implements a DNS provider for solving the DNS-01 challenge using Selectel Domains API. Selectel Domain API reference: https://kb.selectel.com/23136054.html Token: https://my.selectel.ru/profile/apikeys

Index

Constants

This section is empty.

Variables

This section is empty.

Functions

This section is empty.

Types

type APIError

type APIError struct {
	Description string `json:"error"`
	Code        int    `json:"code"`
	Field       string `json:"field"`
}

APIError API error message

func (*APIError) Error

func (a *APIError) Error() string

type Client

type Client struct {
	// contains filtered or unexported fields
}

Client represents DNS client.

func NewClient

func NewClient(opts ClientOpts) *Client

NewClient returns a client instance.

func (*Client) AddRecord

func (c *Client) AddRecord(domainID int, body Record) (*Record, error)

AddRecord adds Record for given domain.

func (*Client) DeleteRecord

func (c *Client) DeleteRecord(domainID, recordID int) error

DeleteRecord deletes specific record.

func (*Client) GetDomainByName

func (c *Client) GetDomainByName(domainName string) (*Domain, error)

GetDomainByName gets Domain object by its name.

func (*Client) ListRecords

func (c *Client) ListRecords(domainID int) ([]*Record, error)

ListRecords returns list records for specific domain.

type ClientOpts

type ClientOpts struct {
	BaseURL    string
	Token      string
	UserAgent  string
	HTTPClient *http.Client
}

ClientOpts represents options to init client.

type Config

type Config struct {
	BaseURL            string
	Token              string
	PropagationTimeout time.Duration
	PollingInterval    time.Duration
	TTL                int
	HTTPClient         *http.Client
}

Config is used to configure the creation of the DNSProvider.

func NewDefaultConfig

func NewDefaultConfig() *Config

NewDefaultConfig returns a default configuration for the DNSProvider.

type DNSProvider

type DNSProvider struct {
	// contains filtered or unexported fields
}

DNSProvider is an implementation of the acme.ChallengeProvider interface.

func NewDNSProvider

func NewDNSProvider() (*DNSProvider, error)

NewDNSProvider returns a DNSProvider instance configured for Selectel Domains API. API token must be passed in the environment variable SELECTEL_API_TOKEN.

func NewDNSProviderConfig

func NewDNSProviderConfig(config *Config) (*DNSProvider, error)

NewDNSProviderConfig return a DNSProvider instance configured for selectel.

func (*DNSProvider) CleanUp

func (d *DNSProvider) CleanUp(domain, token, keyAuth string) error

CleanUp removes a TXT record used for DNS-01 challenge.

func (*DNSProvider) Present

func (d *DNSProvider) Present(domain, token, keyAuth string) error

Present creates a TXT record to fulfill DNS-01 challenge.

func (*DNSProvider) Timeout

func (d *DNSProvider) Timeout() (timeout, interval time.Duration)

Timeout returns the Timeout and interval to use when checking for DNS propagation. Adjusting here to cope with spikes in propagation times.

type Domain

type Domain struct {
	ID   int    `json:"id,omitempty"`
	Name string `json:"name,omitempty"`
}

Domain represents domain name.

type Record

type Record struct {
	ID      int    `json:"id,omitempty"`
	Name    string `json:"name,omitempty"`
	Type    string `json:"type,omitempty"` // Record type (SOA, NS, A/AAAA, CNAME, SRV, MX, TXT, SPF)
	TTL     int    `json:"ttl,omitempty"`
	Email   string `json:"email,omitempty"`   // Email of domain's admin (only for SOA records)
	Content string `json:"content,omitempty"` // Record content (not for SRV)
}

Record represents DNS record.

Jump to

Keyboard shortcuts

? : This menu
/ : Search site
f or F : Jump to
y or Y : Canonical URL