Separate logic into proper places
This commit is contained in:
parent
6bac45efe2
commit
13e497993f
3 changed files with 107 additions and 97 deletions
44
lib/document_handler.js
Normal file
44
lib/document_handler.js
Normal file
|
@ -0,0 +1,44 @@
|
|||
var winston = require('winston');
|
||||
|
||||
// For handling serving stored documents
|
||||
|
||||
var DocumentHandler = function() {
|
||||
|
||||
};
|
||||
|
||||
// TODO implement with FS backend
|
||||
DocumentHandler.documents = {};
|
||||
|
||||
DocumentHandler.prototype.handleGet = function(key, response) {
|
||||
if (DocumentHandler.documents[key]) {
|
||||
winston.verbose('retrieved document', { key: key });
|
||||
response.writeHead(200, { 'content-type': 'application/json' });
|
||||
response.end(JSON.stringify({ data: DocumentHandler.documents[key] }));
|
||||
}
|
||||
else {
|
||||
winston.warn('document not found', { key: key });
|
||||
response.writeHead(400, { 'content-type': 'application/json' });
|
||||
response.end(JSON.stringify({ message: 'document not found' }));
|
||||
}
|
||||
};
|
||||
|
||||
DocumentHandler.prototype.handlePost = function(request, response) {
|
||||
var key = '123';
|
||||
request.on('data', function(data) {
|
||||
if (!DocumentHandler.documents[key]) {
|
||||
DocumentHandler.documents[key] = '';
|
||||
}
|
||||
DocumentHandler.documents[key] += data.toString();
|
||||
});
|
||||
request.on('end', function(end) {
|
||||
winston.verbose('added document', { key: key });
|
||||
response.end(JSON.stringify({ uuid: key }));
|
||||
});
|
||||
request.on('error', function(error) {
|
||||
// TODO handle error
|
||||
// TODO rename key to uuid everywhere behind the scenes
|
||||
// TODO finish all TODOs
|
||||
});
|
||||
};
|
||||
|
||||
module.exports = DocumentHandler;
|
53
lib/static_handler.js
Normal file
53
lib/static_handler.js
Normal file
|
@ -0,0 +1,53 @@
|
|||
var url = require('url'); // TODO not needed
|
||||
var path = require('path');
|
||||
var fs = require('fs');
|
||||
|
||||
var winston = require('winston');
|
||||
|
||||
// For serving static assets
|
||||
|
||||
var StaticHandler = function(path) {
|
||||
this.path = path;
|
||||
this.defaultPath = '/index.html';
|
||||
};
|
||||
|
||||
// Determine the content type for a given extension
|
||||
StaticHandler.contentTypeFor = function(ext) {
|
||||
if (ext == '.js') return 'text/javascript';
|
||||
else if (ext == '.css') return 'text/css';
|
||||
else if (ext == '.html') return 'text/html';
|
||||
else if (ext == '.ico') return 'image/ico';
|
||||
else {
|
||||
winston.error('unable to determine content type for static asset with extension: ' + ext);
|
||||
return 'text/plain';
|
||||
}
|
||||
};
|
||||
|
||||
// Handle a request, and serve back the asset if it exists
|
||||
StaticHandler.prototype.handle = function(request, response) {
|
||||
var inc = url.parse(request.url, false);
|
||||
var filePath = this.path + (inc.pathname == '/' ? this.defaultPath : inc.pathname);
|
||||
path.exists(filePath, function(exists) {
|
||||
if (exists) {
|
||||
fs.readFile(filePath, function(error, content) {
|
||||
if (error) {
|
||||
winston.error('unable to read file', { path: filePath, error: error.message });
|
||||
response.writeHead(500, { 'content-type': 'application/json' });
|
||||
response.end(JSON.stringify({ message: 'IO: Unable to read file' }));
|
||||
}
|
||||
else {
|
||||
var contentType = StaticHandler.contentTypeFor(path.extname(filePath));
|
||||
response.writeHead(200, { 'content-type': contentType });
|
||||
response.end(content, 'utf-8');
|
||||
}
|
||||
});
|
||||
}
|
||||
else {
|
||||
winston.warn('file not found', { path: filePath });
|
||||
response.writeHead(404, { 'content-type': 'application/json' });
|
||||
response.end(JSON.stringify({ message: 'file not found' }));
|
||||
}
|
||||
});
|
||||
};
|
||||
|
||||
module.exports = StaticHandler;
|
Loading…
Add table
Add a link
Reference in a new issue