@prosopo/user-access-policy 2.3.2

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 (263) hide show
  1. package/dist/blacklistInspector.d.ts +6 -0
  2. package/dist/blacklistInspector.d.ts.map +1 -0
  3. package/dist/blacklistInspector.js +2 -0
  4. package/dist/blacklistInspector.js.map +1 -0
  5. package/dist/imageCaptchaConfigResolver.d.ts +7 -0
  6. package/dist/imageCaptchaConfigResolver.d.ts.map +1 -0
  7. package/dist/imageCaptchaConfigResolver.js +2 -0
  8. package/dist/imageCaptchaConfigResolver.js.map +1 -0
  9. package/dist/index.d.ts +15 -0
  10. package/dist/index.d.ts.map +1 -0
  11. package/dist/index.js +20 -0
  12. package/dist/index.js.map +1 -0
  13. package/dist/rules/api/apiRulePaths.d.ts +6 -0
  14. package/dist/rules/api/apiRulePaths.d.ts.map +1 -0
  15. package/dist/rules/api/apiRulePaths.js +6 -0
  16. package/dist/rules/api/apiRulePaths.js.map +1 -0
  17. package/dist/rules/api/apiRuleRoutesProvider.d.ts +9 -0
  18. package/dist/rules/api/apiRuleRoutesProvider.d.ts.map +1 -0
  19. package/dist/rules/api/apiRuleRoutesProvider.js +22 -0
  20. package/dist/rules/api/apiRuleRoutesProvider.js.map +1 -0
  21. package/dist/rules/api/deleteMany/apiDeleteManyRulesArgsSchema.d.ts +159 -0
  22. package/dist/rules/api/deleteMany/apiDeleteManyRulesArgsSchema.d.ts.map +1 -0
  23. package/dist/rules/api/deleteMany/apiDeleteManyRulesArgsSchema.js +9 -0
  24. package/dist/rules/api/deleteMany/apiDeleteManyRulesArgsSchema.js.map +1 -0
  25. package/dist/rules/api/deleteMany/apiDeleteManyRulesEndpoint.d.ts +12 -0
  26. package/dist/rules/api/deleteMany/apiDeleteManyRulesEndpoint.d.ts.map +1 -0
  27. package/dist/rules/api/deleteMany/apiDeleteManyRulesEndpoint.js +18 -0
  28. package/dist/rules/api/deleteMany/apiDeleteManyRulesEndpoint.js.map +1 -0
  29. package/dist/rules/api/getExpressApiRuleRateLimits.d.ts +8 -0
  30. package/dist/rules/api/getExpressApiRuleRateLimits.d.ts.map +1 -0
  31. package/dist/rules/api/getExpressApiRuleRateLimits.js +21 -0
  32. package/dist/rules/api/getExpressApiRuleRateLimits.js.map +1 -0
  33. package/dist/rules/api/insertMany/apiInsertManyRulesArgsSchema.d.ts +199 -0
  34. package/dist/rules/api/insertMany/apiInsertManyRulesArgsSchema.d.ts.map +1 -0
  35. package/dist/rules/api/insertMany/apiInsertManyRulesArgsSchema.js +13 -0
  36. package/dist/rules/api/insertMany/apiInsertManyRulesArgsSchema.js.map +1 -0
  37. package/dist/rules/api/insertMany/apiInsertManyRulesEndpoint.d.ts +15 -0
  38. package/dist/rules/api/insertMany/apiInsertManyRulesEndpoint.d.ts.map +1 -0
  39. package/dist/rules/api/insertMany/apiInsertManyRulesEndpoint.js +50 -0
  40. package/dist/rules/api/insertMany/apiInsertManyRulesEndpoint.js.map +1 -0
  41. package/dist/rules/blacklistRulesInspector.d.ts +12 -0
  42. package/dist/rules/blacklistRulesInspector.d.ts.map +1 -0
  43. package/dist/rules/blacklistRulesInspector.js +29 -0
  44. package/dist/rules/blacklistRulesInspector.js.map +1 -0
  45. package/dist/rules/imageCaptchaConfigRulesResolver.d.ts +19 -0
  46. package/dist/rules/imageCaptchaConfigRulesResolver.d.ts.map +1 -0
  47. package/dist/rules/imageCaptchaConfigRulesResolver.js +82 -0
  48. package/dist/rules/imageCaptchaConfigRulesResolver.js.map +1 -0
  49. package/dist/rules/mongoose/indexes/mongooseIndex.d.ts +7 -0
  50. package/dist/rules/mongoose/indexes/mongooseIndex.d.ts.map +1 -0
  51. package/dist/rules/mongoose/indexes/mongooseIndex.js +2 -0
  52. package/dist/rules/mongoose/indexes/mongooseIndex.js.map +1 -0
  53. package/dist/rules/mongoose/indexes/rulePerformanceMongooseIndexes.d.ts +4 -0
  54. package/dist/rules/mongoose/indexes/rulePerformanceMongooseIndexes.d.ts.map +1 -0
  55. package/dist/rules/mongoose/indexes/rulePerformanceMongooseIndexes.js +49 -0
  56. package/dist/rules/mongoose/indexes/rulePerformanceMongooseIndexes.js.map +1 -0
  57. package/dist/rules/mongoose/indexes/ruleUniqueMongooseIndexes.d.ts +4 -0
  58. package/dist/rules/mongoose/indexes/ruleUniqueMongooseIndexes.d.ts.map +1 -0
  59. package/dist/rules/mongoose/indexes/ruleUniqueMongooseIndexes.js +136 -0
  60. package/dist/rules/mongoose/indexes/ruleUniqueMongooseIndexes.js.map +1 -0
  61. package/dist/rules/mongoose/ruleMongooseRecord.d.ts +7 -0
  62. package/dist/rules/mongoose/ruleMongooseRecord.d.ts.map +1 -0
  63. package/dist/rules/mongoose/ruleMongooseRecord.js +2 -0
  64. package/dist/rules/mongoose/ruleMongooseRecord.js.map +1 -0
  65. package/dist/rules/mongoose/rulesMongooseStorage.d.ts +30 -0
  66. package/dist/rules/mongoose/rulesMongooseStorage.d.ts.map +1 -0
  67. package/dist/rules/mongoose/rulesMongooseStorage.js +143 -0
  68. package/dist/rules/mongoose/rulesMongooseStorage.js.map +1 -0
  69. package/dist/rules/mongoose/schemas/config/configMongooseSchema.d.ts +43 -0
  70. package/dist/rules/mongoose/schemas/config/configMongooseSchema.d.ts.map +1 -0
  71. package/dist/rules/mongoose/schemas/config/configMongooseSchema.js +10 -0
  72. package/dist/rules/mongoose/schemas/config/configMongooseSchema.js.map +1 -0
  73. package/dist/rules/mongoose/schemas/config/imageCaptchaConfigMongooseSchema.d.ts +29 -0
  74. package/dist/rules/mongoose/schemas/config/imageCaptchaConfigMongooseSchema.d.ts.map +1 -0
  75. package/dist/rules/mongoose/schemas/config/imageCaptchaConfigMongooseSchema.js +13 -0
  76. package/dist/rules/mongoose/schemas/config/imageCaptchaConfigMongooseSchema.js.map +1 -0
  77. package/dist/rules/mongoose/schemas/getRuleMongooseSchema.d.ts +5 -0
  78. package/dist/rules/mongoose/schemas/getRuleMongooseSchema.d.ts.map +1 -0
  79. package/dist/rules/mongoose/schemas/getRuleMongooseSchema.js +15 -0
  80. package/dist/rules/mongoose/schemas/getRuleMongooseSchema.js.map +1 -0
  81. package/dist/rules/mongoose/schemas/ip/ipMongooseSchema.d.ts +141 -0
  82. package/dist/rules/mongoose/schemas/ip/ipMongooseSchema.d.ts.map +1 -0
  83. package/dist/rules/mongoose/schemas/ip/ipMongooseSchema.js +25 -0
  84. package/dist/rules/mongoose/schemas/ip/ipMongooseSchema.js.map +1 -0
  85. package/dist/rules/mongoose/schemas/ip/v4/ipV4MaskMongooseSchema.d.ts +36 -0
  86. package/dist/rules/mongoose/schemas/ip/v4/ipV4MaskMongooseSchema.d.ts.map +1 -0
  87. package/dist/rules/mongoose/schemas/ip/v4/ipV4MaskMongooseSchema.js +8 -0
  88. package/dist/rules/mongoose/schemas/ip/v4/ipV4MaskMongooseSchema.js.map +1 -0
  89. package/dist/rules/mongoose/schemas/ip/v4/ipV4MongooseSchema.d.ts +64 -0
  90. package/dist/rules/mongoose/schemas/ip/v4/ipV4MongooseSchema.d.ts.map +1 -0
  91. package/dist/rules/mongoose/schemas/ip/v4/ipV4MongooseSchema.js +12 -0
  92. package/dist/rules/mongoose/schemas/ip/v4/ipV4MongooseSchema.js.map +1 -0
  93. package/dist/rules/mongoose/schemas/ip/v6/ipV6MaskMongooseSchema.d.ts +36 -0
  94. package/dist/rules/mongoose/schemas/ip/v6/ipV6MaskMongooseSchema.d.ts.map +1 -0
  95. package/dist/rules/mongoose/schemas/ip/v6/ipV6MaskMongooseSchema.js +17 -0
  96. package/dist/rules/mongoose/schemas/ip/v6/ipV6MaskMongooseSchema.js.map +1 -0
  97. package/dist/rules/mongoose/schemas/ip/v6/ipV6MongooseSchema.d.ts +64 -0
  98. package/dist/rules/mongoose/schemas/ip/v6/ipV6MongooseSchema.d.ts.map +1 -0
  99. package/dist/rules/mongoose/schemas/ip/v6/ipV6MongooseSchema.js +17 -0
  100. package/dist/rules/mongoose/schemas/ip/v6/ipV6MongooseSchema.js.map +1 -0
  101. package/dist/rules/mongoose/schemas/ruleMongooseSchema.d.ts +9 -0
  102. package/dist/rules/mongoose/schemas/ruleMongooseSchema.d.ts.map +1 -0
  103. package/dist/rules/mongoose/schemas/ruleMongooseSchema.js +32 -0
  104. package/dist/rules/mongoose/schemas/ruleMongooseSchema.js.map +1 -0
  105. package/dist/rules/rule/config/imageCaptcha/imageCaptchaConfig.d.ts +5 -0
  106. package/dist/rules/rule/config/imageCaptcha/imageCaptchaConfig.d.ts.map +1 -0
  107. package/dist/rules/rule/config/imageCaptcha/imageCaptchaConfig.js +2 -0
  108. package/dist/rules/rule/config/imageCaptcha/imageCaptchaConfig.js.map +1 -0
  109. package/dist/rules/rule/config/imageCaptcha/imageCaptchaConfigSchema.d.ts +12 -0
  110. package/dist/rules/rule/config/imageCaptcha/imageCaptchaConfigSchema.d.ts.map +1 -0
  111. package/dist/rules/rule/config/imageCaptcha/imageCaptchaConfigSchema.js +7 -0
  112. package/dist/rules/rule/config/imageCaptcha/imageCaptchaConfigSchema.js.map +1 -0
  113. package/dist/rules/rule/config/ruleConfig.d.ts +5 -0
  114. package/dist/rules/rule/config/ruleConfig.d.ts.map +1 -0
  115. package/dist/rules/rule/config/ruleConfig.js +2 -0
  116. package/dist/rules/rule/config/ruleConfig.js.map +1 -0
  117. package/dist/rules/rule/config/ruleConfigSchema.d.ts +24 -0
  118. package/dist/rules/rule/config/ruleConfigSchema.d.ts.map +1 -0
  119. package/dist/rules/rule/config/ruleConfigSchema.js +7 -0
  120. package/dist/rules/rule/config/ruleConfigSchema.js.map +1 -0
  121. package/dist/rules/rule/ip/ruleIp.d.ts +5 -0
  122. package/dist/rules/rule/ip/ruleIp.d.ts.map +1 -0
  123. package/dist/rules/rule/ip/ruleIp.js +2 -0
  124. package/dist/rules/rule/ip/ruleIp.js.map +1 -0
  125. package/dist/rules/rule/ip/ruleIpSchema.d.ts +108 -0
  126. package/dist/rules/rule/ip/ruleIpSchema.d.ts.map +1 -0
  127. package/dist/rules/rule/ip/ruleIpSchema.js +9 -0
  128. package/dist/rules/rule/ip/ruleIpSchema.js.map +1 -0
  129. package/dist/rules/rule/ip/ruleIpVersion.d.ts +6 -0
  130. package/dist/rules/rule/ip/ruleIpVersion.d.ts.map +1 -0
  131. package/dist/rules/rule/ip/ruleIpVersion.js +7 -0
  132. package/dist/rules/rule/ip/ruleIpVersion.js.map +1 -0
  133. package/dist/rules/rule/ip/v4/mask/ruleIpV4Mask.d.ts +5 -0
  134. package/dist/rules/rule/ip/v4/mask/ruleIpV4Mask.d.ts.map +1 -0
  135. package/dist/rules/rule/ip/v4/mask/ruleIpV4Mask.js +2 -0
  136. package/dist/rules/rule/ip/v4/mask/ruleIpV4Mask.js.map +1 -0
  137. package/dist/rules/rule/ip/v4/mask/ruleIpV4MaskSchema.d.ts +15 -0
  138. package/dist/rules/rule/ip/v4/mask/ruleIpV4MaskSchema.d.ts.map +1 -0
  139. package/dist/rules/rule/ip/v4/mask/ruleIpV4MaskSchema.js +8 -0
  140. package/dist/rules/rule/ip/v4/mask/ruleIpV4MaskSchema.js.map +1 -0
  141. package/dist/rules/rule/ip/v4/ruleIpV4.d.ts +5 -0
  142. package/dist/rules/rule/ip/v4/ruleIpV4.d.ts.map +1 -0
  143. package/dist/rules/rule/ip/v4/ruleIpV4.js +2 -0
  144. package/dist/rules/rule/ip/v4/ruleIpV4.js.map +1 -0
  145. package/dist/rules/rule/ip/v4/ruleIpV4Schema.d.ts +35 -0
  146. package/dist/rules/rule/ip/v4/ruleIpV4Schema.d.ts.map +1 -0
  147. package/dist/rules/rule/ip/v4/ruleIpV4Schema.js +9 -0
  148. package/dist/rules/rule/ip/v4/ruleIpV4Schema.js.map +1 -0
  149. package/dist/rules/rule/ip/v6/mask/ruleIpV6Mask.d.ts +5 -0
  150. package/dist/rules/rule/ip/v6/mask/ruleIpV6Mask.d.ts.map +1 -0
  151. package/dist/rules/rule/ip/v6/mask/ruleIpV6Mask.js +2 -0
  152. package/dist/rules/rule/ip/v6/mask/ruleIpV6Mask.js.map +1 -0
  153. package/dist/rules/rule/ip/v6/mask/ruleIpV6MaskSchema.d.ts +15 -0
  154. package/dist/rules/rule/ip/v6/mask/ruleIpV6MaskSchema.d.ts.map +1 -0
  155. package/dist/rules/rule/ip/v6/mask/ruleIpV6MaskSchema.js +8 -0
  156. package/dist/rules/rule/ip/v6/mask/ruleIpV6MaskSchema.js.map +1 -0
  157. package/dist/rules/rule/ip/v6/ruleIpV6.d.ts +5 -0
  158. package/dist/rules/rule/ip/v6/ruleIpV6.d.ts.map +1 -0
  159. package/dist/rules/rule/ip/v6/ruleIpV6.js +2 -0
  160. package/dist/rules/rule/ip/v6/ruleIpV6.js.map +1 -0
  161. package/dist/rules/rule/ip/v6/ruleIpV6NumericMaxLength.d.ts +3 -0
  162. package/dist/rules/rule/ip/v6/ruleIpV6NumericMaxLength.d.ts.map +1 -0
  163. package/dist/rules/rule/ip/v6/ruleIpV6NumericMaxLength.js +3 -0
  164. package/dist/rules/rule/ip/v6/ruleIpV6NumericMaxLength.js.map +1 -0
  165. package/dist/rules/rule/ip/v6/ruleIpV6Schema.d.ts +35 -0
  166. package/dist/rules/rule/ip/v6/ruleIpV6Schema.d.ts.map +1 -0
  167. package/dist/rules/rule/ip/v6/ruleIpV6Schema.js +9 -0
  168. package/dist/rules/rule/ip/v6/ruleIpV6Schema.js.map +1 -0
  169. package/dist/rules/rule/rule.d.ts +12 -0
  170. package/dist/rules/rule/rule.d.ts.map +1 -0
  171. package/dist/rules/rule/rule.js +2 -0
  172. package/dist/rules/rule/rule.js.map +1 -0
  173. package/dist/rules/storage/filters/deleteRuleFilters.d.ts +8 -0
  174. package/dist/rules/storage/filters/deleteRuleFilters.d.ts.map +1 -0
  175. package/dist/rules/storage/filters/deleteRuleFilters.js +2 -0
  176. package/dist/rules/storage/filters/deleteRuleFilters.js.map +1 -0
  177. package/dist/rules/storage/filters/search/searchRuleFilterSettings.d.ts +6 -0
  178. package/dist/rules/storage/filters/search/searchRuleFilterSettings.d.ts.map +1 -0
  179. package/dist/rules/storage/filters/search/searchRuleFilterSettings.js +2 -0
  180. package/dist/rules/storage/filters/search/searchRuleFilterSettings.js.map +1 -0
  181. package/dist/rules/storage/filters/search/searchRuleFilters.d.ts +8 -0
  182. package/dist/rules/storage/filters/search/searchRuleFilters.d.ts.map +1 -0
  183. package/dist/rules/storage/filters/search/searchRuleFilters.js +2 -0
  184. package/dist/rules/storage/filters/search/searchRuleFilters.js.map +1 -0
  185. package/dist/rules/storage/ruleRecord.d.ts +6 -0
  186. package/dist/rules/storage/ruleRecord.d.ts.map +1 -0
  187. package/dist/rules/storage/ruleRecord.js +2 -0
  188. package/dist/rules/storage/ruleRecord.js.map +1 -0
  189. package/dist/rules/storage/rulesStorage.d.ts +14 -0
  190. package/dist/rules/storage/rulesStorage.d.ts.map +1 -0
  191. package/dist/rules/storage/rulesStorage.js +2 -0
  192. package/dist/rules/storage/rulesStorage.js.map +1 -0
  193. package/dist/tests/benchmark/commands/commandBase.d.ts +14 -0
  194. package/dist/tests/benchmark/commands/commandBase.d.ts.map +1 -0
  195. package/dist/tests/benchmark/commands/commandBase.js +22 -0
  196. package/dist/tests/benchmark/commands/commandBase.js.map +1 -0
  197. package/dist/tests/benchmark/commands/measureFindCommand.d.ts +14 -0
  198. package/dist/tests/benchmark/commands/measureFindCommand.d.ts.map +1 -0
  199. package/dist/tests/benchmark/commands/measureFindCommand.js +60 -0
  200. package/dist/tests/benchmark/commands/measureFindCommand.js.map +1 -0
  201. package/dist/tests/benchmark/commands/populateCommand.d.ts +18 -0
  202. package/dist/tests/benchmark/commands/populateCommand.d.ts.map +1 -0
  203. package/dist/tests/benchmark/commands/populateCommand.js +97 -0
  204. package/dist/tests/benchmark/commands/populateCommand.js.map +1 -0
  205. package/dist/tests/benchmark/connectionCleaner/connectionCleaner.d.ts +5 -0
  206. package/dist/tests/benchmark/connectionCleaner/connectionCleaner.d.ts.map +1 -0
  207. package/dist/tests/benchmark/connectionCleaner/connectionCleaner.js +2 -0
  208. package/dist/tests/benchmark/connectionCleaner/connectionCleaner.js.map +1 -0
  209. package/dist/tests/benchmark/connectionCleaner/mongooseConnectionCleaner.d.ts +6 -0
  210. package/dist/tests/benchmark/connectionCleaner/mongooseConnectionCleaner.d.ts.map +1 -0
  211. package/dist/tests/benchmark/connectionCleaner/mongooseConnectionCleaner.js +8 -0
  212. package/dist/tests/benchmark/connectionCleaner/mongooseConnectionCleaner.js.map +1 -0
  213. package/dist/tests/benchmark/mongooseRulesStorageBenchmark.d.ts +2 -0
  214. package/dist/tests/benchmark/mongooseRulesStorageBenchmark.d.ts.map +1 -0
  215. package/dist/tests/benchmark/mongooseRulesStorageBenchmark.js +8 -0
  216. package/dist/tests/benchmark/mongooseRulesStorageBenchmark.js.map +1 -0
  217. package/dist/tests/benchmark/rulesStorageBenchmark.d.ts +12 -0
  218. package/dist/tests/benchmark/rulesStorageBenchmark.d.ts.map +1 -0
  219. package/dist/tests/benchmark/rulesStorageBenchmark.js +30 -0
  220. package/dist/tests/benchmark/rulesStorageBenchmark.js.map +1 -0
  221. package/dist/tests/benchmark/storageFactory/mongooseRulesStorageFactory.d.ts +10 -0
  222. package/dist/tests/benchmark/storageFactory/mongooseRulesStorageFactory.d.ts.map +1 -0
  223. package/dist/tests/benchmark/storageFactory/mongooseRulesStorageFactory.js +16 -0
  224. package/dist/tests/benchmark/storageFactory/mongooseRulesStorageFactory.js.map +1 -0
  225. package/dist/tests/benchmark/storageFactory/rulesStorageFactory.d.ts +6 -0
  226. package/dist/tests/benchmark/storageFactory/rulesStorageFactory.d.ts.map +1 -0
  227. package/dist/tests/benchmark/storageFactory/rulesStorageFactory.js +2 -0
  228. package/dist/tests/benchmark/storageFactory/rulesStorageFactory.js.map +1 -0
  229. package/dist/tests/rules/ImageCaptchaConfigRulesResolver.test.d.ts +2 -0
  230. package/dist/tests/rules/ImageCaptchaConfigRulesResolver.test.d.ts.map +1 -0
  231. package/dist/tests/rules/ImageCaptchaConfigRulesResolver.test.js +75 -0
  232. package/dist/tests/rules/ImageCaptchaConfigRulesResolver.test.js.map +1 -0
  233. package/dist/tests/rules/blacklistRulesInspector.unit.test.d.ts +2 -0
  234. package/dist/tests/rules/blacklistRulesInspector.unit.test.d.ts.map +1 -0
  235. package/dist/tests/rules/blacklistRulesInspector.unit.test.js +58 -0
  236. package/dist/tests/rules/blacklistRulesInspector.unit.test.js.map +1 -0
  237. package/dist/tests/rules/loggerMockedInstance.d.ts +13 -0
  238. package/dist/tests/rules/loggerMockedInstance.d.ts.map +1 -0
  239. package/dist/tests/rules/loggerMockedInstance.js +14 -0
  240. package/dist/tests/rules/loggerMockedInstance.js.map +1 -0
  241. package/dist/tests/rules/mongoose/find.unit.test.d.ts +2 -0
  242. package/dist/tests/rules/mongoose/find.unit.test.d.ts.map +1 -0
  243. package/dist/tests/rules/mongoose/find.unit.test.js +202 -0
  244. package/dist/tests/rules/mongoose/find.unit.test.js.map +1 -0
  245. package/dist/tests/rules/mongoose/insert/insertIpV6Formatting.unit.test.d.ts +2 -0
  246. package/dist/tests/rules/mongoose/insert/insertIpV6Formatting.unit.test.d.ts.map +1 -0
  247. package/dist/tests/rules/mongoose/insert/insertIpV6Formatting.unit.test.js +131 -0
  248. package/dist/tests/rules/mongoose/insert/insertIpV6Formatting.unit.test.js.map +1 -0
  249. package/dist/tests/rules/mongoose/insert/insertValidation.unit.test.d.ts +2 -0
  250. package/dist/tests/rules/mongoose/insert/insertValidation.unit.test.d.ts.map +1 -0
  251. package/dist/tests/rules/mongoose/insert/insertValidation.unit.test.js +101 -0
  252. package/dist/tests/rules/mongoose/insert/insertValidation.unit.test.js.map +1 -0
  253. package/dist/tests/rules/mongoose/ip.unit.test.d.ts +2 -0
  254. package/dist/tests/rules/mongoose/ip.unit.test.d.ts.map +1 -0
  255. package/dist/tests/rules/mongoose/ip.unit.test.js +392 -0
  256. package/dist/tests/rules/mongoose/ip.unit.test.js.map +1 -0
  257. package/dist/tests/rules/storage/testRulesStorage.d.ts +17 -0
  258. package/dist/tests/rules/storage/testRulesStorage.d.ts.map +1 -0
  259. package/dist/tests/rules/storage/testRulesStorage.js +25 -0
  260. package/dist/tests/rules/storage/testRulesStorage.js.map +1 -0
  261. package/package.json +47 -0
  262. package/vite.cjs.config.ts +23 -0
  263. package/vite.test.config.ts +17 -0
