This commit is contained in:
Typicode
2015-02-05 22:03:50 +01:00
parent b6b4a415b2
commit 80e0df1630
4 changed files with 45 additions and 39 deletions

View File

@ -14,7 +14,7 @@
"errorhandler": "^1.2.0",
"express": "^4.9.5",
"got": "^1.2.2",
"lowdb": "^0.7.0",
"lowdb": "^0.7.1",
"method-override": "^2.1.2",
"morgan": "^1.3.1",
"node-uuid": "^1.4.2",

View File

@ -3,11 +3,8 @@ var path = require('path')
// LowDB
var low = require('lowdb')
var _db = require('underscore-db')
var _inflections = require('underscore.inflections')
low.mixin('_db')
low.mixin('_inflections')
low.mixin(require('underscore-db'))
low.mixin(require('underscore.inflections'))
// Express
var http = require('http')
@ -21,13 +18,26 @@ var errorhandler = require('errorhandler')
// json-server
var utils = require('./utils')
var createRoutes = require('./create-routes')
var getRoutes = require('./routes')
low.mixin({ createId: utils.createId })
module.exports = function(object, filename) {
var server = express()
var routes = createRoutes(object, filename)
// Create database
if (filename) {
var db = low(filename)
} else {
var db = low()
db.object = object
}
// Expose db
server.db = db
// Get routes
var routes = getRoutes(db)
// Don't use logger if json-server is mounted
if (!module.parent) {
@ -39,12 +49,14 @@ module.exports = function(object, filename) {
server.use(bodyParser.urlencoded({ extended: false }))
server.use(methodOverride())
// Serve static files
if (fs.existsSync(process.cwd() + '/public')) {
server.use(serveStatic(process.cwd() + '/public'));
} else {
server.use(serveStatic(__dirname + '/public'));
}
// CORS
server.use(cors({ origin: true, credentials: true }))
server.get('/db', routes.showDatabase)

View File

@ -1,20 +1,7 @@
var _ = require('underscore')
var low = require('lowdb')
var _db = require('underscore-db')
var _inflections = require('underscore.inflections')
var utils = require('./utils')
low.mixin(_db)
low.mixin(_inflections)
module.exports = function(object, filename) {
if (filename) {
var db = low(filename)
} else {
var db = low()
db.object = object
}
module.exports = function(db) {
return {
// GET /db
showDatabase: function(req, res, next) {
@ -85,6 +72,7 @@ module.exports = function(object, filename) {
}
}
// Sort
if(_sort) {
_order = _order || 'ASC'

View File

@ -273,18 +273,24 @@ describe('Server', function() {
request(server)
.get('/')
.expect(/You're successfully running JSON Server/)
.expect(200, done);
});
});
.expect(200, done)
})
})
describe('GET /stylesheets/style.css', function() {
it('should respond with css', function(done) {
request(server)
.get('/stylesheets/style.css')
.expect('Content-Type', /css/)
.expect(200, done);
});
});
.expect(200, done)
})
})
})
describe('Database #object', function() {
it('should be accessible', function() {
assert(server.db.object)
})
})
})