-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathindex.js
57 lines (44 loc) · 1.41 KB
/
index.js
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
const jsonServer = require('json-server')
let isAuthenticated = true;
const data = require('./data.js')
const routes = require('./app/routes.js')
const server = jsonServer.create()
const router = jsonServer.router(data)
const middlewares = jsonServer.defaults()
server.use(jsonServer.bodyParser);
// auth middleware
server.use( function ( req, res, next ) {
if (req.url == '/healthcheck') {
res.status( 200 ).send( "ok" )
} else {
next()
}
})
server.use( function ( req, res, next ) {
if (isAuthenticated) {
next()
} else {
res.status( 401 ).send( "Unauthorized!" )
}
} );
// the logout endpoint
server.get( '/logout', function ( req, res ) {
isAuthenticated = false;
res.status(200).send("logged out");
} );
server.use(middlewares)
// merge routes into default prefix
const prefix = `/${process.env.SERVER_PREFIX}/*`
const defaultRoutes = {}
defaultRoutes[prefix] = "/$1"
server.use(jsonServer.rewriter({...defaultRoutes, ...routes}));
server.use(router)
// Avoid CORS issue
// server.use( (req, res, next) => {
// res.header("Access-Control-Allow-Origin", "*");
// // res.header("Access-Control-Allow-Headers", "Origin, X-Requested-With, Content-Type, Accept");
// next();
// });
server.listen(3000, () => {
console.log(`JSON Server is running, see http://localhost:${process.env.SERVER_PORT}`)
})