# 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=3561),
        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"],
        security_attributes={
            'EXAMPLE_KEY_PVeJs': {
                'EXAMPLE_KEY_vKSBy': 'EXAMPLE--Value'}},
        admin_username="EXAMPLE-adminUsername-Value",
        admin_password="EXAMPLE-adminPassword-Value",
        data_storage_size_in_gbs=86316,
        data_storage=oci.mysql.models.DataStorageDetails(
            is_auto_expand_storage_enabled=False,
            max_storage_size_in_gbs=51031),
        hostname_label="EXAMPLE-hostnameLabel-Value",
        ip_address="EXAMPLE-ipAddress-Value",
        port=6112,
        port_x=46368,
        backup_policy=oci.mysql.models.CreateBackupPolicyDetails(
            is_enabled=False,
            soft_delete="ENABLED",
            copy_policies=[
                oci.mysql.models.CopyPolicy(
                    copy_to_region="EXAMPLE-copyToRegion-Value",
                    backup_copy_retention_in_days=29)],
            window_start_time="EXAMPLE-windowStartTime-Value",
            retention_in_days=10,
            freeform_tags={
                'EXAMPLE_KEY_vdIXH': 'EXAMPLE_VALUE_5teROQxNQv7Mn6nJZZQE'},
            defined_tags={
                'EXAMPLE_KEY_P5aqb': {
                    'EXAMPLE_KEY_09gTX': 'EXAMPLE--Value'}},
            pitr_policy=oci.mysql.models.PitrPolicy(
                is_enabled=False)),
        source=oci.mysql.models.CreateDbSystemSourceFromPitrDetails(
            source_type="PITR",
            db_system_id="ocid1.test.oc1..<unique_ID>EXAMPLE-dbSystemId-Value",
            recovery_point=datetime.strptime(
                "2031-05-05T01:22:29.218Z",
                "%Y-%m-%dT%H:%M:%S.%fZ")),
        maintenance=oci.mysql.models.CreateMaintenanceDetails(
            window_start_time="EXAMPLE-windowStartTime-Value",
            version_preference="SECOND_NEWEST",
            version_track_preference="FOLLOW",
            maintenance_schedule_type="REGULAR"),
        freeform_tags={
            'EXAMPLE_KEY_HI2pf': 'EXAMPLE_VALUE_VypdK2uuTNApmc56lwDU'},
        defined_tags={
            'EXAMPLE_KEY_ohEFV': {
                'EXAMPLE_KEY_qAry2': 'EXAMPLE--Value'}},
        deletion_policy=oci.mysql.models.CreateDeletionPolicyDetails(
            automatic_backup_retention="RETAIN",
            final_backup="SKIP_FINAL_BACKUP",
            is_delete_protected=False),
        crash_recovery="DISABLED",
        database_management="DISABLED",
        secure_connections=oci.mysql.models.SecureConnectionDetails(
            certificate_generation_type="SYSTEM",
            certificate_id="ocid1.test.oc1..<unique_ID>EXAMPLE-certificateId-Value"),
        encrypt_data=oci.mysql.models.EncryptDataDetails(
            key_generation_type="SYSTEM",
            key_id="ocid1.test.oc1..<unique_ID>EXAMPLE-keyId-Value"),
        database_mode="READ_ONLY",
        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="ED4RCESGPQHWK6SRPHSL<unique_ID>",
    opc_retry_token="EXAMPLE-opcRetryToken-Value")

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