-
Notifications
You must be signed in to change notification settings - Fork 254
Expand file tree
/
Copy pathbucketGetPolicy.js
More file actions
49 lines (45 loc) · 1.8 KB
/
bucketGetPolicy.js
File metadata and controls
49 lines (45 loc) · 1.8 KB
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
const { errors } = require('arsenal');
const { metadataValidateBucket } = require('../metadata/metadataUtils');
const collectCorsHeaders = require('../utilities/collectCorsHeaders');
/**
* bucketGetPolicy - Get the bucket policy
* @param {AuthInfo} authInfo - Instance of AuthInfo class with requester's info
* @param {object} request - http request object
* @param {object} log - Werelogs logger
* @param {function} callback - callback to server
* @return {undefined}
*/
function bucketGetPolicy(authInfo, request, log, callback) {
log.debug('processing request', { method: 'bucketGetPolicy' });
const { bucketName, headers, method } = request;
const metadataValParams = {
authInfo,
bucketName,
requestType: 'bucketGetPolicy',
request,
};
return metadataValidateBucket(metadataValParams, request.actionImplicitDenies, log, (err, bucket) => {
const corsHeaders = collectCorsHeaders(headers.origin, method, bucket);
if (err) {
log.debug('error processing request', {
error: err,
method: 'bucketGetPolicy',
});
return callback(err, null, corsHeaders);
}
const bucketPolicy = bucket.getBucketPolicy();
if (!bucketPolicy) {
log.debug('error processing request', {
error: errors.NoSuchBucketPolicy,
method: 'bucketGetPolicy',
});
return callback(errors.NoSuchBucketPolicy, null,
corsHeaders);
}
// TODO: implement Utapi metric support
// bucketPolicy needs to be JSON stringified on return for proper
// parsing on return to caller function
return callback(null, JSON.stringify(bucketPolicy), corsHeaders);
});
}
module.exports = bucketGetPolicy;