NAME
Paws::IoTEvents::CreateAlarmModel - Arguments for method CreateAlarmModel on Paws::IoTEvents
DESCRIPTION
This class represents the parameters used for calling the method CreateAlarmModel on the AWS IoT Events service. Use the attributes of this class as arguments to method CreateAlarmModel.
You shouldn't make instances of this class. Each attribute should be used as a named argument in the call to CreateAlarmModel.
SYNOPSIS
my $iotevents = Paws->service('IoTEvents');
my $CreateAlarmModelResponse = $iotevents->CreateAlarmModel(
AlarmModelName => 'MyAlarmModelName',
AlarmRule => {
SimpleRule => {
ComparisonOperator => 'GREATER'
, # values: GREATER, GREATER_OR_EQUAL, LESS, LESS_OR_EQUAL, EQUAL, NOT_EQUAL
InputProperty => 'MyInputProperty', # min: 1, max: 512
Threshold => 'MyThreshold', # min: 1, max: 512
}, # OPTIONAL
},
RoleArn => 'MyAmazonResourceName',
AlarmCapabilities => {
AcknowledgeFlow => {
Enabled => 1,
}, # OPTIONAL
InitializationConfiguration => {
DisabledOnInitialization => 1,
}, # OPTIONAL
}, # OPTIONAL
AlarmEventActions => {
AlarmActions => [
{
DynamoDB => {
HashKeyField => 'MyDynamoKeyField',
HashKeyValue => 'MyDynamoKeyValue',
TableName => 'MyDynamoTableName',
HashKeyType => 'MyDynamoKeyType', # OPTIONAL
Operation => 'MyDynamoOperation', # OPTIONAL
Payload => {
ContentExpression => 'MyContentExpression', # min: 1
Type => 'STRING', # values: STRING, JSON
}, # OPTIONAL
PayloadField => 'MyDynamoKeyField',
RangeKeyField => 'MyDynamoKeyField',
RangeKeyType => 'MyDynamoKeyType', # OPTIONAL
RangeKeyValue => 'MyDynamoKeyValue',
}, # OPTIONAL
DynamoDBv2 => {
TableName => 'MyDynamoTableName',
Payload => {
ContentExpression => 'MyContentExpression', # min: 1
Type => 'STRING', # values: STRING, JSON
}, # OPTIONAL
}, # OPTIONAL
Firehose => {
DeliveryStreamName => 'MyDeliveryStreamName',
Payload => {
ContentExpression => 'MyContentExpression', # min: 1
Type => 'STRING', # values: STRING, JSON
}, # OPTIONAL
Separator => 'MyFirehoseSeparator', # OPTIONAL
}, # OPTIONAL
IotEvents => {
InputName => 'MyInputName', # min: 1, max: 128
Payload => {
ContentExpression => 'MyContentExpression', # min: 1
Type => 'STRING', # values: STRING, JSON
}, # OPTIONAL
}, # OPTIONAL
IotSiteWise => {
AssetId => 'MyAssetId', # OPTIONAL
EntryId => 'MyAssetPropertyEntryId', # OPTIONAL
PropertyAlias => 'MyAssetPropertyAlias', # OPTIONAL
PropertyId => 'MyAssetPropertyId', # OPTIONAL
PropertyValue => {
Quality => 'MyAssetPropertyQuality', # OPTIONAL
Timestamp => {
TimeInSeconds => 'MyAssetPropertyTimeInSeconds',
OffsetInNanos => 'MyAssetPropertyOffsetInNanos', # OPTIONAL
}, # OPTIONAL
Value => {
BooleanValue => 'MyAssetPropertyBooleanValue', # OPTIONAL
DoubleValue => 'MyAssetPropertyDoubleValue', # OPTIONAL
IntegerValue => 'MyAssetPropertyIntegerValue', # OPTIONAL
StringValue => 'MyAssetPropertyStringValue', # OPTIONAL
}, # OPTIONAL
}, # OPTIONAL
}, # OPTIONAL
IotTopicPublish => {
MqttTopic => 'MyMQTTTopic', # min: 1, max: 128
Payload => {
ContentExpression => 'MyContentExpression', # min: 1
Type => 'STRING', # values: STRING, JSON
}, # OPTIONAL
}, # OPTIONAL
Lambda => {
FunctionArn => 'MyAmazonResourceName', # min: 1, max: 2048
Payload => {
ContentExpression => 'MyContentExpression', # min: 1
Type => 'STRING', # values: STRING, JSON
}, # OPTIONAL
}, # OPTIONAL
Sns => {
TargetArn => 'MyAmazonResourceName', # min: 1, max: 2048
Payload => {
ContentExpression => 'MyContentExpression', # min: 1
Type => 'STRING', # values: STRING, JSON
}, # OPTIONAL
}, # OPTIONAL
Sqs => {
QueueUrl => 'MyQueueUrl',
Payload => {
ContentExpression => 'MyContentExpression', # min: 1
Type => 'STRING', # values: STRING, JSON
}, # OPTIONAL
UseBase64 => 1, # OPTIONAL
}, # OPTIONAL
},
...
], # OPTIONAL
}, # OPTIONAL
AlarmModelDescription => 'MyAlarmModelDescription', # OPTIONAL
AlarmNotification => {
NotificationActions => [
{
Action => {
LambdaAction => {
FunctionArn => 'MyAmazonResourceName', # min: 1, max: 2048
Payload => {
ContentExpression => 'MyContentExpression', # min: 1
Type => 'STRING', # values: STRING, JSON
}, # OPTIONAL
}, # OPTIONAL
},
EmailConfigurations => [
{
From => 'MyFromEmail',
Recipients => {
To => [
{
SsoIdentity => {
IdentityStoreId => 'MyIdentityStoreId',
UserId => 'MySSOReferenceId', # OPTIONAL
}, # OPTIONAL
},
...
], # min: 1; OPTIONAL
},
Content => {
AdditionalMessage =>
'MyNotificationAdditionalMessage', # OPTIONAL
Subject => 'MyEmailSubject', # OPTIONAL
}, # OPTIONAL
},
...
], # min: 1; OPTIONAL
SmsConfigurations => [
{
Recipients => [
{
SsoIdentity => {
IdentityStoreId => 'MyIdentityStoreId',
UserId => 'MySSOReferenceId', # OPTIONAL
}, # OPTIONAL
},
...
], # min: 1; OPTIONAL
AdditionalMessage =>
'MyNotificationAdditionalMessage', # OPTIONAL
SenderId => 'MySMSSenderId', # OPTIONAL
},
...
], # min: 1; OPTIONAL
},
...
], # min: 1; OPTIONAL
}, # OPTIONAL
Key => 'MyAttributeJsonPath', # OPTIONAL
Severity => 1, # OPTIONAL
Tags => [
{
Key => 'MyTagKey', # min: 1, max: 128
Value => 'MyTagValue', # max: 256
},
...
], # OPTIONAL
);
# Results:
my $AlarmModelArn = $CreateAlarmModelResponse->AlarmModelArn;
my $AlarmModelVersion = $CreateAlarmModelResponse->AlarmModelVersion;
my $CreationTime = $CreateAlarmModelResponse->CreationTime;
my $LastUpdateTime = $CreateAlarmModelResponse->LastUpdateTime;
my $Status = $CreateAlarmModelResponse->Status;
# Returns a L<Paws::IoTEvents::CreateAlarmModelResponse> object.
Values for attributes that are native types (Int, String, Float, etc) can passed as-is (scalar values). Values for complex Types (objects) can be passed as a HashRef. The keys and values of the hashref will be used to instance the underlying object. For the AWS API documentation, see https://docs.aws.amazon.com/goto/WebAPI/iotevents/CreateAlarmModel
ATTRIBUTES
AlarmCapabilities => Paws::IoTEvents::AlarmCapabilities
Contains the configuration information of alarm state changes.
AlarmEventActions => Paws::IoTEvents::AlarmEventActions
Contains information about one or more alarm actions.
AlarmModelDescription => Str
A description that tells you what the alarm model detects.
REQUIRED AlarmModelName => Str
A unique name that helps you identify the alarm model. You can't change this name after you create the alarm model.
AlarmNotification => Paws::IoTEvents::AlarmNotification
Contains information about one or more notification actions.
REQUIRED AlarmRule => Paws::IoTEvents::AlarmRule
Defines when your alarm is invoked.
Key => Str
An input attribute used as a key to create an alarm. AWS IoT Events routes inputs (https://docs.aws.amazon.com/iotevents/latest/apireference/API_Input.html) associated with this key to the alarm.
REQUIRED RoleArn => Str
The ARN of the IAM role that allows the alarm to perform actions and access AWS resources. For more information, see Amazon Resource Names (ARNs) (https://docs.aws.amazon.com/general/latest/gr/aws-arns-and-namespaces.html) in the AWS General Reference.
Severity => Int
A non-negative integer that reflects the severity level of the alarm.
Tags => ArrayRef[Paws::IoTEvents::Tag]
A list of key-value pairs that contain metadata for the alarm model. The tags help you manage the alarm model. For more information, see Tagging your AWS IoT Events resources (https://docs.aws.amazon.com/iotevents/latest/developerguide/tagging-iotevents.html) in the AWS IoT Events Developer Guide.
You can create up to 50 tags for one alarm model.
SEE ALSO
This class forms part of Paws, documenting arguments for method CreateAlarmModel in Paws::IoTEvents
BUGS and CONTRIBUTIONS
The source code is located here: https://github.com/pplu/aws-sdk-perl
Please report bugs to: https://github.com/pplu/aws-sdk-perl/issues