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, Amazon Config configuration items, Audit Manager evidence, or non-Amazon 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
-
Note
You can't change the billing mode from
EXTENDABLE_RETENTION_PRICING
toFIXED_RETENTION_PRICING
. IfBillingMode
is set toEXTENDABLE_RETENTION_PRICING
and you want to useFIXED_RETENTION_PRICING
instead, 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 Amazon CloudTrail Pricing
and Managing CloudTrail Lake costs. Type: String
Valid Values:
EXTENDABLE_RETENTION_PRICING | FIXED_RETENTION_PRICING
Required: 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 Amazon 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.Important
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 Amazon KMS multi-Region keys. For more information about multi-Region keys, see Using multi-Region keys in the Amazon 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 Amazon Organizations.
Note
Only 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
BillingMode
is set toEXTENDABLE_RETENTION_PRICING
, you can set a retention period of up to 3653 days, the equivalent of 10 years. IfBillingMode
is 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
eventTime
of the event is within the specified retention period. For example, if you set a retention period of 90 days, CloudTrail will remove events when theeventTime
is older than 90 days.Note
If you decrease the retention period of an event data store, CloudTrail will remove any events with an
eventTime
older 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 aneventTime
older 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
ENABLED
if Lake query federation is enabled, orDISABLED
if Lake query federation is disabled. You cannot delete an event data store if theFederationStatus
isENABLED
.Type: String
Valid Values:
ENABLING | ENABLED | DISABLING | DISABLED
- KmsKeyId
-
Specifies the Amazon KMS key ID that encrypts the events delivered by CloudTrail. The value is a fully specified ARN to a Amazon KMS key in the following format.
arn:aws:kms:us-east-2:123456789012:key/12345678-1234-1234-1234-123456789012
Type: 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 Amazon 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.
UpdatedTimestamp
is 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 Amazon CloudTrail and Amazon Organizations. For more information, see How to enable or disable trusted access in the Amazon Organizations User Guide and Prepare For Creating a Trail For Your Organization in the Amazon 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
CreateTrail
PutInsightSelectors
,UpdateTrail
,StartQuery
, andStartImport
operations, this exception is thrown when the policy on the S3 bucket or Amazon KMS key does not have sufficient permissions for the operation.For all other operations, this exception is thrown when the policy for the Amazon KMS key does not have sufficient permissions for the operation.
HTTP Status Code: 400
- InvalidEventSelectorsException
-
This exception is thrown when the
PutEventSelectors
operation 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
ReadWriteType
parameter with a value ofread-only
is not valid.
HTTP Status Code: 400
-
- InvalidInsightSelectorsException
-
For
PutInsightSelectors
, this exception is thrown when the formatting or syntax of theInsightSelectors
JSON statement is not valid, or the specifiedInsightType
in theInsightSelectors
statement is not valid. Valid values forInsightType
areApiCallRateInsight
andApiErrorRateInsight
. To enable Insights on an event data store, the destination event data store specified by theInsightsDestination
parameter must log Insights events and the source event data store specified by theEventDataStore
parameter 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 theInsightSelectors
includes anInsightType
ofApiCallRateInsight
, the source event data store must logwrite
management events. If theInsightSelectors
includes anInsightType
ofApiErrorRateInsight
, the source event data store must log management events.HTTP Status Code: 400
- InvalidKmsKeyIdException
-
This exception is thrown when the Amazon 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 Amazon KMS key and the trail or event data store can't be updated.
HTTP Status Code: 400
- KmsKeyNotFoundException
-
This exception is thrown when the Amazon KMS key does not exist, when the S3 bucket and the Amazon KMS key are not in the same Region, or when the Amazon 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 Amazon Web Services account making the request to create or update an organization trail or event data store is not the management account for an organization in Amazon 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 Amazon 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 Amazon Web Services 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 Amazon SDKs, see the following: