The Perl Toolchain Summit needs more sponsors. If your company depends on Perl, please support this very important event.

NAME

Paws::WorkSpaces - Perl Interface to AWS Amazon WorkSpaces

SYNOPSIS

  use Paws;

  my $obj = Paws->service('WorkSpaces');
  my $res = $obj->Method(
    Arg1 => $val1,
    Arg2 => [ 'V1', 'V2' ],
    # if Arg3 is an object, the HashRef will be used as arguments to the constructor
    # of the arguments type
    Arg3 => { Att1 => 'Val1' },
    # if Arg4 is an array of objects, the HashRefs will be passed as arguments to
    # the constructor of the arguments type
    Arg4 => [ { Att1 => 'Val1'  }, { Att1 => 'Val2' } ],
  );

DESCRIPTION

Amazon WorkSpaces Service

Amazon WorkSpaces enables you to provision virtual, cloud-based Microsoft Windows and Amazon Linux desktops for your users.

For the AWS API documentation, see https://docs.aws.amazon.com/goto/WebAPI/workspaces-2015-04-08

METHODS

AssociateIpGroups

DirectoryId => Str
GroupIds => ArrayRef[Str|Undef]

Each argument is described in detail in: Paws::WorkSpaces::AssociateIpGroups

Returns: a Paws::WorkSpaces::AssociateIpGroupsResult instance

Associates the specified IP access control group with the specified directory.

AuthorizeIpRules

GroupId => Str
UserRules => ArrayRef[Paws::WorkSpaces::IpRuleItem]

Each argument is described in detail in: Paws::WorkSpaces::AuthorizeIpRules

Returns: a Paws::WorkSpaces::AuthorizeIpRulesResult instance

Adds one or more rules to the specified IP access control group.

This action gives users permission to access their WorkSpaces from the CIDR address ranges specified in the rules.

CreateIpGroup

GroupName => Str
[GroupDesc => Str]
[UserRules => ArrayRef[Paws::WorkSpaces::IpRuleItem]]

Each argument is described in detail in: Paws::WorkSpaces::CreateIpGroup

Returns: a Paws::WorkSpaces::CreateIpGroupResult instance

Creates an IP access control group.

An IP access control group provides you with the ability to control the IP addresses from which users are allowed to access their WorkSpaces. To specify the CIDR address ranges, add rules to your IP access control group and then associate the group with your directory. You can add rules when you create the group or at any time using AuthorizeIpRules.

There is a default IP access control group associated with your directory. If you don't associate an IP access control group with your directory, the default group is used. The default group includes a default rule that allows users to access their WorkSpaces from anywhere. You cannot modify the default IP access control group for your directory.

CreateTags

ResourceId => Str
Tags => ArrayRef[Paws::WorkSpaces::Tag]

Each argument is described in detail in: Paws::WorkSpaces::CreateTags

Returns: a Paws::WorkSpaces::CreateTagsResult instance

Creates the specified tags for the specified WorkSpace.

CreateWorkspaces

Workspaces => ArrayRef[Paws::WorkSpaces::WorkspaceRequest]

Each argument is described in detail in: Paws::WorkSpaces::CreateWorkspaces

Returns: a Paws::WorkSpaces::CreateWorkspacesResult instance

Creates one or more WorkSpaces.

This operation is asynchronous and returns before the WorkSpaces are created.

DeleteIpGroup

GroupId => Str

Each argument is described in detail in: Paws::WorkSpaces::DeleteIpGroup

Returns: a Paws::WorkSpaces::DeleteIpGroupResult instance

Deletes the specified IP access control group.

You cannot delete an IP access control group that is associated with a directory.

DeleteTags

ResourceId => Str
TagKeys => ArrayRef[Str|Undef]

Each argument is described in detail in: Paws::WorkSpaces::DeleteTags

Returns: a Paws::WorkSpaces::DeleteTagsResult instance

Deletes the specified tags from the specified WorkSpace.

DeleteWorkspaceImage

ImageId => Str

