146 lines
4.2 KiB
Go
146 lines
4.2 KiB
Go
package dnsimple
|
|
|
|
import (
|
|
"fmt"
|
|
)
|
|
|
|
// DomainsService handles communication with the domain related
|
|
// methods of the DNSimple API.
|
|
//
|
|
// See https://developer.dnsimple.com/v2/domains/
|
|
type DomainsService struct {
|
|
client *Client
|
|
}
|
|
|
|
// Domain represents a domain in DNSimple.
|
|
type Domain struct {
|
|
ID int `json:"id,omitempty"`
|
|
AccountID int `json:"account_id,omitempty"`
|
|
RegistrantID int `json:"registrant_id,omitempty"`
|
|
Name string `json:"name,omitempty"`
|
|
UnicodeName string `json:"unicode_name,omitempty"`
|
|
Token string `json:"token,omitempty"`
|
|
State string `json:"state,omitempty"`
|
|
AutoRenew bool `json:"auto_renew,omitempty"`
|
|
PrivateWhois bool `json:"private_whois,omitempty"`
|
|
ExpiresOn string `json:"expires_on,omitempty"`
|
|
CreatedAt string `json:"created_at,omitempty"`
|
|
UpdatedAt string `json:"updated_at,omitempty"`
|
|
}
|
|
|
|
func domainPath(accountID string, domainIdentifier string) (path string) {
|
|
path = fmt.Sprintf("/%v/domains", accountID)
|
|
if domainIdentifier != "" {
|
|
path += fmt.Sprintf("/%v", domainIdentifier)
|
|
}
|
|
return
|
|
}
|
|
|
|
// domainResponse represents a response from an API method that returns a Domain struct.
|
|
type domainResponse struct {
|
|
Response
|
|
Data *Domain `json:"data"`
|
|
}
|
|
|
|
// domainsResponse represents a response from an API method that returns a collection of Domain struct.
|
|
type domainsResponse struct {
|
|
Response
|
|
Data []Domain `json:"data"`
|
|
}
|
|
|
|
// DomainListOptions specifies the optional parameters you can provide
|
|
// to customize the DomainsService.ListDomains method.
|
|
type DomainListOptions struct {
|
|
// Select domains where the name contains given string.
|
|
NameLike string `url:"name_like,omitempty"`
|
|
|
|
// Select domains where the registrant matches given ID.
|
|
RegistrantID int `url:"registrant_id,omitempty"`
|
|
|
|
ListOptions
|
|
}
|
|
|
|
// ListDomains lists the domains for an account.
|
|
//
|
|
// See https://developer.dnsimple.com/v2/domains/#list
|
|
func (s *DomainsService) ListDomains(accountID string, options *DomainListOptions) (*domainsResponse, error) {
|
|
path := versioned(domainPath(accountID, ""))
|
|
domainsResponse := &domainsResponse{}
|
|
|
|
path, err := addURLQueryOptions(path, options)
|
|
if err != nil {
|
|
return nil, err
|
|
}
|
|
|
|
resp, err := s.client.get(path, domainsResponse)
|
|
if err != nil {
|
|
return nil, err
|
|
}
|
|
|
|
domainsResponse.HttpResponse = resp
|
|
return domainsResponse, nil
|
|
}
|
|
|
|
// CreateDomain creates a new domain in the account.
|
|
//
|
|
// See https://developer.dnsimple.com/v2/domains/#create
|
|
func (s *DomainsService) CreateDomain(accountID string, domainAttributes Domain) (*domainResponse, error) {
|
|
path := versioned(domainPath(accountID, ""))
|
|
domainResponse := &domainResponse{}
|
|
|
|
resp, err := s.client.post(path, domainAttributes, domainResponse)
|
|
if err != nil {
|
|
return nil, err
|
|
}
|
|
|
|
domainResponse.HttpResponse = resp
|
|
return domainResponse, nil
|
|
}
|
|
|
|
// GetDomain fetches a domain.
|
|
//
|
|
// See https://developer.dnsimple.com/v2/domains/#get
|
|
func (s *DomainsService) GetDomain(accountID string, domainIdentifier string) (*domainResponse, error) {
|
|
path := versioned(domainPath(accountID, domainIdentifier))
|
|
domainResponse := &domainResponse{}
|
|
|
|
resp, err := s.client.get(path, domainResponse)
|
|
if err != nil {
|
|
return nil, err
|
|
}
|
|
|
|
domainResponse.HttpResponse = resp
|
|
return domainResponse, nil
|
|
}
|
|
|
|
// DeleteDomain PERMANENTLY deletes a domain from the account.
|
|
//
|
|
// See https://developer.dnsimple.com/v2/domains/#delete
|
|
func (s *DomainsService) DeleteDomain(accountID string, domainIdentifier string) (*domainResponse, error) {
|
|
path := versioned(domainPath(accountID, domainIdentifier))
|
|
domainResponse := &domainResponse{}
|
|
|
|
resp, err := s.client.delete(path, nil, nil)
|
|
if err != nil {
|
|
return nil, err
|
|
}
|
|
|
|
domainResponse.HttpResponse = resp
|
|
return domainResponse, nil
|
|
}
|
|
|
|
// ResetDomainToken resets the domain token.
|
|
//
|
|
// See https://developer.dnsimple.com/v2/domains/#reset-token
|
|
func (s *DomainsService) ResetDomainToken(accountID string, domainIdentifier string) (*domainResponse, error) {
|
|
path := versioned(domainPath(accountID, domainIdentifier) + "/token")
|
|
domainResponse := &domainResponse{}
|
|
|
|
resp, err := s.client.post(path, nil, domainResponse)
|
|
if err != nil {
|
|
return nil, err
|
|
}
|
|
|
|
domainResponse.HttpResponse = resp
|
|
return domainResponse, nil
|
|
}
|