Browse Source

stats counting implemented

master
Christian Müller 10 years ago
parent
commit
676eb95a4b
  1. 32
      server.js
  2. 8
      src/view.js

32
server.js

@ -9,7 +9,14 @@ var app = express();
app.use(bodyParser.urlencoded({ extended: true })); app.use(bodyParser.urlencoded({ extended: true }));
var CACHE = new LRU(30); var MODELS = {};
var CACHE = new LRU({
max: 50,
dispose: key => {
MODELS[key].save();
delete MODELS[key];
}
});
var getTimeStamp = () => { var getTimeStamp = () => {
var timestamp = new Date().getTime(); var timestamp = new Date().getTime();
@ -68,27 +75,38 @@ app.get(/\/([a-z0-9]+\/export)/, function (req, res) {
app.get(/\/([a-z0-9]+\/stats)/, function (req, res) { app.get(/\/([a-z0-9]+\/stats)/, function (req, res) {
var link = req.params["0"].replace("/stats", ""); var link = req.params["0"].replace("/stats", "");
storage.getNote(link).then(note => note var promise = link in MODELS
? res.send(view.buildStats(note)) ? new Promise(resolve => resolve(MODELS[link]))
: storage.getNote(link);
promise.then(note => note
? res.send(view.renderStats(note))
: notFound(res)); : notFound(res));
}); });
app.get(/\/([a-z0-9]+)/, function (req, res) { app.get(/\/([a-z0-9]+)/, function (req, res) {
var link = req.params["0"]; var link = req.params["0"];
if (CACHE.has(link)) res.send(CACHE.get(link)); if (CACHE.has(link)) {
else storage.getNote(link).then(note => { (link in MODELS) && MODELS[link].views++;
res.send(CACHE.get(link));
} else storage.getNote(link).then(note => {
if (!note) return notFound(res); if (!note) return notFound(res);
var content = view.buildNote(note); var content = view.renderNote(note);
CACHE.set(link, content); CACHE.set(link, content);
MODELS[link] = note;
res.send(content); res.send(content);
}); });
}); });
var sendResponse = (res, code, message) => var sendResponse = (res, code, message) =>
res.status(code).send(view.buildPage(message, "<h1>" + message + "</h1>", "")); res.status(code).send(view.renderPage(message, "<h1>" + message + "</h1>", ""));
var notFound = res => sendResponse(res, 404, "Not found"); var notFound = res => sendResponse(res, 404, "Not found");
var server = app.listen(3000, function () { var server = app.listen(3000, function () {
console.log('NoteHub server listening on port %s', server.address().port); console.log('NoteHub server listening on port %s', server.address().port);
}); });
setInterval(() => {
console.log("saving stats...");
Object.keys(MODELS).forEach(id => MODELS[id].save())
}, 60 * 5 * 1000);

8
src/view.js

@ -9,14 +9,14 @@ var deriveTitle = text => text
.split(/[\n\r]/)[0].slice(0,25) .split(/[\n\r]/)[0].slice(0,25)
.replace(/[^a-zA-Z0-9\s]/g, ""); .replace(/[^a-zA-Z0-9\s]/g, "");
var buildPage = (title, content, footer) => pageTemplate var renderPage = (title, content, footer) => pageTemplate
.replace("%TITLE%", title) .replace("%TITLE%", title)
.replace("%CONTENT%", content) .replace("%CONTENT%", content)
.replace("%FOOTER%", footer); .replace("%FOOTER%", footer);
module.exports.buildPage = buildPage; module.exports.renderPage = renderPage;
module.exports.buildStats = note => buildPage(deriveTitle(note.text), module.exports.renderStats = note => renderPage(deriveTitle(note.text),
`<h2>Statistics</h2> `<h2>Statistics</h2>
<table> <table>
<tr><td>Published</td><td>${note.published}</td></tr> <tr><td>Published</td><td>${note.published}</td></tr>
@ -25,7 +25,7 @@ module.exports.buildStats = note => buildPage(deriveTitle(note.text),
</table>`, </table>`,
""); "");
module.exports.buildNote = note => buildPage(deriveTitle(note.text), module.exports.renderNote = note => renderPage(deriveTitle(note.text),
marked(note.text), marked(note.text),
footerTemplate.replace(/%LINK%/g, note.id)); footerTemplate.replace(/%LINK%/g, note.id));

Loading…
Cancel
Save