/*
* 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.
///
public partial class GlobalSecondaryIndexDescription
{
private bool? _backfilling;
private string _indexArn;
private string _indexName;
private long? _indexSizeBytes;
private IndexStatus _indexStatus;
private long? _itemCount;
private List _keySchema = new List();
private Projection _projection;
private ProvisionedThroughputDescription _provisionedThroughput;
///
/// Gets and sets the property Backfilling.
///
/// Indicates whether the index is currently backfilling. Backfilling is the process
/// of reading items from the table and determining whether they can be added to the index.
/// (Not all items will qualify: For example, a partition key cannot have any duplicate
/// values.) If an item can be added to the index, DynamoDB will do so. After all items
/// have been processed, the backfilling operation is complete and Backfilling
/// is false.
///
///
///
/// You can delete an index that is being created during the Backfilling
/// phase when IndexStatus
is set to CREATING and Backfilling
/// is true. You can't delete the index that is being created when IndexStatus
/// is set to CREATING and Backfilling
is false.
///
///
///
/// For indexes that were created during a CreateTable
operation, the Backfilling
/// attribute does not appear in the DescribeTable
output.
///
///
///
public bool Backfilling
{
get { return this._backfilling.GetValueOrDefault(); }
set { this._backfilling = value; }
}
// Check to see if Backfilling property is set
internal bool IsSetBackfilling()
{
return this._backfilling.HasValue;
}
///
/// Gets and sets the property IndexArn.
///
/// The Amazon Resource Name (ARN) that uniquely identifies the index.
///
///
public string IndexArn
{
get { return this._indexArn; }
set { this._indexArn = value; }
}
// Check to see if IndexArn property is set
internal bool IsSetIndexArn()
{
return this._indexArn != null;
}
///
/// 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 IndexSizeBytes.
///
/// The total size of the specified index, in bytes. DynamoDB updates this value approximately
/// every six hours. Recent changes might not be reflected in this value.
///
///
public long IndexSizeBytes
{
get { return this._indexSizeBytes.GetValueOrDefault(); }
set { this._indexSizeBytes = value; }
}
// Check to see if IndexSizeBytes property is set
internal bool IsSetIndexSizeBytes()
{
return this._indexSizeBytes.HasValue;
}
///
/// Gets and sets the property IndexStatus.
///
/// The current state of the global secondary index:
///
/// -
///
///
CREATING
- The index is being created.
///
/// -
///
///
UPDATING
- The index is being updated.
///
/// -
///
///
DELETING
- The index is being deleted.
///
/// -
///
///
ACTIVE
- The index is ready for use.
///
///
///
public IndexStatus IndexStatus
{
get { return this._indexStatus; }
set { this._indexStatus = value; }
}
// Check to see if IndexStatus property is set
internal bool IsSetIndexStatus()
{
return this._indexStatus != null;
}
///
/// Gets and sets the property ItemCount.
///
/// The number of items in the specified index. DynamoDB updates this value approximately
/// every six hours. Recent changes might not be reflected in this value.
///
///
public long ItemCount
{
get { return this._itemCount.GetValueOrDefault(); }
set { this._itemCount = value; }
}
// Check to see if ItemCount property is set
internal bool IsSetItemCount()
{
return this._itemCount.HasValue;
}
///
/// 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.
///
///
///
/// For current minimum and maximum provisioned throughput values, see Limits
/// in the Amazon DynamoDB Developer Guide.
///
///
public ProvisionedThroughputDescription ProvisionedThroughput
{
get { return this._provisionedThroughput; }
set { this._provisionedThroughput = value; }
}
// Check to see if ProvisionedThroughput property is set
internal bool IsSetProvisionedThroughput()
{
return this._provisionedThroughput != null;
}
}
}