@prosopo/provider 3.12.3 → 3.12.14

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 (351) hide show
  1. package/CHANGELOG.md +173 -0
  2. package/coverage/base.css +224 -0
  3. package/coverage/block-navigation.js +87 -0
  4. package/coverage/clover.xml +4278 -0
  5. package/coverage/coverage-final.json +42 -0
  6. package/coverage/favicon.png +0 -0
  7. package/coverage/index.html +311 -0
  8. package/coverage/prettify.css +1 -0
  9. package/coverage/prettify.js +2 -0
  10. package/coverage/sort-arrow-sprite.png +0 -0
  11. package/coverage/sorter.js +210 -0
  12. package/coverage/src/api/admin/apiAdminRoutesProvider.ts.html +214 -0
  13. package/coverage/src/api/admin/apiRegisterSiteKeyEndpoint.ts.html +259 -0
  14. package/coverage/src/api/admin/apiRemoveDetectorKeyEndpoint.ts.html +283 -0
  15. package/coverage/src/api/admin/apiToggleMaintenanceModeEndpoint.ts.html +334 -0
  16. package/coverage/src/api/admin/apiUpdateDetectorKeyEndpoint.ts.html +298 -0
  17. package/coverage/src/api/admin/createApiAdminRoutesProvider.ts.html +163 -0
  18. package/coverage/src/api/admin/index.html +191 -0
  19. package/coverage/src/api/blacklistRequestInspector.ts.html +751 -0
  20. package/coverage/src/api/block.ts.html +187 -0
  21. package/coverage/src/api/captcha.ts.html +2803 -0
  22. package/coverage/src/api/domainMiddleware.ts.html +493 -0
  23. package/coverage/src/api/headerCheckMiddleware.ts.html +256 -0
  24. package/coverage/src/api/ignoreMiddleware.ts.html +181 -0
  25. package/coverage/src/api/index.html +266 -0
  26. package/coverage/src/api/ja4Middleware.ts.html +400 -0
  27. package/coverage/src/api/public.ts.html +343 -0
  28. package/coverage/src/api/robotsMiddleware.ts.html +157 -0
  29. package/coverage/src/api/validateAddress.ts.html +214 -0
  30. package/coverage/src/api/verify.ts.html +871 -0
  31. package/coverage/src/compositeIpAddress.ts.html +340 -0
  32. package/coverage/src/index.html +161 -0
  33. package/coverage/src/index.ts.html +175 -0
  34. package/coverage/src/pairs.ts.html +238 -0
  35. package/coverage/src/rules/index.html +116 -0
  36. package/coverage/src/rules/lang.ts.html +187 -0
  37. package/coverage/src/schedulers/captchaScheduler.ts.html +250 -0
  38. package/coverage/src/schedulers/getClientList.ts.html +271 -0
  39. package/coverage/src/schedulers/index.html +131 -0
  40. package/coverage/src/services/index.html +131 -0
  41. package/coverage/src/services/ipComparison.ts.html +685 -0
  42. package/coverage/src/services/ipInfo.ts.html +490 -0
  43. package/coverage/src/tasks/captchaManager.ts.html +865 -0
  44. package/coverage/src/tasks/client/clientTasks.ts.html +1381 -0
  45. package/coverage/src/tasks/client/index.html +116 -0
  46. package/coverage/src/tasks/dataset/datasetTasks.ts.html +268 -0
  47. package/coverage/src/tasks/dataset/datasetTasksUtils.ts.html +271 -0
  48. package/coverage/src/tasks/dataset/index.html +131 -0
  49. package/coverage/src/tasks/detection/decodePayload.js.html +127 -0
  50. package/coverage/src/tasks/detection/getBotScore.ts.html +244 -0
  51. package/coverage/src/tasks/detection/index.html +131 -0
  52. package/coverage/src/tasks/frictionless/frictionlessTasks.ts.html +1216 -0
  53. package/coverage/src/tasks/frictionless/frictionlessTasksUtils.ts.html +247 -0
  54. package/coverage/src/tasks/frictionless/index.html +131 -0
  55. package/coverage/src/tasks/imgCaptcha/imgCaptchaTasks.ts.html +1972 -0
  56. package/coverage/src/tasks/imgCaptcha/imgCaptchaTasksUtils.ts.html +232 -0
  57. package/coverage/src/tasks/imgCaptcha/index.html +131 -0
  58. package/coverage/src/tasks/index.html +146 -0
  59. package/coverage/src/tasks/index.ts.html +127 -0
  60. package/coverage/src/tasks/powCaptcha/index.html +131 -0
  61. package/coverage/src/tasks/powCaptcha/powTasks.ts.html +961 -0
  62. package/coverage/src/tasks/powCaptcha/powTasksUtils.ts.html +244 -0
  63. package/coverage/src/tasks/tasks.ts.html +388 -0
  64. package/coverage/src/util.ts.html +1627 -0
  65. package/coverage/src/utils/hashUserAgent.ts.html +184 -0
  66. package/coverage/src/utils/index.html +116 -0
  67. package/dist/api/admin/apiAdminRoutesProvider.d.ts +9 -0
  68. package/dist/api/admin/apiAdminRoutesProvider.d.ts.map +1 -0
  69. package/dist/api/admin/apiAdminRoutesProvider.js +13 -18
  70. package/dist/api/admin/apiAdminRoutesProvider.js.map +1 -0
  71. package/dist/api/admin/apiRegisterSiteKeyEndpoint.d.ts +14 -0
  72. package/dist/api/admin/apiRegisterSiteKeyEndpoint.d.ts.map +1 -0
  73. package/dist/api/admin/apiRegisterSiteKeyEndpoint.js.map +1 -0
  74. package/dist/api/admin/apiRemoveDetectorKeyEndpoint.d.ts +23 -0
  75. package/dist/api/admin/apiRemoveDetectorKeyEndpoint.d.ts.map +1 -0
  76. package/dist/api/admin/apiRemoveDetectorKeyEndpoint.js.map +1 -0
  77. package/dist/api/admin/apiToggleMaintenanceModeEndpoint.d.ts +13 -0
  78. package/dist/api/admin/apiToggleMaintenanceModeEndpoint.d.ts.map +1 -0
  79. package/dist/api/admin/apiToggleMaintenanceModeEndpoint.js +40 -0
  80. package/dist/api/admin/apiToggleMaintenanceModeEndpoint.js.map +1 -0
  81. package/dist/api/admin/apiUpdateDetectorKeyEndpoint.d.ts +14 -0
  82. package/dist/api/admin/apiUpdateDetectorKeyEndpoint.d.ts.map +1 -0
  83. package/dist/api/admin/apiUpdateDetectorKeyEndpoint.js.map +1 -0
  84. package/dist/api/admin/createApiAdminRoutesProvider.d.ts +4 -0
  85. package/dist/api/admin/createApiAdminRoutesProvider.d.ts.map +1 -0
  86. package/dist/api/admin/createApiAdminRoutesProvider.js.map +1 -0
  87. package/dist/api/blacklistRequestInspector.d.ts +19 -0
  88. package/dist/api/blacklistRequestInspector.d.ts.map +1 -0
  89. package/dist/api/blacklistRequestInspector.js +4 -4
  90. package/dist/api/blacklistRequestInspector.js.map +1 -0
  91. package/dist/api/block.d.ts +3 -0
  92. package/dist/api/block.d.ts.map +1 -0
  93. package/dist/api/block.js.map +1 -0
  94. package/dist/api/captcha.d.ts +4 -0
  95. package/dist/api/captcha.d.ts.map +1 -0
  96. package/dist/api/captcha.js +130 -40
  97. package/dist/api/captcha.js.map +1 -0
  98. package/dist/api/domainMiddleware.d.ts +4 -0
  99. package/dist/api/domainMiddleware.d.ts.map +1 -0
  100. package/dist/api/domainMiddleware.js.map +1 -0
  101. package/dist/api/headerCheckMiddleware.d.ts +4 -0
  102. package/dist/api/headerCheckMiddleware.d.ts.map +1 -0
  103. package/dist/api/headerCheckMiddleware.js.map +1 -0
  104. package/dist/api/ignoreMiddleware.d.ts +3 -0
  105. package/dist/api/ignoreMiddleware.d.ts.map +1 -0
  106. package/dist/api/ignoreMiddleware.js.map +1 -0
  107. package/dist/api/ja4Middleware.d.ts +10 -0
  108. package/dist/api/ja4Middleware.d.ts.map +1 -0
  109. package/dist/api/ja4Middleware.js.map +1 -0
  110. package/dist/api/public.d.ts +4 -0
  111. package/dist/api/public.d.ts.map +1 -0
  112. package/dist/api/public.js.map +1 -0
  113. package/dist/api/robotsMiddleware.d.ts +3 -0
  114. package/dist/api/robotsMiddleware.d.ts.map +1 -0
  115. package/dist/api/robotsMiddleware.js.map +1 -0
  116. package/dist/api/validateAddress.d.ts +5 -0
  117. package/dist/api/validateAddress.d.ts.map +1 -0
  118. package/dist/api/validateAddress.js.map +1 -0
  119. package/dist/api/verify.d.ts +4 -0
  120. package/dist/api/verify.d.ts.map +1 -0
  121. package/dist/api/verify.js +23 -1
  122. package/dist/api/verify.js.map +1 -0
  123. package/dist/cjs/api/admin/apiAdminRoutesProvider.cjs +13 -18
  124. package/dist/cjs/api/admin/apiRegisterSiteKeyEndpoint.cjs +2 -1
  125. package/dist/cjs/api/admin/apiRemoveDetectorKeyEndpoint.cjs +3 -2
  126. package/dist/cjs/api/admin/apiToggleMaintenanceModeEndpoint.cjs +41 -0
  127. package/dist/cjs/api/blacklistRequestInspector.cjs +3 -3
  128. package/dist/cjs/api/captcha.cjs +130 -40
  129. package/dist/cjs/api/ja4Middleware.cjs +2 -1
  130. package/dist/cjs/api/verify.cjs +23 -1
  131. package/dist/cjs/tasks/captchaManager.cjs +5 -21
  132. package/dist/cjs/tasks/client/clientTasks.cjs +3 -36
  133. package/dist/cjs/tasks/detection/decodePayload.cjs +570 -669
  134. package/dist/cjs/tasks/detection/getBotScore.cjs +15 -2
  135. package/dist/cjs/tasks/frictionless/frictionlessTasks.cjs +116 -29
  136. package/dist/cjs/tasks/imgCaptcha/imgCaptchaTasks.cjs +18 -12
  137. package/dist/cjs/tasks/powCaptcha/powTasks.cjs +6 -6
  138. package/dist/cjs/util.cjs +14 -1
  139. package/dist/compositeIpAddress.d.ts +5 -0
  140. package/dist/compositeIpAddress.d.ts.map +1 -0
  141. package/dist/compositeIpAddress.js.map +1 -0
  142. package/dist/index.d.ts +17 -0
  143. package/dist/index.d.ts.map +1 -0
  144. package/dist/index.js.map +1 -0
  145. package/dist/pairs.d.ts +3 -0
  146. package/dist/pairs.d.ts.map +1 -0
  147. package/dist/pairs.js.map +1 -0
  148. package/dist/rules/lang.d.ts +3 -0
  149. package/dist/rules/lang.d.ts.map +1 -0
  150. package/dist/rules/lang.js.map +1 -0
  151. package/dist/schedulers/captchaScheduler.d.ts +4 -0
  152. package/dist/schedulers/captchaScheduler.d.ts.map +1 -0
  153. package/dist/schedulers/captchaScheduler.js.map +1 -0
  154. package/dist/schedulers/getClientList.d.ts +4 -0
  155. package/dist/schedulers/getClientList.d.ts.map +1 -0
  156. package/dist/schedulers/getClientList.js.map +1 -0
  157. package/dist/schedulers/setClientEntropy.d.ts +4 -0
  158. package/dist/schedulers/setClientEntropy.d.ts.map +1 -0
  159. package/dist/schedulers/setClientEntropy.js +31 -0
  160. package/dist/schedulers/setClientEntropy.js.map +1 -0
  161. package/dist/services/ipComparison.d.ts +3 -0
  162. package/dist/services/ipComparison.d.ts.map +1 -0
  163. package/dist/services/ipComparison.js.map +1 -0
  164. package/dist/services/ipInfo.d.ts +3 -0
  165. package/dist/services/ipInfo.d.ts.map +1 -0
  166. package/dist/services/ipInfo.js.map +1 -0
  167. package/dist/tasks/captchaManager.d.ts +34 -0
  168. package/dist/tasks/captchaManager.d.ts.map +1 -0
  169. package/dist/tasks/captchaManager.js +3 -20
  170. package/dist/tasks/captchaManager.js.map +1 -0
  171. package/dist/tasks/client/clientTasks.d.ts +21 -0
  172. package/dist/tasks/client/clientTasks.d.ts.map +1 -0
  173. package/dist/tasks/client/clientTasks.js +3 -36
  174. package/dist/tasks/client/clientTasks.js.map +1 -0
  175. package/dist/tasks/dataset/datasetTasks.d.ts +13 -0
  176. package/dist/tasks/dataset/datasetTasks.d.ts.map +1 -0
  177. package/dist/tasks/dataset/datasetTasks.js.map +1 -0
  178. package/dist/tasks/dataset/datasetTasksUtils.d.ts +3 -0
  179. package/dist/tasks/dataset/datasetTasksUtils.d.ts.map +1 -0
  180. package/dist/tasks/dataset/datasetTasksUtils.js.map +1 -0
  181. package/dist/tasks/detection/decodePayload.d.ts +5 -0
  182. package/dist/tasks/detection/decodePayload.d.ts.map +1 -0
  183. package/dist/tasks/detection/decodePayload.js +570 -669
  184. package/dist/tasks/detection/decodePayload.js.map +1 -0
  185. package/dist/tasks/detection/getBotScore.d.ts +20 -0
  186. package/dist/tasks/detection/getBotScore.d.ts.map +1 -0
  187. package/dist/tasks/detection/getBotScore.js +17 -4
  188. package/dist/tasks/detection/getBotScore.js.map +1 -0
  189. package/dist/tasks/frictionless/frictionlessTasks.d.ts +67 -0
  190. package/dist/tasks/frictionless/frictionlessTasks.d.ts.map +1 -0
  191. package/dist/tasks/frictionless/frictionlessTasks.js +116 -29
  192. package/dist/tasks/frictionless/frictionlessTasks.js.map +1 -0
  193. package/dist/tasks/frictionless/frictionlessTasksUtils.d.ts +6 -0
  194. package/dist/tasks/frictionless/frictionlessTasksUtils.d.ts.map +1 -0
  195. package/dist/tasks/frictionless/frictionlessTasksUtils.js.map +1 -0
  196. package/dist/tasks/imgCaptcha/imgCaptchaTasks.d.ts +30 -0
  197. package/dist/tasks/imgCaptcha/imgCaptchaTasks.d.ts.map +1 -0
  198. package/dist/tasks/imgCaptcha/imgCaptchaTasks.js +18 -12
  199. package/dist/tasks/imgCaptcha/imgCaptchaTasks.js.map +1 -0
  200. package/dist/tasks/imgCaptcha/imgCaptchaTasksUtils.d.ts +7 -0
  201. package/dist/tasks/imgCaptcha/imgCaptchaTasksUtils.d.ts.map +1 -0
  202. package/dist/tasks/imgCaptcha/imgCaptchaTasksUtils.js.map +1 -0
  203. package/dist/tasks/index.d.ts +2 -0
  204. package/dist/tasks/index.d.ts.map +1 -0
  205. package/dist/tasks/index.js.map +1 -0
  206. package/dist/tasks/powCaptcha/powTasks.d.ts +17 -0
  207. package/dist/tasks/powCaptcha/powTasks.d.ts.map +1 -0
  208. package/dist/tasks/powCaptcha/powTasks.js +6 -6
  209. package/dist/tasks/powCaptcha/powTasks.js.map +1 -0
  210. package/dist/tasks/powCaptcha/powTasksUtils.d.ts +3 -0
  211. package/dist/tasks/powCaptcha/powTasksUtils.d.ts.map +1 -0
  212. package/dist/tasks/powCaptcha/powTasksUtils.js.map +1 -0
  213. package/dist/tasks/tasks.d.ts +25 -0
  214. package/dist/tasks/tasks.d.ts.map +1 -0
  215. package/dist/tasks/tasks.js.map +1 -0
  216. package/dist/tests/index.d.ts +2 -0
  217. package/dist/tests/index.d.ts.map +1 -0
  218. package/dist/tests/index.js +2 -0
  219. package/dist/tests/index.js.map +1 -0
  220. package/dist/tests/integration/accessRules.integration.test.d.ts +2 -0
  221. package/dist/tests/integration/accessRules.integration.test.d.ts.map +1 -0
  222. package/dist/tests/integration/accessRules.integration.test.js +588 -0
  223. package/dist/tests/integration/accessRules.integration.test.js.map +1 -0
  224. package/dist/tests/integration/api/admin/apiRegisterSiteKeyEndpoint.integration.test.d.ts +2 -0
  225. package/dist/tests/integration/api/admin/apiRegisterSiteKeyEndpoint.integration.test.d.ts.map +1 -0
  226. package/dist/tests/integration/api/admin/apiRegisterSiteKeyEndpoint.integration.test.js +60 -0
  227. package/dist/tests/integration/api/admin/apiRegisterSiteKeyEndpoint.integration.test.js.map +1 -0
  228. package/dist/tests/integration/api/blacklistRequestInspector.integration.test.d.ts +2 -0
  229. package/dist/tests/integration/api/blacklistRequestInspector.integration.test.d.ts.map +1 -0
  230. package/dist/tests/integration/api/blacklistRequestInspector.integration.test.js +368 -0
  231. package/dist/tests/integration/api/blacklistRequestInspector.integration.test.js.map +1 -0
  232. package/dist/tests/integration/imgCaptcha.integration.test.d.ts +2 -0
  233. package/dist/tests/integration/imgCaptcha.integration.test.d.ts.map +1 -0
  234. package/dist/tests/integration/imgCaptcha.integration.test.js +272 -0
  235. package/dist/tests/integration/imgCaptcha.integration.test.js.map +1 -0
  236. package/dist/tests/integration/ipValidation.integration.test.d.ts +2 -0
  237. package/dist/tests/integration/ipValidation.integration.test.d.ts.map +1 -0
  238. package/dist/tests/integration/ipValidation.integration.test.js +75 -0
  239. package/dist/tests/integration/ipValidation.integration.test.js.map +1 -0
  240. package/dist/tests/integration/mocks/solvedTestCaptchas.d.ts +32 -0
  241. package/dist/tests/integration/mocks/solvedTestCaptchas.d.ts.map +1 -0
  242. package/dist/tests/integration/mocks/solvedTestCaptchas.js +1046 -0
  243. package/dist/tests/integration/mocks/solvedTestCaptchas.js.map +1 -0
  244. package/dist/tests/integration/powCaptcha.integration.test.d.ts +2 -0
  245. package/dist/tests/integration/powCaptcha.integration.test.d.ts.map +1 -0
  246. package/dist/tests/integration/powCaptcha.integration.test.js +308 -0
  247. package/dist/tests/integration/powCaptcha.integration.test.js.map +1 -0
  248. package/dist/tests/integration/registerSitekey.d.ts +3 -0
  249. package/dist/tests/integration/registerSitekey.d.ts.map +1 -0
  250. package/dist/tests/integration/registerSitekey.js +24 -0
  251. package/dist/tests/integration/registerSitekey.js.map +1 -0
  252. package/dist/tests/integration/userAccessPolicy.d.ts +2 -0
  253. package/dist/tests/integration/userAccessPolicy.d.ts.map +1 -0
  254. package/dist/tests/integration/userAccessPolicy.js +2 -0
  255. package/dist/tests/integration/userAccessPolicy.js.map +1 -0
  256. package/dist/tests/unit/api/blacklistRequestInspector.unit.test.d.ts +2 -0
  257. package/dist/tests/unit/api/blacklistRequestInspector.unit.test.d.ts.map +1 -0
  258. package/dist/tests/unit/api/blacklistRequestInspector.unit.test.js +60 -0
  259. package/dist/tests/unit/api/blacklistRequestInspector.unit.test.js.map +1 -0
  260. package/dist/tests/unit/api/ignoreMiddleware.unit.test.d.ts +2 -0
  261. package/dist/tests/unit/api/ignoreMiddleware.unit.test.d.ts.map +1 -0
  262. package/dist/tests/unit/api/ignoreMiddleware.unit.test.js +43 -0
  263. package/dist/tests/unit/api/ignoreMiddleware.unit.test.js.map +1 -0
  264. package/dist/tests/unit/api/ja4Middleware.unit.test.d.ts +2 -0
  265. package/dist/tests/unit/api/ja4Middleware.unit.test.d.ts.map +1 -0
  266. package/dist/tests/unit/api/ja4Middleware.unit.test.js +57 -0
  267. package/dist/tests/unit/api/ja4Middleware.unit.test.js.map +1 -0
  268. package/dist/tests/unit/compositeIpAddress.unit.test.d.ts +2 -0
  269. package/dist/tests/unit/compositeIpAddress.unit.test.d.ts.map +1 -0
  270. package/dist/tests/unit/compositeIpAddress.unit.test.js +86 -0
  271. package/dist/tests/unit/compositeIpAddress.unit.test.js.map +1 -0
  272. package/dist/tests/unit/pairs.unit.test.d.ts +2 -0
  273. package/dist/tests/unit/pairs.unit.test.d.ts.map +1 -0
  274. package/dist/tests/unit/pairs.unit.test.js +83 -0
  275. package/dist/tests/unit/pairs.unit.test.js.map +1 -0
  276. package/dist/tests/unit/schedulers/captchaScheduler.unit.test.d.ts +2 -0
  277. package/dist/tests/unit/schedulers/captchaScheduler.unit.test.d.ts.map +1 -0
  278. package/dist/tests/unit/schedulers/captchaScheduler.unit.test.js +75 -0
  279. package/dist/tests/unit/schedulers/captchaScheduler.unit.test.js.map +1 -0
  280. package/dist/tests/unit/services/ipComparison.unit.test.d.ts +2 -0
  281. package/dist/tests/unit/services/ipComparison.unit.test.d.ts.map +1 -0
  282. package/dist/tests/unit/services/ipComparison.unit.test.js +258 -0
  283. package/dist/tests/unit/services/ipComparison.unit.test.js.map +1 -0
  284. package/dist/tests/unit/services/ipInfo.unit.test.d.ts +2 -0
  285. package/dist/tests/unit/services/ipInfo.unit.test.d.ts.map +1 -0
  286. package/dist/tests/unit/services/ipInfo.unit.test.js +210 -0
  287. package/dist/tests/unit/services/ipInfo.unit.test.js.map +1 -0
  288. package/dist/tests/unit/tasks/captchaManager.unit.test.d.ts +2 -0
  289. package/dist/tests/unit/tasks/captchaManager.unit.test.d.ts.map +1 -0
  290. package/dist/tests/unit/tasks/captchaManager.unit.test.js +311 -0
  291. package/dist/tests/unit/tasks/captchaManager.unit.test.js.map +1 -0
  292. package/dist/tests/unit/tasks/client/clientTasks.unit.test.d.ts +2 -0
  293. package/dist/tests/unit/tasks/client/clientTasks.unit.test.d.ts.map +1 -0
  294. package/dist/tests/unit/tasks/client/clientTasks.unit.test.js +289 -0
  295. package/dist/tests/unit/tasks/client/clientTasks.unit.test.js.map +1 -0
  296. package/dist/tests/unit/tasks/dataset/datasetTasks.unit.test.d.ts +2 -0
  297. package/dist/tests/unit/tasks/dataset/datasetTasks.unit.test.d.ts.map +1 -0
  298. package/dist/tests/unit/tasks/dataset/datasetTasks.unit.test.js +92 -0
  299. package/dist/tests/unit/tasks/dataset/datasetTasks.unit.test.js.map +1 -0
  300. package/dist/tests/unit/tasks/dataset/datasetTasksUtils.unit.test.d.ts +2 -0
  301. package/dist/tests/unit/tasks/dataset/datasetTasksUtils.unit.test.d.ts.map +1 -0
  302. package/dist/tests/unit/tasks/dataset/datasetTasksUtils.unit.test.js +75 -0
  303. package/dist/tests/unit/tasks/dataset/datasetTasksUtils.unit.test.js.map +1 -0
  304. package/dist/tests/unit/tasks/frictionless/decryptPayload.unit.test.d.ts +2 -0
  305. package/dist/tests/unit/tasks/frictionless/decryptPayload.unit.test.d.ts.map +1 -0
  306. package/dist/tests/unit/tasks/frictionless/decryptPayload.unit.test.js +143 -0
  307. package/dist/tests/unit/tasks/frictionless/decryptPayload.unit.test.js.map +1 -0
  308. package/dist/tests/unit/tasks/frictionless/frictionlessTasks.unit.test.d.ts +2 -0
  309. package/dist/tests/unit/tasks/frictionless/frictionlessTasks.unit.test.d.ts.map +1 -0
  310. package/dist/tests/unit/tasks/frictionless/frictionlessTasks.unit.test.js +145 -0
  311. package/dist/tests/unit/tasks/frictionless/frictionlessTasks.unit.test.js.map +1 -0
  312. package/dist/tests/unit/tasks/frictionless/frictionlessTasksUtils.unit.test.d.ts +2 -0
  313. package/dist/tests/unit/tasks/frictionless/frictionlessTasksUtils.unit.test.d.ts.map +1 -0
  314. package/dist/tests/unit/tasks/frictionless/frictionlessTasksUtils.unit.test.js +64 -0
  315. package/dist/tests/unit/tasks/frictionless/frictionlessTasksUtils.unit.test.js.map +1 -0
  316. package/dist/tests/unit/tasks/imgCaptcha/imgCaptchaTasks.unit.test.d.ts +2 -0
  317. package/dist/tests/unit/tasks/imgCaptcha/imgCaptchaTasks.unit.test.d.ts.map +1 -0
  318. package/dist/tests/unit/tasks/imgCaptcha/imgCaptchaTasks.unit.test.js +388 -0
  319. package/dist/tests/unit/tasks/imgCaptcha/imgCaptchaTasks.unit.test.js.map +1 -0
  320. package/dist/tests/unit/tasks/imgCaptcha/imgCaptchaTasksUtils.unit.test.d.ts +2 -0
  321. package/dist/tests/unit/tasks/imgCaptcha/imgCaptchaTasksUtils.unit.test.d.ts.map +1 -0
  322. package/dist/tests/unit/tasks/imgCaptcha/imgCaptchaTasksUtils.unit.test.js +46 -0
  323. package/dist/tests/unit/tasks/imgCaptcha/imgCaptchaTasksUtils.unit.test.js.map +1 -0
  324. package/dist/tests/unit/tasks/powCaptcha/powTasks.unit.test.d.ts +2 -0
  325. package/dist/tests/unit/tasks/powCaptcha/powTasks.unit.test.d.ts.map +1 -0
  326. package/dist/tests/unit/tasks/powCaptcha/powTasks.unit.test.js +216 -0
  327. package/dist/tests/unit/tasks/powCaptcha/powTasks.unit.test.js.map +1 -0
  328. package/dist/tests/unit/tasks/powCaptcha/powTasksUtils.unit.test.d.ts +2 -0
  329. package/dist/tests/unit/tasks/powCaptcha/powTasksUtils.unit.test.d.ts.map +1 -0
  330. package/dist/tests/unit/tasks/powCaptcha/powTasksUtils.unit.test.js +69 -0
  331. package/dist/tests/unit/tasks/powCaptcha/powTasksUtils.unit.test.js.map +1 -0
  332. package/dist/tests/unit/util.evaluateIpValidationRules.unit.test.d.ts +2 -0
  333. package/dist/tests/unit/util.evaluateIpValidationRules.unit.test.d.ts.map +1 -0
  334. package/dist/tests/unit/util.evaluateIpValidationRules.unit.test.js +505 -0
  335. package/dist/tests/unit/util.evaluateIpValidationRules.unit.test.js.map +1 -0
  336. package/dist/tests/unit/util.ipDistance.unit.test.d.ts +2 -0
  337. package/dist/tests/unit/util.ipDistance.unit.test.d.ts.map +1 -0
  338. package/dist/tests/unit/util.ipDistance.unit.test.js +93 -0
  339. package/dist/tests/unit/util.ipDistance.unit.test.js.map +1 -0
  340. package/dist/tests/unit/util.unit.test.d.ts +2 -0
  341. package/dist/tests/unit/util.unit.test.d.ts.map +1 -0
  342. package/dist/tests/unit/util.unit.test.js +170 -0
  343. package/dist/tests/unit/util.unit.test.js.map +1 -0
  344. package/dist/util.d.ts +24 -0
  345. package/dist/util.d.ts.map +1 -0
  346. package/dist/util.js +14 -1
  347. package/dist/util.js.map +1 -0
  348. package/dist/utils/hashUserAgent.d.ts +2 -0
  349. package/dist/utils/hashUserAgent.d.ts.map +1 -0
  350. package/dist/utils/hashUserAgent.js.map +1 -0
  351. package/package.json +24 -25
