/* * Copyright Amazon.com, Inc. or its affiliates. All Rights Reserved. * * Licensed under the Apache License, Version 2.0 (the "License"). * You may not use this file except in compliance with the License. * A copy of the License is located at * * http://aws.amazon.com/apache2.0 * * or in the "license" file accompanying this file. This file is distributed * on an "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either * express or implied. See the License for the specific language governing * permissions and limitations under the License. */ /* * Do not modify this file. This file is generated from the monitoring-2010-08-01.normal.json service model. */ using System; using System.Collections.Generic; using System.Xml.Serialization; using System.Text; using System.IO; using System.Net; using Amazon.Runtime; using Amazon.Runtime.Internal; namespace Amazon.CloudWatch.Model { /// /// Container for the parameters to the PutMetricStream operation. /// Creates or updates a metric stream. Metric streams can automatically stream CloudWatch /// metrics to Amazon Web Services destinations, including Amazon S3, and to many third-party /// solutions. /// /// /// /// For more information, see /// Using Metric Streams. /// /// /// /// To create a metric stream, you must be signed in to an account that has the iam:PassRole /// permission and either the CloudWatchFullAccess policy or the cloudwatch:PutMetricStream /// permission. /// /// /// /// When you create or update a metric stream, you choose one of the following: /// /// /// /// By default, a metric stream always sends the MAX, MIN, SUM, /// and SAMPLECOUNT statistics for each metric that is streamed. You can /// use the StatisticsConfigurations parameter to have the metric stream /// send additional statistics in the stream. Streaming additional statistics incurs additional /// costs. For more information, see Amazon /// CloudWatch Pricing. /// /// /// /// When you use PutMetricStream to create a new metric stream, the stream /// is created in the running state. If you use it to update an existing /// stream, the state of the stream is not changed. /// /// /// /// If you are using CloudWatch cross-account observability and you create a metric stream /// in a monitoring account, you can choose whether to include metrics from source accounts /// in the stream. For more information, see CloudWatch /// cross-account observability. /// /// public partial class PutMetricStreamRequest : AmazonCloudWatchRequest { private List _excludeFilters = new List(); private string _firehoseArn; private List _includeFilters = new List(); private bool? _includeLinkedAccountsMetrics; private string _name; private MetricStreamOutputFormat _outputFormat; private string _roleArn; private List _statisticsConfigurations = new List(); private List _tags = new List(); /// /// Gets and sets the property ExcludeFilters. /// /// If you specify this parameter, the stream sends metrics from all metric namespaces /// except for the namespaces that you specify here. /// /// /// /// You cannot include ExcludeFilters and IncludeFilters in /// the same operation. /// /// public List ExcludeFilters { get { return this._excludeFilters; } set { this._excludeFilters = value; } } // Check to see if ExcludeFilters property is set internal bool IsSetExcludeFilters() { return this._excludeFilters != null && this._excludeFilters.Count > 0; } /// /// Gets and sets the property FirehoseArn. /// /// The ARN of the Amazon Kinesis Data Firehose delivery stream to use for this metric /// stream. This Amazon Kinesis Data Firehose delivery stream must already exist and must /// be in the same account as the metric stream. /// /// [AWSProperty(Required=true, Min=1, Max=1024)] public string FirehoseArn { get { return this._firehoseArn; } set { this._firehoseArn = value; } } // Check to see if FirehoseArn property is set internal bool IsSetFirehoseArn() { return this._firehoseArn != null; } /// /// Gets and sets the property IncludeFilters. /// /// If you specify this parameter, the stream sends only the metrics from the metric namespaces /// that you specify here. /// /// /// /// You cannot include IncludeFilters and ExcludeFilters in /// the same operation. /// /// public List IncludeFilters { get { return this._includeFilters; } set { this._includeFilters = value; } } // Check to see if IncludeFilters property is set internal bool IsSetIncludeFilters() { return this._includeFilters != null && this._includeFilters.Count > 0; } /// /// Gets and sets the property IncludeLinkedAccountsMetrics. /// /// If you are creating a metric stream in a monitoring account, specify true /// to include metrics from source accounts in the metric stream. /// /// public bool IncludeLinkedAccountsMetrics { get { return this._includeLinkedAccountsMetrics.GetValueOrDefault(); } set { this._includeLinkedAccountsMetrics = value; } } // Check to see if IncludeLinkedAccountsMetrics property is set internal bool IsSetIncludeLinkedAccountsMetrics() { return this._includeLinkedAccountsMetrics.HasValue; } /// /// Gets and sets the property Name. /// /// If you are creating a new metric stream, this is the name for the new stream. The /// name must be different than the names of other metric streams in this account and /// Region. /// /// /// /// If you are updating a metric stream, specify the name of that stream here. /// /// /// /// Valid characters are A-Z, a-z, 0-9, "-" and "_". /// /// [AWSProperty(Required=true, Min=1, Max=255)] public string Name { get { return this._name; } set { this._name = value; } } // Check to see if Name property is set internal bool IsSetName() { return this._name != null; } /// /// Gets and sets the property OutputFormat. /// /// The output format for the stream. Valid values are json and opentelemetry0.7. /// For more information about metric stream output formats, see /// Metric streams output formats. /// /// [AWSProperty(Required=true, Min=1, Max=255)] public MetricStreamOutputFormat OutputFormat { get { return this._outputFormat; } set { this._outputFormat = value; } } // Check to see if OutputFormat property is set internal bool IsSetOutputFormat() { return this._outputFormat != null; } /// /// Gets and sets the property RoleArn. /// /// The ARN of an IAM role that this metric stream will use to access Amazon Kinesis Data /// Firehose resources. This IAM role must already exist and must be in the same account /// as the metric stream. This IAM role must include the following permissions: /// ///
  • /// /// firehose:PutRecord /// ///
  • /// /// firehose:PutRecordBatch /// ///
///
[AWSProperty(Required=true, Min=1, Max=1024)] public string RoleArn { get { return this._roleArn; } set { this._roleArn = value; } } // Check to see if RoleArn property is set internal bool IsSetRoleArn() { return this._roleArn != null; } /// /// Gets and sets the property StatisticsConfigurations. /// /// By default, a metric stream always sends the MAX, MIN, SUM, /// and SAMPLECOUNT statistics for each metric that is streamed. You can /// use this parameter to have the metric stream also send additional statistics in the /// stream. This array can have up to 100 members. /// /// /// /// For each entry in this array, you specify one or more metrics and the list of additional /// statistics to stream for those metrics. The additional statistics that you can stream /// depend on the stream's OutputFormat. If the OutputFormat /// is json, you can stream any additional statistic that is supported by /// CloudWatch, listed in /// CloudWatch statistics definitions. If the OutputFormat is opentelemetry0.7, /// you can stream percentile statistics such as p95, p99.9, and so on. /// /// public List StatisticsConfigurations { get { return this._statisticsConfigurations; } set { this._statisticsConfigurations = value; } } // Check to see if StatisticsConfigurations property is set internal bool IsSetStatisticsConfigurations() { return this._statisticsConfigurations != null && this._statisticsConfigurations.Count > 0; } /// /// Gets and sets the property Tags. /// /// A list of key-value pairs to associate with the metric stream. You can associate as /// many as 50 tags with a metric stream. /// /// /// /// Tags can help you organize and categorize your resources. You can also use them to /// scope user permissions by granting a user permission to access or change only resources /// with certain tag values. /// /// /// /// You can use this parameter only when you are creating a new metric stream. If you /// are using this operation to update an existing metric stream, any tags you specify /// in this parameter are ignored. To change the tags of an existing metric stream, use /// TagResource /// or UntagResource. /// /// public List Tags { get { return this._tags; } set { this._tags = value; } } // Check to see if Tags property is set internal bool IsSetTags() { return this._tags != null && this._tags.Count > 0; } } }