@prosopo/provider 3.13.7 → 4.7.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 (761) hide show
  1. package/.turbo/turbo-build$colon$cjs.log +107 -56
  2. package/.turbo/turbo-build$colon$tsc.log +71 -0
  3. package/.turbo/turbo-build.log +110 -57
  4. package/CHANGELOG.md +1474 -0
  5. package/dist/api/admin/apiAdminRoutesProvider.d.ts +9 -0
  6. package/dist/api/admin/apiAdminRoutesProvider.d.ts.map +1 -0
  7. package/dist/api/admin/apiAdminRoutesProvider.js +31 -1
  8. package/dist/api/admin/apiAdminRoutesProvider.js.map +1 -0
  9. package/dist/api/admin/apiClearAllCountersEndpoint.d.ts +14 -0
  10. package/dist/api/admin/apiClearAllCountersEndpoint.d.ts.map +1 -0
  11. package/dist/api/admin/apiClearAllCountersEndpoint.js +59 -0
  12. package/dist/api/admin/apiClearAllCountersEndpoint.js.map +1 -0
  13. package/dist/api/admin/apiDnsEventEndpoint.d.ts +15 -0
  14. package/dist/api/admin/apiDnsEventEndpoint.d.ts.map +1 -0
  15. package/dist/api/admin/apiDnsEventEndpoint.js +64 -0
  16. package/dist/api/admin/apiDnsEventEndpoint.js.map +1 -0
  17. package/dist/api/admin/apiGetAllDecisionMachinesEndpoint.d.ts +13 -0
  18. package/dist/api/admin/apiGetAllDecisionMachinesEndpoint.d.ts.map +1 -0
  19. package/dist/api/admin/apiGetAllDecisionMachinesEndpoint.js +49 -0
  20. package/dist/api/admin/apiGetAllDecisionMachinesEndpoint.js.map +1 -0
  21. package/dist/api/admin/apiGetDecisionMachineEndpoint.d.ts +14 -0
  22. package/dist/api/admin/apiGetDecisionMachineEndpoint.d.ts.map +1 -0
  23. package/dist/api/admin/apiGetDecisionMachineEndpoint.js +42 -0
  24. package/dist/api/admin/apiGetDecisionMachineEndpoint.js.map +1 -0
  25. package/dist/api/admin/apiRegisterSiteKeyEndpoint.d.ts +14 -0
  26. package/dist/api/admin/apiRegisterSiteKeyEndpoint.d.ts.map +1 -0
  27. package/dist/api/admin/apiRegisterSiteKeyEndpoint.js +1 -1
  28. package/dist/api/admin/apiRegisterSiteKeyEndpoint.js.map +1 -0
  29. package/dist/api/admin/apiRegisterSiteKeysEndpoint.d.ts +14 -0
  30. package/dist/api/admin/apiRegisterSiteKeysEndpoint.d.ts.map +1 -0
  31. package/dist/api/admin/apiRegisterSiteKeysEndpoint.js +33 -0
  32. package/dist/api/admin/apiRegisterSiteKeysEndpoint.js.map +1 -0
  33. package/dist/api/admin/apiRemoveAllDecisionMachinesEndpoint.d.ts +13 -0
  34. package/dist/api/admin/apiRemoveAllDecisionMachinesEndpoint.d.ts.map +1 -0
  35. package/dist/api/admin/apiRemoveAllDecisionMachinesEndpoint.js +41 -0
  36. package/dist/api/admin/apiRemoveAllDecisionMachinesEndpoint.js.map +1 -0
  37. package/dist/api/admin/apiRemoveDecisionMachineEndpoint.d.ts +14 -0
  38. package/dist/api/admin/apiRemoveDecisionMachineEndpoint.d.ts.map +1 -0
  39. package/dist/api/admin/apiRemoveDecisionMachineEndpoint.js +42 -0
  40. package/dist/api/admin/apiRemoveDecisionMachineEndpoint.js.map +1 -0
  41. package/dist/api/admin/apiRemoveDetectorKeyEndpoint.d.ts +23 -0
  42. package/dist/api/admin/apiRemoveDetectorKeyEndpoint.d.ts.map +1 -0
  43. package/dist/api/admin/apiRemoveDetectorKeyEndpoint.js +1 -1
  44. package/dist/api/admin/apiRemoveDetectorKeyEndpoint.js.map +1 -0
  45. package/dist/api/admin/apiRemoveSiteKeyEndpoint.d.ts +14 -0
  46. package/dist/api/admin/apiRemoveSiteKeyEndpoint.d.ts.map +1 -0
  47. package/dist/api/admin/apiRemoveSiteKeyEndpoint.js +32 -0
  48. package/dist/api/admin/apiRemoveSiteKeyEndpoint.js.map +1 -0
  49. package/dist/api/admin/apiRemoveSiteKeysEndpoint.d.ts +14 -0
  50. package/dist/api/admin/apiRemoveSiteKeysEndpoint.d.ts.map +1 -0
  51. package/dist/api/admin/apiRemoveSiteKeysEndpoint.js +34 -0
  52. package/dist/api/admin/apiRemoveSiteKeysEndpoint.js.map +1 -0
  53. package/dist/api/admin/apiToggleMaintenanceModeEndpoint.d.ts +13 -0
  54. package/dist/api/admin/apiToggleMaintenanceModeEndpoint.d.ts.map +1 -0
  55. package/dist/api/admin/apiToggleMaintenanceModeEndpoint.js +1 -1
  56. package/dist/api/admin/apiToggleMaintenanceModeEndpoint.js.map +1 -0
  57. package/dist/api/admin/apiUpdateDecisionMachineEndpoint.d.ts +14 -0
  58. package/dist/api/admin/apiUpdateDecisionMachineEndpoint.d.ts.map +1 -0
  59. package/dist/api/admin/apiUpdateDecisionMachineEndpoint.js +60 -0
  60. package/dist/api/admin/apiUpdateDecisionMachineEndpoint.js.map +1 -0
  61. package/dist/api/admin/apiUpdateDetectorKeyEndpoint.d.ts +14 -0
  62. package/dist/api/admin/apiUpdateDetectorKeyEndpoint.d.ts.map +1 -0
  63. package/dist/api/admin/apiUpdateDetectorKeyEndpoint.js +1 -1
  64. package/dist/api/admin/apiUpdateDetectorKeyEndpoint.js.map +1 -0
  65. package/dist/api/admin/createApiAdminRoutesProvider.d.ts +4 -0
  66. package/dist/api/admin/createApiAdminRoutesProvider.d.ts.map +1 -0
  67. package/dist/api/admin/createApiAdminRoutesProvider.js.map +1 -0
  68. package/dist/api/blacklistRequestInspector.d.ts +20 -0
  69. package/dist/api/blacklistRequestInspector.d.ts.map +1 -0
  70. package/dist/api/blacklistRequestInspector.js +20 -6
  71. package/dist/api/blacklistRequestInspector.js.map +1 -0
  72. package/dist/api/block.d.ts +4 -0
  73. package/dist/api/block.d.ts.map +1 -0
  74. package/dist/api/block.js +19 -8
  75. package/dist/api/block.js.map +1 -0
  76. package/dist/api/captcha/checkSpamEmail.d.ts +6 -0
  77. package/dist/api/captcha/checkSpamEmail.d.ts.map +1 -0
  78. package/dist/api/captcha/checkSpamEmail.js +80 -0
  79. package/dist/api/captcha/checkSpamEmail.js.map +1 -0
  80. package/dist/api/captcha/contextAwareValidation.d.ts +4 -0
  81. package/dist/api/captcha/contextAwareValidation.d.ts.map +1 -0
  82. package/dist/api/captcha/contextAwareValidation.js.map +1 -0
  83. package/dist/api/captcha/getFrictionlessCaptchaChallenge/accessPolicy.d.ts +31 -0
  84. package/dist/api/captcha/getFrictionlessCaptchaChallenge/accessPolicy.d.ts.map +1 -0
  85. package/dist/api/captcha/getFrictionlessCaptchaChallenge/accessPolicy.js +123 -0
  86. package/dist/api/captcha/getFrictionlessCaptchaChallenge/accessPolicy.js.map +1 -0
  87. package/dist/api/captcha/getFrictionlessCaptchaChallenge/constants.d.ts +3 -0
  88. package/dist/api/captcha/getFrictionlessCaptchaChallenge/constants.d.ts.map +1 -0
  89. package/dist/api/captcha/getFrictionlessCaptchaChallenge/constants.js +13 -0
  90. package/dist/api/captcha/getFrictionlessCaptchaChallenge/constants.js.map +1 -0
  91. package/dist/api/captcha/getFrictionlessCaptchaChallenge/decisionMachine.d.ts +36 -0
  92. package/dist/api/captcha/getFrictionlessCaptchaChallenge/decisionMachine.d.ts.map +1 -0
  93. package/dist/api/captcha/getFrictionlessCaptchaChallenge/decisionMachine.js +287 -0
  94. package/dist/api/captcha/getFrictionlessCaptchaChallenge/decisionMachine.js.map +1 -0
  95. package/dist/api/captcha/getFrictionlessCaptchaChallenge/decryptSimdReadings.d.ts +4 -0
  96. package/dist/api/captcha/getFrictionlessCaptchaChallenge/decryptSimdReadings.d.ts.map +1 -0
  97. package/dist/api/captcha/getFrictionlessCaptchaChallenge/decryptSimdReadings.js +14 -0
  98. package/dist/api/captcha/getFrictionlessCaptchaChallenge/decryptSimdReadings.js.map +1 -0
  99. package/dist/api/captcha/getFrictionlessCaptchaChallenge/handler.d.ts +7 -0
  100. package/dist/api/captcha/getFrictionlessCaptchaChallenge/handler.d.ts.map +1 -0
  101. package/dist/api/captcha/getFrictionlessCaptchaChallenge/handler.js +314 -0
  102. package/dist/api/captcha/getFrictionlessCaptchaChallenge/handler.js.map +1 -0
  103. package/dist/api/captcha/getFrictionlessCaptchaChallenge/honeypotResponse.d.ts +5 -0
  104. package/dist/api/captcha/getFrictionlessCaptchaChallenge/honeypotResponse.d.ts.map +1 -0
  105. package/dist/api/captcha/getFrictionlessCaptchaChallenge/honeypotResponse.js +17 -0
  106. package/dist/api/captcha/getFrictionlessCaptchaChallenge/honeypotResponse.js.map +1 -0
  107. package/dist/api/captcha/getFrictionlessCaptchaChallenge/sessionDedup.d.ts +14 -0
  108. package/dist/api/captcha/getFrictionlessCaptchaChallenge/sessionDedup.d.ts.map +1 -0
  109. package/dist/api/captcha/getFrictionlessCaptchaChallenge/sessionDedup.js +28 -0
  110. package/dist/api/captcha/getFrictionlessCaptchaChallenge/sessionDedup.js.map +1 -0
  111. package/dist/api/captcha/getFrictionlessCaptchaChallenge/shortCircuit.d.ts +23 -0
  112. package/dist/api/captcha/getFrictionlessCaptchaChallenge/shortCircuit.d.ts.map +1 -0
  113. package/dist/api/captcha/getFrictionlessCaptchaChallenge/shortCircuit.js +61 -0
  114. package/dist/api/captcha/getFrictionlessCaptchaChallenge/shortCircuit.js.map +1 -0
  115. package/dist/api/captcha/getFrictionlessCaptchaChallenge.d.ts +2 -0
  116. package/dist/api/captcha/getFrictionlessCaptchaChallenge.d.ts.map +1 -0
  117. package/dist/api/captcha/getFrictionlessCaptchaChallenge.js +2 -364
  118. package/dist/api/captcha/getFrictionlessCaptchaChallenge.js.map +1 -0
  119. package/dist/api/captcha/getImageCaptchaChallenge.d.ts +7 -0
  120. package/dist/api/captcha/getImageCaptchaChallenge.d.ts.map +1 -0
  121. package/dist/api/captcha/getImageCaptchaChallenge.js +36 -9
  122. package/dist/api/captcha/getImageCaptchaChallenge.js.map +1 -0
  123. package/dist/api/captcha/getPoWCaptchaChallenge.d.ts +7 -0
  124. package/dist/api/captcha/getPoWCaptchaChallenge.d.ts.map +1 -0
  125. package/dist/api/captcha/getPoWCaptchaChallenge.js +49 -7
  126. package/dist/api/captcha/getPoWCaptchaChallenge.js.map +1 -0
  127. package/dist/api/captcha/getPuzzleCaptchaChallenge.d.ts +7 -0
  128. package/dist/api/captcha/getPuzzleCaptchaChallenge.d.ts.map +1 -0
  129. package/dist/api/captcha/getPuzzleCaptchaChallenge.js +201 -0
  130. package/dist/api/captcha/getPuzzleCaptchaChallenge.js.map +1 -0
  131. package/dist/api/captcha/maintenanceModeResponses.d.ts +5 -0
  132. package/dist/api/captcha/maintenanceModeResponses.d.ts.map +1 -0
  133. package/dist/api/captcha/maintenanceModeResponses.js +42 -0
  134. package/dist/api/captcha/maintenanceModeResponses.js.map +1 -0
  135. package/dist/api/captcha/submitImageCaptchaSolution.d.ts +6 -0
  136. package/dist/api/captcha/submitImageCaptchaSolution.d.ts.map +1 -0
  137. package/dist/api/captcha/submitImageCaptchaSolution.js +19 -2
  138. package/dist/api/captcha/submitImageCaptchaSolution.js.map +1 -0
  139. package/dist/api/captcha/submitPoWCaptchaSolution.d.ts +6 -0
  140. package/dist/api/captcha/submitPoWCaptchaSolution.d.ts.map +1 -0
  141. package/dist/api/captcha/submitPoWCaptchaSolution.js +94 -6
  142. package/dist/api/captcha/submitPoWCaptchaSolution.js.map +1 -0
  143. package/dist/api/captcha/submitPuzzleCaptchaSolution.d.ts +6 -0
  144. package/dist/api/captcha/submitPuzzleCaptchaSolution.d.ts.map +1 -0
  145. package/dist/api/captcha/submitPuzzleCaptchaSolution.js +108 -0
  146. package/dist/api/captcha/submitPuzzleCaptchaSolution.js.map +1 -0
  147. package/dist/api/captcha.d.ts +4 -0
  148. package/dist/api/captcha.d.ts.map +1 -0
  149. package/dist/api/captcha.js +28 -3
  150. package/dist/api/captcha.js.map +1 -0
  151. package/dist/api/dnsEventUrl.d.ts +3 -0
  152. package/dist/api/dnsEventUrl.d.ts.map +1 -0
  153. package/dist/api/dnsEventUrl.js +25 -0
  154. package/dist/api/dnsEventUrl.js.map +1 -0
  155. package/dist/api/domainMiddleware.d.ts +4 -0
  156. package/dist/api/domainMiddleware.d.ts.map +1 -0
  157. package/dist/api/domainMiddleware.js +36 -5
  158. package/dist/api/domainMiddleware.js.map +1 -0
  159. package/dist/api/headerCheckMiddleware.d.ts +4 -0
  160. package/dist/api/headerCheckMiddleware.d.ts.map +1 -0
  161. package/dist/api/headerCheckMiddleware.js.map +1 -0
  162. package/dist/api/ignoreMiddleware.d.ts +3 -0
  163. package/dist/api/ignoreMiddleware.d.ts.map +1 -0
  164. package/dist/api/ignoreMiddleware.js.map +1 -0
  165. package/dist/api/ipInfoMiddleware.d.ts +4 -0
  166. package/dist/api/ipInfoMiddleware.d.ts.map +1 -0
  167. package/dist/api/ipInfoMiddleware.js +20 -0
  168. package/dist/api/ipInfoMiddleware.js.map +1 -0
  169. package/dist/api/ja4Middleware.d.ts +10 -0
  170. package/dist/api/ja4Middleware.d.ts.map +1 -0
  171. package/dist/api/ja4Middleware.js +1 -1
  172. package/dist/api/ja4Middleware.js.map +1 -0
  173. package/dist/api/public.d.ts +4 -0
  174. package/dist/api/public.d.ts.map +1 -0
  175. package/dist/api/public.js.map +1 -0
  176. package/dist/api/robotsMiddleware.d.ts +3 -0
  177. package/dist/api/robotsMiddleware.d.ts.map +1 -0
  178. package/dist/api/robotsMiddleware.js.map +1 -0
  179. package/dist/api/startProviderApi.d.ts +9 -0
  180. package/dist/api/startProviderApi.d.ts.map +1 -0
  181. package/dist/api/startProviderApi.js +217 -0
  182. package/dist/api/startProviderApi.js.map +1 -0
  183. package/dist/api/testSiteKey.d.ts +4 -0
  184. package/dist/api/testSiteKey.d.ts.map +1 -0
  185. package/dist/api/testSiteKey.js +17 -0
  186. package/dist/api/testSiteKey.js.map +1 -0
  187. package/dist/api/validateAddress.d.ts +5 -0
  188. package/dist/api/validateAddress.d.ts.map +1 -0
  189. package/dist/api/validateAddress.js.map +1 -0
  190. package/dist/api/verify.d.ts +4 -0
  191. package/dist/api/verify.d.ts.map +1 -0
  192. package/dist/api/verify.js +146 -9
  193. package/dist/api/verify.js.map +1 -0
  194. package/dist/cjs/api/admin/apiAdminRoutesProvider.cjs +31 -1
  195. package/dist/cjs/api/admin/apiClearAllCountersEndpoint.cjs +59 -0
  196. package/dist/cjs/api/admin/apiDnsEventEndpoint.cjs +65 -0
  197. package/dist/cjs/api/admin/apiGetAllDecisionMachinesEndpoint.cjs +49 -0
  198. package/dist/cjs/api/admin/apiGetDecisionMachineEndpoint.cjs +42 -0
  199. package/dist/cjs/api/admin/apiRegisterSiteKeyEndpoint.cjs +5 -5
  200. package/dist/cjs/api/admin/apiRegisterSiteKeysEndpoint.cjs +34 -0
  201. package/dist/cjs/api/admin/apiRemoveAllDecisionMachinesEndpoint.cjs +41 -0
  202. package/dist/cjs/api/admin/apiRemoveDecisionMachineEndpoint.cjs +42 -0
  203. package/dist/cjs/api/admin/apiRemoveDetectorKeyEndpoint.cjs +6 -6
  204. package/dist/cjs/api/admin/apiRemoveSiteKeyEndpoint.cjs +33 -0
  205. package/dist/cjs/api/admin/apiRemoveSiteKeysEndpoint.cjs +35 -0
  206. package/dist/cjs/api/admin/apiToggleMaintenanceModeEndpoint.cjs +5 -5
  207. package/dist/cjs/api/admin/apiUpdateDecisionMachineEndpoint.cjs +60 -0
  208. package/dist/cjs/api/admin/apiUpdateDetectorKeyEndpoint.cjs +7 -7
  209. package/dist/cjs/api/blacklistRequestInspector.cjs +20 -6
  210. package/dist/cjs/api/block.cjs +19 -8
  211. package/dist/cjs/api/captcha/checkSpamEmail.cjs +79 -0
  212. package/dist/cjs/api/captcha/getFrictionlessCaptchaChallenge/accessPolicy.cjs +123 -0
  213. package/dist/cjs/api/captcha/getFrictionlessCaptchaChallenge/constants.cjs +13 -0
  214. package/dist/cjs/api/captcha/getFrictionlessCaptchaChallenge/decisionMachine.cjs +287 -0
  215. package/dist/cjs/api/captcha/getFrictionlessCaptchaChallenge/decryptSimdReadings.cjs +14 -0
  216. package/dist/cjs/api/captcha/getFrictionlessCaptchaChallenge/handler.cjs +313 -0
  217. package/dist/cjs/api/captcha/getFrictionlessCaptchaChallenge/honeypotResponse.cjs +17 -0
  218. package/dist/cjs/api/captcha/getFrictionlessCaptchaChallenge/sessionDedup.cjs +28 -0
  219. package/dist/cjs/api/captcha/getFrictionlessCaptchaChallenge/shortCircuit.cjs +61 -0
  220. package/dist/cjs/api/captcha/getFrictionlessCaptchaChallenge.cjs +2 -364
  221. package/dist/cjs/api/captcha/getImageCaptchaChallenge.cjs +35 -8
  222. package/dist/cjs/api/captcha/getPoWCaptchaChallenge.cjs +48 -6
  223. package/dist/cjs/api/captcha/getPuzzleCaptchaChallenge.cjs +200 -0
  224. package/dist/cjs/api/captcha/maintenanceModeResponses.cjs +42 -0
  225. package/dist/cjs/api/captcha/submitImageCaptchaSolution.cjs +19 -2
  226. package/dist/cjs/api/captcha/submitPoWCaptchaSolution.cjs +92 -4
  227. package/dist/cjs/api/captcha/submitPuzzleCaptchaSolution.cjs +107 -0
  228. package/dist/cjs/api/captcha.cjs +29 -4
  229. package/dist/cjs/api/dnsEventUrl.cjs +25 -0
  230. package/dist/cjs/api/domainMiddleware.cjs +36 -5
  231. package/dist/cjs/api/ipInfoMiddleware.cjs +20 -0
  232. package/dist/cjs/api/ja4Middleware.cjs +7 -7
  233. package/dist/cjs/api/startProviderApi.cjs +240 -0
  234. package/dist/cjs/api/testSiteKey.cjs +17 -0
  235. package/dist/cjs/api/verify.cjs +145 -8
  236. package/dist/cjs/compositeIpAddress.cjs +6 -6
  237. package/dist/cjs/index.cjs +19 -0
  238. package/dist/cjs/rules/lang.cjs +1 -1
  239. package/dist/cjs/schedulers/updateSpamEmailDomains.cjs +46 -0
  240. package/dist/cjs/services/ipComparison.cjs +9 -10
  241. package/dist/cjs/tasks/captchaManager.cjs +338 -66
  242. package/dist/cjs/tasks/client/clientTasks.cjs +116 -5
  243. package/dist/cjs/tasks/decisionMachine/decisionMachineRunner.cjs +285 -0
  244. package/dist/cjs/tasks/detection/decodeBehavior.cjs +325 -0
  245. package/dist/cjs/tasks/detection/decodeBehavior.js +15 -0
  246. package/dist/cjs/tasks/detection/decodePayload.cjs +692 -661
  247. package/dist/cjs/tasks/detection/decodePayload.js +15 -0
  248. package/dist/cjs/tasks/detection/decodeSimd.cjs +348 -0
  249. package/dist/cjs/tasks/detection/decodeSimd.js +15 -0
  250. package/dist/cjs/tasks/detection/getBotScore.cjs +4 -2
  251. package/dist/cjs/tasks/frictionless/frictionlessTasks.cjs +146 -43
  252. package/dist/cjs/tasks/frictionless/frictionlessTasksUtils.cjs +10 -7
  253. package/dist/cjs/tasks/frictionless/routingMachine.cjs +58 -0
  254. package/dist/cjs/tasks/imgCaptcha/imgCaptchaTasks.cjs +371 -57
  255. package/dist/cjs/tasks/powCaptcha/powTasks.cjs +450 -55
  256. package/dist/cjs/tasks/puzzleCaptcha/puzzleTasks.cjs +525 -0
  257. package/dist/cjs/tasks/puzzleCaptcha/puzzleTasksUtils.cjs +7 -0
  258. package/dist/cjs/tasks/spam/checkSpamEmail.cjs +147 -0
  259. package/dist/cjs/tasks/spam/checkTrafficFilter.cjs +41 -0
  260. package/dist/cjs/tasks/spam/evaluateEmailSpamRules.cjs +92 -0
  261. package/dist/cjs/tasks/spam/updateSpamEmailDomains.cjs +58 -0
  262. package/dist/cjs/tasks/tasks.cjs +111 -13
  263. package/dist/cjs/util/usageCounters.cjs +201 -0
  264. package/dist/cjs/util.cjs +3 -4
  265. package/dist/cjs/utils/devicePlatform.cjs +10 -0
  266. package/dist/cjs/utils/dns.cjs +102 -0
  267. package/dist/cjs/utils/honeypot/encoders.cjs +86 -0
  268. package/dist/cjs/utils/honeypot/phraseBank.cjs +47 -0
  269. package/dist/cjs/utils/normalizeRequestIp.cjs +27 -0
  270. package/dist/compositeIpAddress.d.ts +5 -0
  271. package/dist/compositeIpAddress.d.ts.map +1 -0
  272. package/dist/compositeIpAddress.js +1 -1
  273. package/dist/compositeIpAddress.js.map +1 -0
  274. package/dist/index.d.ts +23 -0
  275. package/dist/index.d.ts.map +1 -0
  276. package/dist/index.js +16 -0
  277. package/dist/index.js.map +1 -0
  278. package/dist/pairs.d.ts +3 -0
  279. package/dist/pairs.d.ts.map +1 -0
  280. package/dist/pairs.js.map +1 -0
  281. package/dist/rules/lang.d.ts +3 -0
  282. package/dist/rules/lang.d.ts.map +1 -0
  283. package/dist/rules/lang.js +1 -1
  284. package/dist/rules/lang.js.map +1 -0
  285. package/dist/schedulers/captchaScheduler.d.ts +4 -0
  286. package/dist/schedulers/captchaScheduler.d.ts.map +1 -0
  287. package/dist/schedulers/captchaScheduler.js.map +1 -0
  288. package/dist/schedulers/getClientList.d.ts +4 -0
  289. package/dist/schedulers/getClientList.d.ts.map +1 -0
  290. package/dist/schedulers/getClientList.js.map +1 -0
  291. package/dist/schedulers/setClientEntropy.d.ts +4 -0
  292. package/dist/schedulers/setClientEntropy.d.ts.map +1 -0
  293. package/dist/schedulers/setClientEntropy.js.map +1 -0
  294. package/dist/schedulers/updateSpamEmailDomains.d.ts +4 -0
  295. package/dist/schedulers/updateSpamEmailDomains.d.ts.map +1 -0
  296. package/dist/schedulers/updateSpamEmailDomains.js +46 -0
  297. package/dist/schedulers/updateSpamEmailDomains.js.map +1 -0
  298. package/dist/services/ipComparison.d.ts +4 -0
  299. package/dist/services/ipComparison.d.ts.map +1 -0
  300. package/dist/services/ipComparison.js +3 -4
  301. package/dist/services/ipComparison.js.map +1 -0
  302. package/dist/tasks/captchaManager.d.ts +52 -0
  303. package/dist/tasks/captchaManager.d.ts.map +1 -0
  304. package/dist/tasks/captchaManager.js +336 -64
  305. package/dist/tasks/captchaManager.js.map +1 -0
  306. package/dist/tasks/client/clientTasks.d.ts +69 -0
  307. package/dist/tasks/client/clientTasks.d.ts.map +1 -0
  308. package/dist/tasks/client/clientTasks.js +117 -6
  309. package/dist/tasks/client/clientTasks.js.map +1 -0
  310. package/dist/tasks/dataset/datasetTasks.d.ts +13 -0
  311. package/dist/tasks/dataset/datasetTasks.d.ts.map +1 -0
  312. package/dist/tasks/dataset/datasetTasks.js.map +1 -0
  313. package/dist/tasks/dataset/datasetTasksUtils.d.ts +3 -0
  314. package/dist/tasks/dataset/datasetTasksUtils.d.ts.map +1 -0
  315. package/dist/tasks/dataset/datasetTasksUtils.js.map +1 -0
  316. package/dist/tasks/decisionMachine/decisionMachineRunner.d.ts +20 -0
  317. package/dist/tasks/decisionMachine/decisionMachineRunner.d.ts.map +1 -0
  318. package/dist/tasks/decisionMachine/decisionMachineRunner.js +285 -0
  319. package/dist/tasks/decisionMachine/decisionMachineRunner.js.map +1 -0
  320. package/dist/tasks/detection/decodeBehavior.d.ts +3 -0
  321. package/dist/tasks/detection/decodeBehavior.d.ts.map +1 -0
  322. package/dist/tasks/detection/decodeBehavior.js +15 -0
  323. package/dist/tasks/detection/decodeBehavior.js.map +1 -0
  324. package/dist/tasks/detection/decodePayload.d.ts +5 -0
  325. package/dist/tasks/detection/decodePayload.d.ts.map +1 -0
  326. package/dist/tasks/detection/decodePayload.js +15 -849
  327. package/dist/tasks/detection/decodePayload.js.map +1 -0
  328. package/dist/tasks/detection/decodeSimd.d.ts +3 -0
  329. package/dist/tasks/detection/decodeSimd.d.ts.map +1 -0
  330. package/dist/tasks/detection/decodeSimd.js +15 -0
  331. package/dist/tasks/detection/decodeSimd.js.map +1 -0
  332. package/dist/tasks/detection/getBehavioralData.d.ts +4 -0
  333. package/dist/tasks/detection/getBehavioralData.d.ts.map +1 -0
  334. package/dist/tasks/detection/getBehavioralData.js +51 -0
  335. package/dist/tasks/detection/getBehavioralData.js.map +1 -0
  336. package/dist/tasks/detection/getBotScore.d.ts +22 -0
  337. package/dist/tasks/detection/getBotScore.d.ts.map +1 -0
  338. package/dist/tasks/detection/getBotScore.js +6 -4
  339. package/dist/tasks/detection/getBotScore.js.map +1 -0
  340. package/dist/tasks/frictionless/frictionlessTasks.d.ts +69 -0
  341. package/dist/tasks/frictionless/frictionlessTasks.d.ts.map +1 -0
  342. package/dist/tasks/frictionless/frictionlessTasks.js +144 -43
  343. package/dist/tasks/frictionless/frictionlessTasks.js.map +1 -0
  344. package/dist/tasks/frictionless/frictionlessTasksUtils.d.ts +6 -0
  345. package/dist/tasks/frictionless/frictionlessTasksUtils.d.ts.map +1 -0
  346. package/dist/tasks/frictionless/frictionlessTasksUtils.js +10 -7
  347. package/dist/tasks/frictionless/frictionlessTasksUtils.js.map +1 -0
  348. package/dist/tasks/frictionless/routingMachine.d.ts +15 -0
  349. package/dist/tasks/frictionless/routingMachine.d.ts.map +1 -0
  350. package/dist/tasks/frictionless/routingMachine.js +58 -0
  351. package/dist/tasks/frictionless/routingMachine.js.map +1 -0
  352. package/dist/tasks/imgCaptcha/imgCaptchaTasks.d.ts +33 -0
  353. package/dist/tasks/imgCaptcha/imgCaptchaTasks.d.ts.map +1 -0
  354. package/dist/tasks/imgCaptcha/imgCaptchaTasks.js +371 -57
  355. package/dist/tasks/imgCaptcha/imgCaptchaTasks.js.map +1 -0
  356. package/dist/tasks/imgCaptcha/imgCaptchaTasksUtils.d.ts +7 -0
  357. package/dist/tasks/imgCaptcha/imgCaptchaTasksUtils.d.ts.map +1 -0
  358. package/dist/tasks/imgCaptcha/imgCaptchaTasksUtils.js.map +1 -0
  359. package/dist/tasks/index.d.ts +2 -0
  360. package/dist/tasks/index.d.ts.map +1 -0
  361. package/dist/tasks/index.js.map +1 -0
  362. package/dist/tasks/powCaptcha/powTasks.d.ts +36 -0
  363. package/dist/tasks/powCaptcha/powTasks.d.ts.map +1 -0
  364. package/dist/tasks/powCaptcha/powTasks.js +452 -57
  365. package/dist/tasks/powCaptcha/powTasks.js.map +1 -0
  366. package/dist/tasks/powCaptcha/powTasksUtils.d.ts +3 -0
  367. package/dist/tasks/powCaptcha/powTasksUtils.d.ts.map +1 -0
  368. package/dist/tasks/powCaptcha/powTasksUtils.js.map +1 -0
  369. package/dist/tasks/puzzleCaptcha/puzzleTasks.d.ts +32 -0
  370. package/dist/tasks/puzzleCaptcha/puzzleTasks.d.ts.map +1 -0
  371. package/dist/tasks/puzzleCaptcha/puzzleTasks.js +525 -0
  372. package/dist/tasks/puzzleCaptcha/puzzleTasks.js.map +1 -0
  373. package/dist/tasks/puzzleCaptcha/puzzleTasksUtils.d.ts +2 -0
  374. package/dist/tasks/puzzleCaptcha/puzzleTasksUtils.d.ts.map +1 -0
  375. package/dist/tasks/puzzleCaptcha/puzzleTasksUtils.js +7 -0
  376. package/dist/tasks/puzzleCaptcha/puzzleTasksUtils.js.map +1 -0
  377. package/dist/tasks/spam/checkSpamEmail.d.ts +5 -0
  378. package/dist/tasks/spam/checkSpamEmail.d.ts.map +1 -0
  379. package/dist/tasks/spam/checkSpamEmail.js +147 -0
  380. package/dist/tasks/spam/checkSpamEmail.js.map +1 -0
  381. package/dist/tasks/spam/checkTrafficFilter.d.ts +10 -0
  382. package/dist/tasks/spam/checkTrafficFilter.d.ts.map +1 -0
  383. package/dist/tasks/spam/checkTrafficFilter.js +41 -0
  384. package/dist/tasks/spam/checkTrafficFilter.js.map +1 -0
  385. package/dist/tasks/spam/evaluateEmailSpamRules.d.ts +16 -0
  386. package/dist/tasks/spam/evaluateEmailSpamRules.d.ts.map +1 -0
  387. package/dist/tasks/spam/evaluateEmailSpamRules.js +92 -0
  388. package/dist/tasks/spam/evaluateEmailSpamRules.js.map +1 -0
  389. package/dist/tasks/spam/updateSpamEmailDomains.d.ts +4 -0
  390. package/dist/tasks/spam/updateSpamEmailDomains.d.ts.map +1 -0
  391. package/dist/tasks/spam/updateSpamEmailDomains.js +58 -0
  392. package/dist/tasks/spam/updateSpamEmailDomains.js.map +1 -0
  393. package/dist/tasks/tasks.d.ts +36 -0
  394. package/dist/tasks/tasks.d.ts.map +1 -0
  395. package/dist/tasks/tasks.js +102 -4
  396. package/dist/tasks/tasks.js.map +1 -0
  397. package/dist/tests/index.d.ts +2 -0
  398. package/dist/tests/index.d.ts.map +1 -0
  399. package/dist/tests/index.js +2 -0
  400. package/dist/tests/index.js.map +1 -0
  401. package/dist/tests/integration/api/admin/apiRegisterSiteKeyEndpoint.integration.test.d.ts +2 -0
  402. package/dist/tests/integration/api/admin/apiRegisterSiteKeyEndpoint.integration.test.d.ts.map +1 -0
  403. package/dist/tests/integration/api/admin/apiRegisterSiteKeyEndpoint.integration.test.js +82 -0
  404. package/dist/tests/integration/api/admin/apiRegisterSiteKeyEndpoint.integration.test.js.map +1 -0
  405. package/dist/tests/integration/api/admin/apiRegisterSiteKeysEndpoint.integration.test.d.ts +2 -0
  406. package/dist/tests/integration/api/admin/apiRegisterSiteKeysEndpoint.integration.test.d.ts.map +1 -0
  407. package/dist/tests/integration/api/admin/apiRegisterSiteKeysEndpoint.integration.test.js +107 -0
  408. package/dist/tests/integration/api/admin/apiRegisterSiteKeysEndpoint.integration.test.js.map +1 -0
  409. package/dist/tests/integration/api/blacklistRequestInspector.integration.test.d.ts +2 -0
  410. package/dist/tests/integration/api/blacklistRequestInspector.integration.test.d.ts.map +1 -0
  411. package/dist/tests/integration/api/blacklistRequestInspector.integration.test.js +525 -0
  412. package/dist/tests/integration/api/blacklistRequestInspector.integration.test.js.map +1 -0
  413. package/dist/tests/integration/clientSettingsPersistence.integration.test.d.ts +2 -0
  414. package/dist/tests/integration/clientSettingsPersistence.integration.test.d.ts.map +1 -0
  415. package/dist/tests/integration/clientSettingsPersistence.integration.test.js +165 -0
  416. package/dist/tests/integration/clientSettingsPersistence.integration.test.js.map +1 -0
  417. package/dist/tests/integration/decisionMachines.integration.test.d.ts +2 -0
  418. package/dist/tests/integration/decisionMachines.integration.test.d.ts.map +1 -0
  419. package/dist/tests/integration/decisionMachines.integration.test.js +511 -0
  420. package/dist/tests/integration/decisionMachines.integration.test.js.map +1 -0
  421. package/dist/tests/integration/imgCaptcha.integration.test.d.ts +2 -0
  422. package/dist/tests/integration/imgCaptcha.integration.test.d.ts.map +1 -0
  423. package/dist/tests/integration/imgCaptcha.integration.test.js +646 -0
  424. package/dist/tests/integration/imgCaptcha.integration.test.js.map +1 -0
  425. package/dist/tests/integration/ipValidation.integration.test.d.ts +2 -0
  426. package/dist/tests/integration/ipValidation.integration.test.d.ts.map +1 -0
  427. package/dist/tests/integration/ipValidation.integration.test.js +81 -0
  428. package/dist/tests/integration/ipValidation.integration.test.js.map +1 -0
  429. package/dist/tests/integration/mocks/solvedTestCaptchas.d.ts +32 -0
  430. package/dist/tests/integration/mocks/solvedTestCaptchas.d.ts.map +1 -0
  431. package/dist/tests/integration/mocks/solvedTestCaptchas.js +1046 -0
  432. package/dist/tests/integration/mocks/solvedTestCaptchas.js.map +1 -0
  433. package/dist/tests/integration/powCaptcha.integration.test.d.ts +2 -0
  434. package/dist/tests/integration/powCaptcha.integration.test.d.ts.map +1 -0
  435. package/dist/tests/integration/powCaptcha.integration.test.js +502 -0
  436. package/dist/tests/integration/powCaptcha.integration.test.js.map +1 -0
  437. package/dist/tests/integration/registerSitekey.d.ts +3 -0
  438. package/dist/tests/integration/registerSitekey.d.ts.map +1 -0
  439. package/dist/tests/integration/registerSitekey.js +23 -0
  440. package/dist/tests/integration/registerSitekey.js.map +1 -0
  441. package/dist/tests/integration/routingDecisionMachines.integration.test.d.ts +2 -0
  442. package/dist/tests/integration/routingDecisionMachines.integration.test.d.ts.map +1 -0
  443. package/dist/tests/integration/routingDecisionMachines.integration.test.js +276 -0
  444. package/dist/tests/integration/routingDecisionMachines.integration.test.js.map +1 -0
  445. package/dist/tests/integration/testUtils.d.ts +4 -0
  446. package/dist/tests/integration/testUtils.d.ts.map +1 -0
  447. package/dist/tests/integration/testUtils.js +15 -0
  448. package/dist/tests/integration/testUtils.js.map +1 -0
  449. package/dist/tests/integration/usageCounters.integration.test.d.ts +2 -0
  450. package/dist/tests/integration/usageCounters.integration.test.d.ts.map +1 -0
  451. package/dist/tests/integration/usageCounters.integration.test.js +103 -0
  452. package/dist/tests/integration/usageCounters.integration.test.js.map +1 -0
  453. package/dist/tests/integration/userAccessPolicy.d.ts +2 -0
  454. package/dist/tests/integration/userAccessPolicy.d.ts.map +1 -0
  455. package/dist/tests/integration/userAccessPolicy.js +2 -0
  456. package/dist/tests/integration/userAccessPolicy.js.map +1 -0
  457. package/dist/tests/unit/api/admin/apiClearAllCountersEndpoint.unit.test.d.ts +2 -0
  458. package/dist/tests/unit/api/admin/apiClearAllCountersEndpoint.unit.test.d.ts.map +1 -0
  459. package/dist/tests/unit/api/admin/apiClearAllCountersEndpoint.unit.test.js +63 -0
  460. package/dist/tests/unit/api/admin/apiClearAllCountersEndpoint.unit.test.js.map +1 -0
  461. package/dist/tests/unit/api/admin/apiRegisterSiteKeyEndpoint.unit.test.d.ts +2 -0
  462. package/dist/tests/unit/api/admin/apiRegisterSiteKeyEndpoint.unit.test.d.ts.map +1 -0
  463. package/dist/tests/unit/api/admin/apiRegisterSiteKeyEndpoint.unit.test.js +55 -0
  464. package/dist/tests/unit/api/admin/apiRegisterSiteKeyEndpoint.unit.test.js.map +1 -0
  465. package/dist/tests/unit/api/admin/apiRegisterSiteKeysEndpoint.unit.test.d.ts +2 -0
  466. package/dist/tests/unit/api/admin/apiRegisterSiteKeysEndpoint.unit.test.d.ts.map +1 -0
  467. package/dist/tests/unit/api/admin/apiRegisterSiteKeysEndpoint.unit.test.js +67 -0
  468. package/dist/tests/unit/api/admin/apiRegisterSiteKeysEndpoint.unit.test.js.map +1 -0
  469. package/dist/tests/unit/api/admin/apiRemoveDetectorKeyEndpoint.unit.test.d.ts +2 -0
  470. package/dist/tests/unit/api/admin/apiRemoveDetectorKeyEndpoint.unit.test.d.ts.map +1 -0
  471. package/dist/tests/unit/api/admin/apiRemoveDetectorKeyEndpoint.unit.test.js +56 -0
  472. package/dist/tests/unit/api/admin/apiRemoveDetectorKeyEndpoint.unit.test.js.map +1 -0
  473. package/dist/tests/unit/api/admin/apiToggleMaintenanceModeEndpoint.unit.test.d.ts +2 -0
  474. package/dist/tests/unit/api/admin/apiToggleMaintenanceModeEndpoint.unit.test.d.ts.map +1 -0
  475. package/dist/tests/unit/api/admin/apiToggleMaintenanceModeEndpoint.unit.test.js +90 -0
  476. package/dist/tests/unit/api/admin/apiToggleMaintenanceModeEndpoint.unit.test.js.map +1 -0
  477. package/dist/tests/unit/api/admin/apiUpdateDetectorKeyEndpoint.unit.test.d.ts +2 -0
  478. package/dist/tests/unit/api/admin/apiUpdateDetectorKeyEndpoint.unit.test.d.ts.map +1 -0
  479. package/dist/tests/unit/api/admin/apiUpdateDetectorKeyEndpoint.unit.test.js +59 -0
  480. package/dist/tests/unit/api/admin/apiUpdateDetectorKeyEndpoint.unit.test.js.map +1 -0
  481. package/dist/tests/unit/api/adminRoutes.unit.test.d.ts +2 -0
  482. package/dist/tests/unit/api/adminRoutes.unit.test.d.ts.map +1 -0
  483. package/dist/tests/unit/api/adminRoutes.unit.test.js +131 -0
  484. package/dist/tests/unit/api/adminRoutes.unit.test.js.map +1 -0
  485. package/dist/tests/unit/api/blacklistRequestInspector.unit.test.d.ts +2 -0
  486. package/dist/tests/unit/api/blacklistRequestInspector.unit.test.d.ts.map +1 -0
  487. package/dist/tests/unit/api/blacklistRequestInspector.unit.test.js +137 -0
  488. package/dist/tests/unit/api/blacklistRequestInspector.unit.test.js.map +1 -0
  489. package/dist/tests/unit/api/block.unit.test.d.ts +2 -0
  490. package/dist/tests/unit/api/block.unit.test.d.ts.map +1 -0
  491. package/dist/tests/unit/api/block.unit.test.js +60 -0
  492. package/dist/tests/unit/api/block.unit.test.js.map +1 -0
  493. package/dist/tests/unit/api/captcha/getFrictionlessCaptchaChallenge/accessPolicy.unit.test.d.ts +2 -0
  494. package/dist/tests/unit/api/captcha/getFrictionlessCaptchaChallenge/accessPolicy.unit.test.d.ts.map +1 -0
  495. package/dist/tests/unit/api/captcha/getFrictionlessCaptchaChallenge/accessPolicy.unit.test.js +118 -0
  496. package/dist/tests/unit/api/captcha/getFrictionlessCaptchaChallenge/accessPolicy.unit.test.js.map +1 -0
  497. package/dist/tests/unit/api/captcha/getFrictionlessCaptchaChallenge/constants.unit.test.d.ts +2 -0
  498. package/dist/tests/unit/api/captcha/getFrictionlessCaptchaChallenge/constants.unit.test.d.ts.map +1 -0
  499. package/dist/tests/unit/api/captcha/getFrictionlessCaptchaChallenge/constants.unit.test.js +37 -0
  500. package/dist/tests/unit/api/captcha/getFrictionlessCaptchaChallenge/constants.unit.test.js.map +1 -0
  501. package/dist/tests/unit/api/captcha/getFrictionlessCaptchaChallenge/decisionMachine.unit.test.d.ts +2 -0
  502. package/dist/tests/unit/api/captcha/getFrictionlessCaptchaChallenge/decisionMachine.unit.test.d.ts.map +1 -0
  503. package/dist/tests/unit/api/captcha/getFrictionlessCaptchaChallenge/decisionMachine.unit.test.js +154 -0
  504. package/dist/tests/unit/api/captcha/getFrictionlessCaptchaChallenge/decisionMachine.unit.test.js.map +1 -0
  505. package/dist/tests/unit/api/captcha/getFrictionlessCaptchaChallenge/decryptSimdReadings.unit.test.d.ts +2 -0
  506. package/dist/tests/unit/api/captcha/getFrictionlessCaptchaChallenge/decryptSimdReadings.unit.test.d.ts.map +1 -0
  507. package/dist/tests/unit/api/captcha/getFrictionlessCaptchaChallenge/decryptSimdReadings.unit.test.js +46 -0
  508. package/dist/tests/unit/api/captcha/getFrictionlessCaptchaChallenge/decryptSimdReadings.unit.test.js.map +1 -0
  509. package/dist/tests/unit/api/captcha/getFrictionlessCaptchaChallenge/sessionDedup.unit.test.d.ts +2 -0
  510. package/dist/tests/unit/api/captcha/getFrictionlessCaptchaChallenge/sessionDedup.unit.test.d.ts.map +1 -0
  511. package/dist/tests/unit/api/captcha/getFrictionlessCaptchaChallenge/sessionDedup.unit.test.js +69 -0
  512. package/dist/tests/unit/api/captcha/getFrictionlessCaptchaChallenge/sessionDedup.unit.test.js.map +1 -0
  513. package/dist/tests/unit/api/captcha/getFrictionlessCaptchaChallenge/shortCircuit.unit.test.d.ts +2 -0
  514. package/dist/tests/unit/api/captcha/getFrictionlessCaptchaChallenge/shortCircuit.unit.test.d.ts.map +1 -0
  515. package/dist/tests/unit/api/captcha/getFrictionlessCaptchaChallenge/shortCircuit.unit.test.js +98 -0
  516. package/dist/tests/unit/api/captcha/getFrictionlessCaptchaChallenge/shortCircuit.unit.test.js.map +1 -0
  517. package/dist/tests/unit/api/captcha/maintenanceModeResponses.unit.test.d.ts +2 -0
  518. package/dist/tests/unit/api/captcha/maintenanceModeResponses.unit.test.d.ts.map +1 -0
  519. package/dist/tests/unit/api/captcha/maintenanceModeResponses.unit.test.js +60 -0
  520. package/dist/tests/unit/api/captcha/maintenanceModeResponses.unit.test.js.map +1 -0
  521. package/dist/tests/unit/api/captcha/maintenanceModeShortCircuit.unit.test.d.ts +2 -0
  522. package/dist/tests/unit/api/captcha/maintenanceModeShortCircuit.unit.test.d.ts.map +1 -0
  523. package/dist/tests/unit/api/captcha/maintenanceModeShortCircuit.unit.test.js +134 -0
  524. package/dist/tests/unit/api/captcha/maintenanceModeShortCircuit.unit.test.js.map +1 -0
  525. package/dist/tests/unit/api/captcha.unit.test.d.ts +2 -0
  526. package/dist/tests/unit/api/captcha.unit.test.d.ts.map +1 -0
  527. package/dist/tests/unit/api/captcha.unit.test.js +39 -0
  528. package/dist/tests/unit/api/captcha.unit.test.js.map +1 -0
  529. package/dist/tests/unit/api/contextAwareValidation.unit.test.d.ts +2 -0
  530. package/dist/tests/unit/api/contextAwareValidation.unit.test.d.ts.map +1 -0
  531. package/dist/tests/unit/api/contextAwareValidation.unit.test.js +84 -0
  532. package/dist/tests/unit/api/contextAwareValidation.unit.test.js.map +1 -0
  533. package/dist/tests/unit/api/getFrictionlessCaptchaChallenge.unit.test.d.ts +2 -0
  534. package/dist/tests/unit/api/getFrictionlessCaptchaChallenge.unit.test.d.ts.map +1 -0
  535. package/dist/tests/unit/api/getFrictionlessCaptchaChallenge.unit.test.js +435 -0
  536. package/dist/tests/unit/api/getFrictionlessCaptchaChallenge.unit.test.js.map +1 -0
  537. package/dist/tests/unit/api/headerCheckMiddleware.unit.test.d.ts +2 -0
  538. package/dist/tests/unit/api/headerCheckMiddleware.unit.test.d.ts.map +1 -0
  539. package/dist/tests/unit/api/headerCheckMiddleware.unit.test.js +126 -0
  540. package/dist/tests/unit/api/headerCheckMiddleware.unit.test.js.map +1 -0
  541. package/dist/tests/unit/api/ignoreMiddleware.unit.test.d.ts +2 -0
  542. package/dist/tests/unit/api/ignoreMiddleware.unit.test.d.ts.map +1 -0
  543. package/dist/tests/unit/api/ignoreMiddleware.unit.test.js +113 -0
  544. package/dist/tests/unit/api/ignoreMiddleware.unit.test.js.map +1 -0
  545. package/dist/tests/unit/api/ja4Middleware.unit.test.d.ts +2 -0
  546. package/dist/tests/unit/api/ja4Middleware.unit.test.d.ts.map +1 -0
  547. package/dist/tests/unit/api/ja4Middleware.unit.test.js +138 -0
  548. package/dist/tests/unit/api/ja4Middleware.unit.test.js.map +1 -0
  549. package/dist/tests/unit/api/public.unit.test.d.ts +2 -0
  550. package/dist/tests/unit/api/public.unit.test.d.ts.map +1 -0
  551. package/dist/tests/unit/api/public.unit.test.js +198 -0
  552. package/dist/tests/unit/api/public.unit.test.js.map +1 -0
  553. package/dist/tests/unit/api/robotsMiddleware.unit.test.d.ts +2 -0
  554. package/dist/tests/unit/api/robotsMiddleware.unit.test.d.ts.map +1 -0
  555. package/dist/tests/unit/api/robotsMiddleware.unit.test.js +50 -0
  556. package/dist/tests/unit/api/robotsMiddleware.unit.test.js.map +1 -0
  557. package/dist/tests/unit/api/testSiteKey.unit.test.d.ts +2 -0
  558. package/dist/tests/unit/api/testSiteKey.unit.test.d.ts.map +1 -0
  559. package/dist/tests/unit/api/testSiteKey.unit.test.js +51 -0
  560. package/dist/tests/unit/api/testSiteKey.unit.test.js.map +1 -0
  561. package/dist/tests/unit/api/validateAddress.unit.test.d.ts +2 -0
  562. package/dist/tests/unit/api/validateAddress.unit.test.d.ts.map +1 -0
  563. package/dist/tests/unit/api/validateAddress.unit.test.js +141 -0
  564. package/dist/tests/unit/api/validateAddress.unit.test.js.map +1 -0
  565. package/dist/tests/unit/compositeIpAddress.unit.test.d.ts +2 -0
  566. package/dist/tests/unit/compositeIpAddress.unit.test.d.ts.map +1 -0
  567. package/dist/tests/unit/compositeIpAddress.unit.test.js +158 -0
  568. package/dist/tests/unit/compositeIpAddress.unit.test.js.map +1 -0
  569. package/dist/tests/unit/pairs.unit.test.d.ts +2 -0
  570. package/dist/tests/unit/pairs.unit.test.d.ts.map +1 -0
  571. package/dist/tests/unit/pairs.unit.test.js +229 -0
  572. package/dist/tests/unit/pairs.unit.test.js.map +1 -0
  573. package/dist/tests/unit/rules/lang.unit.test.d.ts +2 -0
  574. package/dist/tests/unit/rules/lang.unit.test.d.ts.map +1 -0
  575. package/dist/tests/unit/rules/lang.unit.test.js +207 -0
  576. package/dist/tests/unit/rules/lang.unit.test.js.map +1 -0
  577. package/dist/tests/unit/schedulers/captchaScheduler.unit.test.d.ts +2 -0
  578. package/dist/tests/unit/schedulers/captchaScheduler.unit.test.d.ts.map +1 -0
  579. package/dist/tests/unit/schedulers/captchaScheduler.unit.test.js +75 -0
  580. package/dist/tests/unit/schedulers/captchaScheduler.unit.test.js.map +1 -0
  581. package/dist/tests/unit/schedulers/getClientList.unit.test.d.ts +2 -0
  582. package/dist/tests/unit/schedulers/getClientList.unit.test.d.ts.map +1 -0
  583. package/dist/tests/unit/schedulers/getClientList.unit.test.js +114 -0
  584. package/dist/tests/unit/schedulers/getClientList.unit.test.js.map +1 -0
  585. package/dist/tests/unit/schedulers/setClientEntropy.unit.test.d.ts +2 -0
  586. package/dist/tests/unit/schedulers/setClientEntropy.unit.test.d.ts.map +1 -0
  587. package/dist/tests/unit/schedulers/setClientEntropy.unit.test.js +114 -0
  588. package/dist/tests/unit/schedulers/setClientEntropy.unit.test.js.map +1 -0
  589. package/dist/tests/unit/services/ipComparison.unit.test.d.ts +2 -0
  590. package/dist/tests/unit/services/ipComparison.unit.test.d.ts.map +1 -0
  591. package/dist/tests/unit/services/ipComparison.unit.test.js +272 -0
  592. package/dist/tests/unit/services/ipComparison.unit.test.js.map +1 -0
  593. package/dist/tests/unit/tasks/captchaManager.unit.test.d.ts +2 -0
  594. package/dist/tests/unit/tasks/captchaManager.unit.test.d.ts.map +1 -0
  595. package/dist/tests/unit/tasks/captchaManager.unit.test.js +576 -0
  596. package/dist/tests/unit/tasks/captchaManager.unit.test.js.map +1 -0
  597. package/dist/tests/unit/tasks/client/clientTasks.unit.test.d.ts +2 -0
  598. package/dist/tests/unit/tasks/client/clientTasks.unit.test.d.ts.map +1 -0
  599. package/dist/tests/unit/tasks/client/clientTasks.unit.test.js +343 -0
  600. package/dist/tests/unit/tasks/client/clientTasks.unit.test.js.map +1 -0
  601. package/dist/tests/unit/tasks/dataset/datasetTasks.unit.test.d.ts +2 -0
  602. package/dist/tests/unit/tasks/dataset/datasetTasks.unit.test.d.ts.map +1 -0
  603. package/dist/tests/unit/tasks/dataset/datasetTasks.unit.test.js +92 -0
  604. package/dist/tests/unit/tasks/dataset/datasetTasks.unit.test.js.map +1 -0
  605. package/dist/tests/unit/tasks/dataset/datasetTasksUtils.unit.test.d.ts +2 -0
  606. package/dist/tests/unit/tasks/dataset/datasetTasksUtils.unit.test.d.ts.map +1 -0
  607. package/dist/tests/unit/tasks/dataset/datasetTasksUtils.unit.test.js +75 -0
  608. package/dist/tests/unit/tasks/dataset/datasetTasksUtils.unit.test.js.map +1 -0
  609. package/dist/tests/unit/tasks/decisionMachine/decisionMachineCustomHeaders.unit.test.d.ts +2 -0
  610. package/dist/tests/unit/tasks/decisionMachine/decisionMachineCustomHeaders.unit.test.d.ts.map +1 -0
  611. package/dist/tests/unit/tasks/decisionMachine/decisionMachineCustomHeaders.unit.test.js +213 -0
  612. package/dist/tests/unit/tasks/decisionMachine/decisionMachineCustomHeaders.unit.test.js.map +1 -0
  613. package/dist/tests/unit/tasks/decisionMachine/decisionMachineRunner.unit.test.d.ts +2 -0
  614. package/dist/tests/unit/tasks/decisionMachine/decisionMachineRunner.unit.test.d.ts.map +1 -0
  615. package/dist/tests/unit/tasks/decisionMachine/decisionMachineRunner.unit.test.js +304 -0
  616. package/dist/tests/unit/tasks/decisionMachine/decisionMachineRunner.unit.test.js.map +1 -0
  617. package/dist/tests/unit/tasks/detection/getBehavioralData.unit.test.d.ts +2 -0
  618. package/dist/tests/unit/tasks/detection/getBehavioralData.unit.test.d.ts.map +1 -0
  619. package/dist/tests/unit/tasks/detection/getBehavioralData.unit.test.js +109 -0
  620. package/dist/tests/unit/tasks/detection/getBehavioralData.unit.test.js.map +1 -0
  621. package/dist/tests/unit/tasks/detection/getBotScore.unit.test.d.ts +2 -0
  622. package/dist/tests/unit/tasks/detection/getBotScore.unit.test.d.ts.map +1 -0
  623. package/dist/tests/unit/tasks/detection/getBotScore.unit.test.js +115 -0
  624. package/dist/tests/unit/tasks/detection/getBotScore.unit.test.js.map +1 -0
  625. package/dist/tests/unit/tasks/frictionless/decryptPayload.unit.test.d.ts +2 -0
  626. package/dist/tests/unit/tasks/frictionless/decryptPayload.unit.test.d.ts.map +1 -0
  627. package/dist/tests/unit/tasks/frictionless/decryptPayload.unit.test.js +142 -0
  628. package/dist/tests/unit/tasks/frictionless/decryptPayload.unit.test.js.map +1 -0
  629. package/dist/tests/unit/tasks/frictionless/frictionlessTasks.unit.test.d.ts +2 -0
  630. package/dist/tests/unit/tasks/frictionless/frictionlessTasks.unit.test.d.ts.map +1 -0
  631. package/dist/tests/unit/tasks/frictionless/frictionlessTasks.unit.test.js +350 -0
  632. package/dist/tests/unit/tasks/frictionless/frictionlessTasks.unit.test.js.map +1 -0
  633. package/dist/tests/unit/tasks/frictionless/frictionlessTasksUtils.unit.test.d.ts +2 -0
  634. package/dist/tests/unit/tasks/frictionless/frictionlessTasksUtils.unit.test.d.ts.map +1 -0
  635. package/dist/tests/unit/tasks/frictionless/frictionlessTasksUtils.unit.test.js +103 -0
  636. package/dist/tests/unit/tasks/frictionless/frictionlessTasksUtils.unit.test.js.map +1 -0
  637. package/dist/tests/unit/tasks/frictionless/routingMachine.unit.test.d.ts +2 -0
  638. package/dist/tests/unit/tasks/frictionless/routingMachine.unit.test.d.ts.map +1 -0
  639. package/dist/tests/unit/tasks/frictionless/routingMachine.unit.test.js +169 -0
  640. package/dist/tests/unit/tasks/frictionless/routingMachine.unit.test.js.map +1 -0
  641. package/dist/tests/unit/tasks/imgCaptcha/imgCaptchaTasks.unit.test.d.ts +2 -0
  642. package/dist/tests/unit/tasks/imgCaptcha/imgCaptchaTasks.unit.test.d.ts.map +1 -0
  643. package/dist/tests/unit/tasks/imgCaptcha/imgCaptchaTasks.unit.test.js +1098 -0
  644. package/dist/tests/unit/tasks/imgCaptcha/imgCaptchaTasks.unit.test.js.map +1 -0
  645. package/dist/tests/unit/tasks/imgCaptcha/imgCaptchaTasksUtils.unit.test.d.ts +2 -0
  646. package/dist/tests/unit/tasks/imgCaptcha/imgCaptchaTasksUtils.unit.test.d.ts.map +1 -0
  647. package/dist/tests/unit/tasks/imgCaptcha/imgCaptchaTasksUtils.unit.test.js +56 -0
  648. package/dist/tests/unit/tasks/imgCaptcha/imgCaptchaTasksUtils.unit.test.js.map +1 -0
  649. package/dist/tests/unit/tasks/powCaptcha/powTasks.unit.test.d.ts +2 -0
  650. package/dist/tests/unit/tasks/powCaptcha/powTasks.unit.test.d.ts.map +1 -0
  651. package/dist/tests/unit/tasks/powCaptcha/powTasks.unit.test.js +1714 -0
  652. package/dist/tests/unit/tasks/powCaptcha/powTasks.unit.test.js.map +1 -0
  653. package/dist/tests/unit/tasks/powCaptcha/powTasksUtils.unit.test.d.ts +2 -0
  654. package/dist/tests/unit/tasks/powCaptcha/powTasksUtils.unit.test.d.ts.map +1 -0
  655. package/dist/tests/unit/tasks/powCaptcha/powTasksUtils.unit.test.js +169 -0
  656. package/dist/tests/unit/tasks/powCaptcha/powTasksUtils.unit.test.js.map +1 -0
  657. package/dist/tests/unit/tasks/puzzleCaptcha/puzzleTasks.unit.test.d.ts +2 -0
  658. package/dist/tests/unit/tasks/puzzleCaptcha/puzzleTasks.unit.test.d.ts.map +1 -0
  659. package/dist/tests/unit/tasks/puzzleCaptcha/puzzleTasks.unit.test.js +313 -0
  660. package/dist/tests/unit/tasks/puzzleCaptcha/puzzleTasks.unit.test.js.map +1 -0
  661. package/dist/tests/unit/tasks/puzzleCaptcha/puzzleTasksUtils.unit.test.d.ts +2 -0
  662. package/dist/tests/unit/tasks/puzzleCaptcha/puzzleTasksUtils.unit.test.d.ts.map +1 -0
  663. package/dist/tests/unit/tasks/puzzleCaptcha/puzzleTasksUtils.unit.test.js +29 -0
  664. package/dist/tests/unit/tasks/puzzleCaptcha/puzzleTasksUtils.unit.test.js.map +1 -0
  665. package/dist/tests/unit/tasks/spam/checkSpamEmail.unit.test.d.ts +2 -0
  666. package/dist/tests/unit/tasks/spam/checkSpamEmail.unit.test.d.ts.map +1 -0
  667. package/dist/tests/unit/tasks/spam/checkSpamEmail.unit.test.js +434 -0
  668. package/dist/tests/unit/tasks/spam/checkSpamEmail.unit.test.js.map +1 -0
  669. package/dist/tests/unit/tasks/spam/checkTrafficFilter.unit.test.d.ts +2 -0
  670. package/dist/tests/unit/tasks/spam/checkTrafficFilter.unit.test.d.ts.map +1 -0
  671. package/dist/tests/unit/tasks/spam/checkTrafficFilter.unit.test.js +112 -0
  672. package/dist/tests/unit/tasks/spam/checkTrafficFilter.unit.test.js.map +1 -0
  673. package/dist/tests/unit/tasks/spam/evaluateEmailSpamRules.unit.test.d.ts +2 -0
  674. package/dist/tests/unit/tasks/spam/evaluateEmailSpamRules.unit.test.d.ts.map +1 -0
  675. package/dist/tests/unit/tasks/spam/evaluateEmailSpamRules.unit.test.js +94 -0
  676. package/dist/tests/unit/tasks/spam/evaluateEmailSpamRules.unit.test.js.map +1 -0
  677. package/dist/tests/unit/tasks/streaming/providerDbStreaming.unit.test.d.ts +2 -0
  678. package/dist/tests/unit/tasks/streaming/providerDbStreaming.unit.test.d.ts.map +1 -0
  679. package/dist/tests/unit/tasks/streaming/providerDbStreaming.unit.test.js +94 -0
  680. package/dist/tests/unit/tasks/streaming/providerDbStreaming.unit.test.js.map +1 -0
  681. package/dist/tests/unit/tasks/writeQueueIntegration.unit.test.d.ts +2 -0
  682. package/dist/tests/unit/tasks/writeQueueIntegration.unit.test.d.ts.map +1 -0
  683. package/dist/tests/unit/tasks/writeQueueIntegration.unit.test.js +208 -0
  684. package/dist/tests/unit/tasks/writeQueueIntegration.unit.test.js.map +1 -0
  685. package/dist/tests/unit/testUtils/mockProviderEnv.d.ts +26 -0
  686. package/dist/tests/unit/testUtils/mockProviderEnv.d.ts.map +1 -0
  687. package/dist/tests/unit/testUtils/mockProviderEnv.js +149 -0
  688. package/dist/tests/unit/testUtils/mockProviderEnv.js.map +1 -0
  689. package/dist/tests/unit/util/redisCache.unit.test.d.ts +2 -0
  690. package/dist/tests/unit/util/redisCache.unit.test.d.ts.map +1 -0
  691. package/dist/tests/unit/util/redisCache.unit.test.js +257 -0
  692. package/dist/tests/unit/util/redisCache.unit.test.js.map +1 -0
  693. package/dist/tests/unit/util/usageCounters.unit.test.d.ts +2 -0
  694. package/dist/tests/unit/util/usageCounters.unit.test.d.ts.map +1 -0
  695. package/dist/tests/unit/util/usageCounters.unit.test.js +242 -0
  696. package/dist/tests/unit/util/usageCounters.unit.test.js.map +1 -0
  697. package/dist/tests/unit/util.evaluateIpValidationRules.unit.test.d.ts +2 -0
  698. package/dist/tests/unit/util.evaluateIpValidationRules.unit.test.d.ts.map +1 -0
  699. package/dist/tests/unit/util.evaluateIpValidationRules.unit.test.js +507 -0
  700. package/dist/tests/unit/util.evaluateIpValidationRules.unit.test.js.map +1 -0
  701. package/dist/tests/unit/util.ipDistance.unit.test.d.ts +2 -0
  702. package/dist/tests/unit/util.ipDistance.unit.test.d.ts.map +1 -0
  703. package/dist/tests/unit/util.ipDistance.unit.test.js +99 -0
  704. package/dist/tests/unit/util.ipDistance.unit.test.js.map +1 -0
  705. package/dist/tests/unit/util.unit.test.d.ts +2 -0
  706. package/dist/tests/unit/util.unit.test.d.ts.map +1 -0
  707. package/dist/tests/unit/util.unit.test.js +167 -0
  708. package/dist/tests/unit/util.unit.test.js.map +1 -0
  709. package/dist/tests/unit/utils/devicePlatform.unit.test.d.ts +2 -0
  710. package/dist/tests/unit/utils/devicePlatform.unit.test.d.ts.map +1 -0
  711. package/dist/tests/unit/utils/devicePlatform.unit.test.js +58 -0
  712. package/dist/tests/unit/utils/devicePlatform.unit.test.js.map +1 -0
  713. package/dist/tests/unit/utils/hashUserAgent.unit.test.d.ts +2 -0
  714. package/dist/tests/unit/utils/hashUserAgent.unit.test.d.ts.map +1 -0
  715. package/dist/tests/unit/utils/hashUserAgent.unit.test.js +52 -0
  716. package/dist/tests/unit/utils/hashUserAgent.unit.test.js.map +1 -0
  717. package/dist/tests/unit/utils/hashUserIp.unit.test.d.ts +2 -0
  718. package/dist/tests/unit/utils/hashUserIp.unit.test.d.ts.map +1 -0
  719. package/dist/tests/unit/utils/hashUserIp.unit.test.js +81 -0
  720. package/dist/tests/unit/utils/hashUserIp.unit.test.js.map +1 -0
  721. package/dist/util/usageCounters.d.ts +22 -0
  722. package/dist/util/usageCounters.d.ts.map +1 -0
  723. package/dist/util/usageCounters.js +201 -0
  724. package/dist/util/usageCounters.js.map +1 -0
  725. package/dist/util.d.ts +25 -0
  726. package/dist/util.d.ts.map +1 -0
  727. package/dist/util.js +3 -4
  728. package/dist/util.js.map +1 -0
  729. package/dist/utils/devicePlatform.d.ts +5 -0
  730. package/dist/utils/devicePlatform.d.ts.map +1 -0
  731. package/dist/utils/devicePlatform.js +10 -0
  732. package/dist/utils/devicePlatform.js.map +1 -0
  733. package/dist/utils/dns.d.ts +22 -0
  734. package/dist/utils/dns.d.ts.map +1 -0
  735. package/dist/utils/dns.js +84 -0
  736. package/dist/utils/dns.js.map +1 -0
  737. package/dist/utils/hashUserAgent.d.ts +2 -0
  738. package/dist/utils/hashUserAgent.d.ts.map +1 -0
  739. package/dist/utils/hashUserAgent.js.map +1 -0
  740. package/dist/utils/hashUserIp.d.ts +2 -0
  741. package/dist/utils/hashUserIp.d.ts.map +1 -0
  742. package/dist/utils/hashUserIp.js.map +1 -0
  743. package/dist/utils/honeypot/encoders.d.ts +3 -0
  744. package/dist/utils/honeypot/encoders.d.ts.map +1 -0
  745. package/dist/utils/honeypot/encoders.js +86 -0
  746. package/dist/utils/honeypot/encoders.js.map +1 -0
  747. package/dist/utils/honeypot/phraseBank.d.ts +3 -0
  748. package/dist/utils/honeypot/phraseBank.d.ts.map +1 -0
  749. package/dist/utils/honeypot/phraseBank.js +47 -0
  750. package/dist/utils/honeypot/phraseBank.js.map +1 -0
  751. package/dist/utils/normalizeRequestIp.d.ts +3 -0
  752. package/dist/utils/normalizeRequestIp.d.ts.map +1 -0
  753. package/dist/utils/normalizeRequestIp.js +27 -0
  754. package/dist/utils/normalizeRequestIp.js.map +1 -0
  755. package/package.json +30 -21
  756. package/vite.cjs.config.ts +17 -5
  757. package/vite.esm.config.ts +18 -4
  758. package/vite.test.config.ts +1 -1
  759. package/vite.threads.test.config.ts +1 -1
  760. package/dist/cjs/services/ipInfo.cjs +0 -87
  761. package/dist/services/ipInfo.js +0 -87
