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

import oci
from datetime import datetime

# Create a default config using DEFAULT profile in default location
# Refer to
# https://docs.cloud.oracle.com/en-us/iaas/Content/API/Concepts/sdkconfig.htm#SDK_and_CLI_Configuration_File
# for more info
config = oci.config.from_file()


# Initialize service client with default config file
mysql_client = oci.mysql.DbSystemClient(config)


# Send the request to service, some parameters are not required, see API
# doc for more info
update_db_system_response = mysql_client.update_db_system(
    db_system_id="ocid1.test.oc1..<unique_ID>EXAMPLE-dbSystemId-Value",
    update_db_system_details=oci.mysql.models.UpdateDbSystemDetails(
        display_name="EXAMPLE-displayName-Value",
        description="EXAMPLE-description-Value",
        subnet_id="ocid1.test.oc1..<unique_ID>EXAMPLE-subnetId-Value",
        nsg_ids=["EXAMPLE--Value"],
        security_attributes={
            'EXAMPLE_KEY_BrzQe': {
                'EXAMPLE_KEY_grGi9': 'EXAMPLE--Value'}},
        database_mode="READ_WRITE",
        access_mode="RESTRICTED",
        rest=oci.mysql.models.UpdateRestDetails(
                    configuration="DBSYSTEM_ONLY",
                    port=24265),
        database_console=oci.mysql.models.UpdateDatabaseConsoleDetails(
            status="ENABLED",
            port=61975),
        is_highly_available=True,
        availability_domain="EXAMPLE-availabilityDomain-Value",
        fault_domain="EXAMPLE-faultDomain-Value",
        shape_name="EXAMPLE-shapeName-Value",
        mysql_version="EXAMPLE-mysqlVersion-Value",
        configuration_id="ocid1.test.oc1..<unique_ID>EXAMPLE-configurationId-Value",
        admin_username="EXAMPLE-adminUsername-Value",
        admin_password="EXAMPLE-adminPassword-Value",
        data_storage_size_in_gbs=76111,
        data_storage=oci.mysql.models.DataStorageDetails(
                            is_auto_expand_storage_enabled=False,
                            max_storage_size_in_gbs=70236),
        hostname_label="EXAMPLE-hostnameLabel-Value",
        ip_address="EXAMPLE-ipAddress-Value",
        port=18792,
        port_x=44797,
        backup_policy=oci.mysql.models.UpdateBackupPolicyDetails(
            is_enabled=True,
            soft_delete="ENABLED",
            copy_policies=[
                oci.mysql.models.CopyPolicy(
                    copy_to_region="EXAMPLE-copyToRegion-Value",
                    backup_copy_retention_in_days=9)],
            window_start_time="EXAMPLE-windowStartTime-Value",
            retention_in_days=28,
            freeform_tags={
                'EXAMPLE_KEY_ByEFU': 'EXAMPLE_VALUE_NUt6eb3UbkndtAoqn2PL'},
            defined_tags={
                'EXAMPLE_KEY_zV7Oa': {
                    'EXAMPLE_KEY_aOvez': 'EXAMPLE--Value'}},
            pitr_policy=oci.mysql.models.PitrPolicy(
                is_enabled=True)),
        maintenance=oci.mysql.models.UpdateMaintenanceDetails(
            window_start_time="EXAMPLE-windowStartTime-Value",
            version_preference="NEWEST",
            version_track_preference="INNOVATION",
            maintenance_schedule_type="EARLY",
            maintenance_disabled_windows=[
                oci.mysql.models.MaintenanceDisabledWindow(
                    time_start=datetime.strptime(
                        "2035-05-02T12:56:06.027Z",
                        "%Y-%m-%dT%H:%M:%S.%fZ"),
                    time_end=datetime.strptime(
                        "2007-05-02T18:55:43.281Z",
                        "%Y-%m-%dT%H:%M:%S.%fZ"))]),
        freeform_tags={
            'EXAMPLE_KEY_2g7Ts': 'EXAMPLE_VALUE_71AWmNg8GsISOyHplWaz'},
        defined_tags={
            'EXAMPLE_KEY_2rErz': {
                'EXAMPLE_KEY_zq5bw': 'EXAMPLE--Value'}},
        deletion_policy=oci.mysql.models.UpdateDeletionPolicyDetails(
            automatic_backup_retention="DELETE",
            final_backup="SKIP_FINAL_BACKUP",
            is_delete_protected=False),
        crash_recovery="DISABLED",
        database_management="ENABLED",
        secure_connections=oci.mysql.models.SecureConnectionDetails(
            certificate_generation_type="BYOC",
            certificate_id="ocid1.test.oc1..<unique_ID>EXAMPLE-certificateId-Value"),
        encrypt_data=oci.mysql.models.EncryptDataDetails(
            key_generation_type="BYOK",
            key_id="ocid1.test.oc1..<unique_ID>EXAMPLE-keyId-Value"),
        customer_contacts=[
            oci.mysql.models.CustomerContact(
                email="EXAMPLE-email-Value")],
        read_endpoint=oci.mysql.models.UpdateReadEndpointDetails(
            is_enabled=True,
            read_endpoint_ip_address="EXAMPLE-readEndpointIpAddress-Value",
            read_endpoint_hostname_label="EXAMPLE-readEndpointHostnameLabel-Value",
            exclude_ips=["EXAMPLE--Value"]),
        telemetry_configuration=oci.mysql.models.UpdateTelemetryConfigurationDetails(
            logs=[
                oci.mysql.models.LoggingDestinationConfiguration(
                    destination="OPEN_TELEMETRY",
                    destination_configurations=[
                        oci.mysql.models.DestinationConfiguration(
                            key="EXAMPLE-key-Value",
                            value="EXAMPLE-value-Value")],
                    log_types=["ERROR_LOG"])])),
    if_match="EXAMPLE-ifMatch-Value",
    opc_request_id="9ELOV7WFYA5SQI9XFTSB<unique_ID>")

# Get the data from response
print(update_db_system_response.headers)