com.amazonaws.services.macie2.model.BucketLevelPermissions Maven / Gradle / Ivy
Show all versions of aws-java-sdk-macie2 Show documentation
/*
* Copyright 2018-2023 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.
*/
package com.amazonaws.services.macie2.model;
import java.io.Serializable;
import javax.annotation.Generated;
import com.amazonaws.protocol.StructuredPojo;
import com.amazonaws.protocol.ProtocolMarshaller;
/**
*
* Provides information about the bucket-level permissions settings for an S3 bucket.
*
*
* @see AWS API
* Documentation
*/
@Generated("com.amazonaws:aws-java-sdk-code-generator")
public class BucketLevelPermissions implements Serializable, Cloneable, StructuredPojo {
/**
*
* The permissions settings of the access control list (ACL) for the bucket. This value is null if an ACL hasn't
* been defined for the bucket.
*
*/
private AccessControlList accessControlList;
/**
*
* The block public access settings for the bucket.
*
*/
private BlockPublicAccess blockPublicAccess;
/**
*
* The permissions settings of the bucket policy for the bucket. This value is null if a bucket policy hasn't been
* defined for the bucket.
*
*/
private BucketPolicy bucketPolicy;
/**
*
* The permissions settings of the access control list (ACL) for the bucket. This value is null if an ACL hasn't
* been defined for the bucket.
*
*
* @param accessControlList
* The permissions settings of the access control list (ACL) for the bucket. This value is null if an ACL
* hasn't been defined for the bucket.
*/
public void setAccessControlList(AccessControlList accessControlList) {
this.accessControlList = accessControlList;
}
/**
*
* The permissions settings of the access control list (ACL) for the bucket. This value is null if an ACL hasn't
* been defined for the bucket.
*
*
* @return The permissions settings of the access control list (ACL) for the bucket. This value is null if an ACL
* hasn't been defined for the bucket.
*/
public AccessControlList getAccessControlList() {
return this.accessControlList;
}
/**
*
* The permissions settings of the access control list (ACL) for the bucket. This value is null if an ACL hasn't
* been defined for the bucket.
*
*
* @param accessControlList
* The permissions settings of the access control list (ACL) for the bucket. This value is null if an ACL
* hasn't been defined for the bucket.
* @return Returns a reference to this object so that method calls can be chained together.
*/
public BucketLevelPermissions withAccessControlList(AccessControlList accessControlList) {
setAccessControlList(accessControlList);
return this;
}
/**
*
* The block public access settings for the bucket.
*
*
* @param blockPublicAccess
* The block public access settings for the bucket.
*/
public void setBlockPublicAccess(BlockPublicAccess blockPublicAccess) {
this.blockPublicAccess = blockPublicAccess;
}
/**
*
* The block public access settings for the bucket.
*
*
* @return The block public access settings for the bucket.
*/
public BlockPublicAccess getBlockPublicAccess() {
return this.blockPublicAccess;
}
/**
*
* The block public access settings for the bucket.
*
*
* @param blockPublicAccess
* The block public access settings for the bucket.
* @return Returns a reference to this object so that method calls can be chained together.
*/
public BucketLevelPermissions withBlockPublicAccess(BlockPublicAccess blockPublicAccess) {
setBlockPublicAccess(blockPublicAccess);
return this;
}
/**
*
* The permissions settings of the bucket policy for the bucket. This value is null if a bucket policy hasn't been
* defined for the bucket.
*
*
* @param bucketPolicy
* The permissions settings of the bucket policy for the bucket. This value is null if a bucket policy hasn't
* been defined for the bucket.
*/
public void setBucketPolicy(BucketPolicy bucketPolicy) {
this.bucketPolicy = bucketPolicy;
}
/**
*
* The permissions settings of the bucket policy for the bucket. This value is null if a bucket policy hasn't been
* defined for the bucket.
*
*
* @return The permissions settings of the bucket policy for the bucket. This value is null if a bucket policy
* hasn't been defined for the bucket.
*/
public BucketPolicy getBucketPolicy() {
return this.bucketPolicy;
}
/**
*
* The permissions settings of the bucket policy for the bucket. This value is null if a bucket policy hasn't been
* defined for the bucket.
*
*
* @param bucketPolicy
* The permissions settings of the bucket policy for the bucket. This value is null if a bucket policy hasn't
* been defined for the bucket.
* @return Returns a reference to this object so that method calls can be chained together.
*/
public BucketLevelPermissions withBucketPolicy(BucketPolicy bucketPolicy) {
setBucketPolicy(bucketPolicy);
return this;
}
/**
* Returns a string representation of this object. This is useful for testing and debugging. Sensitive data will be
* redacted from this string using a placeholder value.
*
* @return A string representation of this object.
*
* @see java.lang.Object#toString()
*/
@Override
public String toString() {
StringBuilder sb = new StringBuilder();
sb.append("{");
if (getAccessControlList() != null)
sb.append("AccessControlList: ").append(getAccessControlList()).append(",");
if (getBlockPublicAccess() != null)
sb.append("BlockPublicAccess: ").append(getBlockPublicAccess()).append(",");
if (getBucketPolicy() != null)
sb.append("BucketPolicy: ").append(getBucketPolicy());
sb.append("}");
return sb.toString();
}
@Override
public boolean equals(Object obj) {
if (this == obj)
return true;
if (obj == null)
return false;
if (obj instanceof BucketLevelPermissions == false)
return false;
BucketLevelPermissions other = (BucketLevelPermissions) obj;
if (other.getAccessControlList() == null ^ this.getAccessControlList() == null)
return false;
if (other.getAccessControlList() != null && other.getAccessControlList().equals(this.getAccessControlList()) == false)
return false;
if (other.getBlockPublicAccess() == null ^ this.getBlockPublicAccess() == null)
return false;
if (other.getBlockPublicAccess() != null && other.getBlockPublicAccess().equals(this.getBlockPublicAccess()) == false)
return false;
if (other.getBucketPolicy() == null ^ this.getBucketPolicy() == null)
return false;
if (other.getBucketPolicy() != null && other.getBucketPolicy().equals(this.getBucketPolicy()) == false)
return false;
return true;
}
@Override
public int hashCode() {
final int prime = 31;
int hashCode = 1;
hashCode = prime * hashCode + ((getAccessControlList() == null) ? 0 : getAccessControlList().hashCode());
hashCode = prime * hashCode + ((getBlockPublicAccess() == null) ? 0 : getBlockPublicAccess().hashCode());
hashCode = prime * hashCode + ((getBucketPolicy() == null) ? 0 : getBucketPolicy().hashCode());
return hashCode;
}
@Override
public BucketLevelPermissions clone() {
try {
return (BucketLevelPermissions) super.clone();
} catch (CloneNotSupportedException e) {
throw new IllegalStateException("Got a CloneNotSupportedException from Object.clone() " + "even though we're Cloneable!", e);
}
}
@com.amazonaws.annotation.SdkInternalApi
@Override
public void marshall(ProtocolMarshaller protocolMarshaller) {
com.amazonaws.services.macie2.model.transform.BucketLevelPermissionsMarshaller.getInstance().marshall(this, protocolMarshaller);
}
}