2016/03/08 - Amazon CloudWatch Events - 12 new api methods
Describes the details of the specified rule.
Request Syntax
client.describe_rule( Name='string' )
string
[REQUIRED]
The name of the rule you want to describe details for.
dict
Response Syntax
{ 'Name': 'string', 'Arn': 'string', 'EventPattern': 'string', 'ScheduleExpression': 'string', 'State': 'ENABLED'|'DISABLED', 'Description': 'string', 'RoleArn': 'string' }
Response Structure
(dict) --
The result of the DescribeRule operation.
Name (string) --
The rule's name.
Arn (string) --
The Amazon Resource Name (ARN) associated with the rule.
EventPattern (string) --
The event pattern.
ScheduleExpression (string) --
The scheduling expression. For example, "cron(0 20 * * ? *)", "rate(5 minutes)".
State (string) --
Specifies whether the rule is enabled or disabled.
Description (string) --
The rule's description.
RoleArn (string) --
The Amazon Resource Name (ARN) of the IAM role associated with the rule.
Lists of targets assigned to the rule.
Request Syntax
client.list_targets_by_rule( Rule='string', NextToken='string', Limit=123 )
string
[REQUIRED]
The name of the rule whose targets you want to list.
string
The token returned by a previous call to indicate that there is more data available.
integer
The maximum number of results to return.
dict
Response Syntax
{ 'Targets': [ { 'Id': 'string', 'Arn': 'string', 'Input': 'string', 'InputPath': 'string' }, ], 'NextToken': 'string' }
Response Structure
(dict) --
The result of the ListTargetsByRule operation.
Targets (list) --
Lists the targets assigned to the rule.
(dict) --
Targets are the resources that can be invoked when a rule is triggered. For example, AWS Lambda functions, Amazon Kinesis streams, and built-in targets.
Input and InputPath are mutually-exclusive and optional parameters of a target. When a rule is triggered due to a matched event, if for a target:
Neither Input nor InputPath is specified, then the entire event is passed to the target in JSON form.
InputPath is specified in the form of JSONPath (e.g. $.detail ), then only the part of the event specified in the path is passed to the target (e.g. only the detail part of the event is passed).
Input is specified in the form of a valid JSON, then the matched event is overridden with this constant.
Id (string) --
The unique target assignment ID.
Arn (string) --
The Amazon Resource Name (ARN) associated of the target.
Input (string) --
Valid JSON text passed to the target. For more information about JSON text, see The JavaScript Object Notation (JSON) Data Interchange Format .
InputPath (string) --
The value of the JSONPath that is used for extracting part of the matched event when passing it to the target. For more information about JSON paths, see JSONPath .
NextToken (string) --
Indicates that there are additional results to retrieve.
Disables a rule. A disabled rule won't match any events, and won't self-trigger if it has a schedule expression.
Note: When you disable a rule, incoming events might still continue to match to the disabled rule. Please allow a short period of time for changes to take effect.
Request Syntax
client.disable_rule( Name='string' )
string
[REQUIRED]
The name of the rule you want to disable.
None
Creates or updates a rule. Rules are enabled by default, or based on value of the State parameter. You can disable a rule using DisableRule .
Note: When you create or update a rule, incoming events might not immediately start matching to new or updated rules. Please allow a short period of time for changes to take effect.
A rule must contain at least an EventPattern or ScheduleExpression. Rules with EventPatterns are triggered when a matching event is observed. Rules with ScheduleExpressions self-trigger based on the given schedule. A rule can have both an EventPattern and a ScheduleExpression, in which case the rule will trigger on matching events as well as on a schedule.
Note: Most services in AWS treat : or / as the same character in Amazon Resource Names (ARNs). However, CloudWatch Events uses an exact match in event patterns and rules. Be sure to use the correct ARN characters when creating event patterns so that they match the ARN syntax in the event you want to match.
Request Syntax
client.put_rule( Name='string', ScheduleExpression='string', EventPattern='string', State='ENABLED'|'DISABLED', Description='string', RoleArn='string' )
string
[REQUIRED]
The name of the rule that you are creating or updating.
string
The scheduling expression. For example, "cron(0 20 * * ? *)", "rate(5 minutes)".
string
The event pattern.
string
Indicates whether the rule is enabled or disabled.
string
A description of the rule.
string
The Amazon Resource Name (ARN) of the IAM role associated with the rule.
dict
Response Syntax
{ 'RuleArn': 'string' }
Response Structure
(dict) --
The result of the PutRule operation.
RuleArn (string) --
The Amazon Resource Name (ARN) that identifies the rule.
Removes target(s) from a rule so that when the rule is triggered, those targets will no longer be invoked.
Note: When you remove a target, when the associated rule triggers, removed targets might still continue to be invoked. Please allow a short period of time for changes to take effect.
Request Syntax
client.remove_targets( Rule='string', Ids=[ 'string', ] )
string
[REQUIRED]
The name of the rule you want to remove targets from.
list
[REQUIRED]
The list of target IDs to remove from the rule.
(string) --
dict
Response Syntax
{ 'FailedEntryCount': 123, 'FailedEntries': [ { 'TargetId': 'string', 'ErrorCode': 'string', 'ErrorMessage': 'string' }, ] }
Response Structure
(dict) --
The result of the RemoveTargets operation.
FailedEntryCount (integer) --
The number of failed entries.
FailedEntries (list) --
An array of failed target entries.
(dict) --
The ID of the target requested to be removed from the rule by Amazon CloudWatch Events.
TargetId (string) --
The ID of the target requested to be removed by Amazon CloudWatch Events.
ErrorCode (string) --
The error code representing why the target removal failed on this entry.
ErrorMessage (string) --
The error message explaining why the target removal failed on this entry.
Tests whether an event pattern matches the provided event.
Note: Most services in AWS treat : or / as the same character in Amazon Resource Names (ARNs). However, CloudWatch Events uses an exact match in event patterns and rules. Be sure to use the correct ARN characters when creating event patterns so that they match the ARN syntax in the event you want to match.
Request Syntax
client.test_event_pattern( EventPattern='string', Event='string' )
string
[REQUIRED]
The event pattern you want to test.
string
[REQUIRED]
The event in the JSON format to test against the event pattern.
dict
Response Syntax
{ 'Result': True|False }
Response Structure
(dict) --
The result of the TestEventPattern operation.
Result (boolean) --
Indicates whether the event matches the event pattern.
Lists the Amazon CloudWatch Events rules in your account. You can either list all the rules or you can provide a prefix to match to the rule names. If you have more rules in your account than the given limit, the results will be paginated. In that case, use the next token returned in the response and repeat ListRules until the NextToken in the response is returned as null.
Request Syntax
client.list_rules( NamePrefix='string', NextToken='string', Limit=123 )
string
The prefix matching the rule name.
string
The token returned by a previous call to indicate that there is more data available.
integer
The maximum number of results to return.
dict
Response Syntax
{ 'Rules': [ { 'Name': 'string', 'Arn': 'string', 'EventPattern': 'string', 'State': 'ENABLED'|'DISABLED', 'Description': 'string', 'ScheduleExpression': 'string', 'RoleArn': 'string' }, ], 'NextToken': 'string' }
Response Structure
(dict) --
The result of the ListRules operation.
Rules (list) --
List of rules matching the specified criteria.
(dict) --
Contains information about a rule in Amazon CloudWatch Events. A ListRulesResult contains a list of Rules.
Name (string) --
The rule's name.
Arn (string) --
The Amazon Resource Name (ARN) of the rule.
EventPattern (string) --
The event pattern of the rule.
State (string) --
The rule's state.
Description (string) --
The description of the rule.
ScheduleExpression (string) --
The scheduling expression. For example, "cron(0 20 * * ? *)", "rate(5 minutes)".
RoleArn (string) --
The Amazon Resource Name (ARN) associated with the role that is used for target invocation.
NextToken (string) --
Indicates that there are additional results to retrieve.
Enables a rule. If the rule does not exist, the operation fails.
Note: When you enable a rule, incoming events might not immediately start matching to a newly enabled rule. Please allow a short period of time for changes to take effect.
Request Syntax
client.enable_rule( Name='string' )
string
[REQUIRED]
The name of the rule that you want to enable.
None
Deletes a rule. You must remove all targets from a rule using RemoveTargets before you can delete the rule.
Note: When you delete a rule, incoming events might still continue to match to the deleted rule. Please allow a short period of time for changes to take effect.
Request Syntax
client.delete_rule( Name='string' )
string
[REQUIRED]
The name of the rule to be deleted.
None
Sends custom events to Amazon CloudWatch Events so that they can be matched to rules.
Request Syntax
client.put_events( Entries=[ { 'Time': datetime(2015, 1, 1), 'Source': 'string', 'Resources': [ 'string', ], 'DetailType': 'string', 'Detail': 'string' }, ] )
list
[REQUIRED]
The entry that defines an event in your system. You can specify several parameters for the entry such as the source and type of the event, resources associated with the event, and so on.
(dict) --
Contains information about the event to be used in PutEvents.
Time (datetime) --
Timestamp of event, per RFC3339 . If no timestamp is provided, the timestamp of the PutEvents call will be used.
Source (string) --
The source of the event.
Resources (list) --
AWS resources, identified by Amazon Resource Name (ARN), which the event primarily concerns. Any number, including zero, may be present.
(string) --
DetailType (string) --
Free-form string used to decide what fields to expect in the event detail.
Detail (string) --
In the JSON sense, an object containing fields, which may also contain nested sub-objects. No constraints are imposed on its contents.
dict
Response Syntax
{ 'FailedEntryCount': 123, 'Entries': [ { 'EventId': 'string', 'ErrorCode': 'string', 'ErrorMessage': 'string' }, ] }
Response Structure
(dict) --
The result of the PutEvents operation.
FailedEntryCount (integer) --
The number of failed entries.
Entries (list) --
A list of successfully and unsuccessfully ingested events results. If the ingestion was successful, the entry will have the event ID in it. If not, then the ErrorCode and ErrorMessage can be used to identify the problem with the entry.
(dict) --
A PutEventsResult contains a list of PutEventsResultEntry.
EventId (string) --
The ID of the event submitted to Amazon CloudWatch Events.
ErrorCode (string) --
The error code representing why the event submission failed on this entry.
ErrorMessage (string) --
The error message explaining why the event submission failed on this entry.
Lists the names of the rules that the given target is put to. You can see which of the rules in Amazon CloudWatch Events can invoke a specific target in your account. If you have more rules in your account than the given limit, the results will be paginated. In that case, use the next token returned in the response and repeat ListRulesByTarget until the NextToken in the response is returned as null.
Request Syntax
client.list_rule_names_by_target( TargetArn='string', NextToken='string', Limit=123 )
string
[REQUIRED]
The Amazon Resource Name (ARN) of the target resource that you want to list the rules for.
string
The token returned by a previous call to indicate that there is more data available.
integer
The maximum number of results to return.
dict
Response Syntax
{ 'RuleNames': [ 'string', ], 'NextToken': 'string' }
Response Structure
(dict) --
The result of the ListRuleNamesByTarget operation.
RuleNames (list) --
List of rules names that can invoke the given target.
(string) --
NextToken (string) --
Indicates that there are additional results to retrieve.
Adds target(s) to a rule. Targets are the resources that can be invoked when a rule is triggered. For example, AWS Lambda functions, Amazon Kinesis streams, and built-in targets. Updates the target(s) if they are already associated with the role. In other words, if there is already a target with the given target ID, then the target associated with that ID is updated.
In order to be able to make API calls against the resources you own, Amazon CloudWatch Events needs the appropriate permissions. For AWS Lambda and Amazon SNS resources, CloudWatch Events relies on resource-based policies. For Amazon Kinesis streams, CloudWatch Events relies on IAM roles. For more information, see Permissions for Sending Events to Targets in the *Amazon CloudWatch Developer Guide* .
Input and InputPath are mutually-exclusive and optional parameters of a target. When a rule is triggered due to a matched event, if for a target:
Neither Input nor InputPath is specified, then the entire event is passed to the target in JSON form.
InputPath is specified in the form of JSONPath (e.g. $.detail ), then only the part of the event specified in the path is passed to the target (e.g. only the detail part of the event is passed).
Input is specified in the form of a valid JSON, then the matched event is overridden with this constant.
Note: When you add targets to a rule, when the associated rule triggers, new or updated targets might not be immediately invoked. Please allow a short period of time for changes to take effect.
Request Syntax
client.put_targets( Rule='string', Targets=[ { 'Id': 'string', 'Arn': 'string', 'Input': 'string', 'InputPath': 'string' }, ] )
string
[REQUIRED]
The name of the rule you want to add targets to.
list
[REQUIRED]
List of targets you want to update or add to the rule.
(dict) --
Targets are the resources that can be invoked when a rule is triggered. For example, AWS Lambda functions, Amazon Kinesis streams, and built-in targets.
Input and InputPath are mutually-exclusive and optional parameters of a target. When a rule is triggered due to a matched event, if for a target:
Neither Input nor InputPath is specified, then the entire event is passed to the target in JSON form.
InputPath is specified in the form of JSONPath (e.g. $.detail ), then only the part of the event specified in the path is passed to the target (e.g. only the detail part of the event is passed).
Input is specified in the form of a valid JSON, then the matched event is overridden with this constant.
Id (string) -- [REQUIRED]
The unique target assignment ID.
Arn (string) -- [REQUIRED]
The Amazon Resource Name (ARN) associated of the target.
Input (string) --
Valid JSON text passed to the target. For more information about JSON text, see The JavaScript Object Notation (JSON) Data Interchange Format .
InputPath (string) --
The value of the JSONPath that is used for extracting part of the matched event when passing it to the target. For more information about JSON paths, see JSONPath .
dict
Response Syntax
{ 'FailedEntryCount': 123, 'FailedEntries': [ { 'TargetId': 'string', 'ErrorCode': 'string', 'ErrorMessage': 'string' }, ] }
Response Structure
(dict) --
The result of the PutTargets operation.
FailedEntryCount (integer) --
The number of failed entries.
FailedEntries (list) --
An array of failed target entries.
(dict) --
A PutTargetsResult contains a list of PutTargetsResultEntry.
TargetId (string) --
The ID of the target submitted to Amazon CloudWatch Events.
ErrorCode (string) --
The error code representing why the target submission failed on this entry.
ErrorMessage (string) --
The error message explaining why the target submission failed on this entry.