@prosopo/user-access-policy 3.5.19 → 3.5.27

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 (290) hide show
  1. package/CHANGELOG.md +67 -0
  2. package/coverage/base.css +224 -0
  3. package/coverage/block-navigation.js +87 -0
  4. package/coverage/clover.xml +786 -0
  5. package/coverage/coverage-final.json +15 -0
  6. package/coverage/favicon.png +0 -0
  7. package/coverage/index.html +146 -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/accessPolicy.ts.html +457 -0
  13. package/coverage/src/accessPolicyResolver.ts.html +211 -0
  14. package/coverage/src/accessRules.ts.html +265 -0
  15. package/coverage/src/api/accessRuleApiRoutes.ts.html +379 -0
  16. package/coverage/src/api/accessRulesApiClient.ts.html +274 -0
  17. package/coverage/src/api/deleteAllRulesEndpoint.ts.html +229 -0
  18. package/coverage/src/api/deleteRulesEndpoint.ts.html +301 -0
  19. package/coverage/src/api/index.html +176 -0
  20. package/coverage/src/api/insertRulesEndpoint.ts.html +436 -0
  21. package/coverage/src/index.html +176 -0
  22. package/coverage/src/index.ts.html +277 -0
  23. package/coverage/src/redis/index.html +161 -0
  24. package/coverage/src/redis/redisRulesIndex.ts.html +769 -0
  25. package/coverage/src/redis/redisRulesReader.ts.html +652 -0
  26. package/coverage/src/redis/redisRulesStorage.ts.html +229 -0
  27. package/coverage/src/redis/redisRulesWriter.ts.html +424 -0
  28. package/coverage/src/util.ts.html +136 -0
  29. package/dist/.export.d.ts +6 -0
  30. package/dist/.export.d.ts.map +1 -0
  31. package/dist/.export.js +21 -0
  32. package/dist/.export.js.map +1 -0
  33. package/dist/accessPolicy.d.ts +169 -0
  34. package/dist/accessPolicy.d.ts.map +1 -0
  35. package/dist/accessPolicy.js.map +1 -0
  36. package/dist/accessPolicyResolver.d.ts +110 -0
  37. package/dist/accessPolicyResolver.d.ts.map +1 -0
  38. package/dist/accessPolicyResolver.js.map +1 -0
  39. package/dist/accessRules.d.ts +16 -0
  40. package/dist/accessRules.d.ts.map +1 -0
  41. package/dist/accessRules.js.map +1 -0
  42. package/dist/api/.export.d.ts +7 -0
  43. package/dist/api/.export.d.ts.map +1 -0
  44. package/dist/api/.export.js +11 -0
  45. package/dist/api/.export.js.map +1 -0
  46. package/dist/api/accessRuleApiRoutes.d.ts +27 -0
  47. package/dist/api/accessRuleApiRoutes.d.ts.map +1 -0
  48. package/dist/api/accessRuleApiRoutes.js.map +1 -0
  49. package/dist/api/accessRulesApiClient.d.ts +10 -0
  50. package/dist/api/accessRulesApiClient.d.ts.map +1 -0
  51. package/dist/api/accessRulesApiClient.js.map +1 -0
  52. package/dist/api/delete/.export.d.ts +2 -0
  53. package/dist/api/delete/.export.d.ts.map +1 -0
  54. package/dist/api/delete/.export.js +1 -0
  55. package/dist/api/delete/.export.js.map +1 -0
  56. package/dist/api/delete/deleteAllRules.d.ts +11 -0
  57. package/dist/api/delete/deleteAllRules.d.ts.map +1 -0
  58. package/dist/api/delete/deleteAllRules.js +25 -0
  59. package/dist/api/delete/deleteAllRules.js.map +1 -0
  60. package/dist/api/delete/deleteRuleGroups.d.ts +19 -0
  61. package/dist/api/delete/deleteRuleGroups.d.ts.map +1 -0
  62. package/dist/api/delete/deleteRuleGroups.js +52 -0
  63. package/dist/api/delete/deleteRuleGroups.js.map +1 -0
  64. package/dist/api/delete/deleteRules.d.ts +15 -0
  65. package/dist/api/delete/deleteRules.d.ts.map +1 -0
  66. package/dist/api/delete/deleteRules.js +43 -0
  67. package/dist/api/delete/deleteRules.js.map +1 -0
  68. package/dist/api/deleteAllRulesEndpoint.d.ts +12 -0
  69. package/dist/api/deleteAllRulesEndpoint.d.ts.map +1 -0
  70. package/dist/api/deleteAllRulesEndpoint.js.map +1 -0
  71. package/dist/api/deleteRulesEndpoint.d.ts +116 -0
  72. package/dist/api/deleteRulesEndpoint.d.ts.map +1 -0
  73. package/dist/api/deleteRulesEndpoint.js.map +1 -0
  74. package/dist/api/insertRulesEndpoint.d.ts +22 -0
  75. package/dist/api/insertRulesEndpoint.d.ts.map +1 -0
  76. package/dist/api/insertRulesEndpoint.js.map +1 -0
  77. package/dist/api/read/.export.d.ts +4 -0
  78. package/dist/api/read/.export.d.ts.map +1 -0
  79. package/dist/api/read/.export.js +1 -0
  80. package/dist/api/read/.export.js.map +1 -0
  81. package/dist/api/read/fetchRules.d.ts +53 -0
  82. package/dist/api/read/fetchRules.d.ts.map +1 -0
  83. package/dist/api/read/fetchRules.js +43 -0
  84. package/dist/api/read/fetchRules.js.map +1 -0
  85. package/dist/api/read/findRuleIds.d.ts +28 -0
  86. package/dist/api/read/findRuleIds.d.ts.map +1 -0
  87. package/dist/api/read/findRuleIds.js +50 -0
  88. package/dist/api/read/findRuleIds.js.map +1 -0
  89. package/dist/api/read/getMissingIds.d.ts +28 -0
  90. package/dist/api/read/getMissingIds.d.ts.map +1 -0
  91. package/dist/api/read/getMissingIds.js +41 -0
  92. package/dist/api/read/getMissingIds.js.map +1 -0
  93. package/dist/api/ruleApiRoutes.d.ts +43 -0
  94. package/dist/api/ruleApiRoutes.d.ts.map +1 -0
  95. package/dist/api/ruleApiRoutes.js +131 -0
  96. package/dist/api/ruleApiRoutes.js.map +1 -0
  97. package/dist/api/rulesApiClient.d.ts +20 -0
  98. package/dist/api/rulesApiClient.d.ts.map +1 -0
  99. package/dist/api/rulesApiClient.js +93 -0
  100. package/dist/api/rulesApiClient.js.map +1 -0
  101. package/dist/api/write/.export.d.ts +2 -0
  102. package/dist/api/write/.export.d.ts.map +1 -0
  103. package/dist/api/write/.export.js +1 -0
  104. package/dist/api/write/.export.js.map +1 -0
  105. package/dist/api/write/insertRules.d.ts +29 -0
  106. package/dist/api/write/insertRules.d.ts.map +1 -0
  107. package/dist/api/write/insertRules.js +102 -0
  108. package/dist/api/write/insertRules.js.map +1 -0
  109. package/dist/api/write/rehashRules.d.ts +11 -0
  110. package/dist/api/write/rehashRules.d.ts.map +1 -0
  111. package/dist/api/write/rehashRules.js +57 -0
  112. package/dist/api/write/rehashRules.js.map +1 -0
  113. package/dist/cjs/.export.cjs +21 -0
  114. package/dist/cjs/api/.export.cjs +11 -0
  115. package/dist/cjs/api/delete/.export.cjs +1 -0
  116. package/dist/cjs/api/delete/deleteAllRules.cjs +25 -0
  117. package/dist/cjs/api/delete/deleteRuleGroups.cjs +52 -0
  118. package/dist/cjs/api/delete/deleteRules.cjs +43 -0
  119. package/dist/cjs/api/read/.export.cjs +1 -0
  120. package/dist/cjs/api/read/fetchRules.cjs +43 -0
  121. package/dist/cjs/api/read/findRuleIds.cjs +50 -0
  122. package/dist/cjs/api/read/getMissingIds.cjs +41 -0
  123. package/dist/cjs/api/ruleApiRoutes.cjs +131 -0
  124. package/dist/cjs/api/rulesApiClient.cjs +93 -0
  125. package/dist/cjs/api/write/.export.cjs +1 -0
  126. package/dist/cjs/api/write/insertRules.cjs +102 -0
  127. package/dist/cjs/api/write/rehashRules.cjs +57 -0
  128. package/dist/cjs/index.cjs +4 -6
  129. package/dist/cjs/mongoose/.export.cjs +4 -0
  130. package/dist/cjs/mongoose/mongooseRuleSchema.cjs +36 -0
  131. package/dist/cjs/redis/.export.cjs +6 -0
  132. package/dist/cjs/redis/reader/redisAggregate.cjs +60 -0
  133. package/dist/cjs/redis/reader/redisRulesQuery.cjs +99 -0
  134. package/dist/cjs/redis/reader/redisRulesReader.cjs +230 -0
  135. package/dist/cjs/redis/{redisRulesReader.cjs → redisAccessRules.cjs} +38 -28
  136. package/dist/cjs/redis/{redisRulesIndex.cjs → redisAccessRulesIndex.cjs} +45 -12
  137. package/dist/cjs/redis/redisClient.cjs +67 -0
  138. package/dist/cjs/redis/redisIndex.cjs +22 -0
  139. package/dist/cjs/redis/redisRuleIndex.cjs +50 -0
  140. package/dist/cjs/redis/redisRulesStorage.cjs +22 -9
  141. package/dist/cjs/redis/redisRulesWriter.cjs +91 -64
  142. package/dist/cjs/rule.cjs +8 -0
  143. package/dist/cjs/ruleInput/.export.cjs +9 -0
  144. package/dist/cjs/ruleInput/policyInput.cjs +25 -0
  145. package/dist/cjs/ruleInput/ruleInput.cjs +50 -0
  146. package/dist/cjs/ruleInput/userScopeInput.cjs +55 -0
  147. package/dist/cjs/ruleRecord.cjs +23 -0
  148. package/dist/cjs/rulesStorage.cjs +8 -0
  149. package/dist/cjs/transformRule.cjs +77 -0
  150. package/dist/index.d.ts +15 -0
  151. package/dist/index.d.ts.map +1 -0
  152. package/dist/index.js.map +1 -0
  153. package/dist/mongoose/.export.d.ts +2 -0
  154. package/dist/mongoose/.export.d.ts.map +1 -0
  155. package/dist/mongoose/.export.js +4 -0
  156. package/dist/mongoose/.export.js.map +1 -0
  157. package/dist/mongoose/mongooseRuleSchema.d.ts +4 -0
  158. package/dist/mongoose/mongooseRuleSchema.d.ts.map +1 -0
  159. package/dist/mongoose/mongooseRuleSchema.js +36 -0
  160. package/dist/mongoose/mongooseRuleSchema.js.map +1 -0
  161. package/dist/redis/.export.d.ts +3 -0
  162. package/dist/redis/.export.d.ts.map +1 -0
  163. package/dist/redis/.export.js +6 -0
  164. package/dist/redis/.export.js.map +1 -0
  165. package/dist/redis/reader/redisAggregate.d.ts +4 -0
  166. package/dist/redis/reader/redisAggregate.d.ts.map +1 -0
  167. package/dist/redis/reader/redisAggregate.js +60 -0
  168. package/dist/redis/reader/redisAggregate.js.map +1 -0
  169. package/dist/redis/reader/redisRulesQuery.d.ts +4 -0
  170. package/dist/redis/reader/redisRulesQuery.d.ts.map +1 -0
  171. package/dist/redis/reader/redisRulesQuery.js +99 -0
  172. package/dist/redis/reader/redisRulesQuery.js.map +1 -0
  173. package/dist/redis/reader/redisRulesReader.d.ts +26 -0
  174. package/dist/redis/reader/redisRulesReader.d.ts.map +1 -0
  175. package/dist/redis/reader/redisRulesReader.js +213 -0
  176. package/dist/redis/reader/redisRulesReader.js.map +1 -0
  177. package/dist/redis/redisAccessRules.d.ts +7 -0
  178. package/dist/redis/redisAccessRules.d.ts.map +1 -0
  179. package/dist/redis/redisAccessRules.js +119 -0
  180. package/dist/redis/redisAccessRules.js.map +1 -0
  181. package/dist/redis/redisAccessRulesIndex.d.ts +13 -0
  182. package/dist/redis/redisAccessRulesIndex.d.ts.map +1 -0
  183. package/dist/redis/redisAccessRulesIndex.js +140 -0
  184. package/dist/redis/redisAccessRulesIndex.js.map +1 -0
  185. package/dist/redis/redisClient.d.ts +11 -0
  186. package/dist/redis/redisClient.d.ts.map +1 -0
  187. package/dist/redis/redisClient.js +67 -0
  188. package/dist/redis/redisClient.js.map +1 -0
  189. package/dist/redis/redisIndex.d.ts +9 -0
  190. package/dist/redis/redisIndex.d.ts.map +1 -0
  191. package/dist/redis/redisIndex.js +23 -0
  192. package/dist/redis/redisIndex.js.map +1 -0
  193. package/dist/redis/redisRuleIndex.d.ts +13 -0
  194. package/dist/redis/redisRuleIndex.d.ts.map +1 -0
  195. package/dist/redis/redisRuleIndex.js +50 -0
  196. package/dist/redis/redisRuleIndex.js.map +1 -0
  197. package/dist/redis/redisRulesIndex.d.ts +9 -0
  198. package/dist/redis/redisRulesIndex.d.ts.map +1 -0
  199. package/dist/redis/redisRulesIndex.js.map +1 -0
  200. package/dist/redis/redisRulesReader.d.ts +6 -0
  201. package/dist/redis/redisRulesReader.d.ts.map +1 -0
  202. package/dist/redis/redisRulesReader.js.map +1 -0
  203. package/dist/redis/redisRulesStorage.d.ts +5 -0
  204. package/dist/redis/redisRulesStorage.d.ts.map +1 -0
  205. package/dist/redis/redisRulesStorage.js +23 -10
  206. package/dist/redis/redisRulesStorage.js.map +1 -0
  207. package/dist/redis/redisRulesWriter.d.ts +22 -0
  208. package/dist/redis/redisRulesWriter.d.ts.map +1 -0
  209. package/dist/redis/redisRulesWriter.js +91 -64
  210. package/dist/redis/redisRulesWriter.js.map +1 -0
  211. package/dist/rule.d.ts +34 -0
  212. package/dist/rule.d.ts.map +1 -0
  213. package/dist/rule.js +8 -0
  214. package/dist/rule.js.map +1 -0
  215. package/dist/ruleInput/.export.d.ts +4 -0
  216. package/dist/ruleInput/.export.d.ts.map +1 -0
  217. package/dist/ruleInput/.export.js +9 -0
  218. package/dist/ruleInput/.export.js.map +1 -0
  219. package/dist/ruleInput/policyInput.d.ts +38 -0
  220. package/dist/ruleInput/policyInput.d.ts.map +1 -0
  221. package/dist/ruleInput/policyInput.js +25 -0
  222. package/dist/ruleInput/policyInput.js.map +1 -0
  223. package/dist/ruleInput/ruleInput.d.ts +145 -0
  224. package/dist/ruleInput/ruleInput.d.ts.map +1 -0
  225. package/dist/ruleInput/ruleInput.js +50 -0
  226. package/dist/ruleInput/ruleInput.js.map +1 -0
  227. package/dist/ruleInput/userScopeInput.d.ts +93 -0
  228. package/dist/ruleInput/userScopeInput.d.ts.map +1 -0
  229. package/dist/ruleInput/userScopeInput.js +55 -0
  230. package/dist/ruleInput/userScopeInput.js.map +1 -0
  231. package/dist/ruleRecord.d.ts +18 -0
  232. package/dist/ruleRecord.d.ts.map +1 -0
  233. package/dist/ruleRecord.js +23 -0
  234. package/dist/ruleRecord.js.map +1 -0
  235. package/dist/rulesStorage.d.ts +30 -0
  236. package/dist/rulesStorage.d.ts.map +1 -0
  237. package/dist/rulesStorage.js +8 -0
  238. package/dist/rulesStorage.js.map +1 -0
  239. package/dist/tests/accessPolicy.test.d.ts +2 -0
  240. package/dist/tests/accessPolicy.test.d.ts.map +1 -0
  241. package/dist/tests/accessPolicy.test.js +27 -0
  242. package/dist/tests/accessPolicy.test.js.map +1 -0
  243. package/dist/tests/redis/reader/redisRulesQuery.unit.test.d.ts +2 -0
  244. package/dist/tests/redis/reader/redisRulesQuery.unit.test.d.ts.map +1 -0
  245. package/dist/tests/redis/reader/redisRulesQuery.unit.test.js +101 -0
  246. package/dist/tests/redis/reader/redisRulesQuery.unit.test.js.map +1 -0
  247. package/dist/tests/redis/redisAccessRules.integration.test.d.ts +2 -0
  248. package/dist/tests/redis/redisAccessRules.integration.test.d.ts.map +1 -0
  249. package/dist/tests/redis/redisAccessRules.integration.test.js +586 -0
  250. package/dist/tests/redis/redisAccessRules.integration.test.js.map +1 -0
  251. package/dist/tests/redis/redisAccessRules.unit.test.d.ts +2 -0
  252. package/dist/tests/redis/redisAccessRules.unit.test.d.ts.map +1 -0
  253. package/dist/tests/redis/redisAccessRules.unit.test.js +198 -0
  254. package/dist/tests/redis/redisAccessRules.unit.test.js.map +1 -0
  255. package/dist/tests/redis/redisIndex.integration.test.d.ts +2 -0
  256. package/dist/tests/redis/redisIndex.integration.test.d.ts.map +1 -0
  257. package/dist/tests/redis/redisIndex.integration.test.js +80 -0
  258. package/dist/tests/redis/redisIndex.integration.test.js.map +1 -0
  259. package/dist/tests/redis/redisRulesIndex.unit.test.d.ts +2 -0
  260. package/dist/tests/redis/redisRulesIndex.unit.test.d.ts.map +1 -0
  261. package/dist/tests/redis/redisRulesIndex.unit.test.js +101 -0
  262. package/dist/tests/redis/redisRulesIndex.unit.test.js.map +1 -0
  263. package/dist/tests/redis/redisRulesStorage.integration.test.d.ts +2 -0
  264. package/dist/tests/redis/redisRulesStorage.integration.test.d.ts.map +1 -0
  265. package/dist/tests/redis/redisRulesStorage.integration.test.js +611 -0
  266. package/dist/tests/redis/redisRulesStorage.integration.test.js.map +1 -0
  267. package/dist/tests/redis/testRedisClient.d.ts +3 -0
  268. package/dist/tests/redis/testRedisClient.d.ts.map +1 -0
  269. package/dist/tests/redis/testRedisClient.js +8 -0
  270. package/dist/tests/redis/testRedisClient.js.map +1 -0
  271. package/dist/tests/testLogger.d.ts +4 -0
  272. package/dist/tests/testLogger.d.ts.map +1 -0
  273. package/dist/tests/testLogger.js +22 -0
  274. package/dist/tests/testLogger.js.map +1 -0
  275. package/dist/tests/transformRule.unit.test.d.ts +2 -0
  276. package/dist/tests/transformRule.unit.test.d.ts.map +1 -0
  277. package/dist/tests/transformRule.unit.test.js +188 -0
  278. package/dist/tests/transformRule.unit.test.js.map +1 -0
  279. package/dist/transformRule.d.ts +7 -0
  280. package/dist/transformRule.d.ts.map +1 -0
  281. package/dist/transformRule.js +77 -0
  282. package/dist/transformRule.js.map +1 -0
  283. package/dist/util.d.ts +2 -0
  284. package/dist/util.d.ts.map +1 -0
  285. package/dist/util.js.map +1 -0
  286. package/entries.ts +20 -0
  287. package/package.json +34 -18
  288. package/vite.cjs.config.ts +4 -1
  289. package/vite.esm.config.ts +6 -1
  290. package/dist/cjs/api/accessRulesApiClient.cjs +0 -38
