// 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.DatabaseService;
using Oci.Common;
using Oci.Common.Auth;

namespace Oci.Sdk.DotNet.Example.Database
{
    public class UpdateDbSystemExample
    {
        public static async Task Main()
        {
            // Create a request and dependent object(s).
			var updateDbSystemDetails = new Oci.DatabaseService.Models.UpdateDbSystemDetails
			{
				CpuCoreCount = 809,
				Version = new Oci.DatabaseService.Models.PatchDetails
				{
					PatchId = "ocid1.test.oc1..<unique_ID>EXAMPLE-patchId-Value",
					DatabaseSoftwareImageId = "ocid1.test.oc1..<unique_ID>EXAMPLE-databaseSoftwareImageId-Value",
					Action = Oci.DatabaseService.Models.PatchDetails.ActionEnum.Precheck
				},
				SshPublicKeys = new List<string>
				{
					"EXAMPLE--Value"
				},
				DataStorageSizeInGBs = 172,
				RecoStorageSizeInGBs = 740,
				FreeformTags = new Dictionary<string, string>()
				{
					{
						"EXAMPLE_KEY_SqwC2", 
						"EXAMPLE_VALUE_uwSueJXY6Mu0vG6UYUJj"
					}
				},
				DefinedTags = new Dictionary<string, Dictionary<string, Object>>()
				{
					{
						"EXAMPLE_KEY_MLXuo", 
						new Dictionary<string, Object>()
						{
							{
								"EXAMPLE_KEY_nzTlf", 
								"EXAMPLE--Value"
							}
						}
					}
				},
				Shape = "EXAMPLE-shape-Value",
				NsgIds = new List<string>
				{
					"EXAMPLE--Value"
				},
				BackupNetworkNsgIds = new List<string>
				{
					"EXAMPLE--Value"
				},
				LicenseModel = Oci.DatabaseService.Models.UpdateDbSystemDetails.LicenseModelEnum.BringYourOwnLicense,
				MaintenanceWindowDetails = new Oci.DatabaseService.Models.MaintenanceWindow
				{
					Preference = Oci.DatabaseService.Models.MaintenanceWindow.PreferenceEnum.CustomPreference,
					PatchingMode = Oci.DatabaseService.Models.MaintenanceWindow.PatchingModeEnum.Nonrolling,
					IsCustomActionTimeoutEnabled = false,
					CustomActionTimeoutInMins = 98,
					IsMonthlyPatchingEnabled = true,
					Months = new List<Oci.DatabaseService.Models.Month>
					{
						new Oci.DatabaseService.Models.Month
						{
							Name = Oci.DatabaseService.Models.Month.NameEnum.July
						}
					},
					WeeksOfMonth = new List<Int32>
					{
						1
					},
					DaysOfWeek = new List<Oci.DatabaseService.Models.DayOfWeek>
					{
						new Oci.DatabaseService.Models.DayOfWeek
						{
							Name = Oci.DatabaseService.Models.DayOfWeek.NameEnum.Monday
						}
					},
					HoursOfDay = new List<Int32>
					{
						6
					},
					LeadTimeInWeeks = 1,
					SkipRu = new List<Boolean>
					{
						true,
						false
					}
				},
				DataCollectionOptions = new Oci.DatabaseService.Models.DataCollectionOptions
				{
					IsDiagnosticsEventsEnabled = true,
					IsHealthMonitoringEnabled = false,
					IsIncidentLogsEnabled = true
				}
			};
			var updateDbSystemRequest = new Oci.DatabaseService.Requests.UpdateDbSystemRequest
			{
				DbSystemId = "ocid1.test.oc1..<unique_ID>EXAMPLE-dbSystemId-Value",
				UpdateDbSystemDetails = updateDbSystemDetails,
				IfMatch = "EXAMPLE-ifMatch-Value"
			};

            // 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 DatabaseClient(provider, new ClientConfiguration()))
				{
					var response = await client.UpdateDbSystem(updateDbSystemRequest);
					// Retrieve value from the response.
					var id = response.DbSystem.Id;
				}
            }
            catch (Exception e)
            {
                Console.WriteLine($"UpdateDbSystem Failed with {e.Message}");
                throw e;
            }
        }

    }
}