@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
|
@@ -0,0 +1,21 @@
|
|
|
1
|
+
import { ApiEndpointResponseStatus, } from "@prosopo/api-route";
|
|
2
|
+
import { z } from "zod";
|
|
3
|
+
export const deleteAllRulesEndpointSchema = z.object({});
|
|
4
|
+
export class DeleteAllRulesEndpoint {
|
|
5
|
+
constructor(accessRulesStorage) {
|
|
6
|
+
this.accessRulesStorage = accessRulesStorage;
|
|
7
|
+
}
|
|
8
|
+
async processRequest(args) {
|
|
9
|
+
const deletedCount = await this.accessRulesStorage.deleteAllRules();
|
|
10
|
+
return {
|
|
11
|
+
status: ApiEndpointResponseStatus.SUCCESS,
|
|
12
|
+
data: {
|
|
13
|
+
deleted_count: deletedCount,
|
|
14
|
+
},
|
|
15
|
+
};
|
|
16
|
+
}
|
|
17
|
+
getRequestArgsSchema() {
|
|
18
|
+
return deleteAllRulesEndpointSchema;
|
|
19
|
+
}
|
|
20
|
+
}
|
|
21
|
+
//# sourceMappingURL=deleteAllRulesEndpoint.js.map
|
|
@@ -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,31 @@
|
|
|
1
|
+
import { ApiEndpointResponseStatus, } from "@prosopo/api-route";
|
|
2
|
+
import { z } from "zod";
|
|
3
|
+
import { policyFilterSchema } from "#policy/accessPolicyResolver.js";
|
|
4
|
+
export const deleteRulesEndpointSchema = z.array(policyFilterSchema);
|
|
5
|
+
export class DeleteRulesEndpoint {
|
|
6
|
+
constructor(accessRulesStorage) {
|
|
7
|
+
this.accessRulesStorage = accessRulesStorage;
|
|
8
|
+
}
|
|
9
|
+
async processRequest(args) {
|
|
10
|
+
const allRuleIds = [];
|
|
11
|
+
for (const accessRuleFilter of args) {
|
|
12
|
+
const parsedRules = policyFilterSchema.parse(accessRuleFilter);
|
|
13
|
+
const foundRuleIds = await this.accessRulesStorage.findRuleIds(parsedRules);
|
|
14
|
+
allRuleIds.push(...foundRuleIds);
|
|
15
|
+
}
|
|
16
|
+
const uniqueRuleIds = [...new Set(allRuleIds)];
|
|
17
|
+
if (uniqueRuleIds.length > 0) {
|
|
18
|
+
await this.accessRulesStorage.deleteRules(uniqueRuleIds);
|
|
19
|
+
}
|
|
20
|
+
return {
|
|
21
|
+
status: ApiEndpointResponseStatus.SUCCESS,
|
|
22
|
+
data: {
|
|
23
|
+
deleted_count: uniqueRuleIds.length,
|
|
24
|
+
},
|
|
25
|
+
};
|
|
26
|
+
}
|
|
27
|
+
getRequestArgsSchema() {
|
|
28
|
+
return deleteRulesEndpointSchema;
|
|
29
|
+
}
|
|
30
|
+
}
|
|
31
|
+
//# sourceMappingURL=deleteRulesEndpoint.js.map
|
|
@@ -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
|
+
expirationTimestampSeconds?: 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,0BAA0B,CAAC,EAAE,MAAM,CAAC;CACpC,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;CAoBpB"}
|
|
@@ -0,0 +1,62 @@
|
|
|
1
|
+
import { ApiEndpointResponseStatus, } from "@prosopo/api-route";
|
|
2
|
+
import { LogLevel, getLogger } from "@prosopo/common";
|
|
3
|
+
import { z } from "zod";
|
|
4
|
+
import { accessPolicySchema, policyScopeSchema, userScopeInputSchema, } from "#policy/accessPolicy.js";
|
|
5
|
+
export const insertRulesEndpointSchema = z.object({
|
|
6
|
+
accessPolicy: accessPolicySchema,
|
|
7
|
+
policyScope: policyScopeSchema.optional(),
|
|
8
|
+
userScopes: z.array(userScopeInputSchema),
|
|
9
|
+
expirationTimestampSeconds: z
|
|
10
|
+
.number()
|
|
11
|
+
.optional()
|
|
12
|
+
.transform((val) => (val !== undefined ? Math.floor(val) : val)),
|
|
13
|
+
});
|
|
14
|
+
export class InsertRulesEndpoint {
|
|
15
|
+
constructor(accessRulesWriter) {
|
|
16
|
+
this.accessRulesWriter = accessRulesWriter;
|
|
17
|
+
}
|
|
18
|
+
async processRequest(args, logger) {
|
|
19
|
+
logger = logger || getLogger(LogLevel.enum.info, "InsertRulesEndpoint");
|
|
20
|
+
const timeoutPromise = new Promise((resolve) => {
|
|
21
|
+
setTimeout(() => {
|
|
22
|
+
resolve({
|
|
23
|
+
status: ApiEndpointResponseStatus.PROCESSING,
|
|
24
|
+
});
|
|
25
|
+
}, 5000);
|
|
26
|
+
});
|
|
27
|
+
const createRulesPromise = this.createRules(args)
|
|
28
|
+
.then(() => ({
|
|
29
|
+
status: ApiEndpointResponseStatus.SUCCESS,
|
|
30
|
+
}))
|
|
31
|
+
.catch((error) => {
|
|
32
|
+
if (logger?.getLogLevel() === LogLevel.enum.debug) {
|
|
33
|
+
logger.error(() => ({
|
|
34
|
+
err: error,
|
|
35
|
+
data: { args },
|
|
36
|
+
msg: "Failed to insert access rules",
|
|
37
|
+
}));
|
|
38
|
+
}
|
|
39
|
+
return {
|
|
40
|
+
status: ApiEndpointResponseStatus.FAIL,
|
|
41
|
+
};
|
|
42
|
+
});
|
|
43
|
+
return Promise.race([timeoutPromise, createRulesPromise]);
|
|
44
|
+
}
|
|
45
|
+
getRequestArgsSchema() {
|
|
46
|
+
return insertRulesEndpointSchema;
|
|
47
|
+
}
|
|
48
|
+
async createRules(args) {
|
|
49
|
+
const policyScope = args.policyScope || {};
|
|
50
|
+
const createPromises = [];
|
|
51
|
+
for (const userScope of args.userScopes) {
|
|
52
|
+
const rule = {
|
|
53
|
+
...args.accessPolicy,
|
|
54
|
+
...policyScope,
|
|
55
|
+
...userScope,
|
|
56
|
+
};
|
|
57
|
+
createPromises.push(this.accessRulesWriter.insertRule(rule, args.expirationTimestampSeconds));
|
|
58
|
+
}
|
|
59
|
+
return Promise.all(createPromises);
|
|
60
|
+
}
|
|
61
|
+
}
|
|
62
|
+
//# sourceMappingURL=insertRulesEndpoint.js.map
|
|
@@ -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,0BAA0B,EAAE,CAAC;SAC3B,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,CAChC,IAAI,EACJ,IAAI,CAAC,0BAA0B,CAC/B,CACD,CAAC;QACH,CAAC;QACD,OAAO,OAAO,CAAC,GAAG,CAAC,cAAc,CAAC,CAAC;IACpC,CAAC;CACD"}
|
|
@@ -0,0 +1,79 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, Symbol.toStringTag, { value: "Module" });
|
|
3
|
+
const types = require("@prosopo/types");
|
|
4
|
+
const ipAddress = require("ip-address");
|
|
5
|
+
const zod = require("zod");
|
|
6
|
+
const util = require("./util.cjs");
|
|
7
|
+
var AccessPolicyType = /* @__PURE__ */ ((AccessPolicyType2) => {
|
|
8
|
+
AccessPolicyType2["Block"] = "block";
|
|
9
|
+
AccessPolicyType2["Restrict"] = "restrict";
|
|
10
|
+
return AccessPolicyType2;
|
|
11
|
+
})(AccessPolicyType || {});
|
|
12
|
+
const accessPolicySchema = zod.z.object({
|
|
13
|
+
type: zod.z.nativeEnum(AccessPolicyType),
|
|
14
|
+
captchaType: types.CaptchaTypeSchema.optional(),
|
|
15
|
+
description: zod.z.coerce.string().optional(),
|
|
16
|
+
// Redis stores values as strings, so coerce is needed to parse properly
|
|
17
|
+
solvedImagesCount: zod.z.coerce.number().optional(),
|
|
18
|
+
// the percentage of image panels that must be solved per image CAPTCHA
|
|
19
|
+
imageThreshold: zod.z.coerce.number().optional(),
|
|
20
|
+
// the Proof-of-Work difficulty level
|
|
21
|
+
powDifficulty: zod.z.coerce.number().optional(),
|
|
22
|
+
// the number of unsolved image CAPTCHA challenges to serve
|
|
23
|
+
unsolvedImagesCount: zod.z.coerce.number().optional(),
|
|
24
|
+
// used to increase the user's score
|
|
25
|
+
frictionlessScore: zod.z.coerce.number().optional()
|
|
26
|
+
});
|
|
27
|
+
const policyScopeSchema = zod.z.object({
|
|
28
|
+
clientId: zod.z.coerce.string().optional(),
|
|
29
|
+
ruleGroupId: zod.z.coerce.string().optional()
|
|
30
|
+
});
|
|
31
|
+
const userScopeSchema = zod.z.object({
|
|
32
|
+
// coerce is used for safety, as e.g., incoming userId can be digital
|
|
33
|
+
userId: zod.z.coerce.string().optional(),
|
|
34
|
+
numericIp: zod.z.coerce.bigint().optional(),
|
|
35
|
+
numericIpMaskMin: zod.z.coerce.bigint().optional(),
|
|
36
|
+
numericIpMaskMax: zod.z.coerce.bigint().optional(),
|
|
37
|
+
ja4Hash: zod.z.coerce.string().optional(),
|
|
38
|
+
headersHash: zod.z.coerce.string().optional(),
|
|
39
|
+
userAgentHash: zod.z.coerce.string().optional()
|
|
40
|
+
});
|
|
41
|
+
const userScopeInputSchema = userScopeSchema.extend({
|
|
42
|
+
// human-friendly ip versions. If present, then converted to numeric and removed from the object
|
|
43
|
+
// 127.0.0.1
|
|
44
|
+
ip: zod.z.string().optional(),
|
|
45
|
+
// 127.0.0.1/24
|
|
46
|
+
ipMask: zod.z.string().optional(),
|
|
47
|
+
// human friendly user agent
|
|
48
|
+
userAgent: zod.z.string().optional()
|
|
49
|
+
}).transform((inputUserScope) => {
|
|
50
|
+
const { ip, ipMask, userAgent, ...userScope } = inputUserScope;
|
|
51
|
+
if ("string" === typeof ip) {
|
|
52
|
+
userScope.numericIp = new ipAddress.Address4(ip).bigInt();
|
|
53
|
+
}
|
|
54
|
+
if ("string" === typeof ipMask) {
|
|
55
|
+
const ipObject = new ipAddress.Address4(ipMask);
|
|
56
|
+
userScope.numericIpMaskMin = ipObject.startAddress().bigInt();
|
|
57
|
+
userScope.numericIpMaskMax = ipObject.endAddress().bigInt();
|
|
58
|
+
}
|
|
59
|
+
if ("string" === typeof userAgent) {
|
|
60
|
+
userScope.userAgentHash = util.hashUserAgent(userAgent);
|
|
61
|
+
}
|
|
62
|
+
return userScope;
|
|
63
|
+
});
|
|
64
|
+
const accessRuleSchemaExtended = zod.z.object({
|
|
65
|
+
// flat structure is used to fit the Redis requirements
|
|
66
|
+
...accessPolicySchema.shape,
|
|
67
|
+
...policyScopeSchema.shape,
|
|
68
|
+
...userScopeInputSchema._def.schema.shape
|
|
69
|
+
}).omit({
|
|
70
|
+
numericIp: true,
|
|
71
|
+
numericIpMaskMin: true,
|
|
72
|
+
numericIpMaskMax: true
|
|
73
|
+
});
|
|
74
|
+
exports.AccessPolicyType = AccessPolicyType;
|
|
75
|
+
exports.accessPolicySchema = accessPolicySchema;
|
|
76
|
+
exports.accessRuleSchemaExtended = accessRuleSchemaExtended;
|
|
77
|
+
exports.policyScopeSchema = policyScopeSchema;
|
|
78
|
+
exports.userScopeInputSchema = userScopeInputSchema;
|
|
79
|
+
exports.userScopeSchema = userScopeSchema;
|
|
@@ -0,0 +1,87 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, Symbol.toStringTag, { value: "Module" });
|
|
3
|
+
const util = require("node:util");
|
|
4
|
+
const zod = require("zod");
|
|
5
|
+
const accessPolicy = require("./accessPolicy.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
|
+
var ScopeMatch = /* @__PURE__ */ ((ScopeMatch2) => {
|
|
24
|
+
ScopeMatch2["Exact"] = "exact";
|
|
25
|
+
ScopeMatch2["Greedy"] = "greedy";
|
|
26
|
+
return ScopeMatch2;
|
|
27
|
+
})(ScopeMatch || {});
|
|
28
|
+
const policyFilterSchema = zod.z.object({
|
|
29
|
+
policyScope: accessPolicy.policyScopeSchema.optional(),
|
|
30
|
+
/**
|
|
31
|
+
* Exact: "clientId" => client rules, "undefined" => global rules. Used by the API
|
|
32
|
+
* Greedy: "clientId" => client + global rules, "undefined" => any rules. Used by the Express middleware
|
|
33
|
+
*/
|
|
34
|
+
policyScopeMatch: zod.z.nativeEnum(ScopeMatch).default(
|
|
35
|
+
"exact"
|
|
36
|
+
/* Exact */
|
|
37
|
+
),
|
|
38
|
+
userScope: accessPolicy.userScopeInputSchema.optional(),
|
|
39
|
+
/**
|
|
40
|
+
* Exact: finds rules where all the given fields matches and doesn't check IP against masks. Used by the API
|
|
41
|
+
* Greedy: finds rules where any of the given fields match and checks IP against masks. Used by the Express middleware
|
|
42
|
+
*/
|
|
43
|
+
userScopeMatch: zod.z.nativeEnum(ScopeMatch).default(
|
|
44
|
+
"exact"
|
|
45
|
+
/* Exact */
|
|
46
|
+
)
|
|
47
|
+
});
|
|
48
|
+
const createAccessPolicyResolver = (accessRulesReader, logger) => {
|
|
49
|
+
return async (filter) => {
|
|
50
|
+
const accessRules = await accessRulesReader.findRules(filter);
|
|
51
|
+
const primaryAccessRule = resolvePrimaryRule(accessRules);
|
|
52
|
+
logger.debug(() => ({
|
|
53
|
+
msg: "Resolved access policy",
|
|
54
|
+
// filter contains BigInt, which can't be handled directly via logger.
|
|
55
|
+
data: {
|
|
56
|
+
inspect: util__namespace.inspect(
|
|
57
|
+
{
|
|
58
|
+
filter,
|
|
59
|
+
accessRules,
|
|
60
|
+
primaryAccessRule
|
|
61
|
+
},
|
|
62
|
+
{ depth: null }
|
|
63
|
+
)
|
|
64
|
+
}
|
|
65
|
+
}));
|
|
66
|
+
return primaryAccessRule;
|
|
67
|
+
};
|
|
68
|
+
};
|
|
69
|
+
const resolvePrimaryRule = (rules) => {
|
|
70
|
+
const blockingRules = rules.filter(
|
|
71
|
+
(accessRule) => accessPolicy.AccessPolicyType.Block === accessRule.type
|
|
72
|
+
);
|
|
73
|
+
const rulesToEvaluate = blockingRules.length > 0 ? blockingRules : rules;
|
|
74
|
+
return resolveMostLocalRule(rulesToEvaluate);
|
|
75
|
+
};
|
|
76
|
+
const resolveMostLocalRule = (rules) => {
|
|
77
|
+
const clientRules = rules.filter(
|
|
78
|
+
(accessRule) => "string" === typeof accessRule.clientId
|
|
79
|
+
);
|
|
80
|
+
if (clientRules.length > 0) {
|
|
81
|
+
return clientRules.shift();
|
|
82
|
+
}
|
|
83
|
+
return rules.shift();
|
|
84
|
+
};
|
|
85
|
+
exports.ScopeMatch = ScopeMatch;
|
|
86
|
+
exports.createAccessPolicyResolver = createAccessPolicyResolver;
|
|
87
|
+
exports.policyFilterSchema = policyFilterSchema;
|
|
@@ -0,0 +1,11 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, Symbol.toStringTag, { value: "Module" });
|
|
3
|
+
const zod = require("zod");
|
|
4
|
+
const accessPolicy = require("./accessPolicy.cjs");
|
|
5
|
+
const accessRuleSchema = zod.z.object({
|
|
6
|
+
// flat structure is used to fit the Redis requirements
|
|
7
|
+
...accessPolicy.accessPolicySchema.shape,
|
|
8
|
+
...accessPolicy.policyScopeSchema.shape,
|
|
9
|
+
...accessPolicy.userScopeSchema.shape
|
|
10
|
+
});
|
|
11
|
+
exports.accessRuleSchema = accessRuleSchema;
|
|
@@ -0,0 +1,79 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, Symbol.toStringTag, { value: "Module" });
|
|
3
|
+
const deleteAllRulesEndpoint = require("./deleteAllRulesEndpoint.cjs");
|
|
4
|
+
const deleteRulesEndpoint = require("./deleteRulesEndpoint.cjs");
|
|
5
|
+
const insertRulesEndpoint = require("./insertRulesEndpoint.cjs");
|
|
6
|
+
var accessRuleApiPaths = /* @__PURE__ */ ((accessRuleApiPaths2) => {
|
|
7
|
+
accessRuleApiPaths2["INSERT_MANY"] = "/v1/prosopo/user-access-policy/rules/insert-many";
|
|
8
|
+
accessRuleApiPaths2["DELETE_MANY"] = "/v1/prosopo/user-access-policy/rules/delete-many";
|
|
9
|
+
accessRuleApiPaths2["DELETE_ALL"] = "/v1/prosopo/user-access-policy/rules/delete-all";
|
|
10
|
+
return accessRuleApiPaths2;
|
|
11
|
+
})(accessRuleApiPaths || {});
|
|
12
|
+
class AccessRuleApiRoutes {
|
|
13
|
+
constructor(accessRulesStorage) {
|
|
14
|
+
this.accessRulesStorage = accessRulesStorage;
|
|
15
|
+
}
|
|
16
|
+
getRoutes() {
|
|
17
|
+
return [
|
|
18
|
+
{
|
|
19
|
+
path: "/v1/prosopo/user-access-policy/rules/insert-many",
|
|
20
|
+
endpoint: new insertRulesEndpoint.InsertRulesEndpoint(this.accessRulesStorage)
|
|
21
|
+
},
|
|
22
|
+
{
|
|
23
|
+
path: "/v1/prosopo/user-access-policy/rules/delete-many",
|
|
24
|
+
endpoint: new deleteRulesEndpoint.DeleteRulesEndpoint(this.accessRulesStorage)
|
|
25
|
+
},
|
|
26
|
+
{
|
|
27
|
+
path: "/v1/prosopo/user-access-policy/rules/delete-all",
|
|
28
|
+
endpoint: new deleteAllRulesEndpoint.DeleteAllRulesEndpoint(this.accessRulesStorage)
|
|
29
|
+
}
|
|
30
|
+
];
|
|
31
|
+
}
|
|
32
|
+
}
|
|
33
|
+
const getExpressApiRuleRateLimits = () => {
|
|
34
|
+
const defaultWindowsMs = 6e4;
|
|
35
|
+
const defaultLimit = 5;
|
|
36
|
+
return {
|
|
37
|
+
[
|
|
38
|
+
"/v1/prosopo/user-access-policy/rules/insert-many"
|
|
39
|
+
/* INSERT_MANY */
|
|
40
|
+
]: {
|
|
41
|
+
windowMs: getIntEnvironmentVariable(
|
|
42
|
+
"PROSOPO_USER_ACCESS_POLICY_RULE_INSERT_MANY_WINDOW"
|
|
43
|
+
) || defaultWindowsMs,
|
|
44
|
+
limit: getIntEnvironmentVariable(
|
|
45
|
+
"PROSOPO_USER_ACCESS_POLICY_RULE_INSERT_MANY_LIMIT"
|
|
46
|
+
) || defaultLimit
|
|
47
|
+
},
|
|
48
|
+
[
|
|
49
|
+
"/v1/prosopo/user-access-policy/rules/delete-many"
|
|
50
|
+
/* DELETE_MANY */
|
|
51
|
+
]: {
|
|
52
|
+
windowMs: getIntEnvironmentVariable(
|
|
53
|
+
"PROSOPO_USER_ACCESS_POLICY_RULE_DELETE_MANY_WINDOW"
|
|
54
|
+
) || defaultWindowsMs,
|
|
55
|
+
limit: getIntEnvironmentVariable(
|
|
56
|
+
"PROSOPO_USER_ACCESS_POLICY_RULE_DELETE_MANY_LIMIT"
|
|
57
|
+
) || defaultLimit
|
|
58
|
+
},
|
|
59
|
+
[
|
|
60
|
+
"/v1/prosopo/user-access-policy/rules/delete-all"
|
|
61
|
+
/* DELETE_ALL */
|
|
62
|
+
]: {
|
|
63
|
+
windowMs: getIntEnvironmentVariable(
|
|
64
|
+
"PROSOPO_USER_ACCESS_POLICY_RULE_DELETE_ALL_WINDOW"
|
|
65
|
+
) || defaultWindowsMs,
|
|
66
|
+
limit: getIntEnvironmentVariable(
|
|
67
|
+
"PROSOPO_USER_ACCESS_POLICY_RULE_DELETE_ALL_LIMIT"
|
|
68
|
+
) || defaultLimit
|
|
69
|
+
}
|
|
70
|
+
};
|
|
71
|
+
};
|
|
72
|
+
const getIntEnvironmentVariable = (variableName) => {
|
|
73
|
+
const variableValue = process.env[variableName];
|
|
74
|
+
const numericValue = variableValue ? Number.parseInt(variableValue) : Number.NaN;
|
|
75
|
+
return Number.isInteger(numericValue) ? numericValue : void 0;
|
|
76
|
+
};
|
|
77
|
+
exports.AccessRuleApiRoutes = AccessRuleApiRoutes;
|
|
78
|
+
exports.accessRuleApiPaths = accessRuleApiPaths;
|
|
79
|
+
exports.getExpressApiRuleRateLimits = getExpressApiRuleRateLimits;
|
|
@@ -0,0 +1,24 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, Symbol.toStringTag, { value: "Module" });
|
|
3
|
+
const apiRoute = require("@prosopo/api-route");
|
|
4
|
+
const zod = require("zod");
|
|
5
|
+
const deleteAllRulesEndpointSchema = zod.z.object({});
|
|
6
|
+
class DeleteAllRulesEndpoint {
|
|
7
|
+
constructor(accessRulesStorage) {
|
|
8
|
+
this.accessRulesStorage = accessRulesStorage;
|
|
9
|
+
}
|
|
10
|
+
async processRequest(args) {
|
|
11
|
+
const deletedCount = await this.accessRulesStorage.deleteAllRules();
|
|
12
|
+
return {
|
|
13
|
+
status: apiRoute.ApiEndpointResponseStatus.SUCCESS,
|
|
14
|
+
data: {
|
|
15
|
+
deleted_count: deletedCount
|
|
16
|
+
}
|
|
17
|
+
};
|
|
18
|
+
}
|
|
19
|
+
getRequestArgsSchema() {
|
|
20
|
+
return deleteAllRulesEndpointSchema;
|
|
21
|
+
}
|
|
22
|
+
}
|
|
23
|
+
exports.DeleteAllRulesEndpoint = DeleteAllRulesEndpoint;
|
|
24
|
+
exports.deleteAllRulesEndpointSchema = deleteAllRulesEndpointSchema;
|
|
@@ -0,0 +1,34 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, Symbol.toStringTag, { value: "Module" });
|
|
3
|
+
const apiRoute = require("@prosopo/api-route");
|
|
4
|
+
const zod = require("zod");
|
|
5
|
+
const accessPolicyResolver = require("../accessPolicyResolver.cjs");
|
|
6
|
+
const deleteRulesEndpointSchema = zod.z.array(accessPolicyResolver.policyFilterSchema);
|
|
7
|
+
class DeleteRulesEndpoint {
|
|
8
|
+
constructor(accessRulesStorage) {
|
|
9
|
+
this.accessRulesStorage = accessRulesStorage;
|
|
10
|
+
}
|
|
11
|
+
async processRequest(args) {
|
|
12
|
+
const allRuleIds = [];
|
|
13
|
+
for (const accessRuleFilter of args) {
|
|
14
|
+
const parsedRules = accessPolicyResolver.policyFilterSchema.parse(accessRuleFilter);
|
|
15
|
+
const foundRuleIds = await this.accessRulesStorage.findRuleIds(parsedRules);
|
|
16
|
+
allRuleIds.push(...foundRuleIds);
|
|
17
|
+
}
|
|
18
|
+
const uniqueRuleIds = [...new Set(allRuleIds)];
|
|
19
|
+
if (uniqueRuleIds.length > 0) {
|
|
20
|
+
await this.accessRulesStorage.deleteRules(uniqueRuleIds);
|
|
21
|
+
}
|
|
22
|
+
return {
|
|
23
|
+
status: apiRoute.ApiEndpointResponseStatus.SUCCESS,
|
|
24
|
+
data: {
|
|
25
|
+
deleted_count: uniqueRuleIds.length
|
|
26
|
+
}
|
|
27
|
+
};
|
|
28
|
+
}
|
|
29
|
+
getRequestArgsSchema() {
|
|
30
|
+
return deleteRulesEndpointSchema;
|
|
31
|
+
}
|
|
32
|
+
}
|
|
33
|
+
exports.DeleteRulesEndpoint = DeleteRulesEndpoint;
|
|
34
|
+
exports.deleteRulesEndpointSchema = deleteRulesEndpointSchema;
|
|
@@ -0,0 +1,65 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, Symbol.toStringTag, { value: "Module" });
|
|
3
|
+
const apiRoute = require("@prosopo/api-route");
|
|
4
|
+
const common = require("@prosopo/common");
|
|
5
|
+
const zod = require("zod");
|
|
6
|
+
const accessPolicy = require("../accessPolicy.cjs");
|
|
7
|
+
const insertRulesEndpointSchema = zod.z.object({
|
|
8
|
+
accessPolicy: accessPolicy.accessPolicySchema,
|
|
9
|
+
policyScope: accessPolicy.policyScopeSchema.optional(),
|
|
10
|
+
userScopes: zod.z.array(accessPolicy.userScopeInputSchema),
|
|
11
|
+
expirationTimestampSeconds: zod.z.number().optional().transform((val) => val !== void 0 ? Math.floor(val) : val)
|
|
12
|
+
});
|
|
13
|
+
class InsertRulesEndpoint {
|
|
14
|
+
constructor(accessRulesWriter) {
|
|
15
|
+
this.accessRulesWriter = accessRulesWriter;
|
|
16
|
+
}
|
|
17
|
+
async processRequest(args, logger) {
|
|
18
|
+
logger = logger || common.getLogger(common.LogLevel.enum.info, "InsertRulesEndpoint");
|
|
19
|
+
const timeoutPromise = new Promise((resolve) => {
|
|
20
|
+
setTimeout(() => {
|
|
21
|
+
resolve({
|
|
22
|
+
status: apiRoute.ApiEndpointResponseStatus.PROCESSING
|
|
23
|
+
});
|
|
24
|
+
}, 5e3);
|
|
25
|
+
});
|
|
26
|
+
const createRulesPromise = this.createRules(args).then(() => ({
|
|
27
|
+
status: apiRoute.ApiEndpointResponseStatus.SUCCESS
|
|
28
|
+
})).catch((error) => {
|
|
29
|
+
if (logger?.getLogLevel() === common.LogLevel.enum.debug) {
|
|
30
|
+
logger.error(() => ({
|
|
31
|
+
err: error,
|
|
32
|
+
data: { args },
|
|
33
|
+
msg: "Failed to insert access rules"
|
|
34
|
+
}));
|
|
35
|
+
}
|
|
36
|
+
return {
|
|
37
|
+
status: apiRoute.ApiEndpointResponseStatus.FAIL
|
|
38
|
+
};
|
|
39
|
+
});
|
|
40
|
+
return Promise.race([timeoutPromise, createRulesPromise]);
|
|
41
|
+
}
|
|
42
|
+
getRequestArgsSchema() {
|
|
43
|
+
return insertRulesEndpointSchema;
|
|
44
|
+
}
|
|
45
|
+
async createRules(args) {
|
|
46
|
+
const policyScope = args.policyScope || {};
|
|
47
|
+
const createPromises = [];
|
|
48
|
+
for (const userScope of args.userScopes) {
|
|
49
|
+
const rule = {
|
|
50
|
+
...args.accessPolicy,
|
|
51
|
+
...policyScope,
|
|
52
|
+
...userScope
|
|
53
|
+
};
|
|
54
|
+
createPromises.push(
|
|
55
|
+
this.accessRulesWriter.insertRule(
|
|
56
|
+
rule,
|
|
57
|
+
args.expirationTimestampSeconds
|
|
58
|
+
)
|
|
59
|
+
);
|
|
60
|
+
}
|
|
61
|
+
return Promise.all(createPromises);
|
|
62
|
+
}
|
|
63
|
+
}
|
|
64
|
+
exports.InsertRulesEndpoint = InsertRulesEndpoint;
|
|
65
|
+
exports.insertRulesEndpointSchema = insertRulesEndpointSchema;
|