/*
* 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 redshift-2012-12-01.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.Redshift.Model
{
///
/// Container for the parameters to the CreateHsmConfiguration operation.
/// Creates an HSM configuration that contains the information required by an Amazon Redshift
/// cluster to store and use database encryption keys in a Hardware Security Module (HSM).
/// After creating the HSM configuration, you can specify it as a parameter when creating
/// a cluster. The cluster will then store its encryption keys in the HSM.
///
///
///
/// In addition to creating an HSM configuration, you must also create an HSM client certificate.
/// For more information, go to Hardware
/// Security Modules in the Amazon Redshift Cluster Management Guide.
///
///
public partial class CreateHsmConfigurationRequest : AmazonRedshiftRequest
{
private string _description;
private string _hsmConfigurationIdentifier;
private string _hsmIpAddress;
private string _hsmPartitionName;
private string _hsmPartitionPassword;
private string _hsmServerPublicCertificate;
private List _tags = new List();
///
/// Gets and sets the property Description.
///
/// A text description of the HSM configuration to be created.
///
///
[AWSProperty(Required=true, Max=2147483647)]
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 HsmConfigurationIdentifier.
///
/// The identifier to be assigned to the new Amazon Redshift HSM configuration.
///
///
[AWSProperty(Required=true, Max=2147483647)]
public string HsmConfigurationIdentifier
{
get { return this._hsmConfigurationIdentifier; }
set { this._hsmConfigurationIdentifier = value; }
}
// Check to see if HsmConfigurationIdentifier property is set
internal bool IsSetHsmConfigurationIdentifier()
{
return this._hsmConfigurationIdentifier != null;
}
///
/// Gets and sets the property HsmIpAddress.
///
/// The IP address that the Amazon Redshift cluster must use to access the HSM.
///
///
[AWSProperty(Required=true, Max=2147483647)]
public string HsmIpAddress
{
get { return this._hsmIpAddress; }
set { this._hsmIpAddress = value; }
}
// Check to see if HsmIpAddress property is set
internal bool IsSetHsmIpAddress()
{
return this._hsmIpAddress != null;
}
///
/// Gets and sets the property HsmPartitionName.
///
/// The name of the partition in the HSM where the Amazon Redshift clusters will store
/// their database encryption keys.
///
///
[AWSProperty(Required=true, Max=2147483647)]
public string HsmPartitionName
{
get { return this._hsmPartitionName; }
set { this._hsmPartitionName = value; }
}
// Check to see if HsmPartitionName property is set
internal bool IsSetHsmPartitionName()
{
return this._hsmPartitionName != null;
}
///
/// Gets and sets the property HsmPartitionPassword.
///
/// The password required to access the HSM partition.
///
///
[AWSProperty(Required=true, Max=2147483647)]
public string HsmPartitionPassword
{
get { return this._hsmPartitionPassword; }
set { this._hsmPartitionPassword = value; }
}
// Check to see if HsmPartitionPassword property is set
internal bool IsSetHsmPartitionPassword()
{
return this._hsmPartitionPassword != null;
}
///
/// Gets and sets the property HsmServerPublicCertificate.
///
/// The HSMs public certificate file. When using Cloud HSM, the file name is server.pem.
///
///
[AWSProperty(Required=true, Max=2147483647)]
public string HsmServerPublicCertificate
{
get { return this._hsmServerPublicCertificate; }
set { this._hsmServerPublicCertificate = value; }
}
// Check to see if HsmServerPublicCertificate property is set
internal bool IsSetHsmServerPublicCertificate()
{
return this._hsmServerPublicCertificate != null;
}
///
/// Gets and sets the property Tags.
///
/// A list of tag instances.
///
///
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;
}
}
}