/
create_data_guard_association_with_new_db_system_details.go
108 lines (88 loc) · 6.59 KB
/
create_data_guard_association_with_new_db_system_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
// Copyright (c) 2016, 2018, 2020, 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 (
"encoding/json"
"github.com/oracle/oci-go-sdk/common"
)
// CreateDataGuardAssociationWithNewDbSystemDetails The configuration details for creating a Data Guard association for a virtual machine DB system database. For this type of DB system database, the `creationType` should be `NewDbSystem`. A new DB system will be launched to create the standby database.
// To create a Data Guard association for a database in a bare metal or Exadata DB system, use the CreateDataGuardAssociationToExistingDbSystemDetails subtype instead.
type CreateDataGuardAssociationWithNewDbSystemDetails 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:"true" json:"databaseAdminPassword"`
// The user-friendly name of the DB system that will contain the the standby database. The display name does not have to be unique.
DisplayName *string `mandatory:"false" json:"displayName"`
// The name of the availability domain that the standby database DB system will be located in. For example- "Uocm:PHX-AD-1".
AvailabilityDomain *string `mandatory:"false" json:"availabilityDomain"`
// The virtual machine DB system shape to launch for the standby database in the Data Guard association. The shape determines the number of CPU cores and the amount of memory available for the DB system.
// Only virtual machine shapes are valid options. If you do not supply this parameter, the default shape is the shape of the primary DB system.
// To get a list of all shapes, use the ListDbSystemShapes operation.
Shape *string `mandatory:"false" json:"shape"`
// The OCID of the subnet the DB system is associated with.
// **Subnet Restrictions:**
// - For 1- and 2-node RAC DB systems, do not use a subnet that overlaps with 192.168.16.16/28
// These subnets are used by the Oracle Clusterware private interconnect on the database instance.
// Specifying an overlapping subnet will cause the private interconnect to malfunction.
// This restriction applies to both the client subnet and backup subnet.
SubnetId *string `mandatory:"false" json:"subnetId"`
// A list of the OCIDs (https://docs.cloud.oracle.com/Content/General/Concepts/identifiers.htm) of the network security groups (NSGs) that this resource belongs to. Setting this to an empty array after the list is created removes the resource from all NSGs. For more information about NSGs, see Security Rules (https://docs.cloud.oracle.com/Content/Network/Concepts/securityrules.htm).
// **NsgIds restrictions:**
// - Autonomous Databases with private access require at least 1 Network Security Group (NSG). The nsgIds array cannot be empty.
NsgIds []string `mandatory:"false" json:"nsgIds"`
// A list of the OCIDs (https://docs.cloud.oracle.com/Content/General/Concepts/identifiers.htm) of the network security groups (NSGs) that the backup network of this DB system belongs to. Setting this to an empty array after the list is created removes the resource from all NSGs. For more information about NSGs, see Security Rules (https://docs.cloud.oracle.com/Content/Network/Concepts/securityrules.htm). Applicable only to Exadata DB systems.
BackupNetworkNsgIds []string `mandatory:"false" json:"backupNetworkNsgIds"`
// The hostname for the DB node.
Hostname *string `mandatory:"false" json:"hostname"`
// The protection mode to set up between the primary and standby databases. 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.
// **IMPORTANT** - The only protection mode currently supported by the Database service is MAXIMUM_PERFORMANCE.
ProtectionMode CreateDataGuardAssociationDetailsProtectionModeEnum `mandatory:"true" json:"protectionMode"`
// The redo transport type to use for this Data Guard association. Valid values depend on the specified `protectionMode`:
// * MAXIMUM_AVAILABILITY - SYNC or FASTSYNC
// * MAXIMUM_PERFORMANCE - ASYNC
// * MAXIMUM_PROTECTION - 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.
// **IMPORTANT** - The only transport type currently supported by the Database service is ASYNC.
TransportType CreateDataGuardAssociationDetailsTransportTypeEnum `mandatory:"true" json:"transportType"`
}
//GetDatabaseAdminPassword returns DatabaseAdminPassword
func (m CreateDataGuardAssociationWithNewDbSystemDetails) GetDatabaseAdminPassword() *string {
return m.DatabaseAdminPassword
}
//GetProtectionMode returns ProtectionMode
func (m CreateDataGuardAssociationWithNewDbSystemDetails) GetProtectionMode() CreateDataGuardAssociationDetailsProtectionModeEnum {
return m.ProtectionMode
}
//GetTransportType returns TransportType
func (m CreateDataGuardAssociationWithNewDbSystemDetails) GetTransportType() CreateDataGuardAssociationDetailsTransportTypeEnum {
return m.TransportType
}
func (m CreateDataGuardAssociationWithNewDbSystemDetails) String() string {
return common.PointerString(m)
}
// MarshalJSON marshals to json representation
func (m CreateDataGuardAssociationWithNewDbSystemDetails) MarshalJSON() (buff []byte, e error) {
type MarshalTypeCreateDataGuardAssociationWithNewDbSystemDetails CreateDataGuardAssociationWithNewDbSystemDetails
s := struct {
DiscriminatorParam string `json:"creationType"`
MarshalTypeCreateDataGuardAssociationWithNewDbSystemDetails
}{
"NewDbSystem",
(MarshalTypeCreateDataGuardAssociationWithNewDbSystemDetails)(m),
}
return json.Marshal(&s)
}