# 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

# 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
identity_domains_client = oci.identity_domains.IdentityDomainsClient(
    config, "https://endpoint_of_this_service.com")


# Send the request to service, some parameters are not required, see API
# doc for more info
create_password_policy_response = identity_domains_client.create_password_policy(
    authorization="EXAMPLE-authorization-Value",
    resource_type_schema_version="EXAMPLE-resourceTypeSchemaVersion-Value",
    attributes="EXAMPLE-attributes-Value",
    attribute_sets=["all"],
    password_policy=oci.identity_domains.models.PasswordPolicy(
        schemas=["EXAMPLE--Value"],
        name="EXAMPLE-name-Value",
        id="ocid1.test.oc1..<unique_ID>EXAMPLE-id-Value",
        ocid="EXAMPLE-ocid-Value",
        meta=oci.identity_domains.models.Meta(
            resource_type="EXAMPLE-resourceType-Value",
            created="EXAMPLE-created-Value",
            last_modified="EXAMPLE-lastModified-Value",
            location="EXAMPLE-location-Value",
            version="EXAMPLE-version-Value"),
        idcs_created_by=oci.identity_domains.models.IdcsCreatedBy(
            value="EXAMPLE-value-Value",
            ref=None,
            type="App",
            display="EXAMPLE-display-Value",
            ocid="EXAMPLE-ocid-Value"),
        idcs_last_modified_by=oci.identity_domains.models.IdcsLastModifiedBy(
            value="EXAMPLE-value-Value",
            ref=None,
            type="User",
            display="EXAMPLE-display-Value",
            ocid="EXAMPLE-ocid-Value"),
        idcs_prevented_operations=["update"],
        tags=[
            oci.identity_domains.models.Tags(
                key="EXAMPLE-key-Value",
                value="EXAMPLE-value-Value")],
        delete_in_progress=True,
        idcs_last_upgraded_in_release="EXAMPLE-idcsLastUpgradedInRelease-Value",
        domain_ocid="EXAMPLE-domainOcid-Value",
        compartment_ocid="EXAMPLE-compartmentOcid-Value",
        tenancy_ocid="EXAMPLE-tenancyOcid-Value",
        external_id="ocid1.test.oc1..<unique_ID>EXAMPLE-externalId-Value",
        description="EXAMPLE-description-Value",
        max_length=612,
        min_length=50,
        min_alphas=875,
        min_numerals=550,
        min_alpha_numerals=315,
        min_special_chars=86,
        max_special_chars=688,
        min_lower_case=846,
        min_upper_case=231,
        min_unique_chars=800,
        max_repeated_chars=567,
        starts_with_alphabet=True,
        first_name_disallowed=False,
        last_name_disallowed=True,
        user_name_disallowed=True,
        disallowed_user_attribute_values=["EXAMPLE--Value"],
        min_password_age=190,
        password_expires_after=153,
        password_expire_warning=522,
        required_chars="EXAMPLE-requiredChars-Value",
        disallowed_chars="EXAMPLE-disallowedChars-Value",
        allowed_chars="EXAMPLE-allowedChars-Value",
        disallowed_substrings=["EXAMPLE--Value"],
        dictionary_word_disallowed=True,
        dictionary_location="EXAMPLE-dictionaryLocation-Value",
        dictionary_delimiter="EXAMPLE-dictionaryDelimiter-Value",
        max_incorrect_attempts=897,
        lockout_duration=166,
        num_passwords_in_history=664,
        password_strength="Simple",
        force_password_reset=True,
        distinct_characters=987,
        priority=271,
        groups=[
            oci.identity_domains.models.PasswordPolicyGroups(
                value="EXAMPLE-value-Value",
                ref=None,
                display="EXAMPLE-display-Value")],
        configured_password_policy_rules=[
            oci.identity_domains.models.PasswordPolicyConfiguredPasswordPolicyRules(
                key="EXAMPLE-key-Value",
                value="EXAMPLE-value-Value")]),
    opc_retry_token="EXAMPLE-opcRetryToken-Value")

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