/*
 * Copyright Amazon.com, Inc. or its affiliates. All Rights Reserved.
 * 
 * Licensed under the Apache License, Version 2.0 (the "License").
 * You may not use this file except in compliance with the License.
 * A copy of the License is located at
 * 
 *  http://aws.amazon.com/apache2.0
 * 
 * or in the "license" file accompanying this file. This file is distributed
 * on an "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either
 * express or implied. See the License for the specific language governing
 * permissions and limitations under the License.
 */
using System.IO;
using System.Threading;
using System.Threading.Tasks;
namespace Amazon.DynamoDBv2.DataModel
{
    public partial class S3Link
    {
        /// 
        /// Uploads the specified file and stores it in the specified bucket with the provided key from construction.
        /// 
        /// Path of the file to be uploaded.
        /// A cancellation token that can be used by other objects or threads to receive notice of cancellation.
        /// An asynchronous task of the request
        public Task UploadFromAsync(string sourcePath, CancellationToken cancellationToken = default(CancellationToken))
        {
            return this.s3ClientCache.GetClient(this.RegionAsEndpoint).UploadObjectFromFilePathAsync(this.linker.s3.bucket, this.linker.s3.key, sourcePath, null, cancellationToken);
        }
        /// 
        /// Uploads the stream and stores it in the specified bucket with the provided key from construction.
        /// 
        /// Stream to be uploaded to Amazon S3.
        /// A cancellation token that can be used by other objects or threads to receive notice of cancellation.
        /// An asynchronous task of the request
        public Task UploadStreamAsync(Stream stream, CancellationToken cancellationToken = default(CancellationToken))
        {
            return this.s3ClientCache.GetClient(this.RegionAsEndpoint).UploadObjectFromStreamAsync(this.linker.s3.bucket, this.linker.s3.key, stream, null, cancellationToken);
        }
        /// 
        /// Downloads the file from the S3Link's specified bucket and key then saves it in the given path. 
        /// Creates directories and the file if they do not already exist.
        /// 
        /// Path to save the file.
        /// A cancellation token that can be used by other objects or threads to receive notice of cancellation.
        /// An asynchronous task of the request
        public Task DownloadToAsync(string downloadPath, CancellationToken cancellationToken = default(CancellationToken))
        {
            return this.s3ClientCache.GetClient(this.RegionAsEndpoint).DownloadToFilePathAsync(this.linker.s3.bucket, this.linker.s3.key, downloadPath, null, cancellationToken);
        }
        /// 
        /// Opens a stream to object stored in Amazon S3.
        /// 
        /// A cancellation token that can be used by other objects or threads to receive notice of cancellation.
        /// An asynchronous task of the request
        public Task OpenStreamAsync(CancellationToken cancellationToken = default(CancellationToken))
        {
            return this.s3ClientCache.GetClient(this.RegionAsEndpoint).GetObjectStreamAsync(this.linker.s3.bucket, this.linker.s3.key, null, cancellationToken);
        }
    }
}