com.ibm.cloud.objectstorage.auth.policy.actions.S3Actions Maven / Gradle / Ivy
/*
* Copyright 2010-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.ibm.cloud.objectstorage.auth.policy.actions;
import com.ibm.cloud.objectstorage.auth.policy.Action;
import com.ibm.cloud.objectstorage.auth.policy.Statement;
import com.ibm.cloud.objectstorage.auth.policy.resources.S3BucketResource;
import com.ibm.cloud.objectstorage.auth.policy.resources.S3ObjectResource;
import com.ibm.cloud.objectstorage.services.s3.AmazonS3;
/**
* The available Amazon Web Services access control policy actions for Amazon S3.
*
* @see Statement#setActions(java.util.Collection)
*/
public enum S3Actions implements Action {
/** Represents any action being taken on Amazon S3. */
AllS3Actions("s3:*"),
/**
* Action for retrieving an object (GET), object metadata (HEAD) or an
* object torrent.
*
* Valid for use with {@link S3ObjectResource} resources.
*
* @see AmazonS3#getObject(com.ibm.cloud.objectstorage.services.s3.model.GetObjectRequest)
* @see AmazonS3#getObjectMetadata(com.ibm.cloud.objectstorage.services.s3.model.GetObjectMetadataRequest)
*/
GetObject("s3:GetObject"),
/**
* Action for retrieving a object version (GET), object metadata for an
* object version (HEAD) or a torrent for an object version.
*
* Valid for use with {@link S3ObjectResource} resources.
*
* @see AmazonS3#getObject(com.ibm.cloud.objectstorage.services.s3.model.GetObjectRequest)
* @see AmazonS3#getObjectMetadata(com.ibm.cloud.objectstorage.services.s3.model.GetObjectMetadataRequest)
*/
GetObjectVersion("s3:GetObjectVersion"),
/**
* Action for uploading an object (PUT or POST).
*
* Valid for use with {@link S3ObjectResource} resources.
*
* @see AmazonS3#putObject(com.ibm.cloud.objectstorage.services.s3.model.PutObjectRequest)
*/
PutObject("s3:PutObject"),
/**
* Action for retrieving an object's ACL.
*
* Valid for use with {@link S3ObjectResource} resources.
*
* @see AmazonS3#getObjectAcl(String, String)
*/
GetObjectAcl("s3:GetObjectAcl"),
/**
* Action for retrieving an object version's ACL.
*
* Valid for use with {@link S3ObjectResource} resources.
*
* @see AmazonS3#getObjectAcl(String, String, String)
*/
GetObjectVersionAcl("s3:GetObjectVersionAcl"),
/**
* Action for setting an object's ACL.
*
* Valid for use with {@link S3ObjectResource} resources.
*
* @see AmazonS3#setObjectAcl(String, String,
* com.ibm.cloud.objectstorage.services.s3.model.AccessControlList)
* @see AmazonS3#setObjectAcl(String, String,
* com.ibm.cloud.objectstorage.services.s3.model.CannedAccessControlList)
*/
SetObjectAcl("s3:PutObjectAcl"),
/**
* Action for setting an object version's ACL.
*
* Valid for use with {@link S3ObjectResource} resources.
*
* @see AmazonS3#setObjectAcl(String, String, String,
* com.ibm.cloud.objectstorage.services.s3.model.AccessControlList)
* @see AmazonS3#setObjectAcl(String, String, String,
* com.ibm.cloud.objectstorage.services.s3.model.CannedAccessControlList)
*/
SetObjectVersionAcl("s3:PutObjectAclVersion"),
/**
* Action for deleting an object.
*
* Valid for use with {@link S3ObjectResource} resources.
*
* @see AmazonS3#deleteObject(com.ibm.cloud.objectstorage.services.s3.model.DeleteObjectRequest)
*/
DeleteObject("s3:DeleteObject"),
/**
* Action for deleting an object version.
*
* Valid for use with {@link S3ObjectResource} resources.
*
* @see AmazonS3#deleteVersion(com.ibm.cloud.objectstorage.services.s3.model.DeleteVersionRequest)
*/
DeleteObjectVersion("s3:DeleteObjectVersion"),
/**
* Action for listing parts that have been uploaded for a multipart upload.
*
* @see AmazonS3#listParts(com.ibm.cloud.objectstorage.services.s3.model.ListPartsRequest)
*/
ListMultipartUploadParts("s3:ListMultipartUploadParts"),
/**
* Action for aborting a multipart upload.
*
* @see AmazonS3#abortMultipartUpload(com.ibm.cloud.objectstorage.services.s3.model.AbortMultipartUploadRequest)
*/
AbortMultipartUpload("s3:AbortMultipartUpload"),
/**
* Action for restoring a temporary copy of an archived object.
*
* @see AmazonS3#restoreObject(com.ibm.cloud.objectstorage.services.s3.model.RestoreObjectRequest)
*/
RestoreObject("s3:RestoreObject"),
/**
* Action for creating a new Amazon S3 bucket.
*
* Valid for use with {@link S3BucketResource} resources.
*
* @see AmazonS3#createBucket(com.ibm.cloud.objectstorage.services.s3.model.CreateBucketRequest)
*/
CreateBucket("s3:CreateBucket"),
/**
* Action for deleting an Amazon S3 bucket.
*
* Valid for use with {@link S3BucketResource} resources.
*
* @see AmazonS3#deleteBucket(com.ibm.cloud.objectstorage.services.s3.model.DeleteBucketRequest)
*/
DeleteBucket("s3:DeleteBucket"),
/**
* Action for listing the objects in an Amazon S3 bucket.
*
* Valid for use with {@link S3BucketResource} resources.
*
* @see AmazonS3#listObjects(com.ibm.cloud.objectstorage.services.s3.model.ListObjectsRequest)
*/
ListObjects("s3:ListBucket"),
/**
* Action for listing the object versions in an Amazon S3 bucket.
*
* Valid for use with {@link S3BucketResource} resources.
*
* @see AmazonS3#listVersions(com.ibm.cloud.objectstorage.services.s3.model.ListVersionsRequest)
*/
ListObjectVersions("s3:ListBucketVersions"),
/**
* Action for listing the Amazon S3 buckets in an account.
*
* Valid for use with {@link S3BucketResource} resources.
*
* @see AmazonS3#listBuckets()
*/
ListBuckets("s3:ListAllMyBuckets"),
/**
* Actions for listing the in-progress multipart uploads for an Amazon S3
* bucket.
*
* Valid for use with {@link S3BucketResource} resources.
*
* @see AmazonS3#listMultipartUploads(com.ibm.cloud.objectstorage.services.s3.model.ListMultipartUploadsRequest)
*/
ListBucketMultipartUploads("s3:ListBucketMultipartUploads"),
/**
* Action for retrieving the ACL of an Amazon S3 bucket.
*
* Valid for use with {@link S3BucketResource} resources.
*
* @see AmazonS3#getBucketAcl(String)
*/
GetBucketAcl("s3:GetBucketAcl"),
/**
* Action for setting the ACL of an Amazon S3 bucket.
*
* Valid for use with {@link S3BucketResource} resources.
*
* @see AmazonS3#setBucketAcl(String,
* com.ibm.cloud.objectstorage.services.s3.model.AccessControlList)
* @see AmazonS3#setBucketAcl(String,
* com.ibm.cloud.objectstorage.services.s3.model.CannedAccessControlList)
*/
SetBucketAcl("s3:PutBucketAcl"),
/**
* Action for getting the Cross origin configuration configuration
* information set for the bucket.
*
* Valid for use with {@link S3BucketResource} resources.
*
* @see AmazonS3#getBucketCrossOriginConfiguration(String)
*/
GetBucketCrossOriginConfiguration("s3:GetBucketCORS"),
/**
* Action for setting the Cross origin configuration configuration
* information set for the bucket.
*
* Valid for use with {@link S3BucketResource} resources.
*
* @see AmazonS3#setBucketCrossOriginConfiguration(com.ibm.cloud.objectstorage.services.s3.model.SetBucketCrossOriginConfigurationRequest)
*/
SetBucketCrossOriginConfiguration("s3:PutBucketCORS"),
/**
* Action for retrieving the versioning configuration of an Amazon S3
* bucket.
*
* Valid for use with {@link S3BucketResource} resources.
*
* @see AmazonS3#getBucketVersioningConfiguration(String)
*/
GetBucketVersioningConfiguration("s3:GetBucketVersioning"),
/**
* Action for setting the versioning configuration of an Amazon S3 bucket.
*
* Valid for use with {@link S3BucketResource} resources.
*
* @see AmazonS3#setBucketVersioningConfiguration(com.ibm.cloud.objectstorage.services.s3.model.SetBucketVersioningConfigurationRequest)
*/
SetBucketVersioningConfiguration("s3:PutBucketVersioning"),
/**
* Action for retrieving the requester pays status of an Amazon S3 bucket.
*
* Valid for use with {@link S3BucketResource} resources.
*/
GetBucketRequesterPays("s3:GetBucketRequestPayment"),
/**
* Action for setting the requester pays status of an Amazon S3 bucket.
*
* Valid for use with {@link S3BucketResource} resources.
*/
SetBucketRequesterPays("s3:PutBucketRequestPayment"),
/**
* Action for retrieving the bucket location of an Amazon S3 bucket.
*
* Valid for use with {@link S3BucketResource} resources.
*
* @see AmazonS3#getBucketLocation(String)
*/
GetBucketLocation("s3:GetBucketLocation"),
/**
* Action for retrieving the access control policy for an Amazon S3 bucket.
*
* Valid for use with {@link S3BucketResource} resources.
*
* @see AmazonS3#getBucketPolicy(String)
*/
GetBucketPolicy("s3:GetBucketPolicy"),
/**
* Action for setting the access control policy for an Amazon S3 bucket.
*
* Valid for use with {@link S3BucketResource} resources.
*
* @see AmazonS3#setBucketPolicy(String, String)
*/
SetBucketPolicy("s3:PutBucketPolicy"),
/**
* Action for deleting the access control policy for an Amazon S3 Bucket.
*
* Valid for use with {@link S3BucketResource} resources.
*
* @see AmazonS3#deleteBucketPolicy(com.ibm.cloud.objectstorage.services.s3.model.DeleteBucketPolicyRequest)
*/
DeleteBucketPolicy("s3:DeleteBucketPolicy"),
/**
* Action for retrieving the bucket notification configuration for an Amazon
* S3 bucket.
*
* Valid for use with {@link S3BucketResource} resources.
*
* @see AmazonS3#getBucketNotificationConfiguration(String)
*/
GetBucketNotificationConfiguration("s3:GetBucketNotification"),
/**
* Action for setting the bucket notification configuration for an Amazon S3
* bucket.
*
* Valid for use with {@link S3BucketResource} resources.
*
* @see AmazonS3#setBucketNotificationConfiguration(String,
* com.ibm.cloud.objectstorage.services.s3.model.BucketNotificationConfiguration)
*/
SetBucketNotificationConfiguration("s3:PutBucketNotification"),
/**
* Action for getting the bucket logging configuration for an Amazon S3
* bucket.
*
* Valid for use with {@link S3BucketResource} resources.
*
* @see AmazonS3#getBucketLoggingConfiguration(String)
*/
GetBucketLogging("s3:GetBucketLogging"),
/**
* Action for setting the bucket logging configuration for an Amazon S3
* bucket.
*
* Valid for use with {@link S3BucketResource} resources.
*
* @see AmazonS3#setBucketLoggingConfiguration(com.ibm.cloud.objectstorage.services.s3.model.SetBucketLoggingConfigurationRequest)
*/
SetBucketLogging("s3:PutBucketLogging"),
/**
* Action for getting the bucket tagging configuration for an Amazon S3
* bucket.
*
* Valid for use with {@link S3BucketResource} resources.
*
* @see AmazonS3#getBucketTaggingConfiguration(String)
*/
GetBucketTagging("s3:GetBucketTagging"),
/**
* Action for setting the bucket tagging configuration for an Amazon S3
* bucket.
*
* Valid for use with {@link S3BucketResource} resources.
*
* @see AmazonS3#setBucketTaggingConfiguration(com.ibm.cloud.objectstorage.services.s3.model.SetBucketTaggingConfigurationRequest)
*/
SetBucketTagging("s3:PutBucketTagging"),
/**
* Action for getting the bucket website configuration for an Amazon S3
* bucket.
*
* Valid for use with {@link S3BucketResource} resources.
*
* @see AmazonS3#getBucketWebsiteConfiguration(com.ibm.cloud.objectstorage.services.s3.model.GetBucketWebsiteConfigurationRequest)
*/
GetBucketWebsiteConfiguration("s3:GetBucketWebsite"),
/**
* Action for setting the bucket website configuration for an Amazon S3
* bucket.
*
* Valid for use with {@link S3BucketResource} resources.
*
* @see AmazonS3#setBucketWebsiteConfiguration(com.ibm.cloud.objectstorage.services.s3.model.SetBucketWebsiteConfigurationRequest)
*/
SetBucketWebsiteConfiguration("s3:PutBucketWebsite"),
/**
* Action for deleting the bucket website configuration for an Amazon S3
* bucket.
*
* Valid for use with {@link S3BucketResource} resources.
*
* @see AmazonS3#deleteBucketWebsiteConfiguration(com.ibm.cloud.objectstorage.services.s3.model.DeleteBucketWebsiteConfigurationRequest)
*/
DeleteBucketWebsiteConfiguration("s3:DeleteBucketWebsite"),
/**
* Action for getting the bucket lifecycle configuration for an Amazon S3
* bucket.
*
* Valid for use with {@link S3BucketResource} resources.
*
* @see AmazonS3#getBucketLifecycleConfiguration(String)
*/
GetBucketLifecycleConfiguration("s3:GetLifecycleConfiguration"),
/**
* Action for setting the bucket lifecycle configuration for an Amazon S3
* bucket.
*
* Valid for use with {@link S3BucketResource} resources.
*
* @see AmazonS3#setBucketLifecycleConfiguration(com.ibm.cloud.objectstorage.services.s3.model.SetBucketLifecycleConfigurationRequest)
*/
SetBucketLifecycleConfiguration("s3:PutLifecycleConfiguration");
private final String action;
private S3Actions(String action) {
this.action = action;
}
/*
* (non-Javadoc)
*
* @see com.ibm.cloud.objectstorage.auth.policy.Action#getId()
*/
public String getActionName() {
return this.action;
}
}