-
Notifications
You must be signed in to change notification settings - Fork 82
/
update_data_guard_association_details.go
161 lines (136 loc) · 8.95 KB
/
update_data_guard_association_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
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
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
// 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.
// Database Service API
//
// The API for the Database Service. Use this API to manage resources such as databases and DB Systems. For more information, see Overview of the Database Service (https://docs.cloud.oracle.com/iaas/Content/Database/Concepts/databaseoverview.htm).
//
package database
import (
"fmt"
"github.com/oracle/oci-go-sdk/v65/common"
"strings"
)
// UpdateDataGuardAssociationDetails The configuration details for updating a Data Guard association for a database.
// **Warning:** Oracle recommends that you avoid using any confidential information when you supply string values using the API.
type UpdateDataGuardAssociationDetails struct {
// A strong password for the 'SYS', 'SYSTEM', and 'PDB Admin' users to apply during standby creation.
// The password must contain no fewer than nine characters and include:
// * At least two uppercase characters.
// * At least two lowercase characters.
// * At least two numeric characters.
// * At least two special characters. Valid special characters include "_", "#", and "-" only.
// **The password MUST be the same as the primary admin password.**
DatabaseAdminPassword *string `mandatory:"false" json:"databaseAdminPassword"`
// The protection mode for the Data Guard association's primary and standby database. For more information, see
// Oracle Data Guard Protection Modes (http://docs.oracle.com/database/122/SBYDB/oracle-data-guard-protection-modes.htm#SBYDB02000)
// in the Oracle Data Guard documentation.
ProtectionMode UpdateDataGuardAssociationDetailsProtectionModeEnum `mandatory:"false" json:"protectionMode,omitempty"`
// The redo transport type to use for this Data Guard association. Valid values depend on the specified 'protectionMode':
// * MAXIMUM_AVAILABILITY - Use SYNC or FASTSYNC
// * MAXIMUM_PERFORMANCE - Use ASYNC
// * MAXIMUM_PROTECTION - Use SYNC
// For more information, see
// Redo Transport Services (http://docs.oracle.com/database/122/SBYDB/oracle-data-guard-redo-transport-services.htm#SBYDB00400)
// in the Oracle Data Guard documentation.
TransportType UpdateDataGuardAssociationDetailsTransportTypeEnum `mandatory:"false" json:"transportType,omitempty"`
// True if active Data Guard is enabled. Update this parameter to change the Data Guard setting.
IsActiveDataGuardEnabled *bool `mandatory:"false" json:"isActiveDataGuardEnabled"`
}
func (m UpdateDataGuardAssociationDetails) 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 UpdateDataGuardAssociationDetails) ValidateEnumValue() (bool, error) {
errMessage := []string{}
if _, ok := GetMappingUpdateDataGuardAssociationDetailsProtectionModeEnum(string(m.ProtectionMode)); !ok && m.ProtectionMode != "" {
errMessage = append(errMessage, fmt.Sprintf("unsupported enum value for ProtectionMode: %s. Supported values are: %s.", m.ProtectionMode, strings.Join(GetUpdateDataGuardAssociationDetailsProtectionModeEnumStringValues(), ",")))
}
if _, ok := GetMappingUpdateDataGuardAssociationDetailsTransportTypeEnum(string(m.TransportType)); !ok && m.TransportType != "" {
errMessage = append(errMessage, fmt.Sprintf("unsupported enum value for TransportType: %s. Supported values are: %s.", m.TransportType, strings.Join(GetUpdateDataGuardAssociationDetailsTransportTypeEnumStringValues(), ",")))
}
if len(errMessage) > 0 {
return true, fmt.Errorf(strings.Join(errMessage, "\n"))
}
return false, nil
}
// UpdateDataGuardAssociationDetailsProtectionModeEnum Enum with underlying type: string
type UpdateDataGuardAssociationDetailsProtectionModeEnum string
// Set of constants representing the allowable values for UpdateDataGuardAssociationDetailsProtectionModeEnum
const (
UpdateDataGuardAssociationDetailsProtectionModeAvailability UpdateDataGuardAssociationDetailsProtectionModeEnum = "MAXIMUM_AVAILABILITY"
UpdateDataGuardAssociationDetailsProtectionModePerformance UpdateDataGuardAssociationDetailsProtectionModeEnum = "MAXIMUM_PERFORMANCE"
UpdateDataGuardAssociationDetailsProtectionModeProtection UpdateDataGuardAssociationDetailsProtectionModeEnum = "MAXIMUM_PROTECTION"
)
var mappingUpdateDataGuardAssociationDetailsProtectionModeEnum = map[string]UpdateDataGuardAssociationDetailsProtectionModeEnum{
"MAXIMUM_AVAILABILITY": UpdateDataGuardAssociationDetailsProtectionModeAvailability,
"MAXIMUM_PERFORMANCE": UpdateDataGuardAssociationDetailsProtectionModePerformance,
"MAXIMUM_PROTECTION": UpdateDataGuardAssociationDetailsProtectionModeProtection,
}
var mappingUpdateDataGuardAssociationDetailsProtectionModeEnumLowerCase = map[string]UpdateDataGuardAssociationDetailsProtectionModeEnum{
"maximum_availability": UpdateDataGuardAssociationDetailsProtectionModeAvailability,
"maximum_performance": UpdateDataGuardAssociationDetailsProtectionModePerformance,
"maximum_protection": UpdateDataGuardAssociationDetailsProtectionModeProtection,
}
// GetUpdateDataGuardAssociationDetailsProtectionModeEnumValues Enumerates the set of values for UpdateDataGuardAssociationDetailsProtectionModeEnum
func GetUpdateDataGuardAssociationDetailsProtectionModeEnumValues() []UpdateDataGuardAssociationDetailsProtectionModeEnum {
values := make([]UpdateDataGuardAssociationDetailsProtectionModeEnum, 0)
for _, v := range mappingUpdateDataGuardAssociationDetailsProtectionModeEnum {
values = append(values, v)
}
return values
}
// GetUpdateDataGuardAssociationDetailsProtectionModeEnumStringValues Enumerates the set of values in String for UpdateDataGuardAssociationDetailsProtectionModeEnum
func GetUpdateDataGuardAssociationDetailsProtectionModeEnumStringValues() []string {
return []string{
"MAXIMUM_AVAILABILITY",
"MAXIMUM_PERFORMANCE",
"MAXIMUM_PROTECTION",
}
}
// GetMappingUpdateDataGuardAssociationDetailsProtectionModeEnum performs case Insensitive comparison on enum value and return the desired enum
func GetMappingUpdateDataGuardAssociationDetailsProtectionModeEnum(val string) (UpdateDataGuardAssociationDetailsProtectionModeEnum, bool) {
enum, ok := mappingUpdateDataGuardAssociationDetailsProtectionModeEnumLowerCase[strings.ToLower(val)]
return enum, ok
}
// UpdateDataGuardAssociationDetailsTransportTypeEnum Enum with underlying type: string
type UpdateDataGuardAssociationDetailsTransportTypeEnum string
// Set of constants representing the allowable values for UpdateDataGuardAssociationDetailsTransportTypeEnum
const (
UpdateDataGuardAssociationDetailsTransportTypeSync UpdateDataGuardAssociationDetailsTransportTypeEnum = "SYNC"
UpdateDataGuardAssociationDetailsTransportTypeAsync UpdateDataGuardAssociationDetailsTransportTypeEnum = "ASYNC"
UpdateDataGuardAssociationDetailsTransportTypeFastsync UpdateDataGuardAssociationDetailsTransportTypeEnum = "FASTSYNC"
)
var mappingUpdateDataGuardAssociationDetailsTransportTypeEnum = map[string]UpdateDataGuardAssociationDetailsTransportTypeEnum{
"SYNC": UpdateDataGuardAssociationDetailsTransportTypeSync,
"ASYNC": UpdateDataGuardAssociationDetailsTransportTypeAsync,
"FASTSYNC": UpdateDataGuardAssociationDetailsTransportTypeFastsync,
}
var mappingUpdateDataGuardAssociationDetailsTransportTypeEnumLowerCase = map[string]UpdateDataGuardAssociationDetailsTransportTypeEnum{
"sync": UpdateDataGuardAssociationDetailsTransportTypeSync,
"async": UpdateDataGuardAssociationDetailsTransportTypeAsync,
"fastsync": UpdateDataGuardAssociationDetailsTransportTypeFastsync,
}
// GetUpdateDataGuardAssociationDetailsTransportTypeEnumValues Enumerates the set of values for UpdateDataGuardAssociationDetailsTransportTypeEnum
func GetUpdateDataGuardAssociationDetailsTransportTypeEnumValues() []UpdateDataGuardAssociationDetailsTransportTypeEnum {
values := make([]UpdateDataGuardAssociationDetailsTransportTypeEnum, 0)
for _, v := range mappingUpdateDataGuardAssociationDetailsTransportTypeEnum {
values = append(values, v)
}
return values
}
// GetUpdateDataGuardAssociationDetailsTransportTypeEnumStringValues Enumerates the set of values in String for UpdateDataGuardAssociationDetailsTransportTypeEnum
func GetUpdateDataGuardAssociationDetailsTransportTypeEnumStringValues() []string {
return []string{
"SYNC",
"ASYNC",
"FASTSYNC",
}
}
// GetMappingUpdateDataGuardAssociationDetailsTransportTypeEnum performs case Insensitive comparison on enum value and return the desired enum
func GetMappingUpdateDataGuardAssociationDetailsTransportTypeEnum(val string) (UpdateDataGuardAssociationDetailsTransportTypeEnum, bool) {
enum, ok := mappingUpdateDataGuardAssociationDetailsTransportTypeEnumLowerCase[strings.ToLower(val)]
return enum, ok
}