catbox-s3
Amazon S3 adapter for catbox.
data:image/s3,"s3://crabby-images/368c3/368c3a75ff3848f85d76f2adf038a143ccdfc2ee" alt="Current Version"
Options
bucket
- the S3 bucket. You need to have write access for it.accessKeyId
- the Amazon access key.secretAccessKey
- the Amazon secret access key.region
- the Amazon S3 region. (If you don't specify a region, the bucket will be created in US Standard.)
Caching binary data
At the moment, Hapi doesn't support caching of non-JSONifiable responses (like Streams or Buffers, see #1948).
If you want to use catbox-s3 for binary data, you have to handle it manually in your request handler:
var Catbox = require('catbox');
var cache = new Catbox.Client(require('catbox-s3'), {
accessKeyId : ,
secretAccessKey : ,
region : ,
bucket :
});
cache.start(function (err) {
if (err) { console.error(err); }
});
var handler = function (request, reply) {
var cacheKey = {
id : ,
segment :
};
cache.get(cacheKey, function (err, result) {
if (result) {
return reply(result.item).type();
}
yourBusinessLogic(function (err, data) {
cache.set(cacheKey, data, , function (err) {
});
reply(result.item).type();
});
});
};
Running tests
In order to run the tests, set the aforementioned options as environment variables:
S3_ACCESS_KEY=<YOURKEY> S3_SECRET_KEY=<YOURSECRET> S3_REGION=<REGION> S3_BUCKET=<YOURBUCKET> npm test
License
MIT