UpdateEventDataStore
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 7 and
         3653 if the BillingMode is set to EXTENDABLE_RETENTION_PRICING, or between 7 and 2557 if BillingMode is set to FIXED_RETENTION_PRICING. By default, TerminationProtection is enabled.
For event data stores for CloudTrail events, AdvancedEventSelectors
         includes or excludes management, data, or network activity events in your event data store. For more
         information about AdvancedEventSelectors, see AdvancedEventSelectors.
 For event data stores for CloudTrail Insights events, AWS Config configuration items, Audit Manager evidence, or non-AWS events,
            AdvancedEventSelectors includes events of that type in your event data store.
Request Syntax
{
   "AdvancedEventSelectors": [ 
      { 
         "FieldSelectors": [ 
            { 
               "EndsWith": [ "string" ],
               "Equals": [ "string" ],
               "Field": "string",
               "NotEndsWith": [ "string" ],
               "NotEquals": [ "string" ],
               "NotStartsWith": [ "string" ],
               "StartsWith": [ "string" ]
            }
         ],
         "Name": "string"
      }
   ],
   "BillingMode": "string",
   "EventDataStore": "string",
   "KmsKeyId": "string",
   "MultiRegionEnabled": boolean,
   "Name": "string",
   "OrganizationEnabled": boolean,
   "RetentionPeriod": number,
   "TerminationProtectionEnabled": boolean
}Request Parameters
For information about the parameters that are common to all actions, see Common Parameters.
The request accepts the following data in JSON format.
- 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. Type: Array of AdvancedEventSelector objects Required: No 
- BillingMode
- 
               NoteYou can't change the billing mode from EXTENDABLE_RETENTION_PRICINGtoFIXED_RETENTION_PRICING. IfBillingModeis set toEXTENDABLE_RETENTION_PRICINGand you want to useFIXED_RETENTION_PRICINGinstead, you'll need to stop ingestion on the event data store and create a new event data store that usesFIXED_RETENTION_PRICING.The billing mode for the event data store determines the cost for ingesting events and the default and maximum retention period for the event data store. The following are the possible values: - 
                     EXTENDABLE_RETENTION_PRICING- This billing mode is generally recommended if you want a flexible retention period of up to 3653 days (about 10 years). The default retention period for this billing mode is 366 days.
- 
                     FIXED_RETENTION_PRICING- This billing mode is recommended if you expect to ingest more than 25 TB of event data per month and need a retention period of up to 2557 days (about 7 years). The default retention period for this billing mode is 2557 days.
 For more information about CloudTrail pricing, see AWS CloudTrail Pricing and Managing CloudTrail Lake costs. Type: String Valid Values: EXTENDABLE_RETENTION_PRICING | FIXED_RETENTION_PRICINGRequired: No 
- 
                     
- EventDataStore
- 
               The ARN (or the ID suffix of the ARN) of the event data store that you want to update. Type: String Length Constraints: Minimum length of 3. Maximum length of 256. Pattern: ^[a-zA-Z0-9._/\-:]+$Required: Yes 
- KmsKeyId
- 
               Specifies the AWS 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.ImportantDisabling 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 AWS KMS multi-Region keys. For more information about multi-Region keys, see Using multi-Region keys in the AWS 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
 Type: String Length Constraints: Minimum length of 1. Maximum length of 350. Pattern: ^[a-zA-Z0-9._/\-:]+$Required: No 
- 
                     
- MultiRegionEnabled
- 
               Specifies whether an event data store collects events from all Regions, or only from the Region in which it was created. Type: Boolean Required: No 
- Name
- 
               The event data store name. Type: String Length Constraints: Minimum length of 3. Maximum length of 128. Pattern: ^[a-zA-Z0-9._\-]+$Required: No 
- OrganizationEnabled
- 
               Specifies whether an event data store collects events logged for an organization in AWS Organizations. NoteOnly the management account for the organization can convert an organization event data store to a non-organization event data store, or convert a non-organization event data store to an organization event data store. Type: Boolean Required: No 
- RetentionPeriod
- 
               The retention period of the event data store, in days. If BillingModeis set toEXTENDABLE_RETENTION_PRICING, you can set a retention period of up to 3653 days, the equivalent of 10 years. IfBillingModeis set toFIXED_RETENTION_PRICING, you can set a retention period of up to 2557 days, the equivalent of seven years.CloudTrail Lake determines whether to retain an event by checking if the eventTimeof the event is within the specified retention period. For example, if you set a retention period of 90 days, CloudTrail will remove events when theeventTimeis older than 90 days.NoteIf you decrease the retention period of an event data store, CloudTrail will remove any events with an eventTimeolder than the new retention period. For example, if the previous retention period was 365 days and you decrease it to 100 days, CloudTrail will remove events with aneventTimeolder than 100 days.Type: Integer Valid Range: Minimum value of 7. Maximum value of 3653. Required: No 
