/*
* Copyright 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 ec2-2016-11-15.normal.json service model.
*/
using System;
using System.Collections.Generic;
using System.Xml.Serialization;
using System.Text;
using System.IO;
using System.Net;
using Amazon.Runtime;
using Amazon.Runtime.Internal;
namespace Amazon.EC2.Model
{
///
/// Container for the parameters to the ModifyIdentityIdFormat operation.
/// Modifies the ID format of a resource for a specified IAM user, IAM role, or the root
/// user for an account; or all IAM users, IAM roles, and the root user for an account.
/// You can specify that resources should receive longer IDs (17-character IDs) when they
/// are created.
///
///
///
/// This request can only be used to modify longer ID settings for resource types that
/// are within the opt-in period. Resources currently in their opt-in period include:
/// bundle
| conversion-task
| customer-gateway
/// | dhcp-options
| elastic-ip-allocation
| elastic-ip-association
/// | export-task
| flow-log
| image
| import-task
/// | internet-gateway
| network-acl
| network-acl-association
/// | network-interface
| network-interface-attachment
| prefix-list
/// | route-table
| route-table-association
| security-group
/// | subnet
| subnet-cidr-block-association
| vpc
/// | vpc-cidr-block-association
| vpc-endpoint
| vpc-peering-connection
/// | vpn-connection
| vpn-gateway
.
///
///
///
/// For more information, see Resource
/// IDs in the Amazon Elastic Compute Cloud User Guide.
///
///
///
/// This setting applies to the principal specified in the request; it does not apply
/// to the principal that makes the request.
///
///
///
/// Resources created with longer IDs are visible to all IAM roles and users, regardless
/// of these settings and provided that they have permission to use the relevant Describe
/// command for the resource type.
///
///
public partial class ModifyIdentityIdFormatRequest : AmazonEC2Request
{
private string _principalArn;
private string _resource;
private bool? _useLongIds;
///
/// Gets and sets the property PrincipalArn.
///
/// The ARN of the principal, which can be an IAM user, IAM role, or the root user. Specify
/// all
to modify the ID format for all IAM users, IAM roles, and the root
/// user of the account.
///
///
[AWSProperty(Required=true)]
public string PrincipalArn
{
get { return this._principalArn; }
set { this._principalArn = value; }
}
// Check to see if PrincipalArn property is set
internal bool IsSetPrincipalArn()
{
return this._principalArn != null;
}
///
/// Gets and sets the property Resource.
///
/// The type of resource: bundle
| conversion-task
| customer-gateway
/// | dhcp-options
| elastic-ip-allocation
| elastic-ip-association
/// | export-task
| flow-log
| image
| import-task
/// | internet-gateway
| network-acl
| network-acl-association
/// | network-interface
| network-interface-attachment
| prefix-list
/// | route-table
| route-table-association
| security-group
/// | subnet
| subnet-cidr-block-association
| vpc
/// | vpc-cidr-block-association
| vpc-endpoint
| vpc-peering-connection
/// | vpn-connection
| vpn-gateway
.
///
///
///
/// Alternatively, use the all-current
option to include all resource types
/// that are currently within their opt-in period for longer IDs.
///
///
[AWSProperty(Required=true)]
public string Resource
{
get { return this._resource; }
set { this._resource = value; }
}
// Check to see if Resource property is set
internal bool IsSetResource()
{
return this._resource != null;
}
///
/// Gets and sets the property UseLongIds.
///
/// Indicates whether the resource should use longer IDs (17-character IDs)
///
///
[AWSProperty(Required=true)]
public bool UseLongIds
{
get { return this._useLongIds.GetValueOrDefault(); }
set { this._useLongIds = value; }
}
// Check to see if UseLongIds property is set
internal bool IsSetUseLongIds()
{
return this._useLongIds.HasValue;
}
}
}