-
Notifications
You must be signed in to change notification settings - Fork 0
/
zpa_enrollmentcert.go
74 lines (66 loc) · 3.08 KB
/
zpa_enrollmentcert.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
package enrollmentcert
import (
"fmt"
"net/http"
"strings"
"github.com/SecurityGeekIO/zscaler-sdk-go/v2/zpa/services/common"
)
const (
mgmtConfig = "/mgmtconfig/v2/admin/customers/"
enrollmentCertEndpoint = "/enrollmentCert"
)
type EnrollmentCert struct {
AllowSigning bool `json:"allowSigning,omitempty"`
Cname string `json:"cName,omitempty"`
Certificate string `json:"certificate,omitempty"`
ClientCertType string `json:"clientCertType,omitempty"`
CreationTime string `json:"creationTime,omitempty"`
CSR string `json:"csr,omitempty"`
Description string `json:"description,omitempty"`
ID string `json:"id,omitempty"`
IssuedBy string `json:"issuedBy,omitempty"`
IssuedTo string `json:"issuedTo,omitempty"`
ModifiedBy string `json:"modifiedBy,omitempty"`
ModifiedTime string `json:"modifiedTime,omitempty"`
Name string `json:"name,omitempty"`
ParentCertID string `json:"parentCertId,omitempty"`
ParentCertName string `json:"parentCertName,omitempty"`
PrivateKey string `json:"privateKey,omitempty"`
PrivateKeyPresent bool `json:"privateKeyPresent,omitempty"`
SerialNo string `json:"serialNo,omitempty"`
ValidFromInEpochSec string `json:"validFromInEpochSec,omitempty"`
ValidToInEpochSec string `json:"validToInEpochSec,omitempty"`
ZrsaEncryptedPrivateKey string `json:"zrsaencryptedprivatekey,omitempty"`
ZrsaEncryptedSessionKey string `json:"zrsaencryptedsessionkey,omitempty"`
MicrotenantID string `json:"microtenantId,omitempty"`
}
func (service *Service) Get(id string) (*EnrollmentCert, *http.Response, error) {
v := new(EnrollmentCert)
relativeURL := fmt.Sprintf("%s/%s", mgmtConfig+service.Client.Config.CustomerID+enrollmentCertEndpoint, id)
resp, err := service.Client.NewRequestDo("GET", relativeURL, common.Filter{MicroTenantID: service.microTenantID}, nil, v)
if err != nil {
return nil, nil, err
}
return v, resp, nil
}
func (service *Service) GetByName(certName string) (*EnrollmentCert, *http.Response, error) {
relativeURL := mgmtConfig + service.Client.Config.CustomerID + enrollmentCertEndpoint
list, resp, err := common.GetAllPagesGenericWithCustomFilters[EnrollmentCert](service.Client, relativeURL, common.Filter{Search: certName, MicroTenantID: service.microTenantID})
if err != nil {
return nil, nil, err
}
for _, cert := range list {
if strings.EqualFold(cert.Name, certName) {
return &cert, resp, nil
}
}
return nil, resp, fmt.Errorf("no signing certificate named '%s' was found", certName)
}
func (service *Service) GetAll() ([]EnrollmentCert, *http.Response, error) {
relativeURL := mgmtConfig + service.Client.Config.CustomerID + enrollmentCertEndpoint
list, resp, err := common.GetAllPagesGenericWithCustomFilters[EnrollmentCert](service.Client, relativeURL, common.Filter{MicroTenantID: service.microTenantID})
if err != nil {
return nil, nil, err
}
return list, resp, nil
}