4cac6713ef
The memcached client wasn't correctly handling looking up a key that didn't exist. Now we only try to push the expiration forward if there is actually a value in memcached. Also while I'm in here, allow expiration to be left blank.
54 lines
1.3 KiB
JavaScript
54 lines
1.3 KiB
JavaScript
const memcached = require('memcached');
|
|
const winston = require('winston');
|
|
|
|
class MemcachedDocumentStore {
|
|
|
|
// Create a new store with options
|
|
constructor(options) {
|
|
this.expire = options.expire;
|
|
|
|
const host = options.host || '127.0.0.1';
|
|
const port = options.port || 11211;
|
|
const url = `${host}:${port}`;
|
|
this.connect(url);
|
|
}
|
|
|
|
// Create a connection
|
|
connect(url) {
|
|
this.client = new memcached(url);
|
|
|
|
winston.info(`connecting to memcached on ${url}`);
|
|
|
|
this.client.on('failure', function(error) {
|
|
winston.info('error connecting to memcached', {error});
|
|
});
|
|
}
|
|
|
|
// Save file in a key
|
|
set(key, data, callback, skipExpire) {
|
|
this.client.set(key, data, skipExpire ? 0 : this.expire || 0, (error) => {
|
|
callback(!error);
|
|
});
|
|
}
|
|
|
|
// Get a file from a key
|
|
get(key, callback, skipExpire) {
|
|
this.client.get(key, (error, data) => {
|
|
const value = error ? false : data;
|
|
|
|
callback(value);
|
|
|
|
// Update the key so that the expiration is pushed forward
|
|
if (value && !skipExpire) {
|
|
this.set(key, data, (updateSucceeded) => {
|
|
if (!updateSucceeded) {
|
|
winston.error('failed to update expiration on GET', {key});
|
|
}
|
|
}, skipExpire);
|
|
}
|
|
});
|
|
}
|
|
|
|
}
|
|
|
|
module.exports = MemcachedDocumentStore;
|