// 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 = "BNS",
				PrivateEndpointIds = new List<string>
				{
					"EXAMPLE--Value"
				},
				ShardingMethod = Oci.DistributeddatabaseService.Models.CreateDistributedDatabaseDetails.ShardingMethodEnum.User,
				CharacterSet = "EXAMPLE-characterSet-Value",
				NcharacterSet = "EXAMPLE-ncharacterSet-Value",
				Chunks = 189,
				ListenerPort = 12672,
				ListenerPortTls = 14183,
				OnsPortLocal = 36864,
				OnsPortRemote = 47140,
				ScanListenerPort = 55739,
				ReplicationMethod = Oci.DistributeddatabaseService.Models.CreateDistributedDatabaseDetails.ReplicationMethodEnum.Dg,
				ReplicationFactor = 4,
				ReplicationUnit = 780,
				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.MaximumProtection,
								TransportType = Oci.DistributeddatabaseService.Models.DistributedDbTransportType.Sync
							}
						},
						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.CreateDistributedDatabaseCatalogWithExadbXsNewVaultAndClusterDetails
					{
						AdminPassword = "EXAMPLE-adminPassword-Value",
						PeerDetails = new List<Oci.DistributeddatabaseService.Models.CreateCatalogPeerWithExadbXsNewVaultAndClusterDetails>
						{
							new Oci.DistributeddatabaseService.Models.CreateCatalogPeerWithExadbXsNewVaultAndClusterDetails
							{
								ProtectionMode = Oci.DistributeddatabaseService.Models.DistributedDbProtectionMode.MaximumPerformance,
								TransportType = Oci.DistributeddatabaseService.Models.DistributedDbTransportType.Sync,
								AvailabilityDomain = "EXAMPLE-availabilityDomain-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",
						AvailabilityDomain = "EXAMPLE-availabilityDomain-Value",
						DbStorageVaultDetails = new Oci.DistributeddatabaseService.Models.DbStorageVaultDetails
						{
							HighCapacityDatabaseStorage = 753,
							AdditionalFlashCacheInPercent = 134
						},
						VmClusterDetails = new Oci.DistributeddatabaseService.Models.VmClusterDetails
						{
							SubnetId = "ocid1.test.oc1..<unique_ID>EXAMPLE-subnetId-Value",
							BackupSubnetId = "ocid1.test.oc1..<unique_ID>EXAMPLE-backupSubnetId-Value",
							EnabledECpuCount = 257,
							TotalECpuCount = 476,
							VmFileSystemStorageSize = 532,
							SshPublicKeys = new List<string>
							{
								"EXAMPLE--Value"
							},
							LicenseModel = Oci.DistributeddatabaseService.Models.VmClusterDetails.LicenseModelEnum.LicenseIncluded,
							Domain = "EXAMPLE-domain-Value",
							PrivateZoneId = "ocid1.test.oc1..<unique_ID>EXAMPLE-privateZoneId-Value",
							IsDiagnosticsEventsEnabled = false,
							IsHealthMonitoringEnabled = true,
							IsIncidentLogsEnabled = true,
							NsgIds = new List<string>
							{
								"EXAMPLE--Value"
							},
							BackupNetworkNsgIds = new List<string>
							{
								"EXAMPLE--Value"
							}
						}
					}
				},
				GsmSshPublicKey = "EXAMPLE-gsmSshPublicKey-Value",
				DbBackupConfig = new Oci.DistributeddatabaseService.Models.DistributedDbBackupConfig
				{
					IsAutoBackupEnabled = true,
					RecoveryWindowInDays = 29,
					AutoBackupWindow = Oci.DistributeddatabaseService.Models.DistributedDbBackupConfig.AutoBackupWindowEnum.SlotNine,
					AutoFullBackupWindow = Oci.DistributeddatabaseService.Models.DistributedDbBackupConfig.AutoFullBackupWindowEnum.SlotSeven,
					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.ObjectStore,
							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_WLRh0", 
						"EXAMPLE_VALUE_nrw2Bgt81FUsXAhOFMnw"
					}
				},
				DefinedTags = new Dictionary<string, Dictionary<string, Object>>()
				{
					{
						"EXAMPLE_KEY_y13vQ", 
						new Dictionary<string, Object>()
						{
							{
								"EXAMPLE_KEY_4oVWn", 
								"EXAMPLE--Value"
							}
						}
					}
				}
			};
			var createDistributedDatabaseRequest = new Oci.DistributeddatabaseService.Requests.CreateDistributedDatabaseRequest
			{
				CreateDistributedDatabaseDetails = createDistributedDatabaseDetails,
				OpcRetryToken = "EXAMPLE-opcRetryToken-Value",
				OpcRequestId = "UC6D8EVZJKSW18EPOFR5<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;
            }
        }

    }
}