2021-03-13 06:44:25 +00:00
|
|
|
import isbot from 'isbot';
|
2021-04-26 06:57:49 +00:00
|
|
|
import ipaddr from 'ipaddr.js';
|
2020-08-12 05:24:41 +00:00
|
|
|
import { savePageView, saveEvent } from 'lib/queries';
|
2020-07-28 06:52:14 +00:00
|
|
|
import { useCors, useSession } from 'lib/middleware';
|
2022-03-11 03:01:33 +00:00
|
|
|
import { getJsonBody, getIpAddress } from 'lib/request';
|
2022-03-11 04:39:11 +00:00
|
|
|
import { ok, send, badRequest } from 'lib/response';
|
2020-10-03 03:33:46 +00:00
|
|
|
import { createToken } from 'lib/crypto';
|
2022-01-26 05:23:40 +00:00
|
|
|
import { removeTrailingSlash } from 'lib/url';
|
2020-07-17 08:03:38 +00:00
|
|
|
|
|
|
|
|
export default async (req, res) => {
|
2020-10-09 17:48:47 +00:00
|
|
|
await useCors(req, res);
|
|
|
|
|
|
2021-03-13 06:44:25 +00:00
|
|
|
if (isbot(req.headers['user-agent'])) {
|
2020-09-11 03:37:07 +00:00
|
|
|
return ok(res);
|
|
|
|
|
}
|
|
|
|
|
|
2020-10-04 02:07:56 +00:00
|
|
|
if (process.env.IGNORE_IP) {
|
|
|
|
|
const ips = process.env.IGNORE_IP.split(',').map(n => n.trim());
|
|
|
|
|
const ip = getIpAddress(req);
|
2021-04-26 06:57:49 +00:00
|
|
|
const blocked = ips.find(i => {
|
|
|
|
|
if (i === ip) return true;
|
2020-10-04 02:07:56 +00:00
|
|
|
|
2021-04-26 06:57:49 +00:00
|
|
|
// CIDR notation
|
|
|
|
|
if (i.indexOf('/') > 0) {
|
|
|
|
|
const addr = ipaddr.parse(ip);
|
|
|
|
|
const range = ipaddr.parseCIDR(i);
|
|
|
|
|
|
2021-08-11 12:31:32 +00:00
|
|
|
if (addr.kind() === range[0].kind() && addr.match(range)) return true;
|
2021-04-26 06:57:49 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
|
|
return false;
|
|
|
|
|
});
|
|
|
|
|
|
|
|
|
|
if (blocked) {
|
2020-10-04 02:07:56 +00:00
|
|
|
return ok(res);
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
|
2020-07-28 06:52:14 +00:00
|
|
|
await useSession(req, res);
|
2020-07-18 17:36:46 +00:00
|
|
|
|
2020-08-21 02:17:27 +00:00
|
|
|
const {
|
|
|
|
|
session: { website_id, session_id },
|
|
|
|
|
} = req;
|
2020-07-17 08:03:38 +00:00
|
|
|
|
2022-03-11 03:01:33 +00:00
|
|
|
const { type, payload } = getJsonBody(req);
|
|
|
|
|
|
2022-01-26 05:23:40 +00:00
|
|
|
let { url, referrer, event_type, event_value } = payload;
|
|
|
|
|
|
|
|
|
|
if (process.env.REMOVE_TRAILING_SLASH) {
|
|
|
|
|
url = removeTrailingSlash(url);
|
|
|
|
|
}
|
2020-07-24 02:56:55 +00:00
|
|
|
|
2022-01-26 05:23:40 +00:00
|
|
|
if (type === 'pageview') {
|
2020-07-24 02:56:55 +00:00
|
|
|
await savePageView(website_id, session_id, url, referrer);
|
2020-07-20 08:54:21 +00:00
|
|
|
} else if (type === 'event') {
|
2020-07-24 02:56:55 +00:00
|
|
|
await saveEvent(website_id, session_id, url, event_type, event_value);
|
2020-08-08 00:19:42 +00:00
|
|
|
} else {
|
|
|
|
|
return badRequest(res);
|
2020-07-24 02:56:55 +00:00
|
|
|
}
|
2020-07-23 03:45:09 +00:00
|
|
|
|
2020-10-03 03:33:46 +00:00
|
|
|
const token = await createToken({ website_id, session_id });
|
|
|
|
|
|
2022-03-11 04:39:11 +00:00
|
|
|
return send(res, token);
|
2020-07-17 08:03:38 +00:00
|
|
|
};
|