forked from netbox-community/go-netbox
-
Notifications
You must be signed in to change notification settings - Fork 0
Expand file tree
/
Copy pathdcim_sites.go
More file actions
74 lines (66 loc) · 2.16 KB
/
dcim_sites.go
File metadata and controls
74 lines (66 loc) · 2.16 KB
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
// Copyright 2016 The go-netbox Authors.
//
// Licensed under the Apache License, Version 2.0 (the "License");
// you may not use this file except in compliance with the License.
// You may obtain a copy of the License at
//
// http://www.apache.org/licenses/LICENSE-2.0
//
// Unless required by applicable law or agreed to in writing, software
// distributed under the License is distributed on an "AS IS" BASIS,
// WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
// See the License for the specific language governing permissions and
// limitations under the License.
package netbox
import (
"fmt"
"net/http"
)
// A Site is a physical location where devices may reside.
type Site struct {
ID int `json:"id"`
Name string `json:"name"`
Slug string `json:"slug"`
Facility string `json:"facility"`
ASN ASN `json:"asn"`
PhysicalAddress string `json:"physical_address"`
ShippingAddress string `json:"shipping_address"`
Comments string `json:"comments"`
CountPrefixes int `json:"count_prefixes"`
CountVLANs int `json:"count_vlans"`
CountRacks int `json:"count_racks"`
CountDevices int `json:"count_devices"`
CountCircuits int `json:"count_circuits"`
}
// A SiteIdentifier is a reduced version of a Site, returned as a nested
// object in some top-level objects. It contains information which can
// be used in subsequent API calls to identify and retrieve a full Site.
type SiteIdentifier struct {
ID int `json:"id"`
Name string `json:"name"`
Slug string `json:"slug"`
}
// GetSite retrieves a Site object from NetBox by its ID.
func (s *DCIMService) GetSite(id int) (*Site, error) {
req, err := s.c.newRequest(
http.MethodGet,
fmt.Sprintf("/api/dcim/sites/%d", id),
nil,
)
if err != nil {
return nil, err
}
st := new(Site)
err = s.c.do(req, st)
return st, err
}
// ListSites retrives a list of Site objects from NetBox.
func (s *DCIMService) ListSites() ([]*Site, error) {
req, err := s.c.newRequest(http.MethodGet, "/api/dcim/sites/", nil)
if err != nil {
return nil, err
}
var sts []*Site
err = s.c.do(req, &sts)
return sts, err
}