s3layer
v0.7.1
Published
Node.js middleware for controlled proxying Amazon S3 objects to Internet
Downloads
23
Readme
Express/Connect middleware for proxying files from S3 to Internet
With this middleware you can:
- check authorization of a user to access a target object(using ACL, RBAC, etc.)
- translate urls to S3 keys
This middleware supports:
- Caching objects
- Piping objects from S3 to response, so objects don't fully loaded in memory
Install
npm install s3layer
Usage example:
var
app = require("express")(),
S3Layer = require("s3layer");
AWS_SETUP = {
accessKeyId: "...",
secretAccessKey: "...",
bucket: "..." // default bucket
};
// create a middleware
var s3l = S3Layer({
AWS: AWS_SETUP,
// the default bucket, can be overwritten by a getS3Key's returned value
bucket: AWS_SETUP.bucket,
/**
* params has fields:
* req - http request
* res - http response
* url - requested url
*/
getS3Key: function(params, cb) {
params.url = params.url.replace(/^\//, "");
if(params.url == "restricted-file.png") {
params.res.status(403).send("Forbidden");
return;
}
// proxy request to Key = params.url
cb(null, params.url);
}
});
// use the middleware in the express application
app.use("/files", s3l);
getS3Key
Accepts a request params and a callback function, in the callback function you can return:
string
- interpreted as S3 Keyobject
which can containkey
andbucket
fields
For example:
getS3Key: function(params, cb) {
params.url = params.url.replace(/^\//, "");
if(params.url == "restricted-file.png") {
params.res.status(403).send("Forbidden");
return;
}
// proxy request to Key = params.url
cb(null, {
key: params.url,
bucket: "another-bucket"
});
}
modifyHeaders
You can modify headers returned for a file, with modifyHeaders
callback:
For example
/**
* @param {Object} params
* @return {Object} params.headers - headers returned by Amazon S3
* @return {Object} params.outHeaders - headers that will be returned in a HTTP response, you can modify them directly
*/
modifyHeaders: function(params) {
if(params.headers["content-type"] && params.headers["content-type"].indexOf("image/") === 0) {
// force download all images
params.outHeaders["Content-Disposition"] = 'attachment; filename="img.jpg"';
}
}
modifyHeaders
is synchronous!