@prosopo/user-access-policy 3.4.0 → 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 +309 -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 +38 -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 +2 -0
- 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/redisAccessRules.cjs +4 -4
- package/dist/cjs/redis/redisAccessRulesIndex.cjs +55 -14
- package/dist/cjs/redis/redisClient.cjs +67 -0
- package/dist/cjs/redis/redisRuleIndex.cjs +50 -0
- package/dist/cjs/redis/redisRulesStorage.cjs +34 -0
- package/dist/cjs/redis/redisRulesWriter.cjs +100 -0
- 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 +7 -3
- 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 +112 -128
- 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 +122 -112
- 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 +16 -15
- 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 +138 -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 +125 -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 +34 -0
- 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 +100 -0
- 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 +42 -21
- package/vite.cjs.config.ts +4 -1
- package/vite.esm.config.ts +6 -1
|
@@ -0,0 +1,43 @@
|
|
|
1
|
+
import { ApiEndpointResponseStatus } from "@prosopo/api-route";
|
|
2
|
+
import { executeBatchesSequentially } from "@prosopo/common";
|
|
3
|
+
import { z } from "zod";
|
|
4
|
+
import { accessRulesFilterInput, getAccessRuleFiltersFromInput } from "../../ruleInput/ruleInput.js";
|
|
5
|
+
class DeleteRulesEndpoint {
|
|
6
|
+
constructor(accessRulesStorage, logger) {
|
|
7
|
+
this.accessRulesStorage = accessRulesStorage;
|
|
8
|
+
this.logger = logger;
|
|
9
|
+
}
|
|
10
|
+
getRequestArgsSchema() {
|
|
11
|
+
return z.array(accessRulesFilterInput);
|
|
12
|
+
}
|
|
13
|
+
async processRequest(args) {
|
|
14
|
+
let deletedCount = 0;
|
|
15
|
+
for (const rulesFilterInput of args) {
|
|
16
|
+
const ruleFilters = getAccessRuleFiltersFromInput(rulesFilterInput);
|
|
17
|
+
await executeBatchesSequentially(ruleFilters, async (ruleFilter) => {
|
|
18
|
+
const ruleIds = await this.accessRulesStorage.findRuleIds(ruleFilter);
|
|
19
|
+
const uniqueRuleIds = [...new Set(ruleIds)];
|
|
20
|
+
if (uniqueRuleIds.length > 0) {
|
|
21
|
+
await this.accessRulesStorage.deleteRules(uniqueRuleIds);
|
|
22
|
+
deletedCount += uniqueRuleIds.length;
|
|
23
|
+
this.logger.info(() => ({
|
|
24
|
+
msg: "Endpoint deleted rules",
|
|
25
|
+
data: {
|
|
26
|
+
rulesFilterInput,
|
|
27
|
+
uniqueRuleIds
|
|
28
|
+
}
|
|
29
|
+
}));
|
|
30
|
+
}
|
|
31
|
+
});
|
|
32
|
+
}
|
|
33
|
+
return {
|
|
34
|
+
status: ApiEndpointResponseStatus.SUCCESS,
|
|
35
|
+
data: {
|
|
36
|
+
deleted_count: deletedCount
|
|
37
|
+
}
|
|
38
|
+
};
|
|
39
|
+
}
|
|
40
|
+
}
|
|
41
|
+
export {
|
|
42
|
+
DeleteRulesEndpoint
|
|
43
|
+
};
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"deleteRules.js","sourceRoot":"","sources":["../../../src/api/delete/deleteRules.ts"],"names":[],"mappings":"AAcA,OAAO,EAGN,yBAAyB,GACzB,MAAM,oBAAoB,CAAC;AAC5B,OAAO,EAAe,0BAA0B,EAAE,MAAM,iBAAiB,CAAC;AAC1E,OAAO,EAAgB,CAAC,EAAE,MAAM,KAAK,CAAC;AACtC,OAAO,EAEN,sBAAsB,EACtB,6BAA6B,GAC7B,MAAM,gCAAgC,CAAC;AAKxC,MAAM,OAAO,mBAAmB;IAC/B,YACkB,kBAAsC,EACtC,MAAc;QADd,uBAAkB,GAAlB,kBAAkB,CAAoB;QACtC,WAAM,GAAN,MAAM,CAAQ;IAC7B,CAAC;IAEG,oBAAoB;QAC1B,OAAO,CAAC,CAAC,KAAK,CAAC,sBAAsB,CAAC,CAAC;IACxC,CAAC;IAED,KAAK,CAAC,cAAc,CACnB,IAA8B;QAE9B,IAAI,YAAY,GAAG,CAAC,CAAC;QAErB,KAAK,MAAM,gBAAgB,IAAI,IAAI,EAAE,CAAC;YACrC,MAAM,WAAW,GAAG,6BAA6B,CAAC,gBAAgB,CAAC,CAAC;YAEpE,MAAM,0BAA0B,CAAC,WAAW,EAAE,KAAK,EAAE,UAAU,EAAE,EAAE;gBAClE,MAAM,OAAO,GAAG,MAAM,IAAI,CAAC,kBAAkB,CAAC,WAAW,CAAC,UAAU,CAAC,CAAC;gBAGtE,MAAM,aAAa,GAAG,CAAC,GAAG,IAAI,GAAG,CAAC,OAAO,CAAC,CAAC,CAAC;gBAE5C,IAAI,aAAa,CAAC,MAAM,GAAG,CAAC,EAAE,CAAC;oBAC9B,MAAM,IAAI,CAAC,kBAAkB,CAAC,WAAW,CAAC,aAAa,CAAC,CAAC;oBAEzD,YAAY,IAAI,aAAa,CAAC,MAAM,CAAC;oBAErC,IAAI,CAAC,MAAM,CAAC,IAAI,CAAC,GAAG,EAAE,CAAC,CAAC;wBACvB,GAAG,EAAE,wBAAwB;wBAC7B,IAAI,EAAE;4BACL,gBAAgB;4BAChB,aAAa;yBACb;qBACD,CAAC,CAAC,CAAC;gBACL,CAAC;YACF,CAAC,CAAC,CAAC;QACJ,CAAC;QAED,OAAO;YACN,MAAM,EAAE,yBAAyB,CAAC,OAAO;YACzC,IAAI,EAAE;gBACL,aAAa,EAAE,YAAY;aAC3B;SACD,CAAC;IACH,CAAC;CACD"}
|
|
@@ -0,0 +1,12 @@
|
|
|
1
|
+
import { type ApiEndpoint, type ApiEndpointResponse } from "@prosopo/api-route";
|
|
2
|
+
import { z } from "zod";
|
|
3
|
+
import type { AccessRulesStorage } from "#policy/accessRules.js";
|
|
4
|
+
export declare const deleteAllRulesEndpointSchema: z.ZodObject<{}, "strip", z.ZodTypeAny, {}, {}>;
|
|
5
|
+
export type DeleteAllRulesEndpointSchema = typeof deleteAllRulesEndpointSchema;
|
|
6
|
+
export declare class DeleteAllRulesEndpoint implements ApiEndpoint<DeleteAllRulesEndpointSchema> {
|
|
7
|
+
private readonly accessRulesStorage;
|
|
8
|
+
constructor(accessRulesStorage: AccessRulesStorage);
|
|
9
|
+
processRequest(args: z.infer<DeleteAllRulesEndpointSchema>): Promise<ApiEndpointResponse>;
|
|
10
|
+
getRequestArgsSchema(): DeleteAllRulesEndpointSchema;
|
|
11
|
+
}
|
|
12
|
+
//# sourceMappingURL=deleteAllRulesEndpoint.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"deleteAllRulesEndpoint.d.ts","sourceRoot":"","sources":["../../src/api/deleteAllRulesEndpoint.ts"],"names":[],"mappings":"AAcA,OAAO,EACN,KAAK,WAAW,EAChB,KAAK,mBAAmB,EAExB,MAAM,oBAAoB,CAAC;AAC5B,OAAO,EAAE,CAAC,EAAE,MAAM,KAAK,CAAC;AACxB,OAAO,KAAK,EAAE,kBAAkB,EAAE,MAAM,wBAAwB,CAAC;AAEjE,eAAO,MAAM,4BAA4B,gDAAe,CAAC;AAEzD,MAAM,MAAM,4BAA4B,GAAG,OAAO,4BAA4B,CAAC;AAE/E,qBAAa,sBACZ,YAAW,WAAW,CAAC,4BAA4B,CAAC;IAEjC,OAAO,CAAC,QAAQ,CAAC,kBAAkB;gBAAlB,kBAAkB,EAAE,kBAAkB;IAEpE,cAAc,CACnB,IAAI,EAAE,CAAC,CAAC,KAAK,CAAC,4BAA4B,CAAC,GACzC,OAAO,CAAC,mBAAmB,CAAC;IAW/B,oBAAoB,IAAI,4BAA4B;CAGpD"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"deleteAllRulesEndpoint.js","sourceRoot":"","sources":["../../src/api/deleteAllRulesEndpoint.ts"],"names":[],"mappings":"AAcA,OAAO,EAGN,yBAAyB,GACzB,MAAM,oBAAoB,CAAC;AAC5B,OAAO,EAAE,CAAC,EAAE,MAAM,KAAK,CAAC;AAGxB,MAAM,CAAC,MAAM,4BAA4B,GAAG,CAAC,CAAC,MAAM,CAAC,EAAE,CAAC,CAAC;AAIzD,MAAM,OAAO,sBAAsB;IAGlC,YAAoC,kBAAsC;QAAtC,uBAAkB,GAAlB,kBAAkB,CAAoB;IAAG,CAAC;IAE9E,KAAK,CAAC,cAAc,CACnB,IAA2C;QAE3C,MAAM,YAAY,GAAG,MAAM,IAAI,CAAC,kBAAkB,CAAC,cAAc,EAAE,CAAC;QAEpE,OAAO;YACN,MAAM,EAAE,yBAAyB,CAAC,OAAO;YACzC,IAAI,EAAE;gBACL,aAAa,EAAE,YAAY;aAC3B;SACD,CAAC;IACH,CAAC;IAED,oBAAoB;QACnB,OAAO,4BAA4B,CAAC;IACrC,CAAC;CACD"}
|
|
@@ -0,0 +1,116 @@
|
|
|
1
|
+
import { type ApiEndpoint, type ApiEndpointResponse } from "@prosopo/api-route";
|
|
2
|
+
import { z } from "zod";
|
|
3
|
+
import type { AccessRulesStorage } from "#policy/accessRules.js";
|
|
4
|
+
export declare const deleteRulesEndpointSchema: z.ZodArray<z.ZodObject<{
|
|
5
|
+
policyScope: z.ZodOptional<z.ZodObject<{
|
|
6
|
+
clientId: z.ZodOptional<z.ZodString>;
|
|
7
|
+
ruleGroupId: z.ZodOptional<z.ZodString>;
|
|
8
|
+
}, "strip", z.ZodTypeAny, {
|
|
9
|
+
clientId?: string | undefined;
|
|
10
|
+
ruleGroupId?: string | undefined;
|
|
11
|
+
}, {
|
|
12
|
+
clientId?: string | undefined;
|
|
13
|
+
ruleGroupId?: string | undefined;
|
|
14
|
+
}>>;
|
|
15
|
+
policyScopeMatch: z.ZodDefault<z.ZodNativeEnum<typeof import("#policy/accessPolicyResolver.js").ScopeMatch>>;
|
|
16
|
+
userScope: z.ZodOptional<z.ZodEffects<z.ZodObject<z.objectUtil.extendShape<{
|
|
17
|
+
userId: z.ZodOptional<z.ZodString>;
|
|
18
|
+
numericIp: z.ZodOptional<z.ZodBigInt>;
|
|
19
|
+
numericIpMaskMin: z.ZodOptional<z.ZodBigInt>;
|
|
20
|
+
numericIpMaskMax: z.ZodOptional<z.ZodBigInt>;
|
|
21
|
+
ja4Hash: z.ZodOptional<z.ZodString>;
|
|
22
|
+
headersHash: z.ZodOptional<z.ZodString>;
|
|
23
|
+
userAgentHash: z.ZodOptional<z.ZodString>;
|
|
24
|
+
}, {
|
|
25
|
+
ip: z.ZodOptional<z.ZodString>;
|
|
26
|
+
ipMask: z.ZodOptional<z.ZodString>;
|
|
27
|
+
userAgent: z.ZodOptional<z.ZodString>;
|
|
28
|
+
}>, "strip", z.ZodTypeAny, {
|
|
29
|
+
userId?: string | undefined;
|
|
30
|
+
numericIp?: bigint | undefined;
|
|
31
|
+
numericIpMaskMin?: bigint | undefined;
|
|
32
|
+
numericIpMaskMax?: bigint | undefined;
|
|
33
|
+
ja4Hash?: string | undefined;
|
|
34
|
+
headersHash?: string | undefined;
|
|
35
|
+
userAgentHash?: string | undefined;
|
|
36
|
+
ip?: string | undefined;
|
|
37
|
+
ipMask?: string | undefined;
|
|
38
|
+
userAgent?: string | undefined;
|
|
39
|
+
}, {
|
|
40
|
+
userId?: string | undefined;
|
|
41
|
+
numericIp?: bigint | undefined;
|
|
42
|
+
numericIpMaskMin?: bigint | undefined;
|
|
43
|
+
numericIpMaskMax?: bigint | undefined;
|
|
44
|
+
ja4Hash?: string | undefined;
|
|
45
|
+
headersHash?: string | undefined;
|
|
46
|
+
userAgentHash?: string | undefined;
|
|
47
|
+
ip?: string | undefined;
|
|
48
|
+
ipMask?: string | undefined;
|
|
49
|
+
userAgent?: string | undefined;
|
|
50
|
+
}>, {
|
|
51
|
+
userId?: string | undefined;
|
|
52
|
+
numericIp?: bigint | undefined;
|
|
53
|
+
numericIpMaskMin?: bigint | undefined;
|
|
54
|
+
numericIpMaskMax?: bigint | undefined;
|
|
55
|
+
ja4Hash?: string | undefined;
|
|
56
|
+
headersHash?: string | undefined;
|
|
57
|
+
userAgentHash?: string | undefined;
|
|
58
|
+
}, {
|
|
59
|
+
userId?: string | undefined;
|
|
60
|
+
numericIp?: bigint | undefined;
|
|
61
|
+
numericIpMaskMin?: bigint | undefined;
|
|
62
|
+
numericIpMaskMax?: bigint | undefined;
|
|
63
|
+
ja4Hash?: string | undefined;
|
|
64
|
+
headersHash?: string | undefined;
|
|
65
|
+
userAgentHash?: string | undefined;
|
|
66
|
+
ip?: string | undefined;
|
|
67
|
+
ipMask?: string | undefined;
|
|
68
|
+
userAgent?: string | undefined;
|
|
69
|
+
}>>;
|
|
70
|
+
userScopeMatch: z.ZodDefault<z.ZodNativeEnum<typeof import("#policy/accessPolicyResolver.js").ScopeMatch>>;
|
|
71
|
+
}, "strip", z.ZodTypeAny, {
|
|
72
|
+
policyScopeMatch: import("#policy/accessPolicyResolver.js").ScopeMatch;
|
|
73
|
+
userScopeMatch: import("#policy/accessPolicyResolver.js").ScopeMatch;
|
|
74
|
+
userScope?: {
|
|
75
|
+
userId?: string | undefined;
|
|
76
|
+
numericIp?: bigint | undefined;
|
|
77
|
+
numericIpMaskMin?: bigint | undefined;
|
|
78
|
+
numericIpMaskMax?: bigint | undefined;
|
|
79
|
+
ja4Hash?: string | undefined;
|
|
80
|
+
headersHash?: string | undefined;
|
|
81
|
+
userAgentHash?: string | undefined;
|
|
82
|
+
} | undefined;
|
|
83
|
+
policyScope?: {
|
|
84
|
+
clientId?: string | undefined;
|
|
85
|
+
ruleGroupId?: string | undefined;
|
|
86
|
+
} | undefined;
|
|
87
|
+
}, {
|
|
88
|
+
userScope?: {
|
|
89
|
+
userId?: string | undefined;
|
|
90
|
+
numericIp?: bigint | undefined;
|
|
91
|
+
numericIpMaskMin?: bigint | undefined;
|
|
92
|
+
numericIpMaskMax?: bigint | undefined;
|
|
93
|
+
ja4Hash?: string | undefined;
|
|
94
|
+
headersHash?: string | undefined;
|
|
95
|
+
userAgentHash?: string | undefined;
|
|
96
|
+
ip?: string | undefined;
|
|
97
|
+
ipMask?: string | undefined;
|
|
98
|
+
userAgent?: string | undefined;
|
|
99
|
+
} | undefined;
|
|
100
|
+
policyScope?: {
|
|
101
|
+
clientId?: string | undefined;
|
|
102
|
+
ruleGroupId?: string | undefined;
|
|
103
|
+
} | undefined;
|
|
104
|
+
policyScopeMatch?: import("#policy/accessPolicyResolver.js").ScopeMatch | undefined;
|
|
105
|
+
userScopeMatch?: import("#policy/accessPolicyResolver.js").ScopeMatch | undefined;
|
|
106
|
+
}>, "many">;
|
|
107
|
+
export type DeleteRulesEndpointSchemaOutput = z.output<typeof deleteRulesEndpointSchema>;
|
|
108
|
+
export type DeleteRulesEndpointSchemaInput = z.input<typeof deleteRulesEndpointSchema>;
|
|
109
|
+
export type DeleteRulesEndpointSchema = typeof deleteRulesEndpointSchema;
|
|
110
|
+
export declare class DeleteRulesEndpoint implements ApiEndpoint<DeleteRulesEndpointSchema> {
|
|
111
|
+
private readonly accessRulesStorage;
|
|
112
|
+
constructor(accessRulesStorage: AccessRulesStorage);
|
|
113
|
+
processRequest(args: DeleteRulesEndpointSchemaInput): Promise<ApiEndpointResponse>;
|
|
114
|
+
getRequestArgsSchema(): DeleteRulesEndpointSchema;
|
|
115
|
+
}
|
|
116
|
+
//# sourceMappingURL=deleteRulesEndpoint.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"deleteRulesEndpoint.d.ts","sourceRoot":"","sources":["../../src/api/deleteRulesEndpoint.ts"],"names":[],"mappings":"AAcA,OAAO,EACN,KAAK,WAAW,EAChB,KAAK,mBAAmB,EAExB,MAAM,oBAAoB,CAAC;AAC5B,OAAO,EAAE,CAAC,EAAE,MAAM,KAAK,CAAC;AAExB,OAAO,KAAK,EAAE,kBAAkB,EAAE,MAAM,wBAAwB,CAAC;AAEjE,eAAO,MAAM,yBAAyB;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;WAA8B,CAAC;AAErE,MAAM,MAAM,+BAA+B,GAAG,CAAC,CAAC,MAAM,CACrD,OAAO,yBAAyB,CAChC,CAAC;AAEF,MAAM,MAAM,8BAA8B,GAAG,CAAC,CAAC,KAAK,CACnD,OAAO,yBAAyB,CAChC,CAAC;AAEF,MAAM,MAAM,yBAAyB,GAAG,OAAO,yBAAyB,CAAC;AAEzE,qBAAa,mBACZ,YAAW,WAAW,CAAC,yBAAyB,CAAC;IAE9B,OAAO,CAAC,QAAQ,CAAC,kBAAkB;gBAAlB,kBAAkB,EAAE,kBAAkB;IAEpE,cAAc,CACnB,IAAI,EAAE,8BAA8B,GAClC,OAAO,CAAC,mBAAmB,CAAC;IA0BxB,oBAAoB,IAAI,yBAAyB;CAGxD"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"deleteRulesEndpoint.js","sourceRoot":"","sources":["../../src/api/deleteRulesEndpoint.ts"],"names":[],"mappings":"AAcA,OAAO,EAGN,yBAAyB,GACzB,MAAM,oBAAoB,CAAC;AAC5B,OAAO,EAAE,CAAC,EAAE,MAAM,KAAK,CAAC;AACxB,OAAO,EAAE,kBAAkB,EAAE,MAAM,iCAAiC,CAAC;AAGrE,MAAM,CAAC,MAAM,yBAAyB,GAAG,CAAC,CAAC,KAAK,CAAC,kBAAkB,CAAC,CAAC;AAYrE,MAAM,OAAO,mBAAmB;IAG/B,YAAoC,kBAAsC;QAAtC,uBAAkB,GAAlB,kBAAkB,CAAoB;IAAG,CAAC;IAE9E,KAAK,CAAC,cAAc,CACnB,IAAoC;QAEpC,MAAM,UAAU,GAAG,EAAE,CAAC;QAEtB,KAAK,MAAM,gBAAgB,IAAI,IAAI,EAAE,CAAC;YACrC,MAAM,WAAW,GAAG,kBAAkB,CAAC,KAAK,CAAC,gBAAgB,CAAC,CAAC;YAC/D,MAAM,YAAY,GACjB,MAAM,IAAI,CAAC,kBAAkB,CAAC,WAAW,CAAC,WAAW,CAAC,CAAC;YAExD,UAAU,CAAC,IAAI,CAAC,GAAG,YAAY,CAAC,CAAC;QAClC,CAAC;QAGD,MAAM,aAAa,GAAG,CAAC,GAAG,IAAI,GAAG,CAAC,UAAU,CAAC,CAAC,CAAC;QAE/C,IAAI,aAAa,CAAC,MAAM,GAAG,CAAC,EAAE,CAAC;YAC9B,MAAM,IAAI,CAAC,kBAAkB,CAAC,WAAW,CAAC,aAAa,CAAC,CAAC;QAC1D,CAAC;QAED,OAAO;YACN,MAAM,EAAE,yBAAyB,CAAC,OAAO;YACzC,IAAI,EAAE;gBACL,aAAa,EAAE,aAAa,CAAC,MAAM;aACnC;SACD,CAAC;IACH,CAAC;IAEM,oBAAoB;QAC1B,OAAO,yBAAyB,CAAC;IAClC,CAAC;CACD"}
|
|
@@ -0,0 +1,22 @@
|
|
|
1
|
+
import { type ApiEndpoint, type ApiEndpointResponse } from "@prosopo/api-route";
|
|
2
|
+
import { type Logger } from "@prosopo/common";
|
|
3
|
+
import { z } from "zod";
|
|
4
|
+
import { accessPolicySchema, policyScopeSchema, userScopeInputSchema } from "#policy/accessPolicy.js";
|
|
5
|
+
import type { AccessRulesWriter } from "#policy/accessRules.js";
|
|
6
|
+
export declare const insertRulesEndpointSchema: z.ZodType<{
|
|
7
|
+
accessPolicy: z.infer<typeof accessPolicySchema>;
|
|
8
|
+
policyScope?: z.infer<typeof policyScopeSchema>;
|
|
9
|
+
userScopes: z.input<typeof userScopeInputSchema>[];
|
|
10
|
+
expirationTimestamp?: number;
|
|
11
|
+
}>;
|
|
12
|
+
export type InsertRulesEndpointSchema = typeof insertRulesEndpointSchema;
|
|
13
|
+
export type InsertManyRulesEndpointInputSchema = z.input<typeof insertRulesEndpointSchema>;
|
|
14
|
+
export type InsertManyRulesEndpointOutputSchema = z.output<typeof insertRulesEndpointSchema>;
|
|
15
|
+
export declare class InsertRulesEndpoint implements ApiEndpoint<InsertRulesEndpointSchema> {
|
|
16
|
+
private readonly accessRulesWriter;
|
|
17
|
+
constructor(accessRulesWriter: AccessRulesWriter);
|
|
18
|
+
processRequest(args: z.infer<InsertRulesEndpointSchema>, logger?: Logger): Promise<ApiEndpointResponse>;
|
|
19
|
+
getRequestArgsSchema(): InsertRulesEndpointSchema;
|
|
20
|
+
protected createRules(args: InsertManyRulesEndpointOutputSchema): Promise<string[]>;
|
|
21
|
+
}
|
|
22
|
+
//# sourceMappingURL=insertRulesEndpoint.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"insertRulesEndpoint.d.ts","sourceRoot":"","sources":["../../src/api/insertRulesEndpoint.ts"],"names":[],"mappings":"AAcA,OAAO,EACN,KAAK,WAAW,EAChB,KAAK,mBAAmB,EAExB,MAAM,oBAAoB,CAAC;AAC5B,OAAO,EAAY,KAAK,MAAM,EAAa,MAAM,iBAAiB,CAAC;AACnE,OAAO,EAAE,CAAC,EAAE,MAAM,KAAK,CAAC;AACxB,OAAO,EACN,kBAAkB,EAClB,iBAAiB,EACjB,oBAAoB,EACpB,MAAM,yBAAyB,CAAC;AACjC,OAAO,KAAK,EAAE,iBAAiB,EAAE,MAAM,wBAAwB,CAAC;AAEhE,eAAO,MAAM,yBAAyB,EAAE,CAAC,CAAC,OAAO,CAAC;IACjD,YAAY,EAAE,CAAC,CAAC,KAAK,CAAC,OAAO,kBAAkB,CAAC,CAAC;IACjD,WAAW,CAAC,EAAE,CAAC,CAAC,KAAK,CAAC,OAAO,iBAAiB,CAAC,CAAC;IAChD,UAAU,EAAE,CAAC,CAAC,KAAK,CAAC,OAAO,oBAAoB,CAAC,EAAE,CAAC;IACnD,mBAAmB,CAAC,EAAE,MAAM,CAAC;CAC7B,CAQC,CAAC;AAEH,MAAM,MAAM,yBAAyB,GAAG,OAAO,yBAAyB,CAAC;AAEzE,MAAM,MAAM,kCAAkC,GAAG,CAAC,CAAC,KAAK,CACvD,OAAO,yBAAyB,CAChC,CAAC;AAEF,MAAM,MAAM,mCAAmC,GAAG,CAAC,CAAC,MAAM,CACzD,OAAO,yBAAyB,CAChC,CAAC;AAEF,qBAAa,mBACZ,YAAW,WAAW,CAAC,yBAAyB,CAAC;IAE9B,OAAO,CAAC,QAAQ,CAAC,iBAAiB;gBAAjB,iBAAiB,EAAE,iBAAiB;IAElE,cAAc,CACnB,IAAI,EAAE,CAAC,CAAC,KAAK,CAAC,yBAAyB,CAAC,EACxC,MAAM,CAAC,EAAE,MAAM,GACb,OAAO,CAAC,mBAAmB,CAAC;IAgCxB,oBAAoB,IAAI,yBAAyB;cAIxC,WAAW,CAC1B,IAAI,EAAE,mCAAmC,GACvC,OAAO,CAAC,MAAM,EAAE,CAAC;CAiBpB"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"insertRulesEndpoint.js","sourceRoot":"","sources":["../../src/api/insertRulesEndpoint.ts"],"names":[],"mappings":"AAcA,OAAO,EAGN,yBAAyB,GACzB,MAAM,oBAAoB,CAAC;AAC5B,OAAO,EAAE,QAAQ,EAAe,SAAS,EAAE,MAAM,iBAAiB,CAAC;AACnE,OAAO,EAAE,CAAC,EAAE,MAAM,KAAK,CAAC;AACxB,OAAO,EACN,kBAAkB,EAClB,iBAAiB,EACjB,oBAAoB,GACpB,MAAM,yBAAyB,CAAC;AAGjC,MAAM,CAAC,MAAM,yBAAyB,GAKjC,CAAC,CAAC,MAAM,CAAC;IACb,YAAY,EAAE,kBAAkB;IAChC,WAAW,EAAE,iBAAiB,CAAC,QAAQ,EAAE;IACzC,UAAU,EAAE,CAAC,CAAC,KAAK,CAAC,oBAAoB,CAAC;IACzC,mBAAmB,EAAE,CAAC;SACpB,MAAM,EAAE;SACR,QAAQ,EAAE;SACV,SAAS,CAAC,CAAC,GAAG,EAAE,EAAE,CAAC,CAAC,GAAG,KAAK,SAAS,CAAC,CAAC,CAAC,IAAI,CAAC,KAAK,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC,GAAG,CAAC,CAAC;CACjE,CAAC,CAAC;AAYH,MAAM,OAAO,mBAAmB;IAG/B,YAAoC,iBAAoC;QAApC,sBAAiB,GAAjB,iBAAiB,CAAmB;IAAG,CAAC;IAE5E,KAAK,CAAC,cAAc,CACnB,IAAwC,EACxC,MAAe;QAEf,MAAM,GAAG,MAAM,IAAI,SAAS,CAAC,QAAQ,CAAC,IAAI,CAAC,IAAI,EAAE,qBAAqB,CAAC,CAAC;QAExE,MAAM,cAAc,GAAG,IAAI,OAAO,CAAsB,CAAC,OAAO,EAAE,EAAE;YACnE,UAAU,CAAC,GAAG,EAAE;gBACf,OAAO,CAAC;oBACP,MAAM,EAAE,yBAAyB,CAAC,UAAU;iBAC5C,CAAC,CAAC;YACJ,CAAC,EAAE,IAAI,CAAC,CAAC;QACV,CAAC,CAAC,CAAC;QAEH,MAAM,kBAAkB,GAAG,IAAI,CAAC,WAAW,CAAC,IAAI,CAAC;aAC/C,IAAI,CAAC,GAAG,EAAE,CAAC,CAAC;YACZ,MAAM,EAAE,yBAAyB,CAAC,OAAO;SACzC,CAAC,CAAC;aACF,KAAK,CAAC,CAAC,KAAK,EAAE,EAAE;YAChB,IAAI,MAAM,EAAE,WAAW,EAAE,KAAK,QAAQ,CAAC,IAAI,CAAC,KAAK,EAAE,CAAC;gBACnD,MAAM,CAAC,KAAK,CAAC,GAAG,EAAE,CAAC,CAAC;oBACnB,GAAG,EAAE,KAAK;oBACV,IAAI,EAAE,EAAE,IAAI,EAAE;oBACd,GAAG,EAAE,+BAA+B;iBACpC,CAAC,CAAC,CAAC;YACL,CAAC;YACD,OAAO;gBACN,MAAM,EAAE,yBAAyB,CAAC,IAAI;aACtC,CAAC;QACH,CAAC,CAAC,CAAC;QAGJ,OAAO,OAAO,CAAC,IAAI,CAAC,CAAC,cAAc,EAAE,kBAAkB,CAAC,CAAC,CAAC;IAC3D,CAAC;IAEM,oBAAoB;QAC1B,OAAO,yBAAyB,CAAC;IAClC,CAAC;IAES,KAAK,CAAC,WAAW,CAC1B,IAAyC;QAEzC,MAAM,WAAW,GAAG,IAAI,CAAC,WAAW,IAAI,EAAE,CAAC;QAE3C,MAAM,cAAc,GAAG,EAAE,CAAC;QAC1B,KAAK,MAAM,SAAS,IAAI,IAAI,CAAC,UAAU,EAAE,CAAC;YACzC,MAAM,IAAI,GAAG;gBACZ,GAAG,IAAI,CAAC,YAAY;gBACpB,GAAG,WAAW;gBACd,GAAG,SAAS;aACZ,CAAC;YAEF,cAAc,CAAC,IAAI,CAClB,IAAI,CAAC,iBAAiB,CAAC,UAAU,CAAC,IAAI,EAAE,IAAI,CAAC,mBAAmB,CAAC,CACjE,CAAC;QACH,CAAC;QACD,OAAO,OAAO,CAAC,GAAG,CAAC,cAAc,CAAC,CAAC;IACpC,CAAC;CACD"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":".export.d.ts","sourceRoot":"","sources":["../../../src/api/read/.export.ts"],"names":[],"mappings":"AAcA,YAAY,EACX,eAAe,EACf,uBAAuB,GACvB,MAAM,kBAAkB,CAAC;AAE1B,YAAY,EACX,iBAAiB,EACjB,kBAAkB,GAClB,MAAM,iBAAiB,CAAC;AAEzB,YAAY,EAAE,UAAU,EAAE,MAAM,oBAAoB,CAAC"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":".export.js","sourceRoot":"","sources":["../../../src/api/read/.export.ts"],"names":[],"mappings":""}
|
|
@@ -0,0 +1,53 @@
|
|
|
1
|
+
import { type ApiEndpoint, type ApiEndpointResponse } from "@prosopo/api-route";
|
|
2
|
+
import type { Logger } from "@prosopo/common";
|
|
3
|
+
import { type ZodType, z } from "zod";
|
|
4
|
+
import type { AccessRuleEntry, AccessRulesStorage } from "#policy/rulesStorage.js";
|
|
5
|
+
export type FetchRulesOptions = {
|
|
6
|
+
ids: string[];
|
|
7
|
+
};
|
|
8
|
+
type FetchRulesSchema = ZodType<FetchRulesOptions>;
|
|
9
|
+
export type FetchRulesResponse = {
|
|
10
|
+
ruleEntries: AccessRuleEntry[];
|
|
11
|
+
};
|
|
12
|
+
export declare const fetchRulesResponse: z.ZodObject<{
|
|
13
|
+
ruleEntries: z.ZodArray<z.ZodObject<{
|
|
14
|
+
rule: ZodType<import("../../rule.js").AccessRule, z.ZodTypeDef, import("../../rule.js").AccessRule>;
|
|
15
|
+
expiresUnixTimestamp: z.ZodOptional<z.ZodNumber>;
|
|
16
|
+
}, "strip", z.ZodTypeAny, {
|
|
17
|
+
rule: import("../../rule.js").AccessPolicy & import("../../rule.js").PolicyScope & import("../../rule.js").UserAttributes & import("../../rule.js").UserIp & {
|
|
18
|
+
groupId?: string;
|
|
19
|
+
};
|
|
20
|
+
expiresUnixTimestamp?: number | undefined;
|
|
21
|
+
}, {
|
|
22
|
+
rule: import("../../rule.js").AccessPolicy & import("../../rule.js").PolicyScope & import("../../rule.js").UserAttributes & import("../../rule.js").UserIp & {
|
|
23
|
+
groupId?: string;
|
|
24
|
+
};
|
|
25
|
+
expiresUnixTimestamp?: number | undefined;
|
|
26
|
+
}>, "many">;
|
|
27
|
+
}, "strip", z.ZodTypeAny, {
|
|
28
|
+
ruleEntries: {
|
|
29
|
+
rule: import("../../rule.js").AccessPolicy & import("../../rule.js").PolicyScope & import("../../rule.js").UserAttributes & import("../../rule.js").UserIp & {
|
|
30
|
+
groupId?: string;
|
|
31
|
+
};
|
|
32
|
+
expiresUnixTimestamp?: number | undefined;
|
|
33
|
+
}[];
|
|
34
|
+
}, {
|
|
35
|
+
ruleEntries: {
|
|
36
|
+
rule: import("../../rule.js").AccessPolicy & import("../../rule.js").PolicyScope & import("../../rule.js").UserAttributes & import("../../rule.js").UserIp & {
|
|
37
|
+
groupId?: string;
|
|
38
|
+
};
|
|
39
|
+
expiresUnixTimestamp?: number | undefined;
|
|
40
|
+
}[];
|
|
41
|
+
}>;
|
|
42
|
+
export type FetchRulesEndpointResponse = ApiEndpointResponse & {
|
|
43
|
+
data?: FetchRulesResponse;
|
|
44
|
+
};
|
|
45
|
+
export declare class FetchRulesEndpoint implements ApiEndpoint<FetchRulesSchema> {
|
|
46
|
+
private readonly accessRulesStorage;
|
|
47
|
+
private readonly logger;
|
|
48
|
+
constructor(accessRulesStorage: AccessRulesStorage, logger: Logger);
|
|
49
|
+
getRequestArgsSchema(): FetchRulesSchema;
|
|
50
|
+
processRequest(args: FetchRulesOptions): Promise<FetchRulesEndpointResponse>;
|
|
51
|
+
}
|
|
52
|
+
export {};
|
|
53
|
+
//# sourceMappingURL=fetchRules.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"fetchRules.d.ts","sourceRoot":"","sources":["../../../src/api/read/fetchRules.ts"],"names":[],"mappings":"AAcA,OAAO,EACN,KAAK,WAAW,EAChB,KAAK,mBAAmB,EAExB,MAAM,oBAAoB,CAAC;AAC5B,OAAO,KAAK,EAAW,MAAM,EAAE,MAAM,iBAAiB,CAAC;AACvD,OAAO,EAAE,KAAK,OAAO,EAAE,CAAC,EAAE,MAAM,KAAK,CAAC;AAEtC,OAAO,KAAK,EACX,eAAe,EACf,kBAAkB,EAClB,MAAM,yBAAyB,CAAC;AAEjC,MAAM,MAAM,iBAAiB,GAAG;IAC/B,GAAG,EAAE,MAAM,EAAE,CAAC;CACd,CAAC;AAEF,KAAK,gBAAgB,GAAG,OAAO,CAAC,iBAAiB,CAAC,CAAC;AAEnD,MAAM,MAAM,kBAAkB,GAAG;IAChC,WAAW,EAAE,eAAe,EAAE,CAAC;CAC/B,CAAC;AAEF,eAAO,MAAM,kBAAkB;;;;;;;;;;;;;;;;;;;;;;;;;;;;;EAE+C,CAAC;AAE/E,MAAM,MAAM,0BAA0B,GAAG,mBAAmB,GAAG;IAC9D,IAAI,CAAC,EAAE,kBAAkB,CAAC;CAC1B,CAAC;AAEF,qBAAa,kBAAmB,YAAW,WAAW,CAAC,gBAAgB,CAAC;IAEtE,OAAO,CAAC,QAAQ,CAAC,kBAAkB;IACnC,OAAO,CAAC,QAAQ,CAAC,MAAM;gBADN,kBAAkB,EAAE,kBAAkB,EACtC,MAAM,EAAE,MAAM;IAGzB,oBAAoB,IAAI,gBAAgB;IAMzC,cAAc,CACnB,IAAI,EAAE,iBAAiB,GACrB,OAAO,CAAC,0BAA0B,CAAC;CAyBtC"}
|
|
@@ -0,0 +1,43 @@
|
|
|
1
|
+
import { ApiEndpointResponseStatus } from "@prosopo/api-route";
|
|
2
|
+
import { z } from "zod";
|
|
3
|
+
import { ruleEntryInput } from "../../ruleInput/ruleInput.js";
|
|
4
|
+
const fetchRulesResponse = z.object({
|
|
5
|
+
ruleEntries: ruleEntryInput.array()
|
|
6
|
+
});
|
|
7
|
+
class FetchRulesEndpoint {
|
|
8
|
+
constructor(accessRulesStorage, logger) {
|
|
9
|
+
this.accessRulesStorage = accessRulesStorage;
|
|
10
|
+
this.logger = logger;
|
|
11
|
+
}
|
|
12
|
+
getRequestArgsSchema() {
|
|
13
|
+
return z.object({
|
|
14
|
+
ids: z.string().array()
|
|
15
|
+
});
|
|
16
|
+
}
|
|
17
|
+
async processRequest(args) {
|
|
18
|
+
const ruleEntries = await this.accessRulesStorage.fetchRules(args.ids);
|
|
19
|
+
this.logger.info(() => ({
|
|
20
|
+
msg: "Endpoint fetched rules",
|
|
21
|
+
data: {
|
|
22
|
+
requestedCount: args.ids.length,
|
|
23
|
+
foundCount: ruleEntries.length
|
|
24
|
+
}
|
|
25
|
+
}));
|
|
26
|
+
this.logger.debug(() => ({
|
|
27
|
+
msg: "Fetched rule details",
|
|
28
|
+
data: {
|
|
29
|
+
ruleEntries
|
|
30
|
+
}
|
|
31
|
+
}));
|
|
32
|
+
return {
|
|
33
|
+
status: ApiEndpointResponseStatus.SUCCESS,
|
|
34
|
+
data: {
|
|
35
|
+
ruleEntries
|
|
36
|
+
}
|
|
37
|
+
};
|
|
38
|
+
}
|
|
39
|
+
}
|
|
40
|
+
export {
|
|
41
|
+
FetchRulesEndpoint,
|
|
42
|
+
fetchRulesResponse
|
|
43
|
+
};
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"fetchRules.js","sourceRoot":"","sources":["../../../src/api/read/fetchRules.ts"],"names":[],"mappings":"AAcA,OAAO,EAGN,yBAAyB,GACzB,MAAM,oBAAoB,CAAC;AAE5B,OAAO,EAAgB,CAAC,EAAE,MAAM,KAAK,CAAC;AACtC,OAAO,EAAE,cAAc,EAAE,MAAM,gCAAgC,CAAC;AAgBhE,MAAM,CAAC,MAAM,kBAAkB,GAAG,CAAC,CAAC,MAAM,CAAC;IAC1C,WAAW,EAAE,cAAc,CAAC,KAAK,EAAE;CACG,CAAuC,CAAC;AAM/E,MAAM,OAAO,kBAAkB;IAC9B,YACkB,kBAAsC,EACtC,MAAc;QADd,uBAAkB,GAAlB,kBAAkB,CAAoB;QACtC,WAAM,GAAN,MAAM,CAAQ;IAC7B,CAAC;IAEG,oBAAoB;QAC1B,OAAO,CAAC,CAAC,MAAM,CAAC;YACf,GAAG,EAAE,CAAC,CAAC,MAAM,EAAE,CAAC,KAAK,EAAE;SACc,CAAC,CAAC;IACzC,CAAC;IAED,KAAK,CAAC,cAAc,CACnB,IAAuB;QAEvB,MAAM,WAAW,GAAG,MAAM,IAAI,CAAC,kBAAkB,CAAC,UAAU,CAAC,IAAI,CAAC,GAAG,CAAC,CAAC;QAEvE,IAAI,CAAC,MAAM,CAAC,IAAI,CAAC,GAAG,EAAE,CAAC,CAAC;YACvB,GAAG,EAAE,wBAAwB;YAC7B,IAAI,EAAE;gBACL,cAAc,EAAE,IAAI,CAAC,GAAG,CAAC,MAAM;gBAC/B,UAAU,EAAE,WAAW,CAAC,MAAM;aAC9B;SACD,CAAC,CAAC,CAAC;QAEJ,IAAI,CAAC,MAAM,CAAC,KAAK,CAAC,GAAG,EAAE,CAAC,CAAC;YACxB,GAAG,EAAE,sBAAsB;YAC3B,IAAI,EAAE;gBACL,WAAW,EAAE,WAAW;aACxB;SACD,CAAC,CAAC,CAAC;QAEJ,OAAO;YACN,MAAM,EAAE,yBAAyB,CAAC,OAAO;YACzC,IAAI,EAAE;gBACL,WAAW,EAAE,WAAW;aACxB;SACD,CAAC;IACH,CAAC;CACD"}
|
|
@@ -0,0 +1,28 @@
|
|
|
1
|
+
import { type ApiEndpoint, type ApiEndpointResponse } from "@prosopo/api-route";
|
|
2
|
+
import { type Logger } from "@prosopo/common";
|
|
3
|
+
import { type ZodType, z } from "zod";
|
|
4
|
+
import { type AccessRulesFilterInput } from "#policy/ruleInput/ruleInput.js";
|
|
5
|
+
import type { AccessRulesStorage } from "#policy/rulesStorage.js";
|
|
6
|
+
type FindRulesSchema = ZodType<AccessRulesFilterInput[]>;
|
|
7
|
+
export type RuleIdsResponse = {
|
|
8
|
+
ruleIds: string[];
|
|
9
|
+
};
|
|
10
|
+
export declare const ruleIdsResponse: z.ZodObject<{
|
|
11
|
+
ruleIds: z.ZodArray<z.ZodString, "many">;
|
|
12
|
+
}, "strip", z.ZodTypeAny, {
|
|
13
|
+
ruleIds: string[];
|
|
14
|
+
}, {
|
|
15
|
+
ruleIds: string[];
|
|
16
|
+
}>;
|
|
17
|
+
export type RuleIdsEndpointResponse = ApiEndpointResponse & {
|
|
18
|
+
data?: RuleIdsResponse;
|
|
19
|
+
};
|
|
20
|
+
export declare class FindRuleIdsEndpoint implements ApiEndpoint<FindRulesSchema> {
|
|
21
|
+
private readonly accessRulesStorage;
|
|
22
|
+
private readonly logger;
|
|
23
|
+
constructor(accessRulesStorage: AccessRulesStorage, logger: Logger);
|
|
24
|
+
getRequestArgsSchema(): FindRulesSchema;
|
|
25
|
+
processRequest(args: AccessRulesFilterInput[]): Promise<RuleIdsEndpointResponse>;
|
|
26
|
+
}
|
|
27
|
+
export {};
|
|
28
|
+
//# sourceMappingURL=findRuleIds.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"findRuleIds.d.ts","sourceRoot":"","sources":["../../../src/api/read/findRuleIds.ts"],"names":[],"mappings":"AAcA,OAAO,EACN,KAAK,WAAW,EAChB,KAAK,mBAAmB,EAExB,MAAM,oBAAoB,CAAC;AAC5B,OAAO,EAEN,KAAK,MAAM,EAEX,MAAM,iBAAiB,CAAC;AACzB,OAAO,EAAE,KAAK,OAAO,EAAE,CAAC,EAAE,MAAM,KAAK,CAAC;AACtC,OAAO,EACN,KAAK,sBAAsB,EAG3B,MAAM,gCAAgC,CAAC;AACxC,OAAO,KAAK,EAAE,kBAAkB,EAAE,MAAM,yBAAyB,CAAC;AAElE,KAAK,eAAe,GAAG,OAAO,CAAC,sBAAsB,EAAE,CAAC,CAAC;AAEzD,MAAM,MAAM,eAAe,GAAG;IAC7B,OAAO,EAAE,MAAM,EAAE,CAAC;CAClB,CAAC;AAEF,eAAO,MAAM,eAAe;;;;;;EAE4C,CAAC;AAEzE,MAAM,MAAM,uBAAuB,GAAG,mBAAmB,GAAG;IAC3D,IAAI,CAAC,EAAE,eAAe,CAAC;CACvB,CAAC;AAEF,qBAAa,mBAAoB,YAAW,WAAW,CAAC,eAAe,CAAC;IAEtE,OAAO,CAAC,QAAQ,CAAC,kBAAkB;IACnC,OAAO,CAAC,QAAQ,CAAC,MAAM;gBADN,kBAAkB,EAAE,kBAAkB,EACtC,MAAM,EAAE,MAAM;IAGzB,oBAAoB,IAAI,eAAe;IAIxC,cAAc,CACnB,IAAI,EAAE,sBAAsB,EAAE,GAC5B,OAAO,CAAC,uBAAuB,CAAC;CAqCnC"}
|
|
@@ -0,0 +1,50 @@
|
|
|
1
|
+
import { ApiEndpointResponseStatus } from "@prosopo/api-route";
|
|
2
|
+
import { executeBatchesSequentially } from "@prosopo/common";
|
|
3
|
+
import { z } from "zod";
|
|
4
|
+
import { accessRulesFilterInput, getAccessRuleFiltersFromInput } from "../../ruleInput/ruleInput.js";
|
|
5
|
+
const ruleIdsResponse = z.object({
|
|
6
|
+
ruleIds: z.string().array()
|
|
7
|
+
});
|
|
8
|
+
class FindRuleIdsEndpoint {
|
|
9
|
+
constructor(accessRulesStorage, logger) {
|
|
10
|
+
this.accessRulesStorage = accessRulesStorage;
|
|
11
|
+
this.logger = logger;
|
|
12
|
+
}
|
|
13
|
+
getRequestArgsSchema() {
|
|
14
|
+
return z.array(accessRulesFilterInput);
|
|
15
|
+
}
|
|
16
|
+
async processRequest(args) {
|
|
17
|
+
const ruleIdBatches = await executeBatchesSequentially(
|
|
18
|
+
args,
|
|
19
|
+
async (rulesFilterInput) => {
|
|
20
|
+
const ruleFilters = getAccessRuleFiltersFromInput(rulesFilterInput);
|
|
21
|
+
const ruleIds2 = await executeBatchesSequentially(
|
|
22
|
+
ruleFilters,
|
|
23
|
+
(ruleFilter) => this.accessRulesStorage.findRuleIds(ruleFilter)
|
|
24
|
+
);
|
|
25
|
+
return ruleIds2.flat();
|
|
26
|
+
}
|
|
27
|
+
);
|
|
28
|
+
const ruleIds = ruleIdBatches.flat();
|
|
29
|
+
const uniqueRuleIds = [...new Set(ruleIds)];
|
|
30
|
+
this.logger.info(() => ({
|
|
31
|
+
msg: "Endpoint found rules",
|
|
32
|
+
data: {
|
|
33
|
+
totalFoundCount: ruleIds.length,
|
|
34
|
+
uniqueFoundCount: uniqueRuleIds.length,
|
|
35
|
+
searchFilters: args,
|
|
36
|
+
foundIds: uniqueRuleIds
|
|
37
|
+
}
|
|
38
|
+
}));
|
|
39
|
+
return {
|
|
40
|
+
status: ApiEndpointResponseStatus.SUCCESS,
|
|
41
|
+
data: {
|
|
42
|
+
ruleIds: uniqueRuleIds
|
|
43
|
+
}
|
|
44
|
+
};
|
|
45
|
+
}
|
|
46
|
+
}
|
|
47
|
+
export {
|
|
48
|
+
FindRuleIdsEndpoint,
|
|
49
|
+
ruleIdsResponse
|
|
50
|
+
};
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"findRuleIds.js","sourceRoot":"","sources":["../../../src/api/read/findRuleIds.ts"],"names":[],"mappings":"AAcA,OAAO,EAGN,yBAAyB,GACzB,MAAM,oBAAoB,CAAC;AAC5B,OAAO,EAGN,0BAA0B,GAC1B,MAAM,iBAAiB,CAAC;AACzB,OAAO,EAAgB,CAAC,EAAE,MAAM,KAAK,CAAC;AACtC,OAAO,EAEN,sBAAsB,EACtB,6BAA6B,GAC7B,MAAM,gCAAgC,CAAC;AASxC,MAAM,CAAC,MAAM,eAAe,GAAG,CAAC,CAAC,MAAM,CAAC;IACvC,OAAO,EAAE,CAAC,CAAC,MAAM,EAAE,CAAC,KAAK,EAAE;CACQ,CAAoC,CAAC;AAMzE,MAAM,OAAO,mBAAmB;IAC/B,YACkB,kBAAsC,EACtC,MAAc;QADd,uBAAkB,GAAlB,kBAAkB,CAAoB;QACtC,WAAM,GAAN,MAAM,CAAQ;IAC7B,CAAC;IAEG,oBAAoB;QAC1B,OAAO,CAAC,CAAC,KAAK,CAAC,sBAAsB,CAAC,CAAC;IACxC,CAAC;IAED,KAAK,CAAC,cAAc,CACnB,IAA8B;QAE9B,MAAM,aAAa,GAAG,MAAM,0BAA0B,CACrD,IAAI,EACJ,KAAK,EAAE,gBAAgB,EAAE,EAAE;YAC1B,MAAM,WAAW,GAAG,6BAA6B,CAAC,gBAAgB,CAAC,CAAC;YAEpE,MAAM,OAAO,GAAG,MAAM,0BAA0B,CAC/C,WAAW,EACX,CAAC,UAAU,EAAE,EAAE,CAAC,IAAI,CAAC,kBAAkB,CAAC,WAAW,CAAC,UAAU,CAAC,CAC/D,CAAC;YAEF,OAAO,OAAO,CAAC,IAAI,EAAE,CAAC;QACvB,CAAC,CACD,CAAC;QAEF,MAAM,OAAO,GAAG,aAAa,CAAC,IAAI,EAAE,CAAC;QAGrC,MAAM,aAAa,GAAG,CAAC,GAAG,IAAI,GAAG,CAAC,OAAO,CAAC,CAAC,CAAC;QAE5C,IAAI,CAAC,MAAM,CAAC,IAAI,CAAC,GAAG,EAAE,CAAC,CAAC;YACvB,GAAG,EAAE,sBAAsB;YAC3B,IAAI,EAAE;gBACL,eAAe,EAAE,OAAO,CAAC,MAAM;gBAC/B,gBAAgB,EAAE,aAAa,CAAC,MAAM;gBACtC,aAAa,EAAE,IAAI;gBACnB,QAAQ,EAAE,aAAa;aACvB;SACD,CAAC,CAAC,CAAC;QAEJ,OAAO;YACN,MAAM,EAAE,yBAAyB,CAAC,OAAO;YACzC,IAAI,EAAE;gBACL,OAAO,EAAE,aAAa;aACtB;SACD,CAAC;IACH,CAAC;CACD"}
|
|
@@ -0,0 +1,28 @@
|
|
|
1
|
+
import { type ApiEndpoint, type ApiEndpointResponse } from "@prosopo/api-route";
|
|
2
|
+
import type { Logger } from "@prosopo/common";
|
|
3
|
+
import { type ZodType, z } from "zod";
|
|
4
|
+
import type { AccessRulesStorage } from "#policy/rulesStorage.js";
|
|
5
|
+
export type MissingIds = string[];
|
|
6
|
+
type MissingIdsSchema = ZodType<MissingIds>;
|
|
7
|
+
export type MissingIdsResponse = {
|
|
8
|
+
ids: string[];
|
|
9
|
+
};
|
|
10
|
+
export declare const missingIdsResponse: z.ZodObject<{
|
|
11
|
+
ids: z.ZodArray<z.ZodString, "many">;
|
|
12
|
+
}, "strip", z.ZodTypeAny, {
|
|
13
|
+
ids: string[];
|
|
14
|
+
}, {
|
|
15
|
+
ids: string[];
|
|
16
|
+
}>;
|
|
17
|
+
export type MissingIdsEndpointResponse = ApiEndpointResponse & {
|
|
18
|
+
data?: MissingIdsResponse;
|
|
19
|
+
};
|
|
20
|
+
export declare class GetMissingIdsEndpoint implements ApiEndpoint<MissingIdsSchema> {
|
|
21
|
+
private readonly accessRulesStorage;
|
|
22
|
+
private readonly logger;
|
|
23
|
+
constructor(accessRulesStorage: AccessRulesStorage, logger: Logger);
|
|
24
|
+
getRequestArgsSchema(): MissingIdsSchema;
|
|
25
|
+
processRequest(args: MissingIds): Promise<MissingIdsEndpointResponse>;
|
|
26
|
+
}
|
|
27
|
+
export {};
|
|
28
|
+
//# sourceMappingURL=getMissingIds.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"getMissingIds.d.ts","sourceRoot":"","sources":["../../../src/api/read/getMissingIds.ts"],"names":[],"mappings":"AAcA,OAAO,EACN,KAAK,WAAW,EAChB,KAAK,mBAAmB,EAExB,MAAM,oBAAoB,CAAC;AAC5B,OAAO,KAAK,EAAW,MAAM,EAAE,MAAM,iBAAiB,CAAC;AACvD,OAAO,EAAE,KAAK,OAAO,EAAE,CAAC,EAAE,MAAM,KAAK,CAAC;AACtC,OAAO,KAAK,EAAE,kBAAkB,EAAE,MAAM,yBAAyB,CAAC;AAElE,MAAM,MAAM,UAAU,GAAG,MAAM,EAAE,CAAC;AAElC,KAAK,gBAAgB,GAAG,OAAO,CAAC,UAAU,CAAC,CAAC;AAE5C,MAAM,MAAM,kBAAkB,GAAG;IAChC,GAAG,EAAE,MAAM,EAAE,CAAC;CACd,CAAC;AAEF,eAAO,MAAM,kBAAkB;;;;;;EAE+C,CAAC;AAE/E,MAAM,MAAM,0BAA0B,GAAG,mBAAmB,GAAG;IAC9D,IAAI,CAAC,EAAE,kBAAkB,CAAC;CAC1B,CAAC;AAEF,qBAAa,qBAAsB,YAAW,WAAW,CAAC,gBAAgB,CAAC;IAEzE,OAAO,CAAC,QAAQ,CAAC,kBAAkB;IACnC,OAAO,CAAC,QAAQ,CAAC,MAAM;gBADN,kBAAkB,EAAE,kBAAkB,EACtC,MAAM,EAAE,MAAM;IAGzB,oBAAoB,IAAI,gBAAgB;IAIzC,cAAc,CAAC,IAAI,EAAE,UAAU,GAAG,OAAO,CAAC,0BAA0B,CAAC;CA0B3E"}
|
|
@@ -0,0 +1,41 @@
|
|
|
1
|
+
import { ApiEndpointResponseStatus } from "@prosopo/api-route";
|
|
2
|
+
import { z } from "zod";
|
|
3
|
+
const missingIdsResponse = z.object({
|
|
4
|
+
ids: z.string().array()
|
|
5
|
+
});
|
|
6
|
+
class GetMissingIdsEndpoint {
|
|
7
|
+
constructor(accessRulesStorage, logger) {
|
|
8
|
+
this.accessRulesStorage = accessRulesStorage;
|
|
9
|
+
this.logger = logger;
|
|
10
|
+
}
|
|
11
|
+
getRequestArgsSchema() {
|
|
12
|
+
return z.string().array();
|
|
13
|
+
}
|
|
14
|
+
async processRequest(args) {
|
|
15
|
+
const missingIds = await this.accessRulesStorage.getMissingRuleIds(args);
|
|
16
|
+
this.logger.info(() => ({
|
|
17
|
+
msg: "Endpoint checked missing ids",
|
|
18
|
+
data: {
|
|
19
|
+
idsToCheck: args.length,
|
|
20
|
+
missingIds: missingIds.length
|
|
21
|
+
}
|
|
22
|
+
}));
|
|
23
|
+
this.logger.debug(() => ({
|
|
24
|
+
msg: "Missing id details",
|
|
25
|
+
data: {
|
|
26
|
+
idsToCheck: args,
|
|
27
|
+
missingIds
|
|
28
|
+
}
|
|
29
|
+
}));
|
|
30
|
+
return {
|
|
31
|
+
status: ApiEndpointResponseStatus.SUCCESS,
|
|
32
|
+
data: {
|
|
33
|
+
ids: missingIds
|
|
34
|
+
}
|
|
35
|
+
};
|
|
36
|
+
}
|
|
37
|
+
}
|
|
38
|
+
export {
|
|
39
|
+
GetMissingIdsEndpoint,
|
|
40
|
+
missingIdsResponse
|
|
41
|
+
};
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"getMissingIds.js","sourceRoot":"","sources":["../../../src/api/read/getMissingIds.ts"],"names":[],"mappings":"AAcA,OAAO,EAGN,yBAAyB,GACzB,MAAM,oBAAoB,CAAC;AAE5B,OAAO,EAAgB,CAAC,EAAE,MAAM,KAAK,CAAC;AAWtC,MAAM,CAAC,MAAM,kBAAkB,GAAG,CAAC,CAAC,MAAM,CAAC;IAC1C,GAAG,EAAE,CAAC,CAAC,MAAM,EAAE,CAAC,KAAK,EAAE;CACe,CAAuC,CAAC;AAM/E,MAAM,OAAO,qBAAqB;IACjC,YACkB,kBAAsC,EACtC,MAAc;QADd,uBAAkB,GAAlB,kBAAkB,CAAoB;QACtC,WAAM,GAAN,MAAM,CAAQ;IAC7B,CAAC;IAEG,oBAAoB;QAC1B,OAAO,CAAC,CAAC,MAAM,EAAE,CAAC,KAAK,EAAE,CAAC;IAC3B,CAAC;IAED,KAAK,CAAC,cAAc,CAAC,IAAgB;QACpC,MAAM,UAAU,GAAG,MAAM,IAAI,CAAC,kBAAkB,CAAC,iBAAiB,CAAC,IAAI,CAAC,CAAC;QAEzE,IAAI,CAAC,MAAM,CAAC,IAAI,CAAC,GAAG,EAAE,CAAC,CAAC;YACvB,GAAG,EAAE,8BAA8B;YACnC,IAAI,EAAE;gBACL,UAAU,EAAE,IAAI,CAAC,MAAM;gBACvB,UAAU,EAAE,UAAU,CAAC,MAAM;aAC7B;SACD,CAAC,CAAC,CAAC;QAEJ,IAAI,CAAC,MAAM,CAAC,KAAK,CAAC,GAAG,EAAE,CAAC,CAAC;YACxB,GAAG,EAAE,oBAAoB;YACzB,IAAI,EAAE;gBACL,UAAU,EAAE,IAAI;gBAChB,UAAU,EAAE,UAAU;aACtB;SACD,CAAC,CAAC,CAAC;QAEJ,OAAO;YACN,MAAM,EAAE,yBAAyB,CAAC,OAAO;YACzC,IAAI,EAAE;gBACL,GAAG,EAAE,UAAU;aACf;SACD,CAAC;IACH,CAAC;CACD"}
|
|
@@ -0,0 +1,43 @@
|
|
|
1
|
+
import type { ApiRouteLimits, ApiRoutes, ApiRoutesProvider } from "@prosopo/api-route";
|
|
2
|
+
import type { Logger } from "@prosopo/common";
|
|
3
|
+
import { FetchRulesEndpoint } from "#policy/api/read/fetchRules.js";
|
|
4
|
+
import { FindRuleIdsEndpoint } from "#policy/api/read/findRuleIds.js";
|
|
5
|
+
import { GetMissingIdsEndpoint } from "#policy/api/read/getMissingIds.js";
|
|
6
|
+
import { RehashRulesEndpoint } from "#policy/api/write/rehashRules.js";
|
|
7
|
+
import type { AccessRulesStorage } from "#policy/rulesStorage.js";
|
|
8
|
+
import { DeleteAllRulesEndpoint } from "./delete/deleteAllRules.js";
|
|
9
|
+
import { DeleteRuleGroupsEndpoint } from "./delete/deleteRuleGroups.js";
|
|
10
|
+
import { DeleteRulesEndpoint } from "./delete/deleteRules.js";
|
|
11
|
+
import { InsertRulesEndpoint } from "./write/insertRules.js";
|
|
12
|
+
export declare enum accessRuleApiPaths {
|
|
13
|
+
DELETE_ALL = "/v1/prosopo/user-access-policy/rules/delete-all",
|
|
14
|
+
DELETE_GROUPS = "/v1/prosopo/user-access-policy/rules/delete-groups",
|
|
15
|
+
DELETE_MANY = "/v1/prosopo/user-access-policy/rules/delete-many",
|
|
16
|
+
FETCH_MANY = "/v1/prosopo/user-access-policy/rules/fetch-many",
|
|
17
|
+
FIND_IDS = "/v1/prosopo/user-access-policy/rules/find-ids",
|
|
18
|
+
GET_MISSING_IDS = "/v1/prosopo/user-access-policy/rules/get-missing-ids",
|
|
19
|
+
INSERT_MANY = "/v1/prosopo/user-access-policy/rules/insert-many",
|
|
20
|
+
REHASH_ALL = "/v1/prosopo/user-access-policy/rules/rehash-all"
|
|
21
|
+
}
|
|
22
|
+
export declare class AccessRuleApiRoutes implements ApiRoutesProvider {
|
|
23
|
+
private readonly accessRulesStorage;
|
|
24
|
+
private readonly logger;
|
|
25
|
+
constructor(accessRulesStorage: AccessRulesStorage, logger: Logger);
|
|
26
|
+
getRoutes(): ApiRoutes;
|
|
27
|
+
protected makeDeleteEndpoints(): {
|
|
28
|
+
"/v1/prosopo/user-access-policy/rules/delete-all": DeleteAllRulesEndpoint;
|
|
29
|
+
"/v1/prosopo/user-access-policy/rules/delete-groups": DeleteRuleGroupsEndpoint;
|
|
30
|
+
"/v1/prosopo/user-access-policy/rules/delete-many": DeleteRulesEndpoint;
|
|
31
|
+
};
|
|
32
|
+
protected makeReadEndpoints(): {
|
|
33
|
+
"/v1/prosopo/user-access-policy/rules/fetch-many": FetchRulesEndpoint;
|
|
34
|
+
"/v1/prosopo/user-access-policy/rules/find-ids": FindRuleIdsEndpoint;
|
|
35
|
+
"/v1/prosopo/user-access-policy/rules/get-missing-ids": GetMissingIdsEndpoint;
|
|
36
|
+
};
|
|
37
|
+
protected makeWriteEndpoints(): {
|
|
38
|
+
"/v1/prosopo/user-access-policy/rules/insert-many": InsertRulesEndpoint;
|
|
39
|
+
"/v1/prosopo/user-access-policy/rules/rehash-all": RehashRulesEndpoint;
|
|
40
|
+
};
|
|
41
|
+
}
|
|
42
|
+
export declare const getExpressApiRuleRateLimits: () => ApiRouteLimits<accessRuleApiPaths>;
|
|
43
|
+
//# sourceMappingURL=ruleApiRoutes.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"ruleApiRoutes.d.ts","sourceRoot":"","sources":["../../src/api/ruleApiRoutes.ts"],"names":[],"mappings":"AAcA,OAAO,KAAK,EACX,cAAc,EACd,SAAS,EACT,iBAAiB,EACjB,MAAM,oBAAoB,CAAC;AAC5B,OAAO,KAAK,EAAiB,MAAM,EAAE,MAAM,iBAAiB,CAAC;AAC7D,OAAO,EAAE,kBAAkB,EAAE,MAAM,gCAAgC,CAAC;AACpE,OAAO,EAAE,mBAAmB,EAAE,MAAM,iCAAiC,CAAC;AACtE,OAAO,EAAE,qBAAqB,EAAE,MAAM,mCAAmC,CAAC;AAC1E,OAAO,EAAE,mBAAmB,EAAE,MAAM,kCAAkC,CAAC;AACvE,OAAO,KAAK,EAAE,kBAAkB,EAAE,MAAM,yBAAyB,CAAC;AAClE,OAAO,EAAE,sBAAsB,EAAE,MAAM,4BAA4B,CAAC;AACpE,OAAO,EAAE,wBAAwB,EAAE,MAAM,8BAA8B,CAAC;AACxE,OAAO,EAAE,mBAAmB,EAAE,MAAM,yBAAyB,CAAC;AAC9D,OAAO,EAAE,mBAAmB,EAAE,MAAM,wBAAwB,CAAC;AAE7D,oBAAY,kBAAkB;IAE7B,UAAU,oDAAoD;IAC9D,aAAa,uDAAuD;IACpE,WAAW,qDAAqD;IAEhE,UAAU,oDAAoD;IAC9D,QAAQ,kDAAkD;IAC1D,eAAe,yDAAyD;IAExE,WAAW,qDAAqD;IAChE,UAAU,oDAAoD;CAC9D;AAED,qBAAa,mBAAoB,YAAW,iBAAiB;IAE3D,OAAO,CAAC,QAAQ,CAAC,kBAAkB;IACnC,OAAO,CAAC,QAAQ,CAAC,MAAM;gBADN,kBAAkB,EAAE,kBAAkB,EACtC,MAAM,EAAE,MAAM;IAGzB,SAAS,IAAI,SAAS;IAQ7B,SAAS,CAAC,mBAAmB;;;;;IAiB7B,SAAS,CAAC,iBAAiB;;;;;IAiB3B,SAAS,CAAC,kBAAkB;;;;CAY5B;AAED,eAAO,MAAM,2BAA2B,QACnC,cAAc,CAAC,kBAAkB,CAyBpC,CAAC"}
|