-
Notifications
You must be signed in to change notification settings - Fork 5
/
CreateCloudIdentityProvider.go
89 lines (78 loc) · 2.89 KB
/
CreateCloudIdentityProvider.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
package main
import (
"encoding/json"
"fmt"
"log"
"github.com/deploymenttheory/go-api-sdk-jamfpro/sdk/http_client" // Import http_client for logging
"github.com/deploymenttheory/go-api-sdk-jamfpro/sdk/jamfpro"
)
func main() {
// Define the path to the JSON configuration file
configFilePath := "/Users/dafyddwatkins/GitHub/deploymenttheory/go-api-sdk-jamfpro/clientauth.json"
// Load the client OAuth credentials from the configuration file
authConfig, err := jamfpro.LoadClientAuthConfig(configFilePath)
if err != nil {
log.Fatalf("Failed to load client OAuth configuration: %v", err)
}
// Instantiate the default logger and set the desired log level
logger := http_client.NewDefaultLogger()
logLevel := http_client.LogLevelDebug // LogLevelNone // LogLevelWarning // LogLevelInfo // LogLevelDebug
// Configuration for the jamfpro
config := jamfpro.Config{
InstanceName: authConfig.InstanceName,
OverrideBaseDomain: authConfig.OverrideBaseDomain,
LogLevel: logLevel,
Logger: logger,
ClientID: authConfig.ClientID,
ClientSecret: authConfig.ClientSecret,
}
// Create a new jamfpro client instance
client, err := jamfpro.NewClient(config)
if err != nil {
log.Fatalf("Failed to create Jamf Pro client: %v", err)
}
// Define the Cloud Identity Provider data
cloudIdPData := jamfpro.ResourceCloudIdp{
CloudIdPCommon: jamfpro.CloudIdpListItem{
DisplayName: "Cloud Identity Provider",
ProviderName: "AZURE",
},
Server: jamfpro.ResourceCloudIdpServer{
TenantId: "db65d325-0350-4a17-9af9-b302d0fc386b",
Enabled: true,
Migrated: true, // Note: Ensure this field is required as per your API's specification
Mappings: jamfpro.CloudIdpServerSubsetCloudIdpServerMappings{
UserId: "id",
UserName: "userPrincipalName",
RealName: "displayName",
Email: "mail",
Department: "department",
Building: "companyName",
Room: "officeLocation",
Phone: "mobilePhone",
Position: "jobTitle",
GroupId: "id",
GroupName: "displayName",
},
SearchTimeout: 30,
TransitiveMembershipEnabled: false,
TransitiveMembershipUserField: "userPrincipalName",
TransitiveDirectoryMembershipEnabled: false,
MembershipCalculationOptimizationEnabled: true,
Code: "auth",
},
}
// Create the Cloud Identity Provider
response, err := client.CreateCloudIdentityProvider(&cloudIdPData)
if err != nil {
fmt.Printf("Error creating Cloud Identity Provider: %s\n", err)
return
}
// Marshal the response into pretty JSON
prettyJSON, err := json.MarshalIndent(response, "", " ") // Indents with 4 spaces
if err != nil {
log.Fatalf("Failed to marshal response into JSON: %v", err)
}
// Output the pretty-printed JSON
fmt.Printf("Cloud Identity Provider Created:\n%s\n", string(prettyJSON))
}