-
Notifications
You must be signed in to change notification settings - Fork 30
/
infra_spine_p.go
94 lines (67 loc) · 2.19 KB
/
infra_spine_p.go
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
package models
import (
"fmt"
"strconv"
"github.com/ciscoecosystem/aci-go-client/container"
)
const InfraspinepClassName = "infraSpineP"
type SpineProfile struct {
BaseAttributes
SpineProfileAttributes
}
type SpineProfileAttributes struct {
Name string `json:",omitempty"`
Annotation string `json:",omitempty"`
NameAlias string `json:",omitempty"`
}
func NewSpineProfile(infraSpinePRn, parentDn, description string, infraSpinePattr SpineProfileAttributes) *SpineProfile {
dn := fmt.Sprintf("%s/%s", parentDn, infraSpinePRn)
return &SpineProfile{
BaseAttributes: BaseAttributes{
DistinguishedName: dn,
Description: description,
Status: "created, modified",
ClassName: InfraspinepClassName,
Rn: infraSpinePRn,
},
SpineProfileAttributes: infraSpinePattr,
}
}
func (infraSpineP *SpineProfile) ToMap() (map[string]string, error) {
infraSpinePMap, err := infraSpineP.BaseAttributes.ToMap()
if err != nil {
return nil, err
}
A(infraSpinePMap, "name", infraSpineP.Name)
A(infraSpinePMap, "annotation", infraSpineP.Annotation)
A(infraSpinePMap, "nameAlias", infraSpineP.NameAlias)
return infraSpinePMap, err
}
func SpineProfileFromContainerList(cont *container.Container, index int) *SpineProfile {
SpineProfileCont := cont.S("imdata").Index(index).S(InfraspinepClassName, "attributes")
return &SpineProfile{
BaseAttributes{
DistinguishedName: G(SpineProfileCont, "dn"),
Description: G(SpineProfileCont, "descr"),
Status: G(SpineProfileCont, "status"),
ClassName: InfraspinepClassName,
Rn: G(SpineProfileCont, "rn"),
},
SpineProfileAttributes{
Name: G(SpineProfileCont, "name"),
Annotation: G(SpineProfileCont, "annotation"),
NameAlias: G(SpineProfileCont, "nameAlias"),
},
}
}
func SpineProfileFromContainer(cont *container.Container) *SpineProfile {
return SpineProfileFromContainerList(cont, 0)
}
func SpineProfileListFromContainer(cont *container.Container) []*SpineProfile {
length, _ := strconv.Atoi(G(cont, "totalCount"))
arr := make([]*SpineProfile, length)
for i := 0; i < length; i++ {
arr[i] = SpineProfileFromContainerList(cont, i)
}
return arr
}