Each argument is described in detail in: Paws::WorkSpaces::DeleteWorkspaceImage

Returns: a Paws::WorkSpaces::DeleteWorkspaceImageResult instance

Deletes the specified image from your account. To delete an image, you must first delete any bundles that are associated with the image.

DescribeAccount

Each argument is described in detail in: Paws::WorkSpaces::DescribeAccount

Returns: a Paws::WorkSpaces::DescribeAccountResult instance

Retrieves a list that describes the configuration of bring your own license (BYOL) for the specified account.

DescribeAccountModifications

[NextToken => Str]

Each argument is described in detail in: Paws::WorkSpaces::DescribeAccountModifications

Returns: a Paws::WorkSpaces::DescribeAccountModificationsResult instance

Retrieves a list that describes modifications to the configuration of bring your own license (BYOL) for the specified account.

DescribeClientProperties

ResourceIds => ArrayRef[Str|Undef]

Each argument is described in detail in: Paws::WorkSpaces::DescribeClientProperties

Returns: a Paws::WorkSpaces::DescribeClientPropertiesResult instance

Retrieves a list that describes one or more specified Amazon WorkSpaces clients.

DescribeIpGroups

[GroupIds => ArrayRef[Str|Undef]]
[MaxResults => Int]
[NextToken => Str]

Each argument is described in detail in: Paws::WorkSpaces::DescribeIpGroups

Returns: a Paws::WorkSpaces::DescribeIpGroupsResult instance

Describes one or more of your IP access control groups.

DescribeTags

ResourceId => Str

Each argument is described in detail in: Paws::WorkSpaces::DescribeTags

Returns: a Paws::WorkSpaces::DescribeTagsResult instance

Describes the specified tags for the specified WorkSpace.

DescribeWorkspaceBundles

[BundleIds => ArrayRef[Str|Undef]]
[NextToken => Str]
[Owner => Str]

Each argument is described in detail in: Paws::WorkSpaces::DescribeWorkspaceBundles

Returns: a Paws::WorkSpaces::DescribeWorkspaceBundlesResult instance

Retrieves a list that describes the available WorkSpace bundles.

You can filter the results using either bundle ID or owner, but not both.

DescribeWorkspaceDirectories

[DirectoryIds => ArrayRef[Str|Undef]]
[NextToken => Str]

Each argument is described in detail in: Paws::WorkSpaces::DescribeWorkspaceDirectories

Returns: a Paws::WorkSpaces::DescribeWorkspaceDirectoriesResult instance

Describes the available AWS Directory Service directories that are registered with Amazon WorkSpaces.

DescribeWorkspaceImages

[ImageIds => ArrayRef[Str|Undef]]
[MaxResults => Int]
[NextToken => Str]

Each argument is described in detail in: Paws::WorkSpaces::DescribeWorkspaceImages

Returns: a Paws::WorkSpaces::DescribeWorkspaceImagesResult instance

Retrieves a list that describes one or more specified images, if the image identifiers are provided. Otherwise, all images in the account are described.

DescribeWorkspaces

[BundleId => Str]
[DirectoryId => Str]
[Limit => Int]
[NextToken => Str]
[UserName => Str]
[WorkspaceIds => ArrayRef[Str|Undef]]

Each argument is described in detail in: Paws::WorkSpaces::DescribeWorkspaces

Returns: a Paws::WorkSpaces::DescribeWorkspacesResult instance

Describes the specified WorkSpaces.

You can filter the results by using the bundle identifier, directory identifier, or owner, but you can specify only one filter at a time.

DescribeWorkspacesConnectionStatus

[NextToken => Str]
[WorkspaceIds => ArrayRef[Str|Undef]]

Each argument is described in detail in: Paws::WorkSpaces::DescribeWorkspacesConnectionStatus

Returns: a Paws::WorkSpaces::DescribeWorkspacesConnectionStatusResult instance

Describes the connection status of the specified WorkSpaces.

DisassociateIpGroups

