route author: list, single
This commit is contained in:
parent
8b9ceb7978
commit
64f1e3bf01
9
bin/www
Executable file
9
bin/www
Executable file
@ -0,0 +1,9 @@
|
|||||||
|
#!/usr/bin/nodejs
|
||||||
|
var debug = require('debug')('bouquins');
|
||||||
|
var app = require('../bouquins');
|
||||||
|
|
||||||
|
app.set('port', process.env.PORT || 3000);
|
||||||
|
|
||||||
|
var server = app.listen(app.get('port'), function() {
|
||||||
|
debug('Express server listening on port ' + server.address().port);
|
||||||
|
});
|
74
bouquins.js
Normal file
74
bouquins.js
Normal file
@ -0,0 +1,74 @@
|
|||||||
|
var express = require('express');
|
||||||
|
var path = require('path');
|
||||||
|
var favicon = require('static-favicon');
|
||||||
|
var logger = require('morgan');
|
||||||
|
var cookieParser = require('cookie-parser');
|
||||||
|
var bodyParser = require('body-parser');
|
||||||
|
var sqlite3 = require('sqlite3').verbose();
|
||||||
|
|
||||||
|
var routes = require('./routes/index');
|
||||||
|
var author = require('./routes/author');
|
||||||
|
var book = require('./routes/book');
|
||||||
|
var tag = require('./routes/tag');
|
||||||
|
var serie = require('./routes/serie');
|
||||||
|
|
||||||
|
var app = express();
|
||||||
|
|
||||||
|
// view engine setup
|
||||||
|
app.set('views', path.join(__dirname, 'views'));
|
||||||
|
app.set('view engine', 'jade');
|
||||||
|
|
||||||
|
// db setup
|
||||||
|
var db = new sqlite3.Database('/home/meutel/metadata.db');
|
||||||
|
|
||||||
|
app.use(function(req, res, next) {
|
||||||
|
req.db = db;
|
||||||
|
next();
|
||||||
|
});
|
||||||
|
|
||||||
|
app.use(favicon());
|
||||||
|
app.use(logger('dev'));
|
||||||
|
app.use(bodyParser.json());
|
||||||
|
app.use(bodyParser.urlencoded());
|
||||||
|
app.use(cookieParser());
|
||||||
|
app.use(express.static(path.join(__dirname, 'public')));
|
||||||
|
|
||||||
|
app.use('/', routes);
|
||||||
|
app.use('/author', author);
|
||||||
|
app.use('/book', book);
|
||||||
|
app.use('/tag', tag);
|
||||||
|
app.use('/serie', serie);
|
||||||
|
|
||||||
|
/// catch 404 and forwarding to error handler
|
||||||
|
app.use(function(req, res, next) {
|
||||||
|
var err = new Error('Not Found');
|
||||||
|
err.status = 404;
|
||||||
|
next(err);
|
||||||
|
});
|
||||||
|
|
||||||
|
/// error handlers
|
||||||
|
|
||||||
|
// development error handler
|
||||||
|
// will print stacktrace
|
||||||
|
if (app.get('env') === 'development') {
|
||||||
|
app.use(function(err, req, res, next) {
|
||||||
|
res.status(err.status || 500);
|
||||||
|
res.render('error', {
|
||||||
|
message: err.message,
|
||||||
|
error: err
|
||||||
|
});
|
||||||
|
});
|
||||||
|
}
|
||||||
|
|
||||||
|
// production error handler
|
||||||
|
// no stacktraces leaked to user
|
||||||
|
app.use(function(err, req, res, next) {
|
||||||
|
res.status(err.status || 500);
|
||||||
|
res.render('error', {
|
||||||
|
message: err.message,
|
||||||
|
error: {}
|
||||||
|
});
|
||||||
|
});
|
||||||
|
|
||||||
|
|
||||||
|
module.exports = app;
|
@ -1,5 +0,0 @@
|
|||||||
{
|
|
||||||
"httpPort":8080,
|
|
||||||
"debugLevel":"debug",
|
|
||||||
"dbfile": "/home/meutel/metadata.db"
|
|
||||||
}
|
|
16
package.json
16
package.json
@ -4,10 +4,18 @@
|
|||||||
"url" : "TODO",
|
"url" : "TODO",
|
||||||
"author" : "Meutel <meutel@meutel.net>",
|
"author" : "Meutel <meutel@meutel.net>",
|
||||||
"private" : true,
|
"private" : true,
|
||||||
"dependencies" : {
|
"dependencies": {
|
||||||
"express": "3.x"
|
"express": "~4.0.0",
|
||||||
|
"static-favicon": "~1.0.0",
|
||||||
|
"morgan": "~1.0.0",
|
||||||
|
"cookie-parser": "~1.0.1",
|
||||||
|
"body-parser": "~1.0.0",
|
||||||
|
"debug": "~0.7.4",
|
||||||
|
"jade": "~1.3.0",
|
||||||
|
"sqlite3": "~2.2.0"
|
||||||
|
},
|
||||||
|
"scripts": {
|
||||||
|
"start": "nodejs ./bin/www"
|
||||||
},
|
},
|
||||||
"main" : "./lib/bouquins",
|
|
||||||
"bin" : { "bootstrap" : "./bin/bootstrap" },
|
|
||||||
"version" : "0.1.0"
|
"version" : "0.1.0"
|
||||||
}
|
}
|
||||||
|
25
routes/author.js
Normal file
25
routes/author.js
Normal file
@ -0,0 +1,25 @@
|
|||||||
|
var express = require('express');
|
||||||
|
var router = express.Router();
|
||||||
|
|
||||||
|
/* All authors */
|
||||||
|
router.get('/', function(req, res) {
|
||||||
|
var query = 'SELECT * FROM authors ';
|
||||||
|
query += ' LIMIT ? OFFSET ?';
|
||||||
|
var authors = new Array();
|
||||||
|
var perpage = req.query.perpage;
|
||||||
|
perpage = perpage ? perpage : 10;
|
||||||
|
req.db.each(query, perpage, 0, function (err, row) {
|
||||||
|
authors.push(row);
|
||||||
|
}, function(err) {
|
||||||
|
res.json(authors);
|
||||||
|
});
|
||||||
|
});
|
||||||
|
|
||||||
|
/* Single author */
|
||||||
|
router.get('/:id', function(req, res) {
|
||||||
|
req.db.get('SELECT * FROM authors WHERE id = ?', req.params.id, function(err, row) {
|
||||||
|
res.json(row);
|
||||||
|
});
|
||||||
|
});
|
||||||
|
|
||||||
|
module.exports = router;
|
9
routes/book.js
Normal file
9
routes/book.js
Normal file
@ -0,0 +1,9 @@
|
|||||||
|
var express = require('express');
|
||||||
|
var router = express.Router();
|
||||||
|
|
||||||
|
/* GET home page. */
|
||||||
|
router.get('/', function(req, res) {
|
||||||
|
res.render('index', { title: 'Books' });
|
||||||
|
});
|
||||||
|
|
||||||
|
module.exports = router;
|
9
routes/index.js
Normal file
9
routes/index.js
Normal file
@ -0,0 +1,9 @@
|
|||||||
|
var express = require('express');
|
||||||
|
var router = express.Router();
|
||||||
|
|
||||||
|
/* GET home page. */
|
||||||
|
router.get('/', function(req, res) {
|
||||||
|
res.render('index', { title: 'Express' });
|
||||||
|
});
|
||||||
|
|
||||||
|
module.exports = router;
|
9
routes/serie.js
Normal file
9
routes/serie.js
Normal file
@ -0,0 +1,9 @@
|
|||||||
|
var express = require('express');
|
||||||
|
var router = express.Router();
|
||||||
|
|
||||||
|
/* GET home page. */
|
||||||
|
router.get('/', function(req, res) {
|
||||||
|
res.render('index', { title: 'Series' });
|
||||||
|
});
|
||||||
|
|
||||||
|
module.exports = router;
|
9
routes/tag.js
Normal file
9
routes/tag.js
Normal file
@ -0,0 +1,9 @@
|
|||||||
|
var express = require('express');
|
||||||
|
var router = express.Router();
|
||||||
|
|
||||||
|
/* GET home page. */
|
||||||
|
router.get('/', function(req, res) {
|
||||||
|
res.render('index', { title: 'Tags' });
|
||||||
|
});
|
||||||
|
|
||||||
|
module.exports = router;
|
6
views/error.jade
Normal file
6
views/error.jade
Normal file
@ -0,0 +1,6 @@
|
|||||||
|
extends layout
|
||||||
|
|
||||||
|
block content
|
||||||
|
h1= message
|
||||||
|
h2= error.status
|
||||||
|
pre #{error.stack}
|
5
views/index.jade
Normal file
5
views/index.jade
Normal file
@ -0,0 +1,5 @@
|
|||||||
|
extends layout
|
||||||
|
|
||||||
|
block content
|
||||||
|
h1= title
|
||||||
|
p Welcome to #{title}
|
7
views/layout.jade
Normal file
7
views/layout.jade
Normal file
@ -0,0 +1,7 @@
|
|||||||
|
doctype html
|
||||||
|
html
|
||||||
|
head
|
||||||
|
title= title
|
||||||
|
link(rel='stylesheet', href='/stylesheets/style.css')
|
||||||
|
body
|
||||||
|
block content
|
Loading…
Reference in New Issue
Block a user