// 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).

using System;
using System.Collections.Generic;
using System.Threading.Tasks;
using Oci.DistributeddatabaseService;
using Oci.Common;
using Oci.Common.Auth;

namespace Oci.Sdk.DotNet.Example.Distributeddatabase
{
    public class CreateDistributedDatabaseExample
    {
        public static async Task Main()
        {
            // Create a request and dependent object(s).
			var createDistributedDatabaseDetails = new Oci.DistributeddatabaseService.Models.CreateDistributedDatabaseDetails
			{
				CompartmentId = "ocid1.test.oc1..<unique_ID>EXAMPLE-compartmentId-Value",
				DisplayName = "EXAMPLE-displayName-Value",
				DatabaseVersion = "EXAMPLE-databaseVersion-Value",
				Prefix = "fuC",
				PrivateEndpointIds = new List<string>
				{
					"EXAMPLE--Value"
				},
				ShardingMethod = Oci.DistributeddatabaseService.Models.CreateDistributedDatabaseDetails.ShardingMethodEnum.User,
				CharacterSet = "EXAMPLE-characterSet-Value",
				NcharacterSet = "EXAMPLE-ncharacterSet-Value",
				Chunks = 732,
				ListenerPort = 62582,
				ListenerPortTls = 63460,
				OnsPortLocal = 17025,
				OnsPortRemote = 24926,
				ReplicationMethod = Oci.DistributeddatabaseService.Models.CreateDistributedDatabaseDetails.ReplicationMethodEnum.Dg,
				ReplicationFactor = 4,
				ReplicationUnit = 371,
				DbDeploymentType = Oci.DistributeddatabaseService.Models.CreateDistributedDatabaseDetails.DbDeploymentTypeEnum.ExadbXs,
				ShardDetails = new List<Oci.DistributeddatabaseService.Models.CreateDistributedDatabaseShardDetails>
				{
					new Oci.DistributeddatabaseService.Models.CreateDistributedDatabaseShardWithExadbXsDetails
					{
						VmClusterId = "ocid1.test.oc1..<unique_ID>EXAMPLE-vmClusterId-Value",
						AdminPassword = "EXAMPLE-adminPassword-Value",
						PeerVmClusterIds = new List<string>
						{
							"EXAMPLE--Value"
						},
						ShardSpace = "EXAMPLE-shardSpace-Value",
						VaultId = "ocid1.test.oc1..<unique_ID>EXAMPLE-vaultId-Value",
						KmsKeyId = "ocid1.test.oc1..<unique_ID>EXAMPLE-kmsKeyId-Value",
						KmsKeyVersionId = "ocid1.test.oc1..<unique_ID>EXAMPLE-kmsKeyVersionId-Value"
					}
				},
				CatalogDetails = new List<Oci.DistributeddatabaseService.Models.CreateDistributedDatabaseCatalogDetails>
				{
					new Oci.DistributeddatabaseService.Models.CreateDistributedDatabaseCatalogWithExadbXsDetails
					{
						VmClusterId = "ocid1.test.oc1..<unique_ID>EXAMPLE-vmClusterId-Value",
						AdminPassword = "EXAMPLE-adminPassword-Value",
						PeerVmClusterIds = new List<string>
						{
							"EXAMPLE--Value"
						},
						ShardSpace = "EXAMPLE-shardSpace-Value",
						VaultId = "ocid1.test.oc1..<unique_ID>EXAMPLE-vaultId-Value",
						KmsKeyId = "ocid1.test.oc1..<unique_ID>EXAMPLE-kmsKeyId-Value",
						KmsKeyVersionId = "ocid1.test.oc1..<unique_ID>EXAMPLE-kmsKeyVersionId-Value"
					}
				},
				GsmSshPublicKey = "EXAMPLE-gsmSshPublicKey-Value",
				DbBackupConfig = new Oci.DistributeddatabaseService.Models.DistributedDbBackupConfig
				{
					IsAutoBackupEnabled = false,
					RecoveryWindowInDays = 56,
					AutoBackupWindow = Oci.DistributeddatabaseService.Models.DistributedDbBackupConfig.AutoBackupWindowEnum.SlotTen,
					AutoFullBackupWindow = Oci.DistributeddatabaseService.Models.DistributedDbBackupConfig.AutoFullBackupWindowEnum.SlotNine,
					AutoFullBackupDay = Oci.DistributeddatabaseService.Models.DistributedDbBackupConfig.AutoFullBackupDayEnum.Wednesday,
					CanRunImmediateFullBackup = true,
					IsRemoteBackupEnabled = false,
					RemoteRegion = "EXAMPLE-remoteRegion-Value",
					BackupDestinationDetails = new List<Oci.DistributeddatabaseService.Models.DistributedDbBackupDestination>
					{
						new Oci.DistributeddatabaseService.Models.DistributedDbBackupDestination
						{
							Type = Oci.DistributeddatabaseService.Models.DistributedDbBackupDestination.TypeEnum.ObjectStore,
							Id = "ocid1.test.oc1..<unique_ID>EXAMPLE-id-Value",
							VpcUser = "EXAMPLE-vpcUser-Value",
							VpcPassword = "EXAMPLE-vpcPassword-Value",
							IsZeroDataLossEnabled = true,
							InternetProxy = "EXAMPLE-internetProxy-Value",
							DbrsPolicyId = "ocid1.test.oc1..<unique_ID>EXAMPLE-dbrsPolicyId-Value",
							IsRemote = true,
							RemoteRegion = "EXAMPLE-remoteRegion-Value"
						}
					},
					BackupDeletionPolicy = Oci.DistributeddatabaseService.Models.DistributedDbBackupConfig.BackupDeletionPolicyEnum.DeleteImmediately
				},
				FreeformTags = new Dictionary<string, string>()
				{
					{
						"EXAMPLE_KEY_eiYaY", 
						"EXAMPLE_VALUE_vfjNkQxW053smcdkBXmq"
					}
				},
				DefinedTags = new Dictionary<string, Dictionary<string, Object>>()
				{
					{
						"EXAMPLE_KEY_lUkfE", 
						new Dictionary<string, Object>()
						{
							{
								"EXAMPLE_KEY_TluPB", 
								"EXAMPLE--Value"
							}
						}
					}
				}
			};
			var createDistributedDatabaseRequest = new Oci.DistributeddatabaseService.Requests.CreateDistributedDatabaseRequest
			{
				CreateDistributedDatabaseDetails = createDistributedDatabaseDetails,
				OpcRetryToken = "EXAMPLE-opcRetryToken-Value",
				OpcRequestId = "7YL0W8CASZXWWLN3OVGO<unique_ID>"
			};

            // 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. 
            var provider = new ConfigFileAuthenticationDetailsProvider("DEFAULT");
            try
            {
                // Create a service client and send the request.
				using (var client = new DistributedDbServiceClient(provider, new ClientConfiguration()))
				{
					var response = await client.CreateDistributedDatabase(createDistributedDatabaseRequest);
					// Retrieve value from the response.
					var id = response.DistributedDatabase.Id;
				}
            }
            catch (Exception e)
            {
                Console.WriteLine($"CreateDistributedDatabase Failed with {e.Message}");
                throw e;
            }
        }

    }
}

Was this article helpful?