DirectoryId => Str
GroupIds => ArrayRef[Str|Undef]

Each argument is described in detail in: Paws::WorkSpaces::DisassociateIpGroups

Returns: a Paws::WorkSpaces::DisassociateIpGroupsResult instance

Disassociates the specified IP access control group from the specified directory.

ImportWorkspaceImage

Ec2ImageId => Str
ImageDescription => Str
ImageName => Str
IngestionProcess => Str

Each argument is described in detail in: Paws::WorkSpaces::ImportWorkspaceImage

Returns: a Paws::WorkSpaces::ImportWorkspaceImageResult instance

Imports the specified Windows 7 or Windows 10 bring your own license (BYOL) image into Amazon WorkSpaces. The image must be an already licensed EC2 image that is in your AWS account, and you must own the image.

ListAvailableManagementCidrRanges

ManagementCidrRangeConstraint => Str
[MaxResults => Int]
[NextToken => Str]

Each argument is described in detail in: Paws::WorkSpaces::ListAvailableManagementCidrRanges

Returns: a Paws::WorkSpaces::ListAvailableManagementCidrRangesResult instance

Retrieves a list of IP address ranges, specified as IPv4 CIDR blocks, that you can use for the network management interface when you enable bring your own license (BYOL).

The management network interface is connected to a secure Amazon WorkSpaces management network. It is used for interactive streaming of the WorkSpace desktop to Amazon WorkSpaces clients, and to allow Amazon WorkSpaces to manage the WorkSpace.

ModifyAccount

[DedicatedTenancyManagementCidrRange => Str]
[DedicatedTenancySupport => Str]

Each argument is described in detail in: Paws::WorkSpaces::ModifyAccount

Returns: a Paws::WorkSpaces::ModifyAccountResult instance

Modifies the configuration of bring your own license (BYOL) for the specified account.

ModifyClientProperties

ClientProperties => Paws::WorkSpaces::ClientProperties
ResourceId => Str

Each argument is described in detail in: Paws::WorkSpaces::ModifyClientProperties

Returns: a Paws::WorkSpaces::ModifyClientPropertiesResult instance

Modifies the properties of the specified Amazon WorkSpaces client.

ModifyWorkspaceProperties

WorkspaceId => Str
WorkspaceProperties => Paws::WorkSpaces::WorkspaceProperties

Each argument is described in detail in: Paws::WorkSpaces::ModifyWorkspaceProperties

Returns: a Paws::WorkSpaces::ModifyWorkspacePropertiesResult instance

Modifies the specified WorkSpace properties.

ModifyWorkspaceState

WorkspaceId => Str
WorkspaceState => Str

Each argument is described in detail in: Paws::WorkSpaces::ModifyWorkspaceState

Returns: a Paws::WorkSpaces::ModifyWorkspaceStateResult instance

Sets the state of the specified WorkSpace.

To maintain a WorkSpace without being interrupted, set the WorkSpace state to ADMIN_MAINTENANCE. WorkSpaces in this state do not respond to requests to reboot, stop, start, or rebuild. An AutoStop WorkSpace in this state is not stopped. Users can log into a WorkSpace in the ADMIN_MAINTENANCE state.

RebootWorkspaces

RebootWorkspaceRequests => ArrayRef[Paws::WorkSpaces::RebootRequest]

Each argument is described in detail in: Paws::WorkSpaces::RebootWorkspaces

Returns: a Paws::WorkSpaces::RebootWorkspacesResult instance

Reboots the specified WorkSpaces.

You cannot reboot a WorkSpace unless its state is AVAILABLE or UNHEALTHY.

This operation is asynchronous and returns before the WorkSpaces have rebooted.

RebuildWorkspaces

RebuildWorkspaceRequests => ArrayRef[Paws::WorkSpaces::RebuildRequest]

Each argument is described in detail in: Paws::WorkSpaces::RebuildWorkspaces

Returns: a Paws::WorkSpaces::RebuildWorkspacesResult instance

Rebuilds the specified WorkSpace.

