/* * 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 PutBucketVersioning operation. /// Sets the versioning state of an existing bucket. To set the versioning state, you /// must be the bucket owner. /// /// /// /// You can set the versioning state with one of the following values: /// /// /// /// Enabled Enables versioning for the objects in the bucket. All objects added /// to the bucket receive a unique version ID. /// /// /// /// Suspended Disables versioning for the objects in the bucket. All objects added /// to the bucket receive the version ID null. /// /// /// /// If the versioning state has never been set on a bucket, it has no versioning state; /// a GetBucketVersioning /// request does not return a versioning state value. /// /// /// /// If the bucket owner enables MFA Delete in the bucket versioning configuration, the /// bucket owner must include the x-amz-mfa request header and the Status /// and the MfaDelete request elements in a request to set the versioning /// state of the bucket. /// /// /// /// If you have an object expiration lifecycle policy in your non-versioned bucket and /// you want to maintain the same permanent delete behavior when you enable versioning, /// you must add a noncurrent expiration policy. The noncurrent expiration lifecycle policy /// will manage the deletes of the noncurrent object versions in the version-enabled bucket. /// (A version-enabled bucket maintains one current and zero or more noncurrent object /// versions.) For more information, see Lifecycle /// and Versioning. /// /// /// /// The following operations are related to PutBucketVersioning: /// /// /// public partial class PutBucketVersioningRequest : AmazonWebServiceRequest { private string bucketName; private ChecksumAlgorithm _checksumAlgorithm; private MfaCodes mfaCodes; private S3BucketVersioningConfig config; private string expectedBucketOwner; /// /// The name of the bucket to be updated. /// public string BucketName { get { return this.bucketName; } set { this.bucketName = value; } } // Check to see if Bucket property is set internal bool IsSetBucketName() { return this.bucketName != null; } /// /// Gets and sets the property ChecksumAlgorithm. /// /// Indicates the algorithm used to create the checksum for the object. Amazon S3 will /// fail the request with a 400 error if there is no checksum associated with the object. /// For more information, see /// Checking object integrity in the Amazon S3 User Guide. /// /// public ChecksumAlgorithm ChecksumAlgorithm { get { return this._checksumAlgorithm; } set { this._checksumAlgorithm = value; } } // Check to see if ChecksumAlgorithm property is set internal bool IsSetChecksumAlgorithm() { return this._checksumAlgorithm != null; } /// /// The MfaCodes Tuple associates the Serial Number and the current Token/Code displayed on the /// Multi-Factor Authentication device associated with your AWS Account. /// /// /// This is a required property for this request if:
/// 1. EnableMfaDelete was configured on the bucket /// containing this object's version.
/// 2. You are deleting an object's version ///
public MfaCodes MfaCodes { get { return this.mfaCodes; } set { this.mfaCodes = value; } } /// /// Checks if the MfaCodes property is set. /// /// true if the MfaCodes property is set. internal bool IsSetMfaCodes() { return (this.mfaCodes != null) && (!System.String.IsNullOrEmpty(MfaCodes.SerialNumber)) && (!System.String.IsNullOrEmpty(MfaCodes.AuthenticationValue)); } /// /// The versioning configuration to apply to the bucket. /// /// /// Once Versioning has been "Enabled" on a bucket, it can be "Suspended" /// but cannot be switched "Off". If EnableMfaDelete is set, /// the MfaCodes property needs to contain the Serial of and current Token /// displayed on the MFA device. /// public S3BucketVersioningConfig VersioningConfig { get { if (this.config == null) this.config = new S3BucketVersioningConfig(); return this.config; } set { this.config = value; } } // Check to see if VersioningConfiguration property is set internal bool IsSetVersioningConfiguration() { return this.config != 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); } } }