-
Notifications
You must be signed in to change notification settings - Fork 30
/
aaa_saml_enc_cert.go
105 lines (95 loc) · 3.6 KB
/
aaa_saml_enc_cert.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
95
96
97
98
99
100
101
102
103
104
105
package models
import (
"fmt"
"strconv"
"github.com/ciscoecosystem/aci-go-client/container"
)
const (
DnaaaSamlEncCert = "uni/userext/samlext/samlenccert-%s"
RnaaaSamlEncCert = "samlenccert-%s"
ParentDnaaaSamlEncCert = "uni/userext/samlext"
AaasamlenccertClassName = "aaaSamlEncCert"
)
type KeypairforSAMLEncryption struct {
BaseAttributes
NameAliasAttribute
KeypairforSAMLEncryptionAttributes
}
type KeypairforSAMLEncryptionAttributes struct {
Annotation string `json:",omitempty"`
Name string `json:",omitempty"`
Regenerate string `json:",omitempty"`
Cert string `json:",omitempty"`
CertValidUntil string `json:",omitempty"`
ExpState string `json:",omitempty"`
}
func NewKeypairforSAMLEncryption(aaaSamlEncCertRn, parentDn, description, nameAlias string, aaaSamlEncCertAttr KeypairforSAMLEncryptionAttributes) *KeypairforSAMLEncryption {
dn := fmt.Sprintf("%s/%s", parentDn, aaaSamlEncCertRn)
return &KeypairforSAMLEncryption{
BaseAttributes: BaseAttributes{
DistinguishedName: dn,
Description: description,
Status: "created, modified",
ClassName: AaasamlenccertClassName,
Rn: aaaSamlEncCertRn,
},
NameAliasAttribute: NameAliasAttribute{
NameAlias: nameAlias,
},
KeypairforSAMLEncryptionAttributes: aaaSamlEncCertAttr,
}
}
func (aaaSamlEncCert *KeypairforSAMLEncryption) ToMap() (map[string]string, error) {
aaaSamlEncCertMap, err := aaaSamlEncCert.BaseAttributes.ToMap()
if err != nil {
return nil, err
}
alias, err := aaaSamlEncCert.NameAliasAttribute.ToMap()
if err != nil {
return nil, err
}
for key, value := range alias {
A(aaaSamlEncCertMap, key, value)
}
A(aaaSamlEncCertMap, "annotation", aaaSamlEncCert.Annotation)
A(aaaSamlEncCertMap, "name", aaaSamlEncCert.Name)
A(aaaSamlEncCertMap, "regenerate", aaaSamlEncCert.Regenerate)
A(aaaSamlEncCertMap, "cert", aaaSamlEncCert.Cert)
A(aaaSamlEncCertMap, "certValidUntil", aaaSamlEncCert.CertValidUntil)
A(aaaSamlEncCertMap, "expState", aaaSamlEncCert.ExpState)
return aaaSamlEncCertMap, err
}
func KeypairforSAMLEncryptionFromContainerList(cont *container.Container, index int) *KeypairforSAMLEncryption {
KeypairforSAMLEncryptionCont := cont.S("imdata").Index(index).S(AaasamlenccertClassName, "attributes")
return &KeypairforSAMLEncryption{
BaseAttributes{
DistinguishedName: G(KeypairforSAMLEncryptionCont, "dn"),
Description: G(KeypairforSAMLEncryptionCont, "descr"),
Status: G(KeypairforSAMLEncryptionCont, "status"),
ClassName: AaasamlenccertClassName,
Rn: G(KeypairforSAMLEncryptionCont, "rn"),
},
NameAliasAttribute{
NameAlias: G(KeypairforSAMLEncryptionCont, "nameAlias"),
},
KeypairforSAMLEncryptionAttributes{
Annotation: G(KeypairforSAMLEncryptionCont, "annotation"),
Name: G(KeypairforSAMLEncryptionCont, "name"),
Regenerate: G(KeypairforSAMLEncryptionCont, "regenerate"),
Cert: G(KeypairforSAMLEncryptionCont, "cert"),
CertValidUntil: G(KeypairforSAMLEncryptionCont, "certValidUntil"),
ExpState: G(KeypairforSAMLEncryptionCont, "expState"),
},
}
}
func KeypairforSAMLEncryptionFromContainer(cont *container.Container) *KeypairforSAMLEncryption {
return KeypairforSAMLEncryptionFromContainerList(cont, 0)
}
func KeypairforSAMLEncryptionListFromContainer(cont *container.Container) []*KeypairforSAMLEncryption {
length, _ := strconv.Atoi(G(cont, "totalCount"))
arr := make([]*KeypairforSAMLEncryption, length)
for i := 0; i < length; i++ {
arr[i] = KeypairforSAMLEncryptionFromContainerList(cont, i)
}
return arr
}