UNPKG

@aws-sdk/client-s3

Version:

AWS SDK for JavaScript S3 Client for Node.js, Browser and React Native

79 lines 3.96 kB
import { __extends } from "tslib"; import { GetBucketPolicyOutput, GetBucketPolicyRequest } from "../models/models_0"; import { deserializeAws_restXmlGetBucketPolicyCommand, serializeAws_restXmlGetBucketPolicyCommand, } from "../protocols/Aws_restXml"; import { getBucketEndpointPlugin } from "@aws-sdk/middleware-bucket-endpoint"; import { getSerdePlugin } from "@aws-sdk/middleware-serde"; import { Command as $Command } from "@aws-sdk/smithy-client"; /** * <p>Returns the policy of a specified bucket. If you are using an identity other than the * root user of the AWS account that owns the bucket, the calling identity must have the * <code>GetBucketPolicy</code> permissions on the specified bucket and belong to the * bucket owner's account in order to use this operation.</p> * * <p>If you don't have <code>GetBucketPolicy</code> permissions, Amazon S3 returns a <code>403 * Access Denied</code> error. If you have the correct permissions, but you're not using an * identity that belongs to the bucket owner's account, Amazon S3 returns a <code>405 Method Not * Allowed</code> error.</p> * * <important> * <p>As a security precaution, the root user of the AWS account that owns a bucket can * always use this operation, even if the policy explicitly denies the root user the * ability to perform this action.</p> * </important> * * <p>For more information about bucket policies, see <a href="https://docs.aws.amazon.com/AmazonS3/latest/dev/using-iam-policies.html">Using Bucket Policies and User * Policies</a>.</p> * * <p>The following operation is related to <code>GetBucketPolicy</code>:</p> * <ul> * <li> * <p> * <a href="https://docs.aws.amazon.com/AmazonS3/latest/API/API_GetObject.html">GetObject</a> * </p> * </li> * </ul> */ var GetBucketPolicyCommand = /** @class */ (function (_super) { __extends(GetBucketPolicyCommand, _super); // Start section: command_properties // End section: command_properties function GetBucketPolicyCommand(input) { var _this = // Start section: command_constructor _super.call(this) || this; _this.input = input; return _this; // End section: command_constructor } /** * @internal */ GetBucketPolicyCommand.prototype.resolveMiddleware = function (clientStack, configuration, options) { this.middlewareStack.use(getSerdePlugin(configuration, this.serialize, this.deserialize)); this.middlewareStack.use(getBucketEndpointPlugin(configuration)); var stack = clientStack.concat(this.middlewareStack); var logger = configuration.logger; var clientName = "S3Client"; var commandName = "GetBucketPolicyCommand"; var handlerExecutionContext = { logger: logger, clientName: clientName, commandName: commandName, inputFilterSensitiveLog: GetBucketPolicyRequest.filterSensitiveLog, outputFilterSensitiveLog: GetBucketPolicyOutput.filterSensitiveLog, }; var requestHandler = configuration.requestHandler; return stack.resolve(function (request) { return requestHandler.handle(request.request, options || {}); }, handlerExecutionContext); }; GetBucketPolicyCommand.prototype.serialize = function (input, context) { return serializeAws_restXmlGetBucketPolicyCommand(input, context); }; GetBucketPolicyCommand.prototype.deserialize = function (output, context) { return deserializeAws_restXmlGetBucketPolicyCommand(output, context); }; return GetBucketPolicyCommand; }($Command)); export { GetBucketPolicyCommand }; //# sourceMappingURL=GetBucketPolicyCommand.js.map