"documentation":"<p>Creates a streaming session in a studio.</p> <p>After invoking this operation, you must poll GetStreamingSession until the streaming session is in state READY.</p>"
"documentation":"<p>Creates a streaming session stream for a streaming session.</p> <p>After invoking this API, invoke GetStreamingSessionStream with the returned streamId to poll the resource until it is in state READY.</p>",
"idempotent":true
},
"CreateStudio":{
"name":"CreateStudio",
"http":{
"method":"POST",
"requestUri":"/2020-08-01/studios",
"responseCode":200
},
"input":{"shape":"CreateStudioRequest"},
"output":{"shape":"CreateStudioResponse"},
"errors":[
{"shape":"ResourceNotFoundException"},
{"shape":"ConflictException"},
{"shape":"ThrottlingException"},
{"shape":"ValidationException"},
{"shape":"AccessDeniedException"},
{"shape":"InternalServerErrorException"},
{"shape":"ServiceQuotaExceededException"}
],
"documentation":"<p>Create a new Studio.</p> <p>When creating a Studio, two IAM roles must be provided: the admin role and the user Role. These roles are assumed by your users when they log in to the Nimble Studio portal.</p> <p>The user role must have the AmazonNimbleStudio-StudioUser managed policy attached for the portal to function properly.</p> <p>The Admin Role must have the AmazonNimbleStudio-StudioAdmin managed policy attached for the portal to function properly.</p> <p>You may optionally specify a KMS key in the StudioEncryptionConfiguration.</p> <p>In Nimble Studio, resource names, descriptions, initialization scripts, and other data you provide are always encrypted at rest using an KMS key. By default, this key is owned by Amazon Web Services and managed on your behalf. You may provide your own KMS key when calling CreateStudio to encrypt this data using a key you own and manage.</p> <p>When providing an KMS key during studio creation, Nimble Studio creates KMS grants in your account to provide your studio user and admin roles access to these KMS keys.</p> <p>If you delete this grant, the studio will no longer be accessible to your portal users.</p> <p>If you delete the studio KMS key, your studio will no longer be accessible.</p>"
"documentation":"<p>Deletes streaming session resource.</p> <p>After invoking this operation, use GetStreamingSession to poll the resource until it transitions to a DELETED state.</p> <p>A streaming session will count against your streaming session quota until it is marked DELETED.</p>",
"idempotent":true
},
"DeleteStudio":{
"name":"DeleteStudio",
"http":{
"method":"DELETE",
"requestUri":"/2020-08-01/studios/{studioId}",
"responseCode":200
},
"input":{"shape":"DeleteStudioRequest"},
"output":{"shape":"DeleteStudioResponse"},
"errors":[
{"shape":"ResourceNotFoundException"},
{"shape":"ConflictException"},
{"shape":"ThrottlingException"},
{"shape":"ValidationException"},
{"shape":"AccessDeniedException"},
{"shape":"InternalServerErrorException"},
{"shape":"ServiceQuotaExceededException"}
],
"documentation":"<p>Delete a studio resource.</p>",
"documentation":"<p>Launch profile details include the launch profile resource and summary information of resources that are used by, or available to, the launch profile. This includes the name and description of all studio components used by the launch profiles, and the name and description of streaming images that can be used with this launch profile.</p>"
"documentation":"<p>Gets StreamingSession resource.</p> <p>Invoke this operation to poll for a streaming session state while creating or deleting a session.</p>"
"documentation":"<p>Gets a StreamingSessionStream for a streaming session.</p> <p>Invoke this operation to poll the resource after invoking CreateStreamingSessionStream.</p> <p>After the StreamingSessionStream changes to the state READY, the url property will contain a stream to be used with the DCV streaming client.</p>"
"documentation":"<p>List the streaming image resources available to this studio.</p> <p>This list will contain both images provided by Amazon Web Services, as well as streaming images that you have created in your studio.</p>"
"documentation":"<p>List studios in your Amazon Web Services account in the requested Amazon Web Services Region.</p>"
},
"ListTagsForResource":{
"name":"ListTagsForResource",
"http":{
"method":"GET",
"requestUri":"/2020-08-01/tags/{resourceArn}",
"responseCode":200
},
"input":{"shape":"ListTagsForResourceRequest"},
"output":{"shape":"ListTagsForResourceResponse"},
"errors":[
{"shape":"ResourceNotFoundException"},
{"shape":"ConflictException"},
{"shape":"ThrottlingException"},
{"shape":"ValidationException"},
{"shape":"AccessDeniedException"},
{"shape":"InternalServerErrorException"},
{"shape":"ServiceQuotaExceededException"}
],
"documentation":"<p>Gets the tags for a resource, given its Amazon Resource Names (ARN).</p> <p>This operation supports ARNs for all resource types in Nimble Studio that support tags, including studio, studio component, launch profile, streaming image, and streaming session. All resources that can be tagged will contain an ARN property, so you do not have to create this ARN yourself.</p>"
"documentation":"<p> Transitions sessions from the STOPPED state into the READY state. The START_IN_PROGRESS state is the intermediate state between the STOPPED and READY states.</p>",
"documentation":"<p>Repairs the IAM Identity Center configuration for a given studio.</p> <p>If the studio has a valid IAM Identity Center configuration currently associated with it, this operation will fail with a validation error.</p> <p>If the studio does not have a valid IAM Identity Center configuration currently associated with it, then a new IAM Identity Center application is created for the studio and the studio is changed to the READY state.</p> <p>After the IAM Identity Center application is repaired, you must use the Amazon Nimble Studio console to add administrators and users to your studio.</p>",
"documentation":"<p>Transitions sessions from the READY state into the STOPPED state. The STOP_IN_PROGRESS state is the intermediate state between the READY and STOPPED states.</p>",
"idempotent":true
},
"TagResource":{
"name":"TagResource",
"http":{
"method":"POST",
"requestUri":"/2020-08-01/tags/{resourceArn}",
"responseCode":204
},
"input":{"shape":"TagResourceRequest"},
"output":{"shape":"TagResourceResponse"},
"errors":[
{"shape":"ResourceNotFoundException"},
{"shape":"ConflictException"},
{"shape":"ThrottlingException"},
{"shape":"ValidationException"},
{"shape":"AccessDeniedException"},
{"shape":"InternalServerErrorException"},
{"shape":"ServiceQuotaExceededException"}
],
"documentation":"<p>Creates tags for a resource, given its ARN.</p>"
},
"UntagResource":{
"name":"UntagResource",
"http":{
"method":"DELETE",
"requestUri":"/2020-08-01/tags/{resourceArn}",
"responseCode":204
},
"input":{"shape":"UntagResourceRequest"},
"output":{"shape":"UntagResourceResponse"},
"errors":[
{"shape":"ResourceNotFoundException"},
{"shape":"ConflictException"},
{"shape":"ThrottlingException"},
{"shape":"ValidationException"},
{"shape":"AccessDeniedException"},
{"shape":"InternalServerErrorException"},
{"shape":"ServiceQuotaExceededException"}
],
"documentation":"<p>Deletes the tags for a resource.</p>",
"documentation":"<p>Unique, case-sensitive identifier that you provide to ensure the idempotency of the request. If you don’t specify a client token, the AWS SDK automatically generates a client token and uses it for the request to ensure idempotency.</p>",
"documentation":"<p>A more specific error code.</p>"
},
"context":{
"shape":"ExceptionContext",
"documentation":"<p>The exception context.</p>"
},
"message":{
"shape":"String",
"documentation":"<p>A human-readable description of the error.</p>"
}
},
"documentation":"<p>You are not authorized to perform this operation. Check your IAM policies, and ensure that you are using the correct access keys.</p>",
"error":{
"httpStatusCode":403,
"senderFault":true
},
"exception":true
},
"ActiveDirectoryComputerAttribute":{
"type":"structure",
"members":{
"name":{
"shape":"ActiveDirectoryComputerAttributeName",
"documentation":"<p>The name for the LDAP attribute.</p>"
},
"value":{
"shape":"ActiveDirectoryComputerAttributeValue",
"documentation":"<p>The value for the LDAP attribute.</p>"
}
},
"documentation":"<p>An LDAP attribute of an Active Directory computer account, in the form of a name:value pair.</p>"
"documentation":"<p>The endpoint of the ComputeFarm that is accessed by the studio component resource.</p>"
}
},
"documentation":"<p>The configuration for a render farm that is associated with a studio resource.</p>"
},
"ConflictException":{
"type":"structure",
"members":{
"code":{
"shape":"String",
"documentation":"<p>A more specific error code.</p>"
},
"context":{
"shape":"ExceptionContext",
"documentation":"<p>The exception context.</p>"
},
"message":{
"shape":"String",
"documentation":"<p>A human-readable description of the error.</p>"
}
},
"documentation":"<p>Another operation is in progress. </p>",
"error":{
"httpStatusCode":409,
"senderFault":true
},
"exception":true
},
"CreateLaunchProfileRequest":{
"type":"structure",
"required":[
"ec2SubnetIds",
"launchProfileProtocolVersions",
"name",
"streamConfiguration",
"studioComponentIds",
"studioId"
],
"members":{
"clientToken":{
"shape":"ClientToken",
"documentation":"<p>Unique, case-sensitive identifier that you provide to ensure the idempotency of the request. If you don’t specify a client token, the AWS SDK automatically generates a client token and uses it for the request to ensure idempotency.</p>",
"idempotencyToken":true,
"location":"header",
"locationName":"X-Amz-Client-Token"
},
"description":{
"shape":"LaunchProfileDescription",
"documentation":"<p>The description.</p>"
},
"ec2SubnetIds":{
"shape":"EC2SubnetIdList",
"documentation":"<p>Specifies the IDs of the EC2 subnets where streaming sessions will be accessible from. These subnets must support the specified instance types. </p>"
},
"launchProfileProtocolVersions":{
"shape":"LaunchProfileProtocolVersionList",
"documentation":"<p>The version number of the protocol that is used by the launch profile. The only valid version is \"2021-03-31\".</p>"
},
"name":{
"shape":"LaunchProfileName",
"documentation":"<p>The name for the launch profile.</p>"
},
"streamConfiguration":{
"shape":"StreamConfigurationCreate",
"documentation":"<p>A configuration for a streaming session.</p>"
},
"studioComponentIds":{
"shape":"LaunchProfileStudioComponentIdList",
"documentation":"<p>Unique identifiers for a collection of studio components that can be used with this launch profile.</p>"
},
"studioId":{
"shape":"String",
"documentation":"<p>The studio ID. </p>",
"location":"uri",
"locationName":"studioId"
},
"tags":{
"shape":"Tags",
"documentation":"<p>A collection of labels, in the form of key:value pairs, that apply to this resource.</p>"
"documentation":"<p>Unique, case-sensitive identifier that you provide to ensure the idempotency of the request. If you don’t specify a client token, the AWS SDK automatically generates a client token and uses it for the request to ensure idempotency.</p>",
"documentation":"<p>Unique, case-sensitive identifier that you provide to ensure the idempotency of the request. If you don’t specify a client token, the AWS SDK automatically generates a client token and uses it for the request to ensure idempotency.</p>",
"idempotencyToken":true,
"location":"header",
"locationName":"X-Amz-Client-Token"
},
"ec2InstanceType":{
"shape":"StreamingInstanceType",
"documentation":"<p>The EC2 Instance type used for the streaming session.</p>"
"documentation":"<p>The user ID of the user that owns the streaming session. The user that owns the session will be logging into the session and interacting with the virtual workstation.</p>"
"documentation":"<p>Unique, case-sensitive identifier that you provide to ensure the idempotency of the request. If you don’t specify a client token, the AWS SDK automatically generates a client token and uses it for the request to ensure idempotency.</p>",
"documentation":"<p>Unique, case-sensitive identifier that you provide to ensure the idempotency of the request. If you don’t specify a client token, the AWS SDK automatically generates a client token and uses it for the request to ensure idempotency.</p>",
"idempotencyToken":true,
"location":"header",
"locationName":"X-Amz-Client-Token"
},
"configuration":{
"shape":"StudioComponentConfiguration",
"documentation":"<p>The configuration of the studio component, based on component type.</p>"
},
"description":{
"shape":"StudioComponentDescription",
"documentation":"<p>The description.</p>"
},
"ec2SecurityGroupIds":{
"shape":"StudioComponentSecurityGroupIdList",
"documentation":"<p>The EC2 security groups that control access to the studio component.</p>"
"documentation":"<p>An IAM role attached to a Studio Component that gives the studio component access to AWS resources at anytime while the instance is running. </p>"
"documentation":"<p>An IAM role attached to Studio Component when the system initialization script runs which give the studio component access to AWS resources when the system initialization script runs.</p>"
"documentation":"<p>The IAM role that Studio Admins will assume when logging in to the Nimble Studio portal.</p>"
},
"clientToken":{
"shape":"ClientToken",
"documentation":"<p>Unique, case-sensitive identifier that you provide to ensure the idempotency of the request. If you don’t specify a client token, the AWS SDK automatically generates a client token and uses it for the request to ensure idempotency.</p>",
"documentation":"<p>Unique, case-sensitive identifier that you provide to ensure the idempotency of the request. If you don’t specify a client token, the AWS SDK automatically generates a client token and uses it for the request to ensure idempotency.</p>",
"documentation":"<p>Unique, case-sensitive identifier that you provide to ensure the idempotency of the request. If you don’t specify a client token, the AWS SDK automatically generates a client token and uses it for the request to ensure idempotency.</p>",
"documentation":"<p>Unique, case-sensitive identifier that you provide to ensure the idempotency of the request. If you don’t specify a client token, the AWS SDK automatically generates a client token and uses it for the request to ensure idempotency.</p>",
"documentation":"<p>Unique, case-sensitive identifier that you provide to ensure the idempotency of the request. If you don’t specify a client token, the AWS SDK automatically generates a client token and uses it for the request to ensure idempotency.</p>",
"documentation":"<p>Unique, case-sensitive identifier that you provide to ensure the idempotency of the request. If you don’t specify a client token, the AWS SDK automatically generates a client token and uses it for the request to ensure idempotency.</p>",
"idempotencyToken":true,
"location":"header",
"locationName":"X-Amz-Client-Token"
},
"studioComponentId":{
"shape":"String",
"documentation":"<p>The studio component ID.</p>",
"documentation":"<p>Unique, case-sensitive identifier that you provide to ensure the idempotency of the request. If you don’t specify a client token, the AWS SDK automatically generates a client token and uses it for the request to ensure idempotency.</p>",
"documentation":"<p>Unique, case-sensitive identifier that you provide to ensure the idempotency of the request. If you don’t specify a client token, the AWS SDK automatically generates a client token and uses it for the request to ensure idempotency.</p>",
"documentation":"<p>ExceptionContext is a set of key-value pairs that provide you with more information about the error that occurred. For example, when the service returns a 404 ResourceNotFound error, ExceptionContext will contain the key `resourceId` with the value of resource that was not found.</p> <p>ExceptionContext enables scripts and other programmatic clients to provide for better error handling.</p>"
"documentation":"<p>A launch profile controls your artist workforce’s access to studio components, like compute farms, shared file systems, managed file systems, and license server configurations, as well as instance types and Amazon Machine Images (AMIs). </p> <pre><code> <p>Studio administrators create launch profiles in the Nimble Studio console. Artists can use their launch profiles to launch an instance from the Nimble Studio portal. Each user’s launch profile defines how they can launch a streaming session. By default, studio admins can use all launch profiles.</p> </code></pre>"
},
"LaunchProfileDescription":{
"type":"string",
"documentation":"<p>A human-readable description of the launch profile.</p>",
"documentation":"<p>A Launch Profile Initialization contains information required for a workstation or server to connect to a launch profile.</p> <p>This includes scripts, endpoints, security groups, subnets, and other configuration.</p>"
"documentation":"<p>The Launch Profile Initialization Active Directory contains information required for the launch profile to connect to the Active Directory.</p>"
"documentation":"<p>An IAM role attached to a Studio Component that gives the studio component access to AWS resources at anytime while the instance is running. </p>"
"documentation":"<p>An IAM role attached to Studio Component when the system initialization script runs which give the studio component access to AWS resources when the system initialization script runs.</p>"
"documentation":"<p>Launch profile membership enables your studio admins to delegate launch profile access to other studio users in the Nimble Studio portal without needing to write or maintain complex IAM policies. A launch profile member is a user association from your studio identity source who is granted permissions to a launch profile.</p> <p>A launch profile member (type USER) provides the following permissions to that launch profile:</p> <ul> <li> <p>GetLaunchProfile</p> </li> <li> <p>GetLaunchProfileInitialization</p> </li> <li> <p>GetLaunchProfileMembers</p> </li> <li> <p>GetLaunchProfileMember</p> </li> <li> <p>CreateStreamingSession</p> </li> <li> <p>GetLaunchProfileDetails</p> </li> </ul>"
"documentation":"<p>Unique, case-sensitive identifier that you provide to ensure the idempotency of the request. If you don’t specify a client token, the AWS SDK automatically generates a client token and uses it for the request to ensure idempotency.</p>",
"idempotencyToken":true,
"location":"header",
"locationName":"X-Amz-Client-Token"
},
"identityStoreId":{
"shape":"String",
"documentation":"<p>The ID of the identity store.</p>"
"documentation":"<p>Unique, case-sensitive identifier that you provide to ensure the idempotency of the request. If you don’t specify a client token, the AWS SDK automatically generates a client token and uses it for the request to ensure idempotency.</p>",
"idempotencyToken":true,
"location":"header",
"locationName":"X-Amz-Client-Token"
},
"identityStoreId":{
"shape":"String",
"documentation":"<p>The ID of the identity store.</p>"
"documentation":"<p>A more specific error code.</p>"
},
"context":{
"shape":"ExceptionContext",
"documentation":"<p>The exception context.</p>"
},
"message":{
"shape":"String",
"documentation":"<p>A human-readable description of the error.</p>"
}
},
"documentation":"<p>Your current quota does not allow you to perform the request action. You can request increases for some quotas, and other quotas cannot be increased.</p> <p>Please use AWS Service Quotas to request an increase. </p>",
"documentation":"<p>The name of the file share.</p>"
},
"windowsMountDrive":{
"shape":"WindowsMountDrive",
"documentation":"<p>The mount location for a shared file system on a Windows virtual workstation.</p>"
}
},
"documentation":"<p>The configuration for a shared file storage system that is associated with a studio resource.</p>"
},
"StartStreamingSessionRequest":{
"type":"structure",
"required":[
"sessionId",
"studioId"
],
"members":{
"clientToken":{
"shape":"ClientToken",
"documentation":"<p>Unique, case-sensitive identifier that you provide to ensure the idempotency of the request. If you don’t specify a client token, the AWS SDK automatically generates a client token and uses it for the request to ensure idempotency.</p>",
"idempotencyToken":true,
"location":"header",
"locationName":"X-Amz-Client-Token"
},
"sessionId":{
"shape":"String",
"documentation":"<p>The streaming session ID for the StartStreamingSessionRequest.</p>",
"location":"uri",
"locationName":"sessionId"
},
"studioId":{
"shape":"String",
"documentation":"<p>The studio ID for the StartStreamingSessionRequest.</p>",
"documentation":"<p>Unique, case-sensitive identifier that you provide to ensure the idempotency of the request. If you don’t specify a client token, the AWS SDK automatically generates a client token and uses it for the request to ensure idempotency.</p>",
"documentation":"<p>Unique, case-sensitive identifier that you provide to ensure the idempotency of the request. If you don’t specify a client token, the AWS SDK automatically generates a client token and uses it for the request to ensure idempotency.</p>",
"idempotencyToken":true,
"location":"header",
"locationName":"X-Amz-Client-Token"
},
"sessionId":{
"shape":"String",
"documentation":"<p>The streaming session ID for the StopStreamingSessionRequest.</p>",
"location":"uri",
"locationName":"sessionId"
},
"studioId":{
"shape":"String",
"documentation":"<p>The studioId for the StopStreamingSessionRequest.</p>",
"documentation":"<p>The length of time, in minutes, that a streaming session can be active before it is stopped or terminated. After this point, Nimble Studio automatically terminates or stops the session. The default length of time is 690 minutes, and the maximum length of time is 30 days.</p>"
"documentation":"<p>Integer that determines if you can start and stop your sessions and how long a session can stay in the STOPPED state. The default value is 0. The maximum value is 5760.</p> <p>If the value is missing or set to 0, your sessions can’t be stopped. If you then call <code>StopStreamingSession</code>, the session fails. If the time that a session stays in the READY state exceeds the <code>maxSessionLengthInMinutes</code> value, the session will automatically be terminated (instead of stopped).</p> <p>If the value is set to a positive number, the session can be stopped. You can call <code>StopStreamingSession</code> to stop sessions in the READY state. If the time that a session stays in the READY state exceeds the <code>maxSessionLengthInMinutes</code> value, the session will automatically be stopped (instead of terminated).</p>"
"documentation":"<p>The length of time, in minutes, that a streaming session can be active before it is stopped or terminated. After this point, Nimble Studio automatically terminates or stops the session. The default length of time is 690 minutes, and the maximum length of time is 30 days.</p>"
"documentation":"<p>Integer that determines if you can start and stop your sessions and how long a session can stay in the STOPPED state. The default value is 0. The maximum value is 5760.</p> <p>If the value is missing or set to 0, your sessions can’t be stopped. If you then call <code>StopStreamingSession</code>, the session fails. If the time that a session stays in the READY state exceeds the <code>maxSessionLengthInMinutes</code> value, the session will automatically be terminated (instead of stopped).</p> <p>If the value is set to a positive number, the session can be stopped. You can call <code>StopStreamingSession</code> to stop sessions in the READY state. If the time that a session stays in the READY state exceeds the <code>maxSessionLengthInMinutes</code> value, the session will automatically be stopped (instead of terminated).</p>"
"documentation":"<p>A friendly name for a streaming image resource.</p>"
},
"owner":{
"shape":"StreamingImageOwner",
"documentation":"<p>The owner of the streaming image, either the studioId that contains the streaming image, or 'amazon' for images that are provided by Amazon Nimble Studio.</p>"
},
"platform":{
"shape":"StreamingImagePlatform",
"documentation":"<p>The platform of the streaming image, either WINDOWS or LINUX.</p>"
},
"state":{
"shape":"StreamingImageState",
"documentation":"<p>The current state.</p>"
},
"statusCode":{
"shape":"StreamingImageStatusCode",
"documentation":"<p>The status code.</p>"
},
"statusMessage":{
"shape":"String",
"documentation":"<p>The status message for the streaming image.</p>"
},
"streamingImageId":{
"shape":"StreamingImageId",
"documentation":"<p>The ID of the streaming image.</p>"
},
"tags":{
"shape":"Tags",
"documentation":"<p>A collection of labels, in the form of key:value pairs, that apply to this resource.</p>"
}
},
"documentation":"<p>Represents a streaming image resource.</p> <p>Streaming images are used by studio users to select which operating system and software they want to use in a Nimble Studio streaming session.</p> <p>Amazon provides a number of streaming images that include popular 3rd-party software.</p> <p>You can create your own streaming images using an Amazon Elastic Compute Cloud (Amazon EC2) machine image that you create for this purpose. You can also include software that your users require.</p>"
"documentation":"<p>StreamingImageOwner is the owner of a particular streaming image.</p> <p>This string is either the studioId that contains the streaming image, or the word 'AMAZON' for images provided by Nimble Studio.</p>"
},
"StreamingImagePlatform":{
"type":"string",
"documentation":"<p>The platform of this Streaming Image, either WINDOWS or LINUX.</p>",
"documentation":"<p>The user ID of the user that owns the streaming session. The user that owns the session will be logging into the session and interacting with the virtual workstation.</p>"
"documentation":"<p>The user ID of the user that owns the streaming session. The user that owns the session will be logging into the session and interacting with the virtual workstation.</p>"
"documentation":"<p>The URL to connect to this stream using the DCV client.</p>"
}
},
"documentation":"<p>A stream is an active connection to a streaming session, enabling a studio user to control the streaming session using a compatible client. Streaming session streams are compatible with the NICE DCV web client, included in the Nimble Studio portal, or the NICE DCV desktop client.</p>"
"documentation":"<p>The IAM role that studio admins assume when logging in to the Nimble Studio portal.</p>"
},
"arn":{
"shape":"String",
"documentation":"<p>The Amazon Resource Name (ARN) that is assigned to a studio resource and uniquely identifies it. ARNs are unique across all Regions.</p>"
},
"createdAt":{
"shape":"Timestamp",
"documentation":"<p>The Unix epoch timestamp in seconds for when the resource was created.</p>"
"documentation":"<p>The IAM Identity Center application client ID used to integrate with IAM Identity Center to enable IAM Identity Center users to log in to Nimble Studio portal.</p>"
"documentation":"<p>Represents a studio resource.</p> <p>A studio is the core resource used with Nimble Studio. You must create a studio first, before any other resource type can be created. All other resources you create and manage in Nimble Studio are contained within a studio.</p> <p>When creating a studio, you must provides two IAM roles for use with the Nimble Studio portal. These roles are assumed by your users when they log in to the Nimble Studio portal via IAM Identity Center and your identity source.</p> <p>The user role must have the AmazonNimbleStudio-StudioUser managed policy attached for the portal to function properly.</p> <p>The admin role must have the AmazonNimbleStudio-StudioAdmin managed policy attached for the portal to function properly.</p> <p>Your studio roles must trust the identity.nimble.amazonaws.com service principal to function properly.</p>"
"documentation":"<p>An IAM role attached to a Studio Component that gives the studio component access to AWS resources at anytime while the instance is running. </p>"
"documentation":"<p>An IAM role attached to Studio Component when the system initialization script runs which give the studio component access to AWS resources when the system initialization script runs.</p>"
"documentation":"<p>The status message for the studio component.</p>"
},
"studioComponentId":{
"shape":"StudioComponentId",
"documentation":"<p>The unique identifier for a studio component resource.</p>"
},
"subtype":{
"shape":"StudioComponentSubtype",
"documentation":"<p>The specific subtype of a studio component.</p>"
},
"tags":{
"shape":"Tags",
"documentation":"<p>A collection of labels, in the form of key:value pairs, that apply to this resource.</p>"
},
"type":{
"shape":"StudioComponentType",
"documentation":"<p>The type of the studio component.</p>"
},
"updatedAt":{
"shape":"Timestamp",
"documentation":"<p>The Unix epoch timestamp in seconds for when the resource was updated.</p>"
},
"updatedBy":{
"shape":"String",
"documentation":"<p>The user ID of the user that most recently updated the resource.</p>"
}
},
"documentation":"<p>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.</p> <p>Access to a studio component is managed by specifying security groups for the resource, as well as its endpoint.</p> <p>A studio component also has a set of initialization scripts that are returned by <code>GetLaunchProfileInitialization</code>. 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.</p>"
},
"StudioComponentConfiguration":{
"type":"structure",
"members":{
"activeDirectoryConfiguration":{
"shape":"ActiveDirectoryConfiguration",
"documentation":"<p>The configuration for a Microsoft Active Directory (Microsoft AD) studio resource.</p>"
},
"computeFarmConfiguration":{
"shape":"ComputeFarmConfiguration",
"documentation":"<p>The configuration for a render farm that is associated with a studio resource.</p>"
},
"licenseServiceConfiguration":{
"shape":"LicenseServiceConfiguration",
"documentation":"<p>The configuration for a license service that is associated with a studio resource.</p>"
},
"sharedFileSystemConfiguration":{
"shape":"SharedFileSystemConfiguration",
"documentation":"<p>The configuration for a shared file storage system that is associated with a studio resource.</p>"
}
},
"documentation":"<p>The configuration of the studio component, based on component type.</p>",
"union":true
},
"StudioComponentDescription":{
"type":"string",
"max":256,
"min":0,
"sensitive":true
},
"StudioComponentId":{
"type":"string",
"max":22,
"min":0,
"pattern":"^[a-zA-Z0-9-_]*$"
},
"StudioComponentInitializationScript":{
"type":"structure",
"members":{
"launchProfileProtocolVersion":{
"shape":"LaunchProfileProtocolVersion",
"documentation":"<p>The version number of the protocol that is used by the launch profile. The only valid version is \"2021-03-31\".</p>"
},
"platform":{
"shape":"LaunchProfilePlatform",
"documentation":"<p>The platform of the initialization script, either WINDOWS or LINUX.</p>"
"documentation":"<p>The current state of the studio component resource.</p> <p>While a studio component is being created, modified, or deleted, its state will equal \"CREATE_IN_PROGRESS\", \"UPDATE_IN_PROGRESS\", or \"DELETE_IN_PROGRESS\"</p> <p>These are called 'transition states'.</p> <p>No modifications may be made to the studio component while it is in a transition state.</p> <p>If creation of the resource fails, the state will change to `CREATE_FAILED`. The resource StatusCode and StatusMessage will provide more information of why creation failed. The resource in this state will automatically be deleted from your account after a period of time.</p> <p>If updating the resource fails, the state will change to `UPDATE_FAILED`. The resource StatusCode and StatusMessage will provide more information of why the update failed. The resource will be returned to the state it was in when the update request was invoked.</p> <p>If deleting the resource fails, the state will change to `DELETE_FAILED`. The resource StatusCode and StatusMessage will provide more information of why the update failed. The resource will be returned to the state it was in when the update request was invoked. After the resource is deleted successfully, it will change to the \"DELETED\" state. The resource will no longer count against service quotas and cannot be used or acted upon any futher. It will be removed from your account after a period of time.</p>",
"documentation":"<p>The current status of the studio component resource.</p> <p>When the resource is in the 'READY' state, the status code signals what the last mutation made to the resource was.</p> <p>When the resource is in a CREATE_FAILED/UPDATE_FAILED/DELETE_FAILED state, the status code signals what went wrong and why the mutation failed.</p>",
"enum":[
"ACTIVE_DIRECTORY_ALREADY_EXISTS",
"STUDIO_COMPONENT_CREATED",
"STUDIO_COMPONENT_UPDATED",
"STUDIO_COMPONENT_DELETED",
"ENCRYPTION_KEY_ACCESS_DENIED",
"ENCRYPTION_KEY_NOT_FOUND",
"STUDIO_COMPONENT_CREATE_IN_PROGRESS",
"STUDIO_COMPONENT_UPDATE_IN_PROGRESS",
"STUDIO_COMPONENT_DELETE_IN_PROGRESS",
"INTERNAL_ERROR"
]
},
"StudioComponentSubtype":{
"type":"string",
"enum":[
"AWS_MANAGED_MICROSOFT_AD",
"AMAZON_FSX_FOR_WINDOWS",
"AMAZON_FSX_FOR_LUSTRE",
"CUSTOM"
]
},
"StudioComponentSummary":{
"type":"structure",
"members":{
"createdAt":{
"shape":"Timestamp",
"documentation":"<p>The Unix epoch timestamp in seconds for when the resource was created.</p>"
},
"createdBy":{
"shape":"String",
"documentation":"<p>The user ID of the user that created the studio component.</p>"
},
"description":{
"shape":"StudioComponentDescription",
"documentation":"<p>The description.</p>"
},
"name":{
"shape":"StudioComponentName",
"documentation":"<p>The name for the studio component.</p>"
},
"studioComponentId":{
"shape":"StudioComponentId",
"documentation":"<p>The unique identifier for a studio component resource.</p>"
},
"subtype":{
"shape":"StudioComponentSubtype",
"documentation":"<p>The specific subtype of a studio component.</p>"
},
"type":{
"shape":"StudioComponentType",
"documentation":"<p>The type of the studio component.</p>"
},
"updatedAt":{
"shape":"Timestamp",
"documentation":"<p>The Unix epoch timestamp in seconds for when the resource was updated.</p>"
},
"updatedBy":{
"shape":"String",
"documentation":"<p>The user ID of the user that most recently updated the resource.</p>"
"documentation":"<p>A studio member is an association of a user from your studio identity source to elevated permissions that they are granted in the studio.</p> <p>When you add a user to your studio using the Nimble Studio console, they are given access to the studio's IAM Identity Center application and are given access to log in to the Nimble Studio portal. These users have the permissions provided by the studio's user IAM role and do not appear in the studio membership collection. Only studio admins appear in studio membership.</p> <p>When you add a user to studio membership with the persona ADMIN, upon logging in to the Nimble Studio portal, they are granted permissions specified by the Studio's Admin IAM role.</p>"
"documentation":"<p>Unique, case-sensitive identifier that you provide to ensure the idempotency of the request. If you don’t specify a client token, the AWS SDK automatically generates a client token and uses it for the request to ensure idempotency.</p>",
"documentation":"<p>Unique, case-sensitive identifier that you provide to ensure the idempotency of the request. If you don’t specify a client token, the AWS SDK automatically generates a client token and uses it for the request to ensure idempotency.</p>",
"idempotencyToken":true,
"location":"header",
"locationName":"X-Amz-Client-Token"
},
"description":{
"shape":"LaunchProfileDescription",
"documentation":"<p>The description.</p>"
},
"launchProfileId":{
"shape":"String",
"documentation":"<p>The Launch Profile ID.</p>",
"location":"uri",
"locationName":"launchProfileId"
},
"launchProfileProtocolVersions":{
"shape":"LaunchProfileProtocolVersionList",
"documentation":"<p>The version number of the protocol that is used by the launch profile. The only valid version is \"2021-03-31\".</p>"
},
"name":{
"shape":"LaunchProfileName",
"documentation":"<p>The name for the launch profile.</p>"
},
"streamConfiguration":{
"shape":"StreamConfigurationCreate",
"documentation":"<p>A configuration for a streaming session.</p>"
},
"studioComponentIds":{
"shape":"LaunchProfileStudioComponentIdList",
"documentation":"<p>Unique identifiers for a collection of studio components that can be used with this launch profile.</p>"
"documentation":"<p>Unique, case-sensitive identifier that you provide to ensure the idempotency of the request. If you don’t specify a client token, the AWS SDK automatically generates a client token and uses it for the request to ensure idempotency.</p>",
"documentation":"<p>Unique, case-sensitive identifier that you provide to ensure the idempotency of the request. If you don’t specify a client token, the AWS SDK automatically generates a client token and uses it for the request to ensure idempotency.</p>",
"idempotencyToken":true,
"location":"header",
"locationName":"X-Amz-Client-Token"
},
"configuration":{
"shape":"StudioComponentConfiguration",
"documentation":"<p>The configuration of the studio component, based on component type.</p>"
},
"description":{
"shape":"StudioComponentDescription",
"documentation":"<p>The description.</p>"
},
"ec2SecurityGroupIds":{
"shape":"StudioComponentSecurityGroupIdList",
"documentation":"<p>The EC2 security groups that control access to the studio component.</p>"
"documentation":"<p>An IAM role attached to a Studio Component that gives the studio component access to AWS resources at anytime while the instance is running. </p>"
"documentation":"<p>An IAM role attached to Studio Component when the system initialization script runs which give the studio component access to AWS resources when the system initialization script runs.</p>"
"documentation":"<p>The IAM role that Studio Admins will assume when logging in to the Nimble Studio portal.</p>"
},
"clientToken":{
"shape":"ClientToken",
"documentation":"<p>Unique, case-sensitive identifier that you provide to ensure the idempotency of the request. If you don’t specify a client token, the AWS SDK automatically generates a client token and uses it for the request to ensure idempotency.</p>",
"documentation":"<p>Welcome to the Amazon Nimble Studio API reference. This API reference provides methods, schema, resources, parameters, and more to help you get the most out of Nimble Studio.</p> <p>Nimble Studio is a virtual studio that empowers visual effects, animation, and interactive content teams to create content securely within a scalable, private cloud service.</p>"