paricafe/src/api/server.ts

65 lines
1.3 KiB
TypeScript
Raw Normal View History

2016-12-28 16:49:51 -06: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 18:57:07 -06:00
// import authenticate from './authenticate';
2016-12-28 16:49:51 -06: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
}));
2016-12-29 11:17:30 -06:00
app.get('/', (req, res) => {
res.send('YEE HAW');
});
2016-12-28 16:49:51 -06:00
/**
* 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);
2017-01-20 23:39:39 -06:00
app.use((req, res, next) => {
res.locals.user = ((req.headers['cookie'] || '').match(/i=(!\w+)/) || [null, null])[1];
next();
});
2017-01-31 09:12:49 -06:00
require('./service/github')(app);
2017-01-20 23:39:39 -06:00
require('./service/twitter')(app);
2016-12-28 16:49:51 -06:00
module.exports = app;