1
0
mirror of https://github.com/hotomoe/hotomoe synced 2024-12-21 10:08:07 +09:00
hotomoe/src/server/log-request.ts

22 lines
471 B
TypeScript
Raw Normal View History

2017-11-13 19:58:29 +09:00
import * as crypto from 'crypto';
import * as express from 'express';
import * as proxyAddr from 'proxy-addr';
import Xev from 'xev';
const ev = new Xev();
export default function(req: express.Request) {
const ip = proxyAddr(req, () => true);
const md5 = crypto.createHash('md5');
md5.update(ip);
const hashedIp = md5.digest('hex').substr(0, 3);
ev.emit('request', {
ip: hashedIp,
method: req.method,
hostname: req.hostname,
path: req.originalUrl
});
}