@prosopo/provider 3.1.3 → 3.2.1
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/CHANGELOG.md +54 -0
- package/dist/api/admin/apiAdminRoutesProvider.js +26 -21
- package/dist/api/admin/apiRegisterSiteKeyEndpoint.js +21 -20
- package/dist/api/admin/apiRemoveDetectorKeyEndpoint.js +27 -27
- package/dist/api/admin/apiUpdateDetectorKeyEndpoint.js +33 -33
- package/dist/api/admin/createApiAdminRoutesProvider.js +8 -5
- package/dist/api/blacklistRequestInspector.js +116 -98
- package/dist/api/block.js +13 -8
- package/dist/api/captcha.js +519 -356
- package/dist/api/domainMiddleware.js +75 -68
- package/dist/api/headerCheckMiddleware.js +26 -25
- package/dist/api/ignoreMiddleware.js +12 -10
- package/dist/api/ja4Middleware.js +75 -80
- package/dist/api/public.js +26 -23
- package/dist/api/robotsMiddleware.js +11 -9
- package/dist/api/validateAddress.js +20 -18
- package/dist/api/verify.js +133 -95
- package/dist/cjs/api/blacklistRequestInspector.cjs +4 -6
- package/dist/cjs/api/captcha.cjs +45 -36
- package/dist/cjs/api/ja4Middleware.cjs +4 -1
- package/dist/cjs/tasks/captchaManager.cjs +24 -10
- package/dist/cjs/tasks/frictionless/frictionlessTasks.cjs +0 -3
- package/dist/cjs/tasks/powCaptcha/powTasksUtils.cjs +1 -1
- package/dist/index.js +38 -15
- package/dist/rules/lang.js +14 -14
- package/dist/schedulers/captchaScheduler.js +28 -23
- package/dist/schedulers/getClientList.js +29 -24
- package/dist/tasks/captchaManager.js +109 -85
- package/dist/tasks/client/clientTasks.js +265 -204
- package/dist/tasks/dataset/datasetTasks.js +27 -16
- package/dist/tasks/dataset/datasetTasksUtils.js +31 -31
- package/dist/tasks/detection/decodePayload.js +378 -208
- package/dist/tasks/detection/getBotScore.js +12 -10
- package/dist/tasks/frictionless/frictionlessTasks.js +117 -119
- package/dist/tasks/frictionless/frictionlessTasksUtils.js +10 -5
- package/dist/tasks/imgCaptcha/imgCaptchaTasks.js +360 -271
- package/dist/tasks/imgCaptcha/imgCaptchaTasksUtils.js +23 -16
- package/dist/tasks/index.js +4 -2
- package/dist/tasks/powCaptcha/powTasks.js +157 -97
- package/dist/tasks/powCaptcha/powTasksUtils.js +24 -20
- package/dist/tasks/tasks.js +53 -29
- package/dist/util.js +98 -88
- package/package.json +31 -27
- package/vite.cjs.config.ts +4 -1
- package/vite.esm.config.ts +20 -0
- package/vite.test.config.ts +15 -3
- package/dist/api/admin/apiAdminRoutesProvider.d.ts +0 -9
- package/dist/api/admin/apiAdminRoutesProvider.d.ts.map +0 -1
- package/dist/api/admin/apiAdminRoutesProvider.js.map +0 -1
- package/dist/api/admin/apiRegisterSiteKeyEndpoint.d.ts +0 -14
- package/dist/api/admin/apiRegisterSiteKeyEndpoint.d.ts.map +0 -1
- package/dist/api/admin/apiRegisterSiteKeyEndpoint.js.map +0 -1
- package/dist/api/admin/apiRemoveDetectorKeyEndpoint.d.ts +0 -14
- package/dist/api/admin/apiRemoveDetectorKeyEndpoint.d.ts.map +0 -1
- package/dist/api/admin/apiRemoveDetectorKeyEndpoint.js.map +0 -1
- package/dist/api/admin/apiUpdateDetectorKeyEndpoint.d.ts +0 -14
- package/dist/api/admin/apiUpdateDetectorKeyEndpoint.d.ts.map +0 -1
- package/dist/api/admin/apiUpdateDetectorKeyEndpoint.js.map +0 -1
- package/dist/api/admin/createApiAdminRoutesProvider.d.ts +0 -4
- package/dist/api/admin/createApiAdminRoutesProvider.d.ts.map +0 -1
- package/dist/api/admin/createApiAdminRoutesProvider.js.map +0 -1
- package/dist/api/blacklistRequestInspector.d.ts +0 -44
- package/dist/api/blacklistRequestInspector.d.ts.map +0 -1
- package/dist/api/blacklistRequestInspector.js.map +0 -1
- package/dist/api/block.d.ts +0 -3
- package/dist/api/block.d.ts.map +0 -1
- package/dist/api/block.js.map +0 -1
- package/dist/api/captcha.d.ts +0 -4
- package/dist/api/captcha.d.ts.map +0 -1
- package/dist/api/captcha.js.map +0 -1
- package/dist/api/domainMiddleware.d.ts +0 -4
- package/dist/api/domainMiddleware.d.ts.map +0 -1
- package/dist/api/domainMiddleware.js.map +0 -1
- package/dist/api/headerCheckMiddleware.d.ts +0 -4
- package/dist/api/headerCheckMiddleware.d.ts.map +0 -1
- package/dist/api/headerCheckMiddleware.js.map +0 -1
- package/dist/api/ignoreMiddleware.d.ts +0 -3
- package/dist/api/ignoreMiddleware.d.ts.map +0 -1
- package/dist/api/ignoreMiddleware.js.map +0 -1
- package/dist/api/ja4Middleware.d.ts +0 -10
- package/dist/api/ja4Middleware.d.ts.map +0 -1
- package/dist/api/ja4Middleware.js.map +0 -1
- package/dist/api/public.d.ts +0 -3
- package/dist/api/public.d.ts.map +0 -1
- package/dist/api/public.js.map +0 -1
- package/dist/api/robotsMiddleware.d.ts +0 -3
- package/dist/api/robotsMiddleware.d.ts.map +0 -1
- package/dist/api/robotsMiddleware.js.map +0 -1
- package/dist/api/validateAddress.d.ts +0 -5
- package/dist/api/validateAddress.d.ts.map +0 -1
- package/dist/api/validateAddress.js.map +0 -1
- package/dist/api/verify.d.ts +0 -4
- package/dist/api/verify.d.ts.map +0 -1
- package/dist/api/verify.js.map +0 -1
- package/dist/index.d.ts +0 -15
- package/dist/index.d.ts.map +0 -1
- package/dist/index.js.map +0 -1
- package/dist/rules/lang.d.ts +0 -3
- package/dist/rules/lang.d.ts.map +0 -1
- package/dist/rules/lang.js.map +0 -1
- package/dist/schedulers/captchaScheduler.d.ts +0 -4
- package/dist/schedulers/captchaScheduler.d.ts.map +0 -1
- package/dist/schedulers/captchaScheduler.js.map +0 -1
- package/dist/schedulers/getClientList.d.ts +0 -4
- package/dist/schedulers/getClientList.d.ts.map +0 -1
- package/dist/schedulers/getClientList.js.map +0 -1
- package/dist/tasks/captchaManager.d.ts +0 -48
- package/dist/tasks/captchaManager.d.ts.map +0 -1
- package/dist/tasks/captchaManager.js.map +0 -1
- package/dist/tasks/client/clientTasks.d.ts +0 -21
- package/dist/tasks/client/clientTasks.d.ts.map +0 -1
- package/dist/tasks/client/clientTasks.js.map +0 -1
- package/dist/tasks/dataset/datasetTasks.d.ts +0 -13
- package/dist/tasks/dataset/datasetTasks.d.ts.map +0 -1
- package/dist/tasks/dataset/datasetTasks.js.map +0 -1
- package/dist/tasks/dataset/datasetTasksUtils.d.ts +0 -3
- package/dist/tasks/dataset/datasetTasksUtils.d.ts.map +0 -1
- package/dist/tasks/dataset/datasetTasksUtils.js.map +0 -1
- package/dist/tasks/detection/decodePayload.d.ts +0 -5
- package/dist/tasks/detection/decodePayload.d.ts.map +0 -1
- package/dist/tasks/detection/decodePayload.js.map +0 -1
- package/dist/tasks/detection/getBotScore.d.ts +0 -5
- package/dist/tasks/detection/getBotScore.d.ts.map +0 -1
- package/dist/tasks/detection/getBotScore.js.map +0 -1
- package/dist/tasks/frictionless/frictionlessTasks.d.ts +0 -23
- package/dist/tasks/frictionless/frictionlessTasks.d.ts.map +0 -1
- package/dist/tasks/frictionless/frictionlessTasks.js.map +0 -1
- package/dist/tasks/frictionless/frictionlessTasksUtils.d.ts +0 -5
- package/dist/tasks/frictionless/frictionlessTasksUtils.d.ts.map +0 -1
- package/dist/tasks/frictionless/frictionlessTasksUtils.js.map +0 -1
- package/dist/tasks/imgCaptcha/imgCaptchaTasks.d.ts +0 -29
- package/dist/tasks/imgCaptcha/imgCaptchaTasks.d.ts.map +0 -1
- package/dist/tasks/imgCaptcha/imgCaptchaTasks.js.map +0 -1
- package/dist/tasks/imgCaptcha/imgCaptchaTasksUtils.d.ts +0 -7
- package/dist/tasks/imgCaptcha/imgCaptchaTasksUtils.d.ts.map +0 -1
- package/dist/tasks/imgCaptcha/imgCaptchaTasksUtils.js.map +0 -1
- package/dist/tasks/index.d.ts +0 -2
- package/dist/tasks/index.d.ts.map +0 -1
- package/dist/tasks/index.js.map +0 -1
- package/dist/tasks/powCaptcha/powTasks.d.ts +0 -16
- package/dist/tasks/powCaptcha/powTasks.d.ts.map +0 -1
- package/dist/tasks/powCaptcha/powTasks.js.map +0 -1
- package/dist/tasks/powCaptcha/powTasksUtils.d.ts +0 -3
- package/dist/tasks/powCaptcha/powTasksUtils.d.ts.map +0 -1
- package/dist/tasks/powCaptcha/powTasksUtils.js.map +0 -1
- package/dist/tasks/tasks.d.ts +0 -25
- package/dist/tasks/tasks.d.ts.map +0 -1
- package/dist/tasks/tasks.js.map +0 -1
- package/dist/tests/index.d.ts +0 -2
- package/dist/tests/index.d.ts.map +0 -1
- package/dist/tests/index.js +0 -2
- package/dist/tests/index.js.map +0 -1
- package/dist/tests/integration/imgCaptcha.integration.test.d.ts +0 -2
- package/dist/tests/integration/imgCaptcha.integration.test.d.ts.map +0 -1
- package/dist/tests/integration/imgCaptcha.integration.test.js +0 -261
- package/dist/tests/integration/imgCaptcha.integration.test.js.map +0 -1
- package/dist/tests/integration/mocks/solvedTestCaptchas.d.ts +0 -32
- package/dist/tests/integration/mocks/solvedTestCaptchas.d.ts.map +0 -1
- package/dist/tests/integration/mocks/solvedTestCaptchas.js +0 -1046
- package/dist/tests/integration/mocks/solvedTestCaptchas.js.map +0 -1
- package/dist/tests/integration/powCaptcha.integration.test.d.ts +0 -2
- package/dist/tests/integration/powCaptcha.integration.test.d.ts.map +0 -1
- package/dist/tests/integration/powCaptcha.integration.test.js +0 -299
- package/dist/tests/integration/powCaptcha.integration.test.js.map +0 -1
- package/dist/tests/integration/registerSitekey.d.ts +0 -3
- package/dist/tests/integration/registerSitekey.d.ts.map +0 -1
- package/dist/tests/integration/registerSitekey.js +0 -39
- package/dist/tests/integration/registerSitekey.js.map +0 -1
- package/dist/tests/unit/api/ignoreMiddleware.unit.test.d.ts +0 -2
- package/dist/tests/unit/api/ignoreMiddleware.unit.test.d.ts.map +0 -1
- package/dist/tests/unit/api/ignoreMiddleware.unit.test.js +0 -43
- package/dist/tests/unit/api/ignoreMiddleware.unit.test.js.map +0 -1
- package/dist/tests/unit/api/ja4Middleware.unit.test.d.ts +0 -2
- package/dist/tests/unit/api/ja4Middleware.unit.test.d.ts.map +0 -1
- package/dist/tests/unit/api/ja4Middleware.unit.test.js +0 -71
- package/dist/tests/unit/api/ja4Middleware.unit.test.js.map +0 -1
- package/dist/tests/unit/schedulers/captchaScheduler.unit.test.d.ts +0 -2
- package/dist/tests/unit/schedulers/captchaScheduler.unit.test.d.ts.map +0 -1
- package/dist/tests/unit/schedulers/captchaScheduler.unit.test.js +0 -75
- package/dist/tests/unit/schedulers/captchaScheduler.unit.test.js.map +0 -1
- package/dist/tests/unit/tasks/captchaManager.unit.test.d.ts +0 -2
- package/dist/tests/unit/tasks/captchaManager.unit.test.d.ts.map +0 -1
- package/dist/tests/unit/tasks/captchaManager.unit.test.js +0 -236
- package/dist/tests/unit/tasks/captchaManager.unit.test.js.map +0 -1
- package/dist/tests/unit/tasks/client/clientTasks.unit.test.d.ts +0 -2
- package/dist/tests/unit/tasks/client/clientTasks.unit.test.d.ts.map +0 -1
- package/dist/tests/unit/tasks/client/clientTasks.unit.test.js +0 -277
- package/dist/tests/unit/tasks/client/clientTasks.unit.test.js.map +0 -1
- package/dist/tests/unit/tasks/dataset/datasetTasks.unit.test.d.ts +0 -2
- package/dist/tests/unit/tasks/dataset/datasetTasks.unit.test.d.ts.map +0 -1
- package/dist/tests/unit/tasks/dataset/datasetTasks.unit.test.js +0 -93
- package/dist/tests/unit/tasks/dataset/datasetTasks.unit.test.js.map +0 -1
- package/dist/tests/unit/tasks/dataset/datasetTasksUtils.unit.test.d.ts +0 -2
- package/dist/tests/unit/tasks/dataset/datasetTasksUtils.unit.test.d.ts.map +0 -1
- package/dist/tests/unit/tasks/dataset/datasetTasksUtils.unit.test.js +0 -75
- package/dist/tests/unit/tasks/dataset/datasetTasksUtils.unit.test.js.map +0 -1
- package/dist/tests/unit/tasks/frictionless/frictionlessTasks.unit.test.d.ts +0 -2
- package/dist/tests/unit/tasks/frictionless/frictionlessTasks.unit.test.d.ts.map +0 -1
- package/dist/tests/unit/tasks/frictionless/frictionlessTasks.unit.test.js +0 -68
- package/dist/tests/unit/tasks/frictionless/frictionlessTasks.unit.test.js.map +0 -1
- package/dist/tests/unit/tasks/frictionless/frictionlessTasksUtils.unit.test.d.ts +0 -2
- package/dist/tests/unit/tasks/frictionless/frictionlessTasksUtils.unit.test.d.ts.map +0 -1
- package/dist/tests/unit/tasks/frictionless/frictionlessTasksUtils.unit.test.js +0 -37
- package/dist/tests/unit/tasks/frictionless/frictionlessTasksUtils.unit.test.js.map +0 -1
- package/dist/tests/unit/tasks/imgCaptcha/imgCaptchaTasks.unit.test.d.ts +0 -2
- package/dist/tests/unit/tasks/imgCaptcha/imgCaptchaTasks.unit.test.d.ts.map +0 -1
- package/dist/tests/unit/tasks/imgCaptcha/imgCaptchaTasks.unit.test.js +0 -402
- package/dist/tests/unit/tasks/imgCaptcha/imgCaptchaTasks.unit.test.js.map +0 -1
- package/dist/tests/unit/tasks/imgCaptcha/imgCaptchaTasksUtils.unit.test.d.ts +0 -2
- package/dist/tests/unit/tasks/imgCaptcha/imgCaptchaTasksUtils.unit.test.d.ts.map +0 -1
- package/dist/tests/unit/tasks/imgCaptcha/imgCaptchaTasksUtils.unit.test.js +0 -46
- package/dist/tests/unit/tasks/imgCaptcha/imgCaptchaTasksUtils.unit.test.js.map +0 -1
- package/dist/tests/unit/tasks/powCaptcha/powTasks.unit.test.d.ts +0 -2
- package/dist/tests/unit/tasks/powCaptcha/powTasks.unit.test.d.ts.map +0 -1
- package/dist/tests/unit/tasks/powCaptcha/powTasks.unit.test.js +0 -228
- package/dist/tests/unit/tasks/powCaptcha/powTasks.unit.test.js.map +0 -1
- package/dist/tests/unit/tasks/powCaptcha/powTasksUtils.unit.test.d.ts +0 -2
- package/dist/tests/unit/tasks/powCaptcha/powTasksUtils.unit.test.d.ts.map +0 -1
- package/dist/tests/unit/tasks/powCaptcha/powTasksUtils.unit.test.js +0 -68
- package/dist/tests/unit/tasks/powCaptcha/powTasksUtils.unit.test.js.map +0 -1
- package/dist/tests/unit/util.unit.test.d.ts +0 -2
- package/dist/tests/unit/util.unit.test.d.ts.map +0 -1
- package/dist/tests/unit/util.unit.test.js +0 -148
- package/dist/tests/unit/util.unit.test.js.map +0 -1
- package/dist/util.d.ts +0 -13
- package/dist/util.d.ts.map +0 -1
- package/dist/util.js.map +0 -1
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"datasetTasks.unit.test.d.ts","sourceRoot":"","sources":["../../../../../src/tests/unit/tasks/dataset/datasetTasks.unit.test.ts"],"names":[],"mappings":""}
|
|
@@ -1,93 +0,0 @@
|
|
|
1
|
-
import { getLogger } from "@prosopo/common";
|
|
2
|
-
import { parseCaptchaDataset } from "@prosopo/datasets";
|
|
3
|
-
import { ScheduledTaskSchema, } from "@prosopo/types-database";
|
|
4
|
-
import { beforeEach, describe, expect, it, vi } from "vitest";
|
|
5
|
-
import { DatasetManager } from "../../../../tasks/dataset/datasetTasks.js";
|
|
6
|
-
import * as datasetTasksUtils from "../../../../tasks/dataset/datasetTasksUtils.js";
|
|
7
|
-
const loggerOuter = getLogger("info", import.meta.url);
|
|
8
|
-
vi.mock("@prosopo/database", () => ({
|
|
9
|
-
saveCaptchaEvent: vi.fn(),
|
|
10
|
-
saveCaptchas: vi.fn(),
|
|
11
|
-
}));
|
|
12
|
-
vi.mock("@prosopo/datasets", () => ({
|
|
13
|
-
parseCaptchaDataset: vi.fn(),
|
|
14
|
-
}));
|
|
15
|
-
vi.spyOn(datasetTasksUtils, "providerValidateDataset");
|
|
16
|
-
describe("DatasetManager", () => {
|
|
17
|
-
let config;
|
|
18
|
-
let logger;
|
|
19
|
-
let captchaConfig;
|
|
20
|
-
let providerDB;
|
|
21
|
-
let datasetManager;
|
|
22
|
-
const collections = {};
|
|
23
|
-
beforeEach(() => {
|
|
24
|
-
config = {
|
|
25
|
-
devOnlyWatchEvents: true,
|
|
26
|
-
mongoEventsUri: "mongodb://localhost:27017/events",
|
|
27
|
-
mongoCaptchaUri: "mongodb://localhost:27017/captchas",
|
|
28
|
-
};
|
|
29
|
-
const mockLogger = {
|
|
30
|
-
debug: vi.fn().mockImplementation(loggerOuter.debug.bind(loggerOuter)),
|
|
31
|
-
log: vi.fn().mockImplementation(loggerOuter.log.bind(loggerOuter)),
|
|
32
|
-
info: vi.fn().mockImplementation(loggerOuter.info.bind(loggerOuter)),
|
|
33
|
-
error: vi.fn().mockImplementation(loggerOuter.error.bind(loggerOuter)),
|
|
34
|
-
trace: vi.fn().mockImplementation(loggerOuter.trace.bind(loggerOuter)),
|
|
35
|
-
fatal: vi.fn().mockImplementation(loggerOuter.fatal.bind(loggerOuter)),
|
|
36
|
-
warn: vi.fn().mockImplementation(loggerOuter.warn.bind(loggerOuter)),
|
|
37
|
-
};
|
|
38
|
-
logger = mockLogger;
|
|
39
|
-
captchaConfig = {
|
|
40
|
-
solved: { count: 5 },
|
|
41
|
-
unsolved: { count: 5 },
|
|
42
|
-
};
|
|
43
|
-
collections.schedulers = {};
|
|
44
|
-
collections.schedulers.records = {};
|
|
45
|
-
collections.schedulers.nextID = 0;
|
|
46
|
-
collections.schedulers.time = 0;
|
|
47
|
-
providerDB = {
|
|
48
|
-
storeDataset: vi.fn(),
|
|
49
|
-
getUnstoredDappUserCommitments: vi.fn().mockResolvedValue([]),
|
|
50
|
-
markDappUserCommitmentsStored: vi.fn(),
|
|
51
|
-
markDappUserPoWCommitmentsStored: vi.fn(),
|
|
52
|
-
getUnstoredDappUserPoWCommitments: vi.fn().mockResolvedValue([]),
|
|
53
|
-
createScheduledTaskStatus: vi.fn((taskName, status) => {
|
|
54
|
-
const _id = collections.schedulers.nextID;
|
|
55
|
-
collections.schedulers.records[_id] = ScheduledTaskSchema.parse({
|
|
56
|
-
_id,
|
|
57
|
-
processName: taskName,
|
|
58
|
-
status,
|
|
59
|
-
datetime: collections.schedulers.time,
|
|
60
|
-
});
|
|
61
|
-
collections.schedulers.nextID += 1;
|
|
62
|
-
collections.schedulers.time += 1;
|
|
63
|
-
return _id;
|
|
64
|
-
}),
|
|
65
|
-
updateScheduledTaskStatus: vi.fn((taskID, status, result) => {
|
|
66
|
-
const task = collections.schedulers.records[taskID];
|
|
67
|
-
task.status = status;
|
|
68
|
-
task.result = result;
|
|
69
|
-
task.updated = collections.schedulers.time;
|
|
70
|
-
collections.schedulers.time += 1;
|
|
71
|
-
}),
|
|
72
|
-
getLastScheduledTaskStatus: vi.fn((taskID, status) => {
|
|
73
|
-
return (Object.keys(collections.schedulers.records)
|
|
74
|
-
.map((key) => collections.schedulers.records[key])
|
|
75
|
-
.find((task) => task.processName === taskID && task.status === status));
|
|
76
|
-
}),
|
|
77
|
-
};
|
|
78
|
-
datasetManager = new DatasetManager(config, logger, captchaConfig, providerDB);
|
|
79
|
-
vi.clearAllMocks();
|
|
80
|
-
});
|
|
81
|
-
it("should set the provider dataset from a file", async () => {
|
|
82
|
-
const mockFile = { captchas: [] };
|
|
83
|
-
const mockDatasetRaw = { captchas: [], format: "SelectAll" };
|
|
84
|
-
const mockValidatedDataset = { datasetId: "123", datasetContentId: "456" };
|
|
85
|
-
parseCaptchaDataset.mockReturnValue(mockDatasetRaw);
|
|
86
|
-
datasetTasksUtils.providerValidateDataset.mockResolvedValue(mockValidatedDataset);
|
|
87
|
-
await datasetManager.providerSetDatasetFromFile(mockFile);
|
|
88
|
-
expect(parseCaptchaDataset).toHaveBeenCalledWith(mockFile);
|
|
89
|
-
expect(datasetTasksUtils.providerValidateDataset).toHaveBeenCalledWith(mockDatasetRaw, captchaConfig.solved.count, captchaConfig.unsolved.count);
|
|
90
|
-
expect(providerDB.storeDataset).toHaveBeenCalledWith(mockValidatedDataset);
|
|
91
|
-
});
|
|
92
|
-
});
|
|
93
|
-
//# sourceMappingURL=datasetTasks.unit.test.js.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"datasetTasks.unit.test.js","sourceRoot":"","sources":["../../../../../src/tests/unit/tasks/dataset/datasetTasks.unit.test.ts"],"names":[],"mappings":"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"}
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"datasetTasksUtils.unit.test.d.ts","sourceRoot":"","sources":["../../../../../src/tests/unit/tasks/dataset/datasetTasksUtils.unit.test.ts"],"names":[],"mappings":""}
|
|
@@ -1,75 +0,0 @@
|
|
|
1
|
-
import { ProsopoEnvError } from "@prosopo/common";
|
|
2
|
-
import { buildDataset } from "@prosopo/datasets";
|
|
3
|
-
import { beforeEach, describe, expect, it, vi } from "vitest";
|
|
4
|
-
import { providerValidateDataset } from "../../../../tasks/dataset/datasetTasksUtils.js";
|
|
5
|
-
vi.mock("@prosopo/datasets", () => ({
|
|
6
|
-
buildDataset: vi.fn(),
|
|
7
|
-
}));
|
|
8
|
-
describe("providerValidateDataset", () => {
|
|
9
|
-
beforeEach(() => {
|
|
10
|
-
vi.clearAllMocks();
|
|
11
|
-
});
|
|
12
|
-
it("should throw an error if captchas count is less than configured", async () => {
|
|
13
|
-
const datasetRaw = {
|
|
14
|
-
captchas: [],
|
|
15
|
-
};
|
|
16
|
-
const minSolvedCaptchas = 5;
|
|
17
|
-
const minUnsolvedCaptchas = 5;
|
|
18
|
-
await expect(providerValidateDataset(datasetRaw, minSolvedCaptchas, minUnsolvedCaptchas)).rejects.toThrow(new ProsopoEnvError("DATASET.CAPTCHAS_COUNT_LESS_THAN_CONFIGURED", {
|
|
19
|
-
context: { failedFuncName: "providerValidateDataset" },
|
|
20
|
-
}));
|
|
21
|
-
});
|
|
22
|
-
it("should throw an error if solved captchas count is less than configured", async () => {
|
|
23
|
-
const datasetRaw = {
|
|
24
|
-
captchas: [{ solution: null }, { solution: null }, { solution: null }],
|
|
25
|
-
};
|
|
26
|
-
const minSolvedCaptchas = 2;
|
|
27
|
-
const minUnsolvedCaptchas = 1;
|
|
28
|
-
await expect(providerValidateDataset(datasetRaw, minSolvedCaptchas, minUnsolvedCaptchas)).rejects.toThrow(new ProsopoEnvError("DATASET.SOLUTIONS_COUNT_LESS_THAN_CONFIGURED", {
|
|
29
|
-
context: { failedFuncName: "providerValidateDataset" },
|
|
30
|
-
}));
|
|
31
|
-
});
|
|
32
|
-
it("should throw an error if unsolved captchas count is less than configured", async () => {
|
|
33
|
-
const datasetRaw = {
|
|
34
|
-
captchas: [{ solution: "sol1" }, { solution: "sol2" }],
|
|
35
|
-
};
|
|
36
|
-
const minSolvedCaptchas = 1;
|
|
37
|
-
const minUnsolvedCaptchas = 2;
|
|
38
|
-
await expect(providerValidateDataset(datasetRaw, minSolvedCaptchas, minUnsolvedCaptchas)).rejects.toThrow(new ProsopoEnvError("DATASET.CAPTCHAS_COUNT_LESS_THAN_CONFIGURED", {
|
|
39
|
-
context: { failedFuncName: "providerValidateDataset" },
|
|
40
|
-
}));
|
|
41
|
-
});
|
|
42
|
-
it("should throw an error if datasetId or datasetContentId is undefined", async () => {
|
|
43
|
-
const datasetRaw = {
|
|
44
|
-
captchas: [{ solution: "sol1" }, { solution: "sol2" }],
|
|
45
|
-
};
|
|
46
|
-
const minSolvedCaptchas = 1;
|
|
47
|
-
const minUnsolvedCaptchas = 1;
|
|
48
|
-
buildDataset.mockResolvedValue({
|
|
49
|
-
datasetId: null,
|
|
50
|
-
datasetContentId: null,
|
|
51
|
-
});
|
|
52
|
-
await expect(providerValidateDataset(datasetRaw, minSolvedCaptchas, minUnsolvedCaptchas)).rejects.toThrow(new ProsopoEnvError("DATASET.DATASET_ID_UNDEFINED", {
|
|
53
|
-
context: {
|
|
54
|
-
failedFuncName: "providerValidateDataset",
|
|
55
|
-
datasetId: null,
|
|
56
|
-
datasetContentId: null,
|
|
57
|
-
},
|
|
58
|
-
}));
|
|
59
|
-
});
|
|
60
|
-
it("should return the dataset if validation is successful", async () => {
|
|
61
|
-
const datasetRaw = {
|
|
62
|
-
captchas: [{ solution: "solution" }, {}],
|
|
63
|
-
};
|
|
64
|
-
const minSolvedCaptchas = 1;
|
|
65
|
-
const minUnsolvedCaptchas = 1;
|
|
66
|
-
const mockDataset = {
|
|
67
|
-
datasetId: "datasetId",
|
|
68
|
-
datasetContentId: "datasetContentId",
|
|
69
|
-
};
|
|
70
|
-
buildDataset.mockResolvedValue(mockDataset);
|
|
71
|
-
const result = await providerValidateDataset(datasetRaw, minSolvedCaptchas, minUnsolvedCaptchas);
|
|
72
|
-
expect(result).toEqual(mockDataset);
|
|
73
|
-
});
|
|
74
|
-
});
|
|
75
|
-
//# sourceMappingURL=datasetTasksUtils.unit.test.js.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"datasetTasksUtils.unit.test.js","sourceRoot":"","sources":["../../../../../src/tests/unit/tasks/dataset/datasetTasksUtils.unit.test.ts"],"names":[],"mappings":"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"}
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"frictionlessTasks.unit.test.d.ts","sourceRoot":"","sources":["../../../../../src/tests/unit/tasks/frictionless/frictionlessTasks.unit.test.ts"],"names":[],"mappings":""}
|
|
@@ -1,68 +0,0 @@
|
|
|
1
|
-
import { FrictionlessPenalties, } from "@prosopo/types";
|
|
2
|
-
import { AccessPolicyType, } from "@prosopo/user-access-policy";
|
|
3
|
-
import { beforeEach, describe, expect, it, vi } from "vitest";
|
|
4
|
-
import { FrictionlessManager } from "../../../../tasks/frictionless/frictionlessTasks.js";
|
|
5
|
-
describe("Frictionless Task Manager", () => {
|
|
6
|
-
let db;
|
|
7
|
-
let pair;
|
|
8
|
-
let frictionlessTaskManager;
|
|
9
|
-
let config;
|
|
10
|
-
beforeEach(() => {
|
|
11
|
-
db = {
|
|
12
|
-
updateFrictionlessTokenRecord: vi.fn(),
|
|
13
|
-
};
|
|
14
|
-
pair = {
|
|
15
|
-
sign: vi.fn(),
|
|
16
|
-
address: "testAddress",
|
|
17
|
-
};
|
|
18
|
-
config = {
|
|
19
|
-
penalties: FrictionlessPenalties.parse({}),
|
|
20
|
-
captchas: {
|
|
21
|
-
solved: { count: 5 },
|
|
22
|
-
unsolved: { count: 5 },
|
|
23
|
-
},
|
|
24
|
-
lRules: { en: 1 },
|
|
25
|
-
};
|
|
26
|
-
frictionlessTaskManager = new FrictionlessManager(db, pair, config);
|
|
27
|
-
vi.clearAllMocks();
|
|
28
|
-
});
|
|
29
|
-
describe("checkLangRules", () => {
|
|
30
|
-
it("should return an inflated score if a lang rule is set", async () => {
|
|
31
|
-
const result = frictionlessTaskManager.checkLangRules("en");
|
|
32
|
-
expect(result).toBe(config.lRules?.en);
|
|
33
|
-
});
|
|
34
|
-
it("should return zero score if a lang rule is not set", async () => {
|
|
35
|
-
const result = frictionlessTaskManager.checkLangRules("de");
|
|
36
|
-
expect(result).toBe(0);
|
|
37
|
-
});
|
|
38
|
-
});
|
|
39
|
-
describe("scoreIncreaseAccessPolicy", () => {
|
|
40
|
-
it("should return the correct score increase for 0 score", async () => {
|
|
41
|
-
const accessPolicy = {
|
|
42
|
-
type: AccessPolicyType.Restrict,
|
|
43
|
-
frictionlessScore: 1,
|
|
44
|
-
};
|
|
45
|
-
const tokenId = "tokenId";
|
|
46
|
-
const result = await frictionlessTaskManager.scoreIncreaseAccessPolicy(accessPolicy, 0, 0, tokenId);
|
|
47
|
-
expect(result).toBe(1);
|
|
48
|
-
});
|
|
49
|
-
it("should return the correct score increase for an existing score", async () => {
|
|
50
|
-
const accessPolicy = {
|
|
51
|
-
type: AccessPolicyType.Restrict,
|
|
52
|
-
frictionlessScore: 1,
|
|
53
|
-
};
|
|
54
|
-
const existingScore = 0.1;
|
|
55
|
-
const tokenId = "tokenId";
|
|
56
|
-
const result = await frictionlessTaskManager.scoreIncreaseAccessPolicy(accessPolicy, existingScore, existingScore, tokenId);
|
|
57
|
-
expect(result).toBe(1.1);
|
|
58
|
-
});
|
|
59
|
-
});
|
|
60
|
-
describe("scoreIncreaseTimestamp", () => {
|
|
61
|
-
it("should return the correct score increase when a timestamp is more than the 10 mins old", async () => {
|
|
62
|
-
const defaults = FrictionlessPenalties.parse({});
|
|
63
|
-
const result = await frictionlessTaskManager.scoreIncreaseTimestamp(0, 0, 0, "tokenId");
|
|
64
|
-
expect(result).toBe(defaults.PENALTY_OLD_TIMESTAMP);
|
|
65
|
-
});
|
|
66
|
-
});
|
|
67
|
-
});
|
|
68
|
-
//# sourceMappingURL=frictionlessTasks.unit.test.js.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"frictionlessTasks.unit.test.js","sourceRoot":"","sources":["../../../../../src/tests/unit/tasks/frictionless/frictionlessTasks.unit.test.ts"],"names":[],"mappings":"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"}
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"frictionlessTasksUtils.unit.test.d.ts","sourceRoot":"","sources":["../../../../../src/tests/unit/tasks/frictionless/frictionlessTasksUtils.unit.test.ts"],"names":[],"mappings":""}
|
|
@@ -1,37 +0,0 @@
|
|
|
1
|
-
import { describe, expect, it } from "vitest";
|
|
2
|
-
import { computeFrictionlessScore } from "../../../../tasks/frictionless/frictionlessTasksUtils.js";
|
|
3
|
-
describe("Frictionless Task Utils", () => {
|
|
4
|
-
describe("computeFrictionlessScore", () => {
|
|
5
|
-
it("should return the minimum of 1 and the sum of all score components", async () => {
|
|
6
|
-
const scoreComponents = {
|
|
7
|
-
a: 0.2,
|
|
8
|
-
b: 0.3,
|
|
9
|
-
c: 0.4,
|
|
10
|
-
d: 0.1,
|
|
11
|
-
};
|
|
12
|
-
const result = computeFrictionlessScore(scoreComponents);
|
|
13
|
-
expect(result).toBe(1);
|
|
14
|
-
});
|
|
15
|
-
it("should return the minimum of 1 and the sum of all score components", async () => {
|
|
16
|
-
const scoreComponents = {
|
|
17
|
-
a: 0.1,
|
|
18
|
-
b: 0.1,
|
|
19
|
-
c: 0.1,
|
|
20
|
-
d: 0.1,
|
|
21
|
-
};
|
|
22
|
-
const result = computeFrictionlessScore(scoreComponents);
|
|
23
|
-
expect(result).toBe(0.4);
|
|
24
|
-
});
|
|
25
|
-
it("should return 1 if the sum of all score components is greater than 1", async () => {
|
|
26
|
-
const scoreComponents = {
|
|
27
|
-
a: 1,
|
|
28
|
-
b: 0.3,
|
|
29
|
-
c: 0.4,
|
|
30
|
-
d: 0.2,
|
|
31
|
-
};
|
|
32
|
-
const result = computeFrictionlessScore(scoreComponents);
|
|
33
|
-
expect(result).toBe(1);
|
|
34
|
-
});
|
|
35
|
-
});
|
|
36
|
-
});
|
|
37
|
-
//# sourceMappingURL=frictionlessTasksUtils.unit.test.js.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"frictionlessTasksUtils.unit.test.js","sourceRoot":"","sources":["../../../../../src/tests/unit/tasks/frictionless/frictionlessTasksUtils.unit.test.ts"],"names":[],"mappings":"AAaA,OAAO,EAAE,QAAQ,EAAE,MAAM,EAAE,EAAE,EAAE,MAAM,QAAQ,CAAC;AAC9C,OAAO,EAAE,wBAAwB,EAAE,MAAM,0DAA0D,CAAC;AAEpG,QAAQ,CAAC,yBAAyB,EAAE,GAAG,EAAE;IACxC,QAAQ,CAAC,0BAA0B,EAAE,GAAG,EAAE;QACzC,EAAE,CAAC,oEAAoE,EAAE,KAAK,IAAI,EAAE;YACnF,MAAM,eAAe,GAAG;gBACvB,CAAC,EAAE,GAAG;gBACN,CAAC,EAAE,GAAG;gBACN,CAAC,EAAE,GAAG;gBACN,CAAC,EAAE,GAAG;aACN,CAAC;YACF,MAAM,MAAM,GAAG,wBAAwB,CAAC,eAAe,CAAC,CAAC;YACzD,MAAM,CAAC,MAAM,CAAC,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC;QACxB,CAAC,CAAC,CAAC;QACH,EAAE,CAAC,oEAAoE,EAAE,KAAK,IAAI,EAAE;YACnF,MAAM,eAAe,GAAG;gBACvB,CAAC,EAAE,GAAG;gBACN,CAAC,EAAE,GAAG;gBACN,CAAC,EAAE,GAAG;gBACN,CAAC,EAAE,GAAG;aACN,CAAC;YACF,MAAM,MAAM,GAAG,wBAAwB,CAAC,eAAe,CAAC,CAAC;YACzD,MAAM,CAAC,MAAM,CAAC,CAAC,IAAI,CAAC,GAAG,CAAC,CAAC;QAC1B,CAAC,CAAC,CAAC;QACH,EAAE,CAAC,sEAAsE,EAAE,KAAK,IAAI,EAAE;YACrF,MAAM,eAAe,GAAG;gBACvB,CAAC,EAAE,CAAC;gBACJ,CAAC,EAAE,GAAG;gBACN,CAAC,EAAE,GAAG;gBACN,CAAC,EAAE,GAAG;aACN,CAAC;YACF,MAAM,MAAM,GAAG,wBAAwB,CAAC,eAAe,CAAC,CAAC;YACzD,MAAM,CAAC,MAAM,CAAC,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC;QACxB,CAAC,CAAC,CAAC;IACJ,CAAC,CAAC,CAAC;AACJ,CAAC,CAAC,CAAC"}
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"imgCaptchaTasks.unit.test.d.ts","sourceRoot":"","sources":["../../../../../src/tests/unit/tasks/imgCaptcha/imgCaptchaTasks.unit.test.ts"],"names":[],"mappings":""}
|