# 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
stack_monitoring_client = oci.stack_monitoring.StackMonitoringClient(config)


# Send the request to service, some parameters are not required, see API
# doc for more info
update_metric_extension_response = stack_monitoring_client.update_metric_extension(
    metric_extension_id="ocid1.test.oc1..<unique_ID>EXAMPLE-metricExtensionId-Value",
    update_metric_extension_details=oci.stack_monitoring.models.UpdateMetricExtensionDetails(
        display_name="EXAMPLE-displayName-Value",
        description="EXAMPLE-description-Value",
        collection_recurrences="EXAMPLE-collectionRecurrences-Value",
        metric_list=[
            oci.stack_monitoring.models.Metric(
                name="EXAMPLE-name-Value",
                data_type="STRING",
                display_name="EXAMPLE-displayName-Value",
                is_dimension=False,
                compute_expression="EXAMPLE-computeExpression-Value",
                is_hidden=True,
                metric_category="AVAILABILITY",
                unit="EXAMPLE-unit-Value")],
        query_properties=oci.stack_monitoring.models.SqlUpdateQueryProperties(
            collection_method="SQL",
            sql_type="STATEMENT",
            sql_details=oci.stack_monitoring.models.SqlDetails(
                content="EXAMPLE-content-Value",
                script_file_name="EXAMPLE-scriptFileName-Value"),
            in_param_details=[
                oci.stack_monitoring.models.SqlInParamDetails(
                    in_param_position=17,
                    in_param_value="EXAMPLE-inParamValue-Value")],
            out_param_details=oci.stack_monitoring.models.SqlOutParamDetails(
                out_param_position=929,
                out_param_type="ARRAY"))),
    if_match="EXAMPLE-ifMatch-Value",
    opc_request_id="FSGYG9QBFB0OPK8UOP2H<unique_ID>")

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