File: json.go

package info (click to toggle)
golang-github-nesv-go-dynect 0.6.0%2Bgit20190806.63e11f6-3
  • links: PTS, VCS
  • area: main
  • in suites: bookworm, forky, sid, trixie
  • size: 224 kB
  • sloc: makefile: 2
file content (105 lines) | stat: -rw-r--r-- 3,434 bytes parent folder | download | duplicates (2)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
package dynect

/*
This struct represents the request body that would be sent to the DynECT API
for logging in and getting a session token for future requests.
*/
type LoginBlock struct {
	Username     string `json:"user_name"`
	Password     string `json:"password"`
	CustomerName string `json:"customer_name"`
}

// Type ResponseBlock holds the "header" information returned by any call to
// the DynECT API.
//
// All response-type structs should include this as an anonymous/embedded field.
type ResponseBlock struct {
	Status   string         `json:"status"`
	JobId    int            `json:"job_id,omitempty"`
	Messages []MessageBlock `json:"msgs,omitempty"`
}

// Type MessageBlock holds the message information from the server, and is
// nested within the ResponseBlock type.
type MessageBlock struct {
	Info      string `json:"INFO"`
	Source    string `json:"SOURCE"`
	ErrorCode string `json:"ERR_CD"`
	Level     string `json:"LVL"`
}

// Type LoginResponse holds the data returned by an HTTP POST call to
// https://api.dynect.net/REST/Session/.
type LoginResponse struct {
	ResponseBlock
	Data LoginDataBlock `json:"data"`
}

// Type LoginDataBlock holds the token and API version information from an HTTP
// POST call to https://api.dynect.net/REST/Session/.
//
// It is nested within the LoginResponse struct.
type LoginDataBlock struct {
	Token   string `json:"token"`
	Version string `json:"version"`
}

// RecordRequest holds the request body for a record create/update
type RecordRequest struct {
	RData DataBlock `json:"rdata"`
	TTL   string    `json:"ttl,omitempty"`
}

// CreateZoneBlock holds the request body for a zone create
type CreateZoneBlock struct {
	RName       string `json:"rname"`
	SerialStyle string `json:"serial_style,omitempty"`
	TTL         string `json:"ttl"`
}

// PublishZoneBlock holds the request body for a publish zone request
// https://help.dyn.com/update-zone-api/
type PublishZoneBlock struct {
	Publish bool `json:"publish"`
}

//PublishZoneResponseBlock holds the response for a zone publish request
type PublishZoneResponseBlock struct {
	Status string               `json:"status"`
	Data   PublishZoneDataBlock `json:"data"`
	JobID  int                  `json:"job_id"`
	Msgs   string               `json:"-"`
}

// PublishZoneDataBlock holds the response data filed for a zone publish request
type PublishZoneDataBlock struct {
	TaskID      string `json:"task_id"`
	Serial      int    `json:"serial"`
	SerialStyle string `json:"serial_style"`
	Zone        string `json:"zone"`
	ZoneType    string `json:"zone_type"`
}

// TaskStateResponse hold the response body of a get one DNS task request
// https://help.dyn.com/get-one-dns-task-api/
type TaskStateResponse struct {
	Status   string                `json:"status"`
	Blocking bool                  `json:"blocking"`
	Data     TaskStateResponseData `json:"data"`
}

// TaskStateResponseData hold the response data of a get one DNS task request
type TaskStateResponseData struct {
	TaskID       string `json:"task_id"`
	Name         string `json:"name"`
	CustomerName string `json:"customer_name"`
	ZoneName     string `json:"zone_name"`
	Status       string `json:"status"`
	StepCount    int    `json:"step_count"`
	TotalSteps   int    `json:"total_steps"`
	Blocking     bool   `json:"blocking"`
	Debug        string `json:"blocking,omitempty"`
	CreateTS     int    `json:"created_ts"`
	ModifiedTS   int    `json:"modified_ts"`
}