@@ -0,0 +1,646 @@
1
+ import { stringToU8a, u8aToHex } from "@polkadot/util";
2
+ import { buildDataset, datasetWithSolutionHashes } from "@prosopo/datasets";
3
+ import { ProviderEnvironment } from "@prosopo/env";
4
+ import { generateMnemonic, getPair } from "@prosopo/keyring";
5
+ import { Tasks, isTlsAvailable, startProviderApi } from "@prosopo/provider";
6
+ import { ApiParams, CaptchaType, ClientApiPaths, ClientSettingsSchema, DatabaseTypes, ProsopoConfigSchema, Tier, encodeProcaptchaOutput, } from "@prosopo/types";
7
+ import { embedData } from "@prosopo/util";
8
+ import { randomAsHex } from "@prosopo/util-crypto";
9
+ import { GenericContainer } from "testcontainers";
10
+ import { afterAll, beforeAll, beforeEach, describe, expect, it } from "vitest";
11
+ import { dummyUserAccount } from "./mocks/solvedTestCaptchas.js";
12
+ const solutions = datasetWithSolutionHashes;
13
+ const userAccount = "5FHneW46xGXgs5mUiveU4sbTyGBzmstUspZC92UhjJM694ty";
14
+ function getRandomPort() {
15
+ return Math.floor(Math.random() * 50000) + 10000;
16
+ }
17
+ async function registerSiteKeyInDb(env, siteKey, captchaType) {
18
+ const tasks = new Tasks(env);
19
+ await tasks.clientTaskManager.registerSiteKey(siteKey, Tier.Free, ClientSettingsSchema.parse({
20
+ captchaType,
21
+ domains: ["localhost", "0.0.0.0", "127.0.0.0", "example.com"],
22
+ frictionlessThreshold: 0.5,
23
+ powDifficulty: 4,
24
+ }));
25
+ }
26
+ describe("Image Captcha Integration Tests", () => {
27
+ let env;
28
+ let mongoContainer;
29
+ let redisContainer;
30
+ let server;
31
+ let dappAccount;
32
+ let mnemonic;
33
+ let tasks;
34
+ let testPort;
35
+ let baseUrl;
36
+ let builtDataset;
37
+ beforeAll(async () => {
38
+ testPort = 40000 + (process.pid % 10000) + Math.floor(Math.random() * 5000);
39
+ const protocol = isTlsAvailable() ? "https" : "http";
40
+ baseUrl = `${protocol}://localhost:${testPort}`;
41
+ mongoContainer = await new GenericContainer("mongo:6.0.17")
42
+ .withExposedPorts(27017)
43
+ .withEnvironment({
44
+ MONGO_INITDB_ROOT_USERNAME: "root",
45
+ MONGO_INITDB_ROOT_PASSWORD: "root",
46
+ MONGO_INITDB_DATABASE: "prosopo_test",
47
+ })
48
+ .start();
49
+ const mongoHost = mongoContainer.getHost();
50
+ const mongoPort = mongoContainer.getMappedPort(27017);
51
+ const skipRedis = process.env.SKIP_REDIS === "true";
52
+ let redisHost = "localhost";
53
+ let redisPort = 6379;
54
+ if (!skipRedis) {
55
+ try {
56
+ redisContainer = await new GenericContainer("redis/redis-stack:latest")
57
+ .withExposedPorts(6379)
58
+ .withEnvironment({
59
+ REDIS_ARGS: "--requirepass root",
60
+ })
61
+ .start();
62
+ redisHost = redisContainer.getHost();
63
+ redisPort = redisContainer.getMappedPort(6379);
64
+ }
65
+ catch (error) {
66
+ console.warn("Failed to start Redis container, continuing without Redis:", error);
67
+ }
68
+ }
69
+ const config = ProsopoConfigSchema.parse({
70
+ defaultEnvironment: "development",
71
+ host: `${protocol}://localhost:${testPort}`,
72
+ account: {
73
+ secret: process.env.PROVIDER_MNEMONIC ||
74
+ "puppy cream effort carbon despair leg pyramid cotton endorse immense drill peasant",
75
+ },
76
+ authAccount: {
77
+ secret: process.env.ADMIN_MNEMONIC ||
78
+ "puppy cream effort carbon despair leg pyramid cotton endorse immense drill peasant",
79
+ },
80
+ database: {
81
+ development: {
82
+ type: DatabaseTypes.enum.provider,
83
+ endpoint: `mongodb://root:root@${mongoHost}:${mongoPort}`,
84
+ dbname: "prosopo_test",
85
+ authSource: "admin",
86
+ },
87
+ },
88
+ ...(redisContainer
89
+ ? {
90
+ redisConnection: {
91
+ url: `redis://:${encodeURIComponent("root")}@${redisHost}:${redisPort}`,
92
+ password: "root",
93
+ indexName: randomAsHex(16),
94
+ },
95
+ }
96
+ : {}),
97
+ ipApi: {
98
+ baseUrl: "https://dummyUrl.com",
99
+ apiKey: "dummyKey",
100
+ },
101
+ server: {
102
+ baseURL: `${protocol}://localhost`,
103
+ port: testPort,
104
+ },
105
+ });
106
+ env = new ProviderEnvironment(config);
107
+ await env.isReady();
108
+ const db = env.getDb();
109
+ if (redisContainer) {
110
+ try {
111
+ await db.getRedisAccessRulesConnection().getClient();
112
+ }
113
+ catch (error) {
114
+ console.warn("Redis connection failed, continuing without Redis:", error);
115
+ }
116
+ }
117
+ tasks = new Tasks(env);
118
+ env.logger.info(() => ({ msg: "Setting up provider dataset" }));
119
+ await tasks.datasetManager.providerSetDataset(datasetWithSolutionHashes);
120
+ builtDataset = await buildDataset(datasetWithSolutionHashes);
121
+ env.logger.info(() => ({
122
+ msg: `Starting provider API on port ${testPort}`,
123
+ }));
124
+ let retries = 0;
125
+ const maxRetries = 3;
126
+ while (retries < maxRetries) {
127
+ try {
128
+ server = await startProviderApi(env, true, testPort);
129
+ await new Promise((resolve, reject) => {
130
+ if (!server) {
131
+ reject(new Error("Server is not running."));
132
+ return;
133
+ }
134
+ const checkInterval = setInterval(() => {
135
+ if (server?.listening) {
136
+ clearInterval(checkInterval);
137
+ resolve();
138
+ }
139
+ }, 100);
140
+ setTimeout(() => {
141
+ clearInterval(checkInterval);
142
+ if (!server?.listening) {
143
+ reject(new Error("Server failed to start listening within timeout"));
144
+ }
145
+ }, 5000);
146
+ });
147
+ env.logger.info(() => ({
148
+ msg: `Provider API started successfully on port ${testPort}`,
149
+ }));
150
+ break;
151
+ }
152
+ catch (error) {
153
+ retries++;
154
+ env.logger.warn(() => ({
155
+ msg: `Failed to start server (attempt ${retries}/${maxRetries})`,
156
+ err: error,
157
+ }));
158
+ if (server) {
159
+ await new Promise((resolve) => {
160
+ server?.close(() => resolve());
161
+ });
162
+ server = undefined;
163
+ }
164
+ if (retries >= maxRetries) {
165
+ throw new Error(`Failed to start server after ${maxRetries} attempts: ${error}`);
166
+ }
167
+ testPort =
168
+ 40000 + (process.pid % 10000) + Math.floor(Math.random() * 5000);
169
+ baseUrl = `${protocol}://localhost:${testPort}`;
170
+ env.logger.info(() => ({
171
+ msg: `Retrying with port ${testPort}`,
172
+ }));
173
+ await new Promise((resolve) => setTimeout(resolve, 1000));
174
+ }
175
+ }
176
+ });
177
+ beforeEach(async () => {
178
+ [mnemonic, dappAccount] = await generateMnemonic();
179
+ await registerSiteKeyInDb(env, dappAccount, CaptchaType.image);
180
+ });
181
+ afterAll(async () => {
182
+ if (server) {
183
+ await new Promise((resolve) => {
184
+ server?.close((err) => {
185
+ if (err) {
186
+ console.error("Error closing server:", err);
187
+ }
188
+ resolve();
189
+ });
190
+ });
191
+ await new Promise((resolve) => setTimeout(resolve, 500));
192
+ server = undefined;
193
+ }
194
+ if (env) {
195
+ try {
196
+ await env.getDb().close();
197
+ }
198
+ catch (error) {
199
+ console.error("Error closing database:", error);
200
+ }
201
+ }
202
+ if (mongoContainer) {
203
+ try {
204
+ await mongoContainer.stop();
205
+ }
206
+ catch (error) {
207
+ console.error("Error stopping mongo container:", error);
208
+ }
209
+ }
210
+ if (redisContainer) {
211
+ try {
212
+ await redisContainer.stop();
213
+ }
214
+ catch (error) {
215
+ console.error("Error stopping redis container:", error);
216
+ }
217
+ }
218
+ });
219
+ describe("GetImageCaptchaChallenge", () => {
220
+ it("should supply an image captcha challenge to a Dapp User", async () => {
221
+ const origin = "https://localhost";
222
+ const getImageCaptchaURL = `${baseUrl}${ClientApiPaths.GetImageCaptchaChallenge}`;
223
+ const getImgCaptchaBody = {
224
+ [ApiParams.dapp]: dappAccount,
225
+ [ApiParams.user]: userAccount,
226
+ [ApiParams.datasetId]: solutions.datasetId,
227
+ };
228
+ const response = await fetch(getImageCaptchaURL, {
229
+ method: "POST",
230
+ body: JSON.stringify(getImgCaptchaBody),
231
+ headers: {
232
+ "Content-Type": "application/json",
233
+ Origin: origin,
234
+ "Prosopo-Site-Key": dappAccount,
235
+ "Prosopo-User": userAccount,
236
+ },
237
+ });
238
+ console.log(response);
239
+ expect(response.status).toBe(200);
240
+ const data = await response.json();
241
+ expect(data).toHaveProperty("captchas");
242
+ });
243
+ it("should not supply an image captcha challenge to a Dapp User if the site key is not registered", async () => {
244
+ const origin = "https://localhost";
245
+ const [_mnemonic, unregisteredAccount] = await generateMnemonic();
246
+ const getImageCaptchaURL = `${baseUrl}${ClientApiPaths.GetImageCaptchaChallenge}`;
247
+ const body = {
248
+ [ApiParams.dapp]: unregisteredAccount,
249
+ [ApiParams.user]: userAccount,
250
+ [ApiParams.datasetId]: solutions.datasetId,
251
+ };
252
+ const response = await fetch(getImageCaptchaURL, {
253
+ method: "POST",
254
+ body: JSON.stringify(body),
255
+ headers: {
256
+ "Content-Type": "application/json",
257
+ Origin: origin,
258
+ "Prosopo-Site-Key": unregisteredAccount,
259
+ "Prosopo-User": userAccount,
260
+ },
261
+ });
262
+ expect(response.status).toBe(400);
263
+ const data = (await response.json());
264
+ expect(data).toHaveProperty("error");
265
+ expect(data.error?.message).toBe("Site key not registered");
266
+ });
267
+ it("should not supply an image captcha challenge to a Dapp User if an invalid site key is provided", async () => {
268
+ const invalidSiteKey = "junk";
269
+ const origin = "https://localhost";
270
+ const getImageCaptchaURL = `${baseUrl}${ClientApiPaths.GetImageCaptchaChallenge}`;
271
+ const body = {
272
+ [ApiParams.dapp]: invalidSiteKey,
273
+ [ApiParams.user]: userAccount,
274
+ [ApiParams.datasetId]: solutions.datasetId,
275
+ };
276
+ const response = await fetch(getImageCaptchaURL, {
277
+ method: "POST",
278
+ body: JSON.stringify(body),
279
+ headers: {
280
+ "Content-Type": "application/json",
281
+ Origin: origin,
282
+ "Prosopo-Site-Key": invalidSiteKey,
283
+ "Prosopo-User": userAccount,
284
+ },
285
+ });
286
+ const data = (await response.json());
287
+ expect(response.status).toBe(400);
288
+ expect(data).toHaveProperty("error");
289
+ expect(data.error?.message).toBe("Invalid site key");
290
+ });
291
+ it("should fail if datasetID is incorrect", async () => {
292
+ const datasetId = "thewrongdsetId";
293
+ const origin = "https://localhost";
294
+ const getImageCaptchaURL = `${baseUrl}${ClientApiPaths.GetImageCaptchaChallenge}`;
295
+ const body = {
296
+ [ApiParams.dapp]: dappAccount,
297
+ [ApiParams.user]: userAccount,
298
+ [ApiParams.datasetId]: datasetId,
299
+ };
300
+ const response = await fetch(getImageCaptchaURL, {
301
+ method: "POST",
302
+ body: JSON.stringify(body),
303
+ headers: {
304
+ "Content-Type": "application/json",
305
+ Origin: origin,
306
+ "Prosopo-Site-Key": dappAccount,
307
+ "Prosopo-User": userAccount,
308
+ },
309
+ });
310
+ expect(response.status).toBe(500);
311
+ });
312
+ it("should return an error if the captcha type is set to pow", async () => {
313
+ const origin = "https://localhost";
314
+ const getImageCaptchaURL = `${baseUrl}${ClientApiPaths.GetImageCaptchaChallenge}`;
315
+ await registerSiteKeyInDb(env, dappAccount, CaptchaType.pow);
316
+ const body = {
317
+ [ApiParams.dapp]: dappAccount,
318
+ [ApiParams.user]: userAccount,
319
+ [ApiParams.datasetId]: solutions.datasetId,
320
+ };
321
+ const response = await fetch(getImageCaptchaURL, {
322
+ method: "POST",
323
+ body: JSON.stringify(body),
324
+ headers: {
325
+ "Content-Type": "application/json",
326
+ Origin: origin,
327
+ "Prosopo-Site-Key": dappAccount,
328
+ "Prosopo-User": userAccount,
329
+ },
330
+ });
331
+ expect(response.status).toBe(400);
332
+ const data = (await response.json());
333
+ expect(data).toHaveProperty("error");
334
+ expect(data.error?.message).toBe("Incorrect CAPTCHA type");
335
+ expect(data.error?.code).toBe(400);
336
+ });
337
+ it("should return a translated error if the captcha type is set to pow and the language is set to es", async () => {
338
+ const origin = "https://localhost";
339
+ const getImageCaptchaURL = `${baseUrl}${ClientApiPaths.GetImageCaptchaChallenge}`;
340
+ await registerSiteKeyInDb(env, dappAccount, CaptchaType.pow);
341
+ const body = {
342
+ [ApiParams.dapp]: dappAccount,
343
+ [ApiParams.user]: userAccount,
344
+ [ApiParams.datasetId]: solutions.datasetId,
345
+ };
346
+ const response = await fetch(getImageCaptchaURL, {
347
+ method: "POST",
348
+ body: JSON.stringify(body),
349
+ headers: {
350
+ "Content-Type": "application/json",
351
+ Origin: origin,
352
+ "Prosopo-Site-Key": dappAccount,
353
+ "Prosopo-User": userAccount,
354
+ "Accept-Language": "es",
355
+ },
356
+ });
357
+ expect(response.status).toBe(400);
358
+ const data = (await response.json());
359
+ expect(data).toHaveProperty("error");
360
+ expect(data.error?.message).toBe("Tipo de CAPTCHA incorrecto");
361
+ expect(data.error?.code).toBe(400);
362
+ });
363
+ });
364
+ it("should return an error if the captcha type is set to frictionless and no sessionID is sent", async () => {
365
+ const origin = "https://localhost";
366
+ const getImageCaptchaURL = `${baseUrl}${ClientApiPaths.GetImageCaptchaChallenge}`;
367
+ await registerSiteKeyInDb(env, dappAccount, CaptchaType.frictionless);
368
+ const body = {
369
+ [ApiParams.dapp]: dappAccount,
370
+ [ApiParams.user]: userAccount,
371
+ [ApiParams.datasetId]: solutions.datasetId,
372
+ };
373
+ const response = await fetch(getImageCaptchaURL, {
374
+ method: "POST",
375
+ body: JSON.stringify(body),
376
+ headers: {
377
+ "Content-Type": "application/json",
378
+ Origin: origin,
379
+ "Prosopo-Site-Key": dappAccount,
380
+ "Prosopo-User": userAccount,
381
+ },
382
+ });
383
+ expect(response.status).toBe(400);
384
+ const data = (await response.json());
385
+ expect(data).toHaveProperty("error");
386
+ expect(data.error?.message).toBe("Incorrect CAPTCHA type");
387
+ expect(data.error?.code).toBe(400);
388
+ });
389
+ describe("SubmitImageCaptchaSolution", () => {
390
+ it("should verify a correctly completed image captcha as true", async () => {
391
+ const pair = getPair(dummyUserAccount.seed, undefined, "sr25519", 42);
392
+ const userAccount = dummyUserAccount.address;
393
+ const origin = "https://localhost";
394
+ const getImageCaptchaURL = `${baseUrl}${ClientApiPaths.GetImageCaptchaChallenge}`;
395
+ const getImgCaptchaBody = {
396
+ [ApiParams.dapp]: dappAccount,
397
+ [ApiParams.user]: userAccount,
398
+ [ApiParams.datasetId]: solutions.datasetId,
399
+ };
400
+ const response = await fetch(getImageCaptchaURL, {
401
+ method: "POST",
402
+ body: JSON.stringify(getImgCaptchaBody),
403
+ headers: {
404
+ "Content-Type": "application/json",
405
+ Origin: origin,
406
+ "Prosopo-Site-Key": dappAccount,
407
+ "Prosopo-User": userAccount,
408
+ },
409
+ });
410
+ expect(response.status).toBe(200);
411
+ const data = (await response.json());
412
+ const solutionMap = new Map(builtDataset.captchas
413
+ .filter((captcha) => captcha.solution)
414
+ .map((captcha) => [
415
+ captcha.captchaContentId,
416
+ captcha.solution?.map((s) => s.toString()) ?? [],
417
+ ]));
418
+ const temp = data.captchas.map((captcha, index) => {
419
+ const solution = solutionMap.get(captcha.captchaContentId);
420
+ if (!solution) {
421
+ throw new Error(`Solution not found for captchaContentId: ${captcha.captchaContentId}`);
422
+ }
423
+ return {
424
+ captchaContentId: captcha.captchaContentId,
425
+ captchaId: captcha.captchaId,
426
+ salt: embedData(randomAsHex(), [
427
+ 1 + index,
428
+ 2 + index,
429
+ 3 + index,
430
+ 4 + index,
431
+ ]),
432
+ solution: solution,
433
+ };
434
+ });
435
+ const solveImgCaptchaBody = {
436
+ [ApiParams.captchas]: temp,
437
+ [ApiParams.dapp]: dappAccount,
438
+ [ApiParams.requestHash]: data.requestHash,
439
+ [ApiParams.signature]: {
440
+ [ApiParams.user]: {
441
+ [ApiParams.timestamp]: u8aToHex(pair.sign(stringToU8a(data.timestamp))),
442
+ },
443
+ [ApiParams.provider]: data[ApiParams.signature][ApiParams.provider],
444
+ },
445
+ [ApiParams.timestamp]: data.timestamp,
446
+ [ApiParams.user]: userAccount,
447
+ };
448
+ const solveThatCaptcha = await fetch(`${baseUrl}${ClientApiPaths.SubmitImageCaptchaSolution}`, {
449
+ method: "POST",
450
+ headers: {
451
+ "Content-Type": "application/json",
452
+ Origin: origin,
453
+ "Prosopo-Site-Key": dappAccount,
454
+ "Prosopo-User": userAccount,
455
+ },
456
+ body: JSON.stringify(solveImgCaptchaBody),
457
+ });
458
+ const jsonRes = await solveThatCaptcha.json();
459
+ const res = jsonRes;
460
+ expect(res.status).toBe("You correctly answered the captchas");
461
+ });
462
+ it("should mark an incorrectly completed image captcha as disapproved", async () => {
463
+ const pair = getPair(dummyUserAccount.seed, undefined, "sr25519", 42);
464
+ const userAccount = dummyUserAccount.address;
465
+ const origin = "https://localhost";
466
+ const getImageCaptchaURL = `${baseUrl}${ClientApiPaths.GetImageCaptchaChallenge}`;
467
+ const getImgCaptchaBody = {
468
+ [ApiParams.dapp]: dappAccount,
469
+ [ApiParams.user]: userAccount,
470
+ [ApiParams.datasetId]: solutions.datasetId,
471
+ };
472
+ const response = await fetch(getImageCaptchaURL, {
473
+ method: "POST",
474
+ body: JSON.stringify(getImgCaptchaBody),
475
+ headers: {
476
+ "Content-Type": "application/json",
477
+ Origin: origin,
478
+ "Prosopo-Site-Key": dappAccount,
479
+ "Prosopo-User": userAccount,
480
+ },
481
+ });
482
+ expect(response.status).toBe(200);
483
+ const data = (await response.json());
484
+ const captchaInfoMap = new Map(builtDataset.captchas
485
+ .filter((captcha) => captcha.solution)
486
+ .map((captcha) => [
487
+ captcha.captchaContentId,
488
+ {
489
+ solution: captcha.solution?.map((s) => s.toString()) ?? [],
490
+ itemHashes: captcha.items.map((item) => item.hash),
491
+ },
492
+ ]));
493
+ const temp = data.captchas.map((captcha, index) => {
494
+ const info = captchaInfoMap.get(captcha.captchaContentId);
495
+ if (!info) {
496
+ throw new Error(`Captcha info not found for captchaContentId: ${captcha.captchaContentId}`);
497
+ }
498
+ return {
499
+ captchaContentId: captcha.captchaContentId,
500
+ captchaId: captcha.captchaId,
501
+ salt: embedData(randomAsHex(), [
502
+ 1 + index,
503
+ 2 + index,
504
+ 3 + index,
505
+ 4 + index,
506
+ ]),
507
+ solution: info.itemHashes.filter((hash) => !info.solution.includes(hash)),
508
+ };
509
+ });
510
+ const solveImgCaptchaBody = {
511
+ [ApiParams.captchas]: temp,
512
+ [ApiParams.dapp]: dappAccount,
513
+ [ApiParams.requestHash]: data.requestHash,
514
+ [ApiParams.signature]: {
515
+ [ApiParams.user]: {
516
+ [ApiParams.timestamp]: u8aToHex(pair.sign(stringToU8a(data.timestamp))),
517
+ },
518
+ [ApiParams.provider]: data[ApiParams.signature][ApiParams.provider],
519
+ },
520
+ [ApiParams.timestamp]: data.timestamp,
521
+ [ApiParams.user]: userAccount,
522
+ };
523
+ const solveThatCaptcha = await fetch(`${baseUrl}${ClientApiPaths.SubmitImageCaptchaSolution}`, {
524
+ method: "POST",
525
+ headers: {
526
+ "Content-Type": "application/json",
527
+ Origin: origin,
528
+ "Prosopo-Site-Key": dappAccount,
529
+ "Prosopo-User": userAccount,
530
+ },
531
+ body: JSON.stringify(solveImgCaptchaBody),
532
+ });
533
+ const res = (await solveThatCaptcha.json());
534
+ expect(res.verified).toBe(false);
535
+ expect(res.status).toBe("You answered one or more captchas incorrectly. Please try again");
536
+ });
537
+ it("should disapprove a correct solution submitted after the time limit, and the dapp should verify the challenge as disapproved", async () => {
538
+ const pair = getPair(dummyUserAccount.seed, undefined, "sr25519", 42);
539
+ const userAccount = dummyUserAccount.address;
540
+ const origin = "https://localhost";
541
+ const getImageCaptchaURL = `${baseUrl}${ClientApiPaths.GetImageCaptchaChallenge}`;
542
+ const getImgCaptchaBody = {
543
+ [ApiParams.dapp]: dappAccount,
544
+ [ApiParams.user]: userAccount,
545
+ [ApiParams.datasetId]: solutions.datasetId,
546
+ };
547
+ const response = await fetch(getImageCaptchaURL, {
548
+ method: "POST",
549
+ body: JSON.stringify(getImgCaptchaBody),
550
+ headers: {
551
+ "Content-Type": "application/json",
552
+ Origin: origin,
553
+ "Prosopo-Site-Key": dappAccount,
554
+ "Prosopo-User": userAccount,
555
+ },
556
+ });
557
+ expect(response.status).toBe(200);
558
+ const data = (await response.json());
559
+ const expireResult = await env
560
+ .getDb()
561
+ .getTables()
562
+ .commitment.updateOne({ requestHash: data.requestHash, pending: true }, { $set: { deadlineTimestamp: new Date(Date.now() - 60 * 1000) } });
563
+ expect(expireResult.modifiedCount).toBe(1);
564
+ const solutionMap = new Map(builtDataset.captchas
565
+ .filter((captcha) => captcha.solution)
566
+ .map((captcha) => [
567
+ captcha.captchaContentId,
568
+ captcha.solution?.map((s) => s.toString()) ?? [],
569
+ ]));
570
+ const temp = data.captchas.map((captcha, index) => {
571
+ const solution = solutionMap.get(captcha.captchaContentId);
572
+ if (!solution) {
573
+ throw new Error(`Solution not found for captchaContentId: ${captcha.captchaContentId}`);
574
+ }
575
+ return {
576
+ captchaContentId: captcha.captchaContentId,
577
+ captchaId: captcha.captchaId,
578
+ salt: embedData(randomAsHex(), [
579
+ 1 + index,
580
+ 2 + index,
581
+ 3 + index,
582
+ 4 + index,
583
+ ]),
584
+ solution: solution,
585
+ };
586
+ });
587
+ const solveImgCaptchaBody = {
588
+ [ApiParams.captchas]: temp,
589
+ [ApiParams.dapp]: dappAccount,
590
+ [ApiParams.requestHash]: data.requestHash,
591
+ [ApiParams.signature]: {
592
+ [ApiParams.user]: {
593
+ [ApiParams.timestamp]: u8aToHex(pair.sign(stringToU8a(data.timestamp))),
594
+ },
595
+ [ApiParams.provider]: data[ApiParams.signature][ApiParams.provider],
596
+ },
597
+ [ApiParams.timestamp]: data.timestamp,
598
+ [ApiParams.user]: userAccount,
599
+ };
600
+ const solveThatCaptcha = await fetch(`${baseUrl}${ClientApiPaths.SubmitImageCaptchaSolution}`, {
601
+ method: "POST",
602
+ headers: {
603
+ "Content-Type": "application/json",
604
+ Origin: origin,
605
+ "Prosopo-Site-Key": dappAccount,
606
+ "Prosopo-User": userAccount,
607
+ },
608
+ body: JSON.stringify(solveImgCaptchaBody),
609
+ });
610
+ expect(solveThatCaptcha.status).toBe(200);
611
+ const solutionResult = (await solveThatCaptcha.json());
612
+ expect(solutionResult.verified).toBe(false);
613
+ expect(solutionResult.status).toBe("You answered one or more captchas incorrectly. Please try again");
614
+ const dappPair = getPair(mnemonic);
615
+ const verifyTimestamp = Date.now().toString();
616
+ const token = encodeProcaptchaOutput({
617
+ [ApiParams.dapp]: dappAccount,
618
+ [ApiParams.user]: userAccount,
619
+ [ApiParams.timestamp]: verifyTimestamp,
620
+ [ApiParams.signature]: {
621
+ [ApiParams.provider]: {},
622
+ [ApiParams.user]: {},
623
+ },
624
+ });
625
+ const dappSignature = u8aToHex(dappPair.sign(stringToU8a(verifyTimestamp)));
626
+ const verifyBody = {
627
+ [ApiParams.token]: token,
628
+ [ApiParams.dappSignature]: dappSignature,
629
+ };
630
+ const verifyResponse = await fetch(`${baseUrl}${ClientApiPaths.VerifyImageCaptchaSolutionDapp}`, {
631
+ method: "POST",
632
+ headers: {
633
+ "Content-Type": "application/json",
634
+ Origin: origin,
635
+ "Prosopo-Site-Key": dappAccount,
636
+ "Prosopo-User": userAccount,
637
+ },
638
+ body: JSON.stringify(verifyBody),
639
+ });
640
+ expect(verifyResponse.status).toBe(200);
641
+ const verifyResult = (await verifyResponse.json());
642
+ expect(verifyResult.verified).toBe(false);
643
+ });
644
+ });
645
+ });
646
+ //# sourceMappingURL=imgCaptcha.integration.test.js.map