/*
* 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 kinesis-2013-12-02.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.Kinesis.Model
{
///
/// Container for the parameters to the ListShards operation.
/// Lists the shards in a stream and provides information about each shard. This operation
/// has a limit of 100 transactions per second per data stream.
///
///
///
/// This API is a new operation that is used by the Amazon Kinesis Client Library (KCL).
/// If you have a fine-grained IAM policy that only allows specific operations, you must
/// update your policy to allow calls to this API. For more information, see Controlling
/// Access to Amazon Kinesis Data Streams Resources Using IAM.
///
///
///
public partial class ListShardsRequest : AmazonKinesisRequest
{
private string _exclusiveStartShardId;
private int? _maxResults;
private string _nextToken;
private DateTime? _streamCreationTimestamp;
private string _streamName;
///
/// Gets and sets the property ExclusiveStartShardId.
///
/// Specify this parameter to indicate that you want to list the shards starting with
/// the shard whose ID immediately follows ExclusiveStartShardId
.
///
///
///
/// If you don't specify this parameter, the default behavior is for ListShards
/// to list the shards starting with the first one in the stream.
///
///
///
/// You cannot specify this parameter if you specify NextToken
.
///
///
[AWSProperty(Min=1, Max=128)]
public string ExclusiveStartShardId
{
get { return this._exclusiveStartShardId; }
set { this._exclusiveStartShardId = value; }
}
// Check to see if ExclusiveStartShardId property is set
internal bool IsSetExclusiveStartShardId()
{
return this._exclusiveStartShardId != null;
}
///
/// Gets and sets the property MaxResults.
///
/// The maximum number of shards to return in a single call to ListShards
.
/// The minimum value you can specify for this parameter is 1, and the maximum is 1,000,
/// which is also the default.
///
///
///
/// When the number of shards to be listed is greater than the value of MaxResults
,
/// the response contains a NextToken
value that you can use in a subsequent
/// call to ListShards
to list the next set of shards.
///
///
[AWSProperty(Min=1, Max=10000)]
public int MaxResults
{
get { return this._maxResults.GetValueOrDefault(); }
set { this._maxResults = value; }
}
// Check to see if MaxResults property is set
internal bool IsSetMaxResults()
{
return this._maxResults.HasValue;
}
///
/// Gets and sets the property NextToken.
///
/// When the number of shards in the data stream is greater than the default value for
/// the MaxResults
parameter, or if you explicitly specify a value for MaxResults
/// that is less than the number of shards in the data stream, the response includes a
/// pagination token named NextToken
. You can specify this NextToken
/// value in a subsequent call to ListShards
to list the next set of shards.
///
///
///
/// Don't specify StreamName
or StreamCreationTimestamp
if you
/// specify NextToken
because the latter unambiguously identifies the stream.
///
///
///
/// You can optionally specify a value for the MaxResults
parameter when
/// you specify NextToken
. If you specify a MaxResults
value
/// that is less than the number of shards that the operation returns if you don't specify
/// MaxResults
, the response will contain a new NextToken
value.
/// You can use the new NextToken
value in a subsequent call to the ListShards
/// operation.
///
///
///
/// Tokens expire after 300 seconds. When you obtain a value for NextToken
/// in the response to a call to ListShards
, you have 300 seconds to use
/// that value. If you specify an expired token in a call to ListShards
,
/// you get ExpiredNextTokenException
.
///
///
///
[AWSProperty(Min=1, Max=1048576)]
public string NextToken
{
get { return this._nextToken; }
set { this._nextToken = value; }
}
// Check to see if NextToken property is set
internal bool IsSetNextToken()
{
return this._nextToken != null;
}
///
/// Gets and sets the property StreamCreationTimestamp.
///
/// Specify this input parameter to distinguish data streams that have the same name.
/// For example, if you create a data stream and then delete it, and you later create
/// another data stream with the same name, you can use this input parameter to specify
/// which of the two streams you want to list the shards for.
///
///
///
/// You cannot specify this parameter if you specify the NextToken
parameter.
///
///
public DateTime StreamCreationTimestamp
{
get { return this._streamCreationTimestamp.GetValueOrDefault(); }
set { this._streamCreationTimestamp = value; }
}
// Check to see if StreamCreationTimestamp property is set
internal bool IsSetStreamCreationTimestamp()
{
return this._streamCreationTimestamp.HasValue;
}
///
/// Gets and sets the property StreamName.
///
/// The name of the data stream whose shards you want to list.
///
///
///
/// You cannot specify this parameter if you specify the NextToken
parameter.
///
///
[AWSProperty(Min=1, Max=128)]
public string StreamName
{
get { return this._streamName; }
set { this._streamName = value; }
}
// Check to see if StreamName property is set
internal bool IsSetStreamName()
{
return this._streamName != null;
}
}
}