Move storage mechanism to new object
This commit is contained in:
parent
b173cdd144
commit
fec02cfead
3 changed files with 49 additions and 31 deletions
|
@ -1,42 +1,17 @@
|
||||||
var fs = require('fs'); // TODO won't be needed
|
|
||||||
|
|
||||||
var winston = require('winston');
|
var winston = require('winston');
|
||||||
var hashlib = require('hashlib');
|
|
||||||
|
|
||||||
// For handling serving stored documents
|
// For handling serving stored documents
|
||||||
|
|
||||||
var DocumentHandler = function(options) {
|
var DocumentHandler = function(options) {
|
||||||
if (options) {
|
if (options) {
|
||||||
this.keyLength = options.keyLength || 20;
|
this.keyLength = options.keyLength || 10;
|
||||||
|
this.store = options.store;
|
||||||
}
|
}
|
||||||
};
|
};
|
||||||
|
|
||||||
// Save a document
|
|
||||||
// TODO make data path configurable
|
|
||||||
// TODO move to a separate object
|
|
||||||
DocumentHandler.save = function(key, data, callback) {
|
|
||||||
fs.mkdir('data', '700', function() {
|
|
||||||
fs.writeFile('data/' + hashlib.md5(key), data, 'utf8', function() {
|
|
||||||
callback(true); // TODO handle errors
|
|
||||||
});
|
|
||||||
});
|
|
||||||
};
|
|
||||||
|
|
||||||
// Retrieve a document by key
|
|
||||||
DocumentHandler.get = function(key, callback) {
|
|
||||||
fs.readFile('data/' + hashlib.md5(key), 'utf8', function(err, data) {
|
|
||||||
if (err) {
|
|
||||||
callback(false);
|
|
||||||
}
|
|
||||||
else {
|
|
||||||
callback(data);
|
|
||||||
}
|
|
||||||
});
|
|
||||||
};
|
|
||||||
|
|
||||||
// Handle retrieving a document
|
// Handle retrieving a document
|
||||||
DocumentHandler.prototype.handleGet = function(key, response) {
|
DocumentHandler.prototype.handleGet = function(key, response) {
|
||||||
DocumentHandler.get(key, function(ret) {
|
this.store.get(key, function(ret) {
|
||||||
if (ret) {
|
if (ret) {
|
||||||
winston.verbose('retrieved document', { key: key });
|
winston.verbose('retrieved document', { key: key });
|
||||||
response.writeHead(200, { 'content-type': 'application/json' });
|
response.writeHead(200, { 'content-type': 'application/json' });
|
||||||
|
@ -52,6 +27,7 @@ DocumentHandler.prototype.handleGet = function(key, response) {
|
||||||
|
|
||||||
// Handle adding a new Document
|
// Handle adding a new Document
|
||||||
DocumentHandler.prototype.handlePost = function(request, response) {
|
DocumentHandler.prototype.handlePost = function(request, response) {
|
||||||
|
var _this = this;
|
||||||
var key = this.randomKey();
|
var key = this.randomKey();
|
||||||
var buffer = '';
|
var buffer = '';
|
||||||
request.on('data', function(data) {
|
request.on('data', function(data) {
|
||||||
|
@ -61,7 +37,7 @@ DocumentHandler.prototype.handlePost = function(request, response) {
|
||||||
buffer += data.toString();
|
buffer += data.toString();
|
||||||
});
|
});
|
||||||
request.on('end', function(end) {
|
request.on('end', function(end) {
|
||||||
DocumentHandler.save(key, buffer, function(res) {
|
_this.store.set(key, buffer, function(res) {
|
||||||
if (res) {
|
if (res) {
|
||||||
winston.verbose('added document', { key: key });
|
winston.verbose('added document', { key: key });
|
||||||
response.end(JSON.stringify({ key: key }));
|
response.end(JSON.stringify({ key: key }));
|
||||||
|
|
36
lib/file_document_store.js
Normal file
36
lib/file_document_store.js
Normal file
|
@ -0,0 +1,36 @@
|
||||||
|
var fs = require('fs');
|
||||||
|
|
||||||
|
var winston = require('winston');
|
||||||
|
var hashlib = require('hashlib');
|
||||||
|
|
||||||
|
// For storing in files
|
||||||
|
// TODO make data path configurable
|
||||||
|
// TODO make store type configurable
|
||||||
|
|
||||||
|
var FileDocumentStore = function(path) {
|
||||||
|
this.basePath = path;
|
||||||
|
};
|
||||||
|
|
||||||
|
// Save data in a file, key as md5 - since we don't know what we could be passed here
|
||||||
|
FileDocumentStore.prototype.set = function(key, data, callback) {
|
||||||
|
var _this = this;
|
||||||
|
fs.mkdir(this.basePath, '700', function() {
|
||||||
|
fs.writeFile(_this.basePath + '/' + hashlib.md5(key), data, 'utf8', function() {
|
||||||
|
callback(true); // TODO handle errors
|
||||||
|
});
|
||||||
|
});
|
||||||
|
};
|
||||||
|
|
||||||
|
// Get data from a file from key
|
||||||
|
FileDocumentStore.prototype.get = function(key, callback) {
|
||||||
|
fs.readFile(this.basePath + '/' + hashlib.md5(key), 'utf8', function(err, data) {
|
||||||
|
if (err) {
|
||||||
|
callback(false);
|
||||||
|
}
|
||||||
|
else {
|
||||||
|
callback(data);
|
||||||
|
}
|
||||||
|
});
|
||||||
|
};
|
||||||
|
|
||||||
|
module.exports = FileDocumentStore;
|
10
server.js
10
server.js
|
@ -6,6 +6,7 @@ var winston = require('winston');
|
||||||
|
|
||||||
var StaticHandler = require('./lib/static_handler');
|
var StaticHandler = require('./lib/static_handler');
|
||||||
var DocumentHandler = require('./lib/document_handler');
|
var DocumentHandler = require('./lib/document_handler');
|
||||||
|
var FileDocumentStore = require('./lib/file_document_store');
|
||||||
|
|
||||||
// Load the configuration and set some defaults
|
// Load the configuration and set some defaults
|
||||||
var config = JSON.parse(fs.readFileSync('config.js', 'utf8'));
|
var config = JSON.parse(fs.readFileSync('config.js', 'utf8'));
|
||||||
|
@ -36,14 +37,19 @@ http.createServer(function(request, response) {
|
||||||
|
|
||||||
// Looking to add a new doc
|
// Looking to add a new doc
|
||||||
if (incoming.pathname.match(/^\/documents$/) && request.method == 'POST') {
|
if (incoming.pathname.match(/^\/documents$/) && request.method == 'POST') {
|
||||||
handler = new DocumentHandler({ keyLength: config.keyLength });
|
handler = new DocumentHandler({
|
||||||
|
keyLength: config.keyLength,
|
||||||
|
store: new FileDocumentStore('./data')
|
||||||
|
});
|
||||||
return handler.handlePost(request, response);
|
return handler.handlePost(request, response);
|
||||||
}
|
}
|
||||||
|
|
||||||
// Looking up a doc
|
// Looking up a doc
|
||||||
var match = incoming.pathname.match(/^\/documents\/([A-Za-z0-9]+)$/);
|
var match = incoming.pathname.match(/^\/documents\/([A-Za-z0-9]+)$/);
|
||||||
if (request.method == 'GET' && match) {
|
if (request.method == 'GET' && match) {
|
||||||
handler = new DocumentHandler();
|
handler = new DocumentHandler({
|
||||||
|
store: new FileDocumentStore('./data')
|
||||||
|
});
|
||||||
return handler.handleGet(match[1], response);
|
return handler.handleGet(match[1], response);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
Loading…
Reference in a new issue