-
Notifications
You must be signed in to change notification settings - Fork 82
/
create_operator_control_details.go
84 lines (64 loc) · 4.46 KB
/
create_operator_control_details.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
// Copyright (c) 2016, 2018, 2024, Oracle and/or its affiliates. All rights reserved.
// This software is dual-licensed to you under the Universal Permissive License (UPL) 1.0 as shown at https://oss.oracle.com/licenses/upl or Apache License 2.0 as shown at http://www.apache.org/licenses/LICENSE-2.0. You may choose either license.
// Code generated. DO NOT EDIT.
// OperatorAccessControl API
//
// Operator Access Control enables you to control the time duration and the actions an Oracle operator can perform on your Exadata Cloud@Customer infrastructure.
// Using logging service, you can view a near real-time audit report of all actions performed by an Oracle operator.
// Use the table of contents and search tool to explore the OperatorAccessControl API.
//
package operatoraccesscontrol
import (
"fmt"
"github.com/oracle/oci-go-sdk/v65/common"
"strings"
)
// CreateOperatorControlDetails While creating the operator control, specify how operator actions are approved and the users who have the privilege of approving the operator actions associated with the Operator Control.
// You must specify which operator actions must be pre-approved. The rest of the operator actions associated with the Operator Control will require an explicit approval from the users selected either through the approver groups or individually.
// You must name your Operator Control appropriately so it reflects the resources that will be governed by the Operator Control. Neither the Operator Controls nor their assignments to resources are visible to the Oracle operators.
type CreateOperatorControlDetails struct {
// Name of the operator control.
OperatorControlName *string `mandatory:"true" json:"operatorControlName"`
// List of user groups who can approve an access request associated with a resource governed by this operator control.
ApproverGroupsList []string `mandatory:"true" json:"approverGroupsList"`
// Whether all the operator actions have been pre-approved. If yes, all access requests associated with a resource governed by this operator control
// will be auto-approved.
IsFullyPreApproved *bool `mandatory:"true" json:"isFullyPreApproved"`
// resourceType for which the OperatorControl is applicable
ResourceType ResourceTypesEnum `mandatory:"true" json:"resourceType"`
// The OCID of the compartment that contains this operator control.
CompartmentId *string `mandatory:"true" json:"compartmentId"`
// Description of the operator control.
Description *string `mandatory:"false" json:"description"`
// List of users who can approve an access request associated with a resource governed by this operator control.
ApproversList []string `mandatory:"false" json:"approversList"`
// List of pre-approved operator actions. Access requests associated with a resource governed by this operator control will be
// auto-approved if the access request only contain operator actions in the pre-approved list.
PreApprovedOpActionList []string `mandatory:"false" json:"preApprovedOpActionList"`
// Number of approvers required to approve an access request.
NumberOfApprovers *int `mandatory:"false" json:"numberOfApprovers"`
// List of emailId.
EmailIdList []string `mandatory:"false" json:"emailIdList"`
// This is the message that will be displayed to the operator users while accessing the system.
SystemMessage *string `mandatory:"false" json:"systemMessage"`
// Simple key-value pair that is applied without any predefined name, type or scope. Exists for cross-compatibility only.
FreeformTags map[string]string `mandatory:"false" json:"freeformTags"`
// Defined tags for this resource. Each key is predefined and scoped to a namespace.
DefinedTags map[string]map[string]interface{} `mandatory:"false" json:"definedTags"`
}
func (m CreateOperatorControlDetails) String() string {
return common.PointerString(m)
}
// ValidateEnumValue returns an error when providing an unsupported enum value
// This function is being called during constructing API request process
// Not recommended for calling this function directly
func (m CreateOperatorControlDetails) ValidateEnumValue() (bool, error) {
errMessage := []string{}
if _, ok := GetMappingResourceTypesEnum(string(m.ResourceType)); !ok && m.ResourceType != "" {
errMessage = append(errMessage, fmt.Sprintf("unsupported enum value for ResourceType: %s. Supported values are: %s.", m.ResourceType, strings.Join(GetResourceTypesEnumStringValues(), ",")))
}
if len(errMessage) > 0 {
return true, fmt.Errorf(strings.Join(errMessage, "\n"))
}
return false, nil
}