/*
* Copyright 2010-2014 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 dynamodb-2012-08-10.normal.json service model.
*/
using System;
using System.Collections.Generic;
using System.Xml.Serialization;
using System.Text;
using System.IO;
using Amazon.Runtime;
using Amazon.Runtime.Internal;
namespace Amazon.DynamoDBv2.Model
{
///
/// Represents the properties of a global secondary index for the table when the backup
/// was created.
///
public partial class GlobalSecondaryIndexInfo
{
private string _indexName;
private List _keySchema = new List();
private Projection _projection;
private ProvisionedThroughput _provisionedThroughput;
///
/// Gets and sets the property IndexName.
///
/// The name of the global secondary index.
///
///
[AWSProperty(Min=3, Max=255)]
public string IndexName
{
get { return this._indexName; }
set { this._indexName = value; }
}
// Check to see if IndexName property is set
internal bool IsSetIndexName()
{
return this._indexName != null;
}
///
/// Gets and sets the property KeySchema.
///
/// The complete key schema for a global secondary index, which consists of one or more
/// pairs of attribute names and key types:
///
/// -
///
///
HASH
- partition key
///
/// -
///
///
RANGE
- sort key
///
///
///
/// The partition key of an item is also known as its hash attribute. The term
/// "hash attribute" derives from DynamoDB's usage of an internal hash function to evenly
/// distribute data items across partitions, based on their partition key values.
///
///
///
/// The sort key of an item is also known as its range attribute. The term "range
/// attribute" derives from the way DynamoDB stores items with the same partition key
/// physically close together, in sorted order by the sort key value.
///
///
///
[AWSProperty(Min=1, Max=2)]
public List KeySchema
{
get { return this._keySchema; }
set { this._keySchema = value; }
}
// Check to see if KeySchema property is set
internal bool IsSetKeySchema()
{
return this._keySchema != null && this._keySchema.Count > 0;
}
///
/// Gets and sets the property Projection.
///
/// Represents attributes that are copied (projected) from the table into the global secondary
/// index. These are in addition to the primary key attributes and index key attributes,
/// which are automatically projected.
///
///
public Projection Projection
{
get { return this._projection; }
set { this._projection = value; }
}
// Check to see if Projection property is set
internal bool IsSetProjection()
{
return this._projection != null;
}
///
/// Gets and sets the property ProvisionedThroughput.
///
/// Represents the provisioned throughput settings for the specified global secondary
/// index.
///
///
public ProvisionedThroughput ProvisionedThroughput
{
get { return this._provisionedThroughput; }
set { this._provisionedThroughput = value; }
}
// Check to see if ProvisionedThroughput property is set
internal bool IsSetProvisionedThroughput()
{
return this._provisionedThroughput != null;
}
}
}