/*
* 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 workspaces-web-2020-07-08.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.WorkSpacesWeb.Model
{
///
/// Container for the parameters to the CreatePortal operation.
/// Creates a web portal.
///
public partial class CreatePortalRequest : AmazonWorkSpacesWebRequest
{
private Dictionary _additionalEncryptionContext = new Dictionary();
private AuthenticationType _authenticationType;
private string _clientToken;
private string _customerManagedKey;
private string _displayName;
private List _tags = new List();
///
/// Gets and sets the property AdditionalEncryptionContext.
///
/// The additional encryption context of the portal.
///
///
public Dictionary AdditionalEncryptionContext
{
get { return this._additionalEncryptionContext; }
set { this._additionalEncryptionContext = value; }
}
// Check to see if AdditionalEncryptionContext property is set
internal bool IsSetAdditionalEncryptionContext()
{
return this._additionalEncryptionContext != null && this._additionalEncryptionContext.Count > 0;
}
///
/// Gets and sets the property AuthenticationType.
///
/// The type of authentication integration points used when signing into the web portal.
/// Defaults to Standard
.
///
///
///
/// Standard
web portals are authenticated directly through your identity
/// provider. You need to call CreateIdentityProvider
to integrate your identity
/// provider with your web portal. User and group access to your web portal is controlled
/// through your identity provider.
///
///
///
/// IAM_Identity_Center
web portals are authenticated through AWS IAM Identity
/// Center (successor to AWS Single Sign-On). They provide additional features, such as
/// IdP-initiated authentication. Identity sources (including external identity provider
/// integration), plus user and group access to your web portal, can be configured in
/// the IAM Identity Center.
///
///
public AuthenticationType AuthenticationType
{
get { return this._authenticationType; }
set { this._authenticationType = value; }
}
// Check to see if AuthenticationType property is set
internal bool IsSetAuthenticationType()
{
return this._authenticationType != null;
}
///
/// Gets and sets the property ClientToken.
///
/// A unique, case-sensitive identifier that you provide to ensure the idempotency of
/// the request. Idempotency ensures that an API request completes only once. With an
/// idempotent request, if the original request completes successfully, subsequent retries
/// with the same client token returns the result from the original successful request.
///
///
///
///
/// If you do not specify a client token, one is automatically generated by the AWS SDK.
///
///
[AWSProperty(Min=1, Max=512)]
public string ClientToken
{
get { return this._clientToken; }
set { this._clientToken = value; }
}
// Check to see if ClientToken property is set
internal bool IsSetClientToken()
{
return this._clientToken != null;
}
///
/// Gets and sets the property CustomerManagedKey.
///
/// The customer managed key of the web portal.
///
///
[AWSProperty(Min=20, Max=2048)]
public string CustomerManagedKey
{
get { return this._customerManagedKey; }
set { this._customerManagedKey = value; }
}
// Check to see if CustomerManagedKey property is set
internal bool IsSetCustomerManagedKey()
{
return this._customerManagedKey != null;
}
///
/// Gets and sets the property DisplayName.
///
/// The name of the web portal. This is not visible to users who log into the web portal.
///
///
[AWSProperty(Sensitive=true, Min=1, Max=64)]
public string DisplayName
{
get { return this._displayName; }
set { this._displayName = value; }
}
// Check to see if DisplayName property is set
internal bool IsSetDisplayName()
{
return this._displayName != null;
}
///
/// Gets and sets the property Tags.
///
/// The tags to add to the web portal. A tag is a key-value pair.
///
///
[AWSProperty(Min=0, Max=200)]
public List Tags
{
get { return this._tags; }
set { this._tags = value; }
}
// Check to see if Tags property is set
internal bool IsSetTags()
{
return this._tags != null && this._tags.Count > 0;
}
}
}