|
@@ -1,21 +1,9 @@
|
|
|
-import Queue from "bull";
|
|
|
|
|
import useragent from "useragent";
|
|
import useragent from "useragent";
|
|
|
import geoip from "geoip-lite";
|
|
import geoip from "geoip-lite";
|
|
|
import URL from "url";
|
|
import URL from "url";
|
|
|
|
|
|
|
|
-import { createVisit, addLinkCount } from "./db/link";
|
|
|
|
|
-import { getStatsLimit } from "./utils";
|
|
|
|
|
-
|
|
|
|
|
-const redis = {
|
|
|
|
|
- port: Number(process.env.REDIS_PORT) || 6379,
|
|
|
|
|
- host: process.env.REDIS_HOST || "127.0.0.1",
|
|
|
|
|
- ...(process.env.REDIS_PASSWORD && { password: process.env.REDIS_PASSWORD })
|
|
|
|
|
-};
|
|
|
|
|
-
|
|
|
|
|
-export const visitQueue = new Queue("visit", { redis });
|
|
|
|
|
-
|
|
|
|
|
-visitQueue.clean(5000, "completed");
|
|
|
|
|
-visitQueue.clean(5000, "failed");
|
|
|
|
|
|
|
+import { createVisit, addLinkCount } from "../db/link";
|
|
|
|
|
+import { getStatsLimit } from "../utils";
|
|
|
|
|
|
|
|
const browsersList = ["IE", "Firefox", "Chrome", "Opera", "Safari", "Edge"];
|
|
const browsersList = ["IE", "Firefox", "Chrome", "Opera", "Safari", "Edge"];
|
|
|
const osList = ["Windows", "Mac OS", "Linux", "Android", "iOS"];
|
|
const osList = ["Windows", "Mac OS", "Linux", "Android", "iOS"];
|
|
@@ -24,7 +12,7 @@ const filterInBrowser = agent => item =>
|
|
|
const filterInOs = agent => item =>
|
|
const filterInOs = agent => item =>
|
|
|
agent.os.family.toLowerCase().includes(item.toLocaleLowerCase());
|
|
agent.os.family.toLowerCase().includes(item.toLocaleLowerCase());
|
|
|
|
|
|
|
|
-visitQueue.process(({ data }) => {
|
|
|
|
|
|
|
+export default function({ data }) {
|
|
|
const tasks = [];
|
|
const tasks = [];
|
|
|
|
|
|
|
|
tasks.push(addLinkCount(data.link.id));
|
|
tasks.push(addLinkCount(data.link.id));
|
|
@@ -49,9 +37,4 @@ visitQueue.process(({ data }) => {
|
|
|
}
|
|
}
|
|
|
|
|
|
|
|
return Promise.all(tasks);
|
|
return Promise.all(tasks);
|
|
|
-});
|
|
|
|
|
-
|
|
|
|
|
-const removeJob = job => job.remove();
|
|
|
|
|
-
|
|
|
|
|
-visitQueue.on("completed", removeJob);
|
|
|
|
|
-visitQueue.on("failed", removeJob);
|
|
|
|
|
|
|
+}
|