// This is an automatically generated code sample.
// To make this code sample work in your Oracle Cloud tenancy,
// please replace the values for any parameters whose current values do not fit
// your use case (such as resource IDs, strings containing ‘EXAMPLE’ or ‘unique_id’, and
// boolean, number, and enum parameters with values not fitting your use case).

package main

import (
	"context"
	"fmt"

	"github.com/oracle/oci-go-sdk/v65/common"
	"github.com/oracle/oci-go-sdk/v65/distributeddatabase"
	"github.com/oracle/oci-go-sdk/v65/example/helpers"
)

func ExampleCreateDistributedAutonomousDatabase() {
	// Create a default authentication provider that uses the DEFAULT
	// profile in the configuration file.
	// Refer to <see href="https://docs.cloud.oracle.com/en-us/iaas/Content/API/Concepts/sdkconfig.htm#SDK_and_CLI_Configuration_File>the public documentation</see> on how to prepare a configuration file.
	client, err := distributeddatabase.NewDistributedAutonomousDbServiceClientWithConfigurationProvider(common.DefaultConfigProvider())
	helpers.FatalIfError(err)

	// Create a request and dependent object(s).

	req := distributeddatabase.CreateDistributedAutonomousDatabaseRequest{OpcRetryToken: common.String("EXAMPLE-opcRetryToken-Value"),
		CreateDistributedAutonomousDatabaseDetails: distributeddatabase.CreateDistributedAutonomousDatabaseDetails{ShardingMethod: distributeddatabase.CreateDistributedAutonomousDatabaseDetailsShardingMethodUser,
			NcharacterSet: common.String("EXAMPLE-ncharacterSet-Value"),
			CharacterSet:  common.String("EXAMPLE-characterSet-Value"),
			CompartmentId: common.String("ocid1.test.oc1..<unique_ID>EXAMPLE-compartmentId-Value"),
			DbBackupConfig: &distributeddatabase.DistributedAutonomousDbBackupConfig{RecoveryWindowInDays: common.Int(85),
				BackupDestinationDetails: []distributeddatabase.DistributedAutonomousDbBackupDestination{distributeddatabase.DistributedAutonomousDbBackupDestination{Id: common.String("ocid1.test.oc1..<unique_ID>EXAMPLE-id-Value"),
					InternetProxy: common.String("EXAMPLE-internetProxy-Value"),
					IsRemote:      common.Bool(true),
					RemoteRegion:  common.String("EXAMPLE-remoteRegion-Value"),
					Type:          distributeddatabase.DistributedAutonomousDbBackupDestinationTypeNfs,
					VpcPassword:   common.String("EXAMPLE-vpcPassword-Value"),
					VpcUser:       common.String("EXAMPLE-vpcUser-Value"),
					DbrsPolicyId:  common.String("ocid1.test.oc1..<unique_ID>EXAMPLE-dbrsPolicyId-Value")}}},
			DisplayName:     common.String("EXAMPLE-displayName-Value"),
			ListenerPort:    common.Int(34637),
			OnsPortLocal:    common.Int(13368),
			DatabaseVersion: common.String("EXAMPLE-databaseVersion-Value"),
			ListenerPortTls: common.Int(33651),
			OnsPortRemote:   common.Int(16293),
			Prefix:          common.String("3We"),
			ReplicationUnit: common.Int(786),
			CatalogDetails: []distributeddatabase.CreateDistributedAutonomousDatabaseCatalogDetails{distributeddatabase.CreateDistributedAutonomousDatabaseCatalogWithDedicatedInfraDetails{CloudAutonomousVmClusterId: common.String("ocid1.test.oc1..<unique_ID>EXAMPLE-cloudAutonomousVmClusterId-Value"),
				IsAutoScalingEnabled:            common.Bool(true),
				OkvEndPointGroup:                common.String("EXAMPLE-okvEndPointGroup-Value"),
				OkvKeyStoreId:                   common.String("ocid1.test.oc1..<unique_ID>EXAMPLE-okvKeyStoreId-Value"),
				PeerCloudAutonomousVmClusterIds: []string{"EXAMPLE--Value"},
				AdminPassword:                   common.String("EXAMPLE-adminPassword-Value"),
				ComputeCount:                    common.Float32(2831.698),
				DataStorageSizeInGbs:            common.Float64(4167.837),
				KmsKeyId:                        common.String("ocid1.test.oc1..<unique_ID>EXAMPLE-kmsKeyId-Value"),
				KmsKeyVersionId:                 common.String("ocid1.test.oc1..<unique_ID>EXAMPLE-kmsKeyVersionId-Value"),
				PeerDetails: []distributeddatabase.CreateCatalogPeerWithDedicatedInfraDetails{distributeddatabase.CreateCatalogPeerWithDedicatedInfraDetails{CloudAutonomousVmClusterId: common.String("ocid1.test.oc1..<unique_ID>EXAMPLE-cloudAutonomousVmClusterId-Value"),
					FastStartFailOverLagLimitInSeconds: common.Int(2587),
					IsAutomaticFailoverEnabled:         common.Bool(true),
					ProtectionMode:                     distributeddatabase.DistributedAutonomousDbProtectionModeMaximumPerformance,
					StandbyMaintenanceBufferInDays:     common.Int(1)}},
				VaultId: common.String("ocid1.test.oc1..<unique_ID>EXAMPLE-vaultId-Value")}},
			Chunks:           common.Int(228),
			DbDeploymentType: distributeddatabase.CreateDistributedAutonomousDatabaseDetailsDbDeploymentTypeAdbD,
			ShardDetails: []distributeddatabase.CreateDistributedAutonomousDatabaseShardDetails{distributeddatabase.CreateDistributedAutonomousDatabaseShardWithDedicatedInfraDetails{AdminPassword: common.String("EXAMPLE-adminPassword-Value"),
				CloudAutonomousVmClusterId:      common.String("ocid1.test.oc1..<unique_ID>EXAMPLE-cloudAutonomousVmClusterId-Value"),
				ComputeCount:                    common.Float32(2242.4531),
				KmsKeyVersionId:                 common.String("ocid1.test.oc1..<unique_ID>EXAMPLE-kmsKeyVersionId-Value"),
				OkvEndPointGroup:                common.String("EXAMPLE-okvEndPointGroup-Value"),
				OkvKeyStoreId:                   common.String("ocid1.test.oc1..<unique_ID>EXAMPLE-okvKeyStoreId-Value"),
				ShardSpace:                      common.String("EXAMPLE-shardSpace-Value"),
				VaultId:                         common.String("ocid1.test.oc1..<unique_ID>EXAMPLE-vaultId-Value"),
				DataStorageSizeInGbs:            common.Float64(5388.616),
				IsAutoScalingEnabled:            common.Bool(true),
				KmsKeyId:                        common.String("ocid1.test.oc1..<unique_ID>EXAMPLE-kmsKeyId-Value"),
				PeerCloudAutonomousVmClusterIds: []string{"EXAMPLE--Value"},
				PeerDetails: []distributeddatabase.CreateShardPeerWithDedicatedInfraDetails{distributeddatabase.CreateShardPeerWithDedicatedInfraDetails{CloudAutonomousVmClusterId: common.String("ocid1.test.oc1..<unique_ID>EXAMPLE-cloudAutonomousVmClusterId-Value"),
					FastStartFailOverLagLimitInSeconds: common.Int(1826),
					IsAutomaticFailoverEnabled:         common.Bool(true),
					ProtectionMode:                     distributeddatabase.DistributedAutonomousDbProtectionModeMaximumAvailability,
					StandbyMaintenanceBufferInDays:     common.Int(1)}}}},
			DbWorkload:         distributeddatabase.CreateDistributedAutonomousDatabaseDetailsDbWorkloadOltp,
			DefinedTags:        map[string]map[string]interface{}{"EXAMPLE_KEY_Kgwqq": map[string]interface{}{"EXAMPLE_KEY_qEk5c": "EXAMPLE--Value"}},
			FreeformTags:       map[string]string{"EXAMPLE_KEY_6kcqi": "EXAMPLE_VALUE_3ga9mOBhNRbI0OoJsWxS"},
			PrivateEndpointIds: []string{"EXAMPLE--Value"},
			ReplicationFactor:  common.Int(3),
			ReplicationMethod:  distributeddatabase.CreateDistributedAutonomousDatabaseDetailsReplicationMethodDg},
		OpcRequestId: common.String("WRPU7HZOTHLE38RAKRL8<unique_ID>")}

	// Send the request using the service client
	resp, err := client.CreateDistributedAutonomousDatabase(context.Background(), req)
	helpers.FatalIfError(err)

	// Retrieve value from the response.
	fmt.Println(resp)
}