/* * 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 GlobalSecondaryIndex { 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. The name must be unique among all other indexes /// on this table. /// /// [AWSProperty(Required=true, 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(Required=true, 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. /// /// [AWSProperty(Required=true)] 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 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; } } }