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"
|
||||
}
|
14
package.json
14
package.json
@ -5,9 +5,17 @@
|
||||
"author" : "Meutel <meutel@meutel.net>",
|
||||
"private" : true,
|
||||
"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"
|
||||
}
|
||||
|
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