@Generated(value="software.amazon.awssdk:codegen") public final class UpdateUserRequest extends TransferRequest implements ToCopyableBuilder<UpdateUserRequest.Builder,UpdateUserRequest>
| Modifier and Type | Class and Description |
|---|---|
static interface |
UpdateUserRequest.Builder |
| Modifier and Type | Method and Description |
|---|---|
static UpdateUserRequest.Builder |
builder() |
boolean |
equals(Object obj) |
boolean |
equalsBySdkFields(Object obj) |
<T> Optional<T> |
getValueForField(String fieldName,
Class<T> clazz) |
int |
hashCode() |
boolean |
hasHomeDirectoryMappings()
Returns true if the HomeDirectoryMappings property was specified by the sender (it may be empty), or false if the
sender did not specify the value (it will be empty).
|
String |
homeDirectory()
Specifies the landing directory (folder) for a user when they log in to the server using their file transfer
protocol client.
|
List<HomeDirectoryMapEntry> |
homeDirectoryMappings()
Logical directory mappings that specify what Amazon S3 paths and keys should be visible to your user and how you
want to make them visible.
|
HomeDirectoryType |
homeDirectoryType()
The type of landing directory (folder) you want your users' home directory to be when they log into the server.
|
String |
homeDirectoryTypeAsString()
The type of landing directory (folder) you want your users' home directory to be when they log into the server.
|
String |
policy()
Allows you to supply a scope-down policy for your user so you can use the same IAM role across multiple users.
|
String |
role()
The IAM role that controls your users' access to your Amazon S3 bucket.
|
List<SdkField<?>> |
sdkFields() |
static Class<? extends UpdateUserRequest.Builder> |
serializableBuilderClass() |
String |
serverId()
A system-assigned unique identifier for a server instance that the user account is assigned to.
|
UpdateUserRequest.Builder |
toBuilder() |
String |
toString()
Returns a string representation of this object.
|
String |
userName()
A unique string that identifies a user and is associated with a server as specified by the
ServerId. |
overrideConfigurationclone, finalize, getClass, notify, notifyAll, wait, wait, waitcopypublic String homeDirectory()
Specifies the landing directory (folder) for a user when they log in to the server using their file transfer protocol client.
An example is your-Amazon-S3-bucket-name>/home/username.
An example is your-Amazon-S3-bucket-name>/home/username.
public HomeDirectoryType homeDirectoryType()
The type of landing directory (folder) you want your users' home directory to be when they log into the server.
If you set it to PATH, the user will see the absolute Amazon S3 bucket paths as is in their file
transfer protocol clients. If you set it LOGICAL, you will need to provide mappings in the
HomeDirectoryMappings for how you want to make Amazon S3 paths visible to your users.
If the service returns an enum value that is not available in the current SDK version, homeDirectoryType
will return HomeDirectoryType.UNKNOWN_TO_SDK_VERSION. The raw value returned by the service is available
from homeDirectoryTypeAsString().
PATH, the user will see the absolute Amazon S3 bucket paths as is
in their file transfer protocol clients. If you set it LOGICAL, you will need to provide
mappings in the HomeDirectoryMappings for how you want to make Amazon S3 paths visible to
your users.HomeDirectoryTypepublic String homeDirectoryTypeAsString()
The type of landing directory (folder) you want your users' home directory to be when they log into the server.
If you set it to PATH, the user will see the absolute Amazon S3 bucket paths as is in their file
transfer protocol clients. If you set it LOGICAL, you will need to provide mappings in the
HomeDirectoryMappings for how you want to make Amazon S3 paths visible to your users.
If the service returns an enum value that is not available in the current SDK version, homeDirectoryType
will return HomeDirectoryType.UNKNOWN_TO_SDK_VERSION. The raw value returned by the service is available
from homeDirectoryTypeAsString().
PATH, the user will see the absolute Amazon S3 bucket paths as is
in their file transfer protocol clients. If you set it LOGICAL, you will need to provide
mappings in the HomeDirectoryMappings for how you want to make Amazon S3 paths visible to
your users.HomeDirectoryTypepublic boolean hasHomeDirectoryMappings()
public List<HomeDirectoryMapEntry> homeDirectoryMappings()
Logical directory mappings that specify what Amazon S3 paths and keys should be visible to your user and how you
want to make them visible. You will need to specify the "Entry" and "Target" pair,
where Entry shows how the path is made visible and Target is the actual Amazon S3 path.
If you only specify a target, it will be displayed as is. You will need to also make sure that your IAM role
provides access to paths in Target. The following is an example.
'[ "/bucket2/documentation", { "Entry": "your-personal-report.pdf", "Target": "/bucket3/customized-reports/${transfer:UserName}.pdf" } ]'
In most cases, you can use this value instead of the scope-down policy to lock your user down to the designated
home directory ("chroot"). To do this, you can set Entry to '/' and set Target to the
HomeDirectory parameter value.
If the target of a logical directory entry does not exist in Amazon S3, the entry will be ignored. As a
workaround, you can use the Amazon S3 API to create 0 byte objects as place holders for your directory. If using
the CLI, use the s3api call instead of s3 so you can use the put-object operation. For
example, you use the following: aws s3api put-object --bucket bucketname --key path/to/folder/. Make
sure that the end of the key name ends in a / for it to be considered a folder.
Attempts to modify the collection returned by this method will result in an UnsupportedOperationException.
You can use hasHomeDirectoryMappings() to see if a value was sent in this field.
Entry" and "
Target" pair, where Entry shows how the path is made visible and
Target is the actual Amazon S3 path. If you only specify a target, it will be displayed as
is. You will need to also make sure that your IAM role provides access to paths in Target.
The following is an example.
'[ "/bucket2/documentation", { "Entry": "your-personal-report.pdf", "Target": "/bucket3/customized-reports/${transfer:UserName}.pdf" } ]'
In most cases, you can use this value instead of the scope-down policy to lock your user down to the
designated home directory ("chroot"). To do this, you can set Entry to '/' and set
Target to the HomeDirectory parameter value.
If the target of a logical directory entry does not exist in Amazon S3, the entry will be ignored. As a
workaround, you can use the Amazon S3 API to create 0 byte objects as place holders for your directory.
If using the CLI, use the s3api call instead of s3 so you can use the
put-object operation. For example, you use the following:
aws s3api put-object --bucket bucketname --key path/to/folder/. Make sure that the end of
the key name ends in a / for it to be considered a folder.
public String policy()
Allows you to supply a scope-down policy for your user so you can use the same IAM role across multiple users.
The policy scopes down user access to portions of your Amazon S3 bucket. Variables you can use inside this policy
include ${Transfer:UserName}, ${Transfer:HomeDirectory}, and
${Transfer:HomeBucket}.
For scope-down policies, AWS Transfer Family stores the policy as a JSON blob, instead of the Amazon Resource
Name (ARN) of the policy. You save the policy as a JSON blob and pass it in the Policy argument.
For an example of a scope-down policy, see Creating a scope-down policy.
For more information, see AssumeRole in the AWS Security Token Service API Reference.
${Transfer:UserName}, ${Transfer:HomeDirectory}, and
${Transfer:HomeBucket}.
For scope-down policies, AWS Transfer Family stores the policy as a JSON blob, instead of the Amazon
Resource Name (ARN) of the policy. You save the policy as a JSON blob and pass it in the
Policy argument.
For an example of a scope-down policy, see Creating a scope-down policy.
For more information, see AssumeRole in the AWS Security Token Service API Reference.
public String role()
The IAM role that controls your users' access to your Amazon S3 bucket. The policies attached to this role will determine the level of access you want to provide your users when transferring files into and out of your Amazon S3 bucket or buckets. The IAM role should also contain a trust relationship that allows the server to access your resources when servicing your users' transfer requests.
public String serverId()
A system-assigned unique identifier for a server instance that the user account is assigned to.
public String userName()
A unique string that identifies a user and is associated with a server as specified by the ServerId.
This user name must be a minimum of 3 and a maximum of 100 characters long. The following are valid characters:
a-z, A-Z, 0-9, underscore '_', hyphen '-', period '.', and at sign '@'. The user name can't start with a hyphen,
period, or at sign.
ServerId. This user name must be a minimum of 3 and a maximum of 100 characters long. The
following are valid characters: a-z, A-Z, 0-9, underscore '_', hyphen '-', period '.', and at sign '@'.
The user name can't start with a hyphen, period, or at sign.public UpdateUserRequest.Builder toBuilder()
toBuilder in interface ToCopyableBuilder<UpdateUserRequest.Builder,UpdateUserRequest>toBuilder in class TransferRequestpublic static UpdateUserRequest.Builder builder()
public static Class<? extends UpdateUserRequest.Builder> serializableBuilderClass()
public int hashCode()
hashCode in class AwsRequestpublic boolean equals(Object obj)
equals in class AwsRequestpublic boolean equalsBySdkFields(Object obj)
equalsBySdkFields in interface SdkPojopublic String toString()
public <T> Optional<T> getValueForField(String fieldName, Class<T> clazz)
getValueForField in class SdkRequestCopyright © 2020. All rights reserved.