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

using System;
using System.Collections.Generic;
using System.Threading.Tasks;
using Oci.StackmonitoringService;
using Oci.Common;
using Oci.Common.Auth;

namespace Oci.Sdk.DotNet.Example.Stackmonitoring
{
    public class UpdateMetricExtensionExample
    {
        public static async Task Main()
        {
            // Create a request and dependent object(s).
			var updateMetricExtensionDetails = new Oci.StackmonitoringService.Models.UpdateMetricExtensionDetails
			{
				DisplayName = "EXAMPLE-displayName-Value",
				Description = "EXAMPLE-description-Value",
				CollectionRecurrences = "EXAMPLE-collectionRecurrences-Value",
				MetricList = new List<Oci.StackmonitoringService.Models.Metric>
				{
					new Oci.StackmonitoringService.Models.Metric
					{
						Name = "EXAMPLE-name-Value",
						DisplayName = "EXAMPLE-displayName-Value",
						IsDimension = false,
						ComputeExpression = "EXAMPLE-computeExpression-Value",
						DataType = Oci.StackmonitoringService.Models.Metric.DataTypeEnum.Number,
						IsHidden = false,
						MetricCategory = Oci.StackmonitoringService.Models.Metric.MetricCategoryEnum.Capacity,
						Unit = "EXAMPLE-unit-Value"
					}
				},
				QueryProperties = new Oci.StackmonitoringService.Models.SqlUpdateQueryProperties
				{
					SqlType = Oci.StackmonitoringService.Models.SqlQueryTypes.SqlScript,
					SqlDetails = new Oci.StackmonitoringService.Models.SqlDetails
					{
						ScriptFileName = "EXAMPLE-scriptFileName-Value",
						Content = "EXAMPLE-content-Value"
					},
					InParamDetails = new List<Oci.StackmonitoringService.Models.SqlInParamDetails>
					{
						new Oci.StackmonitoringService.Models.SqlInParamDetails
						{
							InParamPosition = 1,
							InParamValue = "EXAMPLE-inParamValue-Value"
						}
					},
					OutParamDetails = new Oci.StackmonitoringService.Models.SqlOutParamDetails
					{
						OutParamPosition = 745,
						OutParamType = Oci.StackmonitoringService.Models.SqlOutParamTypes.NoOutParam,
						OutParamName = "EXAMPLE-outParamName-Value"
					}
				}
			};
			var updateMetricExtensionRequest = new Oci.StackmonitoringService.Requests.UpdateMetricExtensionRequest
			{
				MetricExtensionId = "ocid1.test.oc1..<unique_ID>EXAMPLE-metricExtensionId-Value",
				UpdateMetricExtensionDetails = updateMetricExtensionDetails,
				IfMatch = "EXAMPLE-ifMatch-Value",
				OpcRequestId = "8QFZ3DZUXKXBXKEIDX6U<unique_ID>"
			};

            // Create a default authentication provider that uses the DEFAULT
            // profile in the configuration file.
            // Refer to <see href="https://docs.cloud.oracle.com/en-us/iaas/Content/API/Concepts/sdkconfig.htm#SDK_and_CLI_Configuration_File>the public documentation</see> on how to prepare a configuration file. 
            var provider = new ConfigFileAuthenticationDetailsProvider("DEFAULT");
            try
            {
                // Create a service client and send the request.
				using (var client = new StackMonitoringClient(provider, new ClientConfiguration()))
				{
					var response = await client.UpdateMetricExtension(updateMetricExtensionRequest);
					// Retrieve value from the response.
					var id = response.MetricExtension.Id;
				}
            }
            catch (Exception e)
            {
                Console.WriteLine($"UpdateMetricExtension Failed with {e.Message}");
                throw e;
            }
        }

    }
}

Was this article helpful?