@@ -0,0 +1,6 @@
1
+ import type { IPAddress } from "@prosopo/types";
2
+ interface BlacklistInspector {
3
+ isUserBlacklisted(clientId: string, userIpAddress: IPAddress, userId: string): Promise<boolean>;
4
+ }
5
+ export type { BlacklistInspector };
6
+ //# sourceMappingURL=blacklistInspector.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"blacklistInspector.d.ts","sourceRoot":"","sources":["../src/blacklistInspector.ts"],"names":[],"mappings":"AAcA,OAAO,KAAK,EAAE,SAAS,EAAE,MAAM,gBAAgB,CAAC;AAEhD,UAAU,kBAAkB;IAC3B,iBAAiB,CAChB,QAAQ,EAAE,MAAM,EAChB,aAAa,EAAE,SAAS,EACxB,MAAM,EAAE,MAAM,GACZ,OAAO,CAAC,OAAO,CAAC,CAAC;CACpB;AAED,YAAY,EAAE,kBAAkB,EAAE,CAAC"}
@@ -0,0 +1,2 @@
1
+ export {};
2
+ //# sourceMappingURL=blacklistInspector.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"blacklistInspector.js","sourceRoot":"","sources":["../src/blacklistInspector.ts"],"names":[],"mappings":""}
@@ -0,0 +1,7 @@
1
+ import type { IPAddress, ProsopoCaptchaCountConfigSchemaOutput } from "@prosopo/types";
2
+ interface ImageCaptchaConfigResolver {
3
+ isConfigDefined(clientId: string, userIpAddress: IPAddress, userId: string): Promise<boolean>;
4
+ resolveConfig(defaults: ProsopoCaptchaCountConfigSchemaOutput, userIpAddress: IPAddress, userId: string, clientId: string): Promise<ProsopoCaptchaCountConfigSchemaOutput>;
5
+ }
6
+ export type { ImageCaptchaConfigResolver };
7
+ //# sourceMappingURL=imageCaptchaConfigResolver.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"imageCaptchaConfigResolver.d.ts","sourceRoot":"","sources":["../src/imageCaptchaConfigResolver.ts"],"names":[],"mappings":"AAcA,OAAO,KAAK,EACX,SAAS,EACT,qCAAqC,EACrC,MAAM,gBAAgB,CAAC;AAExB,UAAU,0BAA0B;IACnC,eAAe,CACd,QAAQ,EAAE,MAAM,EAChB,aAAa,EAAE,SAAS,EACxB,MAAM,EAAE,MAAM,GACZ,OAAO,CAAC,OAAO,CAAC,CAAC;IAEpB,aAAa,CACZ,QAAQ,EAAE,qCAAqC,EAC/C,aAAa,EAAE,SAAS,EACxB,MAAM,EAAE,MAAM,EACd,QAAQ,EAAE,MAAM,GACd,OAAO,CAAC,qCAAqC,CAAC,CAAC;CAClD;AAED,YAAY,EAAE,0BAA0B,EAAE,CAAC"}
@@ -0,0 +1,2 @@
1
+ export {};
2
+ //# sourceMappingURL=imageCaptchaConfigResolver.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"imageCaptchaConfigResolver.js","sourceRoot":"","sources":["../src/imageCaptchaConfigResolver.ts"],"names":[],"mappings":""}
@@ -0,0 +1,15 @@
1
+ import type { ApiRoutesProvider } from "@prosopo/api-route";
2
+ import type { Logger } from "@prosopo/common";
3
+ import type { Model } from "mongoose";
4
+ import type { BlacklistInspector } from "./blacklistInspector.js";
5
+ import { getExpressApiRuleRateLimits } from "./rules/api/getExpressApiRuleRateLimits.js";
6
+ import { ImageCaptchaConfigRulesResolver } from "./rules/imageCaptchaConfigRulesResolver.js";
7
+ import { getRuleMongooseSchema } from "./rules/mongoose/schemas/getRuleMongooseSchema.js";
8
+ import type { Rule } from "./rules/rule/rule.js";
9
+ import type { RulesStorage } from "./rules/storage/rulesStorage.js";
10
+ declare const createBlacklistInspector: (rulesStorage: RulesStorage, logger: Logger) => BlacklistInspector;
11
+ declare const createImageCaptchaConfigResolver: (rulesStorage: RulesStorage, logger: Logger) => ImageCaptchaConfigRulesResolver;
12
+ declare const createApiRuleRoutesProvider: (rulesStorage: RulesStorage) => ApiRoutesProvider;
13
+ declare const createMongooseRulesStorage: (logger: Logger, readingModel: Model<Rule> | null, writingModel?: Model<Rule> | null) => RulesStorage;
14
+ export { type Rule, type RulesStorage, type BlacklistInspector, createMongooseRulesStorage, createImageCaptchaConfigResolver, createBlacklistInspector, createApiRuleRoutesProvider, getRuleMongooseSchema, getExpressApiRuleRateLimits, };
15
+ //# sourceMappingURL=index.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../src/index.ts"],"names":[],"mappings":"AAcA,OAAO,KAAK,EAAE,iBAAiB,EAAE,MAAM,oBAAoB,CAAC;AAC5D,OAAO,KAAK,EAAE,MAAM,EAAE,MAAM,iBAAiB,CAAC;AAC9C,OAAO,KAAK,EAAE,KAAK,EAAE,MAAM,UAAU,CAAC;AACtC,OAAO,KAAK,EAAE,kBAAkB,EAAE,MAAM,yBAAyB,CAAC;AAElE,OAAO,EAAE,2BAA2B,EAAE,MAAM,4CAA4C,CAAC;AAEzF,OAAO,EAAE,+BAA+B,EAAE,MAAM,4CAA4C,CAAC;AAE7F,OAAO,EAAE,qBAAqB,EAAE,MAAM,mDAAmD,CAAC;AAC1F,OAAO,KAAK,EAAE,IAAI,EAAE,MAAM,sBAAsB,CAAC;AACjD,OAAO,KAAK,EAAE,YAAY,EAAE,MAAM,iCAAiC,CAAC;AAEpE,QAAA,MAAM,wBAAwB,iBACf,YAAY,UAClB,MAAM,KACZ,kBAEF,CAAC;AAEF,QAAA,MAAM,gCAAgC,iBACvB,YAAY,UAClB,MAAM,KACZ,+BAEF,CAAC;AAEF,QAAA,MAAM,2BAA2B,iBAClB,YAAY,KACxB,iBAEF,CAAC;AAEF,QAAA,MAAM,0BAA0B,WACvB,MAAM,gBACA,KAAK,CAAC,IAAI,CAAC,GAAG,IAAI,iBAClB,KAAK,CAAC,IAAI,CAAC,GAAG,IAAI,KAC9B,YAEF,CAAC;AAEF,OAAO,EACN,KAAK,IAAI,EACT,KAAK,YAAY,EACjB,KAAK,kBAAkB,EACvB,0BAA0B,EAC1B,gCAAgC,EAChC,wBAAwB,EACxB,2BAA2B,EAC3B,qBAAqB,EACrB,2BAA2B,GAC3B,CAAC"}
package/dist/index.js ADDED
@@ -0,0 +1,20 @@
1
+ import { ApiRuleRoutesProvider } from "./rules/api/apiRuleRoutesProvider.js";
2
+ import { getExpressApiRuleRateLimits } from "./rules/api/getExpressApiRuleRateLimits.js";
3
+ import { BlacklistRulesInspector } from "./rules/blacklistRulesInspector.js";
4
+ import { ImageCaptchaConfigRulesResolver } from "./rules/imageCaptchaConfigRulesResolver.js";
5
+ import { RulesMongooseStorage } from "./rules/mongoose/rulesMongooseStorage.js";
6
+ import { getRuleMongooseSchema } from "./rules/mongoose/schemas/getRuleMongooseSchema.js";
7
+ const createBlacklistInspector = (rulesStorage, logger) => {
8
+ return new BlacklistRulesInspector(rulesStorage, logger);
9
+ };
10
+ const createImageCaptchaConfigResolver = (rulesStorage, logger) => {
11
+ return new ImageCaptchaConfigRulesResolver(rulesStorage, logger);
12
+ };
13
+ const createApiRuleRoutesProvider = (rulesStorage) => {
14
+ return new ApiRuleRoutesProvider(rulesStorage);
15
+ };
16
+ const createMongooseRulesStorage = (logger, readingModel, writingModel = null) => {
17
+ return new RulesMongooseStorage(logger, readingModel, writingModel);
18
+ };
19
+ export { createMongooseRulesStorage, createImageCaptchaConfigResolver, createBlacklistInspector, createApiRuleRoutesProvider, getRuleMongooseSchema, getExpressApiRuleRateLimits, };
20
+ //# sourceMappingURL=index.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"index.js","sourceRoot":"","sources":["../src/index.ts"],"names":[],"mappings":"AAkBA,OAAO,EAAE,qBAAqB,EAAE,MAAM,sCAAsC,CAAC;AAC7E,OAAO,EAAE,2BAA2B,EAAE,MAAM,4CAA4C,CAAC;AACzF,OAAO,EAAE,uBAAuB,EAAE,MAAM,oCAAoC,CAAC;AAC7E,OAAO,EAAE,+BAA+B,EAAE,MAAM,4CAA4C,CAAC;AAC7F,OAAO,EAAE,oBAAoB,EAAE,MAAM,0CAA0C,CAAC;AAChF,OAAO,EAAE,qBAAqB,EAAE,MAAM,mDAAmD,CAAC;AAI1F,MAAM,wBAAwB,GAAG,CAChC,YAA0B,EAC1B,MAAc,EACO,EAAE;IACvB,OAAO,IAAI,uBAAuB,CAAC,YAAY,EAAE,MAAM,CAAC,CAAC;AAC1D,CAAC,CAAC;AAEF,MAAM,gCAAgC,GAAG,CACxC,YAA0B,EAC1B,MAAc,EACoB,EAAE;IACpC,OAAO,IAAI,+BAA+B,CAAC,YAAY,EAAE,MAAM,CAAC,CAAC;AAClE,CAAC,CAAC;AAEF,MAAM,2BAA2B,GAAG,CACnC,YAA0B,EACN,EAAE;IACtB,OAAO,IAAI,qBAAqB,CAAC,YAAY,CAAC,CAAC;AAChD,CAAC,CAAC;AAEF,MAAM,0BAA0B,GAAG,CAClC,MAAc,EACd,YAAgC,EAChC,eAAmC,IAAI,EACxB,EAAE;IACjB,OAAO,IAAI,oBAAoB,CAAC,MAAM,EAAE,YAAY,EAAE,YAAY,CAAC,CAAC;AACrE,CAAC,CAAC;AAEF,OAAO,EAIN,0BAA0B,EAC1B,gCAAgC,EAChC,wBAAwB,EACxB,2BAA2B,EAC3B,qBAAqB,EACrB,2BAA2B,GAC3B,CAAC"}
@@ -0,0 +1,6 @@
1
+ declare const apiRulePaths: {
2
+ INSERT_MANY: string;
3
+ DELETE_MANY: string;
4
+ };
5
+ export { apiRulePaths };
6
+ //# sourceMappingURL=apiRulePaths.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"apiRulePaths.d.ts","sourceRoot":"","sources":["../../../src/rules/api/apiRulePaths.ts"],"names":[],"mappings":"AAcA,QAAA,MAAM,YAAY;;;CAGjB,CAAC;AAEF,OAAO,EAAE,YAAY,EAAE,CAAC"}
@@ -0,0 +1,6 @@
1
+ const apiRulePaths = {
2
+ INSERT_MANY: "/v1/prosopo/user-access-policy/rules/insert-many",
3
+ DELETE_MANY: "/v1/prosopo/user-access-policy/rules/delete-many",
4
+ };
5
+ export { apiRulePaths };
6
+ //# sourceMappingURL=apiRulePaths.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"apiRulePaths.js","sourceRoot":"","sources":["../../../src/rules/api/apiRulePaths.ts"],"names":[],"mappings":"AAcA,MAAM,YAAY,GAAG;IACpB,WAAW,EAAE,kDAAkD;IAC/D,WAAW,EAAE,kDAAkD;CAC/D,CAAC;AAEF,OAAO,EAAE,YAAY,EAAE,CAAC"}
@@ -0,0 +1,9 @@
1
+ import type { ApiRoute, ApiRoutesProvider } from "@prosopo/api-route";
2
+ import type { RulesStorage } from "../storage/rulesStorage.js";
3
+ declare class ApiRuleRoutesProvider implements ApiRoutesProvider {
4
+ private readonly rulesStorage;
5
+ constructor(rulesStorage: RulesStorage);
6
+ getRoutes(): ApiRoute[];
7
+ }
8
+ export { ApiRuleRoutesProvider };
9
+ //# sourceMappingURL=apiRuleRoutesProvider.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"apiRuleRoutesProvider.d.ts","sourceRoot":"","sources":["../../../src/rules/api/apiRuleRoutesProvider.ts"],"names":[],"mappings":"AAcA,OAAO,KAAK,EAAE,QAAQ,EAAE,iBAAiB,EAAE,MAAM,oBAAoB,CAAC;AACtE,OAAO,KAAK,EAAE,YAAY,EAAE,MAAM,4BAA4B,CAAC;AAK/D,cAAM,qBAAsB,YAAW,iBAAiB;IACpC,OAAO,CAAC,QAAQ,CAAC,YAAY;gBAAZ,YAAY,EAAE,YAAY;IAEvD,SAAS,IAAI,QAAQ,EAAE;CAY9B;AAED,OAAO,EAAE,qBAAqB,EAAE,CAAC"}
@@ -0,0 +1,22 @@
1
+ import { apiRulePaths } from "./apiRulePaths.js";
2
+ import { ApiDeleteManyRulesEndpoint } from "./deleteMany/apiDeleteManyRulesEndpoint.js";
3
+ import { ApiInsertManyRulesEndpoint } from "./insertMany/apiInsertManyRulesEndpoint.js";
4
+ class ApiRuleRoutesProvider {
5
+ constructor(rulesStorage) {
6
+ this.rulesStorage = rulesStorage;
7
+ }
8
+ getRoutes() {
9
+ return [
10
+ {
11
+ path: apiRulePaths.INSERT_MANY,
12
+ endpoint: new ApiInsertManyRulesEndpoint(this.rulesStorage),
13
+ },
14
+ {
15
+ path: apiRulePaths.DELETE_MANY,
16
+ endpoint: new ApiDeleteManyRulesEndpoint(this.rulesStorage),
17
+ },
18
+ ];
19
+ }
20
+ }
21
+ export { ApiRuleRoutesProvider };
22
+ //# sourceMappingURL=apiRuleRoutesProvider.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"apiRuleRoutesProvider.js","sourceRoot":"","sources":["../../../src/rules/api/apiRuleRoutesProvider.ts"],"names":[],"mappings":"AAgBA,OAAO,EAAE,YAAY,EAAE,MAAM,mBAAmB,CAAC;AACjD,OAAO,EAAE,0BAA0B,EAAE,MAAM,4CAA4C,CAAC;AACxF,OAAO,EAAE,0BAA0B,EAAE,MAAM,4CAA4C,CAAC;AAExF,MAAM,qBAAqB;IAC1B,YAAoC,YAA0B;QAA1B,iBAAY,GAAZ,YAAY,CAAc;IAAG,CAAC;IAE3D,SAAS;QACf,OAAO;YACN;gBACC,IAAI,EAAE,YAAY,CAAC,WAAW;gBAC9B,QAAQ,EAAE,IAAI,0BAA0B,CAAC,IAAI,CAAC,YAAY,CAAC;aAC3D;YACD;gBACC,IAAI,EAAE,YAAY,CAAC,WAAW;gBAC9B,QAAQ,EAAE,IAAI,0BAA0B,CAAC,IAAI,CAAC,YAAY,CAAC;aAC3D;SACD,CAAC;IACH,CAAC;CACD;AAED,OAAO,EAAE,qBAAqB,EAAE,CAAC"}
@@ -0,0 +1,159 @@
1
+ declare const apiDeleteManyRulesArgsSchema: import("zod").ZodArray<import("zod").ZodObject<{
2
+ clientId: import("zod").ZodOptional<import("zod").ZodString>;
3
+ userIp: import("zod").ZodOptional<import("zod").ZodObject<{
4
+ v4: import("zod").ZodOptional<import("zod").ZodObject<{
5
+ asNumeric: import("zod").ZodBigInt;
6
+ asString: import("zod").ZodString;
7
+ mask: import("zod").ZodOptional<import("zod").ZodObject<{
8
+ rangeMinAsNumeric: import("zod").ZodBigInt;
9
+ rangeMaxAsNumeric: import("zod").ZodBigInt;
10
+ asNumeric: import("zod").ZodNumber;
11
+ }, "strip", import("zod").ZodTypeAny, {
12
+ rangeMinAsNumeric: bigint;
13
+ rangeMaxAsNumeric: bigint;
14
+ asNumeric: number;
15
+ }, {
16
+ rangeMinAsNumeric: bigint;
17
+ rangeMaxAsNumeric: bigint;
18
+ asNumeric: number;
19
+ }>>;
20
+ }, "strip", import("zod").ZodTypeAny, {
21
+ asNumeric: bigint;
22
+ asString: string;
23
+ mask?: {
24
+ rangeMinAsNumeric: bigint;
25
+ rangeMaxAsNumeric: bigint;
26
+ asNumeric: number;
27
+ } | undefined;
28
+ }, {
29
+ asNumeric: bigint;
30
+ asString: string;
31
+ mask?: {
32
+ rangeMinAsNumeric: bigint;
33
+ rangeMaxAsNumeric: bigint;
34
+ asNumeric: number;
35
+ } | undefined;
36
+ }>>;
37
+ v6: import("zod").ZodOptional<import("zod").ZodObject<{
38
+ asNumericString: import("zod").ZodString;
39
+ asString: import("zod").ZodString;
40
+ mask: import("zod").ZodOptional<import("zod").ZodObject<{
41
+ rangeMinAsNumericString: import("zod").ZodString;
42
+ rangeMaxAsNumericString: import("zod").ZodString;
43
+ asNumeric: import("zod").ZodNumber;
44
+ }, "strip", import("zod").ZodTypeAny, {
45
+ asNumeric: number;
46
+ rangeMinAsNumericString: string;
47
+ rangeMaxAsNumericString: string;
48
+ }, {
49
+ asNumeric: number;
50
+ rangeMinAsNumericString: string;
51
+ rangeMaxAsNumericString: string;
52
+ }>>;
53
+ }, "strip", import("zod").ZodTypeAny, {
54
+ asString: string;
55
+ asNumericString: string;
56
+ mask?: {
57
+ asNumeric: number;
58
+ rangeMinAsNumericString: string;
59
+ rangeMaxAsNumericString: string;
60
+ } | undefined;
61
+ }, {
62
+ asString: string;
63
+ asNumericString: string;
64
+ mask?: {
65
+ asNumeric: number;
66
+ rangeMinAsNumericString: string;
67
+ rangeMaxAsNumericString: string;
68
+ } | undefined;
69
+ }>>;
70
+ }, "strip", import("zod").ZodTypeAny, {
71
+ v4?: {
72
+ asNumeric: bigint;
73
+ asString: string;
74
+ mask?: {
75
+ rangeMinAsNumeric: bigint;
76
+ rangeMaxAsNumeric: bigint;
77
+ asNumeric: number;
78
+ } | undefined;
79
+ } | undefined;
80
+ v6?: {
81
+ asString: string;
82
+ asNumericString: string;
83
+ mask?: {
84
+ asNumeric: number;
85
+ rangeMinAsNumericString: string;
86
+ rangeMaxAsNumericString: string;
87
+ } | undefined;
88
+ } | undefined;
89
+ }, {
90
+ v4?: {
91
+ asNumeric: bigint;
92
+ asString: string;
93
+ mask?: {
94
+ rangeMinAsNumeric: bigint;
95
+ rangeMaxAsNumeric: bigint;
96
+ asNumeric: number;
97
+ } | undefined;
98
+ } | undefined;
99
+ v6?: {
100
+ asString: string;
101
+ asNumericString: string;
102
+ mask?: {
103
+ asNumeric: number;
104
+ rangeMinAsNumericString: string;
105
+ rangeMaxAsNumericString: string;
106
+ } | undefined;
107
+ } | undefined;
108
+ }>>;
109
+ userId: import("zod").ZodOptional<import("zod").ZodString>;
110
+ }, "strip", import("zod").ZodTypeAny, {
111
+ clientId?: string | undefined;
112
+ userIp?: {
113
+ v4?: {
114
+ asNumeric: bigint;
115
+ asString: string;
116
+ mask?: {
117
+ rangeMinAsNumeric: bigint;
118
+ rangeMaxAsNumeric: bigint;
119
+ asNumeric: number;
120
+ } | undefined;
121
+ } | undefined;
122
+ v6?: {
123
+ asString: string;
124
+ asNumericString: string;
125
+ mask?: {
126
+ asNumeric: number;
127
+ rangeMinAsNumericString: string;
128
+ rangeMaxAsNumericString: string;
129
+ } | undefined;
130
+ } | undefined;
131
+ } | undefined;
132
+ userId?: string | undefined;
133
+ }, {
134
+ clientId?: string | undefined;
135
+ userIp?: {
136
+ v4?: {
137
+ asNumeric: bigint;
138
+ asString: string;
139
+ mask?: {
140
+ rangeMinAsNumeric: bigint;
141
+ rangeMaxAsNumeric: bigint;
142
+ asNumeric: number;
143
+ } | undefined;
144
+ } | undefined;
145
+ v6?: {
146
+ asString: string;
147
+ asNumericString: string;
148
+ mask?: {
149
+ asNumeric: number;
150
+ rangeMinAsNumericString: string;
151
+ rangeMaxAsNumericString: string;
152
+ } | undefined;
153
+ } | undefined;
154
+ } | undefined;
155
+ userId?: string | undefined;
156
+ }>, "many">;
157
+ type ApiDeleteManyRulesArgsSchema = typeof apiDeleteManyRulesArgsSchema;
158
+ export { apiDeleteManyRulesArgsSchema, type ApiDeleteManyRulesArgsSchema };
159
+ //# sourceMappingURL=apiDeleteManyRulesArgsSchema.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"apiDeleteManyRulesArgsSchema.d.ts","sourceRoot":"","sources":["../../../../src/rules/api/deleteMany/apiDeleteManyRulesArgsSchema.ts"],"names":[],"mappings":"AAiBA,QAAA,MAAM,4BAA4B;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;WAMjC,CAAC;AAEF,KAAK,4BAA4B,GAAG,OAAO,4BAA4B,CAAC;AAExE,OAAO,EAAE,4BAA4B,EAAE,KAAK,4BAA4B,EAAE,CAAC"}
@@ -0,0 +1,9 @@
1
+ import { array, object, string } from "zod";
2
+ import { ruleIpSchema } from "../../rule/ip/ruleIpSchema.js";
3
+ const apiDeleteManyRulesArgsSchema = array(object({
4
+ clientId: string().optional(),
5
+ userIp: ruleIpSchema.optional(),
6
+ userId: string().optional(),
7
+ }));
8
+ export { apiDeleteManyRulesArgsSchema };
9
+ //# sourceMappingURL=apiDeleteManyRulesArgsSchema.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"apiDeleteManyRulesArgsSchema.js","sourceRoot":"","sources":["../../../../src/rules/api/deleteMany/apiDeleteManyRulesArgsSchema.ts"],"names":[],"mappings":"AAcA,OAAO,EAAE,KAAK,EAAE,MAAM,EAAE,MAAM,EAAE,MAAM,KAAK,CAAC;AAC5C,OAAO,EAAE,YAAY,EAAE,MAAM,+BAA+B,CAAC;AAE7D,MAAM,4BAA4B,GAAG,KAAK,CACzC,MAAM,CAAC;IACN,QAAQ,EAAE,MAAM,EAAE,CAAC,QAAQ,EAAE;IAC7B,MAAM,EAAE,YAAY,CAAC,QAAQ,EAAE;IAC/B,MAAM,EAAE,MAAM,EAAE,CAAC,QAAQ,EAAE;CAC3B,CAAC,CACF,CAAC;AAIF,OAAO,EAAE,4BAA4B,EAAqC,CAAC"}
@@ -0,0 +1,12 @@
1
+ import { type ApiEndpoint, type ApiEndpointResponse } from "@prosopo/api-route";
2
+ import type { z } from "zod";
3
+ import type { RulesStorage } from "../../storage/rulesStorage.js";
4
+ import { type ApiDeleteManyRulesArgsSchema } from "./apiDeleteManyRulesArgsSchema.js";
5
+ declare class ApiDeleteManyRulesEndpoint implements ApiEndpoint<ApiDeleteManyRulesArgsSchema> {
6
+ private readonly rulesStorage;
7
+ constructor(rulesStorage: RulesStorage);
8
+ processRequest(args: z.infer<ApiDeleteManyRulesArgsSchema>): Promise<ApiEndpointResponse>;
9
+ getRequestArgsSchema(): ApiDeleteManyRulesArgsSchema;
10
+ }
11
+ export { ApiDeleteManyRulesEndpoint };
12
+ //# sourceMappingURL=apiDeleteManyRulesEndpoint.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"apiDeleteManyRulesEndpoint.d.ts","sourceRoot":"","sources":["../../../../src/rules/api/deleteMany/apiDeleteManyRulesEndpoint.ts"],"names":[],"mappings":"AAcA,OAAO,EACN,KAAK,WAAW,EAChB,KAAK,mBAAmB,EAExB,MAAM,oBAAoB,CAAC;AAC5B,OAAO,KAAK,EAAE,CAAC,EAAE,MAAM,KAAK,CAAC;AAC7B,OAAO,KAAK,EAAE,YAAY,EAAE,MAAM,+BAA+B,CAAC;AAClE,OAAO,EACN,KAAK,4BAA4B,EAEjC,MAAM,mCAAmC,CAAC;AAE3C,cAAM,0BACL,YAAW,WAAW,CAAC,4BAA4B,CAAC;IAEjC,OAAO,CAAC,QAAQ,CAAC,YAAY;gBAAZ,YAAY,EAAE,YAAY;IAExD,cAAc,CACnB,IAAI,EAAE,CAAC,CAAC,KAAK,CAAC,4BAA4B,CAAC,GACzC,OAAO,CAAC,mBAAmB,CAAC;IAQxB,oBAAoB,IAAI,4BAA4B;CAG3D;AAED,OAAO,EAAE,0BAA0B,EAAE,CAAC"}
@@ -0,0 +1,18 @@
1
+ import { ApiEndpointResponseStatus, } from "@prosopo/api-route";
2
+ import { apiDeleteManyRulesArgsSchema, } from "./apiDeleteManyRulesArgsSchema.js";
3
+ class ApiDeleteManyRulesEndpoint {
4
+ constructor(rulesStorage) {
5
+ this.rulesStorage = rulesStorage;
6
+ }
7
+ async processRequest(args) {
8
+ await this.rulesStorage.deleteMany(args);
9
+ return {
10
+ status: ApiEndpointResponseStatus.SUCCESS,
11
+ };
12
+ }
13
+ getRequestArgsSchema() {
14
+ return apiDeleteManyRulesArgsSchema;
15
+ }
16
+ }
17
+ export { ApiDeleteManyRulesEndpoint };
18
+ //# sourceMappingURL=apiDeleteManyRulesEndpoint.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"apiDeleteManyRulesEndpoint.js","sourceRoot":"","sources":["../../../../src/rules/api/deleteMany/apiDeleteManyRulesEndpoint.ts"],"names":[],"mappings":"AAcA,OAAO,EAGN,yBAAyB,GACzB,MAAM,oBAAoB,CAAC;AAG5B,OAAO,EAEN,4BAA4B,GAC5B,MAAM,mCAAmC,CAAC;AAE3C,MAAM,0BAA0B;IAG/B,YAAoC,YAA0B;QAA1B,iBAAY,GAAZ,YAAY,CAAc;IAAG,CAAC;IAElE,KAAK,CAAC,cAAc,CACnB,IAA2C;QAE3C,MAAM,IAAI,CAAC,YAAY,CAAC,UAAU,CAAC,IAAI,CAAC,CAAC;QAEzC,OAAO;YACN,MAAM,EAAE,yBAAyB,CAAC,OAAO;SACzC,CAAC;IACH,CAAC;IAEM,oBAAoB;QAC1B,OAAO,4BAA4B,CAAC;IACrC,CAAC;CACD;AAED,OAAO,EAAE,0BAA0B,EAAE,CAAC"}
@@ -0,0 +1,8 @@
1
+ declare const getExpressApiRuleRateLimits: () => {
2
+ [x: string]: {
3
+ windowMs: string | number;
4
+ limit: string | number;
5
+ };
6
+ };
7
+ export { getExpressApiRuleRateLimits };
8
+ //# sourceMappingURL=getExpressApiRuleRateLimits.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"getExpressApiRuleRateLimits.d.ts","sourceRoot":"","sources":["../../../src/rules/api/getExpressApiRuleRateLimits.ts"],"names":[],"mappings":"AAgBA,QAAA,MAAM,2BAA2B;;;;;CAsBhC,CAAC;AAEF,OAAO,EAAE,2BAA2B,EAAE,CAAC"}
@@ -0,0 +1,21 @@
1
+ import { apiRulePaths } from "./apiRulePaths.js";
2
+ const getExpressApiRuleRateLimits = () => {
3
+ const defaultWindowsMs = 60000;
4
+ const defaultLimit = 5;
5
+ return {
6
+ [apiRulePaths.INSERT_MANY]: {
7
+ windowMs: process.env.PROSOPO_USER_ACCESS_POLICY_RULE_INSERT_MANY_WINDOW ||
8
+ defaultWindowsMs,
9
+ limit: process.env.PROSOPO_USER_ACCESS_POLICY_RULE_INSERT_MANY_LIMIT ||
10
+ defaultLimit,
11
+ },
12
+ [apiRulePaths.DELETE_MANY]: {
13
+ windowMs: process.env.PROSOPO_USER_ACCESS_POLICY_RULE_DELETE_MANY_WINDOW ||
14
+ defaultWindowsMs,
15
+ limit: process.env.PROSOPO_USER_ACCESS_POLICY_RULE_DELETE_MANY_LIMIT ||
16
+ defaultLimit,
17
+ },
18
+ };
19
+ };
20
+ export { getExpressApiRuleRateLimits };
21
+ //# sourceMappingURL=getExpressApiRuleRateLimits.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"getExpressApiRuleRateLimits.js","sourceRoot":"","sources":["../../../src/rules/api/getExpressApiRuleRateLimits.ts"],"names":[],"mappings":"AAcA,OAAO,EAAE,YAAY,EAAE,MAAM,mBAAmB,CAAC;AAEjD,MAAM,2BAA2B,GAAG,GAAG,EAAE;IACxC,MAAM,gBAAgB,GAAG,KAAK,CAAC;IAC/B,MAAM,YAAY,GAAG,CAAC,CAAC;IAEvB,OAAO;QACN,CAAC,YAAY,CAAC,WAAW,CAAC,EAAE;YAC3B,QAAQ,EACP,OAAO,CAAC,GAAG,CAAC,kDAAkD;gBAC9D,gBAAgB;YACjB,KAAK,EACJ,OAAO,CAAC,GAAG,CAAC,iDAAiD;gBAC7D,YAAY;SACb;QACD,CAAC,YAAY,CAAC,WAAW,CAAC,EAAE;YAC3B,QAAQ,EACP,OAAO,CAAC,GAAG,CAAC,kDAAkD;gBAC9D,gBAAgB;YACjB,KAAK,EACJ,OAAO,CAAC,GAAG,CAAC,iDAAiD;gBAC7D,YAAY;SACb;KACD,CAAC;AACH,CAAC,CAAC;AAEF,OAAO,EAAE,2BAA2B,EAAE,CAAC"}
@@ -0,0 +1,199 @@
1
+ declare const apiInsertManyRulesArgsSchema: import("zod").ZodObject<{
2
+ isUserBlocked: import("zod").ZodBoolean;
3
+ clientId: import("zod").ZodOptional<import("zod").ZodString>;
4
+ description: import("zod").ZodOptional<import("zod").ZodString>;
5
+ userIps: import("zod").ZodOptional<import("zod").ZodArray<import("zod").ZodObject<{
6
+ v4: import("zod").ZodOptional<import("zod").ZodObject<{
7
+ asNumeric: import("zod").ZodBigInt;
8
+ asString: import("zod").ZodString;
9
+ mask: import("zod").ZodOptional<import("zod").ZodObject<{
10
+ rangeMinAsNumeric: import("zod").ZodBigInt;
11
+ rangeMaxAsNumeric: import("zod").ZodBigInt;
12
+ asNumeric: import("zod").ZodNumber;
13
+ }, "strip", import("zod").ZodTypeAny, {
14
+ rangeMinAsNumeric: bigint;
15
+ rangeMaxAsNumeric: bigint;
16
+ asNumeric: number;
17
+ }, {
18
+ rangeMinAsNumeric: bigint;
19
+ rangeMaxAsNumeric: bigint;
20
+ asNumeric: number;
21
+ }>>;
22
+ }, "strip", import("zod").ZodTypeAny, {
23
+ asNumeric: bigint;
24
+ asString: string;
25
+ mask?: {
26
+ rangeMinAsNumeric: bigint;
27
+ rangeMaxAsNumeric: bigint;
28
+ asNumeric: number;
29
+ } | undefined;
30
+ }, {
31
+ asNumeric: bigint;
32
+ asString: string;
33
+ mask?: {
34
+ rangeMinAsNumeric: bigint;
35
+ rangeMaxAsNumeric: bigint;
36
+ asNumeric: number;
37
+ } | undefined;
38
+ }>>;
39
+ v6: import("zod").ZodOptional<import("zod").ZodObject<{
40
+ asNumericString: import("zod").ZodString;
41
+ asString: import("zod").ZodString;
42
+ mask: import("zod").ZodOptional<import("zod").ZodObject<{
43
+ rangeMinAsNumericString: import("zod").ZodString;
44
+ rangeMaxAsNumericString: import("zod").ZodString;
45
+ asNumeric: import("zod").ZodNumber;
46
+ }, "strip", import("zod").ZodTypeAny, {
47
+ asNumeric: number;
48
+ rangeMinAsNumericString: string;
49
+ rangeMaxAsNumericString: string;
50
+ }, {
51
+ asNumeric: number;
52
+ rangeMinAsNumericString: string;
53
+ rangeMaxAsNumericString: string;
54
+ }>>;
55
+ }, "strip", import("zod").ZodTypeAny, {
56
+ asString: string;
57
+ asNumericString: string;
58
+ mask?: {
59
+ asNumeric: number;
60
+ rangeMinAsNumericString: string;
61
+ rangeMaxAsNumericString: string;
62
+ } | undefined;
63
+ }, {
64
+ asString: string;
65
+ asNumericString: string;
66
+ mask?: {
67
+ asNumeric: number;
68
+ rangeMinAsNumericString: string;
69
+ rangeMaxAsNumericString: string;
70
+ } | undefined;
71
+ }>>;
72
+ }, "strip", import("zod").ZodTypeAny, {
73
+ v4?: {
74
+ asNumeric: bigint;
75
+ asString: string;
76
+ mask?: {
77
+ rangeMinAsNumeric: bigint;
78
+ rangeMaxAsNumeric: bigint;
79
+ asNumeric: number;
80
+ } | undefined;
81
+ } | undefined;
82
+ v6?: {
83
+ asString: string;
84
+ asNumericString: string;
85
+ mask?: {
86
+ asNumeric: number;
87
+ rangeMinAsNumericString: string;
88
+ rangeMaxAsNumericString: string;
89
+ } | undefined;
90
+ } | undefined;
91
+ }, {
92
+ v4?: {
93
+ asNumeric: bigint;
94
+ asString: string;
95
+ mask?: {
96
+ rangeMinAsNumeric: bigint;
97
+ rangeMaxAsNumeric: bigint;
98
+ asNumeric: number;
99
+ } | undefined;
100
+ } | undefined;
101
+ v6?: {
102
+ asString: string;
103
+ asNumericString: string;
104
+ mask?: {
105
+ asNumeric: number;
106
+ rangeMinAsNumericString: string;
107
+ rangeMaxAsNumericString: string;
108
+ } | undefined;
109
+ } | undefined;
110
+ }>, "many">>;
111
+ userIds: import("zod").ZodOptional<import("zod").ZodArray<import("zod").ZodString, "many">>;
112
+ config: import("zod").ZodOptional<import("zod").ZodObject<{
113
+ imageCaptcha: import("zod").ZodOptional<import("zod").ZodObject<{
114
+ solvedCount: import("zod").ZodOptional<import("zod").ZodNumber>;
115
+ unsolvedCount: import("zod").ZodOptional<import("zod").ZodNumber>;
116
+ }, "strip", import("zod").ZodTypeAny, {
117
+ solvedCount?: number | undefined;
118
+ unsolvedCount?: number | undefined;
119
+ }, {
120
+ solvedCount?: number | undefined;
121
+ unsolvedCount?: number | undefined;
122
+ }>>;
123
+ }, "strip", import("zod").ZodTypeAny, {
124
+ imageCaptcha?: {
125
+ solvedCount?: number | undefined;
126
+ unsolvedCount?: number | undefined;
127
+ } | undefined;
128
+ }, {
129
+ imageCaptcha?: {
130
+ solvedCount?: number | undefined;
131
+ unsolvedCount?: number | undefined;
132
+ } | undefined;
133
+ }>>;
134
+ }, "strip", import("zod").ZodTypeAny, {
135
+ isUserBlocked: boolean;
136
+ clientId?: string | undefined;
137
+ description?: string | undefined;
138
+ userIps?: {
139
+ v4?: {
140
+ asNumeric: bigint;
141
+ asString: string;
142
+ mask?: {
143
+ rangeMinAsNumeric: bigint;
144
+ rangeMaxAsNumeric: bigint;
145
+ asNumeric: number;
146
+ } | undefined;
147
+ } | undefined;
148
+ v6?: {
149
+ asString: string;
150
+ asNumericString: string;
151
+ mask?: {
152
+ asNumeric: number;
153
+ rangeMinAsNumericString: string;
154
+ rangeMaxAsNumericString: string;
155
+ } | undefined;
156
+ } | undefined;
157
+ }[] | undefined;
158
+ userIds?: string[] | undefined;
159
+ config?: {
160
+ imageCaptcha?: {
161
+ solvedCount?: number | undefined;
162
+ unsolvedCount?: number | undefined;
163
+ } | undefined;
164
+ } | undefined;
165
+ }, {
166
+ isUserBlocked: boolean;
167
+ clientId?: string | undefined;
168
+ description?: string | undefined;
169
+ userIps?: {
170
+ v4?: {
171
+ asNumeric: bigint;
172
+ asString: string;
173
+ mask?: {
174
+ rangeMinAsNumeric: bigint;
175
+ rangeMaxAsNumeric: bigint;
176
+ asNumeric: number;
177
+ } | undefined;
178
+ } | undefined;
179
+ v6?: {
180
+ asString: string;
181
+ asNumericString: string;
182
+ mask?: {
183
+ asNumeric: number;
184
+ rangeMinAsNumericString: string;
185
+ rangeMaxAsNumericString: string;
186
+ } | undefined;
187
+ } | undefined;
188
+ }[] | undefined;
189
+ userIds?: string[] | undefined;
190
+ config?: {
191
+ imageCaptcha?: {
192
+ solvedCount?: number | undefined;
193
+ unsolvedCount?: number | undefined;
194
+ } | undefined;
195
+ } | undefined;
196
+ }>;
197
+ type ApiInsertManyRulesArgsSchema = typeof apiInsertManyRulesArgsSchema;
198
+ export { apiInsertManyRulesArgsSchema, type ApiInsertManyRulesArgsSchema };
199
+ //# sourceMappingURL=apiInsertManyRulesArgsSchema.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"apiInsertManyRulesArgsSchema.d.ts","sourceRoot":"","sources":["../../../../src/rules/api/insertMany/apiInsertManyRulesArgsSchema.ts"],"names":[],"mappings":"AAkBA,QAAA,MAAM,4BAA4B;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;EAOhC,CAAC;AAEH,KAAK,4BAA4B,GAAG,OAAO,4BAA4B,CAAC;AAExE,OAAO,EAAE,4BAA4B,EAAE,KAAK,4BAA4B,EAAE,CAAC"}
@@ -0,0 +1,13 @@
1
+ import { boolean, object, string } from "zod";
2
+ import { ruleConfigSchema } from "../../rule/config/ruleConfigSchema.js";
3
+ import { ruleIpSchema } from "../../rule/ip/ruleIpSchema.js";
4
+ const apiInsertManyRulesArgsSchema = object({
5
+ isUserBlocked: boolean(),
6
+ clientId: string().optional(),
7
+ description: string().optional(),
8
+ userIps: ruleIpSchema.array().optional(),
9
+ userIds: string().array().optional(),
10
+ config: ruleConfigSchema.optional(),
11
+ });
12
+ export { apiInsertManyRulesArgsSchema };
13
+ //# sourceMappingURL=apiInsertManyRulesArgsSchema.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"apiInsertManyRulesArgsSchema.js","sourceRoot":"","sources":["../../../../src/rules/api/insertMany/apiInsertManyRulesArgsSchema.ts"],"names":[],"mappings":"AAcA,OAAO,EAAE,OAAO,EAAE,MAAM,EAAE,MAAM,EAAE,MAAM,KAAK,CAAC;AAC9C,OAAO,EAAE,gBAAgB,EAAE,MAAM,uCAAuC,CAAC;AACzE,OAAO,EAAE,YAAY,EAAE,MAAM,+BAA+B,CAAC;AAE7D,MAAM,4BAA4B,GAAG,MAAM,CAAC;IAC3C,aAAa,EAAE,OAAO,EAAE;IACxB,QAAQ,EAAE,MAAM,EAAE,CAAC,QAAQ,EAAE;IAC7B,WAAW,EAAE,MAAM,EAAE,CAAC,QAAQ,EAAE;IAChC,OAAO,EAAE,YAAY,CAAC,KAAK,EAAE,CAAC,QAAQ,EAAE;IACxC,OAAO,EAAE,MAAM,EAAE,CAAC,KAAK,EAAE,CAAC,QAAQ,EAAE;IACpC,MAAM,EAAE,gBAAgB,CAAC,QAAQ,EAAE;CACnC,CAAC,CAAC;AAIH,OAAO,EAAE,4BAA4B,EAAqC,CAAC"}