2016-12-28 15:49:51 -07:00
|
|
|
/**
|
|
|
|
* API Server
|
|
|
|
*/
|
|
|
|
|
|
|
|
import * as express from 'express';
|
|
|
|
import * as bodyParser from 'body-parser';
|
|
|
|
import * as cors from 'cors';
|
|
|
|
import * as multer from 'multer';
|
|
|
|
|
2016-12-28 17:57:07 -07:00
|
|
|
// import authenticate from './authenticate';
|
2016-12-28 15:49:51 -07:00
|
|
|
import endpoints from './endpoints';
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Init app
|
|
|
|
*/
|
|
|
|
const app = express();
|
|
|
|
|
|
|
|
app.disable('x-powered-by');
|
|
|
|
app.set('etag', false);
|
|
|
|
app.use(bodyParser.urlencoded({ extended: true }));
|
|
|
|
app.use(cors({
|
|
|
|
origin: true
|
|
|
|
}));
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Authetication
|
|
|
|
*/
|
|
|
|
/*app.post('*', async (req, res, next) => {
|
|
|
|
try {
|
|
|
|
ctx = await authenticate(req);
|
|
|
|
next();
|
|
|
|
} catch (e) {
|
|
|
|
res.status(403).send('AUTHENTICATION_FAILED');
|
|
|
|
}
|
|
|
|
});
|
|
|
|
*/
|
|
|
|
/**
|
|
|
|
* Register endpoint handlers
|
|
|
|
*/
|
|
|
|
endpoints.forEach(endpoint =>
|
|
|
|
endpoint.withFile ?
|
|
|
|
app.post('/' + endpoint.name,
|
|
|
|
endpoint.withFile ? multer({ dest: 'uploads/' }).single('file') : null,
|
|
|
|
require('./api-handler').default.bind(null, endpoint)) :
|
|
|
|
app.post('/' + endpoint.name,
|
|
|
|
require('./api-handler').default.bind(null, endpoint))
|
|
|
|
);
|
|
|
|
|
|
|
|
app.post('/signup', require('./private/signup').default);
|
|
|
|
app.post('/signin', require('./private/signin').default);
|
|
|
|
|
|
|
|
module.exports = app;
|