/*
* 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 nimble-2020-08-01.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.NimbleStudio.Model
{
///
/// A studio component represents a network resource to be used by a studio's users and
/// workflows. A typical studio contains studio components for each of the following:
/// render farm, Active Directory, licensing, and file system.
///
///
///
/// Access to a studio component is managed by specifying security groups for the resource,
/// as well as its endpoint.
///
///
///
/// A studio component also has a set of initialization scripts that are returned by GetLaunchProfileInitialization
.
/// These initialization scripts run on streaming sessions when they start. They provide
/// users with flexibility in controlling how the studio resources are configured on a
/// streaming session.
///
///
public partial class StudioComponent
{
private string _arn;
private StudioComponentConfiguration _configuration;
private DateTime? _createdAt;
private string _createdBy;
private string _description;
private List _ec2SecurityGroupIds = new List();
private List _initializationScripts = new List();
private string _name;
private string _runtimeRoleArn;
private List _scriptParameters = new List();
private string _secureInitializationRoleArn;
private StudioComponentState _state;
private StudioComponentStatusCode _statusCode;
private string _statusMessage;
private string _studioComponentId;
private StudioComponentSubtype _subtype;
private Dictionary _tags = new Dictionary();
private StudioComponentType _type;
private DateTime? _updatedAt;
private string _updatedBy;
///
/// Gets and sets the property Arn.
///
/// The Amazon Resource Name (ARN) that is assigned to a studio resource and uniquely
/// identifies it. ARNs are unique across all Regions.
///
///
public string Arn
{
get { return this._arn; }
set { this._arn = value; }
}
// Check to see if Arn property is set
internal bool IsSetArn()
{
return this._arn != null;
}
///
/// Gets and sets the property Configuration.
///
/// The configuration of the studio component, based on component type.
///
///
public StudioComponentConfiguration Configuration
{
get { return this._configuration; }
set { this._configuration = value; }
}
// Check to see if Configuration property is set
internal bool IsSetConfiguration()
{
return this._configuration != null;
}
///
/// Gets and sets the property CreatedAt.
///
/// The ISO timestamp in seconds for when the resource was created.
///
///
public DateTime CreatedAt
{
get { return this._createdAt.GetValueOrDefault(); }
set { this._createdAt = value; }
}
// Check to see if CreatedAt property is set
internal bool IsSetCreatedAt()
{
return this._createdAt.HasValue;
}
///
/// Gets and sets the property CreatedBy.
///
/// The user ID of the user that created the studio component.
///
///
public string CreatedBy
{
get { return this._createdBy; }
set { this._createdBy = value; }
}
// Check to see if CreatedBy property is set
internal bool IsSetCreatedBy()
{
return this._createdBy != null;
}
///
/// Gets and sets the property Description.
///
/// A human-readable description for the studio component resource.
///
///
[AWSProperty(Sensitive=true, Min=0, Max=256)]
public string Description
{
get { return this._description; }
set { this._description = value; }
}
// Check to see if Description property is set
internal bool IsSetDescription()
{
return this._description != null;
}
///
/// Gets and sets the property Ec2SecurityGroupIds.
///
/// The EC2 security groups that control access to the studio component.
///
///
[AWSProperty(Min=0, Max=30)]
public List Ec2SecurityGroupIds
{
get { return this._ec2SecurityGroupIds; }
set { this._ec2SecurityGroupIds = value; }
}
// Check to see if Ec2SecurityGroupIds property is set
internal bool IsSetEc2SecurityGroupIds()
{
return this._ec2SecurityGroupIds != null && this._ec2SecurityGroupIds.Count > 0;
}
///
/// Gets and sets the property InitializationScripts.
///
/// Initialization scripts for studio components.
///
///
public List InitializationScripts
{
get { return this._initializationScripts; }
set { this._initializationScripts = value; }
}
// Check to see if InitializationScripts property is set
internal bool IsSetInitializationScripts()
{
return this._initializationScripts != null && this._initializationScripts.Count > 0;
}
///
/// Gets and sets the property Name.
///
/// A friendly name for the studio component resource.
///
///
[AWSProperty(Sensitive=true, Min=0, Max=64)]
public string Name
{
get { return this._name; }
set { this._name = value; }
}
// Check to see if Name property is set
internal bool IsSetName()
{
return this._name != null;
}
///
/// Gets and sets the property RuntimeRoleArn.
///
/// An IAM role attached to a Studio Component that gives the studio component access
/// to Amazon Web Services resources at anytime while the instance is running.
///
///
[AWSProperty(Min=0, Max=2048)]
public string RuntimeRoleArn
{
get { return this._runtimeRoleArn; }
set { this._runtimeRoleArn = value; }
}
// Check to see if RuntimeRoleArn property is set
internal bool IsSetRuntimeRoleArn()
{
return this._runtimeRoleArn != null;
}
///
/// Gets and sets the property ScriptParameters.
///
/// Parameters for the studio component scripts.
///
///
[AWSProperty(Sensitive=true, Min=0, Max=30)]
public List ScriptParameters
{
get { return this._scriptParameters; }
set { this._scriptParameters = value; }
}
// Check to see if ScriptParameters property is set
internal bool IsSetScriptParameters()
{
return this._scriptParameters != null && this._scriptParameters.Count > 0;
}
///
/// Gets and sets the property SecureInitializationRoleArn.
///
/// An IAM role attached to Studio Component when the system initialization script runs
/// which give the studio component access to Amazon Web Services resources when the system
/// initialization script runs.
///
///
[AWSProperty(Min=0, Max=2048)]
public string SecureInitializationRoleArn
{
get { return this._secureInitializationRoleArn; }
set { this._secureInitializationRoleArn = value; }
}
// Check to see if SecureInitializationRoleArn property is set
internal bool IsSetSecureInitializationRoleArn()
{
return this._secureInitializationRoleArn != null;
}
///
/// Gets and sets the property State.
///
/// The current state.
///
///
public StudioComponentState State
{
get { return this._state; }
set { this._state = value; }
}
// Check to see if State property is set
internal bool IsSetState()
{
return this._state != null;
}
///
/// Gets and sets the property StatusCode.
///
/// The status code.
///
///
public StudioComponentStatusCode StatusCode
{
get { return this._statusCode; }
set { this._statusCode = value; }
}
// Check to see if StatusCode property is set
internal bool IsSetStatusCode()
{
return this._statusCode != null;
}
///
/// Gets and sets the property StatusMessage.
///
/// The status message for the studio component.
///
///
public string StatusMessage
{
get { return this._statusMessage; }
set { this._statusMessage = value; }
}
// Check to see if StatusMessage property is set
internal bool IsSetStatusMessage()
{
return this._statusMessage != null;
}
///
/// Gets and sets the property StudioComponentId.
///
/// The unique identifier for a studio component resource.
///
///
[AWSProperty(Min=0, Max=22)]
public string StudioComponentId
{
get { return this._studioComponentId; }
set { this._studioComponentId = value; }
}
// Check to see if StudioComponentId property is set
internal bool IsSetStudioComponentId()
{
return this._studioComponentId != null;
}
///
/// Gets and sets the property Subtype.
///
/// The specific subtype of a studio component.
///
///
public StudioComponentSubtype Subtype
{
get { return this._subtype; }
set { this._subtype = value; }
}
// Check to see if Subtype property is set
internal bool IsSetSubtype()
{
return this._subtype != null;
}
///
/// Gets and sets the property Tags.
///
/// A collection of labels, in the form of key-value pairs, that apply to this resource.
///
///
public Dictionary 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;
}
///
/// Gets and sets the property Type.
///
/// The type of the studio component.
///
///
public StudioComponentType Type
{
get { return this._type; }
set { this._type = value; }
}
// Check to see if Type property is set
internal bool IsSetType()
{
return this._type != null;
}
///
/// Gets and sets the property UpdatedAt.
///
/// The ISO timestamp in seconds for when the resource was updated.
///
///
public DateTime UpdatedAt
{
get { return this._updatedAt.GetValueOrDefault(); }
set { this._updatedAt = value; }
}
// Check to see if UpdatedAt property is set
internal bool IsSetUpdatedAt()
{
return this._updatedAt.HasValue;
}
///
/// Gets and sets the property UpdatedBy.
///
/// The user ID of the user that most recently updated the resource.
///
///
public string UpdatedBy
{
get { return this._updatedBy; }
set { this._updatedBy = value; }
}
// Check to see if UpdatedBy property is set
internal bool IsSetUpdatedBy()
{
return this._updatedBy != null;
}
}
}