/*
* 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 iot-2015-05-28.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.IoT.Model
{
///
/// Describes a rule.
///
public partial class TopicRule
{
private List _actions = new List();
private string _awsIotSqlVersion;
private DateTime? _createdAt;
private string _description;
private Action _errorAction;
private bool? _ruleDisabled;
private string _ruleName;
private string _sql;
///
/// Gets and sets the property Actions.
///
/// The actions associated with the rule.
///
///
[AWSProperty(Min=0, Max=10)]
public List Actions
{
get { return this._actions; }
set { this._actions = value; }
}
// Check to see if Actions property is set
internal bool IsSetActions()
{
return this._actions != null && this._actions.Count > 0;
}
///
/// Gets and sets the property AwsIotSqlVersion.
///
/// The version of the SQL rules engine to use when evaluating the rule.
///
///
public string AwsIotSqlVersion
{
get { return this._awsIotSqlVersion; }
set { this._awsIotSqlVersion = value; }
}
// Check to see if AwsIotSqlVersion property is set
internal bool IsSetAwsIotSqlVersion()
{
return this._awsIotSqlVersion != null;
}
///
/// Gets and sets the property CreatedAt.
///
/// The date and time the rule was created.
///
///
public DateTime CreatedAt
{
get { return this._createdAt.GetValueOrDefault(); }
set { this._createdAt = value; }
}
// Check to see if CreatedAt property is set
internal bool IsSetCreatedAt()
{
return this._createdAt.HasValue;
}
///
/// Gets and sets the property Description.
///
/// The description of the rule.
///
///
public string Description
{
get { return this._description; }
set { this._description = value; }
}
// Check to see if Description property is set
internal bool IsSetDescription()
{
return this._description != null;
}
///
/// Gets and sets the property ErrorAction.
///
/// The action to perform when an error occurs.
///
///
public Action ErrorAction
{
get { return this._errorAction; }
set { this._errorAction = value; }
}
// Check to see if ErrorAction property is set
internal bool IsSetErrorAction()
{
return this._errorAction != null;
}
///
/// Gets and sets the property RuleDisabled.
///
/// Specifies whether the rule is disabled.
///
///
public bool RuleDisabled
{
get { return this._ruleDisabled.GetValueOrDefault(); }
set { this._ruleDisabled = value; }
}
// Check to see if RuleDisabled property is set
internal bool IsSetRuleDisabled()
{
return this._ruleDisabled.HasValue;
}
///
/// Gets and sets the property RuleName.
///
/// The name of the rule.
///
///
[AWSProperty(Min=1, Max=128)]
public string RuleName
{
get { return this._ruleName; }
set { this._ruleName = value; }
}
// Check to see if RuleName property is set
internal bool IsSetRuleName()
{
return this._ruleName != null;
}
///
/// Gets and sets the property Sql.
///
/// The SQL statement used to query the topic. When using a SQL query with multiple lines,
/// be sure to escape the newline characters.
///
///
public string Sql
{
get { return this._sql; }
set { this._sql = value; }
}
// Check to see if Sql property is set
internal bool IsSetSql()
{
return this._sql != null;
}
}
}