/*
* 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
{
///
/// Container for the parameters to the CreatePolicy operation.
/// Creates an IoT policy.
///
///
///
/// The created policy is the default version for the policy. This operation creates a
/// policy version with a version identifier of 1 and sets 1 as the policy's
/// default version.
///
///
///
/// Requires permission to access the CreatePolicy
/// action.
///
///
public partial class CreatePolicyRequest : AmazonIoTRequest
{
private string _policyDocument;
private string _policyName;
private List _tags = new List();
///
/// Gets and sets the property PolicyDocument.
///
/// The JSON document that describes the policy. policyDocument must have a minimum
/// length of 1, with a maximum length of 2048, excluding whitespace.
///
///
[AWSProperty(Required=true, Min=0, Max=404600)]
public string PolicyDocument
{
get { return this._policyDocument; }
set { this._policyDocument = value; }
}
// Check to see if PolicyDocument property is set
internal bool IsSetPolicyDocument()
{
return this._policyDocument != null;
}
///
/// Gets and sets the property PolicyName.
///
/// The policy name.
///
///
[AWSProperty(Required=true, Min=1, Max=128)]
public string PolicyName
{
get { return this._policyName; }
set { this._policyName = value; }
}
// Check to see if PolicyName property is set
internal bool IsSetPolicyName()
{
return this._policyName != null;
}
///
/// Gets and sets the property Tags.
///
/// Metadata which can be used to manage the policy.
///
///
///
/// For URI Request parameters use format: ...key1=value1&key2=value2...
///
///
///
/// For the CLI command-line parameter use format: &&tags "key1=value1&key2=value2..."
///
///
///
/// For the cli-input-json file use format: "tags": "key1=value1&key2=value2..."
///
///
///
public List Tags
{
get { return this._tags; }
set { this._tags = value; }
}
// Check to see if Tags property is set
internal bool IsSetTags()
{
return this._tags != null && this._tags.Count > 0;
}
}
}