@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.
Files changed (227) hide show
  1. package/CHANGELOG.md +54 -0
  2. package/dist/api/admin/apiAdminRoutesProvider.js +26 -21
  3. package/dist/api/admin/apiRegisterSiteKeyEndpoint.js +21 -20
  4. package/dist/api/admin/apiRemoveDetectorKeyEndpoint.js +27 -27
  5. package/dist/api/admin/apiUpdateDetectorKeyEndpoint.js +33 -33
  6. package/dist/api/admin/createApiAdminRoutesProvider.js +8 -5
  7. package/dist/api/blacklistRequestInspector.js +116 -98
  8. package/dist/api/block.js +13 -8
  9. package/dist/api/captcha.js +519 -356
  10. package/dist/api/domainMiddleware.js +75 -68
  11. package/dist/api/headerCheckMiddleware.js +26 -25
  12. package/dist/api/ignoreMiddleware.js +12 -10
  13. package/dist/api/ja4Middleware.js +75 -80
  14. package/dist/api/public.js +26 -23
  15. package/dist/api/robotsMiddleware.js +11 -9
  16. package/dist/api/validateAddress.js +20 -18
  17. package/dist/api/verify.js +133 -95
  18. package/dist/cjs/api/blacklistRequestInspector.cjs +4 -6
  19. package/dist/cjs/api/captcha.cjs +45 -36
  20. package/dist/cjs/api/ja4Middleware.cjs +4 -1
  21. package/dist/cjs/tasks/captchaManager.cjs +24 -10
  22. package/dist/cjs/tasks/frictionless/frictionlessTasks.cjs +0 -3
  23. package/dist/cjs/tasks/powCaptcha/powTasksUtils.cjs +1 -1
  24. package/dist/index.js +38 -15
  25. package/dist/rules/lang.js +14 -14
  26. package/dist/schedulers/captchaScheduler.js +28 -23
  27. package/dist/schedulers/getClientList.js +29 -24
  28. package/dist/tasks/captchaManager.js +109 -85
  29. package/dist/tasks/client/clientTasks.js +265 -204
  30. package/dist/tasks/dataset/datasetTasks.js +27 -16
  31. package/dist/tasks/dataset/datasetTasksUtils.js +31 -31
  32. package/dist/tasks/detection/decodePayload.js +378 -208
  33. package/dist/tasks/detection/getBotScore.js +12 -10
  34. package/dist/tasks/frictionless/frictionlessTasks.js +117 -119
  35. package/dist/tasks/frictionless/frictionlessTasksUtils.js +10 -5
  36. package/dist/tasks/imgCaptcha/imgCaptchaTasks.js +360 -271
  37. package/dist/tasks/imgCaptcha/imgCaptchaTasksUtils.js +23 -16
  38. package/dist/tasks/index.js +4 -2
  39. package/dist/tasks/powCaptcha/powTasks.js +157 -97
  40. package/dist/tasks/powCaptcha/powTasksUtils.js +24 -20
  41. package/dist/tasks/tasks.js +53 -29
  42. package/dist/util.js +98 -88
  43. package/package.json +31 -27
  44. package/vite.cjs.config.ts +4 -1
  45. package/vite.esm.config.ts +20 -0
  46. package/vite.test.config.ts +15 -3
  47. package/dist/api/admin/apiAdminRoutesProvider.d.ts +0 -9
  48. package/dist/api/admin/apiAdminRoutesProvider.d.ts.map +0 -1
  49. package/dist/api/admin/apiAdminRoutesProvider.js.map +0 -1
  50. package/dist/api/admin/apiRegisterSiteKeyEndpoint.d.ts +0 -14
  51. package/dist/api/admin/apiRegisterSiteKeyEndpoint.d.ts.map +0 -1
  52. package/dist/api/admin/apiRegisterSiteKeyEndpoint.js.map +0 -1
  53. package/dist/api/admin/apiRemoveDetectorKeyEndpoint.d.ts +0 -14
  54. package/dist/api/admin/apiRemoveDetectorKeyEndpoint.d.ts.map +0 -1
  55. package/dist/api/admin/apiRemoveDetectorKeyEndpoint.js.map +0 -1
  56. package/dist/api/admin/apiUpdateDetectorKeyEndpoint.d.ts +0 -14
  57. package/dist/api/admin/apiUpdateDetectorKeyEndpoint.d.ts.map +0 -1
  58. package/dist/api/admin/apiUpdateDetectorKeyEndpoint.js.map +0 -1
  59. package/dist/api/admin/createApiAdminRoutesProvider.d.ts +0 -4
  60. package/dist/api/admin/createApiAdminRoutesProvider.d.ts.map +0 -1
  61. package/dist/api/admin/createApiAdminRoutesProvider.js.map +0 -1
  62. package/dist/api/blacklistRequestInspector.d.ts +0 -44
  63. package/dist/api/blacklistRequestInspector.d.ts.map +0 -1
  64. package/dist/api/blacklistRequestInspector.js.map +0 -1
  65. package/dist/api/block.d.ts +0 -3
  66. package/dist/api/block.d.ts.map +0 -1
  67. package/dist/api/block.js.map +0 -1
  68. package/dist/api/captcha.d.ts +0 -4
  69. package/dist/api/captcha.d.ts.map +0 -1
  70. package/dist/api/captcha.js.map +0 -1
  71. package/dist/api/domainMiddleware.d.ts +0 -4
  72. package/dist/api/domainMiddleware.d.ts.map +0 -1
  73. package/dist/api/domainMiddleware.js.map +0 -1
  74. package/dist/api/headerCheckMiddleware.d.ts +0 -4
  75. package/dist/api/headerCheckMiddleware.d.ts.map +0 -1
  76. package/dist/api/headerCheckMiddleware.js.map +0 -1
  77. package/dist/api/ignoreMiddleware.d.ts +0 -3
  78. package/dist/api/ignoreMiddleware.d.ts.map +0 -1
  79. package/dist/api/ignoreMiddleware.js.map +0 -1
  80. package/dist/api/ja4Middleware.d.ts +0 -10
  81. package/dist/api/ja4Middleware.d.ts.map +0 -1
  82. package/dist/api/ja4Middleware.js.map +0 -1
  83. package/dist/api/public.d.ts +0 -3
  84. package/dist/api/public.d.ts.map +0 -1
  85. package/dist/api/public.js.map +0 -1
  86. package/dist/api/robotsMiddleware.d.ts +0 -3
  87. package/dist/api/robotsMiddleware.d.ts.map +0 -1
  88. package/dist/api/robotsMiddleware.js.map +0 -1
  89. package/dist/api/validateAddress.d.ts +0 -5
  90. package/dist/api/validateAddress.d.ts.map +0 -1
  91. package/dist/api/validateAddress.js.map +0 -1
  92. package/dist/api/verify.d.ts +0 -4
  93. package/dist/api/verify.d.ts.map +0 -1
  94. package/dist/api/verify.js.map +0 -1
  95. package/dist/index.d.ts +0 -15
  96. package/dist/index.d.ts.map +0 -1
  97. package/dist/index.js.map +0 -1
  98. package/dist/rules/lang.d.ts +0 -3
  99. package/dist/rules/lang.d.ts.map +0 -1
  100. package/dist/rules/lang.js.map +0 -1
  101. package/dist/schedulers/captchaScheduler.d.ts +0 -4
  102. package/dist/schedulers/captchaScheduler.d.ts.map +0 -1
  103. package/dist/schedulers/captchaScheduler.js.map +0 -1
  104. package/dist/schedulers/getClientList.d.ts +0 -4
  105. package/dist/schedulers/getClientList.d.ts.map +0 -1
  106. package/dist/schedulers/getClientList.js.map +0 -1
  107. package/dist/tasks/captchaManager.d.ts +0 -48
  108. package/dist/tasks/captchaManager.d.ts.map +0 -1
  109. package/dist/tasks/captchaManager.js.map +0 -1
  110. package/dist/tasks/client/clientTasks.d.ts +0 -21
  111. package/dist/tasks/client/clientTasks.d.ts.map +0 -1
  112. package/dist/tasks/client/clientTasks.js.map +0 -1
  113. package/dist/tasks/dataset/datasetTasks.d.ts +0 -13
  114. package/dist/tasks/dataset/datasetTasks.d.ts.map +0 -1
  115. package/dist/tasks/dataset/datasetTasks.js.map +0 -1
  116. package/dist/tasks/dataset/datasetTasksUtils.d.ts +0 -3
  117. package/dist/tasks/dataset/datasetTasksUtils.d.ts.map +0 -1
  118. package/dist/tasks/dataset/datasetTasksUtils.js.map +0 -1
  119. package/dist/tasks/detection/decodePayload.d.ts +0 -5
  120. package/dist/tasks/detection/decodePayload.d.ts.map +0 -1
  121. package/dist/tasks/detection/decodePayload.js.map +0 -1
  122. package/dist/tasks/detection/getBotScore.d.ts +0 -5
  123. package/dist/tasks/detection/getBotScore.d.ts.map +0 -1
  124. package/dist/tasks/detection/getBotScore.js.map +0 -1
  125. package/dist/tasks/frictionless/frictionlessTasks.d.ts +0 -23
  126. package/dist/tasks/frictionless/frictionlessTasks.d.ts.map +0 -1
  127. package/dist/tasks/frictionless/frictionlessTasks.js.map +0 -1
  128. package/dist/tasks/frictionless/frictionlessTasksUtils.d.ts +0 -5
  129. package/dist/tasks/frictionless/frictionlessTasksUtils.d.ts.map +0 -1
  130. package/dist/tasks/frictionless/frictionlessTasksUtils.js.map +0 -1
  131. package/dist/tasks/imgCaptcha/imgCaptchaTasks.d.ts +0 -29
  132. package/dist/tasks/imgCaptcha/imgCaptchaTasks.d.ts.map +0 -1
  133. package/dist/tasks/imgCaptcha/imgCaptchaTasks.js.map +0 -1
  134. package/dist/tasks/imgCaptcha/imgCaptchaTasksUtils.d.ts +0 -7
  135. package/dist/tasks/imgCaptcha/imgCaptchaTasksUtils.d.ts.map +0 -1
  136. package/dist/tasks/imgCaptcha/imgCaptchaTasksUtils.js.map +0 -1
  137. package/dist/tasks/index.d.ts +0 -2
  138. package/dist/tasks/index.d.ts.map +0 -1
  139. package/dist/tasks/index.js.map +0 -1
  140. package/dist/tasks/powCaptcha/powTasks.d.ts +0 -16
  141. package/dist/tasks/powCaptcha/powTasks.d.ts.map +0 -1
  142. package/dist/tasks/powCaptcha/powTasks.js.map +0 -1
  143. package/dist/tasks/powCaptcha/powTasksUtils.d.ts +0 -3
  144. package/dist/tasks/powCaptcha/powTasksUtils.d.ts.map +0 -1
  145. package/dist/tasks/powCaptcha/powTasksUtils.js.map +0 -1
  146. package/dist/tasks/tasks.d.ts +0 -25
  147. package/dist/tasks/tasks.d.ts.map +0 -1
  148. package/dist/tasks/tasks.js.map +0 -1
  149. package/dist/tests/index.d.ts +0 -2
  150. package/dist/tests/index.d.ts.map +0 -1
  151. package/dist/tests/index.js +0 -2
  152. package/dist/tests/index.js.map +0 -1
  153. package/dist/tests/integration/imgCaptcha.integration.test.d.ts +0 -2
  154. package/dist/tests/integration/imgCaptcha.integration.test.d.ts.map +0 -1
  155. package/dist/tests/integration/imgCaptcha.integration.test.js +0 -261
  156. package/dist/tests/integration/imgCaptcha.integration.test.js.map +0 -1
  157. package/dist/tests/integration/mocks/solvedTestCaptchas.d.ts +0 -32
  158. package/dist/tests/integration/mocks/solvedTestCaptchas.d.ts.map +0 -1
  159. package/dist/tests/integration/mocks/solvedTestCaptchas.js +0 -1046
  160. package/dist/tests/integration/mocks/solvedTestCaptchas.js.map +0 -1
  161. package/dist/tests/integration/powCaptcha.integration.test.d.ts +0 -2
  162. package/dist/tests/integration/powCaptcha.integration.test.d.ts.map +0 -1
  163. package/dist/tests/integration/powCaptcha.integration.test.js +0 -299
  164. package/dist/tests/integration/powCaptcha.integration.test.js.map +0 -1
  165. package/dist/tests/integration/registerSitekey.d.ts +0 -3
  166. package/dist/tests/integration/registerSitekey.d.ts.map +0 -1
  167. package/dist/tests/integration/registerSitekey.js +0 -39
  168. package/dist/tests/integration/registerSitekey.js.map +0 -1
  169. package/dist/tests/unit/api/ignoreMiddleware.unit.test.d.ts +0 -2
  170. package/dist/tests/unit/api/ignoreMiddleware.unit.test.d.ts.map +0 -1
  171. package/dist/tests/unit/api/ignoreMiddleware.unit.test.js +0 -43
  172. package/dist/tests/unit/api/ignoreMiddleware.unit.test.js.map +0 -1
  173. package/dist/tests/unit/api/ja4Middleware.unit.test.d.ts +0 -2
  174. package/dist/tests/unit/api/ja4Middleware.unit.test.d.ts.map +0 -1
  175. package/dist/tests/unit/api/ja4Middleware.unit.test.js +0 -71
  176. package/dist/tests/unit/api/ja4Middleware.unit.test.js.map +0 -1
  177. package/dist/tests/unit/schedulers/captchaScheduler.unit.test.d.ts +0 -2
  178. package/dist/tests/unit/schedulers/captchaScheduler.unit.test.d.ts.map +0 -1
  179. package/dist/tests/unit/schedulers/captchaScheduler.unit.test.js +0 -75
  180. package/dist/tests/unit/schedulers/captchaScheduler.unit.test.js.map +0 -1
  181. package/dist/tests/unit/tasks/captchaManager.unit.test.d.ts +0 -2
  182. package/dist/tests/unit/tasks/captchaManager.unit.test.d.ts.map +0 -1
  183. package/dist/tests/unit/tasks/captchaManager.unit.test.js +0 -236
  184. package/dist/tests/unit/tasks/captchaManager.unit.test.js.map +0 -1
  185. package/dist/tests/unit/tasks/client/clientTasks.unit.test.d.ts +0 -2
  186. package/dist/tests/unit/tasks/client/clientTasks.unit.test.d.ts.map +0 -1
  187. package/dist/tests/unit/tasks/client/clientTasks.unit.test.js +0 -277
  188. package/dist/tests/unit/tasks/client/clientTasks.unit.test.js.map +0 -1
  189. package/dist/tests/unit/tasks/dataset/datasetTasks.unit.test.d.ts +0 -2
  190. package/dist/tests/unit/tasks/dataset/datasetTasks.unit.test.d.ts.map +0 -1
  191. package/dist/tests/unit/tasks/dataset/datasetTasks.unit.test.js +0 -93
  192. package/dist/tests/unit/tasks/dataset/datasetTasks.unit.test.js.map +0 -1
  193. package/dist/tests/unit/tasks/dataset/datasetTasksUtils.unit.test.d.ts +0 -2
  194. package/dist/tests/unit/tasks/dataset/datasetTasksUtils.unit.test.d.ts.map +0 -1
  195. package/dist/tests/unit/tasks/dataset/datasetTasksUtils.unit.test.js +0 -75
  196. package/dist/tests/unit/tasks/dataset/datasetTasksUtils.unit.test.js.map +0 -1
  197. package/dist/tests/unit/tasks/frictionless/frictionlessTasks.unit.test.d.ts +0 -2
  198. package/dist/tests/unit/tasks/frictionless/frictionlessTasks.unit.test.d.ts.map +0 -1
  199. package/dist/tests/unit/tasks/frictionless/frictionlessTasks.unit.test.js +0 -68
  200. package/dist/tests/unit/tasks/frictionless/frictionlessTasks.unit.test.js.map +0 -1
  201. package/dist/tests/unit/tasks/frictionless/frictionlessTasksUtils.unit.test.d.ts +0 -2
  202. package/dist/tests/unit/tasks/frictionless/frictionlessTasksUtils.unit.test.d.ts.map +0 -1
  203. package/dist/tests/unit/tasks/frictionless/frictionlessTasksUtils.unit.test.js +0 -37
  204. package/dist/tests/unit/tasks/frictionless/frictionlessTasksUtils.unit.test.js.map +0 -1
  205. package/dist/tests/unit/tasks/imgCaptcha/imgCaptchaTasks.unit.test.d.ts +0 -2
  206. package/dist/tests/unit/tasks/imgCaptcha/imgCaptchaTasks.unit.test.d.ts.map +0 -1
  207. package/dist/tests/unit/tasks/imgCaptcha/imgCaptchaTasks.unit.test.js +0 -402
  208. package/dist/tests/unit/tasks/imgCaptcha/imgCaptchaTasks.unit.test.js.map +0 -1
  209. package/dist/tests/unit/tasks/imgCaptcha/imgCaptchaTasksUtils.unit.test.d.ts +0 -2
  210. package/dist/tests/unit/tasks/imgCaptcha/imgCaptchaTasksUtils.unit.test.d.ts.map +0 -1
  211. package/dist/tests/unit/tasks/imgCaptcha/imgCaptchaTasksUtils.unit.test.js +0 -46
  212. package/dist/tests/unit/tasks/imgCaptcha/imgCaptchaTasksUtils.unit.test.js.map +0 -1
  213. package/dist/tests/unit/tasks/powCaptcha/powTasks.unit.test.d.ts +0 -2
  214. package/dist/tests/unit/tasks/powCaptcha/powTasks.unit.test.d.ts.map +0 -1
  215. package/dist/tests/unit/tasks/powCaptcha/powTasks.unit.test.js +0 -228
  216. package/dist/tests/unit/tasks/powCaptcha/powTasks.unit.test.js.map +0 -1
  217. package/dist/tests/unit/tasks/powCaptcha/powTasksUtils.unit.test.d.ts +0 -2
  218. package/dist/tests/unit/tasks/powCaptcha/powTasksUtils.unit.test.d.ts.map +0 -1
  219. package/dist/tests/unit/tasks/powCaptcha/powTasksUtils.unit.test.js +0 -68
  220. package/dist/tests/unit/tasks/powCaptcha/powTasksUtils.unit.test.js.map +0 -1
  221. package/dist/tests/unit/util.unit.test.d.ts +0 -2
  222. package/dist/tests/unit/util.unit.test.d.ts.map +0 -1
  223. package/dist/tests/unit/util.unit.test.js +0 -148
  224. package/dist/tests/unit/util.unit.test.js.map +0 -1
  225. package/dist/util.d.ts +0 -13
  226. package/dist/util.d.ts.map +0 -1
  227. package/dist/util.js.map +0 -1
