-
Notifications
You must be signed in to change notification settings - Fork 82
/
group.go
140 lines (117 loc) · 6.84 KB
/
group.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
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
// Copyright (c) 2016, 2018, 2023, 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.
// Identity and Access Management Service API
//
// Use the Identity and Access Management Service API to manage users, groups, identity domains, compartments, policies, tagging, and limits. For information about managing users, groups, compartments, and policies, see Identity and Access Management (without identity domains) (https://docs.cloud.oracle.com/iaas/Content/Identity/Concepts/overview.htm). For information about tagging and service limits, see Tagging (https://docs.cloud.oracle.com/iaas/Content/Tagging/Concepts/taggingoverview.htm) and Service Limits (https://docs.cloud.oracle.com/iaas/Content/General/Concepts/servicelimits.htm). For information about creating, modifying, and deleting identity domains, see Identity and Access Management (with identity domains) (https://docs.cloud.oracle.com/iaas/Content/Identity/home.htm).
//
package identity
import (
"fmt"
"github.com/oracle/oci-go-sdk/v65/common"
"strings"
)
// Group A collection of users who all need the same type of access to a particular set of resources or compartment.
// For conceptual information about groups and other IAM Service components, see
// Overview of IAM (https://docs.cloud.oracle.com/Content/Identity/getstarted/identity-domains.htm).
// If you're federating with an identity provider (IdP), you need to create mappings between the groups
// defined in the IdP and groups you define in the IAM service. For more information, see
// Identity Providers and Federation (https://docs.cloud.oracle.com/Content/Identity/Concepts/federation.htm). Also see
// IdentityProvider and
// IdpGroupMapping.
// To use any of the API operations, you must be authorized in an IAM policy. If you're not authorized,
// talk to an administrator. If you're an administrator who needs to write policies to give users access,
// see Get Started with Policies (https://docs.cloud.oracle.com/Content/Identity/policiesgs/get-started-with-policies.htm).
// **Warning:** Oracle recommends that you avoid using any confidential information when you supply string values
// using the API.
type Group struct {
// The OCID of the group.
Id *string `mandatory:"true" json:"id"`
// The OCID of the tenancy containing the group.
CompartmentId *string `mandatory:"true" json:"compartmentId"`
// The name you assign to the group during creation. The name must be unique across all groups in
// the tenancy and cannot be changed.
Name *string `mandatory:"true" json:"name"`
// The description you assign to the group. Does not have to be unique, and it's changeable.
// (For tenancies that support identity domains) You can have an empty description.
Description *string `mandatory:"true" json:"description"`
// Date and time the group was created, in the format defined by RFC3339.
// Example: `2016-08-25T21:10:29.600Z`
TimeCreated *common.SDKTime `mandatory:"true" json:"timeCreated"`
// The group's current state. After creating a group, make sure its `lifecycleState` changes from CREATING to
// ACTIVE before using it.
LifecycleState GroupLifecycleStateEnum `mandatory:"true" json:"lifecycleState"`
// The detailed status of INACTIVE lifecycleState.
InactiveStatus *int64 `mandatory:"false" json:"inactiveStatus"`
// Free-form tags for this resource. Each tag is a simple key-value pair with no predefined name, type, or namespace.
// For more information, see Resource Tags (https://docs.cloud.oracle.com/Content/General/Concepts/resourcetags.htm).
// Example: `{"Department": "Finance"}`
FreeformTags map[string]string `mandatory:"false" json:"freeformTags"`
// Defined tags for this resource. Each key is predefined and scoped to a namespace.
// For more information, see Resource Tags (https://docs.cloud.oracle.com/Content/General/Concepts/resourcetags.htm).
// Example: `{"Operations": {"CostCenter": "42"}}`
DefinedTags map[string]map[string]interface{} `mandatory:"false" json:"definedTags"`
}
func (m Group) 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 Group) ValidateEnumValue() (bool, error) {
errMessage := []string{}
if _, ok := GetMappingGroupLifecycleStateEnum(string(m.LifecycleState)); !ok && m.LifecycleState != "" {
errMessage = append(errMessage, fmt.Sprintf("unsupported enum value for LifecycleState: %s. Supported values are: %s.", m.LifecycleState, strings.Join(GetGroupLifecycleStateEnumStringValues(), ",")))
}
if len(errMessage) > 0 {
return true, fmt.Errorf(strings.Join(errMessage, "\n"))
}
return false, nil
}
// GroupLifecycleStateEnum Enum with underlying type: string
type GroupLifecycleStateEnum string
// Set of constants representing the allowable values for GroupLifecycleStateEnum
const (
GroupLifecycleStateCreating GroupLifecycleStateEnum = "CREATING"
GroupLifecycleStateActive GroupLifecycleStateEnum = "ACTIVE"
GroupLifecycleStateInactive GroupLifecycleStateEnum = "INACTIVE"
GroupLifecycleStateDeleting GroupLifecycleStateEnum = "DELETING"
GroupLifecycleStateDeleted GroupLifecycleStateEnum = "DELETED"
)
var mappingGroupLifecycleStateEnum = map[string]GroupLifecycleStateEnum{
"CREATING": GroupLifecycleStateCreating,
"ACTIVE": GroupLifecycleStateActive,
"INACTIVE": GroupLifecycleStateInactive,
"DELETING": GroupLifecycleStateDeleting,
"DELETED": GroupLifecycleStateDeleted,
}
var mappingGroupLifecycleStateEnumLowerCase = map[string]GroupLifecycleStateEnum{
"creating": GroupLifecycleStateCreating,
"active": GroupLifecycleStateActive,
"inactive": GroupLifecycleStateInactive,
"deleting": GroupLifecycleStateDeleting,
"deleted": GroupLifecycleStateDeleted,
}
// GetGroupLifecycleStateEnumValues Enumerates the set of values for GroupLifecycleStateEnum
func GetGroupLifecycleStateEnumValues() []GroupLifecycleStateEnum {
values := make([]GroupLifecycleStateEnum, 0)
for _, v := range mappingGroupLifecycleStateEnum {
values = append(values, v)
}
return values
}
// GetGroupLifecycleStateEnumStringValues Enumerates the set of values in String for GroupLifecycleStateEnum
func GetGroupLifecycleStateEnumStringValues() []string {
return []string{
"CREATING",
"ACTIVE",
"INACTIVE",
"DELETING",
"DELETED",
}
}
// GetMappingGroupLifecycleStateEnum performs case Insensitive comparison on enum value and return the desired enum
func GetMappingGroupLifecycleStateEnum(val string) (GroupLifecycleStateEnum, bool) {
enum, ok := mappingGroupLifecycleStateEnumLowerCase[strings.ToLower(val)]
return enum, ok
}