class Aws::DataSync::Client
An API client for DataSync
. To construct a client, you need to configure a `:region` and `:credentials`.
client = Aws::DataSync::Client.new( region: region_name, credentials: credentials, # ... )
For details on configuring region and credentials see the [developer guide](/sdk-for-ruby/v3/developer-guide/setup-config.html).
See {#initialize} for a full list of supported configuration options.
Attributes
@api private
Public Class Methods
@api private
# File lib/aws-sdk-datasync/client.rb, line 2537 def errors_module Errors end
@overload initialize(options)
@param [Hash] options @option options [required, Aws::CredentialProvider] :credentials Your AWS credentials. This can be an instance of any one of the following classes: * `Aws::Credentials` - Used for configuring static, non-refreshing credentials. * `Aws::SharedCredentials` - Used for loading static credentials from a shared file, such as `~/.aws/config`. * `Aws::AssumeRoleCredentials` - Used when you need to assume a role. * `Aws::AssumeRoleWebIdentityCredentials` - Used when you need to assume a role after providing credentials via the web. * `Aws::SSOCredentials` - Used for loading credentials from AWS SSO using an access token generated from `aws login`. * `Aws::ProcessCredentials` - Used for loading credentials from a process that outputs to stdout. * `Aws::InstanceProfileCredentials` - Used for loading credentials from an EC2 IMDS on an EC2 instance. * `Aws::ECSCredentials` - Used for loading credentials from instances running in ECS. * `Aws::CognitoIdentityCredentials` - Used for loading credentials from the Cognito Identity service. When `:credentials` are not configured directly, the following locations will be searched for credentials: * `Aws.config[:credentials]` * The `:access_key_id`, `:secret_access_key`, and `:session_token` options. * ENV['AWS_ACCESS_KEY_ID'], ENV['AWS_SECRET_ACCESS_KEY'] * `~/.aws/credentials` * `~/.aws/config` * EC2/ECS IMDS instance profile - When used by default, the timeouts are very aggressive. Construct and pass an instance of `Aws::InstanceProfileCredentails` or `Aws::ECSCredentials` to enable retries and extended timeouts. @option options [required, String] :region The AWS region to connect to. The configured `:region` is used to determine the service `:endpoint`. When not passed, a default `:region` is searched for in the following locations: * `Aws.config[:region]` * `ENV['AWS_REGION']` * `ENV['AMAZON_REGION']` * `ENV['AWS_DEFAULT_REGION']` * `~/.aws/credentials` * `~/.aws/config` @option options [String] :access_key_id @option options [Boolean] :active_endpoint_cache (false) When set to `true`, a thread polling for endpoints will be running in the background every 60 secs (default). Defaults to `false`. @option options [Boolean] :adaptive_retry_wait_to_fill (true) Used only in `adaptive` retry mode. When true, the request will sleep until there is sufficent client side capacity to retry the request. When false, the request will raise a `RetryCapacityNotAvailableError` and will not retry instead of sleeping. @option options [Boolean] :client_side_monitoring (false) When `true`, client-side metrics will be collected for all API requests from this client. @option options [String] :client_side_monitoring_client_id ("") Allows you to provide an identifier for this client which will be attached to all generated client side metrics. Defaults to an empty string. @option options [String] :client_side_monitoring_host ("127.0.0.1") Allows you to specify the DNS hostname or IPv4 or IPv6 address that the client side monitoring agent is running on, where client metrics will be published via UDP. @option options [Integer] :client_side_monitoring_port (31000) Required for publishing client metrics. The port that the client side monitoring agent is running on, where client metrics will be published via UDP. @option options [Aws::ClientSideMonitoring::Publisher] :client_side_monitoring_publisher (Aws::ClientSideMonitoring::Publisher) Allows you to provide a custom client-side monitoring publisher class. By default, will use the Client Side Monitoring Agent Publisher. @option options [Boolean] :convert_params (true) When `true`, an attempt is made to coerce request parameters into the required types. @option options [Boolean] :correct_clock_skew (true) Used only in `standard` and adaptive retry modes. Specifies whether to apply a clock skew correction and retry requests with skewed client clocks. @option options [Boolean] :disable_host_prefix_injection (false) Set to true to disable SDK automatically adding host prefix to default service endpoint when available. @option options [String] :endpoint The client endpoint is normally constructed from the `:region` option. You should only configure an `:endpoint` when connecting to test or custom endpoints. This should be a valid HTTP(S) URI. @option options [Integer] :endpoint_cache_max_entries (1000) Used for the maximum size limit of the LRU cache storing endpoints data for endpoint discovery enabled operations. Defaults to 1000. @option options [Integer] :endpoint_cache_max_threads (10) Used for the maximum threads in use for polling endpoints to be cached, defaults to 10. @option options [Integer] :endpoint_cache_poll_interval (60) When :endpoint_discovery and :active_endpoint_cache is enabled, Use this option to config the time interval in seconds for making requests fetching endpoints information. Defaults to 60 sec. @option options [Boolean] :endpoint_discovery (false) When set to `true`, endpoint discovery will be enabled for operations when available. @option options [Aws::Log::Formatter] :log_formatter (Aws::Log::Formatter.default) The log formatter. @option options [Symbol] :log_level (:info) The log level to send messages to the `:logger` at. @option options [Logger] :logger The Logger instance to send log messages to. If this option is not set, logging will be disabled. @option options [Integer] :max_attempts (3) An integer representing the maximum number attempts that will be made for a single request, including the initial attempt. For example, setting this value to 5 will result in a request being retried up to 4 times. Used in `standard` and `adaptive` retry modes. @option options [String] :profile ("default") Used when loading credentials from the shared credentials file at HOME/.aws/credentials. When not specified, 'default' is used. @option options [Proc] :retry_backoff A proc or lambda used for backoff. Defaults to 2**retries * retry_base_delay. This option is only used in the `legacy` retry mode. @option options [Float] :retry_base_delay (0.3) The base delay in seconds used by the default backoff function. This option is only used in the `legacy` retry mode. @option options [Symbol] :retry_jitter (:none) A delay randomiser function used by the default backoff function. Some predefined functions can be referenced by name - :none, :equal, :full, otherwise a Proc that takes and returns a number. This option is only used in the `legacy` retry mode. @see https://www.awsarchitectureblog.com/2015/03/backoff.html @option options [Integer] :retry_limit (3) The maximum number of times to retry failed requests. Only ~ 500 level server errors and certain ~ 400 level client errors are retried. Generally, these are throttling errors, data checksum errors, networking errors, timeout errors, auth errors, endpoint discovery, and errors from expired credentials. This option is only used in the `legacy` retry mode. @option options [Integer] :retry_max_delay (0) The maximum number of seconds to delay between retries (0 for no limit) used by the default backoff function. This option is only used in the `legacy` retry mode. @option options [String] :retry_mode ("legacy") Specifies which retry algorithm to use. Values are: * `legacy` - The pre-existing retry behavior. This is default value if no retry mode is provided. * `standard` - A standardized set of retry rules across the AWS SDKs. This includes support for retry quotas, which limit the number of unsuccessful retries a client can make. * `adaptive` - An experimental retry mode that includes all the functionality of `standard` mode along with automatic client side throttling. This is a provisional mode that may change behavior in the future. @option options [String] :secret_access_key @option options [String] :session_token @option options [Boolean] :simple_json (false) Disables request parameter conversion, validation, and formatting. Also disable response data type conversions. This option is useful when you want to ensure the highest level of performance by avoiding overhead of walking request parameters and response data structures. When `:simple_json` is enabled, the request parameters hash must be formatted exactly as the DynamoDB API expects. @option options [Boolean] :stub_responses (false) Causes the client to return stubbed responses. By default fake responses are generated and returned. You can specify the response data to return or errors to raise by calling {ClientStubs#stub_responses}. See {ClientStubs} for more information. ** Please note ** When response stubbing is enabled, no HTTP requests are made, and retries are disabled. @option options [Boolean] :validate_params (true) When `true`, request parameters are validated before sending the request. @option options [URI::HTTP,String] :http_proxy A proxy to send requests through. Formatted like 'http://proxy.com:123'. @option options [Float] :http_open_timeout (15) The number of seconds to wait when opening a HTTP session before raising a `Timeout::Error`. @option options [Integer] :http_read_timeout (60) The default number of seconds to wait for response data. This value can safely be set per-request on the session. @option options [Float] :http_idle_timeout (5) The number of seconds a connection is allowed to sit idle before it is considered stale. Stale connections are closed and removed from the pool before making a request. @option options [Float] :http_continue_timeout (1) The number of seconds to wait for a 100-continue response before sending the request body. This option has no effect unless the request has "Expect" header set to "100-continue". Defaults to `nil` which disables this behaviour. This value can safely be set per request on the session. @option options [Boolean] :http_wire_trace (false) When `true`, HTTP debug output will be sent to the `:logger`. @option options [Boolean] :ssl_verify_peer (true) When `true`, SSL peer certificates are verified when establishing a connection. @option options [String] :ssl_ca_bundle Full path to the SSL certificate authority bundle file that should be used when verifying peer certificates. If you do not pass `:ssl_ca_bundle` or `:ssl_ca_directory` the the system default will be used if available. @option options [String] :ssl_ca_directory Full path of the directory that contains the unbundled SSL certificate authority files for verifying peer certificates. If you do not pass `:ssl_ca_bundle` or `:ssl_ca_directory` the the system default will be used if available.
# File lib/aws-sdk-datasync/client.rb, line 334 def initialize(*args) super end
Public Instance Methods
@param params ({}) @api private
# File lib/aws-sdk-datasync/client.rb, line 2512 def build_request(operation_name, params = {}) handlers = @handlers.for(operation_name) context = Seahorse::Client::RequestContext.new( operation_name: operation_name, operation: config.api.operation(operation_name), client: self, params: params, config: config) context[:gem_name] = 'aws-sdk-datasync' context[:gem_version] = '1.36.0' Seahorse::Client::Request.new(handlers, context) end
Cancels execution of a task.
When you cancel a task execution, the transfer of some files is abruptly interrupted. The contents of files that are transferred to the destination might be incomplete or inconsistent with the source files. However, if you start a new task execution on the same task and you allow the task execution to complete, file content on the destination is complete and consistent. This applies to other unexpected failures that interrupt a task execution. In all of these cases, DataSync
successfully complete the transfer when you start the next task execution.
@option params [required, String] :task_execution_arn
The Amazon Resource Name (ARN) of the task execution to cancel.
@return [Struct] Returns an empty {Seahorse::Client::Response response}.
@example Request syntax with placeholder values
resp = client.cancel_task_execution({ task_execution_arn: "TaskExecutionArn", # required })
@see docs.aws.amazon.com/goto/WebAPI/datasync-2018-11-09/CancelTaskExecution AWS API Documentation
@overload cancel_task_execution
(params = {}) @param [Hash] params ({})
# File lib/aws-sdk-datasync/client.rb, line 367 def cancel_task_execution(params = {}, options = {}) req = build_request(:cancel_task_execution, params) req.send_request(options) end
Activates an DataSync
agent that you have deployed on your host. The activation process associates your agent with your account. In the activation process, you specify information such as the Amazon Web Services Region that you want to activate the agent in. You activate the agent in the Amazon Web Services Region where your target locations (in Amazon S3 or Amazon EFS) reside. Your tasks are created in this Amazon Web Services Region.
You can activate the agent in a VPC (virtual private cloud) or provide the agent access to a VPC endpoint so you can run tasks without going over the public internet.
You can use an agent for more than one location. If a task uses multiple agents, all of them need to have status AVAILABLE for the task to run. If you use multiple agents for a source location, the status of all the agents must be AVAILABLE for the task to run.
Agents are automatically updated by Amazon Web Services on a regular basis, using a mechanism that ensures minimal interruption to your tasks.
@option params [required, String] :activation_key
Your agent activation key. You can get the activation key either by sending an HTTP GET request with redirects that enable you to get the agent IP address (port 80). Alternatively, you can get it from the DataSync console. The redirect URL returned in the response provides you the activation key for your agent in the query string parameter `activationKey`. It might also include other activation-related parameters; however, these are merely defaults. The arguments you pass to this API call determine the actual configuration of your agent. For more information, see Activating an Agent in the *DataSync User Guide.*
@option params [String] :agent_name
The name you configured for your agent. This value is a text reference that is used to identify the agent in the console.
@option params [Array<Types::TagListEntry>] :tags
The key-value pair that represents the tag that you want to associate with the agent. The value can be an empty string. This value helps you manage, filter, and search for your agents. <note markdown="1"> Valid characters for key and value are letters, spaces, and numbers representable in UTF-8 format, and the following special characters: + - = . \_ : / @. </note>
@option params [String] :vpc_endpoint_id
The ID of the VPC (virtual private cloud) endpoint that the agent has access to. This is the client-side VPC endpoint, also called a PrivateLink. If you don't have a PrivateLink VPC endpoint, see [Creating a VPC Endpoint Service Configuration][1] in the Amazon VPC User Guide. VPC endpoint ID looks like this: `vpce-01234d5aff67890e1`. [1]: https://docs.aws.amazon.com/vpc/latest/userguide/endpoint-service.html#create-endpoint-service
@option params [Array<String>] :subnet_arns
The Amazon Resource Names (ARNs) of the subnets in which DataSync will create elastic network interfaces for each data transfer task. The agent that runs a task must be private. When you start a task that is associated with an agent created in a VPC, or one that has access to an IP address in a VPC, then the task is also private. In this case, DataSync creates four network interfaces for each task in your subnet. For a data transfer to work, the agent must be able to route to all these four network interfaces.
@option params [Array<String>] :security_group_arns
The ARNs of the security groups used to protect your data transfer task subnets. See [SecurityGroupArns][1]. [1]: https://docs.aws.amazon.com/datasync/latest/userguide/API_Ec2Config.html#DataSync-Type-Ec2Config-SecurityGroupArns
@return [Types::CreateAgentResponse] Returns a {Seahorse::Client::Response response} object which responds to the following methods:
* {Types::CreateAgentResponse#agent_arn #agent_arn} => String
@example Request syntax with placeholder values
resp = client.create_agent({ activation_key: "ActivationKey", # required agent_name: "TagValue", tags: [ { key: "TagKey", # required value: "TagValue", }, ], vpc_endpoint_id: "VpcEndpointId", subnet_arns: ["Ec2SubnetArn"], security_group_arns: ["Ec2SecurityGroupArn"], })
@example Response structure
resp.agent_arn #=> String
@see docs.aws.amazon.com/goto/WebAPI/datasync-2018-11-09/CreateAgent AWS API Documentation
@overload create_agent
(params = {}) @param [Hash] params ({})
# File lib/aws-sdk-datasync/client.rb, line 482 def create_agent(params = {}, options = {}) req = build_request(:create_agent, params) req.send_request(options) end
Creates an endpoint for an Amazon EFS file system.
@option params [String] :subdirectory
A subdirectory in the location’s path. This subdirectory in the EFS file system is used to read data from the EFS source location or write data to the EFS destination. By default, DataSync uses the root directory. <note markdown="1"> `Subdirectory` must be specified with forward slashes. For example, `/path/to/folder`. </note>
@option params [required, String] :efs_filesystem_arn
The Amazon Resource Name (ARN) for the Amazon EFS file system.
@option params [required, Types::Ec2Config] :ec2_config
The subnet and security group that the Amazon EFS file system uses. The security group that you provide needs to be able to communicate with the security group on the mount target in the subnet specified. The exact relationship between security group M (of the mount target) and security group S (which you provide for DataSync to use at this stage) is as follows: * Security group M (which you associate with the mount target) must allow inbound access for the Transmission Control Protocol (TCP) on the NFS port (2049) from security group S. You can enable inbound connections either by IP address (CIDR range) or security group. * Security group S (provided to DataSync to access EFS) should have a rule that enables outbound connections to the NFS port on one of the file system’s mount targets. You can enable outbound connections either by IP address (CIDR range) or security group. For information about security groups and mount targets, see Security Groups for Amazon EC2 Instances and Mount Targets in the *Amazon EFS User Guide.*
@option params [Array<Types::TagListEntry>] :tags
The key-value pair that represents a tag that you want to add to the resource. The value can be an empty string. This value helps you manage, filter, and search for your resources. We recommend that you create a name tag for your location.
@return [Types::CreateLocationEfsResponse] Returns a {Seahorse::Client::Response response} object which responds to the following methods:
* {Types::CreateLocationEfsResponse#location_arn #location_arn} => String
@example Request syntax with placeholder values
resp = client.create_location_efs({ subdirectory: "EfsSubdirectory", efs_filesystem_arn: "EfsFilesystemArn", # required ec2_config: { # required subnet_arn: "Ec2SubnetArn", # required security_group_arns: ["Ec2SecurityGroupArn"], # required }, tags: [ { key: "TagKey", # required value: "TagValue", }, ], })
@example Response structure
resp.location_arn #=> String
@see docs.aws.amazon.com/goto/WebAPI/datasync-2018-11-09/CreateLocationEfs AWS API Documentation
@overload create_location_efs
(params = {}) @param [Hash] params ({})
# File lib/aws-sdk-datasync/client.rb, line 561 def create_location_efs(params = {}, options = {}) req = build_request(:create_location_efs, params) req.send_request(options) end
Creates an endpoint for an Amazon FSx for Windows File Server file system.
@option params [String] :subdirectory
A subdirectory in the location’s path. This subdirectory in the Amazon FSx for Windows File Server file system is used to read data from the Amazon FSx for Windows File Server source location or write data to the FSx for Windows File Server destination.
@option params [required, String] :fsx_filesystem_arn
The Amazon Resource Name (ARN) for the FSx for Windows File Server file system.
@option params [required, Array<String>] :security_group_arns
The Amazon Resource Names (ARNs) of the security groups that are to use to configure the FSx for Windows File Server file system.
@option params [Array<Types::TagListEntry>] :tags
The key-value pair that represents a tag that you want to add to the resource. The value can be an empty string. This value helps you manage, filter, and search for your resources. We recommend that you create a name tag for your location.
@option params [required, String] :user
The user who has the permissions to access files and folders in the FSx for Windows File Server file system. For information about choosing a user name that ensures sufficient permissions to files, folders, and metadata, see [user](create-fsx-location.html#FSxWuser).
@option params [String] :domain
The name of the Windows domain that the FSx for Windows File Server belongs to.
@option params [required, String] :password
The password of the user who has the permissions to access files and folders in the FSx for Windows File Server file system.
@return [Types::CreateLocationFsxWindowsResponse] Returns a {Seahorse::Client::Response response} object which responds to the following methods:
* {Types::CreateLocationFsxWindowsResponse#location_arn #location_arn} => String
@example Request syntax with placeholder values
resp = client.create_location_fsx_windows({ subdirectory: "FsxWindowsSubdirectory", fsx_filesystem_arn: "FsxFilesystemArn", # required security_group_arns: ["Ec2SecurityGroupArn"], # required tags: [ { key: "TagKey", # required value: "TagValue", }, ], user: "SmbUser", # required domain: "SmbDomain", password: "SmbPassword", # required })
@example Response structure
resp.location_arn #=> String
@see docs.aws.amazon.com/goto/WebAPI/datasync-2018-11-09/CreateLocationFsxWindows AWS API Documentation
@overload create_location_fsx_windows
(params = {}) @param [Hash] params ({})
# File lib/aws-sdk-datasync/client.rb, line 634 def create_location_fsx_windows(params = {}, options = {}) req = build_request(:create_location_fsx_windows, params) req.send_request(options) end
Defines a file system on a Network File System (NFS) server that can be read from or written to.
@option params [required, String] :subdirectory
The subdirectory in the NFS file system that is used to read data from the NFS source location or write data to the NFS destination. The NFS path should be a path that's exported by the NFS server, or a subdirectory of that path. The path should be such that it can be mounted by other NFS clients in your network. To see all the paths exported by your NFS server, run "`showmount -e nfs-server-name`" from an NFS client that has access to your server. You can specify any directory that appears in the results, and any subdirectory of that directory. Ensure that the NFS export is accessible without Kerberos authentication. To transfer all the data in the folder you specified, DataSync needs to have permissions to read all the data. To ensure this, either configure the NFS export with `no_root_squash,` or ensure that the permissions for all of the files that you want DataSync allow read access for all users. Doing either enables the agent to read the files. For the agent to access directories, you must additionally enable all execute access. If you are copying data to or from your Snowcone device, see [NFS Server on Snowcone][1] for more information. For information about NFS export configuration, see 18.7. The /etc/exports Configuration File in the Red Hat Enterprise Linux documentation. [1]: https://docs.aws.amazon.com/datasync/latest/userguide/create-nfs-location.html#nfs-on-snowcone
@option params [required, String] :server_hostname
The name of the NFS server. This value is the IP address or Domain Name Service (DNS) name of the NFS server. An agent that is installed on-premises uses this host name to mount the NFS server in a network. If you are copying data to or from your Snowcone device, see [NFS Server on Snowcone][1] for more information. <note markdown="1"> This name must either be DNS-compliant or must be an IP version 4 (IPv4) address. </note> [1]: https://docs.aws.amazon.com/datasync/latest/userguide/create-nfs-location.html#nfs-on-snowcone
@option params [required, Types::OnPremConfig] :on_prem_config
Contains a list of Amazon Resource Names (ARNs) of agents that are used to connect to an NFS server. If you are copying data to or from your Snowcone device, see [NFS Server on Snowcone][1] for more information. [1]: https://docs.aws.amazon.com/datasync/latest/userguide/create-nfs-location.html#nfs-on-snowcone
@option params [Types::NfsMountOptions] :mount_options
The NFS mount options that DataSync can use to mount your NFS share.
@option params [Array<Types::TagListEntry>] :tags
The key-value pair that represents the tag that you want to add to the location. The value can be an empty string. We recommend using tags to name your resources.
@return [Types::CreateLocationNfsResponse] Returns a {Seahorse::Client::Response response} object which responds to the following methods:
* {Types::CreateLocationNfsResponse#location_arn #location_arn} => String
@example Request syntax with placeholder values
resp = client.create_location_nfs({ subdirectory: "NfsSubdirectory", # required server_hostname: "ServerHostname", # required on_prem_config: { # required agent_arns: ["AgentArn"], # required }, mount_options: { version: "AUTOMATIC", # accepts AUTOMATIC, NFS3, NFS4_0, NFS4_1 }, tags: [ { key: "TagKey", # required value: "TagValue", }, ], })
@example Response structure
resp.location_arn #=> String
@see docs.aws.amazon.com/goto/WebAPI/datasync-2018-11-09/CreateLocationNfs AWS API Documentation
@overload create_location_nfs
(params = {}) @param [Hash] params ({})
# File lib/aws-sdk-datasync/client.rb, line 741 def create_location_nfs(params = {}, options = {}) req = build_request(:create_location_nfs, params) req.send_request(options) end
Creates an endpoint for a self-managed object storage bucket. For more information about self-managed object storage locations, see [Creating a location for object storage].
[1]: docs.aws.amazon.com/datasync/latest/userguide/create-object-location.html
@option params [required, String] :server_hostname
The name of the self-managed object storage server. This value is the IP address or Domain Name Service (DNS) name of the object storage server. An agent uses this host name to mount the object storage server in a network.
@option params [Integer] :server_port
The port that your self-managed object storage server accepts inbound network traffic on. The server port is set by default to TCP 80 (HTTP) or TCP 443 (HTTPS). You can specify a custom port if your self-managed object storage server requires one.
@option params [String] :server_protocol
The protocol that the object storage server uses to communicate. Valid values are HTTP or HTTPS.
@option params [String] :subdirectory
The subdirectory in the self-managed object storage server that is used to read data from.
@option params [required, String] :bucket_name
The bucket on the self-managed object storage server that is used to read data from.
@option params [String] :access_key
Optional. The access key is used if credentials are required to access the self-managed object storage server. If your object storage requires a user name and password to authenticate, use `AccessKey` and `SecretKey` to provide the user name and password, respectively.
@option params [String] :secret_key
Optional. The secret key is used if credentials are required to access the self-managed object storage server. If your object storage requires a user name and password to authenticate, use `AccessKey` and `SecretKey` to provide the user name and password, respectively.
@option params [required, Array<String>] :agent_arns
The Amazon Resource Name (ARN) of the agents associated with the self-managed object storage server location.
@option params [Array<Types::TagListEntry>] :tags
The key-value pair that represents the tag that you want to add to the location. The value can be an empty string. We recommend using tags to name your resources.
@return [Types::CreateLocationObjectStorageResponse] Returns a {Seahorse::Client::Response response} object which responds to the following methods:
* {Types::CreateLocationObjectStorageResponse#location_arn #location_arn} => String
@example Request syntax with placeholder values
resp = client.create_location_object_storage({ server_hostname: "ServerHostname", # required server_port: 1, server_protocol: "HTTPS", # accepts HTTPS, HTTP subdirectory: "S3Subdirectory", bucket_name: "ObjectStorageBucketName", # required access_key: "ObjectStorageAccessKey", secret_key: "ObjectStorageSecretKey", agent_arns: ["AgentArn"], # required tags: [ { key: "TagKey", # required value: "TagValue", }, ], })
@example Response structure
resp.location_arn #=> String
@see docs.aws.amazon.com/goto/WebAPI/datasync-2018-11-09/CreateLocationObjectStorage AWS API Documentation
@overload create_location_object_storage
(params = {}) @param [Hash] params ({})
# File lib/aws-sdk-datasync/client.rb, line 830 def create_location_object_storage(params = {}, options = {}) req = build_request(:create_location_object_storage, params) req.send_request(options) end
Creates an endpoint for an Amazon S3 bucket.
For more information, see [Create an Amazon S3 location] in the *DataSync User Guide*.
[1]: docs.aws.amazon.com/datasync/latest/userguide/create-locations-cli.html#create-location-s3-cli
@option params [String] :subdirectory
A subdirectory in the Amazon S3 bucket. This subdirectory in Amazon S3 is used to read data from the S3 source location or write data to the S3 destination.
@option params [required, String] :s3_bucket_arn
The ARN of the Amazon S3 bucket. If the bucket is on an Amazon Web Services Outpost, this must be an access point ARN.
@option params [String] :s3_storage_class
The Amazon S3 storage class that you want to store your files in when this location is used as a task destination. For buckets in Amazon Web Services Regions, the storage class defaults to Standard. For buckets on Outposts, the storage class defaults to Amazon Web Services S3 Outposts. For more information about S3 storage classes, see [Amazon S3 Storage Classes][1]. Some storage classes have behaviors that can affect your S3 storage cost. For detailed information, see [Considerations when working with S3 storage classes in DataSync][2]. [1]: http://aws.amazon.com/s3/storage-classes/ [2]: https://docs.aws.amazon.com/datasync/latest/userguide/create-s3-location.html#using-storage-classes
@option params [required, Types::S3Config] :s3_config
The Amazon Resource Name (ARN) of the Identity and Access Management (IAM) role that is used to access an Amazon S3 bucket. For detailed information about using such a role, see Creating a Location for Amazon S3 in the *DataSync User Guide*.
@option params [Array<String>] :agent_arns
If you are using DataSync on an Amazon Web Services Outpost, specify the Amazon Resource Names (ARNs) of the DataSync agents deployed on your Outpost. For more information about launching a DataSync agent on an Amazon Web Services Outpost, see [Deploy your DataSync agent on Outposts][1]. [1]: https://docs.aws.amazon.com/datasync/latest/userguide/deploy-agents.html#outposts-agent
@option params [Array<Types::TagListEntry>] :tags
The key-value pair that represents the tag that you want to add to the location. The value can be an empty string. We recommend using tags to name your resources.
@return [Types::CreateLocationS3Response] Returns a {Seahorse::Client::Response response} object which responds to the following methods:
* {Types::CreateLocationS3Response#location_arn #location_arn} => String
@example Request syntax with placeholder values
resp = client.create_location_s3({ subdirectory: "S3Subdirectory", s3_bucket_arn: "S3BucketArn", # required s3_storage_class: "STANDARD", # accepts STANDARD, STANDARD_IA, ONEZONE_IA, INTELLIGENT_TIERING, GLACIER, DEEP_ARCHIVE, OUTPOSTS s3_config: { # required bucket_access_role_arn: "IamRoleArn", # required }, agent_arns: ["AgentArn"], tags: [ { key: "TagKey", # required value: "TagValue", }, ], })
@example Response structure
resp.location_arn #=> String
@see docs.aws.amazon.com/goto/WebAPI/datasync-2018-11-09/CreateLocationS3 AWS API Documentation
@overload create_location_s3
(params = {}) @param [Hash] params ({})
# File lib/aws-sdk-datasync/client.rb, line 923 def create_location_s3(params = {}, options = {}) req = build_request(:create_location_s3, params) req.send_request(options) end
Defines a file system on a Server Message Block (SMB) server that can be read from or written to.
@option params [required, String] :subdirectory
The subdirectory in the SMB file system that is used to read data from the SMB source location or write data to the SMB destination. The SMB path should be a path that's exported by the SMB server, or a subdirectory of that path. The path should be such that it can be mounted by other SMB clients in your network. <note markdown="1"> `Subdirectory` must be specified with forward slashes. For example, `/path/to/folder`. </note> To transfer all the data in the folder you specified, DataSync needs to have permissions to mount the SMB share, as well as to access all the data in that share. To ensure this, either ensure that the user/password specified belongs to the user who can mount the share, and who has the appropriate permissions for all of the files and directories that you want DataSync to access, or use credentials of a member of the Backup Operators group to mount the share. Doing either enables the agent to access the data. For the agent to access directories, you must additionally enable all execute access.
@option params [required, String] :server_hostname
The name of the SMB server. This value is the IP address or Domain Name Service (DNS) name of the SMB server. An agent that is installed on-premises uses this hostname to mount the SMB server in a network. <note markdown="1"> This name must either be DNS-compliant or must be an IP version 4 (IPv4) address. </note>
@option params [required, String] :user
The user who can mount the share, has the permissions to access files and folders in the SMB share. For information about choosing a user name that ensures sufficient permissions to files, folders, and metadata, see [user](create-smb-location.html#SMBuser).
@option params [String] :domain
The name of the Windows domain that the SMB server belongs to.
@option params [required, String] :password
The password of the user who can mount the share, has the permissions to access files and folders in the SMB share.
@option params [required, Array<String>] :agent_arns
The Amazon Resource Names (ARNs) of agents to use for a Simple Message Block (SMB) location.
@option params [Types::SmbMountOptions] :mount_options
The mount options used by DataSync to access the SMB server.
@option params [Array<Types::TagListEntry>] :tags
The key-value pair that represents the tag that you want to add to the location. The value can be an empty string. We recommend using tags to name your resources.
@return [Types::CreateLocationSmbResponse] Returns a {Seahorse::Client::Response response} object which responds to the following methods:
* {Types::CreateLocationSmbResponse#location_arn #location_arn} => String
@example Request syntax with placeholder values
resp = client.create_location_smb({ subdirectory: "SmbSubdirectory", # required server_hostname: "ServerHostname", # required user: "SmbUser", # required domain: "SmbDomain", password: "SmbPassword", # required agent_arns: ["AgentArn"], # required mount_options: { version: "AUTOMATIC", # accepts AUTOMATIC, SMB2, SMB3 }, tags: [ { key: "TagKey", # required value: "TagValue", }, ], })
@example Response structure
resp.location_arn #=> String
@see docs.aws.amazon.com/goto/WebAPI/datasync-2018-11-09/CreateLocationSmb AWS API Documentation
@overload create_location_smb
(params = {}) @param [Hash] params ({})
# File lib/aws-sdk-datasync/client.rb, line 1022 def create_location_smb(params = {}, options = {}) req = build_request(:create_location_smb, params) req.send_request(options) end
Creates a task.
A task includes a source location and a destination location, and a configuration that specifies how data is transferred. A task always transfers data from the source location to the destination location. The configuration specifies options such as task scheduling, bandwidth limits, etc. A task is the complete definition of a data transfer.
When you create a task that transfers data between Amazon Web Services services in different Amazon Web Services Regions, one of the two locations that you specify must reside in the Region where DataSync
is being used. The other location must be specified in a different Region.
You can transfer data between commercial Amazon Web Services Regions except for China, or between Amazon Web Services GovCloud (US) Regions.
When you use DataSync
to copy files or objects between Amazon Web Services Regions, you pay for data transfer between Regions. This is billed as data transfer OUT from your source Region to your destination Region. For more information, see [Data Transfer pricing].
[1]: aws.amazon.com/ec2/pricing/on-demand/#Data_Transfer
@option params [required, String] :source_location_arn
The Amazon Resource Name (ARN) of the source location for the task.
@option params [required, String] :destination_location_arn
The Amazon Resource Name (ARN) of an Amazon Web Services storage resource's location.
@option params [String] :cloud_watch_log_group_arn
The Amazon Resource Name (ARN) of the Amazon CloudWatch log group that is used to monitor and log events in the task.
@option params [String] :name
The name of a task. This value is a text reference that is used to identify the task in the console.
@option params [Types::Options] :options
The set of configuration options that control the behavior of a single execution of the task that occurs when you call `StartTaskExecution`. You can configure these options to preserve metadata such as user ID (UID) and group ID (GID), file permissions, data integrity verification, and so on. For each individual task execution, you can override these options by specifying the `OverrideOptions` before starting the task execution. For more information, see the [StartTaskExecution][1] operation. [1]: https://docs.aws.amazon.com/datasync/latest/userguide/API_StartTaskExecution.html
@option params [Array<Types::FilterRule>] :excludes
A list of filter rules that determines which files to exclude from a task. The list should contain a single filter string that consists of the patterns to exclude. The patterns are delimited by "\|" (that is, a pipe), for example, `"/folder1|/folder2"`.
@option params [Types::TaskSchedule] :schedule
Specifies a schedule used to periodically transfer files from a source to a destination location. The schedule should be specified in UTC time. For more information, see [Scheduling your task][1]. [1]: https://docs.aws.amazon.com/datasync/latest/userguide/task-scheduling.html
@option params [Array<Types::TagListEntry>] :tags
The key-value pair that represents the tag that you want to add to the resource. The value can be an empty string.
@option params [Array<Types::FilterRule>] :includes
A list of filter rules that determines which files to include when running a task. The pattern should contain a single filter string that consists of the patterns to include. The patterns are delimited by "\|" (that is, a pipe). For example: `"/folder1|/folder2`"
@return [Types::CreateTaskResponse] Returns a {Seahorse::Client::Response response} object which responds to the following methods:
* {Types::CreateTaskResponse#task_arn #task_arn} => String
@example Request syntax with placeholder values
resp = client.create_task({ source_location_arn: "LocationArn", # required destination_location_arn: "LocationArn", # required cloud_watch_log_group_arn: "LogGroupArn", name: "TagValue", options: { verify_mode: "POINT_IN_TIME_CONSISTENT", # accepts POINT_IN_TIME_CONSISTENT, ONLY_FILES_TRANSFERRED, NONE overwrite_mode: "ALWAYS", # accepts ALWAYS, NEVER atime: "NONE", # accepts NONE, BEST_EFFORT mtime: "NONE", # accepts NONE, PRESERVE uid: "NONE", # accepts NONE, INT_VALUE, NAME, BOTH gid: "NONE", # accepts NONE, INT_VALUE, NAME, BOTH preserve_deleted_files: "PRESERVE", # accepts PRESERVE, REMOVE preserve_devices: "NONE", # accepts NONE, PRESERVE posix_permissions: "NONE", # accepts NONE, PRESERVE bytes_per_second: 1, task_queueing: "ENABLED", # accepts ENABLED, DISABLED log_level: "OFF", # accepts OFF, BASIC, TRANSFER transfer_mode: "CHANGED", # accepts CHANGED, ALL security_descriptor_copy_flags: "NONE", # accepts NONE, OWNER_DACL, OWNER_DACL_SACL }, excludes: [ { filter_type: "SIMPLE_PATTERN", # accepts SIMPLE_PATTERN value: "FilterValue", }, ], schedule: { schedule_expression: "ScheduleExpressionCron", # required }, tags: [ { key: "TagKey", # required value: "TagValue", }, ], includes: [ { filter_type: "SIMPLE_PATTERN", # accepts SIMPLE_PATTERN value: "FilterValue", }, ], })
@example Response structure
resp.task_arn #=> String
@see docs.aws.amazon.com/goto/WebAPI/datasync-2018-11-09/CreateTask AWS API Documentation
@overload create_task
(params = {}) @param [Hash] params ({})
# File lib/aws-sdk-datasync/client.rb, line 1168 def create_task(params = {}, options = {}) req = build_request(:create_task, params) req.send_request(options) end
Deletes an agent. To specify which agent to delete, use the Amazon Resource
Name (ARN) of the agent in your request. The operation disassociates the agent from your Amazon Web Services account. However, it doesn't delete the agent virtual machine (VM) from your on-premises environment.
@option params [required, String] :agent_arn
The Amazon Resource Name (ARN) of the agent to delete. Use the `ListAgents` operation to return a list of agents for your account and Amazon Web Services Region.
@return [Struct] Returns an empty {Seahorse::Client::Response response}.
@example Request syntax with placeholder values
resp = client.delete_agent({ agent_arn: "AgentArn", # required })
@see docs.aws.amazon.com/goto/WebAPI/datasync-2018-11-09/DeleteAgent AWS API Documentation
@overload delete_agent
(params = {}) @param [Hash] params ({})
# File lib/aws-sdk-datasync/client.rb, line 1196 def delete_agent(params = {}, options = {}) req = build_request(:delete_agent, params) req.send_request(options) end
Deletes the configuration of a location used by DataSync
.
@option params [required, String] :location_arn
The Amazon Resource Name (ARN) of the location to delete.
@return [Struct] Returns an empty {Seahorse::Client::Response response}.
@example Request syntax with placeholder values
resp = client.delete_location({ location_arn: "LocationArn", # required })
@see docs.aws.amazon.com/goto/WebAPI/datasync-2018-11-09/DeleteLocation AWS API Documentation
@overload delete_location
(params = {}) @param [Hash] params ({})
# File lib/aws-sdk-datasync/client.rb, line 1218 def delete_location(params = {}, options = {}) req = build_request(:delete_location, params) req.send_request(options) end
Deletes a task.
@option params [required, String] :task_arn
The Amazon Resource Name (ARN) of the task to delete.
@return [Struct] Returns an empty {Seahorse::Client::Response response}.
@example Request syntax with placeholder values
resp = client.delete_task({ task_arn: "TaskArn", # required })
@see docs.aws.amazon.com/goto/WebAPI/datasync-2018-11-09/DeleteTask AWS API Documentation
@overload delete_task
(params = {}) @param [Hash] params ({})
# File lib/aws-sdk-datasync/client.rb, line 1240 def delete_task(params = {}, options = {}) req = build_request(:delete_task, params) req.send_request(options) end
Returns metadata such as the name, the network interfaces, and the status (that is, whether the agent is running or not) for an agent. To specify which agent to describe, use the Amazon Resource
Name (ARN) of the agent in your request.
@option params [required, String] :agent_arn
The Amazon Resource Name (ARN) of the agent to describe.
@return [Types::DescribeAgentResponse] Returns a {Seahorse::Client::Response response} object which responds to the following methods:
* {Types::DescribeAgentResponse#agent_arn #agent_arn} => String * {Types::DescribeAgentResponse#name #name} => String * {Types::DescribeAgentResponse#status #status} => String * {Types::DescribeAgentResponse#last_connection_time #last_connection_time} => Time * {Types::DescribeAgentResponse#creation_time #creation_time} => Time * {Types::DescribeAgentResponse#endpoint_type #endpoint_type} => String * {Types::DescribeAgentResponse#private_link_config #private_link_config} => Types::PrivateLinkConfig
@example Request syntax with placeholder values
resp = client.describe_agent({ agent_arn: "AgentArn", # required })
@example Response structure
resp.agent_arn #=> String resp.name #=> String resp.status #=> String, one of "ONLINE", "OFFLINE" resp.last_connection_time #=> Time resp.creation_time #=> Time resp.endpoint_type #=> String, one of "PUBLIC", "PRIVATE_LINK", "FIPS" resp.private_link_config.vpc_endpoint_id #=> String resp.private_link_config.private_link_endpoint #=> String resp.private_link_config.subnet_arns #=> Array resp.private_link_config.subnet_arns[0] #=> String resp.private_link_config.security_group_arns #=> Array resp.private_link_config.security_group_arns[0] #=> String
@see docs.aws.amazon.com/goto/WebAPI/datasync-2018-11-09/DescribeAgent AWS API Documentation
@overload describe_agent
(params = {}) @param [Hash] params ({})
# File lib/aws-sdk-datasync/client.rb, line 1288 def describe_agent(params = {}, options = {}) req = build_request(:describe_agent, params) req.send_request(options) end
Returns metadata, such as the path information about an Amazon EFS location.
@option params [required, String] :location_arn
The Amazon Resource Name (ARN) of the EFS location to describe.
@return [Types::DescribeLocationEfsResponse] Returns a {Seahorse::Client::Response response} object which responds to the following methods:
* {Types::DescribeLocationEfsResponse#location_arn #location_arn} => String * {Types::DescribeLocationEfsResponse#location_uri #location_uri} => String * {Types::DescribeLocationEfsResponse#ec2_config #ec2_config} => Types::Ec2Config * {Types::DescribeLocationEfsResponse#creation_time #creation_time} => Time
@example Request syntax with placeholder values
resp = client.describe_location_efs({ location_arn: "LocationArn", # required })
@example Response structure
resp.location_arn #=> String resp.location_uri #=> String resp.ec2_config.subnet_arn #=> String resp.ec2_config.security_group_arns #=> Array resp.ec2_config.security_group_arns[0] #=> String resp.creation_time #=> Time
@see docs.aws.amazon.com/goto/WebAPI/datasync-2018-11-09/DescribeLocationEfs AWS API Documentation
@overload describe_location_efs
(params = {}) @param [Hash] params ({})
# File lib/aws-sdk-datasync/client.rb, line 1325 def describe_location_efs(params = {}, options = {}) req = build_request(:describe_location_efs, params) req.send_request(options) end
Returns metadata, such as the path information about an Amazon FSx for Windows File Server location.
@option params [required, String] :location_arn
The Amazon Resource Name (ARN) of the FSx for Windows File Server location to describe.
@return [Types::DescribeLocationFsxWindowsResponse] Returns a {Seahorse::Client::Response response} object which responds to the following methods:
* {Types::DescribeLocationFsxWindowsResponse#location_arn #location_arn} => String * {Types::DescribeLocationFsxWindowsResponse#location_uri #location_uri} => String * {Types::DescribeLocationFsxWindowsResponse#security_group_arns #security_group_arns} => Array<String> * {Types::DescribeLocationFsxWindowsResponse#creation_time #creation_time} => Time * {Types::DescribeLocationFsxWindowsResponse#user #user} => String * {Types::DescribeLocationFsxWindowsResponse#domain #domain} => String
@example Request syntax with placeholder values
resp = client.describe_location_fsx_windows({ location_arn: "LocationArn", # required })
@example Response structure
resp.location_arn #=> String resp.location_uri #=> String resp.security_group_arns #=> Array resp.security_group_arns[0] #=> String resp.creation_time #=> Time resp.user #=> String resp.domain #=> String
@see docs.aws.amazon.com/goto/WebAPI/datasync-2018-11-09/DescribeLocationFsxWindows AWS API Documentation
@overload describe_location_fsx_windows
(params = {}) @param [Hash] params ({})
# File lib/aws-sdk-datasync/client.rb, line 1366 def describe_location_fsx_windows(params = {}, options = {}) req = build_request(:describe_location_fsx_windows, params) req.send_request(options) end
Returns metadata, such as the path information, about an NFS location.
@option params [required, String] :location_arn
The Amazon Resource Name (ARN) of the NFS location to describe.
@return [Types::DescribeLocationNfsResponse] Returns a {Seahorse::Client::Response response} object which responds to the following methods:
* {Types::DescribeLocationNfsResponse#location_arn #location_arn} => String * {Types::DescribeLocationNfsResponse#location_uri #location_uri} => String * {Types::DescribeLocationNfsResponse#on_prem_config #on_prem_config} => Types::OnPremConfig * {Types::DescribeLocationNfsResponse#mount_options #mount_options} => Types::NfsMountOptions * {Types::DescribeLocationNfsResponse#creation_time #creation_time} => Time
@example Request syntax with placeholder values
resp = client.describe_location_nfs({ location_arn: "LocationArn", # required })
@example Response structure
resp.location_arn #=> String resp.location_uri #=> String resp.on_prem_config.agent_arns #=> Array resp.on_prem_config.agent_arns[0] #=> String resp.mount_options.version #=> String, one of "AUTOMATIC", "NFS3", "NFS4_0", "NFS4_1" resp.creation_time #=> Time
@see docs.aws.amazon.com/goto/WebAPI/datasync-2018-11-09/DescribeLocationNfs AWS API Documentation
@overload describe_location_nfs
(params = {}) @param [Hash] params ({})
# File lib/aws-sdk-datasync/client.rb, line 1403 def describe_location_nfs(params = {}, options = {}) req = build_request(:describe_location_nfs, params) req.send_request(options) end
Returns metadata about a self-managed object storage server location. For more information about self-managed object storage locations, see [Creating a location for object storage].
[1]: docs.aws.amazon.com/datasync/latest/userguide/create-object-location.html
@option params [required, String] :location_arn
The Amazon Resource Name (ARN) of the self-managed object storage server location that was described.
@return [Types::DescribeLocationObjectStorageResponse] Returns a {Seahorse::Client::Response response} object which responds to the following methods:
* {Types::DescribeLocationObjectStorageResponse#location_arn #location_arn} => String * {Types::DescribeLocationObjectStorageResponse#location_uri #location_uri} => String * {Types::DescribeLocationObjectStorageResponse#access_key #access_key} => String * {Types::DescribeLocationObjectStorageResponse#server_port #server_port} => Integer * {Types::DescribeLocationObjectStorageResponse#server_protocol #server_protocol} => String * {Types::DescribeLocationObjectStorageResponse#agent_arns #agent_arns} => Array<String> * {Types::DescribeLocationObjectStorageResponse#creation_time #creation_time} => Time
@example Request syntax with placeholder values
resp = client.describe_location_object_storage({ location_arn: "LocationArn", # required })
@example Response structure
resp.location_arn #=> String resp.location_uri #=> String resp.access_key #=> String resp.server_port #=> Integer resp.server_protocol #=> String, one of "HTTPS", "HTTP" resp.agent_arns #=> Array resp.agent_arns[0] #=> String resp.creation_time #=> Time
@see docs.aws.amazon.com/goto/WebAPI/datasync-2018-11-09/DescribeLocationObjectStorage AWS API Documentation
@overload describe_location_object_storage
(params = {}) @param [Hash] params ({})
# File lib/aws-sdk-datasync/client.rb, line 1451 def describe_location_object_storage(params = {}, options = {}) req = build_request(:describe_location_object_storage, params) req.send_request(options) end
Returns metadata, such as bucket name, about an Amazon S3 bucket location.
@option params [required, String] :location_arn
The Amazon Resource Name (ARN) of the Amazon S3 bucket location to describe.
@return [Types::DescribeLocationS3Response] Returns a {Seahorse::Client::Response response} object which responds to the following methods:
* {Types::DescribeLocationS3Response#location_arn #location_arn} => String * {Types::DescribeLocationS3Response#location_uri #location_uri} => String * {Types::DescribeLocationS3Response#s3_storage_class #s3_storage_class} => String * {Types::DescribeLocationS3Response#s3_config #s3_config} => Types::S3Config * {Types::DescribeLocationS3Response#agent_arns #agent_arns} => Array<String> * {Types::DescribeLocationS3Response#creation_time #creation_time} => Time
@example Request syntax with placeholder values
resp = client.describe_location_s3({ location_arn: "LocationArn", # required })
@example Response structure
resp.location_arn #=> String resp.location_uri #=> String resp.s3_storage_class #=> String, one of "STANDARD", "STANDARD_IA", "ONEZONE_IA", "INTELLIGENT_TIERING", "GLACIER", "DEEP_ARCHIVE", "OUTPOSTS" resp.s3_config.bucket_access_role_arn #=> String resp.agent_arns #=> Array resp.agent_arns[0] #=> String resp.creation_time #=> Time
@see docs.aws.amazon.com/goto/WebAPI/datasync-2018-11-09/DescribeLocationS3 AWS API Documentation
@overload describe_location_s3
(params = {}) @param [Hash] params ({})
# File lib/aws-sdk-datasync/client.rb, line 1492 def describe_location_s3(params = {}, options = {}) req = build_request(:describe_location_s3, params) req.send_request(options) end
Returns metadata, such as the path and user information about an SMB location.
@option params [required, String] :location_arn
The Amazon Resource Name (ARN) of the SMB location to describe.
@return [Types::DescribeLocationSmbResponse] Returns a {Seahorse::Client::Response response} object which responds to the following methods:
* {Types::DescribeLocationSmbResponse#location_arn #location_arn} => String * {Types::DescribeLocationSmbResponse#location_uri #location_uri} => String * {Types::DescribeLocationSmbResponse#agent_arns #agent_arns} => Array<String> * {Types::DescribeLocationSmbResponse#user #user} => String * {Types::DescribeLocationSmbResponse#domain #domain} => String * {Types::DescribeLocationSmbResponse#mount_options #mount_options} => Types::SmbMountOptions * {Types::DescribeLocationSmbResponse#creation_time #creation_time} => Time
@example Request syntax with placeholder values
resp = client.describe_location_smb({ location_arn: "LocationArn", # required })
@example Response structure
resp.location_arn #=> String resp.location_uri #=> String resp.agent_arns #=> Array resp.agent_arns[0] #=> String resp.user #=> String resp.domain #=> String resp.mount_options.version #=> String, one of "AUTOMATIC", "SMB2", "SMB3" resp.creation_time #=> Time
@see docs.aws.amazon.com/goto/WebAPI/datasync-2018-11-09/DescribeLocationSmb AWS API Documentation
@overload describe_location_smb
(params = {}) @param [Hash] params ({})
# File lib/aws-sdk-datasync/client.rb, line 1534 def describe_location_smb(params = {}, options = {}) req = build_request(:describe_location_smb, params) req.send_request(options) end
Returns metadata about a task.
@option params [required, String] :task_arn
The Amazon Resource Name (ARN) of the task to describe.
@return [Types::DescribeTaskResponse] Returns a {Seahorse::Client::Response response} object which responds to the following methods:
* {Types::DescribeTaskResponse#task_arn #task_arn} => String * {Types::DescribeTaskResponse#status #status} => String * {Types::DescribeTaskResponse#name #name} => String * {Types::DescribeTaskResponse#current_task_execution_arn #current_task_execution_arn} => String * {Types::DescribeTaskResponse#source_location_arn #source_location_arn} => String * {Types::DescribeTaskResponse#destination_location_arn #destination_location_arn} => String * {Types::DescribeTaskResponse#cloud_watch_log_group_arn #cloud_watch_log_group_arn} => String * {Types::DescribeTaskResponse#source_network_interface_arns #source_network_interface_arns} => Array<String> * {Types::DescribeTaskResponse#destination_network_interface_arns #destination_network_interface_arns} => Array<String> * {Types::DescribeTaskResponse#options #options} => Types::Options * {Types::DescribeTaskResponse#excludes #excludes} => Array<Types::FilterRule> * {Types::DescribeTaskResponse#schedule #schedule} => Types::TaskSchedule * {Types::DescribeTaskResponse#error_code #error_code} => String * {Types::DescribeTaskResponse#error_detail #error_detail} => String * {Types::DescribeTaskResponse#creation_time #creation_time} => Time * {Types::DescribeTaskResponse#includes #includes} => Array<Types::FilterRule>
@example Request syntax with placeholder values
resp = client.describe_task({ task_arn: "TaskArn", # required })
@example Response structure
resp.task_arn #=> String resp.status #=> String, one of "AVAILABLE", "CREATING", "QUEUED", "RUNNING", "UNAVAILABLE" resp.name #=> String resp.current_task_execution_arn #=> String resp.source_location_arn #=> String resp.destination_location_arn #=> String resp.cloud_watch_log_group_arn #=> String resp.source_network_interface_arns #=> Array resp.source_network_interface_arns[0] #=> String resp.destination_network_interface_arns #=> Array resp.destination_network_interface_arns[0] #=> String resp.options.verify_mode #=> String, one of "POINT_IN_TIME_CONSISTENT", "ONLY_FILES_TRANSFERRED", "NONE" resp.options.overwrite_mode #=> String, one of "ALWAYS", "NEVER" resp.options.atime #=> String, one of "NONE", "BEST_EFFORT" resp.options.mtime #=> String, one of "NONE", "PRESERVE" resp.options.uid #=> String, one of "NONE", "INT_VALUE", "NAME", "BOTH" resp.options.gid #=> String, one of "NONE", "INT_VALUE", "NAME", "BOTH" resp.options.preserve_deleted_files #=> String, one of "PRESERVE", "REMOVE" resp.options.preserve_devices #=> String, one of "NONE", "PRESERVE" resp.options.posix_permissions #=> String, one of "NONE", "PRESERVE" resp.options.bytes_per_second #=> Integer resp.options.task_queueing #=> String, one of "ENABLED", "DISABLED" resp.options.log_level #=> String, one of "OFF", "BASIC", "TRANSFER" resp.options.transfer_mode #=> String, one of "CHANGED", "ALL" resp.options.security_descriptor_copy_flags #=> String, one of "NONE", "OWNER_DACL", "OWNER_DACL_SACL" resp.excludes #=> Array resp.excludes[0].filter_type #=> String, one of "SIMPLE_PATTERN" resp.excludes[0].value #=> String resp.schedule.schedule_expression #=> String resp.error_code #=> String resp.error_detail #=> String resp.creation_time #=> Time resp.includes #=> Array resp.includes[0].filter_type #=> String, one of "SIMPLE_PATTERN" resp.includes[0].value #=> String
@see docs.aws.amazon.com/goto/WebAPI/datasync-2018-11-09/DescribeTask AWS API Documentation
@overload describe_task
(params = {}) @param [Hash] params ({})
# File lib/aws-sdk-datasync/client.rb, line 1611 def describe_task(params = {}, options = {}) req = build_request(:describe_task, params) req.send_request(options) end
Returns detailed metadata about a task that is being executed.
@option params [required, String] :task_execution_arn
The Amazon Resource Name (ARN) of the task that is being executed.
@return [Types::DescribeTaskExecutionResponse] Returns a {Seahorse::Client::Response response} object which responds to the following methods:
* {Types::DescribeTaskExecutionResponse#task_execution_arn #task_execution_arn} => String * {Types::DescribeTaskExecutionResponse#status #status} => String * {Types::DescribeTaskExecutionResponse#options #options} => Types::Options * {Types::DescribeTaskExecutionResponse#excludes #excludes} => Array<Types::FilterRule> * {Types::DescribeTaskExecutionResponse#includes #includes} => Array<Types::FilterRule> * {Types::DescribeTaskExecutionResponse#start_time #start_time} => Time * {Types::DescribeTaskExecutionResponse#estimated_files_to_transfer #estimated_files_to_transfer} => Integer * {Types::DescribeTaskExecutionResponse#estimated_bytes_to_transfer #estimated_bytes_to_transfer} => Integer * {Types::DescribeTaskExecutionResponse#files_transferred #files_transferred} => Integer * {Types::DescribeTaskExecutionResponse#bytes_written #bytes_written} => Integer * {Types::DescribeTaskExecutionResponse#bytes_transferred #bytes_transferred} => Integer * {Types::DescribeTaskExecutionResponse#result #result} => Types::TaskExecutionResultDetail
@example Request syntax with placeholder values
resp = client.describe_task_execution({ task_execution_arn: "TaskExecutionArn", # required })
@example Response structure
resp.task_execution_arn #=> String resp.status #=> String, one of "QUEUED", "LAUNCHING", "PREPARING", "TRANSFERRING", "VERIFYING", "SUCCESS", "ERROR" resp.options.verify_mode #=> String, one of "POINT_IN_TIME_CONSISTENT", "ONLY_FILES_TRANSFERRED", "NONE" resp.options.overwrite_mode #=> String, one of "ALWAYS", "NEVER" resp.options.atime #=> String, one of "NONE", "BEST_EFFORT" resp.options.mtime #=> String, one of "NONE", "PRESERVE" resp.options.uid #=> String, one of "NONE", "INT_VALUE", "NAME", "BOTH" resp.options.gid #=> String, one of "NONE", "INT_VALUE", "NAME", "BOTH" resp.options.preserve_deleted_files #=> String, one of "PRESERVE", "REMOVE" resp.options.preserve_devices #=> String, one of "NONE", "PRESERVE" resp.options.posix_permissions #=> String, one of "NONE", "PRESERVE" resp.options.bytes_per_second #=> Integer resp.options.task_queueing #=> String, one of "ENABLED", "DISABLED" resp.options.log_level #=> String, one of "OFF", "BASIC", "TRANSFER" resp.options.transfer_mode #=> String, one of "CHANGED", "ALL" resp.options.security_descriptor_copy_flags #=> String, one of "NONE", "OWNER_DACL", "OWNER_DACL_SACL" resp.excludes #=> Array resp.excludes[0].filter_type #=> String, one of "SIMPLE_PATTERN" resp.excludes[0].value #=> String resp.includes #=> Array resp.includes[0].filter_type #=> String, one of "SIMPLE_PATTERN" resp.includes[0].value #=> String resp.start_time #=> Time resp.estimated_files_to_transfer #=> Integer resp.estimated_bytes_to_transfer #=> Integer resp.files_transferred #=> Integer resp.bytes_written #=> Integer resp.bytes_transferred #=> Integer resp.result.prepare_duration #=> Integer resp.result.prepare_status #=> String, one of "PENDING", "SUCCESS", "ERROR" resp.result.total_duration #=> Integer resp.result.transfer_duration #=> Integer resp.result.transfer_status #=> String, one of "PENDING", "SUCCESS", "ERROR" resp.result.verify_duration #=> Integer resp.result.verify_status #=> String, one of "PENDING", "SUCCESS", "ERROR" resp.result.error_code #=> String resp.result.error_detail #=> String
@see docs.aws.amazon.com/goto/WebAPI/datasync-2018-11-09/DescribeTaskExecution AWS API Documentation
@overload describe_task_execution
(params = {}) @param [Hash] params ({})
# File lib/aws-sdk-datasync/client.rb, line 1686 def describe_task_execution(params = {}, options = {}) req = build_request(:describe_task_execution, params) req.send_request(options) end
Returns a list of agents owned by an Amazon Web Services account in the Amazon Web Services Region specified in the request. The returned list is ordered by agent Amazon Resource
Name (ARN).
By default, this operation returns a maximum of 100 agents. This operation supports pagination that enables you to optionally reduce the number of agents returned in a response.
If you have more agents than are returned in a response (that is, the response returns only a truncated list of your agents), the response contains a marker that you can specify in your next request to fetch the next page of agents.
@option params [Integer] :max_results
The maximum number of agents to list.
@option params [String] :next_token
An opaque string that indicates the position at which to begin the next list of agents.
@return [Types::ListAgentsResponse] Returns a {Seahorse::Client::Response response} object which responds to the following methods:
* {Types::ListAgentsResponse#agents #agents} => Array<Types::AgentListEntry> * {Types::ListAgentsResponse#next_token #next_token} => String
The returned {Seahorse::Client::Response response} is a pageable response and is Enumerable. For details on usage see {Aws::PageableResponse PageableResponse}.
@example Request syntax with placeholder values
resp = client.list_agents({ max_results: 1, next_token: "NextToken", })
@example Response structure
resp.agents #=> Array resp.agents[0].agent_arn #=> String resp.agents[0].name #=> String resp.agents[0].status #=> String, one of "ONLINE", "OFFLINE" resp.next_token #=> String
@see docs.aws.amazon.com/goto/WebAPI/datasync-2018-11-09/ListAgents AWS API Documentation
@overload list_agents
(params = {}) @param [Hash] params ({})
# File lib/aws-sdk-datasync/client.rb, line 1737 def list_agents(params = {}, options = {}) req = build_request(:list_agents, params) req.send_request(options) end
Returns a list of source and destination locations.
If you have more locations than are returned in a response (that is, the response returns only a truncated list of your agents), the response contains a token that you can specify in your next request to fetch the next page of locations.
@option params [Integer] :max_results
The maximum number of locations to return.
@option params [String] :next_token
An opaque string that indicates the position at which to begin the next list of locations.
@option params [Array<Types::LocationFilter>] :filters
You can use API filters to narrow down the list of resources returned by `ListLocations`. For example, to retrieve all tasks on a specific source location, you can use `ListLocations` with filter name `LocationType S3` and `Operator Equals`.
@return [Types::ListLocationsResponse] Returns a {Seahorse::Client::Response response} object which responds to the following methods:
* {Types::ListLocationsResponse#locations #locations} => Array<Types::LocationListEntry> * {Types::ListLocationsResponse#next_token #next_token} => String
The returned {Seahorse::Client::Response response} is a pageable response and is Enumerable. For details on usage see {Aws::PageableResponse PageableResponse}.
@example Request syntax with placeholder values
resp = client.list_locations({ max_results: 1, next_token: "NextToken", filters: [ { name: "LocationUri", # required, accepts LocationUri, LocationType, CreationTime values: ["FilterAttributeValue"], # required operator: "Equals", # required, accepts Equals, NotEquals, In, LessThanOrEqual, LessThan, GreaterThanOrEqual, GreaterThan, Contains, NotContains, BeginsWith }, ], })
@example Response structure
resp.locations #=> Array resp.locations[0].location_arn #=> String resp.locations[0].location_uri #=> String resp.next_token #=> String
@see docs.aws.amazon.com/goto/WebAPI/datasync-2018-11-09/ListLocations AWS API Documentation
@overload list_locations
(params = {}) @param [Hash] params ({})
# File lib/aws-sdk-datasync/client.rb, line 1794 def list_locations(params = {}, options = {}) req = build_request(:list_locations, params) req.send_request(options) end
Returns a list of executed tasks.
@option params [String] :task_arn
The Amazon Resource Name (ARN) of the task whose tasks you want to list.
@option params [Integer] :max_results
The maximum number of executed tasks to list.
@option params [String] :next_token
An opaque string that indicates the position at which to begin the next list of the executed tasks.
@return [Types::ListTaskExecutionsResponse] Returns a {Seahorse::Client::Response response} object which responds to the following methods:
* {Types::ListTaskExecutionsResponse#task_executions #task_executions} => Array<Types::TaskExecutionListEntry> * {Types::ListTaskExecutionsResponse#next_token #next_token} => String
The returned {Seahorse::Client::Response response} is a pageable response and is Enumerable. For details on usage see {Aws::PageableResponse PageableResponse}.
@example Request syntax with placeholder values
resp = client.list_task_executions({ task_arn: "TaskArn", max_results: 1, next_token: "NextToken", })
@example Response structure
resp.task_executions #=> Array resp.task_executions[0].task_execution_arn #=> String resp.task_executions[0].status #=> String, one of "QUEUED", "LAUNCHING", "PREPARING", "TRANSFERRING", "VERIFYING", "SUCCESS", "ERROR" resp.next_token #=> String
@see docs.aws.amazon.com/goto/WebAPI/datasync-2018-11-09/ListTaskExecutions AWS API Documentation
@overload list_task_executions
(params = {}) @param [Hash] params ({})
# File lib/aws-sdk-datasync/client.rb, line 1881 def list_task_executions(params = {}, options = {}) req = build_request(:list_task_executions, params) req.send_request(options) end
Returns a list of all the tasks.
@option params [Integer] :max_results
The maximum number of tasks to return.
@option params [String] :next_token
An opaque string that indicates the position at which to begin the next list of tasks.
@option params [Array<Types::TaskFilter>] :filters
You can use API filters to narrow down the list of resources returned by `ListTasks`. For example, to retrieve all tasks on a specific source location, you can use `ListTasks` with filter name `LocationId` and `Operator Equals` with the ARN for the location.
@return [Types::ListTasksResponse] Returns a {Seahorse::Client::Response response} object which responds to the following methods:
* {Types::ListTasksResponse#tasks #tasks} => Array<Types::TaskListEntry> * {Types::ListTasksResponse#next_token #next_token} => String
The returned {Seahorse::Client::Response response} is a pageable response and is Enumerable. For details on usage see {Aws::PageableResponse PageableResponse}.
@example Request syntax with placeholder values
resp = client.list_tasks({ max_results: 1, next_token: "NextToken", filters: [ { name: "LocationId", # required, accepts LocationId, CreationTime values: ["FilterAttributeValue"], # required operator: "Equals", # required, accepts Equals, NotEquals, In, LessThanOrEqual, LessThan, GreaterThanOrEqual, GreaterThan, Contains, NotContains, BeginsWith }, ], })
@example Response structure
resp.tasks #=> Array resp.tasks[0].task_arn #=> String resp.tasks[0].status #=> String, one of "AVAILABLE", "CREATING", "QUEUED", "RUNNING", "UNAVAILABLE" resp.tasks[0].name #=> String resp.next_token #=> String
@see docs.aws.amazon.com/goto/WebAPI/datasync-2018-11-09/ListTasks AWS API Documentation
@overload list_tasks
(params = {}) @param [Hash] params ({})
# File lib/aws-sdk-datasync/client.rb, line 1934 def list_tasks(params = {}, options = {}) req = build_request(:list_tasks, params) req.send_request(options) end
Starts a specific invocation of a task. A `TaskExecution` value represents an individual run of a task. Each task can have at most one `TaskExecution` at a time.
`TaskExecution` has the following transition phases: INITIALIZING | PREPARING | TRANSFERRING | VERIFYING | SUCCESS/FAILURE.
For detailed information, see the Task Execution section in the Components and Terminology topic in the *DataSync User Guide*.
@option params [required, String] :task_arn
The Amazon Resource Name (ARN) of the task to start.
@option params [Types::Options] :override_options
Represents the options that are available to control the behavior of a [StartTaskExecution][1] operation. Behavior includes preserving metadata such as user ID (UID), group ID (GID), and file permissions, and also overwriting files in the destination, data integrity verification, and so on. A task has a set of default options associated with it. If you don't specify an option in [StartTaskExecution][1], the default value is used. You can override the defaults options on each task execution by specifying an overriding `Options` value to [StartTaskExecution][1]. [1]: https://docs.aws.amazon.com/datasync/latest/userguide/API_StartTaskExecution.html
@option params [Array<Types::FilterRule>] :includes
A list of filter rules that determines which files to include when running a task. The pattern should contain a single filter string that consists of the patterns to include. The patterns are delimited by "\|" (that is, a pipe). For example: `"/folder1|/folder2"`
@option params [Array<Types::FilterRule>] :excludes
A list of filter rules that determines which files to exclude from a task. The list should contain a single filter string that consists of the patterns to exclude. The patterns are delimited by "\|" (that is, a pipe), for example, `"/folder1|/folder2"`.
@return [Types::StartTaskExecutionResponse] Returns a {Seahorse::Client::Response response} object which responds to the following methods:
* {Types::StartTaskExecutionResponse#task_execution_arn #task_execution_arn} => String
@example Request syntax with placeholder values
resp = client.start_task_execution({ task_arn: "TaskArn", # required override_options: { verify_mode: "POINT_IN_TIME_CONSISTENT", # accepts POINT_IN_TIME_CONSISTENT, ONLY_FILES_TRANSFERRED, NONE overwrite_mode: "ALWAYS", # accepts ALWAYS, NEVER atime: "NONE", # accepts NONE, BEST_EFFORT mtime: "NONE", # accepts NONE, PRESERVE uid: "NONE", # accepts NONE, INT_VALUE, NAME, BOTH gid: "NONE", # accepts NONE, INT_VALUE, NAME, BOTH preserve_deleted_files: "PRESERVE", # accepts PRESERVE, REMOVE preserve_devices: "NONE", # accepts NONE, PRESERVE posix_permissions: "NONE", # accepts NONE, PRESERVE bytes_per_second: 1, task_queueing: "ENABLED", # accepts ENABLED, DISABLED log_level: "OFF", # accepts OFF, BASIC, TRANSFER transfer_mode: "CHANGED", # accepts CHANGED, ALL security_descriptor_copy_flags: "NONE", # accepts NONE, OWNER_DACL, OWNER_DACL_SACL }, includes: [ { filter_type: "SIMPLE_PATTERN", # accepts SIMPLE_PATTERN value: "FilterValue", }, ], excludes: [ { filter_type: "SIMPLE_PATTERN", # accepts SIMPLE_PATTERN value: "FilterValue", }, ], })
@example Response structure
resp.task_execution_arn #=> String
@see docs.aws.amazon.com/goto/WebAPI/datasync-2018-11-09/StartTaskExecution AWS API Documentation
@overload start_task_execution
(params = {}) @param [Hash] params ({})
# File lib/aws-sdk-datasync/client.rb, line 2026 def start_task_execution(params = {}, options = {}) req = build_request(:start_task_execution, params) req.send_request(options) end
Applies a key-value pair to an Amazon Web Services resource.
@option params [required, String] :resource_arn
The Amazon Resource Name (ARN) of the resource to apply the tag to.
@option params [required, Array<Types::TagListEntry>] :tags
The tags to apply.
@return [Struct] Returns an empty {Seahorse::Client::Response response}.
@example Request syntax with placeholder values
resp = client.tag_resource({ resource_arn: "TaggableResourceArn", # required tags: [ # required { key: "TagKey", # required value: "TagValue", }, ], })
@see docs.aws.amazon.com/goto/WebAPI/datasync-2018-11-09/TagResource AWS API Documentation
@overload tag_resource
(params = {}) @param [Hash] params ({})
# File lib/aws-sdk-datasync/client.rb, line 2057 def tag_resource(params = {}, options = {}) req = build_request(:tag_resource, params) req.send_request(options) end
Removes a tag from an Amazon Web Services resource.
@option params [required, String] :resource_arn
The Amazon Resource Name (ARN) of the resource to remove the tag from.
@option params [required, Array<String>] :keys
The keys in the key-value pair in the tag to remove.
@return [Struct] Returns an empty {Seahorse::Client::Response response}.
@example Request syntax with placeholder values
resp = client.untag_resource({ resource_arn: "TaggableResourceArn", # required keys: ["TagKey"], # required })
@see docs.aws.amazon.com/goto/WebAPI/datasync-2018-11-09/UntagResource AWS API Documentation
@overload untag_resource
(params = {}) @param [Hash] params ({})
# File lib/aws-sdk-datasync/client.rb, line 2083 def untag_resource(params = {}, options = {}) req = build_request(:untag_resource, params) req.send_request(options) end
Updates the name of an agent.
@option params [required, String] :agent_arn
The Amazon Resource Name (ARN) of the agent to update.
@option params [String] :name
The name that you want to use to configure the agent.
@return [Struct] Returns an empty {Seahorse::Client::Response response}.
@example Request syntax with placeholder values
resp = client.update_agent({ agent_arn: "AgentArn", # required name: "TagValue", })
@see docs.aws.amazon.com/goto/WebAPI/datasync-2018-11-09/UpdateAgent AWS API Documentation
@overload update_agent
(params = {}) @param [Hash] params ({})
# File lib/aws-sdk-datasync/client.rb, line 2109 def update_agent(params = {}, options = {}) req = build_request(:update_agent, params) req.send_request(options) end
Updates some of the parameters of a previously created location for Network File System (NFS) access. For information about creating an NFS location, see [Creating a location for NFS].
[1]: docs.aws.amazon.com/datasync/latest/userguide/create-nfs-location.html
@option params [required, String] :location_arn
The Amazon Resource Name (ARN) of the NFS location to update.
@option params [String] :subdirectory
The subdirectory in the NFS file system that is used to read data from the NFS source location or write data to the NFS destination. The NFS path should be a path that's exported by the NFS server, or a subdirectory of that path. The path should be such that it can be mounted by other NFS clients in your network. To see all the paths exported by your NFS server, run "`showmount -e nfs-server-name`" from an NFS client that has access to your server. You can specify any directory that appears in the results, and any subdirectory of that directory. Ensure that the NFS export is accessible without Kerberos authentication. To transfer all the data in the folder that you specified, DataSync must have permissions to read all the data. To ensure this, either configure the NFS export with `no_root_squash`, or ensure that the files you want DataSync to access have permissions that allow read access for all users. Doing either option enables the agent to read the files. For the agent to access directories, you must additionally enable all execute access. If you are copying data to or from your Snowcone device, see [NFS Server on Snowcone][1] for more information. For information about NFS export configuration, see 18.7. The /etc/exports Configuration File in the Red Hat Enterprise Linux documentation. [1]: https://docs.aws.amazon.com/datasync/latest/userguide/create-nfs-location.html#nfs-on-snowcone
@option params [Types::OnPremConfig] :on_prem_config
A list of Amazon Resource Names (ARNs) of agents to use for a Network File System (NFS) location.
@option params [Types::NfsMountOptions] :mount_options
Represents the mount options that are available for DataSync to access an NFS location.
@return [Struct] Returns an empty {Seahorse::Client::Response response}.
@example Request syntax with placeholder values
resp = client.update_location_nfs({ location_arn: "LocationArn", # required subdirectory: "NfsSubdirectory", on_prem_config: { agent_arns: ["AgentArn"], # required }, mount_options: { version: "AUTOMATIC", # accepts AUTOMATIC, NFS3, NFS4_0, NFS4_1 }, })
@see docs.aws.amazon.com/goto/WebAPI/datasync-2018-11-09/UpdateLocationNfs AWS API Documentation
@overload update_location_nfs
(params = {}) @param [Hash] params ({})
# File lib/aws-sdk-datasync/client.rb, line 2184 def update_location_nfs(params = {}, options = {}) req = build_request(:update_location_nfs, params) req.send_request(options) end
Updates some of the parameters of a previously created location for self-managed object storage server access. For information about creating a self-managed object storage location, see [Creating a location for object storage].
[1]: docs.aws.amazon.com/datasync/latest/userguide/create-object-location.html
@option params [required, String] :location_arn
The Amazon Resource Name (ARN) of the self-managed object storage server location to be updated.
@option params [Integer] :server_port
The port that your self-managed object storage server accepts inbound network traffic on. The server port is set by default to TCP 80 (HTTP) or TCP 443 (HTTPS). You can specify a custom port if your self-managed object storage server requires one.
@option params [String] :server_protocol
The protocol that the object storage server uses to communicate. Valid values are `HTTP` or `HTTPS`.
@option params [String] :subdirectory
The subdirectory in the self-managed object storage server that is used to read data from.
@option params [String] :access_key
Optional. The access key is used if credentials are required to access the self-managed object storage server. If your object storage requires a user name and password to authenticate, use `AccessKey` and `SecretKey` to provide the user name and password, respectively.
@option params [String] :secret_key
Optional. The secret key is used if credentials are required to access the self-managed object storage server. If your object storage requires a user name and password to authenticate, use `AccessKey` and `SecretKey` to provide the user name and password, respectively.
@option params [Array<String>] :agent_arns
The Amazon Resource Name (ARN) of the agents associated with the self-managed object storage server location.
@return [Struct] Returns an empty {Seahorse::Client::Response response}.
@example Request syntax with placeholder values
resp = client.update_location_object_storage({ location_arn: "LocationArn", # required server_port: 1, server_protocol: "HTTPS", # accepts HTTPS, HTTP subdirectory: "S3Subdirectory", access_key: "ObjectStorageAccessKey", secret_key: "ObjectStorageSecretKey", agent_arns: ["AgentArn"], })
@see docs.aws.amazon.com/goto/WebAPI/datasync-2018-11-09/UpdateLocationObjectStorage AWS API Documentation
@overload update_location_object_storage
(params = {}) @param [Hash] params ({})
# File lib/aws-sdk-datasync/client.rb, line 2250 def update_location_object_storage(params = {}, options = {}) req = build_request(:update_location_object_storage, params) req.send_request(options) end
Updates some of the parameters of a previously created location for Server Message Block (SMB) file system access. For information about creating an SMB location, see [Creating a location for SMB].
[1]: docs.aws.amazon.com/datasync/latest/userguide/create-smb-location.html
@option params [required, String] :location_arn
The Amazon Resource Name (ARN) of the SMB location to update.
@option params [String] :subdirectory
The subdirectory in the SMB file system that is used to read data from the SMB source location or write data to the SMB destination. The SMB path should be a path that's exported by the SMB server, or a subdirectory of that path. The path should be such that it can be mounted by other SMB clients in your network. <note markdown="1"> `Subdirectory` must be specified with forward slashes. For example, `/path/to/folder`. </note> To transfer all the data in the folder that you specified, DataSync must have permissions to mount the SMB share and to access all the data in that share. To ensure this, do either of the following: * Ensure that the user/password specified belongs to the user who can mount the share and who has the appropriate permissions for all of the files and directories that you want DataSync to access. * Use credentials of a member of the Backup Operators group to mount the share. Doing either of these options enables the agent to access the data. For the agent to access directories, you must also enable all execute access.
@option params [String] :user
The user who can mount the share has the permissions to access files and folders in the SMB share.
@option params [String] :domain
The name of the Windows domain that the SMB server belongs to.
@option params [String] :password
The password of the user who can mount the share has the permissions to access files and folders in the SMB share.
@option params [Array<String>] :agent_arns
The Amazon Resource Names (ARNs) of agents to use for a Simple Message Block (SMB) location.
@option params [Types::SmbMountOptions] :mount_options
Represents the mount options that are available for DataSync to access an SMB location.
@return [Struct] Returns an empty {Seahorse::Client::Response response}.
@example Request syntax with placeholder values
resp = client.update_location_smb({ location_arn: "LocationArn", # required subdirectory: "SmbSubdirectory", user: "SmbUser", domain: "SmbDomain", password: "SmbPassword", agent_arns: ["AgentArn"], mount_options: { version: "AUTOMATIC", # accepts AUTOMATIC, SMB2, SMB3 }, })
@see docs.aws.amazon.com/goto/WebAPI/datasync-2018-11-09/UpdateLocationSmb AWS API Documentation
@overload update_location_smb
(params = {}) @param [Hash] params ({})
# File lib/aws-sdk-datasync/client.rb, line 2332 def update_location_smb(params = {}, options = {}) req = build_request(:update_location_smb, params) req.send_request(options) end
Updates the metadata associated with a task.
@option params [required, String] :task_arn
The Amazon Resource Name (ARN) of the resource name of the task to update.
@option params [Types::Options] :options
Represents the options that are available to control the behavior of a [StartTaskExecution][1] operation. Behavior includes preserving metadata such as user ID (UID), group ID (GID), and file permissions, and also overwriting files in the destination, data integrity verification, and so on. A task has a set of default options associated with it. If you don't specify an option in [StartTaskExecution][1], the default value is used. You can override the defaults options on each task execution by specifying an overriding `Options` value to [StartTaskExecution][1]. [1]: https://docs.aws.amazon.com/datasync/latest/userguide/API_StartTaskExecution.html
@option params [Array<Types::FilterRule>] :excludes
A list of filter rules that determines which files to exclude from a task. The list should contain a single filter string that consists of the patterns to exclude. The patterns are delimited by "\|" (that is, a pipe), for example: `"/folder1|/folder2"`
@option params [Types::TaskSchedule] :schedule
Specifies a schedule used to periodically transfer files from a source to a destination location. You can configure your task to execute hourly, daily, weekly or on specific days of the week. You control when in the day or hour you want the task to execute. The time you specify is UTC time. For more information, see [Scheduling your task][1]. [1]: https://docs.aws.amazon.com/datasync/latest/userguide/task-scheduling.html
@option params [String] :name
The name of the task to update.
@option params [String] :cloud_watch_log_group_arn
The Amazon Resource Name (ARN) of the resource name of the CloudWatch LogGroup.
@option params [Array<Types::FilterRule>] :includes
A list of filter rules that determines which files to include when running a task. The pattern should contain a single filter string that consists of the patterns to include. The patterns are delimited by "\|" (that is, a pipe). For example: `"/folder1|/folder2`"
@return [Struct] Returns an empty {Seahorse::Client::Response response}.
@example Request syntax with placeholder values
resp = client.update_task({ task_arn: "TaskArn", # required options: { verify_mode: "POINT_IN_TIME_CONSISTENT", # accepts POINT_IN_TIME_CONSISTENT, ONLY_FILES_TRANSFERRED, NONE overwrite_mode: "ALWAYS", # accepts ALWAYS, NEVER atime: "NONE", # accepts NONE, BEST_EFFORT mtime: "NONE", # accepts NONE, PRESERVE uid: "NONE", # accepts NONE, INT_VALUE, NAME, BOTH gid: "NONE", # accepts NONE, INT_VALUE, NAME, BOTH preserve_deleted_files: "PRESERVE", # accepts PRESERVE, REMOVE preserve_devices: "NONE", # accepts NONE, PRESERVE posix_permissions: "NONE", # accepts NONE, PRESERVE bytes_per_second: 1, task_queueing: "ENABLED", # accepts ENABLED, DISABLED log_level: "OFF", # accepts OFF, BASIC, TRANSFER transfer_mode: "CHANGED", # accepts CHANGED, ALL security_descriptor_copy_flags: "NONE", # accepts NONE, OWNER_DACL, OWNER_DACL_SACL }, excludes: [ { filter_type: "SIMPLE_PATTERN", # accepts SIMPLE_PATTERN value: "FilterValue", }, ], schedule: { schedule_expression: "ScheduleExpressionCron", # required }, name: "TagValue", cloud_watch_log_group_arn: "LogGroupArn", includes: [ { filter_type: "SIMPLE_PATTERN", # accepts SIMPLE_PATTERN value: "FilterValue", }, ], })
@see docs.aws.amazon.com/goto/WebAPI/datasync-2018-11-09/UpdateTask AWS API Documentation
@overload update_task
(params = {}) @param [Hash] params ({})
# File lib/aws-sdk-datasync/client.rb, line 2435 def update_task(params = {}, options = {}) req = build_request(:update_task, params) req.send_request(options) end
Updates execution of a task.
You can modify bandwidth throttling for a task execution that is running or queued. For more information, see [Adjusting Bandwidth Throttling for a Task Execution].
<note markdown=“1”> The only `Option` that can be modified by `UpdateTaskExecution` is ` BytesPerSecond `.
</note>
@option params [required, String] :task_execution_arn
The Amazon Resource Name (ARN) of the specific task execution that is being updated.
@option params [required, Types::Options] :options
Represents the options that are available to control the behavior of a [StartTaskExecution][1] operation. Behavior includes preserving metadata such as user ID (UID), group ID (GID), and file permissions, and also overwriting files in the destination, data integrity verification, and so on. A task has a set of default options associated with it. If you don't specify an option in [StartTaskExecution][1], the default value is used. You can override the defaults options on each task execution by specifying an overriding `Options` value to [StartTaskExecution][1]. [1]: https://docs.aws.amazon.com/datasync/latest/userguide/API_StartTaskExecution.html
@return [Struct] Returns an empty {Seahorse::Client::Response response}.
@example Request syntax with placeholder values
resp = client.update_task_execution({ task_execution_arn: "TaskExecutionArn", # required options: { # required verify_mode: "POINT_IN_TIME_CONSISTENT", # accepts POINT_IN_TIME_CONSISTENT, ONLY_FILES_TRANSFERRED, NONE overwrite_mode: "ALWAYS", # accepts ALWAYS, NEVER atime: "NONE", # accepts NONE, BEST_EFFORT mtime: "NONE", # accepts NONE, PRESERVE uid: "NONE", # accepts NONE, INT_VALUE, NAME, BOTH gid: "NONE", # accepts NONE, INT_VALUE, NAME, BOTH preserve_deleted_files: "PRESERVE", # accepts PRESERVE, REMOVE preserve_devices: "NONE", # accepts NONE, PRESERVE posix_permissions: "NONE", # accepts NONE, PRESERVE bytes_per_second: 1, task_queueing: "ENABLED", # accepts ENABLED, DISABLED log_level: "OFF", # accepts OFF, BASIC, TRANSFER transfer_mode: "CHANGED", # accepts CHANGED, ALL security_descriptor_copy_flags: "NONE", # accepts NONE, OWNER_DACL, OWNER_DACL_SACL }, })
@see docs.aws.amazon.com/goto/WebAPI/datasync-2018-11-09/UpdateTaskExecution AWS API Documentation
@overload update_task_execution
(params = {}) @param [Hash] params ({})
# File lib/aws-sdk-datasync/client.rb, line 2503 def update_task_execution(params = {}, options = {}) req = build_request(:update_task_execution, params) req.send_request(options) end
@api private @deprecated
# File lib/aws-sdk-datasync/client.rb, line 2527 def waiter_names [] end