2020-07-19 08:57:01 +00:00
|
|
|
import { savePageView, saveEvent } from 'lib/db';
|
2020-07-28 06:52:14 +00:00
|
|
|
import { useCors, useSession } from 'lib/middleware';
|
2020-07-23 03:45:09 +00:00
|
|
|
import { createToken } from 'lib/crypto';
|
2020-08-08 00:19:42 +00:00
|
|
|
import { ok, badRequest } from 'lib/response';
|
2020-07-17 08:03:38 +00:00
|
|
|
|
|
|
|
|
export default async (req, res) => {
|
2020-07-25 23:31:07 +00:00
|
|
|
await useCors(req, res);
|
2020-07-28 06:52:14 +00:00
|
|
|
await useSession(req, res);
|
2020-07-18 17:36:46 +00:00
|
|
|
|
2020-07-28 06:52:14 +00:00
|
|
|
const { session } = req;
|
2020-07-24 02:56:55 +00:00
|
|
|
const token = await createToken(session);
|
2020-07-23 03:45:09 +00:00
|
|
|
const { website_id, session_id } = session;
|
2020-07-20 08:54:21 +00:00
|
|
|
const { type, payload } = req.body;
|
2020-07-17 08:03:38 +00:00
|
|
|
|
2020-07-20 08:54:21 +00:00
|
|
|
if (type === 'pageview') {
|
|
|
|
|
const { url, referrer } = payload;
|
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') {
|
|
|
|
|
const { url, event_type, event_value } = payload;
|
2020-07-17 08:03:38 +00:00
|
|
|
|
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-08-08 00:19:42 +00:00
|
|
|
return ok(res, { session: token });
|
2020-07-17 08:03:38 +00:00
|
|
|
};
|