UNPKG

@a11ywatch/core

Version:
81 lines 3.76 kB
"use strict"; var __awaiter = (this && this.__awaiter) || function (thisArg, _arguments, P, generator) { function adopt(value) { return value instanceof P ? value : new P(function (resolve) { resolve(value); }); } return new (P || (P = Promise))(function (resolve, reject) { function fulfilled(value) { try { step(generator.next(value)); } catch (e) { reject(e); } } function rejected(value) { try { step(generator["throw"](value)); } catch (e) { reject(e); } } function step(result) { result.done ? resolve(result.value) : adopt(result.value).then(fulfilled, rejected); } step((generator = generator.apply(thisArg, _arguments || [])).next()); }); }; Object.defineProperty(exports, "__esModule", { value: true }); exports.getScanEnabled = exports.validateScanEnabled = exports.updateScanAttempt = void 0; const date_fns_1 = require("date-fns"); const website_source_builder_1 = require("@a11ywatch/website-source-builder"); const find_1 = require("../find"); const config_1 = require("../../../../config/config"); const extracter_1 = require("../../../../web/params/extracter"); const validateResetDate = (date) => (0, date_fns_1.differenceInMonths)(date, new Date()); const updateScanAttempt = ({ userId, user, collection, }) => __awaiter(void 0, void 0, void 0, function* () { var _a; if (config_1.SUPER_MODE) { return [true, null, collection]; } if (!collection && (0, extracter_1.validateUID)(userId)) { [user, collection] = yield (0, find_1.getUser)({ id: userId }); } if (user && !user.emailConfirmed) { return [false, user, collection]; } if (user) { const currentDate = new Date(); const scanInfo = (_a = user === null || user === void 0 ? void 0 : user.scanInfo) !== null && _a !== void 0 ? _a : { lastScanDate: null, totalUptime: 0, creditedUptime: 0, usageLimit: 0, }; if (!user.role && validateResetDate(user.usageAnchorDate)) { user.usageAnchorDate = (0, date_fns_1.addMonths)(user.usageAnchorDate, 1); scanInfo.totalUptime = 0; } const canScan = (0, exports.validateScanEnabled)({ user: { role: user === null || user === void 0 ? void 0 : user.role, scanInfo, }, }); if (canScan) { scanInfo.lastScanDate = currentDate; const updateProps = { usageAnchorDate: user.usageAnchorDate, scanInfo, }; try { yield collection.findOneAndUpdate({ id: user.id }, { $set: updateProps }); } catch (e) { console.error(e); } } return [canScan, user, collection]; } return [false, user, collection]; }); exports.updateScanAttempt = updateScanAttempt; const validateScanEnabled = ({ user }) => { var _a, _b, _c; if (!config_1.SUPER_MODE) { const totalUptime = (_b = (_a = user === null || user === void 0 ? void 0 : user.scanInfo) === null || _a === void 0 ? void 0 : _a.totalUptime) !== null && _b !== void 0 ? _b : 0; const role = (_c = user === null || user === void 0 ? void 0 : user.role) !== null && _c !== void 0 ? _c : 0; return totalUptime <= (0, website_source_builder_1.getUsageLimitsMs)(role); } return true; }; exports.validateScanEnabled = validateScanEnabled; const getScanEnabled = ({ userId }) => __awaiter(void 0, void 0, void 0, function* () { const [user] = yield (0, find_1.getUser)({ id: userId }); return (0, exports.validateScanEnabled)({ user }); }); exports.getScanEnabled = getScanEnabled; //# sourceMappingURL=scan-attempt.js.map