mirror of
https://github.com/StackExchange/dnscontrol.git
synced 2025-01-11 01:47:53 +08:00
825ba2d081
* Replaced errors.Wrap with fmt.Errorf (#589) * Find: errors\.Wrap\(([^,]+),\s+(["`][^"`]*)(["`])\) Replace: fmt.Errorf($2: %w$3, $1) * Replaced errors.Wrapf with fmt.Errorf (#589) * Find: errors\.Wrapf\(([^,]+),\s+(["`][^"`]*)(["`])\) Replace: fmt.Errorf($2: %w$3, $1) * Find: errors\.Wrapf\(([^,]+),\s+(["`][^"`]*)(["`])(,[^)]+)\) * Replace: fmt.Errorf($2: %w$3$4, $1) * Replaced errors.Errorf with fmt.Errorf (#589) * Find: errors\.Errorf Replace: fmt.Errorf * Cleaned up remaining imports * Cleanup * Regenerate provider support matrix This was broken by #533 ... and it's now the third time this has been missed.
88 lines
2 KiB
Go
88 lines
2 KiB
Go
package internetbs
|
|
|
|
import (
|
|
"encoding/json"
|
|
"fmt"
|
|
"io/ioutil"
|
|
"net/http"
|
|
"strings"
|
|
)
|
|
|
|
// Api layer for Internet.bs
|
|
|
|
type api struct {
|
|
key string
|
|
password string
|
|
}
|
|
|
|
type requestParams map[string]string
|
|
|
|
type errorResponse struct {
|
|
TransactID string `json:"transactid"`
|
|
Status string `json:"status"`
|
|
Message string `json:"message,omitempty"`
|
|
Code uint `json:"code,omitempty"`
|
|
}
|
|
|
|
type domainRecord struct {
|
|
Nameserver []string `json:"nameserver"`
|
|
}
|
|
|
|
func (c *api) getNameservers(domain string) ([]string, error) {
|
|
var bodyString, err = c.get("/Domain/Info", requestParams{"Domain": domain})
|
|
if err != nil {
|
|
return []string{}, fmt.Errorf("Error fetching nameservers list from Internet.bs: %s", err)
|
|
}
|
|
var dr domainRecord
|
|
json.Unmarshal(bodyString, &dr)
|
|
ns := []string{}
|
|
for _, nameserver := range dr.Nameserver {
|
|
ns = append(ns, nameserver)
|
|
}
|
|
return ns, nil
|
|
}
|
|
|
|
func (c *api) updateNameservers(ns []string, domain string) error {
|
|
rec := requestParams{}
|
|
rec["Domain"] = domain
|
|
rec["Ns_list"] = strings.Join(ns, ",")
|
|
if _, err := c.get("/Domain/Update", rec); err != nil {
|
|
return fmt.Errorf("Internet.ns: Error update NS : %s", err)
|
|
}
|
|
return nil
|
|
}
|
|
|
|
func (c *api) get(endpoint string, params requestParams) ([]byte, error) {
|
|
client := &http.Client{}
|
|
req, _ := http.NewRequest("GET", "https://api.internet.bs/"+endpoint, nil)
|
|
q := req.URL.Query()
|
|
|
|
// Add auth params
|
|
q.Add("ApiKey", c.key)
|
|
q.Add("Password", c.password)
|
|
q.Add("ResponseFormat", "JSON")
|
|
|
|
for pName, pValue := range params {
|
|
q.Add(pName, pValue)
|
|
}
|
|
|
|
req.URL.RawQuery = q.Encode()
|
|
|
|
resp, err := client.Do(req)
|
|
if err != nil {
|
|
return []byte{}, err
|
|
}
|
|
|
|
bodyString, _ := ioutil.ReadAll(resp.Body)
|
|
|
|
// Got error from API ?
|
|
var errResp errorResponse
|
|
err = json.Unmarshal(bodyString, &errResp)
|
|
if errResp.Status == "FAILURE" {
|
|
return bodyString, fmt.Errorf("Internet.bs API error: %s code: %d transactid: %s URL:%s%s ",
|
|
errResp.Message, errResp.Code, errResp.TransactID,
|
|
req.Host, req.URL.RequestURI())
|
|
}
|
|
|
|
return bodyString, nil
|
|
}
|