/* * 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 cloudtrail-2013-11-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.CloudTrail.Model { /// /// Container for the parameters to the UpdateEventDataStore operation. /// Updates an event data store. The required EventDataStore value is an /// ARN or the ID portion of the ARN. Other parameters are optional, but at least one /// optional parameter must be specified, or CloudTrail throws an error. RetentionPeriod /// is in days, and valid values are integers between 90 and 2557. By default, TerminationProtection /// is enabled. /// /// /// /// For event data stores for CloudTrail events, AdvancedEventSelectors includes /// or excludes management and data events in your event data store. For more information /// about AdvancedEventSelectors, see AdvancedEventSelectors. /// /// /// /// For event data stores for Config configuration items, Audit Manager evidence, or /// non-Amazon Web Services events, AdvancedEventSelectors includes events /// of that type in your event data store. /// /// public partial class UpdateEventDataStoreRequest : AmazonCloudTrailRequest { private List _advancedEventSelectors = new List(); private string _eventDataStore; private string _kmsKeyId; private bool? _multiRegionEnabled; private string _name; private bool? _organizationEnabled; private int? _retentionPeriod; private bool? _terminationProtectionEnabled; /// /// Gets and sets the property AdvancedEventSelectors. /// /// The advanced event selectors used to select events for the event data store. You can /// configure up to five advanced event selectors for each event data store. /// /// public List AdvancedEventSelectors { get { return this._advancedEventSelectors; } set { this._advancedEventSelectors = value; } } // Check to see if AdvancedEventSelectors property is set internal bool IsSetAdvancedEventSelectors() { return this._advancedEventSelectors != null && this._advancedEventSelectors.Count > 0; } /// /// Gets and sets the property EventDataStore. /// /// The ARN (or the ID suffix of the ARN) of the event data store that you want to update. /// /// [AWSProperty(Required=true, Min=3, Max=256)] public string EventDataStore { get { return this._eventDataStore; } set { this._eventDataStore = value; } } // Check to see if EventDataStore property is set internal bool IsSetEventDataStore() { return this._eventDataStore != null; } /// /// Gets and sets the property KmsKeyId. /// /// Specifies the KMS key ID to use to encrypt the events delivered by CloudTrail. The /// value can be an alias name prefixed by alias/, a fully specified ARN /// to an alias, a fully specified ARN to a key, or a globally unique identifier. /// /// /// /// Disabling or deleting the KMS key, or removing CloudTrail permissions on the key, /// prevents CloudTrail from logging events to the event data store, and prevents users /// from querying the data in the event data store that was encrypted with the key. After /// you associate an event data store with a KMS key, the KMS key cannot be removed or /// changed. Before you disable or delete a KMS key that you are using with an event data /// store, delete or back up your event data store. /// /// /// /// CloudTrail also supports KMS multi-Region keys. For more information about multi-Region /// keys, see Using /// multi-Region keys in the Key Management Service Developer Guide. /// /// /// /// Examples: /// ///
  • /// /// alias/MyAliasName /// ///
  • /// /// arn:aws:kms:us-east-2:123456789012:alias/MyAliasName /// ///
  • /// /// arn:aws:kms:us-east-2:123456789012:key/12345678-1234-1234-1234-123456789012 /// /// ///
  • /// /// 12345678-1234-1234-1234-123456789012 /// ///
///
[AWSProperty(Min=1, Max=350)] public string KmsKeyId { get { return this._kmsKeyId; } set { this._kmsKeyId = value; } } // Check to see if KmsKeyId property is set internal bool IsSetKmsKeyId() { return this._kmsKeyId != null; } /// /// Gets and sets the property MultiRegionEnabled. /// /// Specifies whether an event data store collects events from all Regions, or only from /// the Region in which it was created. /// /// public bool MultiRegionEnabled { get { return this._multiRegionEnabled.GetValueOrDefault(); } set { this._multiRegionEnabled = value; } } // Check to see if MultiRegionEnabled property is set internal bool IsSetMultiRegionEnabled() { return this._multiRegionEnabled.HasValue; } /// /// Gets and sets the property Name. /// /// The event data store name. /// /// [AWSProperty(Min=3, Max=128)] 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 OrganizationEnabled. /// /// Specifies whether an event data store collects events logged for an organization in /// Organizations. /// /// public bool OrganizationEnabled { get { return this._organizationEnabled.GetValueOrDefault(); } set { this._organizationEnabled = value; } } // Check to see if OrganizationEnabled property is set internal bool IsSetOrganizationEnabled() { return this._organizationEnabled.HasValue; } /// /// Gets and sets the property RetentionPeriod. /// /// The retention period, in days. /// /// [AWSProperty(Min=7, Max=2557)] public int RetentionPeriod { get { return this._retentionPeriod.GetValueOrDefault(); } set { this._retentionPeriod = value; } } // Check to see if RetentionPeriod property is set internal bool IsSetRetentionPeriod() { return this._retentionPeriod.HasValue; } /// /// Gets and sets the property TerminationProtectionEnabled. /// /// Indicates that termination protection is enabled and the event data store cannot be /// automatically deleted. /// /// public bool TerminationProtectionEnabled { get { return this._terminationProtectionEnabled.GetValueOrDefault(); } set { this._terminationProtectionEnabled = value; } } // Check to see if TerminationProtectionEnabled property is set internal bool IsSetTerminationProtectionEnabled() { return this._terminationProtectionEnabled.HasValue; } } }