@@ -2,9 +2,10 @@
2
2
  Object.defineProperty(exports, Symbol.toStringTag, { value: "Module" });
3
3
  const decodePayload = require("./decodePayload.cjs");
4
4
  const DEFAULT_ENTROPY = 13837;
5
- const getBotScore = async (payload, privateKeyString) => {
5
+ const getBotScore = async (payload, headHash, privateKeyString) => {
6
6
  const result = await decodePayload(
7
7
  payload,
8
+ headHash,
8
9
  privateKeyString
9
10
  );
10
11
  const baseBotScore = result.score;
@@ -12,6 +13,9 @@ const getBotScore = async (payload, privateKeyString) => {
12
13
  const providerSelectEntropy = result.providerSelectEntropy;
13
14
  const userId = result.userId;
14
15
  const userAgent = result.userAgent;
16
+ const isWebView = result.isWebView ?? false;
17
+ const isIframe = result.isIframe ?? false;
18
+ const decryptedHeadHash = result.decryptedHeadHash;
15
19
  if (baseBotScore === void 0) {
16
20
  return {
17
21
  baseBotScore: 1,
@@ -19,6 +23,15 @@ const getBotScore = async (payload, privateKeyString) => {
19
23
  providerSelectEntropy: DEFAULT_ENTROPY
20
24
  };
21
25
  }
22
- return { baseBotScore, timestamp, providerSelectEntropy, userId, userAgent };
26
+ return {
27
+ baseBotScore,
28
+ timestamp,
29
+ providerSelectEntropy,
30
+ userId,
31
+ userAgent,
32
+ isWebView,
33
+ isIframe,
34
+ decryptedHeadHash
35
+ };
23
36
  };
24
37
  exports.getBotScore = getBotScore;
@@ -22,17 +22,44 @@ class FrictionlessManager extends captchaManager.CaptchaManager {
22
22
  super(db, pair, logger);
23
23
  this.config = config;
24
24
  }
25
+ setSessionParams(params) {
26
+ this.sessionParams = {
27
+ token: params.token,
28
+ score: params.score,
29
+ threshold: params.threshold,
30
+ scoreComponents: params.scoreComponents,
31
+ providerSelectEntropy: params.providerSelectEntropy,
32
+ ipAddress: params.ipAddress,
33
+ webView: params.webView ?? false,
34
+ iFrame: params.iFrame ?? false,
35
+ decryptedHeadHash: params.decryptedHeadHash
36
+ };
37
+ }
38
+ updateScore(score, scoreComponents) {
39
+ if (this.sessionParams) {
40
+ this.sessionParams.score = score;
41
+ this.sessionParams.scoreComponents = scoreComponents;
42
+ }
43
+ }
25
44
  checkLangRules(acceptLanguage) {
26
45
  return lang.checkLangRules(this.config, acceptLanguage);
27
46
  }
28
- async createSession(tokenId, captchaType, solvedImagesCount, powDifficulty) {
47
+ async createSession(token, score, threshold, scoreComponents, providerSelectEntropy, ipAddress, captchaType, solvedImagesCount, powDifficulty, webView = false, iFrame = false, decryptedHeadHash = "") {
29
48
  const sessionRecord = {
30
49
  sessionId: uuid.v4(),
31
50
  createdAt: /* @__PURE__ */ new Date(),
32
- tokenId,
51
+ token,
52
+ score,
53
+ threshold,
54
+ scoreComponents,
55
+ providerSelectEntropy,
56
+ ipAddress,
33
57
  captchaType,
34
58
  solvedImagesCount,
35
- powDifficulty
59
+ powDifficulty,
60
+ webView,
61
+ iFrame,
62
+ decryptedHeadHash
36
63
  };
37
64
  await this.db.storeSessionRecord(sessionRecord);
38
65
  return sessionRecord;
@@ -55,11 +82,26 @@ class FrictionlessManager extends captchaManager.CaptchaManager {
55
82
  }
56
83
  return { verified: true, domain };
57
84
  }
58
- async sendImageCaptcha(tokenId, solvedImagesCount) {
85
+ async sendImageCaptcha(params) {
86
+ const effectiveParams = { ...this.sessionParams, ...params };
87
+ if (!effectiveParams.token || effectiveParams.score === void 0 || effectiveParams.threshold === void 0 || !effectiveParams.scoreComponents || effectiveParams.providerSelectEntropy === void 0 || !effectiveParams.ipAddress) {
88
+ throw new Error(
89
+ "Session parameters must be set before calling sendImageCaptcha"
90
+ );
91
+ }
59
92
  const sessionRecord = await this.createSession(
60
- tokenId,
93
+ effectiveParams.token,
94
+ effectiveParams.score,
95
+ effectiveParams.threshold,
96
+ effectiveParams.scoreComponents,
97
+ effectiveParams.providerSelectEntropy,
98
+ effectiveParams.ipAddress,
61
99
  types.CaptchaType.image,
62
- solvedImagesCount
100
+ params?.solvedImagesCount,
101
+ void 0,
102
+ effectiveParams.webView ?? false,
103
+ effectiveParams.iFrame ?? false,
104
+ effectiveParams.decryptedHeadHash
63
105
  );
64
106
  return {
65
107
  [types.ApiParams.captchaType]: types.CaptchaType.image,
@@ -67,11 +109,26 @@ class FrictionlessManager extends captchaManager.CaptchaManager {
67
109
  [types.ApiParams.status]: "ok"
68
110
  };
69
111
  }
70
- async sendPowCaptcha(tokenId, powDifficulty) {
112
+ async sendPowCaptcha(params) {
113
+ const effectiveParams = { ...this.sessionParams, ...params };
114
+ if (!effectiveParams.token || effectiveParams.score === void 0 || effectiveParams.threshold === void 0 || !effectiveParams.scoreComponents || effectiveParams.providerSelectEntropy === void 0 || !effectiveParams.ipAddress) {
115
+ throw new Error(
116
+ "Session parameters must be set before calling sendPowCaptcha"
117
+ );
118
+ }
71
119
  const sessionRecord = await this.createSession(
72
- tokenId,
120
+ effectiveParams.token,
121
+ effectiveParams.score,
122
+ effectiveParams.threshold,
123
+ effectiveParams.scoreComponents,
124
+ effectiveParams.providerSelectEntropy,
125
+ effectiveParams.ipAddress,
73
126
  types.CaptchaType.pow,
74
- powDifficulty
127
+ void 0,
128
+ params?.powDifficulty,
129
+ effectiveParams.webView ?? false,
130
+ effectiveParams.iFrame ?? false,
131
+ effectiveParams.decryptedHeadHash
75
132
  );
76
133
  return {
77
134
  [types.ApiParams.captchaType]: types.CaptchaType.pow,
@@ -79,47 +136,57 @@ class FrictionlessManager extends captchaManager.CaptchaManager {
79
136
  [types.ApiParams.status]: "ok"
80
137
  };
81
138
  }
82
- async scoreIncreaseAccessPolicy(accessPolicy, baseBotScore, botScore, tokenId) {
139
+ scoreIncreaseAccessPolicy(accessPolicy, baseBotScore, botScore, scoreComponents) {
83
140
  const accessPolicyPenalty = accessPolicy?.frictionlessScore || this.config.penalties.PENALTY_ACCESS_RULE;
84
141
  botScore += accessPolicyPenalty;
85
- await this.db.updateFrictionlessTokenRecord(tokenId, {
142
+ return {
86
143
  score: botScore,
87
144
  scoreComponents: {
88
- baseScore: baseBotScore,
145
+ ...scoreComponents,
89
146
  accessPolicy: accessPolicyPenalty
90
147
  }
91
- });
92
- return botScore;
148
+ };
93
149
  }
94
- async scoreIncreaseUnverifiedHost(host, baseBotScore, botScore, tokenId) {
150
+ scoreIncreaseUnverifiedHost(host, baseBotScore, botScore, scoreComponents) {
95
151
  this.logger.info(() => ({
96
152
  msg: "Host not verified",
97
153
  data: { requested: this.config.host, selected: host }
98
154
  }));
99
155
  botScore += this.config.penalties.PENALTY_UNVERIFIED_HOST;
100
- await this.db.updateFrictionlessTokenRecord(tokenId, {
156
+ return {
101
157
  score: botScore,
102
158
  scoreComponents: {
103
- baseScore: baseBotScore,
159
+ ...scoreComponents,
104
160
  unverifiedHost: this.config.penalties.PENALTY_UNVERIFIED_HOST
105
161
  }
106
- });
107
- return botScore;
162
+ };
163
+ }
164
+ scoreIncreaseWebView(baseBotScore, botScore, scoreComponents) {
165
+ this.logger.debug(() => ({
166
+ msg: "WebView detected"
167
+ }));
168
+ botScore += this.config.penalties.PENALTY_WEBVIEW;
169
+ return {
170
+ score: botScore,
171
+ scoreComponents: {
172
+ ...scoreComponents,
173
+ webView: this.config.penalties.PENALTY_WEBVIEW
174
+ }
175
+ };
108
176
  }
109
- async scoreIncreaseTimestamp(timestamp, baseBotScore, botScore, tokenId) {
177
+ scoreIncreaseTimestamp(timestamp, baseBotScore, botScore, scoreComponents) {
110
178
  this.logger.info(() => ({
111
179
  msg: "Timestamp is older than 10 minutes",
112
180
  data: { timestamp: new Date(timestamp) }
113
181
  }));
114
182
  botScore += this.config.penalties.PENALTY_OLD_TIMESTAMP;
115
- await this.db.updateFrictionlessTokenRecord(tokenId, {
183
+ return {
116
184
  score: botScore,
117
185
  scoreComponents: {
118
- baseScore: baseBotScore,
186
+ ...scoreComponents,
119
187
  timeout: this.config.penalties.PENALTY_OLD_TIMESTAMP
120
188
  }
121
- });
122
- return botScore;
189
+ };
123
190
  }
124
191
  static timestampTooOld(timestamp) {
125
192
  const now = Date.now();
@@ -141,7 +208,7 @@ class FrictionlessManager extends captchaManager.CaptchaManager {
141
208
  const end = key.slice(-5);
142
209
  return `${start}...${middle}...${end}`;
143
210
  }
144
- async decryptPayload(token) {
211
+ async decryptPayload(token, headHash) {
145
212
  const decryptKeys = [
146
213
  // Process DB keys first, then env var key last as env key will likely be invalid
147
214
  ...await this.getDetectorKeys(),
@@ -164,6 +231,9 @@ class FrictionlessManager extends captchaManager.CaptchaManager {
164
231
  let providerSelectEntropy;
165
232
  let userId;
166
233
  let userAgent;
234
+ let webView;
235
+ let iFrame;
236
+ let decryptedHeadHash = "";
167
237
  for (const [keyIndex, key] of decryptKeys.entries()) {
168
238
  try {
169
239
  this.logger.info(() => ({
@@ -172,12 +242,15 @@ class FrictionlessManager extends captchaManager.CaptchaManager {
172
242
  key: this.redactKeyForLogging(key)
173
243
  }
174
244
  }));
175
- const decrypted = await getBotScore.getBotScore(token, key);
245
+ const decrypted = await getBotScore.getBotScore(token, headHash, key);
246
+ decryptedHeadHash = decrypted.decryptedHeadHash || "";
176
247
  const s = decrypted.baseBotScore;
177
248
  const t = decrypted.timestamp;
178
249
  const p = decrypted.providerSelectEntropy;
179
250
  const a = decrypted.userId;
180
251
  const u = decrypted.userAgent;
252
+ const w = decrypted.isWebView;
253
+ const i = decrypted.isIframe;
181
254
  this.logger.debug(() => ({
182
255
  msg: "Successfully decrypted score",
183
256
  data: {
@@ -186,7 +259,9 @@ class FrictionlessManager extends captchaManager.CaptchaManager {
186
259
  timestamp: t,
187
260
  entropy: p,
188
261
  userId: a,
189
- userAgent: u
262
+ userAgent: u,
263
+ webView: w,
264
+ iFrame: i
190
265
  }
191
266
  }));
192
267
  baseBotScore = s;
@@ -194,6 +269,8 @@ class FrictionlessManager extends captchaManager.CaptchaManager {
194
269
  providerSelectEntropy = p;
195
270
  userId = a;
196
271
  userAgent = u;
272
+ webView = w;
273
+ iFrame = i;
197
274
  break;
198
275
  } catch (err) {
199
276
  if (keyIndex === decryptKeys.length - 1) {
@@ -203,6 +280,7 @@ class FrictionlessManager extends captchaManager.CaptchaManager {
203
280
  baseBotScore = 1;
204
281
  timestamp = 0;
205
282
  providerSelectEntropy = DEFAULT_ENTROPY + 1;
283
+ decryptedHeadHash = "";
206
284
  }
207
285
  }
208
286
  }
@@ -217,13 +295,19 @@ class FrictionlessManager extends captchaManager.CaptchaManager {
217
295
  baseBotScore = 1;
218
296
  timestamp = 0;
219
297
  providerSelectEntropy = DEFAULT_ENTROPY - undefinedCount;
298
+ decryptedHeadHash = "";
220
299
  }
221
300
  this.logger.info(() => ({
222
301
  msg: "decryptPayload result",
223
302
  data: {
224
303
  baseBotScore,
225
304
  timestamp,
226
- entropy: providerSelectEntropy
305
+ entropy: providerSelectEntropy,
306
+ userId,
307
+ userAgent,
308
+ webView,
309
+ iFrame,
310
+ decryptedHeadHash
227
311
  }
228
312
  }));
229
313
  return {
@@ -231,7 +315,10 @@ class FrictionlessManager extends captchaManager.CaptchaManager {
231
315
  timestamp: Number(timestamp),
232
316
  providerSelectEntropy: Number(providerSelectEntropy),
233
317
  userId,
234
- userAgent
318
+ userAgent,
319
+ webView,
320
+ iFrame,
321
+ decryptedHeadHash
235
322
  };
236
323
  }
237
324
  }
@@ -32,7 +32,7 @@ class ImgCaptchaManager extends captchaManager.CaptchaManager {
32
32
  }
33
33
  return captchaDocs;
34
34
  }
35
- async getRandomCaptchasAndRequestHash(datasetId, userAccount, ipAddress, captchaConfig, threshold, frictionlessTokenId) {
35
+ async getRandomCaptchasAndRequestHash(datasetId, userAccount, ipAddress, captchaConfig, threshold, sessionId) {
36
36
  const dataset = await this.db.getDatasetDetails(datasetId);
37
37
  if (!dataset) {
38
38
  throw new common.ProsopoEnvError("DATABASE.DATASET_GET_FAILED", {
@@ -82,7 +82,7 @@ class ImgCaptchaManager extends captchaManager.CaptchaManager {
82
82
  currentTime,
83
83
  compositeIpAddress.getCompositeIpAddress(ipAddress),
84
84
  threshold,
85
- frictionlessTokenId
85
+ sessionId
86
86
  );
87
87
  return {
88
88
  captchas,
@@ -174,10 +174,10 @@ class ImgCaptchaManager extends captchaManager.CaptchaManager {
174
174
  userSignature: userTimestampSignature,
175
175
  userSubmitted: true,
176
176
  serverChecked: false,
177
- requestedAtTimestamp: timestamp,
177
+ requestedAtTimestamp: new Date(timestamp),
178
178
  ipAddress: compositeIpAddress.getCompositeIpAddress(ipAddress),
179
179
  headers,
180
- frictionlessTokenId: pendingRecord.frictionlessTokenId,
180
+ sessionId: pendingRecord.sessionId,
181
181
  ja4
182
182
  };
183
183
  await this.db.storeUserImageCaptchaSolution(receivedCaptchas, commit);
@@ -334,7 +334,7 @@ class ImgCaptchaManager extends captchaManager.CaptchaManager {
334
334
  }
335
335
  return void 0;
336
336
  }
337
- async verifyImageCaptchaSolution(user, dapp, commitmentId, env, maxVerifiedTime, ip) {
337
+ async verifyImageCaptchaSolution(user, dapp, commitmentId, env, maxVerifiedTime, ip, disallowWebView) {
338
338
  const solution = await (commitmentId ? this.getDappUserCommitmentById(commitmentId) : this.getDappUserCommitmentByAccount(user, dapp));
339
339
  if (!solution) {
340
340
  this.logger.debug(() => ({
@@ -351,7 +351,7 @@ class ImgCaptchaManager extends captchaManager.CaptchaManager {
351
351
  }
352
352
  maxVerifiedTime = maxVerifiedTime || 60 * 1e3;
353
353
  const currentTime = Date.now();
354
- const timeSinceCompletion = currentTime - solution.requestedAtTimestamp;
354
+ const timeSinceCompletion = currentTime - solution.requestedAtTimestamp.getTime();
355
355
  if (timeSinceCompletion > maxVerifiedTime) {
356
356
  this.logger.debug(() => ({
357
357
  msg: "Not verified - timed out"
@@ -391,18 +391,24 @@ class ImgCaptchaManager extends captchaManager.CaptchaManager {
391
391
  }
392
392
  const isApproved = solution.result.status === types.CaptchaStatus.approved;
393
393
  let score;
394
- if (solution.frictionlessTokenId) {
395
- const tokenRecord = await this.db.getFrictionlessTokenRecordByTokenId(
396
- solution.frictionlessTokenId
394
+ if (solution.sessionId) {
395
+ const sessionRecord = await this.db.getSessionRecordBySessionId(
396
+ solution.sessionId
397
397
  );
398
- if (tokenRecord) {
399
- score = frictionlessTasksUtils.computeFrictionlessScore(tokenRecord?.scoreComponents);
398
+ if (sessionRecord) {
399
+ score = frictionlessTasksUtils.computeFrictionlessScore(sessionRecord?.scoreComponents);
400
400
  this.logger.info(() => ({
401
401
  data: {
402
- tscoreComponents: tokenRecord?.scoreComponents,
402
+ scoreComponents: sessionRecord?.scoreComponents,
403
403
  score
404
404
  }
405
405
  }));
406
+ if (disallowWebView === true && (sessionRecord.scoreComponents.webView || 0) > 0) {
407
+ this.logger.info(() => ({
408
+ msg: "Disallowing webview access - user not verified"
409
+ }));
410
+ return { status: "API.USER_NOT_VERIFIED", verified: false };
411
+ }
406
412
  }
407
413
  }
408
414
  return {
@@ -179,15 +179,15 @@ class PowCaptchaManager extends captchaManager.CaptchaManager {
179
179
  }
180
180
  }
181
181
  let score;
182
- if (challengeRecord.frictionlessTokenId) {
183
- const tokenRecord = await this.db.getFrictionlessTokenRecordByTokenId(
184
- challengeRecord.frictionlessTokenId
182
+ if (challengeRecord.sessionId) {
183
+ const sessionRecord = await this.db.getSessionRecordBySessionId(
184
+ challengeRecord.sessionId
185
185
  );
186
- if (tokenRecord) {
187
- score = frictionlessTasksUtils.computeFrictionlessScore(tokenRecord?.scoreComponents);
186
+ if (sessionRecord) {
187
+ score = frictionlessTasksUtils.computeFrictionlessScore(sessionRecord?.scoreComponents);
188
188
  this.logger.info(() => ({
189
189
  data: {
190
- tscoreComponents: { ...tokenRecord?.scoreComponents || {} },
190
+ scoreComponents: { ...sessionRecord?.scoreComponents || {} },
191
191
  score
192
192
  }
193
193
  }));
package/dist/cjs/util.cjs CHANGED
@@ -34,7 +34,7 @@ async function checkIfTaskIsRunning(taskName, db) {
34
34
  types.ScheduledTaskStatus.Running
35
35
  );
36
36
  const twoMinutesAgo = (/* @__PURE__ */ new Date()).getTime() - 1e3 * 60 * 2;
37
- if (runningTask && runningTask.datetime > twoMinutesAgo) {
37
+ if (runningTask && runningTask.datetime.getTime() > twoMinutesAgo) {
38
38
  const completedTask = await db.getScheduledTaskStatus(
39
39
  runningTask._id,
40
40
  types.ScheduledTaskStatus.Completed
@@ -231,6 +231,19 @@ const deepValidateIpAddress = async (ip, challengeIpAddress, logger, apiKey, api
231
231
  if (standardValidation.errorMessage?.includes("Invalid IP address")) {
232
232
  return standardValidation;
233
233
  }
234
+ if (ipValidationRules?.forceConsistentIp === true) {
235
+ logger.info(() => ({
236
+ msg: "IP validation failed - forceConsistentIp is true",
237
+ data: {
238
+ challengeIp: challengeIpAddress.address,
239
+ providedIp: ip
240
+ }
241
+ }));
242
+ return {
243
+ isValid: false,
244
+ errorMessage: standardValidation.errorMessage
245
+ };
246
+ }
234
247
  } else {
235
248
  return { isValid: true };
236
249
  }
@@ -0,0 +1,5 @@
1
+ import type { IPAddress } from "@prosopo/types";
2
+ import { type CompositeIpAddress } from "@prosopo/types-database";
3
+ export declare const getCompositeIpAddress: (ip: string | IPAddress) => CompositeIpAddress;
4
+ export declare const getIpAddressFromComposite: (compositeIpAddress: CompositeIpAddress) => IPAddress;
5
+ //# sourceMappingURL=compositeIpAddress.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"compositeIpAddress.d.ts","sourceRoot":"","sources":["../src/compositeIpAddress.ts"],"names":[],"mappings":"AAcA,OAAO,KAAK,EAAE,SAAS,EAAE,MAAM,gBAAgB,CAAC;AAChD,OAAO,EACN,KAAK,kBAAkB,EAEvB,MAAM,yBAAyB,CAAC;AAOjC,eAAO,MAAM,qBAAqB,OAC7B,MAAM,GAAG,SAAS,KACpB,kBAaF,CAAC;AAuBF,eAAO,MAAM,yBAAyB,uBACjB,kBAAkB,KACpC,SAaF,CAAC"}
@@ -0,0 +1 @@
1
+ {"version":3,"file":"compositeIpAddress.js","sourceRoot":"","sources":["../src/compositeIpAddress.ts"],"names":[],"mappings":"AAeA,OAAO,EAEN,aAAa,GACb,MAAM,yBAAyB,CAAC;AACjC,OAAO,EAAE,YAAY,EAAE,MAAM,eAAe,CAAC;AAC7C,OAAO,EAAE,QAAQ,EAAE,QAAQ,EAAE,MAAM,YAAY,CAAC;AAEhD,MAAM,QAAQ,GAAG,GAAG,CAAC;AACrB,MAAM,aAAa,GAAG,CAAC,EAAE,IAAI,QAAQ,CAAC,GAAG,EAAE,CAAC;AAE5C,MAAM,CAAC,MAAM,qBAAqB,GAAG,CACpC,EAAsB,EACD,EAAE;IACvB,IAAI,SAAoB,CAAC;IAEzB,IAAI,CAAC;QACJ,SAAS,GAAG,QAAQ,KAAK,OAAO,EAAE,CAAC,CAAC,CAAC,YAAY,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC,EAAE,CAAC;IAC5D,CAAC;IAAC,OAAO,CAAC,EAAE,CAAC;QACZ,OAAO;YACN,KAAK,EAAE,EAAE;YACT,IAAI,EAAE,aAAa,CAAC,EAAE;SACtB,CAAC;IACH,CAAC;IAED,OAAO,yBAAyB,CAAC,SAAS,CAAC,CAAC;AAC7C,CAAC,CAAC;AAEF,MAAM,yBAAyB,GAAG,CACjC,SAAoB,EACC,EAAE;IACvB,MAAM,SAAS,GAAG,SAAS,CAAC,MAAM,EAAE,CAAC;IAErC,IAAI,SAAS,YAAY,QAAQ,EAAE,CAAC;QACnC,OAAO;YACN,KAAK,EAAE,SAAS;YAChB,IAAI,EAAE,aAAa,CAAC,EAAE;SACtB,CAAC;IACH,CAAC;IAED,SAA4B,CAAC;IAE7B,OAAO;QACN,KAAK,EAAE,SAAS,GAAG,aAAa;QAChC,KAAK,EAAE,SAAS,IAAI,QAAQ;QAC5B,IAAI,EAAE,aAAa,CAAC,EAAE;KACtB,CAAC;AACH,CAAC,CAAC;AAEF,MAAM,CAAC,MAAM,yBAAyB,GAAG,CACxC,kBAAsC,EAC1B,EAAE;IACd,QAAQ,kBAAkB,CAAC,IAAI,EAAE,CAAC;QACjC,KAAK,aAAa,CAAC,EAAE;YACpB,OAAO,QAAQ,CAAC,UAAU,CAAC,SAAS,CAAC,kBAAkB,CAAC,KAAK,CAAC,CAAC,CAAC;QACjE,KAAK,aAAa,CAAC,EAAE;YACpB,OAAO,QAAQ,CAAC,UAAU,CACzB,CAAC,SAAS,CAAC,kBAAkB,CAAC,KAAK,CAAC,IAAI,QAAQ,CAAC;gBAChD,CAAC,SAAS,CAAC,kBAAkB,CAAC,KAAK,CAAC,GAAG,aAAa,CAAC,CACtD,CAAC;QACH;YACC,KAAK,EAAE,CAAC;YACR,OAAO,QAAQ,CAAC,UAAU,CAAC,EAAE,CAAC,CAAC;IACjC,CAAC;AACF,CAAC,CAAC;AAEF,MAAM,SAAS,GAAG,CAAC,MAAmC,EAAE,EAAE,CAAC,MAAM,CAAC,MAAM,IAAI,EAAE,CAAC,CAAC;AAEhF,MAAM,KAAK,GAAG,GAAU,EAAE;IACzB,MAAM,IAAI,KAAK,CAAC,gBAAgB,CAAC,CAAC;AACnC,CAAC,CAAC"}
@@ -0,0 +1,17 @@
1
+ export * from "./tasks/index.js";
2
+ export * from "./util.js";
3
+ export * from "./api/block.js";
4
+ export * from "./api/captcha.js";
5
+ export * from "./api/verify.js";
6
+ export * from "./api/ja4Middleware.js";
7
+ export * from "./api/public.js";
8
+ export * from "./api/domainMiddleware.js";
9
+ export * from "./schedulers/captchaScheduler.js";
10
+ export * from "./schedulers/getClientList.js";
11
+ export * from "./api/headerCheckMiddleware.js";
12
+ export * from "./api/admin/createApiAdminRoutesProvider.js";
13
+ export * from "./api/ignoreMiddleware.js";
14
+ export * from "./api/robotsMiddleware.js";
15
+ export * from "./compositeIpAddress.js";
16
+ export * from "./services/ipComparison.js";
17
+ //# sourceMappingURL=index.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../src/index.ts"],"names":[],"mappings":"AAcA,cAAc,kBAAkB,CAAC;AACjC,cAAc,WAAW,CAAC;AAC1B,cAAc,gBAAgB,CAAC;AAC/B,cAAc,kBAAkB,CAAC;AACjC,cAAc,iBAAiB,CAAC;AAChC,cAAc,wBAAwB,CAAC;AACvC,cAAc,iBAAiB,CAAC;AAChC,cAAc,2BAA2B,CAAC;AAC1C,cAAc,kCAAkC,CAAC;AACjD,cAAc,+BAA+B,CAAC;AAC9C,cAAc,gCAAgC,CAAC;AAC/C,cAAc,6CAA6C,CAAC;AAC5D,cAAc,2BAA2B,CAAC;AAC1C,cAAc,2BAA2B,CAAC;AAC1C,cAAc,yBAAyB,CAAC;AACxC,cAAc,4BAA4B,CAAC"}
@@ -0,0 +1 @@
1
+ {"version":3,"file":"index.js","sourceRoot":"","sources":["../src/index.ts"],"names":[],"mappings":"AAcA,cAAc,kBAAkB,CAAC;AACjC,cAAc,WAAW,CAAC;AAC1B,cAAc,gBAAgB,CAAC;AAC/B,cAAc,kBAAkB,CAAC;AACjC,cAAc,iBAAiB,CAAC;AAChC,cAAc,wBAAwB,CAAC;AACvC,cAAc,iBAAiB,CAAC;AAChC,cAAc,2BAA2B,CAAC;AAC1C,cAAc,kCAAkC,CAAC;AACjD,cAAc,+BAA+B,CAAC;AAC9C,cAAc,gCAAgC,CAAC;AAC/C,cAAc,6CAA6C,CAAC;AAC5D,cAAc,2BAA2B,CAAC;AAC1C,cAAc,2BAA2B,CAAC;AAC1C,cAAc,yBAAyB,CAAC;AACxC,cAAc,4BAA4B,CAAC"}
@@ -0,0 +1,3 @@
1
+ export declare const constructPairList: (list: number[]) => [number, number][];
2
+ export declare const containsIdenticalPairs: (pairsLists: [number, number][][]) => boolean;
3
+ //# sourceMappingURL=pairs.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"pairs.d.ts","sourceRoot":"","sources":["../src/pairs.ts"],"names":[],"mappings":"AAmBA,eAAO,MAAM,iBAAiB,SAAU,MAAM,EAAE,KAAG,CAAC,MAAM,EAAE,MAAM,CAAC,EAWlE,CAAC;AAMF,eAAO,MAAM,sBAAsB,eAAgB,CAAC,MAAM,EAAE,MAAM,CAAC,EAAE,EAAE,YActE,CAAC"}
@@ -0,0 +1 @@
1
+ {"version":3,"file":"pairs.js","sourceRoot":"","sources":["../src/pairs.ts"],"names":[],"mappings":"AAcA,OAAO,EAAE,EAAE,EAAE,MAAM,eAAe,CAAC;AAKnC,MAAM,CAAC,MAAM,iBAAiB,GAAG,CAAC,IAAc,EAAsB,EAAE;IAEvE,IAAI,IAAI,CAAC,MAAM,GAAG,CAAC,KAAK,CAAC,EAAE,CAAC;QAC3B,MAAM,IAAI,KAAK,CAAC,sBAAsB,CAAC,CAAC;IACzC,CAAC;IAED,MAAM,QAAQ,GAAuB,EAAE,CAAC;IACxC,KAAK,IAAI,CAAC,GAAG,CAAC,EAAE,CAAC,GAAG,IAAI,CAAC,MAAM,EAAE,CAAC,IAAI,CAAC,EAAE,CAAC;QACzC,QAAQ,CAAC,IAAI,CAAC,CAAC,EAAE,CAAC,IAAI,EAAE,CAAC,CAAC,EAAE,EAAE,CAAC,IAAI,EAAE,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC,CAAC;IAC/C,CAAC;IACD,OAAO,QAAQ,CAAC;AACjB,CAAC,CAAC;AAMF,MAAM,CAAC,MAAM,sBAAsB,GAAG,CAAC,UAAgC,EAAE,EAAE;IAC1E,MAAM,GAAG,GAAG,IAAI,GAAG,EAAU,CAAC;IAE9B,KAAK,MAAM,QAAQ,IAAI,UAAU,EAAE,CAAC;QACnC,KAAK,MAAM,IAAI,IAAI,QAAQ,EAAE,CAAC;YAC7B,MAAM,CAAC,GAAG,EAAE,CAAC,IAAI,EAAE,CAAC,CAAC,CAAC;YACtB,MAAM,CAAC,GAAG,EAAE,CAAC,IAAI,EAAE,CAAC,CAAC,CAAC;YACtB,MAAM,WAAW,GAAG,GAAG,CAAC,IAAI,CAAC,EAAE,CAAC;YAChC,GAAG,CAAC,GAAG,CAAC,WAAW,CAAC,CAAC;QACtB,CAAC;IACF,CAAC;IAGD,OAAO,GAAG,CAAC,IAAI,KAAK,UAAU,CAAC,IAAI,EAAE,CAAC,IAAI,EAAE,CAAC,MAAM,GAAG,CAAC,CAAC;AACzD,CAAC,CAAC"}
@@ -0,0 +1,3 @@
1
+ import type { ProsopoConfigOutput } from "@prosopo/types";
2
+ export declare const checkLangRules: (config: ProsopoConfigOutput, acceptLanguage: string) => number;
3
+ //# sourceMappingURL=lang.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"lang.d.ts","sourceRoot":"","sources":["../../src/rules/lang.ts"],"names":[],"mappings":"AAaA,OAAO,KAAK,EAAE,mBAAmB,EAAE,MAAM,gBAAgB,CAAC;AAE1D,eAAO,MAAM,cAAc,WAClB,mBAAmB,kBACX,MAAM,KACpB,MAeF,CAAC"}
@@ -0,0 +1 @@
1
+ {"version":3,"file":"lang.js","sourceRoot":"","sources":["../../src/rules/lang.ts"],"names":[],"mappings":"AAeA,MAAM,CAAC,MAAM,cAAc,GAAG,CAC7B,MAA2B,EAC3B,cAAsB,EACb,EAAE;IACX,MAAM,OAAO,GAAG,MAAM,CAAC,MAAM,CAAC;IAC9B,IAAI,MAAM,GAAG,CAAC,CAAC;IACf,IAAI,OAAO,EAAE,CAAC;QACb,MAAM,SAAS,GAAG,cAAc;aAC9B,KAAK,CAAC,GAAG,CAAC;aACV,GAAG,CAAC,CAAC,IAAI,EAAE,EAAE,CAAC,IAAI,CAAC,IAAI,EAAE,CAAC,KAAK,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC;QAE3C,KAAK,MAAM,IAAI,IAAI,SAAS,EAAE,CAAC;YAC9B,IAAI,IAAI,IAAI,OAAO,CAAC,IAAI,CAAC,EAAE,CAAC;gBAC3B,MAAM,IAAI,OAAO,CAAC,IAAI,CAAC,CAAC;YACzB,CAAC;QACF,CAAC;IACF,CAAC;IACD,OAAO,MAAM,CAAC;AACf,CAAC,CAAC"}
@@ -0,0 +1,4 @@
1
+ import type { KeyringPair } from "@prosopo/types";
2
+ import { type ProsopoConfigOutput } from "@prosopo/types";
3
+ export declare function storeCaptchasExternally(pair: KeyringPair, cronSchedule: string, config: ProsopoConfigOutput): Promise<void>;
4
+ //# sourceMappingURL=captchaScheduler.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"captchaScheduler.d.ts","sourceRoot":"","sources":["../../src/schedulers/captchaScheduler.ts"],"names":[],"mappings":"AAeA,OAAO,KAAK,EAAE,WAAW,EAAE,MAAM,gBAAgB,CAAC;AAClD,OAAO,EAAE,KAAK,mBAAmB,EAAsB,MAAM,gBAAgB,CAAC;AAK9E,wBAAsB,uBAAuB,CAC5C,IAAI,EAAE,WAAW,EACjB,YAAY,EAAE,MAAM,EACpB,MAAM,EAAE,mBAAmB,iBA8B3B"}
@@ -0,0 +1 @@
1
+ {"version":3,"file":"captchaScheduler.js","sourceRoot":"","sources":["../../src/schedulers/captchaScheduler.ts"],"names":[],"mappings":"AAcA,OAAO,EAAE,mBAAmB,EAAE,MAAM,cAAc,CAAC;AAEnD,OAAO,EAA4B,kBAAkB,EAAE,MAAM,gBAAgB,CAAC;AAC9E,OAAO,EAAE,OAAO,EAAE,MAAM,MAAM,CAAC;AAC/B,OAAO,EAAE,KAAK,EAAE,MAAM,mBAAmB,CAAC;AAC1C,OAAO,EAAE,oBAAoB,EAAE,MAAM,YAAY,CAAC;AAElD,MAAM,CAAC,KAAK,UAAU,uBAAuB,CAC5C,IAAiB,EACjB,YAAoB,EACpB,MAA2B;IAE3B,MAAM,GAAG,GAAG,IAAI,mBAAmB,CAAC,MAAM,EAAE,IAAI,CAAC,CAAC;IAClD,MAAM,GAAG,CAAC,OAAO,EAAE,CAAC;IAEpB,MAAM,KAAK,GAAG,IAAI,KAAK,CAAC,GAAG,CAAC,CAAC;IAE7B,MAAM,GAAG,GAAG,IAAI,OAAO,CAAC,YAAY,EAAE,KAAK,IAAI,EAAE;QAChD,MAAM,WAAW,GAAG,MAAM,oBAAoB,CAC7C,kBAAkB,CAAC,wBAAwB,EAC3C,GAAG,CAAC,KAAK,EAAE,CACX,CAAC;QACF,GAAG,CAAC,MAAM,CAAC,IAAI,CAAC,GAAG,EAAE,CAAC,CAAC;YACtB,IAAI,EAAE,EAAE,WAAW,EAAE;YACrB,GAAG,EAAE,GAAG,kBAAkB,CAAC,wBAAwB,kBAAkB,WAAW,EAAE;SAClF,CAAC,CAAC,CAAC;QACJ,IAAI,CAAC,WAAW,EAAE,CAAC;YAClB,GAAG,CAAC,MAAM,CAAC,IAAI,CAAC,GAAG,EAAE,CAAC,CAAC;gBACtB,GAAG,EAAE,GAAG,kBAAkB,CAAC,wBAAwB,WAAW;aAC9D,CAAC,CAAC,CAAC;YACJ,MAAM,KAAK,CAAC,iBAAiB,CAAC,wBAAwB,EAAE,CAAC,KAAK,CAAC,CAAC,GAAG,EAAE,EAAE;gBACtE,GAAG,CAAC,MAAM,CAAC,KAAK,CAAC,GAAG,EAAE,CAAC,CAAC;oBACvB,GAAG;oBACH,GAAG,EAAE,sCAAsC;iBAC3C,CAAC,CAAC,CAAC;YACL,CAAC,CAAC,CAAC;QACJ,CAAC;IACF,CAAC,CAAC,CAAC;IAEH,GAAG,CAAC,KAAK,EAAE,CAAC;AACb,CAAC"}
@@ -0,0 +1,4 @@
1
+ import type { KeyringPair } from "@prosopo/types";
2
+ import { type ProsopoConfigOutput } from "@prosopo/types";
3
+ export declare function getClientList(pair: KeyringPair, cronSchedule: string, config: ProsopoConfigOutput): Promise<void>;
4
+ //# sourceMappingURL=getClientList.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"getClientList.d.ts","sourceRoot":"","sources":["../../src/schedulers/getClientList.ts"],"names":[],"mappings":"AAeA,OAAO,KAAK,EAAE,WAAW,EAAE,MAAM,gBAAgB,CAAC;AAClD,OAAO,EAAE,KAAK,mBAAmB,EAAsB,MAAM,gBAAgB,CAAC;AAW9E,wBAAsB,aAAa,CAClC,IAAI,EAAE,WAAW,EACjB,YAAY,EAAE,MAAM,EACpB,MAAM,EAAE,mBAAmB,iBA+B3B"}
@@ -0,0 +1 @@
1
+ {"version":3,"file":"getClientList.js","sourceRoot":"","sources":["../../src/schedulers/getClientList.ts"],"names":[],"mappings":"AAcA,OAAO,EAAE,mBAAmB,EAAE,MAAM,cAAc,CAAC;AAEnD,OAAO,EAA4B,kBAAkB,EAAE,MAAM,gBAAgB,CAAC;AAC9E,OAAO,EAAE,OAAO,EAAE,MAAM,MAAM,CAAC;AAC/B,OAAO,EAAE,KAAK,EAAE,MAAM,mBAAmB,CAAC;AAC1C,OAAO,EAAE,oBAAoB,EAAE,MAAM,YAAY,CAAC;AAQlD,MAAM,CAAC,KAAK,UAAU,aAAa,CAClC,IAAiB,EACjB,YAAoB,EACpB,MAA2B;IAE3B,MAAM,GAAG,GAAG,IAAI,mBAAmB,CAAC,MAAM,EAAE,IAAI,CAAC,CAAC;IAClD,MAAM,GAAG,CAAC,OAAO,EAAE,CAAC;IAEpB,MAAM,KAAK,GAAG,IAAI,KAAK,CAAC,GAAG,CAAC,CAAC;IAE7B,MAAM,GAAG,GAAG,IAAI,OAAO,CAAC,YAAY,EAAE,KAAK,IAAI,EAAE;QAChD,MAAM,WAAW,GAAG,MAAM,oBAAoB,CAC7C,kBAAkB,CAAC,aAAa,EAChC,GAAG,CAAC,KAAK,EAAE,CACX,CAAC;QACF,GAAG,CAAC,MAAM,CAAC,IAAI,CAAC,GAAG,EAAE,CAAC,CAAC;YACtB,GAAG,EAAE,GAAG,kBAAkB,CAAC,aAAa,kBAAkB,WAAW,EAAE;YACvE,IAAI,EAAE,EAAE,WAAW,EAAE;SACrB,CAAC,CAAC,CAAC;QACJ,IAAI,CAAC,WAAW,EAAE,CAAC;YAClB,GAAG,CAAC,MAAM,CAAC,IAAI,CAAC,GAAG,EAAE,CAAC,CAAC;gBACtB,GAAG,EAAE,GAAG,kBAAkB,CAAC,aAAa,WAAW;gBACnD,IAAI,EAAE,EAAE;aACR,CAAC,CAAC,CAAC;YACJ,MAAM,KAAK,CAAC,iBAAiB,CAAC,aAAa,EAAE,CAAC,KAAK,CAAC,CAAC,GAAG,EAAE,EAAE;gBAC3D,GAAG,CAAC,MAAM,CAAC,KAAK,CAAC,GAAG,EAAE,CAAC,CAAC;oBACvB,GAAG;oBACH,GAAG,EAAE,2BAA2B;iBAChC,CAAC,CAAC,CAAC;YACL,CAAC,CAAC,CAAC;QACJ,CAAC;IACF,CAAC,CAAC,CAAC;IAEH,GAAG,CAAC,KAAK,EAAE,CAAC;AACb,CAAC"}
@@ -0,0 +1,4 @@
1
+ import type { KeyringPair } from "@prosopo/types";
2
+ import { type ProsopoConfigOutput } from "@prosopo/types";
3
+ export declare function setClientEntropy(pair: KeyringPair, cronSchedule: string, config: ProsopoConfigOutput): Promise<void>;
4
+ //# sourceMappingURL=setClientEntropy.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"setClientEntropy.d.ts","sourceRoot":"","sources":["../../src/schedulers/setClientEntropy.ts"],"names":[],"mappings":"AAeA,OAAO,KAAK,EAAE,WAAW,EAAE,MAAM,gBAAgB,CAAC;AAClD,OAAO,EAAE,KAAK,mBAAmB,EAAsB,MAAM,gBAAgB,CAAC;AAW9E,wBAAsB,gBAAgB,CACrC,IAAI,EAAE,WAAW,EACjB,YAAY,EAAE,MAAM,EACpB,MAAM,EAAE,mBAAmB,iBA+B3B"}
@@ -0,0 +1,31 @@
1
+ import { ProviderEnvironment } from "@prosopo/env";
2
+ import { ScheduledTaskNames } from "@prosopo/types";
3
+ import { CronJob } from "cron";
4
+ import { Tasks } from "../tasks/tasks.js";
5
+ import { checkIfTaskIsRunning } from "../util.js";
6
+ export async function setClientEntropy(pair, cronSchedule, config) {
7
+ const env = new ProviderEnvironment(config, pair);
8
+ await env.isReady();
9
+ const tasks = new Tasks(env);
10
+ const job = new CronJob(cronSchedule, async () => {
11
+ const taskRunning = await checkIfTaskIsRunning(ScheduledTaskNames.SetClientEntropy, env.getDb());
12
+ env.logger.info(() => ({
13
+ msg: `${ScheduledTaskNames.SetClientEntropy} task running: ${taskRunning}`,
14
+ data: { taskRunning },
15
+ }));
16
+ if (!taskRunning) {
17
+ env.logger.info(() => ({
18
+ msg: `${ScheduledTaskNames.SetClientEntropy} task....`,
19
+ data: {},
20
+ }));
21
+ await tasks.clientTaskManager.calculateClientEntropy().catch((err) => {
22
+ env.logger.error(() => ({
23
+ err,
24
+ msg: "Error setting client entropy",
25
+ }));
26
+ });
27
+ }
28
+ });
29
+ job.start();
30
+ }
31
+ //# sourceMappingURL=setClientEntropy.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"setClientEntropy.js","sourceRoot":"","sources":["../../src/schedulers/setClientEntropy.ts"],"names":[],"mappings":"AAcA,OAAO,EAAE,mBAAmB,EAAE,MAAM,cAAc,CAAC;AAEnD,OAAO,EAA4B,kBAAkB,EAAE,MAAM,gBAAgB,CAAC;AAC9E,OAAO,EAAE,OAAO,EAAE,MAAM,MAAM,CAAC;AAC/B,OAAO,EAAE,KAAK,EAAE,MAAM,mBAAmB,CAAC;AAC1C,OAAO,EAAE,oBAAoB,EAAE,MAAM,YAAY,CAAC;AAQlD,MAAM,CAAC,KAAK,UAAU,gBAAgB,CACrC,IAAiB,EACjB,YAAoB,EACpB,MAA2B;IAE3B,MAAM,GAAG,GAAG,IAAI,mBAAmB,CAAC,MAAM,EAAE,IAAI,CAAC,CAAC;IAClD,MAAM,GAAG,CAAC,OAAO,EAAE,CAAC;IAEpB,MAAM,KAAK,GAAG,IAAI,KAAK,CAAC,GAAG,CAAC,CAAC;IAE7B,MAAM,GAAG,GAAG,IAAI,OAAO,CAAC,YAAY,EAAE,KAAK,IAAI,EAAE;QAChD,MAAM,WAAW,GAAG,MAAM,oBAAoB,CAC7C,kBAAkB,CAAC,gBAAgB,EACnC,GAAG,CAAC,KAAK,EAAE,CACX,CAAC;QACF,GAAG,CAAC,MAAM,CAAC,IAAI,CAAC,GAAG,EAAE,CAAC,CAAC;YACtB,GAAG,EAAE,GAAG,kBAAkB,CAAC,gBAAgB,kBAAkB,WAAW,EAAE;YAC1E,IAAI,EAAE,EAAE,WAAW,EAAE;SACrB,CAAC,CAAC,CAAC;QACJ,IAAI,CAAC,WAAW,EAAE,CAAC;YAClB,GAAG,CAAC,MAAM,CAAC,IAAI,CAAC,GAAG,EAAE,CAAC,CAAC;gBACtB,GAAG,EAAE,GAAG,kBAAkB,CAAC,gBAAgB,WAAW;gBACtD,IAAI,EAAE,EAAE;aACR,CAAC,CAAC,CAAC;YACJ,MAAM,KAAK,CAAC,iBAAiB,CAAC,sBAAsB,EAAE,CAAC,KAAK,CAAC,CAAC,GAAG,EAAE,EAAE;gBACpE,GAAG,CAAC,MAAM,CAAC,KAAK,CAAC,GAAG,EAAE,CAAC,CAAC;oBACvB,GAAG;oBACH,GAAG,EAAE,8BAA8B;iBACnC,CAAC,CAAC,CAAC;YACL,CAAC,CAAC,CAAC;QACJ,CAAC;IACF,CAAC,CAAC,CAAC;IAEH,GAAG,CAAC,KAAK,EAAE,CAAC;AACb,CAAC"}
@@ -0,0 +1,3 @@
1
+ import type { IPComparisonResponse } from "@prosopo/types";
2
+ export declare function compareIPs(ip1: string, ip2: string, apiKey: string, apiUrl: string): Promise<IPComparisonResponse>;
3
+ //# sourceMappingURL=ipComparison.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"ipComparison.d.ts","sourceRoot":"","sources":["../../src/services/ipComparison.ts"],"names":[],"mappings":"AAcA,OAAO,KAAK,EACX,oBAAoB,EAGpB,MAAM,gBAAgB,CAAC;AAkBxB,wBAAsB,UAAU,CAC/B,GAAG,EAAE,MAAM,EACX,GAAG,EAAE,MAAM,EACX,MAAM,EAAE,MAAM,EACd,MAAM,EAAE,MAAM,GACZ,OAAO,CAAC,oBAAoB,CAAC,CA6J/B"}
@@ -0,0 +1 @@
1
+ {"version":3,"file":"ipComparison.js","sourceRoot":"","sources":["../../src/services/ipComparison.ts"],"names":[],"mappings":"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"}
@@ -0,0 +1,3 @@
1
+ import type { IPInfoResponse } from "@prosopo/types";
2
+ export declare function getIPInfo(ip: string, apiUrl: string, apiKey?: string, includeRawResponse?: boolean): Promise<IPInfoResponse>;
3
+ //# sourceMappingURL=ipInfo.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"ipInfo.d.ts","sourceRoot":"","sources":["../../src/services/ipInfo.ts"],"names":[],"mappings":"AAcA,OAAO,KAAK,EAEX,cAAc,EAEd,MAAM,gBAAgB,CAAC;AAYxB,wBAAsB,SAAS,CAC9B,EAAE,EAAE,MAAM,EACV,MAAM,EAAE,MAAM,EACd,MAAM,CAAC,EAAE,MAAM,EACf,kBAAkB,UAAQ,GACxB,OAAO,CAAC,cAAc,CAAC,CAmGzB"}
@@ -0,0 +1 @@
1
+ {"version":3,"file":"ipInfo.js","sourceRoot":"","sources":["../../src/services/ipInfo.ts"],"names":[],"mappings":"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"}