@@ -1,73 +1,100 @@
1
- import crypto from "node:crypto";
2
- import { redisRuleKeyPrefix } from "./redisRulesIndex.js";
3
- const redisRuleContentHashAlgorithm = "md5";
4
- const createRedisRulesWriter = (client) => {
5
- return {
6
- insertRule: async (rule, expirationTimestamp) => {
7
- const ruleKey = getRedisRuleKey(rule);
1
+ import { chunkIntoBatches, executeBatchesSequentially } from "@prosopo/common";
2
+ import { REDIS_BATCH_SIZE } from "./redisClient.js";
3
+ import { ACCESS_RULE_REDIS_KEY_PREFIX, getAccessRuleRedisKey } from "./redisRuleIndex.js";
4
+ class RedisRulesWriter {
5
+ constructor(client, logger) {
6
+ this.client = client;
7
+ this.logger = logger;
8
+ }
9
+ async insertRules(ruleEntries) {
10
+ const entryBatches = chunkIntoBatches(ruleEntries, REDIS_BATCH_SIZE);
11
+ const keyBatches = await executeBatchesSequentially(
12
+ entryBatches,
13
+ async (entriesBatch) => this.insertRuleEntries(entriesBatch)
14
+ );
15
+ return keyBatches.flatMap(
16
+ (ruleKey) => ruleKey.slice(ACCESS_RULE_REDIS_KEY_PREFIX.length)
17
+ );
18
+ }
19
+ async deleteRules(ruleIds) {
20
+ const ruleKeys = ruleIds.map(
21
+ (ruleId) => ACCESS_RULE_REDIS_KEY_PREFIX + ruleId
22
+ );
23
+ const keyBatches = chunkIntoBatches(ruleKeys, REDIS_BATCH_SIZE);
24
+ await executeBatchesSequentially(keyBatches, async (keysBatch) => {
25
+ const queries = this.client.multi();
26
+ for (const ruleKey of keysBatch) {
27
+ queries.del(ruleKey);
28
+ }
29
+ await queries.exec();
30
+ });
31
+ }
32
+ async deleteAllRules() {
33
+ let cursor = "0";
34
+ let total = 0;
35
+ do {
36
+ const reply = await this.client.scan(cursor, {
37
+ MATCH: `${ACCESS_RULE_REDIS_KEY_PREFIX}*`,
38
+ COUNT: REDIS_BATCH_SIZE
39
+ });
40
+ const ids = reply.keys.map(
41
+ (key) => key.slice(ACCESS_RULE_REDIS_KEY_PREFIX.length)
42
+ );
43
+ await this.deleteRules(ids);
44
+ total += ids.length;
45
+ cursor = reply.cursor;
46
+ } while ("0" !== cursor);
47
+ return total;
48
+ }
49
+ async insertRuleEntries(ruleEntries) {
50
+ const queries = this.client.multi();
51
+ const ruleKeys = ruleEntries.map((ruleEntry) => {
52
+ const { rule, expiresUnixTimestamp } = ruleEntry;
53
+ const ruleKey = getAccessRuleRedisKey(rule);
8
54
  const ruleValue = getRedisRuleValue(rule);
9
- await client.hSet(ruleKey, ruleValue);
10
- if (expirationTimestamp) {
11
- const expiryDate = new Date(expirationTimestamp);
12
- if (expiryDate.getUTCFullYear() === 1970) {
13
- await client.expireAt(ruleKey, expirationTimestamp);
14
- } else {
15
- const timestampInSeconds = Math.floor(expirationTimestamp / 1e3);
16
- await client.expireAt(ruleKey, timestampInSeconds);
17
- }
55
+ queries.hSet(ruleKey, ruleValue);
56
+ if (expiresUnixTimestamp) {
57
+ queries.expireAt(ruleKey, expiresUnixTimestamp);
18
58
  }
19
59
  return ruleKey;
20
- },
21
- deleteRules: async (ruleIds) => void await client.del(ruleIds),
22
- deleteAllRules: async () => {
23
- const keys = await client.keys(`${redisRuleKeyPrefix}*`);
24
- if (keys.length === 0) return 0;
25
- return await client.del(keys);
26
- }
27
- };
28
- };
29
- const getDummyRedisRulesWriter = (logger) => {
30
- return {
31
- insertRule: async (rule, expirationTimestamp) => {
32
- logger.info(() => ({
33
- msg: "Dummy insertRule() has no effect (redis is not ready)",
34
- data: {
35
- rule
36
- }
37
- }));
38
- return "";
39
- },
40
- deleteRules: async (ruleIds) => {
41
- logger.info(() => ({
42
- msg: "Dummy deleteRules() has no effect (redis is not ready)",
43
- data: {
44
- ruleIds
45
- }
46
- }));
47
- },
48
- deleteAllRules: async () => {
49
- logger.info(() => ({
50
- msg: "Dummy deleteAllRules() has no effect (redis is not ready)"
51
- }));
52
- return 0;
53
- }
54
- };
55
- };
56
- const getRedisRuleKey = (rule) => redisRuleKeyPrefix + crypto.createHash(redisRuleContentHashAlgorithm).update(
57
- JSON.stringify(
58
- rule,
59
- (key, value) => (
60
- // JSON.stringify can't handle BigInt itself: throws "Do not know how to serialize a BigInt"
61
- "bigint" === typeof value ? value.toString() : value
62
- )
63
- )
64
- ).digest("hex");
60
+ });
61
+ await queries.exec();
62
+ return ruleKeys;
63
+ }
64
+ }
65
65
  const getRedisRuleValue = (rule) => Object.fromEntries(
66
66
  Object.entries(rule).map(([key, value]) => [key, String(value)])
67
67
  );
68
+ class DummyRedisRulesWriter {
69
+ constructor(logger) {
70
+ this.logger = logger;
71
+ }
72
+ async insertRules(ruleEntries) {
73
+ this.logger.info(() => ({
74
+ msg: "Dummy insertRules() has no effect (redis is not ready)",
75
+ data: {
76
+ ruleEntries
77
+ }
78
+ }));
79
+ return [];
80
+ }
81
+ async deleteRules(ruleIds) {
82
+ this.logger.info(() => ({
83
+ msg: "Dummy deleteRules() has no effect (redis is not ready)",
84
+ data: {
85
+ ruleIds
86
+ }
87
+ }));
88
+ }
89
+ async deleteAllRules() {
90
+ this.logger.info(() => ({
91
+ msg: "Dummy deleteAllRules() has no effect (redis is not ready)"
92
+ }));
93
+ return 0;
94
+ }
95
+ }
68
96
  export {
69
- createRedisRulesWriter,
70
- getDummyRedisRulesWriter,
71
- getRedisRuleKey,
97
+ DummyRedisRulesWriter,
98
+ RedisRulesWriter,
72
99
  getRedisRuleValue
73
100
  };
@@ -0,0 +1 @@
1
+ {"version":3,"file":"redisRulesWriter.js","sourceRoot":"","sources":["../../src/redis/redisRulesWriter.ts"],"names":[],"mappings":"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"}
package/dist/rule.d.ts ADDED
@@ -0,0 +1,34 @@
1
+ import type { CaptchaType } from "@prosopo/types";
2
+ export declare enum AccessPolicyType {
3
+ Block = "block",
4
+ Restrict = "restrict"
5
+ }
6
+ export type AccessPolicy = {
7
+ type: AccessPolicyType;
8
+ captchaType?: CaptchaType;
9
+ description?: string;
10
+ solvedImagesCount?: number;
11
+ imageThreshold?: number;
12
+ powDifficulty?: number;
13
+ unsolvedImagesCount?: number;
14
+ frictionlessScore?: number;
15
+ };
16
+ export type PolicyScope = {
17
+ clientId?: string;
18
+ };
19
+ export type UserIp = {
20
+ numericIp?: bigint;
21
+ numericIpMaskMin?: bigint;
22
+ numericIpMaskMax?: bigint;
23
+ };
24
+ export type UserAttributes = {
25
+ userId?: string;
26
+ ja4Hash?: string;
27
+ headersHash?: string;
28
+ userAgentHash?: string;
29
+ };
30
+ export type UserScope = UserAttributes & UserIp;
31
+ export type AccessRule = AccessPolicy & PolicyScope & UserScope & {
32
+ groupId?: string;
33
+ };
34
+ //# sourceMappingURL=rule.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"rule.d.ts","sourceRoot":"","sources":["../src/rule.ts"],"names":[],"mappings":"AAaA,OAAO,KAAK,EAAE,WAAW,EAAE,MAAM,gBAAgB,CAAC;AAElD,oBAAY,gBAAgB;IAC3B,KAAK,UAAU;IACf,QAAQ,aAAa;CACrB;AAED,MAAM,MAAM,YAAY,GAAG;IAC1B,IAAI,EAAE,gBAAgB,CAAC;IACvB,WAAW,CAAC,EAAE,WAAW,CAAC;IAC1B,WAAW,CAAC,EAAE,MAAM,CAAC;IACrB,iBAAiB,CAAC,EAAE,MAAM,CAAC;IAC3B,cAAc,CAAC,EAAE,MAAM,CAAC;IACxB,aAAa,CAAC,EAAE,MAAM,CAAC;IACvB,mBAAmB,CAAC,EAAE,MAAM,CAAC;IAC7B,iBAAiB,CAAC,EAAE,MAAM,CAAC;CAC3B,CAAC;AAEF,MAAM,MAAM,WAAW,GAAG;IACzB,QAAQ,CAAC,EAAE,MAAM,CAAC;CAClB,CAAC;AAEF,MAAM,MAAM,MAAM,GAAG;IACpB,SAAS,CAAC,EAAE,MAAM,CAAC;IACnB,gBAAgB,CAAC,EAAE,MAAM,CAAC;IAC1B,gBAAgB,CAAC,EAAE,MAAM,CAAC;CAC1B,CAAC;AAEF,MAAM,MAAM,cAAc,GAAG;IAC5B,MAAM,CAAC,EAAE,MAAM,CAAC;IAChB,OAAO,CAAC,EAAE,MAAM,CAAC;IACjB,WAAW,CAAC,EAAE,MAAM,CAAC;IACrB,aAAa,CAAC,EAAE,MAAM,CAAC;CACvB,CAAC;AAEF,MAAM,MAAM,SAAS,GAAG,cAAc,GAAG,MAAM,CAAC;AAGhD,MAAM,MAAM,UAAU,GAAG,YAAY,GACpC,WAAW,GACX,SAAS,GAAG;IACX,OAAO,CAAC,EAAE,MAAM,CAAC;CACjB,CAAC"}
package/dist/rule.js ADDED
@@ -0,0 +1,8 @@
1
+ var AccessPolicyType = /* @__PURE__ */ ((AccessPolicyType2) => {
2
+ AccessPolicyType2["Block"] = "block";
3
+ AccessPolicyType2["Restrict"] = "restrict";
4
+ return AccessPolicyType2;
5
+ })(AccessPolicyType || {});
6
+ export {
7
+ AccessPolicyType
8
+ };
@@ -0,0 +1 @@
1
+ {"version":3,"file":"rule.js","sourceRoot":"","sources":["../src/rule.ts"],"names":[],"mappings":"AAeA,MAAM,CAAN,IAAY,gBAGX;AAHD,WAAY,gBAAgB;IAC3B,mCAAe,CAAA;IACf,yCAAqB,CAAA;AACtB,CAAC,EAHW,gBAAgB,KAAhB,gBAAgB,QAG3B"}
@@ -0,0 +1,4 @@
1
+ export { accessRuleInput, type AccessRulesFilterInput } from "./ruleInput.js";
2
+ export { accessPolicyInput, policyScopeInput } from "./policyInput.js";
3
+ export { userScopeInput } from "./userScopeInput.js";
4
+ //# sourceMappingURL=.export.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":".export.d.ts","sourceRoot":"","sources":["../../src/ruleInput/.export.ts"],"names":[],"mappings":"AAcA,OAAO,EAAE,eAAe,EAAE,KAAK,sBAAsB,EAAE,MAAM,gBAAgB,CAAC;AAE9E,OAAO,EAAE,iBAAiB,EAAE,gBAAgB,EAAE,MAAM,kBAAkB,CAAC;AAEvE,OAAO,EAAE,cAAc,EAAE,MAAM,qBAAqB,CAAC"}
@@ -0,0 +1,9 @@
1
+ import { accessRuleInput } from "./ruleInput.js";
2
+ import { accessPolicyInput, policyScopeInput } from "./policyInput.js";
3
+ import { userScopeInput } from "./userScopeInput.js";
4
+ export {
5
+ accessPolicyInput,
6
+ accessRuleInput,
7
+ policyScopeInput,
8
+ userScopeInput
9
+ };
@@ -0,0 +1 @@
1
+ {"version":3,"file":".export.js","sourceRoot":"","sources":["../../src/ruleInput/.export.ts"],"names":[],"mappings":"AAcA,OAAO,EAAE,eAAe,EAA+B,MAAM,gBAAgB,CAAC;AAE9E,OAAO,EAAE,iBAAiB,EAAE,gBAAgB,EAAE,MAAM,kBAAkB,CAAC;AAEvE,OAAO,EAAE,cAAc,EAAE,MAAM,qBAAqB,CAAC"}
@@ -0,0 +1,38 @@
1
+ import { z } from "zod";
2
+ import { AccessPolicyType } from "#policy/rule.js";
3
+ export declare const accessPolicyInput: z.ZodObject<{
4
+ type: z.ZodNativeEnum<typeof AccessPolicyType>;
5
+ captchaType: z.ZodOptional<z.ZodNativeEnum<typeof import("@prosopo/types").CaptchaType>>;
6
+ description: z.ZodOptional<z.ZodString>;
7
+ solvedImagesCount: z.ZodOptional<z.ZodNumber>;
8
+ imageThreshold: z.ZodOptional<z.ZodNumber>;
9
+ powDifficulty: z.ZodOptional<z.ZodNumber>;
10
+ unsolvedImagesCount: z.ZodOptional<z.ZodNumber>;
11
+ frictionlessScore: z.ZodOptional<z.ZodNumber>;
12
+ }, "strip", z.ZodTypeAny, {
13
+ type: AccessPolicyType;
14
+ captchaType?: import("@prosopo/types").CaptchaType | undefined;
15
+ description?: string | undefined;
16
+ solvedImagesCount?: number | undefined;
17
+ imageThreshold?: number | undefined;
18
+ powDifficulty?: number | undefined;
19
+ unsolvedImagesCount?: number | undefined;
20
+ frictionlessScore?: number | undefined;
21
+ }, {
22
+ type: AccessPolicyType;
23
+ captchaType?: import("@prosopo/types").CaptchaType | undefined;
24
+ description?: string | undefined;
25
+ solvedImagesCount?: number | undefined;
26
+ imageThreshold?: number | undefined;
27
+ powDifficulty?: number | undefined;
28
+ unsolvedImagesCount?: number | undefined;
29
+ frictionlessScore?: number | undefined;
30
+ }>;
31
+ export declare const policyScopeInput: z.ZodObject<{
32
+ clientId: z.ZodOptional<z.ZodString>;
33
+ }, "strip", z.ZodTypeAny, {
34
+ clientId?: string | undefined;
35
+ }, {
36
+ clientId?: string | undefined;
37
+ }>;
38
+ //# sourceMappingURL=policyInput.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"policyInput.d.ts","sourceRoot":"","sources":["../../src/ruleInput/policyInput.ts"],"names":[],"mappings":"AAgBA,OAAO,EAAgB,CAAC,EAAE,MAAM,KAAK,CAAC;AACtC,OAAO,EAEN,gBAAgB,EAEhB,MAAM,iBAAiB,CAAC;AAEzB,eAAO,MAAM,iBAAiB;;;;;;;;;;;;;;;;;;;;;;;;;;;EAcoC,CAAC;AAEnE,eAAO,MAAM,gBAAgB;;;;;;EAEmC,CAAC"}
@@ -0,0 +1,25 @@
1
+ import { CaptchaTypeSchema } from "@prosopo/types";
2
+ import { z } from "zod";
3
+ import { AccessPolicyType } from "../rule.js";
4
+ const accessPolicyInput = z.object({
5
+ type: z.nativeEnum(AccessPolicyType),
6
+ captchaType: CaptchaTypeSchema.optional(),
7
+ description: z.coerce.string().optional(),
8
+ // Redis stores values as strings, so coerce is needed to parse properly
9
+ solvedImagesCount: z.coerce.number().optional(),
10
+ // the percentage of image panels that must be solved per image CAPTCHA
11
+ imageThreshold: z.coerce.number().optional(),
12
+ // the Proof-of-Work difficulty level
13
+ powDifficulty: z.coerce.number().optional(),
14
+ // the number of unsolved image CAPTCHA challenges to serve
15
+ unsolvedImagesCount: z.coerce.number().optional(),
16
+ // used to increase the user's score
17
+ frictionlessScore: z.coerce.number().optional()
18
+ });
19
+ const policyScopeInput = z.object({
20
+ clientId: z.coerce.string().optional()
21
+ });
22
+ export {
23
+ accessPolicyInput,
24
+ policyScopeInput
25
+ };
@@ -0,0 +1 @@
1
+ {"version":3,"file":"policyInput.js","sourceRoot":"","sources":["../../src/ruleInput/policyInput.ts"],"names":[],"mappings":"AAeA,OAAO,EAAE,iBAAiB,EAAE,MAAM,gBAAgB,CAAC;AACnD,OAAO,EAAgB,CAAC,EAAE,MAAM,KAAK,CAAC;AACtC,OAAO,EAEN,gBAAgB,GAEhB,MAAM,iBAAiB,CAAC;AAEzB,MAAM,CAAC,MAAM,iBAAiB,GAAG,CAAC,CAAC,MAAM,CAAC;IACzC,IAAI,EAAE,CAAC,CAAC,UAAU,CAAC,gBAAgB,CAAC;IACpC,WAAW,EAAE,iBAAiB,CAAC,QAAQ,EAAE;IACzC,WAAW,EAAE,CAAC,CAAC,MAAM,CAAC,MAAM,EAAE,CAAC,QAAQ,EAAE;IAEzC,iBAAiB,EAAE,CAAC,CAAC,MAAM,CAAC,MAAM,EAAE,CAAC,QAAQ,EAAE;IAE/C,cAAc,EAAE,CAAC,CAAC,MAAM,CAAC,MAAM,EAAE,CAAC,QAAQ,EAAE;IAE5C,aAAa,EAAE,CAAC,CAAC,MAAM,CAAC,MAAM,EAAE,CAAC,QAAQ,EAAE;IAE3C,mBAAmB,EAAE,CAAC,CAAC,MAAM,CAAC,MAAM,EAAE,CAAC,QAAQ,EAAE;IAEjD,iBAAiB,EAAE,CAAC,CAAC,MAAM,CAAC,MAAM,EAAE,CAAC,QAAQ,EAAE;CACf,CAAiC,CAAC;AAEnE,MAAM,CAAC,MAAM,gBAAgB,GAAG,CAAC,CAAC,MAAM,CAAC;IACxC,QAAQ,EAAE,CAAC,CAAC,MAAM,CAAC,MAAM,EAAE,CAAC,QAAQ,EAAE;CACP,CAAgC,CAAC"}
@@ -0,0 +1,145 @@
1
+ import { type ZodType, z } from "zod";
2
+ import type { AccessPolicy, AccessRule, PolicyScope } from "#policy/rule.js";
3
+ import { type AccessRulesFilter, FilterScopeMatch } from "#policy/rulesStorage.js";
4
+ import { type UserScopeInput } from "./userScopeInput.js";
5
+ type RuleGroupInput = {
6
+ groupId?: string;
7
+ ruleGroupId?: string;
8
+ };
9
+ export type AccessRuleInput = AccessPolicy & PolicyScope & UserScopeInput & RuleGroupInput;
10
+ export declare const accessRuleInput: ZodType<AccessRule>;
11
+ export declare const ruleEntryInput: z.ZodObject<{
12
+ rule: ZodType<AccessRule, z.ZodTypeDef, AccessRule>;
13
+ expiresUnixTimestamp: z.ZodOptional<z.ZodNumber>;
14
+ }, "strip", z.ZodTypeAny, {
15
+ rule: AccessPolicy & PolicyScope & import("#policy/rule.js").UserAttributes & import("#policy/rule.js").UserIp & {
16
+ groupId?: string;
17
+ };
18
+ expiresUnixTimestamp?: number | undefined;
19
+ }, {
20
+ rule: AccessPolicy & PolicyScope & import("#policy/rule.js").UserAttributes & import("#policy/rule.js").UserIp & {
21
+ groupId?: string;
22
+ };
23
+ expiresUnixTimestamp?: number | undefined;
24
+ }>;
25
+ export type AccessRulesFilterInput = AccessRulesFilter & {
26
+ userScope?: UserScopeInput;
27
+ policyScopes?: PolicyScope[];
28
+ };
29
+ export declare const accessRulesFilterInput: z.ZodObject<{
30
+ policyScope: z.ZodOptional<z.ZodObject<{
31
+ clientId: z.ZodOptional<z.ZodString>;
32
+ }, "strip", z.ZodTypeAny, {
33
+ clientId?: string | undefined;
34
+ }, {
35
+ clientId?: string | undefined;
36
+ }>>;
37
+ policyScopes: z.ZodOptional<z.ZodArray<z.ZodObject<{
38
+ clientId: z.ZodOptional<z.ZodString>;
39
+ }, "strip", z.ZodTypeAny, {
40
+ clientId?: string | undefined;
41
+ }, {
42
+ clientId?: string | undefined;
43
+ }>, "many">>;
44
+ policyScopeMatch: z.ZodDefault<z.ZodNativeEnum<typeof FilterScopeMatch>>;
45
+ userScope: z.ZodOptional<z.ZodEffects<z.ZodIntersection<z.ZodIntersection<z.ZodObject<{}, "strip", z.ZodTypeAny, {}, {}>, z.ZodEffects<z.ZodObject<{
46
+ ip: z.ZodOptional<z.ZodString>;
47
+ ipMask: z.ZodOptional<z.ZodString>;
48
+ numericIp: z.ZodOptional<z.ZodBigInt>;
49
+ numericIpMaskMin: z.ZodOptional<z.ZodBigInt>;
50
+ numericIpMaskMax: z.ZodOptional<z.ZodBigInt>;
51
+ }, "strip", z.ZodTypeAny, {
52
+ ip?: string | undefined;
53
+ ipMask?: string | undefined;
54
+ numericIp?: bigint | undefined;
55
+ numericIpMaskMin?: bigint | undefined;
56
+ numericIpMaskMax?: bigint | undefined;
57
+ }, {
58
+ ip?: string | undefined;
59
+ ipMask?: string | undefined;
60
+ numericIp?: bigint | undefined;
61
+ numericIpMaskMin?: bigint | undefined;
62
+ numericIpMaskMax?: bigint | undefined;
63
+ }>, import("#policy/rule.js").UserIp, {
64
+ ip?: string | undefined;
65
+ ipMask?: string | undefined;
66
+ numericIp?: bigint | undefined;
67
+ numericIpMaskMin?: bigint | undefined;
68
+ numericIpMaskMax?: bigint | undefined;
69
+ }>>, z.ZodEffects<z.ZodObject<{
70
+ userAgent: z.ZodOptional<z.ZodString>;
71
+ userId: z.ZodOptional<z.ZodString>;
72
+ ja4Hash: z.ZodOptional<z.ZodString>;
73
+ headersHash: z.ZodOptional<z.ZodString>;
74
+ userAgentHash: z.ZodOptional<z.ZodString>;
75
+ }, "strip", z.ZodTypeAny, {
76
+ userAgentHash?: string | undefined;
77
+ userId?: string | undefined;
78
+ ja4Hash?: string | undefined;
79
+ headersHash?: string | undefined;
80
+ userAgent?: string | undefined;
81
+ }, {
82
+ userAgentHash?: string | undefined;
83
+ userId?: string | undefined;
84
+ ja4Hash?: string | undefined;
85
+ headersHash?: string | undefined;
86
+ userAgent?: string | undefined;
87
+ }>, import("#policy/rule.js").UserAttributes, {
88
+ userAgentHash?: string | undefined;
89
+ userId?: string | undefined;
90
+ ja4Hash?: string | undefined;
91
+ headersHash?: string | undefined;
92
+ userAgent?: string | undefined;
93
+ }>>, UserScopeInput, {} & {
94
+ ip?: string | undefined;
95
+ ipMask?: string | undefined;
96
+ numericIp?: bigint | undefined;
97
+ numericIpMaskMin?: bigint | undefined;
98
+ numericIpMaskMax?: bigint | undefined;
99
+ } & {
100
+ userAgentHash?: string | undefined;
101
+ userId?: string | undefined;
102
+ ja4Hash?: string | undefined;
103
+ headersHash?: string | undefined;
104
+ userAgent?: string | undefined;
105
+ }>>;
106
+ userScopeMatch: z.ZodDefault<z.ZodNativeEnum<typeof FilterScopeMatch>>;
107
+ groupId: z.ZodOptional<z.ZodString>;
108
+ }, "strip", z.ZodTypeAny, {
109
+ policyScopeMatch: FilterScopeMatch;
110
+ userScopeMatch: FilterScopeMatch;
111
+ userScope?: UserScopeInput | undefined;
112
+ groupId?: string | undefined;
113
+ policyScope?: {
114
+ clientId?: string | undefined;
115
+ } | undefined;
116
+ policyScopes?: {
117
+ clientId?: string | undefined;
118
+ }[] | undefined;
119
+ }, {
120
+ userScope?: ({} & {
121
+ ip?: string | undefined;
122
+ ipMask?: string | undefined;
123
+ numericIp?: bigint | undefined;
124
+ numericIpMaskMin?: bigint | undefined;
125
+ numericIpMaskMax?: bigint | undefined;
126
+ } & {
127
+ userAgentHash?: string | undefined;
128
+ userId?: string | undefined;
129
+ ja4Hash?: string | undefined;
130
+ headersHash?: string | undefined;
131
+ userAgent?: string | undefined;
132
+ }) | undefined;
133
+ groupId?: string | undefined;
134
+ policyScope?: {
135
+ clientId?: string | undefined;
136
+ } | undefined;
137
+ policyScopeMatch?: FilterScopeMatch | undefined;
138
+ userScopeMatch?: FilterScopeMatch | undefined;
139
+ policyScopes?: {
140
+ clientId?: string | undefined;
141
+ }[] | undefined;
142
+ }>;
143
+ export declare const getAccessRuleFiltersFromInput: (filterInput: AccessRulesFilterInput) => AccessRulesFilter[];
144
+ export {};
145
+ //# sourceMappingURL=ruleInput.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"ruleInput.d.ts","sourceRoot":"","sources":["../../src/ruleInput/ruleInput.ts"],"names":[],"mappings":"AAeA,OAAO,EAAE,KAAK,OAAO,EAAE,CAAC,EAAE,MAAM,KAAK,CAAC;AACtC,OAAO,KAAK,EAAE,YAAY,EAAE,UAAU,EAAE,WAAW,EAAE,MAAM,iBAAiB,CAAC;AAC7E,OAAO,EAEN,KAAK,iBAAiB,EACtB,gBAAgB,EAChB,MAAM,yBAAyB,CAAC;AAEjC,OAAO,EAAE,KAAK,cAAc,EAAkB,MAAM,qBAAqB,CAAC;AAE1E,KAAK,cAAc,GAAG;IACrB,OAAO,CAAC,EAAE,MAAM,CAAC;IACjB,WAAW,CAAC,EAAE,MAAM,CAAC;CACrB,CAAC;AAEF,MAAM,MAAM,eAAe,GAAG,YAAY,GACzC,WAAW,GACX,cAAc,GACd,cAAc,CAAC;AAiBhB,eAAO,MAAM,eAAe,EAAE,OAAO,CAAC,UAAU,CAQkB,CAAC;AAEnE,eAAO,MAAM,cAAc;;;;;;;;;;;;;EAG6C,CAAC;AAEzE,MAAM,MAAM,sBAAsB,GAAG,iBAAiB,GAAG;IACxD,SAAS,CAAC,EAAE,cAAc,CAAC;IAC3B,YAAY,CAAC,EAAE,WAAW,EAAE,CAAC;CAC7B,CAAC;AAEF,eAAO,MAAM,sBAAsB;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;EAWmD,CAAC;AAEvF,eAAO,MAAM,6BAA6B,gBAC5B,sBAAsB,KACjC,iBAAiB,EAiBnB,CAAC"}
@@ -0,0 +1,50 @@
1
+ import { z } from "zod";
2
+ import { FilterScopeMatch } from "../rulesStorage.js";
3
+ import { policyScopeInput, accessPolicyInput } from "./policyInput.js";
4
+ import { userScopeInput } from "./userScopeInput.js";
5
+ const ruleGroupInput = z.object({
6
+ groupId: z.coerce.string().optional(),
7
+ ruleGroupId: z.coerce.string().optional()
8
+ }).transform((ruleGroupInput2) => {
9
+ const { ruleGroupId, ...ruleGroup } = ruleGroupInput2;
10
+ if ("string" === typeof ruleGroupId) {
11
+ ruleGroup.groupId = ruleGroupId;
12
+ }
13
+ return ruleGroup;
14
+ });
15
+ const accessRuleInput = z.object({
16
+ ...accessPolicyInput.shape,
17
+ ...policyScopeInput.shape
18
+ }).and(userScopeInput).and(ruleGroupInput).transform((ruleInput) => ruleInput);
19
+ const ruleEntryInput = z.object({
20
+ rule: accessRuleInput,
21
+ expiresUnixTimestamp: z.coerce.number().optional()
22
+ });
23
+ const accessRulesFilterInput = z.object({
24
+ policyScope: policyScopeInput.optional(),
25
+ policyScopes: z.array(policyScopeInput).optional(),
26
+ policyScopeMatch: z.nativeEnum(FilterScopeMatch).default(FilterScopeMatch.Exact),
27
+ userScope: userScopeInput.optional(),
28
+ userScopeMatch: z.nativeEnum(FilterScopeMatch).default(FilterScopeMatch.Exact),
29
+ groupId: z.string().optional()
30
+ });
31
+ const getAccessRuleFiltersFromInput = (filterInput) => {
32
+ const { policyScopes, policyScope, ...filterBase } = filterInput;
33
+ const allPolicyScopes = policyScopes || [];
34
+ if (policyScope) {
35
+ allPolicyScopes.push(policyScope);
36
+ }
37
+ if (allPolicyScopes.length > 0) {
38
+ return allPolicyScopes.map((policyScope2) => ({
39
+ ...filterBase,
40
+ policyScope: policyScope2
41
+ }));
42
+ }
43
+ return [filterBase];
44
+ };
45
+ export {
46
+ accessRuleInput,
47
+ accessRulesFilterInput,
48
+ getAccessRuleFiltersFromInput,
49
+ ruleEntryInput
50
+ };
@@ -0,0 +1 @@
1
+ {"version":3,"file":"ruleInput.js","sourceRoot":"","sources":["../../src/ruleInput/ruleInput.ts"],"names":[],"mappings":"AAeA,OAAO,EAAgB,CAAC,EAAE,MAAM,KAAK,CAAC;AAEtC,OAAO,EAGN,gBAAgB,GAChB,MAAM,yBAAyB,CAAC;AACjC,OAAO,EAAE,iBAAiB,EAAE,gBAAgB,EAAE,MAAM,kBAAkB,CAAC;AACvE,OAAO,EAAuB,cAAc,EAAE,MAAM,qBAAqB,CAAC;AAY1E,MAAM,cAAc,GAAG,CAAC;KACtB,MAAM,CAAC;IACP,OAAO,EAAE,CAAC,CAAC,MAAM,CAAC,MAAM,EAAE,CAAC,QAAQ,EAAE;IACrC,WAAW,EAAE,CAAC,CAAC,MAAM,CAAC,MAAM,EAAE,CAAC,QAAQ,EAAE;CACP,CAAC;KACnC,SAAS,CAAC,CAAC,cAA8B,EAAE,EAAE;IAC7C,MAAM,EAAE,WAAW,EAAE,GAAG,SAAS,EAAE,GAAG,cAAc,CAAC;IAErD,IAAI,QAAQ,KAAK,OAAO,WAAW,EAAE,CAAC;QACrC,SAAS,CAAC,OAAO,GAAG,WAAW,CAAC;IACjC,CAAC;IAED,OAAO,SAAS,CAAC;AAClB,CAAC,CAAC,CAAC;AAEJ,MAAM,CAAC,MAAM,eAAe,GAAwB,CAAC;KACnD,MAAM,CAAC;IACP,GAAG,iBAAiB,CAAC,KAAK;IAC1B,GAAG,gBAAgB,CAAC,KAAK;CACzB,CAAC;KACD,GAAG,CAAC,cAAc,CAAC;KACnB,GAAG,CAAC,cAAc,CAAC;KAEnB,SAAS,CAAC,CAAC,SAA0B,EAAc,EAAE,CAAC,SAAS,CAAC,CAAC;AAEnE,MAAM,CAAC,MAAM,cAAc,GAAG,CAAC,CAAC,MAAM,CAAC;IACtC,IAAI,EAAE,eAAe;IACrB,oBAAoB,EAAE,CAAC,CAAC,MAAM,CAAC,MAAM,EAAE,CAAC,QAAQ,EAAE;CACf,CAAoC,CAAC;AAOzE,MAAM,CAAC,MAAM,sBAAsB,GAAG,CAAC,CAAC,MAAM,CAAC;IAC9C,WAAW,EAAE,gBAAgB,CAAC,QAAQ,EAAE;IACxC,YAAY,EAAE,CAAC,CAAC,KAAK,CAAC,gBAAgB,CAAC,CAAC,QAAQ,EAAE;IAClD,gBAAgB,EAAE,CAAC;SACjB,UAAU,CAAC,gBAAgB,CAAC;SAC5B,OAAO,CAAC,gBAAgB,CAAC,KAAK,CAAC;IACjC,SAAS,EAAE,cAAc,CAAC,QAAQ,EAAE;IACpC,cAAc,EAAE,CAAC;SACf,UAAU,CAAC,gBAAgB,CAAC;SAC5B,OAAO,CAAC,gBAAgB,CAAC,KAAK,CAAC;IACjC,OAAO,EAAE,CAAC,CAAC,MAAM,EAAE,CAAC,QAAQ,EAAE;CACY,CAA2C,CAAC;AAEvF,MAAM,CAAC,MAAM,6BAA6B,GAAG,CAC5C,WAAmC,EACb,EAAE;IACxB,MAAM,EAAE,YAAY,EAAE,WAAW,EAAE,GAAG,UAAU,EAAE,GAAG,WAAW,CAAC;IAEjE,MAAM,eAAe,GAAG,YAAY,IAAI,EAAE,CAAC;IAE3C,IAAI,WAAW,EAAE,CAAC;QACjB,eAAe,CAAC,IAAI,CAAC,WAAW,CAAC,CAAC;IACnC,CAAC;IAED,IAAI,eAAe,CAAC,MAAM,GAAG,CAAC,EAAE,CAAC;QAChC,OAAO,eAAe,CAAC,GAAG,CAAC,CAAC,WAAW,EAAE,EAAE,CAAC,CAAC;YAC5C,GAAG,UAAU;YACb,WAAW;SACX,CAAC,CAAC,CAAC;IACL,CAAC;IAED,OAAO,CAAC,UAAU,CAAC,CAAC;AACrB,CAAC,CAAC"}
@@ -0,0 +1,93 @@
1
+ import { z } from "zod";
2
+ import type { UserAttributes, UserIp } from "#policy/rule.js";
3
+ import type { UserAttributesRecord, UserIpRecord } from "#policy/ruleRecord.js";
4
+ export type UserAttributesInput = UserAttributes & UserAttributesRecord;
5
+ export type UserIpInput = UserIp & UserIpRecord;
6
+ export type UserScopeInput = UserAttributesInput & UserIpInput;
7
+ export declare const userScopeSchema: z.ZodObject<{
8
+ userId: z.ZodOptional<z.ZodString>;
9
+ ja4Hash: z.ZodOptional<z.ZodString>;
10
+ headersHash: z.ZodOptional<z.ZodString>;
11
+ userAgentHash: z.ZodOptional<z.ZodString>;
12
+ numericIp: z.ZodOptional<z.ZodBigInt>;
13
+ numericIpMaskMin: z.ZodOptional<z.ZodBigInt>;
14
+ numericIpMaskMax: z.ZodOptional<z.ZodBigInt>;
15
+ }, "strip", z.ZodTypeAny, {
16
+ userAgentHash?: string | undefined;
17
+ userId?: string | undefined;
18
+ ja4Hash?: string | undefined;
19
+ headersHash?: string | undefined;
20
+ numericIp?: bigint | undefined;
21
+ numericIpMaskMin?: bigint | undefined;
22
+ numericIpMaskMax?: bigint | undefined;
23
+ }, {
24
+ userAgentHash?: string | undefined;
25
+ userId?: string | undefined;
26
+ ja4Hash?: string | undefined;
27
+ headersHash?: string | undefined;
28
+ numericIp?: bigint | undefined;
29
+ numericIpMaskMin?: bigint | undefined;
30
+ numericIpMaskMax?: bigint | undefined;
31
+ }>;
32
+ export declare const userScopeInput: z.ZodEffects<z.ZodIntersection<z.ZodIntersection<z.ZodObject<{}, "strip", z.ZodTypeAny, {}, {}>, z.ZodEffects<z.ZodObject<{
33
+ ip: z.ZodOptional<z.ZodString>;
34
+ ipMask: z.ZodOptional<z.ZodString>;
35
+ numericIp: z.ZodOptional<z.ZodBigInt>;
36
+ numericIpMaskMin: z.ZodOptional<z.ZodBigInt>;
37
+ numericIpMaskMax: z.ZodOptional<z.ZodBigInt>;
38
+ }, "strip", z.ZodTypeAny, {
39
+ ip?: string | undefined;
40
+ ipMask?: string | undefined;
41
+ numericIp?: bigint | undefined;
42
+ numericIpMaskMin?: bigint | undefined;
43
+ numericIpMaskMax?: bigint | undefined;
44
+ }, {
45
+ ip?: string | undefined;
46
+ ipMask?: string | undefined;
47
+ numericIp?: bigint | undefined;
48
+ numericIpMaskMin?: bigint | undefined;
49
+ numericIpMaskMax?: bigint | undefined;
50
+ }>, UserIp, {
51
+ ip?: string | undefined;
52
+ ipMask?: string | undefined;
53
+ numericIp?: bigint | undefined;
54
+ numericIpMaskMin?: bigint | undefined;
55
+ numericIpMaskMax?: bigint | undefined;
56
+ }>>, z.ZodEffects<z.ZodObject<{
57
+ userAgent: z.ZodOptional<z.ZodString>;
58
+ userId: z.ZodOptional<z.ZodString>;
59
+ ja4Hash: z.ZodOptional<z.ZodString>;
60
+ headersHash: z.ZodOptional<z.ZodString>;
61
+ userAgentHash: z.ZodOptional<z.ZodString>;
62
+ }, "strip", z.ZodTypeAny, {
63
+ userAgentHash?: string | undefined;
64
+ userId?: string | undefined;
65
+ ja4Hash?: string | undefined;
66
+ headersHash?: string | undefined;
67
+ userAgent?: string | undefined;
68
+ }, {
69
+ userAgentHash?: string | undefined;
70
+ userId?: string | undefined;
71
+ ja4Hash?: string | undefined;
72
+ headersHash?: string | undefined;
73
+ userAgent?: string | undefined;
74
+ }>, UserAttributes, {
75
+ userAgentHash?: string | undefined;
76
+ userId?: string | undefined;
77
+ ja4Hash?: string | undefined;
78
+ headersHash?: string | undefined;
79
+ userAgent?: string | undefined;
80
+ }>>, UserScopeInput, {} & {
81
+ ip?: string | undefined;
82
+ ipMask?: string | undefined;
83
+ numericIp?: bigint | undefined;
84
+ numericIpMaskMin?: bigint | undefined;
85
+ numericIpMaskMax?: bigint | undefined;
86
+ } & {
87
+ userAgentHash?: string | undefined;
88
+ userId?: string | undefined;
89
+ ja4Hash?: string | undefined;
90
+ headersHash?: string | undefined;
91
+ userAgent?: string | undefined;
92
+ }>;
93
+ //# sourceMappingURL=userScopeInput.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"userScopeInput.d.ts","sourceRoot":"","sources":["../../src/ruleInput/userScopeInput.ts"],"names":[],"mappings":"AAkBA,OAAO,EAAgB,CAAC,EAAE,MAAM,KAAK,CAAC;AACtC,OAAO,KAAK,EAAE,cAAc,EAAE,MAAM,EAAa,MAAM,iBAAiB,CAAC;AACzE,OAAO,KAAK,EAAE,oBAAoB,EAAE,YAAY,EAAE,MAAM,uBAAuB,CAAC;AAEhF,MAAM,MAAM,mBAAmB,GAAG,cAAc,GAAG,oBAAoB,CAAC;AA6BxE,MAAM,MAAM,WAAW,GAAG,MAAM,GAAG,YAAY,CAAC;AAsChD,MAAM,MAAM,cAAc,GAAG,mBAAmB,GAAG,WAAW,CAAC;AAE/D,eAAO,MAAM,eAAe;;;;;;;;;;;;;;;;;;;;;;;;EAGgC,CAAC;AAE7D,eAAO,MAAM,cAAc;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;EAQzB,CAAC"}