ButlerBin/lib/document_handler.js

69 lines
2.1 KiB
JavaScript
Raw Normal View History

2011-11-18 20:51:38 +00:00
var winston = require('winston');
// For handling serving stored documents
var DocumentHandler = function(options) {
2011-11-18 21:57:23 +00:00
if (options) {
2011-11-18 22:54:57 +00:00
this.keyLength = options.keyLength || 10;
this.store = options.store;
2011-11-18 21:57:23 +00:00
}
2011-11-18 20:51:38 +00:00
};
2011-11-18 21:45:48 +00:00
// Handle retrieving a document
2011-11-18 20:51:38 +00:00
DocumentHandler.prototype.handleGet = function(key, response) {
2011-11-18 22:54:57 +00:00
this.store.get(key, function(ret) {
2011-11-18 22:12:28 +00:00
if (ret) {
winston.verbose('retrieved document', { key: key });
response.writeHead(200, { 'content-type': 'application/json' });
response.end(JSON.stringify({ data: ret, key: key }));
}
else {
winston.warn('document not found', { key: key });
response.writeHead(404, { 'content-type': 'application/json' });
response.end(JSON.stringify({ message: 'document not found' }));
}
});
2011-11-18 20:51:38 +00:00
};
2011-11-18 21:45:48 +00:00
// Handle adding a new Document
2011-11-18 20:51:38 +00:00
DocumentHandler.prototype.handlePost = function(request, response) {
2011-11-18 22:54:57 +00:00
var _this = this;
2011-11-18 21:45:48 +00:00
var key = this.randomKey();
2011-11-18 22:12:28 +00:00
var buffer = '';
2011-11-18 20:51:38 +00:00
request.on('data', function(data) {
2011-11-18 22:12:28 +00:00
if (!buffer) {
2011-11-18 21:28:09 +00:00
response.writeHead(200, { 'content-type': 'application/json' });
2011-11-18 20:51:38 +00:00
}
2011-11-18 22:12:28 +00:00
buffer += data.toString();
2011-11-18 20:51:38 +00:00
});
request.on('end', function(end) {
2011-11-18 22:54:57 +00:00
_this.store.set(key, buffer, function(res) {
2011-11-18 22:12:28 +00:00
if (res) {
winston.verbose('added document', { key: key });
response.end(JSON.stringify({ key: key }));
}
else {
winston.verbose('error adding document');
response.end(JSON.stringify({ message: 'error adding document' }));
}
});
2011-11-18 20:51:38 +00:00
});
request.on('error', function(error) {
2011-11-18 21:28:09 +00:00
winston.error('connection error: ' + error.message);
response.writeHead(500, { 'content-type': 'application/json' });
response.end(JSON.stringify({ message: 'connection error' }));
2011-11-18 20:51:38 +00:00
});
};
2011-11-18 21:45:48 +00:00
// Generate a random key
DocumentHandler.prototype.randomKey = function() {
var text = '';
var keyspace = 'ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789';
for (var i = 0; i < this.keyLength; i++) {
2011-11-18 21:45:48 +00:00
text += keyspace.charAt(Math.floor(Math.random() * keyspace.length));
}
return text;
};
2011-11-18 21:22:00 +00:00
2011-11-18 20:51:38 +00:00
module.exports = DocumentHandler;