mirror of
https://github.com/ajayyy/SponsorBlockServer.git
synced 2025-12-14 07:27:01 +03:00
83 lines
3.5 KiB
TypeScript
83 lines
3.5 KiB
TypeScript
import { db } from "../databases/databases";
|
|
import { config } from "../config";
|
|
import { Request, Response } from "express";
|
|
import axios from "axios";
|
|
import { Logger } from "../utils/logger";
|
|
|
|
// A cache of the number of chrome web store users
|
|
let chromeUsersCache = 0;
|
|
let firefoxUsersCache = 0;
|
|
|
|
// By the privacy friendly user counter
|
|
let apiUsersCache = 0;
|
|
|
|
let lastUserCountCheck = 0;
|
|
|
|
export async function getTotalStats(req: Request, res: Response): Promise<void> {
|
|
const userCountQuery = `(SELECT COUNT(*) FROM (SELECT DISTINCT "userID" from "sponsorTimes") t) "userCount",`;
|
|
|
|
const row = await db.prepare("get", `SELECT ${req.query.countContributingUsers ? userCountQuery : ""} COUNT(*) as "totalSubmissions",
|
|
SUM("views") as "viewCount", SUM(("endTime" - "startTime") / 60 * "views") as "minutesSaved" FROM "sponsorTimes" WHERE "shadowHidden" != 1 AND "votes" >= 0`, []);
|
|
|
|
if (row !== undefined) {
|
|
const extensionUsers = chromeUsersCache + firefoxUsersCache;
|
|
|
|
//send this result
|
|
res.send({
|
|
userCount: row.userCount,
|
|
activeUsers: extensionUsers,
|
|
apiUsers: Math.max(apiUsersCache, extensionUsers),
|
|
viewCount: row.viewCount,
|
|
totalSubmissions: row.totalSubmissions,
|
|
minutesSaved: row.minutesSaved,
|
|
});
|
|
|
|
// Check if the cache should be updated (every ~14 hours)
|
|
const now = Date.now();
|
|
if (now - lastUserCountCheck > 5000000) {
|
|
lastUserCountCheck = now;
|
|
|
|
updateExtensionUsers();
|
|
}
|
|
}
|
|
}
|
|
|
|
function updateExtensionUsers() {
|
|
if (config.userCounterURL) {
|
|
axios.get(`${config.userCounterURL}/api/v1/userCount`)
|
|
.then(res => {
|
|
apiUsersCache = Math.max(apiUsersCache, res.data.userCount);
|
|
})
|
|
.catch(() => Logger.debug(`Failing to connect to user counter at: ${config.userCounterURL}`));
|
|
}
|
|
|
|
const mozillaAddonsUrl = "https://addons.mozilla.org/api/v3/addons/addon/sponsorblock/";
|
|
const chromeExtensionUrl = "https://chrome.google.com/webstore/detail/sponsorblock-for-youtube/mnjggcdmjocbbbhaepdhchncahnbgone";
|
|
|
|
axios.get(mozillaAddonsUrl)
|
|
.then(res => {
|
|
firefoxUsersCache = res.data.average_daily_users;
|
|
axios.get(chromeExtensionUrl)
|
|
.then(res => {
|
|
const body = res.data;
|
|
// 2021-01-05
|
|
// [...]<span><meta itemprop="interactionCount" content="UserDownloads:100.000+"/><meta itemprop="opera[...]
|
|
const matchingString = '"UserDownloads:';
|
|
const matchingStringLen = matchingString.length;
|
|
const userDownloadsStartIndex = body.indexOf(matchingString);
|
|
if (userDownloadsStartIndex >= 0) {
|
|
const closingQuoteIndex = body.indexOf('"', userDownloadsStartIndex + matchingStringLen);
|
|
const userDownloadsStr = body.substr(userDownloadsStartIndex + matchingStringLen, closingQuoteIndex - userDownloadsStartIndex).replace(",","").replace(".","");
|
|
chromeUsersCache = parseInt(userDownloadsStr);
|
|
}
|
|
else {
|
|
lastUserCountCheck = 0;
|
|
}
|
|
})
|
|
.catch(() => Logger.debug(`Failing to connect to ${chromeExtensionUrl}`));
|
|
})
|
|
.catch(() => {
|
|
Logger.debug(`Failing to connect to ${mozillaAddonsUrl}`);
|
|
});
|
|
}
|