- TerminationProtectionEnabled
- 
               Indicates that termination protection is enabled and the event data store cannot be automatically deleted. Type: Boolean Required: No 
Response Syntax
{
   "AdvancedEventSelectors": [ 
      { 
         "FieldSelectors": [ 
            { 
               "EndsWith": [ "string" ],
               "Equals": [ "string" ],
               "Field": "string",
               "NotEndsWith": [ "string" ],
               "NotEquals": [ "string" ],
               "NotStartsWith": [ "string" ],
               "StartsWith": [ "string" ]
            }
         ],
         "Name": "string"
      }
   ],
   "BillingMode": "string",
   "CreatedTimestamp": number,
   "EventDataStoreArn": "string",
   "FederationRoleArn": "string",
   "FederationStatus": "string",
   "KmsKeyId": "string",
   "MultiRegionEnabled": boolean,
   "Name": "string",
   "OrganizationEnabled": boolean,
   "RetentionPeriod": number,
   "Status": "string",
   "TerminationProtectionEnabled": boolean,
   "UpdatedTimestamp": number
}Response Elements
If the action is successful, the service sends back an HTTP 200 response.
The following data is returned in JSON format by the service.
- AdvancedEventSelectors
- 
               The advanced event selectors that are applied to the event data store. Type: Array of AdvancedEventSelector objects 
- BillingMode
- 
               The billing mode for the event data store. Type: String Valid Values: EXTENDABLE_RETENTION_PRICING | FIXED_RETENTION_PRICING
- CreatedTimestamp
- 
               The timestamp that shows when an event data store was first created. Type: Timestamp 
- EventDataStoreArn
- 
               The ARN of the event data store. Type: String Length Constraints: Minimum length of 3. Maximum length of 256. Pattern: ^[a-zA-Z0-9._/\-:]+$
- FederationRoleArn
- 
               If Lake query federation is enabled, provides the ARN of the federation role used to access the resources for the federated event data store. Type: String Length Constraints: Minimum length of 3. Maximum length of 125. Pattern: ^[a-zA-Z0-9._/\-:@=\+,\.]+$
- FederationStatus
- 
               Indicates the Lake query federation status. The status is ENABLEDif Lake query federation is enabled, orDISABLEDif Lake query federation is disabled. You cannot delete an event data store if theFederationStatusisENABLED.Type: String Valid Values: ENABLING | ENABLED | DISABLING | DISABLED
- KmsKeyId
- 
               Specifies the AWS KMS key ID that encrypts the events delivered by CloudTrail. The value is a fully specified ARN to a AWS KMS key in the following format. arn:aws:kms:us-east-2:123456789012:key/12345678-1234-1234-1234-123456789012Type: String Length Constraints: Minimum length of 1. Maximum length of 350. Pattern: ^[a-zA-Z0-9._/\-:]+$
- MultiRegionEnabled
- 
               Indicates whether the event data store includes events from all Regions, or only from the Region in which it was created. Type: Boolean 
- Name
- 
               The name of the event data store. Type: String Length Constraints: Minimum length of 3. Maximum length of 128. Pattern: ^[a-zA-Z0-9._\-]+$
- OrganizationEnabled
- 
               Indicates whether an event data store is collecting logged events for an organization in AWS Organizations. Type: Boolean 
- RetentionPeriod
- 
               The retention period, in days. Type: Integer Valid Range: Minimum value of 7. Maximum value of 3653. 
- Status
- 
               The status of an event data store. Type: String Valid Values: CREATED | ENABLED | PENDING_DELETION | STARTING_INGESTION | STOPPING_INGESTION | STOPPED_INGESTION
- TerminationProtectionEnabled
- 
               Indicates whether termination protection is enabled for the event data store. Type: Boolean 
- UpdatedTimestamp
- 
               The timestamp that shows when the event data store was last updated. UpdatedTimestampis always either the same or newer than the time shown inCreatedTimestamp.Type: Timestamp 
Errors
For information about the errors that are common to all actions, see Common Errors.
- CloudTrailAccessNotEnabledException
- 
               This exception is thrown when trusted access has not been enabled between AWS CloudTrail and AWS Organizations. For more information, see How to enable or disable trusted access in the AWS Organizations User Guide and Prepare For Creating a Trail For Your Organization in the AWS CloudTrail User Guide. HTTP Status Code: 400 
- EventDataStoreAlreadyExistsException
- 
               An event data store with that name already exists. HTTP Status Code: 400 
- EventDataStoreARNInvalidException
- 
               The specified event data store ARN is not valid or does not map to an event data store in your account. HTTP Status Code: 400 
