// 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 = "dqR",
				PrivateEndpointIds = new List<string>
				{
					"EXAMPLE--Value"
				},
				ShardingMethod = Oci.DistributeddatabaseService.Models.CreateDistributedDatabaseDetails.ShardingMethodEnum.User,
				CharacterSet = "EXAMPLE-characterSet-Value",
				NcharacterSet = "EXAMPLE-ncharacterSet-Value",
				Chunks = 276,
				ListenerPort = 50608,
				ListenerPortTls = 56159,
				OnsPortLocal = 12428,
				OnsPortRemote = 58152,
				ScanListenerPort = 2398,
				ReplicationMethod = Oci.DistributeddatabaseService.Models.CreateDistributedDatabaseDetails.ReplicationMethodEnum.Raft,
				ReplicationFactor = 3,
				ReplicationUnit = 57,
				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"
						},
						PeerDetails = new List<Oci.DistributeddatabaseService.Models.CreateShardPeerWithExadbXsDetails>
						{
							new Oci.DistributeddatabaseService.Models.CreateShardPeerWithExadbXsDetails
							{
								VmClusterId = "ocid1.test.oc1..<unique_ID>EXAMPLE-vmClusterId-Value",
								ProtectionMode = Oci.DistributeddatabaseService.Models.DistributedDbProtectionMode.MaximumAvailability,
								TransportType = Oci.DistributeddatabaseService.Models.DistributedDbTransportType.Async
							}
						},
						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"
						},
						PeerDetails = new List<Oci.DistributeddatabaseService.Models.CreateCatalogPeerWithExadbXsDetails>
						{
							new Oci.DistributeddatabaseService.Models.CreateCatalogPeerWithExadbXsDetails
							{
								VmClusterId = "ocid1.test.oc1..<unique_ID>EXAMPLE-vmClusterId-Value",
								ProtectionMode = Oci.DistributeddatabaseService.Models.DistributedDbProtectionMode.MaximumAvailability,
								TransportType = Oci.DistributeddatabaseService.Models.DistributedDbTransportType.Async
							}
						},
						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 = true,
					RecoveryWindowInDays = 53,
					AutoBackupWindow = Oci.DistributeddatabaseService.Models.DistributedDbBackupConfig.AutoBackupWindowEnum.SlotThree,
					AutoFullBackupWindow = Oci.DistributeddatabaseService.Models.DistributedDbBackupConfig.AutoFullBackupWindowEnum.SlotThree,
					AutoFullBackupDay = Oci.DistributeddatabaseService.Models.DistributedDbBackupConfig.AutoFullBackupDayEnum.Friday,
					CanRunImmediateFullBackup = false,
					IsRemoteBackupEnabled = true,
					RemoteRegion = "EXAMPLE-remoteRegion-Value",
					BackupDestinationDetails = new List<Oci.DistributeddatabaseService.Models.DistributedDbBackupDestination>
					{
						new Oci.DistributeddatabaseService.Models.DistributedDbBackupDestination
						{
							Type = Oci.DistributeddatabaseService.Models.DistributedDbBackupDestination.TypeEnum.Nfs,
							Id = "ocid1.test.oc1..<unique_ID>EXAMPLE-id-Value",
							VpcUser = "EXAMPLE-vpcUser-Value",
							VpcPassword = "EXAMPLE-vpcPassword-Value",
							IsZeroDataLossEnabled = false,
							InternetProxy = "EXAMPLE-internetProxy-Value",
							DbrsPolicyId = "ocid1.test.oc1..<unique_ID>EXAMPLE-dbrsPolicyId-Value",
							IsRemote = false,
							RemoteRegion = "EXAMPLE-remoteRegion-Value"
						}
					},
					BackupDeletionPolicy = Oci.DistributeddatabaseService.Models.DistributedDbBackupConfig.BackupDeletionPolicyEnum.DeleteAfterRetentionPeriod
				},
				FreeformTags = new Dictionary<string, string>()
				{
					{
						"EXAMPLE_KEY_tpmEl", 
						"EXAMPLE_VALUE_IHi92YFjSSSD1sDaTQhp"
					}
				},
				DefinedTags = new Dictionary<string, Dictionary<string, Object>>()
				{
					{
						"EXAMPLE_KEY_P56HW", 
						new Dictionary<string, Object>()
						{
							{
								"EXAMPLE_KEY_zqXg6", 
								"EXAMPLE--Value"
							}
						}
					}
				}
			};
			var createDistributedDatabaseRequest = new Oci.DistributeddatabaseService.Requests.CreateDistributedDatabaseRequest
			{
				CreateDistributedDatabaseDetails = createDistributedDatabaseDetails,
				OpcRetryToken = "EXAMPLE-opcRetryToken-Value",
				OpcRequestId = "SVGI3EI6T9TWSWHATEZ4<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;
            }
        }

    }
}