# 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
create_db_system_response = mysql_client.create_db_system(
    create_db_system_details=oci.mysql.models.CreateDbSystemDetails(
        compartment_id="ocid1.test.oc1..<unique_ID>EXAMPLE-compartmentId-Value",
        shape_name="EXAMPLE-shapeName-Value",
        subnet_id="ocid1.test.oc1..<unique_ID>EXAMPLE-subnetId-Value",
        display_name="EXAMPLE-displayName-Value",
        description="EXAMPLE-description-Value",
        rest=oci.mysql.models.CreateRestDetails(
            configuration="DBSYSTEM_ONLY",
            port=22321),
        is_highly_available=False,
        availability_domain="EXAMPLE-availabilityDomain-Value",
        fault_domain="EXAMPLE-faultDomain-Value",
        configuration_id="ocid1.test.oc1..<unique_ID>EXAMPLE-configurationId-Value",
        mysql_version="EXAMPLE-mysqlVersion-Value",
        nsg_ids=["EXAMPLE--Value"],
        admin_username="EXAMPLE-adminUsername-Value",
        admin_password="EXAMPLE-adminPassword-Value",
        data_storage_size_in_gbs=113937,
        data_storage=oci.mysql.models.DataStorageDetails(
            is_auto_expand_storage_enabled=True,
            max_storage_size_in_gbs=86177),
        hostname_label="EXAMPLE-hostnameLabel-Value",
        ip_address="EXAMPLE-ipAddress-Value",
        port=58592,
        port_x=49238,
        backup_policy=oci.mysql.models.CreateBackupPolicyDetails(
            is_enabled=True,
            soft_delete="DISABLED",
            copy_policies=[
                        oci.mysql.models.CopyPolicy(
                            copy_to_region="EXAMPLE-copyToRegion-Value",
                            backup_copy_retention_in_days=28)],
            window_start_time="EXAMPLE-windowStartTime-Value",
            retention_in_days=23,
            freeform_tags={
                        'EXAMPLE_KEY_M7TX9': 'EXAMPLE_VALUE_avu9JTM4ljmRbzGg0plk'},
            defined_tags={
                'EXAMPLE_KEY_OZeNl': {
                    'EXAMPLE_KEY_1MSDI': 'EXAMPLE--Value'}},
            pitr_policy=oci.mysql.models.PitrPolicy(
                is_enabled=True)),
        source=oci.mysql.models.CreateDbSystemSourceFromPitrDetails(
            source_type="PITR",
            db_system_id="ocid1.test.oc1..<unique_ID>EXAMPLE-dbSystemId-Value",
            recovery_point=datetime.strptime(
                "2046-07-28T05:55:28.891Z",
                "%Y-%m-%dT%H:%M:%S.%fZ")),
        maintenance=oci.mysql.models.CreateMaintenanceDetails(
            window_start_time="EXAMPLE-windowStartTime-Value"),
        freeform_tags={
            'EXAMPLE_KEY_N9xOU': 'EXAMPLE_VALUE_7X7WkPFir7zktFnyec6p'},
        defined_tags={
            'EXAMPLE_KEY_7SUDY': {
                'EXAMPLE_KEY_gAP5D': 'EXAMPLE--Value'}},
        deletion_policy=oci.mysql.models.CreateDeletionPolicyDetails(
            automatic_backup_retention="DELETE",
            final_backup="REQUIRE_FINAL_BACKUP",
            is_delete_protected=True),
        crash_recovery="ENABLED",
        database_management="DISABLED",
        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"),
        database_mode="READ_WRITE",
        access_mode="RESTRICTED",
        customer_contacts=[
            oci.mysql.models.CustomerContact(
                email="EXAMPLE-email-Value")],
        read_endpoint=oci.mysql.models.CreateReadEndpointDetails(
            is_enabled=False,
            read_endpoint_ip_address="EXAMPLE-readEndpointIpAddress-Value",
            read_endpoint_hostname_label="EXAMPLE-readEndpointHostnameLabel-Value",
            exclude_ips=["EXAMPLE--Value"])),
    opc_request_id="16OMIQ6UC3IEQQHTE3IH<unique_ID>",
    opc_retry_token="EXAMPLE-opcRetryToken-Value")

# Get the data from response
print(create_db_system_response.data)