@prosopo/user-access-policy 2.6.4 → 3.1.5
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 +80 -0
- package/dist/accessPolicy.d.ts +169 -0
- package/dist/accessPolicy.d.ts.map +1 -0
- package/dist/accessPolicy.js +65 -0
- package/dist/accessPolicy.js.map +1 -0
- package/dist/accessPolicyResolver.d.ts +115 -0
- package/dist/accessPolicyResolver.d.ts.map +1 -0
- package/dist/accessPolicyResolver.js +44 -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 +8 -0
- package/dist/accessRules.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 +56 -0
- package/dist/api/accessRuleApiRoutes.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 +21 -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 +31 -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 +62 -0
- package/dist/api/insertRulesEndpoint.js.map +1 -0
- package/dist/cjs/accessPolicy.cjs +79 -0
- package/dist/cjs/accessPolicyResolver.cjs +87 -0
- package/dist/cjs/accessRules.cjs +11 -0
- package/dist/cjs/api/accessRuleApiRoutes.cjs +79 -0
- package/dist/cjs/api/deleteAllRulesEndpoint.cjs +24 -0
- package/dist/cjs/api/deleteRulesEndpoint.cjs +34 -0
- package/dist/cjs/api/insertRulesEndpoint.cjs +65 -0
- package/dist/cjs/index.cjs +22 -23
- package/dist/cjs/redis/redisAccessRules.cjs +140 -0
- package/dist/cjs/redis/redisAccessRulesIndex.cjs +103 -0
- package/dist/cjs/redis/redisIndex.cjs +22 -0
- package/dist/cjs/util.cjs +5 -0
- package/dist/index.d.ts +13 -15
- package/dist/index.d.ts.map +1 -1
- package/dist/index.js +14 -20
- package/dist/index.js.map +1 -1
- package/dist/redis/redisAccessRules.d.ts +7 -0
- package/dist/redis/redisAccessRules.d.ts.map +1 -0
- package/dist/redis/redisAccessRules.js +105 -0
- package/dist/redis/redisAccessRules.js.map +1 -0
- package/dist/redis/redisAccessRulesIndex.d.ts +12 -0
- package/dist/redis/redisAccessRulesIndex.d.ts.map +1 -0
- package/dist/redis/redisAccessRulesIndex.js +81 -0
- package/dist/redis/redisAccessRulesIndex.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/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/redisAccessRules.test.d.ts +2 -0
- package/dist/tests/redis/redisAccessRules.test.d.ts.map +1 -0
- package/dist/tests/redis/redisAccessRules.test.js +398 -0
- package/dist/tests/redis/redisAccessRules.test.js.map +1 -0
- package/dist/tests/redis/redisIndex.test.d.ts +2 -0
- package/dist/tests/redis/redisIndex.test.d.ts.map +1 -0
- package/dist/tests/redis/redisIndex.test.js +84 -0
- package/dist/tests/redis/redisIndex.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/util.d.ts +2 -0
- package/dist/util.d.ts.map +1 -0
- package/dist/util.js +3 -0
- package/dist/util.js.map +1 -0
- package/package.json +16 -14
- package/vite.cjs.config.ts +4 -6
- package/vite.config.ts +39 -0
- package/vite.test.config.ts +2 -1
- package/dist/blacklistInspector.d.ts +0 -6
- package/dist/blacklistInspector.d.ts.map +0 -1
- package/dist/blacklistInspector.js +0 -2
- package/dist/blacklistInspector.js.map +0 -1
- package/dist/cjs/rules/api/apiRulePaths.cjs +0 -7
- package/dist/cjs/rules/api/apiRuleRoutesProvider.cjs +0 -23
- package/dist/cjs/rules/api/deleteMany/apiDeleteManyRulesArgsSchema.cjs +0 -13
- package/dist/cjs/rules/api/deleteMany/apiDeleteManyRulesEndpoint.cjs +0 -19
- package/dist/cjs/rules/api/getExpressApiRuleRateLimits.cjs +0 -18
- package/dist/cjs/rules/api/insertMany/apiInsertManyRulesArgsSchema.cjs +0 -39
- package/dist/cjs/rules/api/insertMany/apiInsertManyRulesEndpoint.cjs +0 -193
- package/dist/cjs/rules/blacklistRulesInspector.cjs +0 -44
- package/dist/cjs/rules/imageCaptchaConfigRulesResolver.cjs +0 -115
- package/dist/cjs/rules/mongoose/indexes/rulePerformanceMongooseIndexes.cjs +0 -75
- package/dist/cjs/rules/mongoose/indexes/ruleUniqueMongooseIndexes.cjs +0 -137
- package/dist/cjs/rules/mongoose/rulesMongooseStorage.cjs +0 -177
- package/dist/cjs/rules/mongoose/schemas/config/configMongooseSchema.cjs +0 -14
- package/dist/cjs/rules/mongoose/schemas/config/imageCaptchaConfigMongooseSchema.cjs +0 -17
- package/dist/cjs/rules/mongoose/schemas/getRuleMongooseSchema.cjs +0 -19
- package/dist/cjs/rules/mongoose/schemas/ip/ipMongooseSchema.cjs +0 -29
- package/dist/cjs/rules/mongoose/schemas/ip/v4/ipV4MaskMongooseSchema.cjs +0 -14
- package/dist/cjs/rules/mongoose/schemas/ip/v4/ipV4MongooseSchema.cjs +0 -18
- package/dist/cjs/rules/mongoose/schemas/ip/v6/ipV6MaskMongooseSchema.cjs +0 -34
- package/dist/cjs/rules/mongoose/schemas/ip/v6/ipV6MongooseSchema.cjs +0 -33
- package/dist/cjs/rules/mongoose/schemas/ruleMongooseSchema.cjs +0 -43
- package/dist/cjs/rules/rule/config/imageCaptcha/imageCaptchaConfigSchema.cjs +0 -8
- package/dist/cjs/rules/rule/config/ruleConfigSchema.cjs +0 -8
- package/dist/cjs/rules/rule/ip/ruleIpSchema.cjs +0 -10
- package/dist/cjs/rules/rule/ip/ruleIpVersion.cjs +0 -8
- package/dist/cjs/rules/rule/ip/v4/mask/ruleIpV4MaskSchema.cjs +0 -9
- package/dist/cjs/rules/rule/ip/v4/ruleIpV4Schema.cjs +0 -10
- package/dist/cjs/rules/rule/ip/v6/mask/ruleIpV6MaskSchema.cjs +0 -9
- package/dist/cjs/rules/rule/ip/v6/ruleIpV6NumericMaxLength.cjs +0 -4
- package/dist/cjs/rules/rule/ip/v6/ruleIpV6Schema.cjs +0 -10
- package/dist/imageCaptchaConfigResolver.d.ts +0 -7
- package/dist/imageCaptchaConfigResolver.d.ts.map +0 -1
- package/dist/imageCaptchaConfigResolver.js +0 -2
- package/dist/imageCaptchaConfigResolver.js.map +0 -1
- package/dist/rules/api/apiRulePaths.d.ts +0 -5
- package/dist/rules/api/apiRulePaths.d.ts.map +0 -1
- package/dist/rules/api/apiRulePaths.js +0 -5
- package/dist/rules/api/apiRulePaths.js.map +0 -1
- package/dist/rules/api/apiRuleRoutesProvider.d.ts +0 -9
- package/dist/rules/api/apiRuleRoutesProvider.d.ts.map +0 -1
- package/dist/rules/api/apiRuleRoutesProvider.js +0 -22
- package/dist/rules/api/apiRuleRoutesProvider.js.map +0 -1
- package/dist/rules/api/deleteMany/apiDeleteManyRulesArgsSchema.d.ts +0 -162
- package/dist/rules/api/deleteMany/apiDeleteManyRulesArgsSchema.d.ts.map +0 -1
- package/dist/rules/api/deleteMany/apiDeleteManyRulesArgsSchema.js +0 -10
- package/dist/rules/api/deleteMany/apiDeleteManyRulesArgsSchema.js.map +0 -1
- package/dist/rules/api/deleteMany/apiDeleteManyRulesEndpoint.d.ts +0 -12
- package/dist/rules/api/deleteMany/apiDeleteManyRulesEndpoint.d.ts.map +0 -1
- package/dist/rules/api/deleteMany/apiDeleteManyRulesEndpoint.js +0 -18
- package/dist/rules/api/deleteMany/apiDeleteManyRulesEndpoint.js.map +0 -1
- package/dist/rules/api/getExpressApiRuleRateLimits.d.ts +0 -8
- package/dist/rules/api/getExpressApiRuleRateLimits.d.ts.map +0 -1
- package/dist/rules/api/getExpressApiRuleRateLimits.js +0 -21
- package/dist/rules/api/getExpressApiRuleRateLimits.js.map +0 -1
- package/dist/rules/api/insertMany/apiInsertManyRulesArgsSchema.d.ts +0 -163
- package/dist/rules/api/insertMany/apiInsertManyRulesArgsSchema.d.ts.map +0 -1
- package/dist/rules/api/insertMany/apiInsertManyRulesArgsSchema.js +0 -37
- package/dist/rules/api/insertMany/apiInsertManyRulesArgsSchema.js.map +0 -1
- package/dist/rules/api/insertMany/apiInsertManyRulesEndpoint.d.ts +0 -18
- package/dist/rules/api/insertMany/apiInsertManyRulesEndpoint.d.ts.map +0 -1
- package/dist/rules/api/insertMany/apiInsertManyRulesEndpoint.js +0 -195
- package/dist/rules/api/insertMany/apiInsertManyRulesEndpoint.js.map +0 -1
- package/dist/rules/blacklistRulesInspector.d.ts +0 -12
- package/dist/rules/blacklistRulesInspector.d.ts.map +0 -1
- package/dist/rules/blacklistRulesInspector.js +0 -38
- package/dist/rules/blacklistRulesInspector.js.map +0 -1
- package/dist/rules/imageCaptchaConfigRulesResolver.d.ts +0 -21
- package/dist/rules/imageCaptchaConfigRulesResolver.d.ts.map +0 -1
- package/dist/rules/imageCaptchaConfigRulesResolver.js +0 -92
- package/dist/rules/imageCaptchaConfigRulesResolver.js.map +0 -1
- package/dist/rules/mongoose/indexes/mongooseIndex.d.ts +0 -7
- package/dist/rules/mongoose/indexes/mongooseIndex.d.ts.map +0 -1
- package/dist/rules/mongoose/indexes/mongooseIndex.js +0 -2
- package/dist/rules/mongoose/indexes/mongooseIndex.js.map +0 -1
- package/dist/rules/mongoose/indexes/rulePerformanceMongooseIndexes.d.ts +0 -4
- package/dist/rules/mongoose/indexes/rulePerformanceMongooseIndexes.d.ts.map +0 -1
- package/dist/rules/mongoose/indexes/rulePerformanceMongooseIndexes.js +0 -74
- package/dist/rules/mongoose/indexes/rulePerformanceMongooseIndexes.js.map +0 -1
- package/dist/rules/mongoose/indexes/ruleUniqueMongooseIndexes.d.ts +0 -4
- package/dist/rules/mongoose/indexes/ruleUniqueMongooseIndexes.d.ts.map +0 -1
- package/dist/rules/mongoose/indexes/ruleUniqueMongooseIndexes.js +0 -136
- package/dist/rules/mongoose/indexes/ruleUniqueMongooseIndexes.js.map +0 -1
- package/dist/rules/mongoose/ruleMongooseRecord.d.ts +0 -7
- package/dist/rules/mongoose/ruleMongooseRecord.d.ts.map +0 -1
- package/dist/rules/mongoose/ruleMongooseRecord.js +0 -2
- package/dist/rules/mongoose/ruleMongooseRecord.js.map +0 -1
- package/dist/rules/mongoose/rulesMongooseStorage.d.ts +0 -30
- package/dist/rules/mongoose/rulesMongooseStorage.d.ts.map +0 -1
- package/dist/rules/mongoose/rulesMongooseStorage.js +0 -177
- package/dist/rules/mongoose/rulesMongooseStorage.js.map +0 -1
- package/dist/rules/mongoose/schemas/config/configMongooseSchema.d.ts +0 -43
- package/dist/rules/mongoose/schemas/config/configMongooseSchema.d.ts.map +0 -1
- package/dist/rules/mongoose/schemas/config/configMongooseSchema.js +0 -10
- package/dist/rules/mongoose/schemas/config/configMongooseSchema.js.map +0 -1
- package/dist/rules/mongoose/schemas/config/imageCaptchaConfigMongooseSchema.d.ts +0 -29
- package/dist/rules/mongoose/schemas/config/imageCaptchaConfigMongooseSchema.d.ts.map +0 -1
- package/dist/rules/mongoose/schemas/config/imageCaptchaConfigMongooseSchema.js +0 -13
- package/dist/rules/mongoose/schemas/config/imageCaptchaConfigMongooseSchema.js.map +0 -1
- package/dist/rules/mongoose/schemas/getRuleMongooseSchema.d.ts +0 -5
- package/dist/rules/mongoose/schemas/getRuleMongooseSchema.d.ts.map +0 -1
- package/dist/rules/mongoose/schemas/getRuleMongooseSchema.js +0 -15
- package/dist/rules/mongoose/schemas/getRuleMongooseSchema.js.map +0 -1
- package/dist/rules/mongoose/schemas/ip/ipMongooseSchema.d.ts +0 -141
- package/dist/rules/mongoose/schemas/ip/ipMongooseSchema.d.ts.map +0 -1
- package/dist/rules/mongoose/schemas/ip/ipMongooseSchema.js +0 -25
- package/dist/rules/mongoose/schemas/ip/ipMongooseSchema.js.map +0 -1
- package/dist/rules/mongoose/schemas/ip/v4/ipV4MaskMongooseSchema.d.ts +0 -36
- package/dist/rules/mongoose/schemas/ip/v4/ipV4MaskMongooseSchema.d.ts.map +0 -1
- package/dist/rules/mongoose/schemas/ip/v4/ipV4MaskMongooseSchema.js +0 -8
- package/dist/rules/mongoose/schemas/ip/v4/ipV4MaskMongooseSchema.js.map +0 -1
- package/dist/rules/mongoose/schemas/ip/v4/ipV4MongooseSchema.d.ts +0 -64
- package/dist/rules/mongoose/schemas/ip/v4/ipV4MongooseSchema.d.ts.map +0 -1
- package/dist/rules/mongoose/schemas/ip/v4/ipV4MongooseSchema.js +0 -12
- package/dist/rules/mongoose/schemas/ip/v4/ipV4MongooseSchema.js.map +0 -1
- package/dist/rules/mongoose/schemas/ip/v6/ipV6MaskMongooseSchema.d.ts +0 -36
- package/dist/rules/mongoose/schemas/ip/v6/ipV6MaskMongooseSchema.d.ts.map +0 -1
- package/dist/rules/mongoose/schemas/ip/v6/ipV6MaskMongooseSchema.js +0 -17
- package/dist/rules/mongoose/schemas/ip/v6/ipV6MaskMongooseSchema.js.map +0 -1
- package/dist/rules/mongoose/schemas/ip/v6/ipV6MongooseSchema.d.ts +0 -64
- package/dist/rules/mongoose/schemas/ip/v6/ipV6MongooseSchema.d.ts.map +0 -1
- package/dist/rules/mongoose/schemas/ip/v6/ipV6MongooseSchema.js +0 -17
- package/dist/rules/mongoose/schemas/ip/v6/ipV6MongooseSchema.js.map +0 -1
- package/dist/rules/mongoose/schemas/ruleMongooseSchema.d.ts +0 -9
- package/dist/rules/mongoose/schemas/ruleMongooseSchema.d.ts.map +0 -1
- package/dist/rules/mongoose/schemas/ruleMongooseSchema.js +0 -42
- package/dist/rules/mongoose/schemas/ruleMongooseSchema.js.map +0 -1
- package/dist/rules/rule/config/imageCaptcha/imageCaptchaConfig.d.ts +0 -5
- package/dist/rules/rule/config/imageCaptcha/imageCaptchaConfig.d.ts.map +0 -1
- package/dist/rules/rule/config/imageCaptcha/imageCaptchaConfig.js +0 -2
- package/dist/rules/rule/config/imageCaptcha/imageCaptchaConfig.js.map +0 -1
- package/dist/rules/rule/config/imageCaptcha/imageCaptchaConfigSchema.d.ts +0 -12
- package/dist/rules/rule/config/imageCaptcha/imageCaptchaConfigSchema.d.ts.map +0 -1
- package/dist/rules/rule/config/imageCaptcha/imageCaptchaConfigSchema.js +0 -7
- package/dist/rules/rule/config/imageCaptcha/imageCaptchaConfigSchema.js.map +0 -1
- package/dist/rules/rule/config/ruleConfig.d.ts +0 -5
- package/dist/rules/rule/config/ruleConfig.d.ts.map +0 -1
- package/dist/rules/rule/config/ruleConfig.js +0 -2
- package/dist/rules/rule/config/ruleConfig.js.map +0 -1
- package/dist/rules/rule/config/ruleConfigSchema.d.ts +0 -24
- package/dist/rules/rule/config/ruleConfigSchema.d.ts.map +0 -1
- package/dist/rules/rule/config/ruleConfigSchema.js +0 -7
- package/dist/rules/rule/config/ruleConfigSchema.js.map +0 -1
- package/dist/rules/rule/ip/ruleIp.d.ts +0 -5
- package/dist/rules/rule/ip/ruleIp.d.ts.map +0 -1
- package/dist/rules/rule/ip/ruleIp.js +0 -2
- package/dist/rules/rule/ip/ruleIp.js.map +0 -1
- package/dist/rules/rule/ip/ruleIpSchema.d.ts +0 -108
- package/dist/rules/rule/ip/ruleIpSchema.d.ts.map +0 -1
- package/dist/rules/rule/ip/ruleIpSchema.js +0 -9
- package/dist/rules/rule/ip/ruleIpSchema.js.map +0 -1
- package/dist/rules/rule/ip/ruleIpVersion.d.ts +0 -6
- package/dist/rules/rule/ip/ruleIpVersion.d.ts.map +0 -1
- package/dist/rules/rule/ip/ruleIpVersion.js +0 -7
- package/dist/rules/rule/ip/ruleIpVersion.js.map +0 -1
- package/dist/rules/rule/ip/v4/mask/ruleIpV4Mask.d.ts +0 -5
- package/dist/rules/rule/ip/v4/mask/ruleIpV4Mask.d.ts.map +0 -1
- package/dist/rules/rule/ip/v4/mask/ruleIpV4Mask.js +0 -2
- package/dist/rules/rule/ip/v4/mask/ruleIpV4Mask.js.map +0 -1
- package/dist/rules/rule/ip/v4/mask/ruleIpV4MaskSchema.d.ts +0 -15
- package/dist/rules/rule/ip/v4/mask/ruleIpV4MaskSchema.d.ts.map +0 -1
- package/dist/rules/rule/ip/v4/mask/ruleIpV4MaskSchema.js +0 -8
- package/dist/rules/rule/ip/v4/mask/ruleIpV4MaskSchema.js.map +0 -1
- package/dist/rules/rule/ip/v4/ruleIpV4.d.ts +0 -5
- package/dist/rules/rule/ip/v4/ruleIpV4.d.ts.map +0 -1
- package/dist/rules/rule/ip/v4/ruleIpV4.js +0 -2
- package/dist/rules/rule/ip/v4/ruleIpV4.js.map +0 -1
- package/dist/rules/rule/ip/v4/ruleIpV4Schema.d.ts +0 -35
- package/dist/rules/rule/ip/v4/ruleIpV4Schema.d.ts.map +0 -1
- package/dist/rules/rule/ip/v4/ruleIpV4Schema.js +0 -9
- package/dist/rules/rule/ip/v4/ruleIpV4Schema.js.map +0 -1
- package/dist/rules/rule/ip/v6/mask/ruleIpV6Mask.d.ts +0 -5
- package/dist/rules/rule/ip/v6/mask/ruleIpV6Mask.d.ts.map +0 -1
- package/dist/rules/rule/ip/v6/mask/ruleIpV6Mask.js +0 -2
- package/dist/rules/rule/ip/v6/mask/ruleIpV6Mask.js.map +0 -1
- package/dist/rules/rule/ip/v6/mask/ruleIpV6MaskSchema.d.ts +0 -15
- package/dist/rules/rule/ip/v6/mask/ruleIpV6MaskSchema.d.ts.map +0 -1
- package/dist/rules/rule/ip/v6/mask/ruleIpV6MaskSchema.js +0 -8
- package/dist/rules/rule/ip/v6/mask/ruleIpV6MaskSchema.js.map +0 -1
- package/dist/rules/rule/ip/v6/ruleIpV6.d.ts +0 -5
- package/dist/rules/rule/ip/v6/ruleIpV6.d.ts.map +0 -1
- package/dist/rules/rule/ip/v6/ruleIpV6.js +0 -2
- package/dist/rules/rule/ip/v6/ruleIpV6.js.map +0 -1
- package/dist/rules/rule/ip/v6/ruleIpV6NumericMaxLength.d.ts +0 -3
- package/dist/rules/rule/ip/v6/ruleIpV6NumericMaxLength.d.ts.map +0 -1
- package/dist/rules/rule/ip/v6/ruleIpV6NumericMaxLength.js +0 -3
- package/dist/rules/rule/ip/v6/ruleIpV6NumericMaxLength.js.map +0 -1
- package/dist/rules/rule/ip/v6/ruleIpV6Schema.d.ts +0 -35
- package/dist/rules/rule/ip/v6/ruleIpV6Schema.d.ts.map +0 -1
- package/dist/rules/rule/ip/v6/ruleIpV6Schema.js +0 -9
- package/dist/rules/rule/ip/v6/ruleIpV6Schema.js.map +0 -1
- package/dist/rules/rule/rule.d.ts +0 -14
- package/dist/rules/rule/rule.d.ts.map +0 -1
- package/dist/rules/rule/rule.js +0 -2
- package/dist/rules/rule/rule.js.map +0 -1
- package/dist/rules/storage/filters/deleteRuleFilters.d.ts +0 -9
- package/dist/rules/storage/filters/deleteRuleFilters.d.ts.map +0 -1
- package/dist/rules/storage/filters/deleteRuleFilters.js +0 -2
- package/dist/rules/storage/filters/deleteRuleFilters.js.map +0 -1
- package/dist/rules/storage/filters/search/searchRuleFilterSettings.d.ts +0 -6
- package/dist/rules/storage/filters/search/searchRuleFilterSettings.d.ts.map +0 -1
- package/dist/rules/storage/filters/search/searchRuleFilterSettings.js +0 -2
- package/dist/rules/storage/filters/search/searchRuleFilterSettings.js.map +0 -1
- package/dist/rules/storage/filters/search/searchRuleFilters.d.ts +0 -9
- package/dist/rules/storage/filters/search/searchRuleFilters.d.ts.map +0 -1
- package/dist/rules/storage/filters/search/searchRuleFilters.js +0 -2
- package/dist/rules/storage/filters/search/searchRuleFilters.js.map +0 -1
- package/dist/rules/storage/ruleRecord.d.ts +0 -6
- package/dist/rules/storage/ruleRecord.d.ts.map +0 -1
- package/dist/rules/storage/ruleRecord.js +0 -2
- package/dist/rules/storage/ruleRecord.js.map +0 -1
- package/dist/rules/storage/rulesStorage.d.ts +0 -14
- package/dist/rules/storage/rulesStorage.d.ts.map +0 -1
- package/dist/rules/storage/rulesStorage.js +0 -2
- package/dist/rules/storage/rulesStorage.js.map +0 -1
- package/dist/tests/benchmark/commands/commandBase.d.ts +0 -14
- package/dist/tests/benchmark/commands/commandBase.d.ts.map +0 -1
- package/dist/tests/benchmark/commands/commandBase.js +0 -22
- package/dist/tests/benchmark/commands/commandBase.js.map +0 -1
- package/dist/tests/benchmark/commands/measureFindCommand.d.ts +0 -14
- package/dist/tests/benchmark/commands/measureFindCommand.d.ts.map +0 -1
- package/dist/tests/benchmark/commands/measureFindCommand.js +0 -60
- package/dist/tests/benchmark/commands/measureFindCommand.js.map +0 -1
- package/dist/tests/benchmark/commands/populateCommand.d.ts +0 -18
- package/dist/tests/benchmark/commands/populateCommand.d.ts.map +0 -1
- package/dist/tests/benchmark/commands/populateCommand.js +0 -97
- package/dist/tests/benchmark/commands/populateCommand.js.map +0 -1
- package/dist/tests/benchmark/connectionCleaner/connectionCleaner.d.ts +0 -5
- package/dist/tests/benchmark/connectionCleaner/connectionCleaner.d.ts.map +0 -1
- package/dist/tests/benchmark/connectionCleaner/connectionCleaner.js +0 -2
- package/dist/tests/benchmark/connectionCleaner/connectionCleaner.js.map +0 -1
- package/dist/tests/benchmark/connectionCleaner/mongooseConnectionCleaner.d.ts +0 -6
- package/dist/tests/benchmark/connectionCleaner/mongooseConnectionCleaner.d.ts.map +0 -1
- package/dist/tests/benchmark/connectionCleaner/mongooseConnectionCleaner.js +0 -8
- package/dist/tests/benchmark/connectionCleaner/mongooseConnectionCleaner.js.map +0 -1
- package/dist/tests/benchmark/mongooseRulesStorageBenchmark.d.ts +0 -2
- package/dist/tests/benchmark/mongooseRulesStorageBenchmark.d.ts.map +0 -1
- package/dist/tests/benchmark/mongooseRulesStorageBenchmark.js +0 -8
- package/dist/tests/benchmark/mongooseRulesStorageBenchmark.js.map +0 -1
- package/dist/tests/benchmark/rulesStorageBenchmark.d.ts +0 -12
- package/dist/tests/benchmark/rulesStorageBenchmark.d.ts.map +0 -1
- package/dist/tests/benchmark/rulesStorageBenchmark.js +0 -30
- package/dist/tests/benchmark/rulesStorageBenchmark.js.map +0 -1
- package/dist/tests/benchmark/storageFactory/mongooseRulesStorageFactory.d.ts +0 -10
- package/dist/tests/benchmark/storageFactory/mongooseRulesStorageFactory.d.ts.map +0 -1
- package/dist/tests/benchmark/storageFactory/mongooseRulesStorageFactory.js +0 -16
- package/dist/tests/benchmark/storageFactory/mongooseRulesStorageFactory.js.map +0 -1
- package/dist/tests/benchmark/storageFactory/rulesStorageFactory.d.ts +0 -6
- package/dist/tests/benchmark/storageFactory/rulesStorageFactory.d.ts.map +0 -1
- package/dist/tests/benchmark/storageFactory/rulesStorageFactory.js +0 -2
- package/dist/tests/benchmark/storageFactory/rulesStorageFactory.js.map +0 -1
- package/dist/tests/rules/ImageCaptchaConfigRulesResolver.test.d.ts +0 -2
- package/dist/tests/rules/ImageCaptchaConfigRulesResolver.test.d.ts.map +0 -1
- package/dist/tests/rules/ImageCaptchaConfigRulesResolver.test.js +0 -75
- package/dist/tests/rules/ImageCaptchaConfigRulesResolver.test.js.map +0 -1
- package/dist/tests/rules/blacklistRulesInspector.unit.test.d.ts +0 -2
- package/dist/tests/rules/blacklistRulesInspector.unit.test.d.ts.map +0 -1
- package/dist/tests/rules/blacklistRulesInspector.unit.test.js +0 -58
- package/dist/tests/rules/blacklistRulesInspector.unit.test.js.map +0 -1
- package/dist/tests/rules/loggerMockedInstance.d.ts +0 -13
- package/dist/tests/rules/loggerMockedInstance.d.ts.map +0 -1
- package/dist/tests/rules/loggerMockedInstance.js +0 -14
- package/dist/tests/rules/loggerMockedInstance.js.map +0 -1
- package/dist/tests/rules/mongoose/find.unit.test.d.ts +0 -2
- package/dist/tests/rules/mongoose/find.unit.test.d.ts.map +0 -1
- package/dist/tests/rules/mongoose/find.unit.test.js +0 -202
- package/dist/tests/rules/mongoose/find.unit.test.js.map +0 -1
- package/dist/tests/rules/mongoose/insert/insertIpV6Formatting.unit.test.d.ts +0 -2
- package/dist/tests/rules/mongoose/insert/insertIpV6Formatting.unit.test.d.ts.map +0 -1
- package/dist/tests/rules/mongoose/insert/insertIpV6Formatting.unit.test.js +0 -131
- package/dist/tests/rules/mongoose/insert/insertIpV6Formatting.unit.test.js.map +0 -1
- package/dist/tests/rules/mongoose/insert/insertValidation.unit.test.d.ts +0 -2
- package/dist/tests/rules/mongoose/insert/insertValidation.unit.test.d.ts.map +0 -1
- package/dist/tests/rules/mongoose/insert/insertValidation.unit.test.js +0 -101
- package/dist/tests/rules/mongoose/insert/insertValidation.unit.test.js.map +0 -1
- package/dist/tests/rules/mongoose/ip.unit.test.d.ts +0 -2
- package/dist/tests/rules/mongoose/ip.unit.test.d.ts.map +0 -1
- package/dist/tests/rules/mongoose/ip.unit.test.js +0 -380
- package/dist/tests/rules/mongoose/ip.unit.test.js.map +0 -1
- package/dist/tests/rules/storage/testRulesStorage.d.ts +0 -17
- package/dist/tests/rules/storage/testRulesStorage.d.ts.map +0 -1
- package/dist/tests/rules/storage/testRulesStorage.js +0 -25
- package/dist/tests/rules/storage/testRulesStorage.js.map +0 -1
package/dist/cjs/index.cjs
CHANGED
|
@@ -1,28 +1,27 @@
|
|
|
1
1
|
"use strict";
|
|
2
2
|
Object.defineProperty(exports, Symbol.toStringTag, { value: "Module" });
|
|
3
|
-
const
|
|
4
|
-
const
|
|
5
|
-
const
|
|
6
|
-
const
|
|
7
|
-
const
|
|
8
|
-
const
|
|
9
|
-
const
|
|
10
|
-
const
|
|
11
|
-
return new blacklistRulesInspector.BlacklistRulesInspector(rulesStorage, logger);
|
|
12
|
-
};
|
|
13
|
-
const createImageCaptchaConfigResolver = (rulesStorage, logger) => {
|
|
14
|
-
return new imageCaptchaConfigRulesResolver.ImageCaptchaConfigRulesResolver(rulesStorage, logger);
|
|
15
|
-
};
|
|
3
|
+
const accessPolicy = require("./accessPolicy.cjs");
|
|
4
|
+
const accessPolicyResolver = require("./accessPolicyResolver.cjs");
|
|
5
|
+
const accessRuleApiRoutes = require("./api/accessRuleApiRoutes.cjs");
|
|
6
|
+
const deleteAllRulesEndpoint = require("./api/deleteAllRulesEndpoint.cjs");
|
|
7
|
+
const deleteRulesEndpoint = require("./api/deleteRulesEndpoint.cjs");
|
|
8
|
+
const insertRulesEndpoint = require("./api/insertRulesEndpoint.cjs");
|
|
9
|
+
const redisAccessRules = require("./redis/redisAccessRules.cjs");
|
|
10
|
+
const redisAccessRulesIndex = require("./redis/redisAccessRulesIndex.cjs");
|
|
16
11
|
const createApiRuleRoutesProvider = (rulesStorage) => {
|
|
17
|
-
return new
|
|
18
|
-
};
|
|
19
|
-
const createMongooseRulesStorage = (logger, readingModel, writingModel = null) => {
|
|
20
|
-
return new rulesMongooseStorage.RulesMongooseStorage(logger, readingModel, writingModel);
|
|
12
|
+
return new accessRuleApiRoutes.AccessRuleApiRoutes(rulesStorage);
|
|
21
13
|
};
|
|
22
|
-
exports.
|
|
23
|
-
exports.
|
|
24
|
-
exports.
|
|
14
|
+
exports.AccessPolicyType = accessPolicy.AccessPolicyType;
|
|
15
|
+
exports.accessPolicySchema = accessPolicy.accessPolicySchema;
|
|
16
|
+
exports.policyScopeSchema = accessPolicy.policyScopeSchema;
|
|
17
|
+
exports.userScopeInputSchema = accessPolicy.userScopeInputSchema;
|
|
18
|
+
exports.ScopeMatch = accessPolicyResolver.ScopeMatch;
|
|
19
|
+
exports.createAccessPolicyResolver = accessPolicyResolver.createAccessPolicyResolver;
|
|
20
|
+
exports.accessRuleApiPaths = accessRuleApiRoutes.accessRuleApiPaths;
|
|
21
|
+
exports.getExpressApiRuleRateLimits = accessRuleApiRoutes.getExpressApiRuleRateLimits;
|
|
22
|
+
exports.deleteAllRulesEndpointSchema = deleteAllRulesEndpoint.deleteAllRulesEndpointSchema;
|
|
23
|
+
exports.deleteRulesEndpointSchema = deleteRulesEndpoint.deleteRulesEndpointSchema;
|
|
24
|
+
exports.insertRulesEndpointSchema = insertRulesEndpoint.insertRulesEndpointSchema;
|
|
25
|
+
exports.createRedisAccessRulesStorage = redisAccessRules.createRedisAccessRulesStorage;
|
|
26
|
+
exports.createRedisAccessRulesIndex = redisAccessRulesIndex.createRedisAccessRulesIndex;
|
|
25
27
|
exports.createApiRuleRoutesProvider = createApiRuleRoutesProvider;
|
|
26
|
-
exports.createBlacklistInspector = createBlacklistInspector;
|
|
27
|
-
exports.createImageCaptchaConfigResolver = createImageCaptchaConfigResolver;
|
|
28
|
-
exports.createMongooseRulesStorage = createMongooseRulesStorage;
|
|
@@ -0,0 +1,140 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, Symbol.toStringTag, { value: "Module" });
|
|
3
|
+
const util = require("node:util");
|
|
4
|
+
const accessRules = require("../accessRules.cjs");
|
|
5
|
+
const redisAccessRulesIndex = require("./redisAccessRulesIndex.cjs");
|
|
6
|
+
function _interopNamespaceDefault(e) {
|
|
7
|
+
const n = Object.create(null, { [Symbol.toStringTag]: { value: "Module" } });
|
|
8
|
+
if (e) {
|
|
9
|
+
for (const k in e) {
|
|
10
|
+
if (k !== "default") {
|
|
11
|
+
const d = Object.getOwnPropertyDescriptor(e, k);
|
|
12
|
+
Object.defineProperty(n, k, d.get ? d : {
|
|
13
|
+
enumerable: true,
|
|
14
|
+
get: () => e[k]
|
|
15
|
+
});
|
|
16
|
+
}
|
|
17
|
+
}
|
|
18
|
+
}
|
|
19
|
+
n.default = e;
|
|
20
|
+
return Object.freeze(n);
|
|
21
|
+
}
|
|
22
|
+
const util__namespace = /* @__PURE__ */ _interopNamespaceDefault(util);
|
|
23
|
+
const createRedisAccessRulesReader = (client, logger) => {
|
|
24
|
+
return {
|
|
25
|
+
findRules: async (filter) => {
|
|
26
|
+
const query = redisAccessRulesIndex.getRedisAccessRulesQuery(filter);
|
|
27
|
+
let searchReply;
|
|
28
|
+
try {
|
|
29
|
+
searchReply = await client.ft.search(
|
|
30
|
+
redisAccessRulesIndex.accessRulesRedisIndexName,
|
|
31
|
+
query,
|
|
32
|
+
redisAccessRulesIndex.accessRulesRedisSearchOptions
|
|
33
|
+
);
|
|
34
|
+
logger.debug(() => ({
|
|
35
|
+
msg: "Executed search query",
|
|
36
|
+
data: {
|
|
37
|
+
inspect: util__namespace.inspect(
|
|
38
|
+
{
|
|
39
|
+
filter,
|
|
40
|
+
searchReply,
|
|
41
|
+
query
|
|
42
|
+
},
|
|
43
|
+
{ depth: null }
|
|
44
|
+
)
|
|
45
|
+
}
|
|
46
|
+
}));
|
|
47
|
+
} catch (e) {
|
|
48
|
+
logger.error(() => ({
|
|
49
|
+
err: e,
|
|
50
|
+
data: {
|
|
51
|
+
inspect: util__namespace.inspect(
|
|
52
|
+
{
|
|
53
|
+
query,
|
|
54
|
+
filter
|
|
55
|
+
},
|
|
56
|
+
{
|
|
57
|
+
depth: null
|
|
58
|
+
}
|
|
59
|
+
)
|
|
60
|
+
},
|
|
61
|
+
msg: "failed to execute search query"
|
|
62
|
+
}));
|
|
63
|
+
return [];
|
|
64
|
+
}
|
|
65
|
+
return extractAccessRulesFromSearchReply(searchReply, logger);
|
|
66
|
+
},
|
|
67
|
+
findRuleIds: async (filter) => {
|
|
68
|
+
const query = redisAccessRulesIndex.getRedisAccessRulesQuery(filter);
|
|
69
|
+
let searchReply;
|
|
70
|
+
try {
|
|
71
|
+
searchReply = await client.ft.searchNoContent(
|
|
72
|
+
redisAccessRulesIndex.accessRulesRedisIndexName,
|
|
73
|
+
query,
|
|
74
|
+
redisAccessRulesIndex.accessRulesRedisSearchOptions
|
|
75
|
+
);
|
|
76
|
+
} catch (e) {
|
|
77
|
+
logger.error(() => ({
|
|
78
|
+
err: e,
|
|
79
|
+
data: {
|
|
80
|
+
inspect: util__namespace.inspect(
|
|
81
|
+
{
|
|
82
|
+
query,
|
|
83
|
+
filter
|
|
84
|
+
},
|
|
85
|
+
{
|
|
86
|
+
depth: null
|
|
87
|
+
}
|
|
88
|
+
)
|
|
89
|
+
},
|
|
90
|
+
msg: "Failed to execute search query for rule IDs"
|
|
91
|
+
}));
|
|
92
|
+
return [];
|
|
93
|
+
}
|
|
94
|
+
return searchReply.documents;
|
|
95
|
+
}
|
|
96
|
+
};
|
|
97
|
+
};
|
|
98
|
+
const createRedisAccessRulesWriter = (client) => {
|
|
99
|
+
return {
|
|
100
|
+
insertRule: async (rule, expirationSeconds) => {
|
|
101
|
+
const ruleKey = redisAccessRulesIndex.getRedisAccessRuleKey(rule);
|
|
102
|
+
const ruleValue = redisAccessRulesIndex.getRedisAccessRuleValue(rule);
|
|
103
|
+
await client.hSet(ruleKey, ruleValue);
|
|
104
|
+
if (expirationSeconds) {
|
|
105
|
+
await client.expire(ruleKey, expirationSeconds);
|
|
106
|
+
}
|
|
107
|
+
return ruleKey;
|
|
108
|
+
},
|
|
109
|
+
deleteRules: async (ruleIds) => void await client.del(ruleIds),
|
|
110
|
+
deleteAllRules: async () => {
|
|
111
|
+
const keys = await client.keys(`${redisAccessRulesIndex.accessRuleRedisKeyPrefix}*`);
|
|
112
|
+
return keys.length > 0 ? await client.del(keys) : 0;
|
|
113
|
+
}
|
|
114
|
+
};
|
|
115
|
+
};
|
|
116
|
+
const createRedisAccessRulesStorage = (client, logger) => {
|
|
117
|
+
return {
|
|
118
|
+
...createRedisAccessRulesReader(client, logger),
|
|
119
|
+
...createRedisAccessRulesWriter(client)
|
|
120
|
+
};
|
|
121
|
+
};
|
|
122
|
+
const extractAccessRulesFromSearchReply = (searchReply, logger) => {
|
|
123
|
+
const accessRules$1 = [];
|
|
124
|
+
searchReply.documents.map(({ id, value: document }) => {
|
|
125
|
+
const parsedDocument = accessRules.accessRuleSchema.safeParse(document);
|
|
126
|
+
if (parsedDocument.success) {
|
|
127
|
+
accessRules$1.push(parsedDocument.data);
|
|
128
|
+
} else {
|
|
129
|
+
logger.debug(() => ({
|
|
130
|
+
msg: "Failed to parse access rule from search reply",
|
|
131
|
+
id,
|
|
132
|
+
error: parsedDocument.error
|
|
133
|
+
}));
|
|
134
|
+
}
|
|
135
|
+
});
|
|
136
|
+
return accessRules$1;
|
|
137
|
+
};
|
|
138
|
+
exports.createRedisAccessRulesReader = createRedisAccessRulesReader;
|
|
139
|
+
exports.createRedisAccessRulesStorage = createRedisAccessRulesStorage;
|
|
140
|
+
exports.createRedisAccessRulesWriter = createRedisAccessRulesWriter;
|
|
@@ -0,0 +1,103 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, Symbol.toStringTag, { value: "Module" });
|
|
3
|
+
const crypto = require("node:crypto");
|
|
4
|
+
const search = require("@redis/search");
|
|
5
|
+
const accessPolicyResolver = require("../accessPolicyResolver.cjs");
|
|
6
|
+
const redisIndex = require("./redisIndex.cjs");
|
|
7
|
+
const accessRulesRedisIndexName = "index:user-access-rules";
|
|
8
|
+
const accessRuleRedisKeyPrefix = "uar:";
|
|
9
|
+
const accessRuleContentHashAlgorithm = "md5";
|
|
10
|
+
const accessRulesIndex = {
|
|
11
|
+
name: accessRulesRedisIndexName,
|
|
12
|
+
/**
|
|
13
|
+
* Note on the field type decision
|
|
14
|
+
*
|
|
15
|
+
* TAG is designed for the exact value matching
|
|
16
|
+
* TEXT is designed for the word-based and pattern matching
|
|
17
|
+
*
|
|
18
|
+
* For our goal TAG fits perfectly and, more performant
|
|
19
|
+
*/
|
|
20
|
+
schema: {
|
|
21
|
+
clientId: {
|
|
22
|
+
type: search.SCHEMA_FIELD_TYPE.TAG,
|
|
23
|
+
// necessary to make possible use of the ismissing() function on this field in the search
|
|
24
|
+
INDEXMISSING: true
|
|
25
|
+
},
|
|
26
|
+
numericIpMaskMin: search.SCHEMA_FIELD_TYPE.NUMERIC,
|
|
27
|
+
numericIpMaskMax: search.SCHEMA_FIELD_TYPE.NUMERIC,
|
|
28
|
+
userId: search.SCHEMA_FIELD_TYPE.TAG,
|
|
29
|
+
numericIp: search.SCHEMA_FIELD_TYPE.NUMERIC,
|
|
30
|
+
ja4Hash: search.SCHEMA_FIELD_TYPE.TAG,
|
|
31
|
+
headersHash: search.SCHEMA_FIELD_TYPE.TAG,
|
|
32
|
+
userAgentHash: search.SCHEMA_FIELD_TYPE.TAG
|
|
33
|
+
},
|
|
34
|
+
// the satisfy statement is to guarantee that the keys are right
|
|
35
|
+
options: {
|
|
36
|
+
ON: "HASH",
|
|
37
|
+
PREFIX: accessRuleRedisKeyPrefix
|
|
38
|
+
}
|
|
39
|
+
};
|
|
40
|
+
const createRedisAccessRulesIndex = async (client) => redisIndex.createRedisIndex(client, accessRulesIndex);
|
|
41
|
+
const numericIndexFields = [
|
|
42
|
+
"numericIp",
|
|
43
|
+
"numericIpMaskMin",
|
|
44
|
+
"numericIpMaskMax"
|
|
45
|
+
];
|
|
46
|
+
const greedyFieldComparisons = {
|
|
47
|
+
numericIp: (value) => `( @numericIp:[${value}] | ( @numericIpMaskMin:[-inf ${value}] @numericIpMaskMax:[${value} +inf] ) )`
|
|
48
|
+
};
|
|
49
|
+
const accessRulesRedisSearchOptions = {
|
|
50
|
+
// #2 is a required option when the 'ismissing()' function is in the query body
|
|
51
|
+
DIALECT: 2
|
|
52
|
+
};
|
|
53
|
+
const getRedisAccessRulesQuery = (filter) => {
|
|
54
|
+
const { policyScope, userScope } = filter;
|
|
55
|
+
const policyScopeFilter = getPolicyScopeQuery(
|
|
56
|
+
policyScope,
|
|
57
|
+
filter.policyScopeMatch
|
|
58
|
+
);
|
|
59
|
+
if (userScope && Object.keys(userScope).length > 0) {
|
|
60
|
+
const userScopeFilter = getUserScopeQuery(userScope, filter.userScopeMatch);
|
|
61
|
+
return `${policyScopeFilter} ( ${userScopeFilter} )`;
|
|
62
|
+
}
|
|
63
|
+
return policyScopeFilter ? policyScopeFilter : "*";
|
|
64
|
+
};
|
|
65
|
+
const getPolicyScopeQuery = (policyScope, scopeMatchType) => {
|
|
66
|
+
const clientId = policyScope?.clientId;
|
|
67
|
+
if ("string" === typeof clientId) {
|
|
68
|
+
return accessPolicyResolver.ScopeMatch.Exact === scopeMatchType ? `@clientId:{${clientId}}` : `( @clientId:{${clientId}} | ismissing(@clientId) )`;
|
|
69
|
+
}
|
|
70
|
+
return accessPolicyResolver.ScopeMatch.Exact === scopeMatchType ? "ismissing(@clientId)" : "";
|
|
71
|
+
};
|
|
72
|
+
const getUserScopeQuery = (userScope, scopeMatchType) => {
|
|
73
|
+
const scopeEntries = Object.entries(userScope).filter(([_, value]) => value !== void 0);
|
|
74
|
+
const scopeJoinType = accessPolicyResolver.ScopeMatch.Exact === scopeMatchType ? " " : " | ";
|
|
75
|
+
return scopeEntries.map(
|
|
76
|
+
([scopeFieldName, scopeFieldValue]) => getUserScopeFieldQuery(scopeFieldName, scopeFieldValue, scopeMatchType)
|
|
77
|
+
).join(scopeJoinType);
|
|
78
|
+
};
|
|
79
|
+
const getUserScopeFieldQuery = (fieldName, fieldValue, matchType) => {
|
|
80
|
+
if (accessPolicyResolver.ScopeMatch.Greedy === matchType && "function" === typeof greedyFieldComparisons[fieldName]) {
|
|
81
|
+
return greedyFieldComparisons[fieldName](fieldValue);
|
|
82
|
+
}
|
|
83
|
+
return numericIndexFields.includes(fieldName) ? `@${fieldName}:[${fieldValue}]` : `@${fieldName}:{${fieldValue}}`;
|
|
84
|
+
};
|
|
85
|
+
const getRedisAccessRuleKey = (rule) => accessRuleRedisKeyPrefix + crypto.createHash(accessRuleContentHashAlgorithm).update(
|
|
86
|
+
JSON.stringify(
|
|
87
|
+
rule,
|
|
88
|
+
(key, value) => (
|
|
89
|
+
// JSON.stringify can't handle BigInt itself: throws "Do not know how to serialize a BigInt"
|
|
90
|
+
"bigint" === typeof value ? value.toString() : value
|
|
91
|
+
)
|
|
92
|
+
)
|
|
93
|
+
).digest("hex");
|
|
94
|
+
const getRedisAccessRuleValue = (rule) => Object.fromEntries(
|
|
95
|
+
Object.entries(rule).map(([key, value]) => [key, String(value)])
|
|
96
|
+
);
|
|
97
|
+
exports.accessRuleRedisKeyPrefix = accessRuleRedisKeyPrefix;
|
|
98
|
+
exports.accessRulesRedisIndexName = accessRulesRedisIndexName;
|
|
99
|
+
exports.accessRulesRedisSearchOptions = accessRulesRedisSearchOptions;
|
|
100
|
+
exports.createRedisAccessRulesIndex = createRedisAccessRulesIndex;
|
|
101
|
+
exports.getRedisAccessRuleKey = getRedisAccessRuleKey;
|
|
102
|
+
exports.getRedisAccessRuleValue = getRedisAccessRuleValue;
|
|
103
|
+
exports.getRedisAccessRulesQuery = getRedisAccessRulesQuery;
|
|
@@ -0,0 +1,22 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, Symbol.toStringTag, { value: "Module" });
|
|
3
|
+
const crypto = require("node:crypto");
|
|
4
|
+
const redisIndexHashesRecordKey = "_index_hashes";
|
|
5
|
+
const redisIndexHashAlgorithm = "sha256";
|
|
6
|
+
const createRedisIndex = async (client, index) => {
|
|
7
|
+
const indexHash = createIndexHash(index);
|
|
8
|
+
const existingIndexes = await client.ft._LIST();
|
|
9
|
+
if (existingIndexes.includes(index.name)) {
|
|
10
|
+
const existingIndexHash = await fetchIndexHash(client, index.name);
|
|
11
|
+
if (indexHash === existingIndexHash) {
|
|
12
|
+
return;
|
|
13
|
+
}
|
|
14
|
+
await client.ft.dropIndex(index.name);
|
|
15
|
+
}
|
|
16
|
+
await client.ft.create(index.name, index.schema, index.options);
|
|
17
|
+
await saveIndexHash(client, index.name, indexHash);
|
|
18
|
+
};
|
|
19
|
+
const createIndexHash = (index) => crypto.createHash(redisIndexHashAlgorithm).update(JSON.stringify(index)).digest("hex");
|
|
20
|
+
const fetchIndexHash = async (client, indexName) => client.hGet(redisIndexHashesRecordKey, indexName);
|
|
21
|
+
const saveIndexHash = async (client, indexName, indexHash) => client.hSet(redisIndexHashesRecordKey, indexName, indexHash);
|
|
22
|
+
exports.createRedisIndex = createRedisIndex;
|
package/dist/index.d.ts
CHANGED
|
@@ -1,17 +1,15 @@
|
|
|
1
1
|
import type { ApiRoutesProvider } from "@prosopo/api-route";
|
|
2
|
-
import type
|
|
3
|
-
import type
|
|
4
|
-
import type
|
|
5
|
-
import {
|
|
6
|
-
import { getExpressApiRuleRateLimits } from "
|
|
7
|
-
import
|
|
8
|
-
import {
|
|
9
|
-
import {
|
|
10
|
-
import
|
|
11
|
-
import
|
|
12
|
-
|
|
13
|
-
declare const
|
|
14
|
-
|
|
15
|
-
declare const createMongooseRulesStorage: (logger: Logger, readingModel: Model<Rule> | null, writingModel?: Model<Rule> | null) => RulesStorage;
|
|
16
|
-
export { type Rule, type RulesStorage, type BlacklistInspector, type ApiInsertManyRulesArgsSchema, type ApiInsertManyRulesArgsOutputSchema, createMongooseRulesStorage, createImageCaptchaConfigResolver, createBlacklistInspector, createApiRuleRoutesProvider, getRuleMongooseSchema, getExpressApiRuleRateLimits, apiRulePaths, };
|
|
2
|
+
import { type AccessPolicy, AccessPolicyType, type AccessRuleExtended, type PolicyScope, type UserScope, type UserScopeApiInput, type UserScopeApiOutput, accessPolicySchema, policyScopeSchema } from "#policy/accessPolicy.js";
|
|
3
|
+
import { type ResolveAccessPolicy, createAccessPolicyResolver } from "#policy/accessPolicyResolver.js";
|
|
4
|
+
import { type PolicyFilter, ScopeMatch } from "#policy/accessPolicyResolver.js";
|
|
5
|
+
import type { AccessRule, AccessRulesStorage } from "#policy/accessRules.js";
|
|
6
|
+
import { accessRuleApiPaths, getExpressApiRuleRateLimits } from "#policy/api/accessRuleApiRoutes.js";
|
|
7
|
+
import { deleteAllRulesEndpointSchema } from "#policy/api/deleteAllRulesEndpoint.js";
|
|
8
|
+
import { type DeleteRulesEndpointSchemaInput, type DeleteRulesEndpointSchemaOutput, deleteRulesEndpointSchema } from "#policy/api/deleteRulesEndpoint.js";
|
|
9
|
+
import { type InsertManyRulesEndpointInputSchema, type InsertManyRulesEndpointOutputSchema, insertRulesEndpointSchema } from "#policy/api/insertRulesEndpoint.js";
|
|
10
|
+
import { createRedisAccessRulesStorage } from "#policy/redis/redisAccessRules.js";
|
|
11
|
+
import { createRedisAccessRulesIndex } from "#policy/redis/redisAccessRulesIndex.js";
|
|
12
|
+
import { userScopeInputSchema } from "./accessPolicy.js";
|
|
13
|
+
export declare const createApiRuleRoutesProvider: (rulesStorage: AccessRulesStorage) => ApiRoutesProvider;
|
|
14
|
+
export { type AccessPolicy, type PolicyScope, type AccessRulesStorage, type ResolveAccessPolicy, type PolicyFilter, type DeleteRulesEndpointSchemaOutput, type DeleteRulesEndpointSchemaInput, type InsertManyRulesEndpointInputSchema, type InsertManyRulesEndpointOutputSchema, type AccessRule, type UserScope, type UserScopeApiInput, type UserScopeApiOutput, type AccessRuleExtended, createAccessPolicyResolver, AccessPolicyType, ScopeMatch, createRedisAccessRulesIndex, createRedisAccessRulesStorage, accessRuleApiPaths, accessPolicySchema, policyScopeSchema, insertRulesEndpointSchema, deleteAllRulesEndpointSchema, deleteRulesEndpointSchema, getExpressApiRuleRateLimits, userScopeInputSchema, };
|
|
17
15
|
//# sourceMappingURL=index.d.ts.map
|
package/dist/index.d.ts.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../src/index.ts"],"names":[],"mappings":"AAcA,OAAO,KAAK,EAAE,iBAAiB,EAAE,MAAM,oBAAoB,CAAC;AAC5D,OAAO,KAAK,
|
|
1
|
+
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../src/index.ts"],"names":[],"mappings":"AAcA,OAAO,KAAK,EAAE,iBAAiB,EAAE,MAAM,oBAAoB,CAAC;AAC5D,OAAO,EACN,KAAK,YAAY,EACjB,gBAAgB,EAChB,KAAK,kBAAkB,EACvB,KAAK,WAAW,EAChB,KAAK,SAAS,EACd,KAAK,iBAAiB,EACtB,KAAK,kBAAkB,EACvB,kBAAkB,EAClB,iBAAiB,EACjB,MAAM,yBAAyB,CAAC;AACjC,OAAO,EACN,KAAK,mBAAmB,EACxB,0BAA0B,EAC1B,MAAM,iCAAiC,CAAC;AACzC,OAAO,EAAE,KAAK,YAAY,EAAE,UAAU,EAAE,MAAM,iCAAiC,CAAC;AAChF,OAAO,KAAK,EAAE,UAAU,EAAE,kBAAkB,EAAE,MAAM,wBAAwB,CAAC;AAC7E,OAAO,EAEN,kBAAkB,EAClB,2BAA2B,EAC3B,MAAM,oCAAoC,CAAC;AAC5C,OAAO,EAAE,4BAA4B,EAAE,MAAM,uCAAuC,CAAC;AACrF,OAAO,EACN,KAAK,8BAA8B,EACnC,KAAK,+BAA+B,EACpC,yBAAyB,EACzB,MAAM,oCAAoC,CAAC;AAC5C,OAAO,EACN,KAAK,kCAAkC,EACvC,KAAK,mCAAmC,EACxC,yBAAyB,EACzB,MAAM,oCAAoC,CAAC;AAC5C,OAAO,EAAE,6BAA6B,EAAE,MAAM,mCAAmC,CAAC;AAClF,OAAO,EAAE,2BAA2B,EAAE,MAAM,wCAAwC,CAAC;AACrF,OAAO,EAAE,oBAAoB,EAAE,MAAM,mBAAmB,CAAC;AAEzD,eAAO,MAAM,2BAA2B,iBACzB,kBAAkB,KAC9B,iBAEF,CAAC;AAEF,OAAO,EACN,KAAK,YAAY,EACjB,KAAK,WAAW,EAChB,KAAK,kBAAkB,EACvB,KAAK,mBAAmB,EACxB,KAAK,YAAY,EACjB,KAAK,+BAA+B,EACpC,KAAK,8BAA8B,EACnC,KAAK,kCAAkC,EACvC,KAAK,mCAAmC,EACxC,KAAK,UAAU,EACf,KAAK,SAAS,EACd,KAAK,iBAAiB,EACtB,KAAK,kBAAkB,EACvB,KAAK,kBAAkB,EACvB,0BAA0B,EAC1B,gBAAgB,EAChB,UAAU,EAEV,2BAA2B,EAC3B,6BAA6B,EAE7B,kBAAkB,EAClB,kBAAkB,EAClB,iBAAiB,EACjB,yBAAyB,EACzB,4BAA4B,EAC5B,yBAAyB,EACzB,2BAA2B,EAC3B,oBAAoB,GACpB,CAAC"}
|
package/dist/index.js
CHANGED
|
@@ -1,21 +1,15 @@
|
|
|
1
|
-
import {
|
|
2
|
-
import {
|
|
3
|
-
import {
|
|
4
|
-
import {
|
|
5
|
-
import {
|
|
6
|
-
import {
|
|
7
|
-
import {
|
|
8
|
-
|
|
9
|
-
|
|
10
|
-
};
|
|
11
|
-
const
|
|
12
|
-
return new
|
|
13
|
-
};
|
|
14
|
-
|
|
15
|
-
return new ApiRuleRoutesProvider(rulesStorage);
|
|
16
|
-
};
|
|
17
|
-
const createMongooseRulesStorage = (logger, readingModel, writingModel = null) => {
|
|
18
|
-
return new RulesMongooseStorage(logger, readingModel, writingModel);
|
|
19
|
-
};
|
|
20
|
-
export { createMongooseRulesStorage, createImageCaptchaConfigResolver, createBlacklistInspector, createApiRuleRoutesProvider, getRuleMongooseSchema, getExpressApiRuleRateLimits, apiRulePaths, };
|
|
1
|
+
import { AccessPolicyType, accessPolicySchema, policyScopeSchema, } from "#policy/accessPolicy.js";
|
|
2
|
+
import { createAccessPolicyResolver, } from "#policy/accessPolicyResolver.js";
|
|
3
|
+
import { ScopeMatch } from "#policy/accessPolicyResolver.js";
|
|
4
|
+
import { AccessRuleApiRoutes, accessRuleApiPaths, getExpressApiRuleRateLimits, } from "#policy/api/accessRuleApiRoutes.js";
|
|
5
|
+
import { deleteAllRulesEndpointSchema } from "#policy/api/deleteAllRulesEndpoint.js";
|
|
6
|
+
import { deleteRulesEndpointSchema, } from "#policy/api/deleteRulesEndpoint.js";
|
|
7
|
+
import { insertRulesEndpointSchema, } from "#policy/api/insertRulesEndpoint.js";
|
|
8
|
+
import { createRedisAccessRulesStorage } from "#policy/redis/redisAccessRules.js";
|
|
9
|
+
import { createRedisAccessRulesIndex } from "#policy/redis/redisAccessRulesIndex.js";
|
|
10
|
+
import { userScopeInputSchema } from "./accessPolicy.js";
|
|
11
|
+
export const createApiRuleRoutesProvider = (rulesStorage) => {
|
|
12
|
+
return new AccessRuleApiRoutes(rulesStorage);
|
|
13
|
+
};
|
|
14
|
+
export { createAccessPolicyResolver, AccessPolicyType, ScopeMatch, createRedisAccessRulesIndex, createRedisAccessRulesStorage, accessRuleApiPaths, accessPolicySchema, policyScopeSchema, insertRulesEndpointSchema, deleteAllRulesEndpointSchema, deleteRulesEndpointSchema, getExpressApiRuleRateLimits, userScopeInputSchema, };
|
|
21
15
|
//# sourceMappingURL=index.js.map
|
package/dist/index.js.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"index.js","sourceRoot":"","sources":["../src/index.ts"],"names":[],"mappings":"
|
|
1
|
+
{"version":3,"file":"index.js","sourceRoot":"","sources":["../src/index.ts"],"names":[],"mappings":"AAeA,OAAO,EAEN,gBAAgB,EAMhB,kBAAkB,EAClB,iBAAiB,GACjB,MAAM,yBAAyB,CAAC;AACjC,OAAO,EAEN,0BAA0B,GAC1B,MAAM,iCAAiC,CAAC;AACzC,OAAO,EAAqB,UAAU,EAAE,MAAM,iCAAiC,CAAC;AAEhF,OAAO,EACN,mBAAmB,EACnB,kBAAkB,EAClB,2BAA2B,GAC3B,MAAM,oCAAoC,CAAC;AAC5C,OAAO,EAAE,4BAA4B,EAAE,MAAM,uCAAuC,CAAC;AACrF,OAAO,EAGN,yBAAyB,GACzB,MAAM,oCAAoC,CAAC;AAC5C,OAAO,EAGN,yBAAyB,GACzB,MAAM,oCAAoC,CAAC;AAC5C,OAAO,EAAE,6BAA6B,EAAE,MAAM,mCAAmC,CAAC;AAClF,OAAO,EAAE,2BAA2B,EAAE,MAAM,wCAAwC,CAAC;AACrF,OAAO,EAAE,oBAAoB,EAAE,MAAM,mBAAmB,CAAC;AAEzD,MAAM,CAAC,MAAM,2BAA2B,GAAG,CAC1C,YAAgC,EACZ,EAAE;IACtB,OAAO,IAAI,mBAAmB,CAAC,YAAY,CAAC,CAAC;AAC9C,CAAC,CAAC;AAEF,OAAO,EAeN,0BAA0B,EAC1B,gBAAgB,EAChB,UAAU,EAEV,2BAA2B,EAC3B,6BAA6B,EAE7B,kBAAkB,EAClB,kBAAkB,EAClB,iBAAiB,EACjB,yBAAyB,EACzB,4BAA4B,EAC5B,yBAAyB,EACzB,2BAA2B,EAC3B,oBAAoB,GACpB,CAAC"}
|
|
@@ -0,0 +1,7 @@
|
|
|
1
|
+
import type { Logger } from "@prosopo/common";
|
|
2
|
+
import type { RedisClientType } from "redis";
|
|
3
|
+
import { type AccessRulesReader, type AccessRulesStorage, type AccessRulesWriter } from "#policy/accessRules.js";
|
|
4
|
+
export declare const createRedisAccessRulesReader: (client: RedisClientType, logger: Logger) => AccessRulesReader;
|
|
5
|
+
export declare const createRedisAccessRulesWriter: (client: RedisClientType) => AccessRulesWriter;
|
|
6
|
+
export declare const createRedisAccessRulesStorage: (client: RedisClientType, logger: Logger) => AccessRulesStorage;
|
|
7
|
+
//# sourceMappingURL=redisAccessRules.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"redisAccessRules.d.ts","sourceRoot":"","sources":["../../src/redis/redisAccessRules.ts"],"names":[],"mappings":"AAeA,OAAO,KAAK,EAAE,MAAM,EAAE,MAAM,iBAAiB,CAAC;AAG9C,OAAO,KAAK,EAAE,eAAe,EAAE,MAAM,OAAO,CAAC;AAE7C,OAAO,EAEN,KAAK,iBAAiB,EACtB,KAAK,kBAAkB,EACvB,KAAK,iBAAiB,EAEtB,MAAM,wBAAwB,CAAC;AAUhC,eAAO,MAAM,4BAA4B,WAChC,eAAe,UACf,MAAM,KACZ,iBAqFF,CAAC;AAEF,eAAO,MAAM,4BAA4B,WAChC,eAAe,KACrB,iBA2BF,CAAC;AAEF,eAAO,MAAM,6BAA6B,WACjC,eAAe,UACf,MAAM,KACZ,kBAKF,CAAC"}
|
|
@@ -0,0 +1,105 @@
|
|
|
1
|
+
import * as util from "node:util";
|
|
2
|
+
import { accessRuleSchema, } from "#policy/accessRules.js";
|
|
3
|
+
import { accessRuleRedisKeyPrefix, accessRulesRedisIndexName, accessRulesRedisSearchOptions, getRedisAccessRuleKey, getRedisAccessRuleValue, getRedisAccessRulesQuery, } from "#policy/redis/redisAccessRulesIndex.js";
|
|
4
|
+
export const createRedisAccessRulesReader = (client, logger) => {
|
|
5
|
+
return {
|
|
6
|
+
findRules: async (filter) => {
|
|
7
|
+
const query = getRedisAccessRulesQuery(filter);
|
|
8
|
+
let searchReply;
|
|
9
|
+
try {
|
|
10
|
+
searchReply = await client.ft.search(accessRulesRedisIndexName, query, accessRulesRedisSearchOptions);
|
|
11
|
+
logger.debug(() => ({
|
|
12
|
+
msg: "Executed search query",
|
|
13
|
+
data: {
|
|
14
|
+
inspect: util.inspect({
|
|
15
|
+
filter: filter,
|
|
16
|
+
searchReply: searchReply,
|
|
17
|
+
query: query,
|
|
18
|
+
}, { depth: null }),
|
|
19
|
+
},
|
|
20
|
+
}));
|
|
21
|
+
}
|
|
22
|
+
catch (e) {
|
|
23
|
+
logger.error(() => ({
|
|
24
|
+
err: e,
|
|
25
|
+
data: {
|
|
26
|
+
inspect: util.inspect({
|
|
27
|
+
query: query,
|
|
28
|
+
filter: filter,
|
|
29
|
+
}, {
|
|
30
|
+
depth: null,
|
|
31
|
+
}),
|
|
32
|
+
},
|
|
33
|
+
msg: "failed to execute search query",
|
|
34
|
+
}));
|
|
35
|
+
return [];
|
|
36
|
+
}
|
|
37
|
+
return extractAccessRulesFromSearchReply(searchReply, logger);
|
|
38
|
+
},
|
|
39
|
+
findRuleIds: async (filter) => {
|
|
40
|
+
const query = getRedisAccessRulesQuery(filter);
|
|
41
|
+
let searchReply;
|
|
42
|
+
try {
|
|
43
|
+
searchReply = await client.ft.searchNoContent(accessRulesRedisIndexName, query, accessRulesRedisSearchOptions);
|
|
44
|
+
}
|
|
45
|
+
catch (e) {
|
|
46
|
+
logger.error(() => ({
|
|
47
|
+
err: e,
|
|
48
|
+
data: {
|
|
49
|
+
inspect: util.inspect({
|
|
50
|
+
query: query,
|
|
51
|
+
filter: filter,
|
|
52
|
+
}, {
|
|
53
|
+
depth: null,
|
|
54
|
+
}),
|
|
55
|
+
},
|
|
56
|
+
msg: "Failed to execute search query for rule IDs",
|
|
57
|
+
}));
|
|
58
|
+
return [];
|
|
59
|
+
}
|
|
60
|
+
return searchReply.documents;
|
|
61
|
+
},
|
|
62
|
+
};
|
|
63
|
+
};
|
|
64
|
+
export const createRedisAccessRulesWriter = (client) => {
|
|
65
|
+
return {
|
|
66
|
+
insertRule: async (rule, expirationSeconds) => {
|
|
67
|
+
const ruleKey = getRedisAccessRuleKey(rule);
|
|
68
|
+
const ruleValue = getRedisAccessRuleValue(rule);
|
|
69
|
+
await client.hSet(ruleKey, ruleValue);
|
|
70
|
+
if (expirationSeconds) {
|
|
71
|
+
await client.expire(ruleKey, expirationSeconds);
|
|
72
|
+
}
|
|
73
|
+
return ruleKey;
|
|
74
|
+
},
|
|
75
|
+
deleteRules: async (ruleIds) => void (await client.del(ruleIds)),
|
|
76
|
+
deleteAllRules: async () => {
|
|
77
|
+
const keys = await client.keys(`${accessRuleRedisKeyPrefix}*`);
|
|
78
|
+
return keys.length > 0 ? await client.del(keys) : 0;
|
|
79
|
+
},
|
|
80
|
+
};
|
|
81
|
+
};
|
|
82
|
+
export const createRedisAccessRulesStorage = (client, logger) => {
|
|
83
|
+
return {
|
|
84
|
+
...createRedisAccessRulesReader(client, logger),
|
|
85
|
+
...createRedisAccessRulesWriter(client),
|
|
86
|
+
};
|
|
87
|
+
};
|
|
88
|
+
const extractAccessRulesFromSearchReply = (searchReply, logger) => {
|
|
89
|
+
const accessRules = [];
|
|
90
|
+
searchReply.documents.map(({ id, value: document }) => {
|
|
91
|
+
const parsedDocument = accessRuleSchema.safeParse(document);
|
|
92
|
+
if (parsedDocument.success) {
|
|
93
|
+
accessRules.push(parsedDocument.data);
|
|
94
|
+
}
|
|
95
|
+
else {
|
|
96
|
+
logger.debug(() => ({
|
|
97
|
+
msg: "Failed to parse access rule from search reply",
|
|
98
|
+
id: id,
|
|
99
|
+
error: parsedDocument.error,
|
|
100
|
+
}));
|
|
101
|
+
}
|
|
102
|
+
});
|
|
103
|
+
return accessRules;
|
|
104
|
+
};
|
|
105
|
+
//# sourceMappingURL=redisAccessRules.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"redisAccessRules.js","sourceRoot":"","sources":["../../src/redis/redisAccessRules.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,12 @@
|
|
|
1
|
+
import { type FtSearchOptions } from "@redis/search";
|
|
2
|
+
import type { RedisClientType } from "redis";
|
|
3
|
+
import { type PolicyFilter } from "#policy/accessPolicyResolver.js";
|
|
4
|
+
import type { AccessRule } from "#policy/accessRules.js";
|
|
5
|
+
export declare const accessRulesRedisIndexName = "index:user-access-rules";
|
|
6
|
+
export declare const accessRuleRedisKeyPrefix = "uar:";
|
|
7
|
+
export declare const createRedisAccessRulesIndex: (client: RedisClientType) => Promise<void>;
|
|
8
|
+
export declare const accessRulesRedisSearchOptions: FtSearchOptions;
|
|
9
|
+
export declare const getRedisAccessRulesQuery: (filter: PolicyFilter) => string;
|
|
10
|
+
export declare const getRedisAccessRuleKey: (rule: AccessRule) => string;
|
|
11
|
+
export declare const getRedisAccessRuleValue: (rule: AccessRule) => Record<string, string>;
|
|
12
|
+
//# sourceMappingURL=redisAccessRulesIndex.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"redisAccessRulesIndex.d.ts","sourceRoot":"","sources":["../../src/redis/redisAccessRulesIndex.ts"],"names":[],"mappings":"AAeA,OAAO,EAAE,KAAK,eAAe,EAAqB,MAAM,eAAe,CAAC;AACxE,OAAO,KAAK,EAAE,eAAe,EAAE,MAAM,OAAO,CAAC;AAE7C,OAAO,EAAE,KAAK,YAAY,EAAc,MAAM,iCAAiC,CAAC;AAChF,OAAO,KAAK,EAAE,UAAU,EAAE,MAAM,wBAAwB,CAAC;AAGzD,eAAO,MAAM,yBAAyB,4BAA4B,CAAC;AAEnE,eAAO,MAAM,wBAAwB,SAAS,CAAC;AAkC/C,eAAO,MAAM,2BAA2B,WAC/B,eAAe,KACrB,OAAO,CAAC,IAAI,CAA+C,CAAC;AAkB/D,eAAO,MAAM,6BAA6B,EAAE,eAG3C,CAAC;AAYF,eAAO,MAAM,wBAAwB,WAAY,YAAY,KAAG,MAe/D,CAAC;AAqDF,eAAO,MAAM,qBAAqB,SAAU,UAAU,KAAG,MAUzC,CAAC;AAEjB,eAAO,MAAM,uBAAuB,SAC7B,UAAU,KACd,MAAM,CAAC,MAAM,EAAE,MAAM,CAGtB,CAAC"}
|