-
Notifications
You must be signed in to change notification settings - Fork 1
/
zpa_idp_controller.go
96 lines (86 loc) · 4.15 KB
/
zpa_idp_controller.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
package idpcontroller
import (
"fmt"
"net/http"
"github.com/zscaler/zscaler-sdk-go/zpa/services/common"
)
const (
mgmtConfig = "/mgmtconfig/v2/admin/customers/"
mgmtConfigV1 = "/mgmtconfig/v1/admin/customers/"
idpControllerEndpoint = "/idp"
)
type IdpController struct {
AdminSpSigningCertID string `json:"adminSpSigningCertId,omitempty"`
AutoProvision string `json:"autoProvision,omitempty"`
CreationTime string `json:"creationTime,omitempty"`
Description string `json:"description,omitempty"`
DisableSamlBasedPolicy bool `json:"disableSamlBasedPolicy"`
Domainlist []string `json:"domainList,omitempty"`
EnableScimBasedPolicy bool `json:"enableScimBasedPolicy"`
EnableArbitraryAuthDomains string `json:"enableArbitraryAuthDomains"`
Enabled bool `json:"enabled"`
ForceAuth bool `json:"forceAuth"`
ID string `json:"id,omitempty"`
IdpEntityID string `json:"idpEntityId,omitempty"`
LoginHint bool `json:"loginHint,omitempty"`
LoginNameAttribute string `json:"loginNameAttribute,omitempty"`
LoginURL string `json:"loginUrl,omitempty"`
ModifiedBy string `json:"modifiedBy,omitempty"`
ModifiedTime string `json:"modifiedTime,omitempty"`
Name string `json:"name,omitempty"`
ReauthOnUserUpdate bool `json:"reauthOnUserUpdate"`
RedirectBinding bool `json:"redirectBinding"`
ScimEnabled bool `json:"scimEnabled"`
ScimServiceProviderEndpoint string `json:"scimServiceProviderEndpoint,omitempty"`
ScimSharedSecretExists bool `json:"scimSharedSecretExists,omitempty"`
SignSamlRequest string `json:"signSamlRequest,,omitempty"`
SsoType []string `json:"ssoType,omitempty"`
UseCustomSpMetadata bool `json:"useCustomSPMetadata"`
UserSpSigningCertID string `json:"userSpSigningCertId,omitempty"`
AdminMetadata *AdminMetadata `json:"adminMetadata,omitempty"`
UserMetadata *UserMetadata `json:"userMetadata,omitempty"`
}
type AdminMetadata struct {
CertificateURL string `json:"certificateUrl"`
SpBaseURL string `json:"spBaseUrl"`
SpEntityID string `json:"spEntityId"`
SpMetadataURL string `json:"spMetadataUrl"`
SpPostURL string `json:"spPostUrl"`
}
type UserMetadata struct {
CertificateURL string `json:"certificateUrl,omitempty"`
SpBaseURL string `json:"spBaseUrl"`
SpEntityID string `json:"spEntityId,omitempty"`
SpMetadataURL string `json:"spMetadataUrl,omitempty"`
SpPostURL string `json:"spPostUrl,omitempty"`
}
func (service *Service) Get(IdpID string) (*IdpController, *http.Response, error) {
v := new(IdpController)
relativeURL := fmt.Sprintf("%s/%s", mgmtConfigV1+service.Client.Config.CustomerID+idpControllerEndpoint, IdpID)
resp, err := service.Client.NewRequestDo("GET", relativeURL, nil, nil, &v)
if err != nil {
return nil, nil, err
}
return v, resp, nil
}
func (service *Service) GetByName(idpName string) (*IdpController, *http.Response, error) {
relativeURL := fmt.Sprintf(mgmtConfig + service.Client.Config.CustomerID + idpControllerEndpoint)
list, resp, err := common.GetAllPagesGeneric[IdpController](service.Client, relativeURL, "")
if err != nil {
return nil, nil, err
}
for _, idpController := range list {
if idpController.Name == idpName {
return &idpController, resp, nil
}
}
return nil, resp, fmt.Errorf("no Idp-Controller named '%s' was found", idpName)
}
func (service *Service) GetAll() ([]IdpController, *http.Response, error) {
relativeURL := fmt.Sprintf(mgmtConfig + service.Client.Config.CustomerID + idpControllerEndpoint)
list, resp, err := common.GetAllPagesGeneric[IdpController](service.Client, relativeURL, "")
if err != nil {
return nil, nil, err
}
return list, resp, nil
}