@@ -1,2 +0,0 @@
1
- export {};
2
- //# sourceMappingURL=datasetTasks.unit.test.d.ts.map
@@ -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":"AAcA,OAAO,EAAe,SAAS,EAAE,MAAM,iBAAiB,CAAC;AACzD,OAAO,EAAE,mBAAmB,EAAE,MAAM,mBAAmB,CAAC;AASxD,OAAO,EAGN,mBAAmB,GACnB,MAAM,yBAAyB,CAAC;AACjC,OAAO,EAAE,UAAU,EAAE,QAAQ,EAAE,MAAM,EAAE,EAAE,EAAE,EAAE,EAAE,MAAM,QAAQ,CAAC;AAC9D,OAAO,EAAE,cAAc,EAAE,MAAM,2CAA2C,CAAC;AAG3E,OAAO,KAAK,iBAAiB,MAAM,gDAAgD,CAAC;AAEpF,MAAM,WAAW,GAAG,SAAS,CAAC,MAAM,EAAE,MAAM,CAAC,IAAI,CAAC,GAAG,CAAC,CAAC;AAEvD,EAAE,CAAC,IAAI,CAAC,mBAAmB,EAAE,GAAG,EAAE,CAAC,CAAC;IACnC,gBAAgB,EAAE,EAAE,CAAC,EAAE,EAAE;IACzB,YAAY,EAAE,EAAE,CAAC,EAAE,EAAE;CACrB,CAAC,CAAC,CAAC;AAEJ,EAAE,CAAC,IAAI,CAAC,mBAAmB,EAAE,GAAG,EAAE,CAAC,CAAC;IACnC,mBAAmB,EAAE,EAAE,CAAC,EAAE,EAAE;CAC5B,CAAC,CAAC,CAAC;AAEJ,EAAE,CAAC,KAAK,CAAC,iBAAiB,EAAE,yBAAyB,CAAC,CAAC;AAOvD,QAAQ,CAAC,gBAAgB,EAAE,GAAG,EAAE;IAC/B,IAAI,MAA2B,CAAC;IAChC,IAAI,MAAc,CAAC;IACnB,IAAI,aAAoD,CAAC;IACzD,IAAI,UAA6B,CAAC;IAClC,IAAI,cAA8B,CAAC;IAEnC,MAAM,WAAW,GAAwB,EAAE,CAAC;IAE5C,UAAU,CAAC,GAAG,EAAE;QACf,MAAM,GAAG;YACR,kBAAkB,EAAE,IAAI;YACxB,cAAc,EAAE,kCAAkC;YAClD,eAAe,EAAE,oCAAoC;SAC9B,CAAC;QAEzB,MAAM,UAAU,GAAG;YAClB,KAAK,EAAE,EAAE,CAAC,EAAE,EAAE,CAAC,kBAAkB,CAAC,WAAW,CAAC,KAAK,CAAC,IAAI,CAAC,WAAW,CAAC,CAAC;YACtE,GAAG,EAAE,EAAE,CAAC,EAAE,EAAE,CAAC,kBAAkB,CAAC,WAAW,CAAC,GAAG,CAAC,IAAI,CAAC,WAAW,CAAC,CAAC;YAClE,IAAI,EAAE,EAAE,CAAC,EAAE,EAAE,CAAC,kBAAkB,CAAC,WAAW,CAAC,IAAI,CAAC,IAAI,CAAC,WAAW,CAAC,CAAC;YACpE,KAAK,EAAE,EAAE,CAAC,EAAE,EAAE,CAAC,kBAAkB,CAAC,WAAW,CAAC,KAAK,CAAC,IAAI,CAAC,WAAW,CAAC,CAAC;YACtE,KAAK,EAAE,EAAE,CAAC,EAAE,EAAE,CAAC,kBAAkB,CAAC,WAAW,CAAC,KAAK,CAAC,IAAI,CAAC,WAAW,CAAC,CAAC;YACtE,KAAK,EAAE,EAAE,CAAC,EAAE,EAAE,CAAC,kBAAkB,CAAC,WAAW,CAAC,KAAK,CAAC,IAAI,CAAC,WAAW,CAAC,CAAC;YACtE,IAAI,EAAE,EAAE,CAAC,EAAE,EAAE,CAAC,kBAAkB,CAAC,WAAW,CAAC,IAAI,CAAC,IAAI,CAAC,WAAW,CAAC,CAAC;SAC/C,CAAC;QACvB,MAAM,GAAG,UAAU,CAAC;QAEpB,aAAa,GAAG;YACf,MAAM,EAAE,EAAE,KAAK,EAAE,CAAC,EAAE;YACpB,QAAQ,EAAE,EAAE,KAAK,EAAE,CAAC,EAAE;SACmB,CAAC;QAE3C,WAAW,CAAC,UAAU,GAAG,EAIxB,CAAC;QACF,WAAW,CAAC,UAAU,CAAC,OAAO,GAAG,EAEhC,CAAC;QACF,WAAW,CAAC,UAAU,CAAC,MAAM,GAAG,CAAC,CAAC;QAClC,WAAW,CAAC,UAAU,CAAC,IAAI,GAAG,CAAC,CAAC;QAEhC,UAAU,GAAG;YACZ,YAAY,EAAE,EAAE,CAAC,EAAE,EAAE;YACrB,8BAA8B,EAAE,EAAE,CAAC,EAAE,EAAE,CAAC,iBAAiB,CAAC,EAAE,CAAC;YAC7D,6BAA6B,EAAE,EAAE,CAAC,EAAE,EAAE;YACtC,gCAAgC,EAAE,EAAE,CAAC,EAAE,EAAE;YACzC,iCAAiC,EAAE,EAAE,CAAC,EAAE,EAAE,CAAC,iBAAiB,CAAC,EAAE,CAAC;YAChE,yBAAyB,EAAE,EAAE,CAAC,EAAE,CAC/B,CAAC,QAA4B,EAAE,MAA2B,EAAE,EAAE;gBAC7D,MAAM,GAAG,GAAG,WAAW,CAAC,UAAU,CAAC,MAAM,CAAC;gBAC1C,WAAW,CAAC,UAAU,CAAC,OAAO,CAAC,GAAG,CAAC,GAAG,mBAAmB,CAAC,KAAK,CAAC;oBAC/D,GAAG;oBACH,WAAW,EAAE,QAAQ;oBACrB,MAAM;oBACN,QAAQ,EAAE,WAAW,CAAC,UAAU,CAAC,IAAI;iBACrC,CAAC,CAAC;gBACH,WAAW,CAAC,UAAU,CAAC,MAAM,IAAI,CAAC,CAAC;gBACnC,WAAW,CAAC,UAAU,CAAC,IAAI,IAAI,CAAC,CAAC;gBACjC,OAAO,GAAG,CAAC;YACZ,CAAC,CACD;YACD,yBAAyB,EAAE,EAAE,CAAC,EAAE,CAC/B,CAEC,MAAW,EACX,MAA2B,EAC3B,MAA4B,EAC3B,EAAE;gBACH,MAAM,IAAI,GAAG,WAAW,CAAC,UAAU,CAAC,OAAO,CAAC,MAAM,CAAC,CAAC;gBACpD,IAAI,CAAC,MAAM,GAAG,MAAM,CAAC;gBACrB,IAAI,CAAC,MAAM,GAAG,MAAM,CAAC;gBACrB,IAAI,CAAC,OAAO,GAAG,WAAW,CAAC,UAAU,CAAC,IAAI,CAAC;gBAC3C,WAAW,CAAC,UAAU,CAAC,IAAI,IAAI,CAAC,CAAC;YAClC,CAAC,CACD;YACD,0BAA0B,EAAE,EAAE,CAAC,EAAE,CAEhC,CAAC,MAAW,EAAE,MAA2B,EAAE,EAAE;gBAC5C,OAAO,CACN,MAAM,CAAC,IAAI,CAAC,WAAW,CAAC,UAAU,CAAC,OAAO,CAAC;qBAEzC,GAAG,CAAC,CAAC,GAAQ,EAAE,EAAE,CAAC,WAAW,CAAC,UAAU,CAAC,OAAO,CAAC,GAAG,CAAC,CAAC;qBACtD,IAAI,CACJ,CAAC,IAAyB,EAAE,EAAE,CAC7B,IAAI,CAAC,WAAW,KAAK,MAAM,IAAI,IAAI,CAAC,MAAM,KAAK,MAAM,CACtD,CACF,CAAC;YACH,CAAC,CACD;SAC+B,CAAC;QAElC,cAAc,GAAG,IAAI,cAAc,CAClC,MAAM,EACN,MAAM,EACN,aAAa,EACb,UAAU,CACV,CAAC;QACF,EAAE,CAAC,aAAa,EAAE,CAAC;IACpB,CAAC,CAAC,CAAC;IAEH,EAAE,CAAC,6CAA6C,EAAE,KAAK,IAAI,EAAE;QAC5D,MAAM,QAAQ,GAAG,EAAE,QAAQ,EAAE,EAAE,EAAE,CAAC;QAClC,MAAM,cAAc,GAAG,EAAE,QAAQ,EAAE,EAAE,EAAE,MAAM,EAAE,WAAW,EAAgB,CAAC;QAC3E,MAAM,oBAAoB,GAAG,EAAE,SAAS,EAAE,KAAK,EAAE,gBAAgB,EAAE,KAAK,EAAE,CAAC;QAE1E,mBAA2B,CAAC,eAAe,CAAC,cAAc,CAAC,CAAC;QAE5D,iBAAiB,CAAC,uBAA+B,CAAC,iBAAiB,CACnE,oBAAoB,CACpB,CAAC;QAEF,MAAM,cAAc,CAAC,0BAA0B,CAC9C,QAA2B,CAC3B,CAAC;QAEF,MAAM,CAAC,mBAAmB,CAAC,CAAC,oBAAoB,CAAC,QAAQ,CAAC,CAAC;QAC3D,MAAM,CAAC,iBAAiB,CAAC,uBAAuB,CAAC,CAAC,oBAAoB,CACrE,cAAc,EACd,aAAa,CAAC,MAAM,CAAC,KAAK,EAC1B,aAAa,CAAC,QAAQ,CAAC,KAAK,CAC5B,CAAC;QACF,MAAM,CAAC,UAAU,CAAC,YAAY,CAAC,CAAC,oBAAoB,CAAC,oBAAoB,CAAC,CAAC;IAC5E,CAAC,CAAC,CAAC;AACJ,CAAC,CAAC,CAAC"}
@@ -1,2 +0,0 @@
1
- export {};
2
- //# sourceMappingURL=datasetTasksUtils.unit.test.d.ts.map
@@ -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,2 +0,0 @@
1
- export {};
2
- //# sourceMappingURL=frictionlessTasks.unit.test.d.ts.map
@@ -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,2 +0,0 @@
1
- export {};
2
- //# sourceMappingURL=frictionlessTasksUtils.unit.test.d.ts.map
@@ -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,2 +0,0 @@
1
- export {};
2
- //# sourceMappingURL=imgCaptchaTasks.unit.test.d.ts.map
@@ -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":""}