/*
 * 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;
using System.Collections.Generic;
using System.Xml.Serialization;
using System.Text;
using System.IO;
using Amazon.Runtime;
using Amazon.Runtime.Internal;
namespace Amazon.S3.Model
{
    /// 
    /// Container for the parameters to the GetObjectTorrent operation.
    /// Return torrent files from a bucket.
    /// 
    public partial class GetObjectTorrentRequest : AmazonWebServiceRequest
    {
        private string bucketName;
        private string key;
        private RequestPayer requestPayer;
        private string expectedBucketOwner;
        /// 
        /// The name of the bucket containing the object.
        /// 
        public string BucketName
        {
            get { return this.bucketName; }
            set { this.bucketName = value; }
        }
        // Check to see if BucketName property is set
        internal bool IsSetBucketName()
        {
            return this.bucketName != null;
        }
        /// 
        /// The key identifying the object.
        /// 
        /// 
        /// This property will be used as part of the resource path of the HTTP request. In .NET the System.Uri class
        /// is used to construct the uri for the request. The System.Uri class will canonicalize the uri string by compacting characters like "..". /// For example an object key of "foo/../bar/file.txt" will be transformed into "bar/file.txt" because the ".." 
        /// is interpreted as use parent directory. For further information view the documentation for 
        /// the Uri class: https://docs.microsoft.com/en-us/dotnet/api/system.uri
        /// 
        public string Key
        {
            get { return this.key; }
            set { this.key = value; }
        }
        // Check to see if Key property is set
        internal bool IsSetKey()
        {
            return this.key != null;
        }
        /// 
        /// Confirms that the requester knows that she or he will be charged for the request.
        /// Bucket owners need not specify this parameter in their requests.
        /// 
        public RequestPayer RequestPayer
        {
            get { return this.requestPayer; }
            set { this.requestPayer = value; }
        }
        /// 
        /// Checks to see if RequetsPayer is set.
        /// 
        /// true, if RequestPayer property is set.
        internal bool IsSetRequestPayer()
        {
            return requestPayer != null;
        }
        /// 
        /// The account ID of the expected bucket owner. 
        /// If the bucket is owned by a different account, the request will fail with an HTTP 403 (Access Denied) error.
        /// 
        public string ExpectedBucketOwner
        {
            get { return this.expectedBucketOwner; }
            set { this.expectedBucketOwner = value; }
        }
        /// 
        /// Checks to see if ExpectedBucketOwner is set.
        /// 
        /// true, if ExpectedBucketOwner property is set.
        internal bool IsSetExpectedBucketOwner()
        {
            return !String.IsNullOrEmpty(this.expectedBucketOwner);
        }
    }
}