You cannot rebuild a WorkSpace unless its state is AVAILABLE, ERROR, or UNHEALTHY.

Rebuilding a WorkSpace is a potentially destructive action that can result in the loss of data. For more information, see Rebuild a WorkSpace (http://docs.aws.amazon.com/workspaces/latest/adminguide/reset-workspace.html).

This operation is asynchronous and returns before the WorkSpaces have been completely rebuilt.

RevokeIpRules

GroupId => Str
UserRules => ArrayRef[Str|Undef]

Each argument is described in detail in: Paws::WorkSpaces::RevokeIpRules

Returns: a Paws::WorkSpaces::RevokeIpRulesResult instance

Removes one or more rules from the specified IP access control group.

StartWorkspaces

StartWorkspaceRequests => ArrayRef[Paws::WorkSpaces::StartRequest]

Each argument is described in detail in: Paws::WorkSpaces::StartWorkspaces

Returns: a Paws::WorkSpaces::StartWorkspacesResult instance

Starts the specified WorkSpaces.

You cannot start a WorkSpace unless it has a running mode of AutoStop and a state of STOPPED.

StopWorkspaces

StopWorkspaceRequests => ArrayRef[Paws::WorkSpaces::StopRequest]

Each argument is described in detail in: Paws::WorkSpaces::StopWorkspaces

Returns: a Paws::WorkSpaces::StopWorkspacesResult instance

Stops the specified WorkSpaces.

You cannot stop a WorkSpace unless it has a running mode of AutoStop and a state of AVAILABLE, IMPAIRED, UNHEALTHY, or ERROR.

TerminateWorkspaces

TerminateWorkspaceRequests => ArrayRef[Paws::WorkSpaces::TerminateRequest]

Each argument is described in detail in: Paws::WorkSpaces::TerminateWorkspaces

Returns: a Paws::WorkSpaces::TerminateWorkspacesResult instance

Terminates the specified WorkSpaces.

Terminating a WorkSpace is a permanent action and cannot be undone. The user's data is destroyed. If you need to archive any user data, contact Amazon Web Services before terminating the WorkSpace.

You can terminate a WorkSpace that is in any state except SUSPENDED.

This operation is asynchronous and returns before the WorkSpaces have been completely terminated.

UpdateRulesOfIpGroup

GroupId => Str
UserRules => ArrayRef[Paws::WorkSpaces::IpRuleItem]

Each argument is described in detail in: Paws::WorkSpaces::UpdateRulesOfIpGroup

Returns: a Paws::WorkSpaces::UpdateRulesOfIpGroupResult instance

Replaces the current rules of the specified IP access control group with the specified rules.

PAGINATORS

Paginator methods are helpers that repetively call methods that return partial results

DescribeAllAccountModifications(sub { },[NextToken => Str])

DescribeAllAccountModifications([NextToken => Str])

If passed a sub as first parameter, it will call the sub for each element found in :

 - AccountModifications, passing the object as the first parameter, and the string 'AccountModifications' as the second parameter 

If not, it will return a a Paws::WorkSpaces::DescribeAccountModificationsResult instance with all the params; from all the responses. Please take into account that this mode can potentially consume vasts ammounts of memory.

DescribeAllIpGroups(sub { },[GroupIds => ArrayRef[Str|Undef], MaxResults => Int, NextToken => Str])

DescribeAllIpGroups([GroupIds => ArrayRef[Str|Undef], MaxResults => Int, NextToken => Str])

If passed a sub as first parameter, it will call the sub for each element found in :

 - Result, passing the object as the first parameter, and the string 'Result' as the second parameter 

If not, it will return a a Paws::WorkSpaces::DescribeIpGroupsResult instance with all the params; from all the responses. Please take into account that this mode can potentially consume vasts ammounts of memory.

DescribeAllWorkspaceBundles(sub { },[BundleIds => ArrayRef[Str|Undef], NextToken => Str, Owner => Str])

DescribeAllWorkspaceBundles([BundleIds => ArrayRef[Str|Undef], NextToken => Str, Owner => Str])

If passed a sub as first parameter, it will call the sub for each element found in :

 - Bundles, passing the object as the first parameter, and the string 'Bundles' as the second parameter 

If not, it will return a a Paws::WorkSpaces::DescribeWorkspaceBundlesResult instance with all the params; from all the responses. Please take into account that this mode can potentially consume vasts ammounts of memory.

DescribeAllWorkspaceDirectories(sub { },[DirectoryIds => ArrayRef[Str|Undef], NextToken => Str])

DescribeAllWorkspaceDirectories([DirectoryIds => ArrayRef[Str|Undef], NextToken => Str])

If passed a sub as first parameter, it will call the sub for each element found in :

 - Directories, passing the object as the first parameter, and the string 'Directories' as the second parameter 

If not, it will return a a Paws::WorkSpaces::DescribeWorkspaceDirectoriesResult instance with all the params; from all the responses. Please take into account that this mode can potentially consume vasts ammounts of memory.

DescribeAllWorkspaceImages(sub { },[ImageIds => ArrayRef[Str|Undef], MaxResults => Int, NextToken => Str])

DescribeAllWorkspaceImages([ImageIds => ArrayRef[Str|Undef], MaxResults => Int, NextToken => Str])

If passed a sub as first parameter, it will call the sub for each element found in :

 - Images, passing the object as the first parameter, and the string 'Images' as the second parameter 

If not, it will return a a Paws::WorkSpaces::DescribeWorkspaceImagesResult instance with all the params; from all the responses. Please take into account that this mode can potentially consume vasts ammounts of memory.

DescribeAllWorkspaces(sub { },[BundleId => Str, DirectoryId => Str, Limit => Int, NextToken => Str, UserName => Str, WorkspaceIds => ArrayRef[Str|Undef]])

DescribeAllWorkspaces([BundleId => Str, DirectoryId => Str, Limit => Int, NextToken => Str, UserName => Str, WorkspaceIds => ArrayRef[Str|Undef]])

If passed a sub as first parameter, it will call the sub for each element found in :

 - Workspaces, passing the object as the first parameter, and the string 'Workspaces' as the second parameter 

If not, it will return a a Paws::WorkSpaces::DescribeWorkspacesResult instance with all the params; from all the responses. Please take into account that this mode can potentially consume vasts ammounts of memory.

DescribeAllWorkspacesConnectionStatus(sub { },[NextToken => Str, WorkspaceIds => ArrayRef[Str|Undef]])

DescribeAllWorkspacesConnectionStatus([NextToken => Str, WorkspaceIds => ArrayRef[Str|Undef]])

If passed a sub as first parameter, it will call the sub for each element found in :

 - WorkspacesConnectionStatus, passing the object as the first parameter, and the string 'WorkspacesConnectionStatus' as the second parameter 

If not, it will return a a Paws::WorkSpaces::DescribeWorkspacesConnectionStatusResult instance with all the params; from all the responses. Please take into account that this mode can potentially consume vasts ammounts of memory.

ListAllAvailableManagementCidrRanges(sub { },ManagementCidrRangeConstraint => Str, [MaxResults => Int, NextToken => Str])

ListAllAvailableManagementCidrRanges(ManagementCidrRangeConstraint => Str, [MaxResults => Int, NextToken => Str])

If passed a sub as first parameter, it will call the sub for each element found in :

 - ManagementCidrRanges, passing the object as the first parameter, and the string 'ManagementCidrRanges' as the second parameter 

If not, it will return a a Paws::WorkSpaces::ListAvailableManagementCidrRangesResult instance with all the params; from all the responses. Please take into account that this mode can potentially consume vasts ammounts of memory.

SEE ALSO

This service class forms part of Paws

BUGS and CONTRIBUTIONS

The source code is located here: https://github.com/pplu/aws-sdk-perl

Please report bugs to: https://github.com/pplu/aws-sdk-perl/issues