- EventDataStoreHasOngoingImportException
- 
               This exception is thrown when you try to update or delete an event data store that currently has an import in progress. HTTP Status Code: 400 
- EventDataStoreNotFoundException
- 
               The specified event data store was not found. HTTP Status Code: 400 
- InactiveEventDataStoreException
- 
               The event data store is inactive. HTTP Status Code: 400 
- InsufficientDependencyServiceAccessPermissionException
- 
               This exception is thrown when the IAM identity that is used to create the organization resource lacks one or more required permissions for creating an organization resource in a required service. HTTP Status Code: 400 
- InsufficientEncryptionPolicyException
- 
               For the CreateTrailPutInsightSelectors,UpdateTrail,StartQuery, andStartImportoperations, this exception is thrown when the policy on the S3 bucket or AWS KMS key does not have sufficient permissions for the operation.For all other operations, this exception is thrown when the policy for the AWS KMS key does not have sufficient permissions for the operation. HTTP Status Code: 400 
- InvalidEventSelectorsException
- 
               This exception is thrown when the PutEventSelectorsoperation is called with a number of event selectors, advanced event selectors, or data resources that is not valid. The combination of event selectors or advanced event selectors and data resources is not valid. A trail can have up to 5 event selectors. If a trail uses advanced event selectors, a maximum of 500 total values for all conditions in all advanced event selectors is allowed. A trail is limited to 250 data resources. These data resources can be distributed across event selectors, but the overall total cannot exceed 250.You can: - 
                     Specify a valid number of event selectors (1 to 5) for a trail. 
- 
                     Specify a valid number of data resources (1 to 250) for an event selector. The limit of number of resources on an individual event selector is configurable up to 250. However, this upper limit is allowed only if the total number of data resources does not exceed 250 across all event selectors for a trail. 
- 
                     Specify up to 500 values for all conditions in all advanced event selectors for a trail. 
- 
                     Specify a valid value for a parameter. For example, specifying the ReadWriteTypeparameter with a value ofread-onlyis not valid.
 HTTP Status Code: 400 
- 
                     
- InvalidInsightSelectorsException
- 
               For PutInsightSelectors, this exception is thrown when the formatting or syntax of theInsightSelectorsJSON statement is not valid, or the specifiedInsightTypein theInsightSelectorsstatement is not valid. Valid values forInsightTypeareApiCallRateInsightandApiErrorRateInsight. To enable Insights on an event data store, the destination event data store specified by theInsightsDestinationparameter must log Insights events and the source event data store specified by theEventDataStoreparameter must log management events.For UpdateEventDataStore, this exception is thrown if Insights are enabled on the event data store and the updated advanced event selectors are not compatible with the configuredInsightSelectors. If theInsightSelectorsincludes anInsightTypeofApiCallRateInsight, the source event data store must logwritemanagement events. If theInsightSelectorsincludes anInsightTypeofApiErrorRateInsight, the source event data store must log management events.HTTP Status Code: 400 
- InvalidKmsKeyIdException
- 
               This exception is thrown when the AWS KMS key ARN is not valid. HTTP Status Code: 400 
- InvalidParameterException
- 
               The request includes a parameter that is not valid. HTTP Status Code: 400 
- KmsException
- 
               This exception is thrown when there is an issue with the specified AWS KMS key and the trail or event data store can't be updated. HTTP Status Code: 400 
- KmsKeyNotFoundException
- 
               This exception is thrown when the AWS KMS key does not exist, when the S3 bucket and the AWS KMS key are not in the same Region, or when the AWS KMS key associated with the Amazon SNS topic either does not exist or is not in the same Region. HTTP Status Code: 400 
- NoManagementAccountSLRExistsException
- 
               This exception is thrown when the management account does not have a service-linked role. HTTP Status Code: 400 
- NotOrganizationMasterAccountException
- 
               This exception is thrown when the AWS account making the request to create or update an organization trail or event data store is not the management account for an organization in AWS Organizations. For more information, see Prepare For Creating a Trail For Your Organization or Organization event data stores. HTTP Status Code: 400 
- OperationNotPermittedException
- 
               This exception is thrown when the requested operation is not permitted. HTTP Status Code: 400 
- OrganizationNotInAllFeaturesModeException
- 
               This exception is thrown when AWS Organizations is not configured to support all features. All features must be enabled in Organizations to support creating an organization trail or event data store. HTTP Status Code: 400 
- OrganizationsNotInUseException
- 
               This exception is thrown when the request is made from an AWS account that is not a member of an organization. To make this request, sign in using the credentials of an account that belongs to an organization. HTTP Status Code: 400 
- UnsupportedOperationException
- 
               This exception is thrown when the requested operation is not supported. HTTP Status Code: 400 
See Also
For more information about using this API in one of the language-specific AWS SDKs, see the following: