/*
* Copyright 2010-2013 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 PutAcl operation.
/// uses the acl subresource to set the access control list (ACL) permissions for an object that already exists in a bucket
///
public partial class PutACLRequest : AmazonWebServiceRequest
{
private S3CannedACL cannedACL;
private S3AccessControlList accessControlPolicy;
private string bucket;
private string key;
private string versionId;
///
/// The canned ACL to apply to the bucket.
///
///
public S3CannedACL CannedACL
{
get { return this.cannedACL; }
set { this.cannedACL = value; }
}
// Check to see if CannedACL property is set
internal bool IsSetCannedACL()
{
return this.cannedACL != null;
}
///
/// Custom ACLs to be applied to the bucket or object.
///
public S3AccessControlList AccessControlList
{
get { return this.accessControlPolicy; }
set { this.accessControlPolicy = value; }
}
// Check to see if AccessControlPolicy property is set
internal bool IsSetAccessControlPolicy()
{
return this.accessControlPolicy != null;
}
///
/// The bucket name that contains the object to which you want to attach the ACL.
/// When using this API with an access point, you must direct requests to the access point hostname.
/// The access point hostname takes the form AccessPointName-AccountId.s3-accesspoint.Region.amazonaws.com.
/// When using this operation using an access point through the AWS SDKs, you provide the access point
/// ARN in place of the bucket name. For more information about access point ARNs, see
/// Using Access Points
/// in the Amazon Simple Storage Service Developer Guide.
///
public string BucketName
{
get { return this.bucket; }
set { this.bucket = value; }
}
// Check to see if BucketName property is set
internal bool IsSetBucketName()
{
return this.bucket != null;
}
///
/// The key of an S3 object.
/// If not specified, the ACLs are applied to the bucket.
///
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;
}
///
/// If set and an object key has been specified, the ACLs are applied
/// to the specific version of the object.
/// This property is ignored if the ACL is to be set on a Bucket.
///
public string VersionId
{
get { return this.versionId; }
set { this.versionId = value; }
}
///
/// Checks if VersionId property is set.
///
/// true if VersionId property is set.
internal bool IsSetVersionId()
{
return this.versionId != null;
}
}
}