@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.
- package/CHANGELOG.md +67 -0
- package/coverage/base.css +224 -0
- package/coverage/block-navigation.js +87 -0
- package/coverage/clover.xml +786 -0
- package/coverage/coverage-final.json +15 -0
- package/coverage/favicon.png +0 -0
- package/coverage/index.html +146 -0
- package/coverage/prettify.css +1 -0
- package/coverage/prettify.js +2 -0
- package/coverage/sort-arrow-sprite.png +0 -0
- package/coverage/sorter.js +210 -0
- package/coverage/src/accessPolicy.ts.html +457 -0
- package/coverage/src/accessPolicyResolver.ts.html +211 -0
- package/coverage/src/accessRules.ts.html +265 -0
- package/coverage/src/api/accessRuleApiRoutes.ts.html +379 -0
- package/coverage/src/api/accessRulesApiClient.ts.html +274 -0
- package/coverage/src/api/deleteAllRulesEndpoint.ts.html +229 -0
- package/coverage/src/api/deleteRulesEndpoint.ts.html +301 -0
- package/coverage/src/api/index.html +176 -0
- package/coverage/src/api/insertRulesEndpoint.ts.html +436 -0
- package/coverage/src/index.html +176 -0
- package/coverage/src/index.ts.html +277 -0
- package/coverage/src/redis/index.html +161 -0
- package/coverage/src/redis/redisRulesIndex.ts.html +769 -0
- package/coverage/src/redis/redisRulesReader.ts.html +652 -0
- package/coverage/src/redis/redisRulesStorage.ts.html +229 -0
- package/coverage/src/redis/redisRulesWriter.ts.html +424 -0
- package/coverage/src/util.ts.html +136 -0
- package/dist/.export.d.ts +6 -0
- package/dist/.export.d.ts.map +1 -0
- package/dist/.export.js +21 -0
- package/dist/.export.js.map +1 -0
- package/dist/accessPolicy.d.ts +169 -0
- package/dist/accessPolicy.d.ts.map +1 -0
- package/dist/accessPolicy.js.map +1 -0
- package/dist/accessPolicyResolver.d.ts +110 -0
- package/dist/accessPolicyResolver.d.ts.map +1 -0
- package/dist/accessPolicyResolver.js.map +1 -0
- package/dist/accessRules.d.ts +16 -0
- package/dist/accessRules.d.ts.map +1 -0
- package/dist/accessRules.js.map +1 -0
- package/dist/api/.export.d.ts +7 -0
- package/dist/api/.export.d.ts.map +1 -0
- package/dist/api/.export.js +11 -0
- package/dist/api/.export.js.map +1 -0
- package/dist/api/accessRuleApiRoutes.d.ts +27 -0
- package/dist/api/accessRuleApiRoutes.d.ts.map +1 -0
- package/dist/api/accessRuleApiRoutes.js.map +1 -0
- package/dist/api/accessRulesApiClient.d.ts +10 -0
- package/dist/api/accessRulesApiClient.d.ts.map +1 -0
- package/dist/api/accessRulesApiClient.js.map +1 -0
- package/dist/api/delete/.export.d.ts +2 -0
- package/dist/api/delete/.export.d.ts.map +1 -0
- package/dist/api/delete/.export.js +1 -0
- package/dist/api/delete/.export.js.map +1 -0
- package/dist/api/delete/deleteAllRules.d.ts +11 -0
- package/dist/api/delete/deleteAllRules.d.ts.map +1 -0
- package/dist/api/delete/deleteAllRules.js +25 -0
- package/dist/api/delete/deleteAllRules.js.map +1 -0
- package/dist/api/delete/deleteRuleGroups.d.ts +19 -0
- package/dist/api/delete/deleteRuleGroups.d.ts.map +1 -0
- package/dist/api/delete/deleteRuleGroups.js +52 -0
- package/dist/api/delete/deleteRuleGroups.js.map +1 -0
- package/dist/api/delete/deleteRules.d.ts +15 -0
- package/dist/api/delete/deleteRules.d.ts.map +1 -0
- package/dist/api/delete/deleteRules.js +43 -0
- package/dist/api/delete/deleteRules.js.map +1 -0
- package/dist/api/deleteAllRulesEndpoint.d.ts +12 -0
- package/dist/api/deleteAllRulesEndpoint.d.ts.map +1 -0
- package/dist/api/deleteAllRulesEndpoint.js.map +1 -0
- package/dist/api/deleteRulesEndpoint.d.ts +116 -0
- package/dist/api/deleteRulesEndpoint.d.ts.map +1 -0
- package/dist/api/deleteRulesEndpoint.js.map +1 -0
- package/dist/api/insertRulesEndpoint.d.ts +22 -0
- package/dist/api/insertRulesEndpoint.d.ts.map +1 -0
- package/dist/api/insertRulesEndpoint.js.map +1 -0
- package/dist/api/read/.export.d.ts +4 -0
- package/dist/api/read/.export.d.ts.map +1 -0
- package/dist/api/read/.export.js +1 -0
- package/dist/api/read/.export.js.map +1 -0
- package/dist/api/read/fetchRules.d.ts +53 -0
- package/dist/api/read/fetchRules.d.ts.map +1 -0
- package/dist/api/read/fetchRules.js +43 -0
- package/dist/api/read/fetchRules.js.map +1 -0
- package/dist/api/read/findRuleIds.d.ts +28 -0
- package/dist/api/read/findRuleIds.d.ts.map +1 -0
- package/dist/api/read/findRuleIds.js +50 -0
- package/dist/api/read/findRuleIds.js.map +1 -0
- package/dist/api/read/getMissingIds.d.ts +28 -0
- package/dist/api/read/getMissingIds.d.ts.map +1 -0
- package/dist/api/read/getMissingIds.js +41 -0
- package/dist/api/read/getMissingIds.js.map +1 -0
- package/dist/api/ruleApiRoutes.d.ts +43 -0
- package/dist/api/ruleApiRoutes.d.ts.map +1 -0
- package/dist/api/ruleApiRoutes.js +131 -0
- package/dist/api/ruleApiRoutes.js.map +1 -0
- package/dist/api/rulesApiClient.d.ts +20 -0
- package/dist/api/rulesApiClient.d.ts.map +1 -0
- package/dist/api/rulesApiClient.js +93 -0
- package/dist/api/rulesApiClient.js.map +1 -0
- package/dist/api/write/.export.d.ts +2 -0
- package/dist/api/write/.export.d.ts.map +1 -0
- package/dist/api/write/.export.js +1 -0
- package/dist/api/write/.export.js.map +1 -0
- package/dist/api/write/insertRules.d.ts +29 -0
- package/dist/api/write/insertRules.d.ts.map +1 -0
- package/dist/api/write/insertRules.js +102 -0
- package/dist/api/write/insertRules.js.map +1 -0
- package/dist/api/write/rehashRules.d.ts +11 -0
- package/dist/api/write/rehashRules.d.ts.map +1 -0
- package/dist/api/write/rehashRules.js +57 -0
- package/dist/api/write/rehashRules.js.map +1 -0
- package/dist/cjs/.export.cjs +21 -0
- package/dist/cjs/api/.export.cjs +11 -0
- package/dist/cjs/api/delete/.export.cjs +1 -0
- package/dist/cjs/api/delete/deleteAllRules.cjs +25 -0
- package/dist/cjs/api/delete/deleteRuleGroups.cjs +52 -0
- package/dist/cjs/api/delete/deleteRules.cjs +43 -0
- package/dist/cjs/api/read/.export.cjs +1 -0
- package/dist/cjs/api/read/fetchRules.cjs +43 -0
- package/dist/cjs/api/read/findRuleIds.cjs +50 -0
- package/dist/cjs/api/read/getMissingIds.cjs +41 -0
- package/dist/cjs/api/ruleApiRoutes.cjs +131 -0
- package/dist/cjs/api/rulesApiClient.cjs +93 -0
- package/dist/cjs/api/write/.export.cjs +1 -0
- package/dist/cjs/api/write/insertRules.cjs +102 -0
- package/dist/cjs/api/write/rehashRules.cjs +57 -0
- package/dist/cjs/index.cjs +4 -6
- package/dist/cjs/mongoose/.export.cjs +4 -0
- package/dist/cjs/mongoose/mongooseRuleSchema.cjs +36 -0
- package/dist/cjs/redis/.export.cjs +6 -0
- package/dist/cjs/redis/reader/redisAggregate.cjs +60 -0
- package/dist/cjs/redis/reader/redisRulesQuery.cjs +99 -0
- package/dist/cjs/redis/reader/redisRulesReader.cjs +230 -0
- package/dist/cjs/redis/{redisRulesReader.cjs → redisAccessRules.cjs} +38 -28
- package/dist/cjs/redis/{redisRulesIndex.cjs → redisAccessRulesIndex.cjs} +45 -12
- package/dist/cjs/redis/redisClient.cjs +67 -0
- package/dist/cjs/redis/redisIndex.cjs +22 -0
- package/dist/cjs/redis/redisRuleIndex.cjs +50 -0
- package/dist/cjs/redis/redisRulesStorage.cjs +22 -9
- package/dist/cjs/redis/redisRulesWriter.cjs +91 -64
- package/dist/cjs/rule.cjs +8 -0
- package/dist/cjs/ruleInput/.export.cjs +9 -0
- package/dist/cjs/ruleInput/policyInput.cjs +25 -0
- package/dist/cjs/ruleInput/ruleInput.cjs +50 -0
- package/dist/cjs/ruleInput/userScopeInput.cjs +55 -0
- package/dist/cjs/ruleRecord.cjs +23 -0
- package/dist/cjs/rulesStorage.cjs +8 -0
- package/dist/cjs/transformRule.cjs +77 -0
- package/dist/index.d.ts +15 -0
- package/dist/index.d.ts.map +1 -0
- package/dist/index.js.map +1 -0
- package/dist/mongoose/.export.d.ts +2 -0
- package/dist/mongoose/.export.d.ts.map +1 -0
- package/dist/mongoose/.export.js +4 -0
- package/dist/mongoose/.export.js.map +1 -0
- package/dist/mongoose/mongooseRuleSchema.d.ts +4 -0
- package/dist/mongoose/mongooseRuleSchema.d.ts.map +1 -0
- package/dist/mongoose/mongooseRuleSchema.js +36 -0
- package/dist/mongoose/mongooseRuleSchema.js.map +1 -0
- package/dist/redis/.export.d.ts +3 -0
- package/dist/redis/.export.d.ts.map +1 -0
- package/dist/redis/.export.js +6 -0
- package/dist/redis/.export.js.map +1 -0
- package/dist/redis/reader/redisAggregate.d.ts +4 -0
- package/dist/redis/reader/redisAggregate.d.ts.map +1 -0
- package/dist/redis/reader/redisAggregate.js +60 -0
- package/dist/redis/reader/redisAggregate.js.map +1 -0
- package/dist/redis/reader/redisRulesQuery.d.ts +4 -0
- package/dist/redis/reader/redisRulesQuery.d.ts.map +1 -0
- package/dist/redis/reader/redisRulesQuery.js +99 -0
- package/dist/redis/reader/redisRulesQuery.js.map +1 -0
- package/dist/redis/reader/redisRulesReader.d.ts +26 -0
- package/dist/redis/reader/redisRulesReader.d.ts.map +1 -0
- package/dist/redis/reader/redisRulesReader.js +213 -0
- package/dist/redis/reader/redisRulesReader.js.map +1 -0
- package/dist/redis/redisAccessRules.d.ts +7 -0
- package/dist/redis/redisAccessRules.d.ts.map +1 -0
- package/dist/redis/redisAccessRules.js +119 -0
- package/dist/redis/redisAccessRules.js.map +1 -0
- package/dist/redis/redisAccessRulesIndex.d.ts +13 -0
- package/dist/redis/redisAccessRulesIndex.d.ts.map +1 -0
- package/dist/redis/redisAccessRulesIndex.js +140 -0
- package/dist/redis/redisAccessRulesIndex.js.map +1 -0
- package/dist/redis/redisClient.d.ts +11 -0
- package/dist/redis/redisClient.d.ts.map +1 -0
- package/dist/redis/redisClient.js +67 -0
- package/dist/redis/redisClient.js.map +1 -0
- package/dist/redis/redisIndex.d.ts +9 -0
- package/dist/redis/redisIndex.d.ts.map +1 -0
- package/dist/redis/redisIndex.js +23 -0
- package/dist/redis/redisIndex.js.map +1 -0
- package/dist/redis/redisRuleIndex.d.ts +13 -0
- package/dist/redis/redisRuleIndex.d.ts.map +1 -0
- package/dist/redis/redisRuleIndex.js +50 -0
- package/dist/redis/redisRuleIndex.js.map +1 -0
- package/dist/redis/redisRulesIndex.d.ts +9 -0
- package/dist/redis/redisRulesIndex.d.ts.map +1 -0
- package/dist/redis/redisRulesIndex.js.map +1 -0
- package/dist/redis/redisRulesReader.d.ts +6 -0
- package/dist/redis/redisRulesReader.d.ts.map +1 -0
- package/dist/redis/redisRulesReader.js.map +1 -0
- package/dist/redis/redisRulesStorage.d.ts +5 -0
- package/dist/redis/redisRulesStorage.d.ts.map +1 -0
- package/dist/redis/redisRulesStorage.js +23 -10
- package/dist/redis/redisRulesStorage.js.map +1 -0
- package/dist/redis/redisRulesWriter.d.ts +22 -0
- package/dist/redis/redisRulesWriter.d.ts.map +1 -0
- package/dist/redis/redisRulesWriter.js +91 -64
- package/dist/redis/redisRulesWriter.js.map +1 -0
- package/dist/rule.d.ts +34 -0
- package/dist/rule.d.ts.map +1 -0
- package/dist/rule.js +8 -0
- package/dist/rule.js.map +1 -0
- package/dist/ruleInput/.export.d.ts +4 -0
- package/dist/ruleInput/.export.d.ts.map +1 -0
- package/dist/ruleInput/.export.js +9 -0
- package/dist/ruleInput/.export.js.map +1 -0
- package/dist/ruleInput/policyInput.d.ts +38 -0
- package/dist/ruleInput/policyInput.d.ts.map +1 -0
- package/dist/ruleInput/policyInput.js +25 -0
- package/dist/ruleInput/policyInput.js.map +1 -0
- package/dist/ruleInput/ruleInput.d.ts +145 -0
- package/dist/ruleInput/ruleInput.d.ts.map +1 -0
- package/dist/ruleInput/ruleInput.js +50 -0
- package/dist/ruleInput/ruleInput.js.map +1 -0
- package/dist/ruleInput/userScopeInput.d.ts +93 -0
- package/dist/ruleInput/userScopeInput.d.ts.map +1 -0
- package/dist/ruleInput/userScopeInput.js +55 -0
- package/dist/ruleInput/userScopeInput.js.map +1 -0
- package/dist/ruleRecord.d.ts +18 -0
- package/dist/ruleRecord.d.ts.map +1 -0
- package/dist/ruleRecord.js +23 -0
- package/dist/ruleRecord.js.map +1 -0
- package/dist/rulesStorage.d.ts +30 -0
- package/dist/rulesStorage.d.ts.map +1 -0
- package/dist/rulesStorage.js +8 -0
- package/dist/rulesStorage.js.map +1 -0
- package/dist/tests/accessPolicy.test.d.ts +2 -0
- package/dist/tests/accessPolicy.test.d.ts.map +1 -0
- package/dist/tests/accessPolicy.test.js +27 -0
- package/dist/tests/accessPolicy.test.js.map +1 -0
- package/dist/tests/redis/reader/redisRulesQuery.unit.test.d.ts +2 -0
- package/dist/tests/redis/reader/redisRulesQuery.unit.test.d.ts.map +1 -0
- package/dist/tests/redis/reader/redisRulesQuery.unit.test.js +101 -0
- package/dist/tests/redis/reader/redisRulesQuery.unit.test.js.map +1 -0
- package/dist/tests/redis/redisAccessRules.integration.test.d.ts +2 -0
- package/dist/tests/redis/redisAccessRules.integration.test.d.ts.map +1 -0
- package/dist/tests/redis/redisAccessRules.integration.test.js +586 -0
- package/dist/tests/redis/redisAccessRules.integration.test.js.map +1 -0
- package/dist/tests/redis/redisAccessRules.unit.test.d.ts +2 -0
- package/dist/tests/redis/redisAccessRules.unit.test.d.ts.map +1 -0
- package/dist/tests/redis/redisAccessRules.unit.test.js +198 -0
- package/dist/tests/redis/redisAccessRules.unit.test.js.map +1 -0
- package/dist/tests/redis/redisIndex.integration.test.d.ts +2 -0
- package/dist/tests/redis/redisIndex.integration.test.d.ts.map +1 -0
- package/dist/tests/redis/redisIndex.integration.test.js +80 -0
- package/dist/tests/redis/redisIndex.integration.test.js.map +1 -0
- package/dist/tests/redis/redisRulesIndex.unit.test.d.ts +2 -0
- package/dist/tests/redis/redisRulesIndex.unit.test.d.ts.map +1 -0
- package/dist/tests/redis/redisRulesIndex.unit.test.js +101 -0
- package/dist/tests/redis/redisRulesIndex.unit.test.js.map +1 -0
- package/dist/tests/redis/redisRulesStorage.integration.test.d.ts +2 -0
- package/dist/tests/redis/redisRulesStorage.integration.test.d.ts.map +1 -0
- package/dist/tests/redis/redisRulesStorage.integration.test.js +611 -0
- package/dist/tests/redis/redisRulesStorage.integration.test.js.map +1 -0
- package/dist/tests/redis/testRedisClient.d.ts +3 -0
- package/dist/tests/redis/testRedisClient.d.ts.map +1 -0
- package/dist/tests/redis/testRedisClient.js +8 -0
- package/dist/tests/redis/testRedisClient.js.map +1 -0
- package/dist/tests/testLogger.d.ts +4 -0
- package/dist/tests/testLogger.d.ts.map +1 -0
- package/dist/tests/testLogger.js +22 -0
- package/dist/tests/testLogger.js.map +1 -0
- package/dist/tests/transformRule.unit.test.d.ts +2 -0
- package/dist/tests/transformRule.unit.test.d.ts.map +1 -0
- package/dist/tests/transformRule.unit.test.js +188 -0
- package/dist/tests/transformRule.unit.test.js.map +1 -0
- package/dist/transformRule.d.ts +7 -0
- package/dist/transformRule.d.ts.map +1 -0
- package/dist/transformRule.js +77 -0
- package/dist/transformRule.js.map +1 -0
- package/dist/util.d.ts +2 -0
- package/dist/util.d.ts.map +1 -0
- package/dist/util.js.map +1 -0
- package/entries.ts +20 -0
- package/package.json +34 -18
- package/vite.cjs.config.ts +4 -1
- package/vite.esm.config.ts +6 -1
- package/dist/cjs/api/accessRulesApiClient.cjs +0 -38
|
@@ -1,73 +1,100 @@
|
|
|
1
|
-
import
|
|
2
|
-
import {
|
|
3
|
-
|
|
4
|
-
|
|
5
|
-
|
|
6
|
-
|
|
7
|
-
|
|
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
|
-
|
|
10
|
-
if (
|
|
11
|
-
|
|
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
|
-
|
|
22
|
-
|
|
23
|
-
|
|
24
|
-
|
|
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
|
-
|
|
70
|
-
|
|
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
package/dist/rule.js.map
ADDED
|
@@ -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 @@
|
|
|
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"}
|