/* * 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; } } }