misskey/src/api/server.ts

68 lines
1.4 KiB
TypeScript
Raw Normal View History

2016-12-29 07:49:51 +09: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-29 09:57:07 +09:00
// import authenticate from './authenticate';
2016-12-29 07:49:51 +09: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(bodyParser.json({
type: ['application/json', 'text/plain']
}));
2016-12-29 07:49:51 +09:00
app.use(cors({
origin: true
}));
2016-12-30 02:17:30 +09:00
app.get('/', (req, res) => {
res.send('YEE HAW');
});
2016-12-29 07:49:51 +09: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-21 14:39:39 +09:00
app.use((req, res, next) => {
res.locals.user = ((req.headers['cookie'] || '').match(/i=(!\w+)/) || [null, null])[1];
next();
});
2017-02-01 00:12:49 +09:00
require('./service/github')(app);
2017-01-21 14:39:39 +09:00
require('./service/twitter')(app);
2016-12-29 07:49:51 +09:00
module.exports = app;