* Determine if bucket exists and if user has permission to access it * @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 respond to http
(authInfo, request, log, callback)
| 14 | * @return {undefined} |
| 15 | */ |
| 16 | function bucketHead(authInfo, request, log, callback) { |
| 17 | log.debug('processing request', { method: 'bucketHead' }); |
| 18 | const bucketName = request.bucketName; |
| 19 | const metadataValParams = { |
| 20 | authInfo, |
| 21 | bucketName, |
| 22 | requestType: request.apiMethods || 'bucketHead', |
| 23 | request, |
| 24 | }; |
| 25 | standardMetadataValidateBucket(metadataValParams, request.actionImplicitDenies, log, (err, bucket) => { |
| 26 | const corsHeaders = collectCorsHeaders(request.headers.origin, |
| 27 | request.method, bucket); |
| 28 | if (err) { |
| 29 | monitoring.promMetrics( |
| 30 | 'HEAD', bucketName, err.code, 'headBucket'); |
| 31 | return callback(err, corsHeaders); |
| 32 | } |
| 33 | pushMetric('headBucket', log, { |
| 34 | authInfo, |
| 35 | bucket: bucketName, |
| 36 | }); |
| 37 | const headers = { |
| 38 | 'x-amz-bucket-region': bucket.getLocationConstraint(), |
| 39 | }; |
| 40 | return callback(null, Object.assign(corsHeaders, headers)); |
| 41 | }); |
| 42 | } |
| 43 | |
| 44 | module.exports = bucketHead; |
no test coverage detected