@a11ywatch/core
Version:
a11ywatch central API
81 lines • 3.76 kB
JavaScript
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
;