@prosopo/user-access-policy 2.3.2
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/dist/blacklistInspector.d.ts +6 -0
- package/dist/blacklistInspector.d.ts.map +1 -0
- package/dist/blacklistInspector.js +2 -0
- package/dist/blacklistInspector.js.map +1 -0
- package/dist/imageCaptchaConfigResolver.d.ts +7 -0
- package/dist/imageCaptchaConfigResolver.d.ts.map +1 -0
- package/dist/imageCaptchaConfigResolver.js +2 -0
- package/dist/imageCaptchaConfigResolver.js.map +1 -0
- package/dist/index.d.ts +15 -0
- package/dist/index.d.ts.map +1 -0
- package/dist/index.js +20 -0
- package/dist/index.js.map +1 -0
- package/dist/rules/api/apiRulePaths.d.ts +6 -0
- package/dist/rules/api/apiRulePaths.d.ts.map +1 -0
- package/dist/rules/api/apiRulePaths.js +6 -0
- package/dist/rules/api/apiRulePaths.js.map +1 -0
- package/dist/rules/api/apiRuleRoutesProvider.d.ts +9 -0
- package/dist/rules/api/apiRuleRoutesProvider.d.ts.map +1 -0
- package/dist/rules/api/apiRuleRoutesProvider.js +22 -0
- package/dist/rules/api/apiRuleRoutesProvider.js.map +1 -0
- package/dist/rules/api/deleteMany/apiDeleteManyRulesArgsSchema.d.ts +159 -0
- package/dist/rules/api/deleteMany/apiDeleteManyRulesArgsSchema.d.ts.map +1 -0
- package/dist/rules/api/deleteMany/apiDeleteManyRulesArgsSchema.js +9 -0
- package/dist/rules/api/deleteMany/apiDeleteManyRulesArgsSchema.js.map +1 -0
- package/dist/rules/api/deleteMany/apiDeleteManyRulesEndpoint.d.ts +12 -0
- package/dist/rules/api/deleteMany/apiDeleteManyRulesEndpoint.d.ts.map +1 -0
- package/dist/rules/api/deleteMany/apiDeleteManyRulesEndpoint.js +18 -0
- package/dist/rules/api/deleteMany/apiDeleteManyRulesEndpoint.js.map +1 -0
- package/dist/rules/api/getExpressApiRuleRateLimits.d.ts +8 -0
- package/dist/rules/api/getExpressApiRuleRateLimits.d.ts.map +1 -0
- package/dist/rules/api/getExpressApiRuleRateLimits.js +21 -0
- package/dist/rules/api/getExpressApiRuleRateLimits.js.map +1 -0
- package/dist/rules/api/insertMany/apiInsertManyRulesArgsSchema.d.ts +199 -0
- package/dist/rules/api/insertMany/apiInsertManyRulesArgsSchema.d.ts.map +1 -0
- package/dist/rules/api/insertMany/apiInsertManyRulesArgsSchema.js +13 -0
- package/dist/rules/api/insertMany/apiInsertManyRulesArgsSchema.js.map +1 -0
- package/dist/rules/api/insertMany/apiInsertManyRulesEndpoint.d.ts +15 -0
- package/dist/rules/api/insertMany/apiInsertManyRulesEndpoint.d.ts.map +1 -0
- package/dist/rules/api/insertMany/apiInsertManyRulesEndpoint.js +50 -0
- package/dist/rules/api/insertMany/apiInsertManyRulesEndpoint.js.map +1 -0
- package/dist/rules/blacklistRulesInspector.d.ts +12 -0
- package/dist/rules/blacklistRulesInspector.d.ts.map +1 -0
- package/dist/rules/blacklistRulesInspector.js +29 -0
- package/dist/rules/blacklistRulesInspector.js.map +1 -0
- package/dist/rules/imageCaptchaConfigRulesResolver.d.ts +19 -0
- package/dist/rules/imageCaptchaConfigRulesResolver.d.ts.map +1 -0
- package/dist/rules/imageCaptchaConfigRulesResolver.js +82 -0
- package/dist/rules/imageCaptchaConfigRulesResolver.js.map +1 -0
- package/dist/rules/mongoose/indexes/mongooseIndex.d.ts +7 -0
- package/dist/rules/mongoose/indexes/mongooseIndex.d.ts.map +1 -0
- package/dist/rules/mongoose/indexes/mongooseIndex.js +2 -0
- package/dist/rules/mongoose/indexes/mongooseIndex.js.map +1 -0
- package/dist/rules/mongoose/indexes/rulePerformanceMongooseIndexes.d.ts +4 -0
- package/dist/rules/mongoose/indexes/rulePerformanceMongooseIndexes.d.ts.map +1 -0
- package/dist/rules/mongoose/indexes/rulePerformanceMongooseIndexes.js +49 -0
- package/dist/rules/mongoose/indexes/rulePerformanceMongooseIndexes.js.map +1 -0
- package/dist/rules/mongoose/indexes/ruleUniqueMongooseIndexes.d.ts +4 -0
- package/dist/rules/mongoose/indexes/ruleUniqueMongooseIndexes.d.ts.map +1 -0
- package/dist/rules/mongoose/indexes/ruleUniqueMongooseIndexes.js +136 -0
- package/dist/rules/mongoose/indexes/ruleUniqueMongooseIndexes.js.map +1 -0
- package/dist/rules/mongoose/ruleMongooseRecord.d.ts +7 -0
- package/dist/rules/mongoose/ruleMongooseRecord.d.ts.map +1 -0
- package/dist/rules/mongoose/ruleMongooseRecord.js +2 -0
- package/dist/rules/mongoose/ruleMongooseRecord.js.map +1 -0
- package/dist/rules/mongoose/rulesMongooseStorage.d.ts +30 -0
- package/dist/rules/mongoose/rulesMongooseStorage.d.ts.map +1 -0
- package/dist/rules/mongoose/rulesMongooseStorage.js +143 -0
- package/dist/rules/mongoose/rulesMongooseStorage.js.map +1 -0
- package/dist/rules/mongoose/schemas/config/configMongooseSchema.d.ts +43 -0
- package/dist/rules/mongoose/schemas/config/configMongooseSchema.d.ts.map +1 -0
- package/dist/rules/mongoose/schemas/config/configMongooseSchema.js +10 -0
- package/dist/rules/mongoose/schemas/config/configMongooseSchema.js.map +1 -0
- package/dist/rules/mongoose/schemas/config/imageCaptchaConfigMongooseSchema.d.ts +29 -0
- package/dist/rules/mongoose/schemas/config/imageCaptchaConfigMongooseSchema.d.ts.map +1 -0
- package/dist/rules/mongoose/schemas/config/imageCaptchaConfigMongooseSchema.js +13 -0
- package/dist/rules/mongoose/schemas/config/imageCaptchaConfigMongooseSchema.js.map +1 -0
- package/dist/rules/mongoose/schemas/getRuleMongooseSchema.d.ts +5 -0
- package/dist/rules/mongoose/schemas/getRuleMongooseSchema.d.ts.map +1 -0
- package/dist/rules/mongoose/schemas/getRuleMongooseSchema.js +15 -0
- package/dist/rules/mongoose/schemas/getRuleMongooseSchema.js.map +1 -0
- package/dist/rules/mongoose/schemas/ip/ipMongooseSchema.d.ts +141 -0
- package/dist/rules/mongoose/schemas/ip/ipMongooseSchema.d.ts.map +1 -0
- package/dist/rules/mongoose/schemas/ip/ipMongooseSchema.js +25 -0
- package/dist/rules/mongoose/schemas/ip/ipMongooseSchema.js.map +1 -0
- package/dist/rules/mongoose/schemas/ip/v4/ipV4MaskMongooseSchema.d.ts +36 -0
- package/dist/rules/mongoose/schemas/ip/v4/ipV4MaskMongooseSchema.d.ts.map +1 -0
- package/dist/rules/mongoose/schemas/ip/v4/ipV4MaskMongooseSchema.js +8 -0
- package/dist/rules/mongoose/schemas/ip/v4/ipV4MaskMongooseSchema.js.map +1 -0
- package/dist/rules/mongoose/schemas/ip/v4/ipV4MongooseSchema.d.ts +64 -0
- package/dist/rules/mongoose/schemas/ip/v4/ipV4MongooseSchema.d.ts.map +1 -0
- package/dist/rules/mongoose/schemas/ip/v4/ipV4MongooseSchema.js +12 -0
- package/dist/rules/mongoose/schemas/ip/v4/ipV4MongooseSchema.js.map +1 -0
- package/dist/rules/mongoose/schemas/ip/v6/ipV6MaskMongooseSchema.d.ts +36 -0
- package/dist/rules/mongoose/schemas/ip/v6/ipV6MaskMongooseSchema.d.ts.map +1 -0
- package/dist/rules/mongoose/schemas/ip/v6/ipV6MaskMongooseSchema.js +17 -0
- package/dist/rules/mongoose/schemas/ip/v6/ipV6MaskMongooseSchema.js.map +1 -0
- package/dist/rules/mongoose/schemas/ip/v6/ipV6MongooseSchema.d.ts +64 -0
- package/dist/rules/mongoose/schemas/ip/v6/ipV6MongooseSchema.d.ts.map +1 -0
- package/dist/rules/mongoose/schemas/ip/v6/ipV6MongooseSchema.js +17 -0
- package/dist/rules/mongoose/schemas/ip/v6/ipV6MongooseSchema.js.map +1 -0
- package/dist/rules/mongoose/schemas/ruleMongooseSchema.d.ts +9 -0
- package/dist/rules/mongoose/schemas/ruleMongooseSchema.d.ts.map +1 -0
- package/dist/rules/mongoose/schemas/ruleMongooseSchema.js +32 -0
- package/dist/rules/mongoose/schemas/ruleMongooseSchema.js.map +1 -0
- package/dist/rules/rule/config/imageCaptcha/imageCaptchaConfig.d.ts +5 -0
- package/dist/rules/rule/config/imageCaptcha/imageCaptchaConfig.d.ts.map +1 -0
- package/dist/rules/rule/config/imageCaptcha/imageCaptchaConfig.js +2 -0
- package/dist/rules/rule/config/imageCaptcha/imageCaptchaConfig.js.map +1 -0
- package/dist/rules/rule/config/imageCaptcha/imageCaptchaConfigSchema.d.ts +12 -0
- package/dist/rules/rule/config/imageCaptcha/imageCaptchaConfigSchema.d.ts.map +1 -0
- package/dist/rules/rule/config/imageCaptcha/imageCaptchaConfigSchema.js +7 -0
- package/dist/rules/rule/config/imageCaptcha/imageCaptchaConfigSchema.js.map +1 -0
- package/dist/rules/rule/config/ruleConfig.d.ts +5 -0
- package/dist/rules/rule/config/ruleConfig.d.ts.map +1 -0
- package/dist/rules/rule/config/ruleConfig.js +2 -0
- package/dist/rules/rule/config/ruleConfig.js.map +1 -0
- package/dist/rules/rule/config/ruleConfigSchema.d.ts +24 -0
- package/dist/rules/rule/config/ruleConfigSchema.d.ts.map +1 -0
- package/dist/rules/rule/config/ruleConfigSchema.js +7 -0
- package/dist/rules/rule/config/ruleConfigSchema.js.map +1 -0
- package/dist/rules/rule/ip/ruleIp.d.ts +5 -0
- package/dist/rules/rule/ip/ruleIp.d.ts.map +1 -0
- package/dist/rules/rule/ip/ruleIp.js +2 -0
- package/dist/rules/rule/ip/ruleIp.js.map +1 -0
- package/dist/rules/rule/ip/ruleIpSchema.d.ts +108 -0
- package/dist/rules/rule/ip/ruleIpSchema.d.ts.map +1 -0
- package/dist/rules/rule/ip/ruleIpSchema.js +9 -0
- package/dist/rules/rule/ip/ruleIpSchema.js.map +1 -0
- package/dist/rules/rule/ip/ruleIpVersion.d.ts +6 -0
- package/dist/rules/rule/ip/ruleIpVersion.d.ts.map +1 -0
- package/dist/rules/rule/ip/ruleIpVersion.js +7 -0
- package/dist/rules/rule/ip/ruleIpVersion.js.map +1 -0
- package/dist/rules/rule/ip/v4/mask/ruleIpV4Mask.d.ts +5 -0
- package/dist/rules/rule/ip/v4/mask/ruleIpV4Mask.d.ts.map +1 -0
- package/dist/rules/rule/ip/v4/mask/ruleIpV4Mask.js +2 -0
- package/dist/rules/rule/ip/v4/mask/ruleIpV4Mask.js.map +1 -0
- package/dist/rules/rule/ip/v4/mask/ruleIpV4MaskSchema.d.ts +15 -0
- package/dist/rules/rule/ip/v4/mask/ruleIpV4MaskSchema.d.ts.map +1 -0
- package/dist/rules/rule/ip/v4/mask/ruleIpV4MaskSchema.js +8 -0
- package/dist/rules/rule/ip/v4/mask/ruleIpV4MaskSchema.js.map +1 -0
- package/dist/rules/rule/ip/v4/ruleIpV4.d.ts +5 -0
- package/dist/rules/rule/ip/v4/ruleIpV4.d.ts.map +1 -0
- package/dist/rules/rule/ip/v4/ruleIpV4.js +2 -0
- package/dist/rules/rule/ip/v4/ruleIpV4.js.map +1 -0
- package/dist/rules/rule/ip/v4/ruleIpV4Schema.d.ts +35 -0
- package/dist/rules/rule/ip/v4/ruleIpV4Schema.d.ts.map +1 -0
- package/dist/rules/rule/ip/v4/ruleIpV4Schema.js +9 -0
- package/dist/rules/rule/ip/v4/ruleIpV4Schema.js.map +1 -0
- package/dist/rules/rule/ip/v6/mask/ruleIpV6Mask.d.ts +5 -0
- package/dist/rules/rule/ip/v6/mask/ruleIpV6Mask.d.ts.map +1 -0
- package/dist/rules/rule/ip/v6/mask/ruleIpV6Mask.js +2 -0
- package/dist/rules/rule/ip/v6/mask/ruleIpV6Mask.js.map +1 -0
- package/dist/rules/rule/ip/v6/mask/ruleIpV6MaskSchema.d.ts +15 -0
- package/dist/rules/rule/ip/v6/mask/ruleIpV6MaskSchema.d.ts.map +1 -0
- package/dist/rules/rule/ip/v6/mask/ruleIpV6MaskSchema.js +8 -0
- package/dist/rules/rule/ip/v6/mask/ruleIpV6MaskSchema.js.map +1 -0
- package/dist/rules/rule/ip/v6/ruleIpV6.d.ts +5 -0
- package/dist/rules/rule/ip/v6/ruleIpV6.d.ts.map +1 -0
- package/dist/rules/rule/ip/v6/ruleIpV6.js +2 -0
- package/dist/rules/rule/ip/v6/ruleIpV6.js.map +1 -0
- package/dist/rules/rule/ip/v6/ruleIpV6NumericMaxLength.d.ts +3 -0
- package/dist/rules/rule/ip/v6/ruleIpV6NumericMaxLength.d.ts.map +1 -0
- package/dist/rules/rule/ip/v6/ruleIpV6NumericMaxLength.js +3 -0
- package/dist/rules/rule/ip/v6/ruleIpV6NumericMaxLength.js.map +1 -0
- package/dist/rules/rule/ip/v6/ruleIpV6Schema.d.ts +35 -0
- package/dist/rules/rule/ip/v6/ruleIpV6Schema.d.ts.map +1 -0
- package/dist/rules/rule/ip/v6/ruleIpV6Schema.js +9 -0
- package/dist/rules/rule/ip/v6/ruleIpV6Schema.js.map +1 -0
- package/dist/rules/rule/rule.d.ts +12 -0
- package/dist/rules/rule/rule.d.ts.map +1 -0
- package/dist/rules/rule/rule.js +2 -0
- package/dist/rules/rule/rule.js.map +1 -0
- package/dist/rules/storage/filters/deleteRuleFilters.d.ts +8 -0
- package/dist/rules/storage/filters/deleteRuleFilters.d.ts.map +1 -0
- package/dist/rules/storage/filters/deleteRuleFilters.js +2 -0
- package/dist/rules/storage/filters/deleteRuleFilters.js.map +1 -0
- package/dist/rules/storage/filters/search/searchRuleFilterSettings.d.ts +6 -0
- package/dist/rules/storage/filters/search/searchRuleFilterSettings.d.ts.map +1 -0
- package/dist/rules/storage/filters/search/searchRuleFilterSettings.js +2 -0
- package/dist/rules/storage/filters/search/searchRuleFilterSettings.js.map +1 -0
- package/dist/rules/storage/filters/search/searchRuleFilters.d.ts +8 -0
- package/dist/rules/storage/filters/search/searchRuleFilters.d.ts.map +1 -0
- package/dist/rules/storage/filters/search/searchRuleFilters.js +2 -0
- package/dist/rules/storage/filters/search/searchRuleFilters.js.map +1 -0
- package/dist/rules/storage/ruleRecord.d.ts +6 -0
- package/dist/rules/storage/ruleRecord.d.ts.map +1 -0
- package/dist/rules/storage/ruleRecord.js +2 -0
- package/dist/rules/storage/ruleRecord.js.map +1 -0
- package/dist/rules/storage/rulesStorage.d.ts +14 -0
- package/dist/rules/storage/rulesStorage.d.ts.map +1 -0
- package/dist/rules/storage/rulesStorage.js +2 -0
- package/dist/rules/storage/rulesStorage.js.map +1 -0
- package/dist/tests/benchmark/commands/commandBase.d.ts +14 -0
- package/dist/tests/benchmark/commands/commandBase.d.ts.map +1 -0
- package/dist/tests/benchmark/commands/commandBase.js +22 -0
- package/dist/tests/benchmark/commands/commandBase.js.map +1 -0
- package/dist/tests/benchmark/commands/measureFindCommand.d.ts +14 -0
- package/dist/tests/benchmark/commands/measureFindCommand.d.ts.map +1 -0
- package/dist/tests/benchmark/commands/measureFindCommand.js +60 -0
- package/dist/tests/benchmark/commands/measureFindCommand.js.map +1 -0
- package/dist/tests/benchmark/commands/populateCommand.d.ts +18 -0
- package/dist/tests/benchmark/commands/populateCommand.d.ts.map +1 -0
- package/dist/tests/benchmark/commands/populateCommand.js +97 -0
- package/dist/tests/benchmark/commands/populateCommand.js.map +1 -0
- package/dist/tests/benchmark/connectionCleaner/connectionCleaner.d.ts +5 -0
- package/dist/tests/benchmark/connectionCleaner/connectionCleaner.d.ts.map +1 -0
- package/dist/tests/benchmark/connectionCleaner/connectionCleaner.js +2 -0
- package/dist/tests/benchmark/connectionCleaner/connectionCleaner.js.map +1 -0
- package/dist/tests/benchmark/connectionCleaner/mongooseConnectionCleaner.d.ts +6 -0
- package/dist/tests/benchmark/connectionCleaner/mongooseConnectionCleaner.d.ts.map +1 -0
- package/dist/tests/benchmark/connectionCleaner/mongooseConnectionCleaner.js +8 -0
- package/dist/tests/benchmark/connectionCleaner/mongooseConnectionCleaner.js.map +1 -0
- package/dist/tests/benchmark/mongooseRulesStorageBenchmark.d.ts +2 -0
- package/dist/tests/benchmark/mongooseRulesStorageBenchmark.d.ts.map +1 -0
- package/dist/tests/benchmark/mongooseRulesStorageBenchmark.js +8 -0
- package/dist/tests/benchmark/mongooseRulesStorageBenchmark.js.map +1 -0
- package/dist/tests/benchmark/rulesStorageBenchmark.d.ts +12 -0
- package/dist/tests/benchmark/rulesStorageBenchmark.d.ts.map +1 -0
- package/dist/tests/benchmark/rulesStorageBenchmark.js +30 -0
- package/dist/tests/benchmark/rulesStorageBenchmark.js.map +1 -0
- package/dist/tests/benchmark/storageFactory/mongooseRulesStorageFactory.d.ts +10 -0
- package/dist/tests/benchmark/storageFactory/mongooseRulesStorageFactory.d.ts.map +1 -0
- package/dist/tests/benchmark/storageFactory/mongooseRulesStorageFactory.js +16 -0
- package/dist/tests/benchmark/storageFactory/mongooseRulesStorageFactory.js.map +1 -0
- package/dist/tests/benchmark/storageFactory/rulesStorageFactory.d.ts +6 -0
- package/dist/tests/benchmark/storageFactory/rulesStorageFactory.d.ts.map +1 -0
- package/dist/tests/benchmark/storageFactory/rulesStorageFactory.js +2 -0
- package/dist/tests/benchmark/storageFactory/rulesStorageFactory.js.map +1 -0
- package/dist/tests/rules/ImageCaptchaConfigRulesResolver.test.d.ts +2 -0
- package/dist/tests/rules/ImageCaptchaConfigRulesResolver.test.d.ts.map +1 -0
- package/dist/tests/rules/ImageCaptchaConfigRulesResolver.test.js +75 -0
- package/dist/tests/rules/ImageCaptchaConfigRulesResolver.test.js.map +1 -0
- package/dist/tests/rules/blacklistRulesInspector.unit.test.d.ts +2 -0
- package/dist/tests/rules/blacklistRulesInspector.unit.test.d.ts.map +1 -0
- package/dist/tests/rules/blacklistRulesInspector.unit.test.js +58 -0
- package/dist/tests/rules/blacklistRulesInspector.unit.test.js.map +1 -0
- package/dist/tests/rules/loggerMockedInstance.d.ts +13 -0
- package/dist/tests/rules/loggerMockedInstance.d.ts.map +1 -0
- package/dist/tests/rules/loggerMockedInstance.js +14 -0
- package/dist/tests/rules/loggerMockedInstance.js.map +1 -0
- package/dist/tests/rules/mongoose/find.unit.test.d.ts +2 -0
- package/dist/tests/rules/mongoose/find.unit.test.d.ts.map +1 -0
- package/dist/tests/rules/mongoose/find.unit.test.js +202 -0
- package/dist/tests/rules/mongoose/find.unit.test.js.map +1 -0
- package/dist/tests/rules/mongoose/insert/insertIpV6Formatting.unit.test.d.ts +2 -0
- package/dist/tests/rules/mongoose/insert/insertIpV6Formatting.unit.test.d.ts.map +1 -0
- package/dist/tests/rules/mongoose/insert/insertIpV6Formatting.unit.test.js +131 -0
- package/dist/tests/rules/mongoose/insert/insertIpV6Formatting.unit.test.js.map +1 -0
- package/dist/tests/rules/mongoose/insert/insertValidation.unit.test.d.ts +2 -0
- package/dist/tests/rules/mongoose/insert/insertValidation.unit.test.d.ts.map +1 -0
- package/dist/tests/rules/mongoose/insert/insertValidation.unit.test.js +101 -0
- package/dist/tests/rules/mongoose/insert/insertValidation.unit.test.js.map +1 -0
- package/dist/tests/rules/mongoose/ip.unit.test.d.ts +2 -0
- package/dist/tests/rules/mongoose/ip.unit.test.d.ts.map +1 -0
- package/dist/tests/rules/mongoose/ip.unit.test.js +392 -0
- package/dist/tests/rules/mongoose/ip.unit.test.js.map +1 -0
- package/dist/tests/rules/storage/testRulesStorage.d.ts +17 -0
- package/dist/tests/rules/storage/testRulesStorage.d.ts.map +1 -0
- package/dist/tests/rules/storage/testRulesStorage.js +25 -0
- package/dist/tests/rules/storage/testRulesStorage.js.map +1 -0
- package/package.json +47 -0
- package/vite.cjs.config.ts +23 -0
- package/vite.test.config.ts +17 -0
|
@@ -0,0 +1,6 @@
|
|
|
1
|
+
import type { IPAddress } from "@prosopo/types";
|
|
2
|
+
interface BlacklistInspector {
|
|
3
|
+
isUserBlacklisted(clientId: string, userIpAddress: IPAddress, userId: string): Promise<boolean>;
|
|
4
|
+
}
|
|
5
|
+
export type { BlacklistInspector };
|
|
6
|
+
//# sourceMappingURL=blacklistInspector.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"blacklistInspector.d.ts","sourceRoot":"","sources":["../src/blacklistInspector.ts"],"names":[],"mappings":"AAcA,OAAO,KAAK,EAAE,SAAS,EAAE,MAAM,gBAAgB,CAAC;AAEhD,UAAU,kBAAkB;IAC3B,iBAAiB,CAChB,QAAQ,EAAE,MAAM,EAChB,aAAa,EAAE,SAAS,EACxB,MAAM,EAAE,MAAM,GACZ,OAAO,CAAC,OAAO,CAAC,CAAC;CACpB;AAED,YAAY,EAAE,kBAAkB,EAAE,CAAC"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"blacklistInspector.js","sourceRoot":"","sources":["../src/blacklistInspector.ts"],"names":[],"mappings":""}
|
|
@@ -0,0 +1,7 @@
|
|
|
1
|
+
import type { IPAddress, ProsopoCaptchaCountConfigSchemaOutput } from "@prosopo/types";
|
|
2
|
+
interface ImageCaptchaConfigResolver {
|
|
3
|
+
isConfigDefined(clientId: string, userIpAddress: IPAddress, userId: string): Promise<boolean>;
|
|
4
|
+
resolveConfig(defaults: ProsopoCaptchaCountConfigSchemaOutput, userIpAddress: IPAddress, userId: string, clientId: string): Promise<ProsopoCaptchaCountConfigSchemaOutput>;
|
|
5
|
+
}
|
|
6
|
+
export type { ImageCaptchaConfigResolver };
|
|
7
|
+
//# sourceMappingURL=imageCaptchaConfigResolver.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"imageCaptchaConfigResolver.d.ts","sourceRoot":"","sources":["../src/imageCaptchaConfigResolver.ts"],"names":[],"mappings":"AAcA,OAAO,KAAK,EACX,SAAS,EACT,qCAAqC,EACrC,MAAM,gBAAgB,CAAC;AAExB,UAAU,0BAA0B;IACnC,eAAe,CACd,QAAQ,EAAE,MAAM,EAChB,aAAa,EAAE,SAAS,EACxB,MAAM,EAAE,MAAM,GACZ,OAAO,CAAC,OAAO,CAAC,CAAC;IAEpB,aAAa,CACZ,QAAQ,EAAE,qCAAqC,EAC/C,aAAa,EAAE,SAAS,EACxB,MAAM,EAAE,MAAM,EACd,QAAQ,EAAE,MAAM,GACd,OAAO,CAAC,qCAAqC,CAAC,CAAC;CAClD;AAED,YAAY,EAAE,0BAA0B,EAAE,CAAC"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"imageCaptchaConfigResolver.js","sourceRoot":"","sources":["../src/imageCaptchaConfigResolver.ts"],"names":[],"mappings":""}
|
package/dist/index.d.ts
ADDED
|
@@ -0,0 +1,15 @@
|
|
|
1
|
+
import type { ApiRoutesProvider } from "@prosopo/api-route";
|
|
2
|
+
import type { Logger } from "@prosopo/common";
|
|
3
|
+
import type { Model } from "mongoose";
|
|
4
|
+
import type { BlacklistInspector } from "./blacklistInspector.js";
|
|
5
|
+
import { getExpressApiRuleRateLimits } from "./rules/api/getExpressApiRuleRateLimits.js";
|
|
6
|
+
import { ImageCaptchaConfigRulesResolver } from "./rules/imageCaptchaConfigRulesResolver.js";
|
|
7
|
+
import { getRuleMongooseSchema } from "./rules/mongoose/schemas/getRuleMongooseSchema.js";
|
|
8
|
+
import type { Rule } from "./rules/rule/rule.js";
|
|
9
|
+
import type { RulesStorage } from "./rules/storage/rulesStorage.js";
|
|
10
|
+
declare const createBlacklistInspector: (rulesStorage: RulesStorage, logger: Logger) => BlacklistInspector;
|
|
11
|
+
declare const createImageCaptchaConfigResolver: (rulesStorage: RulesStorage, logger: Logger) => ImageCaptchaConfigRulesResolver;
|
|
12
|
+
declare const createApiRuleRoutesProvider: (rulesStorage: RulesStorage) => ApiRoutesProvider;
|
|
13
|
+
declare const createMongooseRulesStorage: (logger: Logger, readingModel: Model<Rule> | null, writingModel?: Model<Rule> | null) => RulesStorage;
|
|
14
|
+
export { type Rule, type RulesStorage, type BlacklistInspector, createMongooseRulesStorage, createImageCaptchaConfigResolver, createBlacklistInspector, createApiRuleRoutesProvider, getRuleMongooseSchema, getExpressApiRuleRateLimits, };
|
|
15
|
+
//# sourceMappingURL=index.d.ts.map
|
|
@@ -0,0 +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,EAAE,MAAM,EAAE,MAAM,iBAAiB,CAAC;AAC9C,OAAO,KAAK,EAAE,KAAK,EAAE,MAAM,UAAU,CAAC;AACtC,OAAO,KAAK,EAAE,kBAAkB,EAAE,MAAM,yBAAyB,CAAC;AAElE,OAAO,EAAE,2BAA2B,EAAE,MAAM,4CAA4C,CAAC;AAEzF,OAAO,EAAE,+BAA+B,EAAE,MAAM,4CAA4C,CAAC;AAE7F,OAAO,EAAE,qBAAqB,EAAE,MAAM,mDAAmD,CAAC;AAC1F,OAAO,KAAK,EAAE,IAAI,EAAE,MAAM,sBAAsB,CAAC;AACjD,OAAO,KAAK,EAAE,YAAY,EAAE,MAAM,iCAAiC,CAAC;AAEpE,QAAA,MAAM,wBAAwB,iBACf,YAAY,UAClB,MAAM,KACZ,kBAEF,CAAC;AAEF,QAAA,MAAM,gCAAgC,iBACvB,YAAY,UAClB,MAAM,KACZ,+BAEF,CAAC;AAEF,QAAA,MAAM,2BAA2B,iBAClB,YAAY,KACxB,iBAEF,CAAC;AAEF,QAAA,MAAM,0BAA0B,WACvB,MAAM,gBACA,KAAK,CAAC,IAAI,CAAC,GAAG,IAAI,iBAClB,KAAK,CAAC,IAAI,CAAC,GAAG,IAAI,KAC9B,YAEF,CAAC;AAEF,OAAO,EACN,KAAK,IAAI,EACT,KAAK,YAAY,EACjB,KAAK,kBAAkB,EACvB,0BAA0B,EAC1B,gCAAgC,EAChC,wBAAwB,EACxB,2BAA2B,EAC3B,qBAAqB,EACrB,2BAA2B,GAC3B,CAAC"}
|
package/dist/index.js
ADDED
|
@@ -0,0 +1,20 @@
|
|
|
1
|
+
import { ApiRuleRoutesProvider } from "./rules/api/apiRuleRoutesProvider.js";
|
|
2
|
+
import { getExpressApiRuleRateLimits } from "./rules/api/getExpressApiRuleRateLimits.js";
|
|
3
|
+
import { BlacklistRulesInspector } from "./rules/blacklistRulesInspector.js";
|
|
4
|
+
import { ImageCaptchaConfigRulesResolver } from "./rules/imageCaptchaConfigRulesResolver.js";
|
|
5
|
+
import { RulesMongooseStorage } from "./rules/mongoose/rulesMongooseStorage.js";
|
|
6
|
+
import { getRuleMongooseSchema } from "./rules/mongoose/schemas/getRuleMongooseSchema.js";
|
|
7
|
+
const createBlacklistInspector = (rulesStorage, logger) => {
|
|
8
|
+
return new BlacklistRulesInspector(rulesStorage, logger);
|
|
9
|
+
};
|
|
10
|
+
const createImageCaptchaConfigResolver = (rulesStorage, logger) => {
|
|
11
|
+
return new ImageCaptchaConfigRulesResolver(rulesStorage, logger);
|
|
12
|
+
};
|
|
13
|
+
const createApiRuleRoutesProvider = (rulesStorage) => {
|
|
14
|
+
return new ApiRuleRoutesProvider(rulesStorage);
|
|
15
|
+
};
|
|
16
|
+
const createMongooseRulesStorage = (logger, readingModel, writingModel = null) => {
|
|
17
|
+
return new RulesMongooseStorage(logger, readingModel, writingModel);
|
|
18
|
+
};
|
|
19
|
+
export { createMongooseRulesStorage, createImageCaptchaConfigResolver, createBlacklistInspector, createApiRuleRoutesProvider, getRuleMongooseSchema, getExpressApiRuleRateLimits, };
|
|
20
|
+
//# sourceMappingURL=index.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index.js","sourceRoot":"","sources":["../src/index.ts"],"names":[],"mappings":"AAkBA,OAAO,EAAE,qBAAqB,EAAE,MAAM,sCAAsC,CAAC;AAC7E,OAAO,EAAE,2BAA2B,EAAE,MAAM,4CAA4C,CAAC;AACzF,OAAO,EAAE,uBAAuB,EAAE,MAAM,oCAAoC,CAAC;AAC7E,OAAO,EAAE,+BAA+B,EAAE,MAAM,4CAA4C,CAAC;AAC7F,OAAO,EAAE,oBAAoB,EAAE,MAAM,0CAA0C,CAAC;AAChF,OAAO,EAAE,qBAAqB,EAAE,MAAM,mDAAmD,CAAC;AAI1F,MAAM,wBAAwB,GAAG,CAChC,YAA0B,EAC1B,MAAc,EACO,EAAE;IACvB,OAAO,IAAI,uBAAuB,CAAC,YAAY,EAAE,MAAM,CAAC,CAAC;AAC1D,CAAC,CAAC;AAEF,MAAM,gCAAgC,GAAG,CACxC,YAA0B,EAC1B,MAAc,EACoB,EAAE;IACpC,OAAO,IAAI,+BAA+B,CAAC,YAAY,EAAE,MAAM,CAAC,CAAC;AAClE,CAAC,CAAC;AAEF,MAAM,2BAA2B,GAAG,CACnC,YAA0B,EACN,EAAE;IACtB,OAAO,IAAI,qBAAqB,CAAC,YAAY,CAAC,CAAC;AAChD,CAAC,CAAC;AAEF,MAAM,0BAA0B,GAAG,CAClC,MAAc,EACd,YAAgC,EAChC,eAAmC,IAAI,EACxB,EAAE;IACjB,OAAO,IAAI,oBAAoB,CAAC,MAAM,EAAE,YAAY,EAAE,YAAY,CAAC,CAAC;AACrE,CAAC,CAAC;AAEF,OAAO,EAIN,0BAA0B,EAC1B,gCAAgC,EAChC,wBAAwB,EACxB,2BAA2B,EAC3B,qBAAqB,EACrB,2BAA2B,GAC3B,CAAC"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"apiRulePaths.d.ts","sourceRoot":"","sources":["../../../src/rules/api/apiRulePaths.ts"],"names":[],"mappings":"AAcA,QAAA,MAAM,YAAY;;;CAGjB,CAAC;AAEF,OAAO,EAAE,YAAY,EAAE,CAAC"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"apiRulePaths.js","sourceRoot":"","sources":["../../../src/rules/api/apiRulePaths.ts"],"names":[],"mappings":"AAcA,MAAM,YAAY,GAAG;IACpB,WAAW,EAAE,kDAAkD;IAC/D,WAAW,EAAE,kDAAkD;CAC/D,CAAC;AAEF,OAAO,EAAE,YAAY,EAAE,CAAC"}
|
|
@@ -0,0 +1,9 @@
|
|
|
1
|
+
import type { ApiRoute, ApiRoutesProvider } from "@prosopo/api-route";
|
|
2
|
+
import type { RulesStorage } from "../storage/rulesStorage.js";
|
|
3
|
+
declare class ApiRuleRoutesProvider implements ApiRoutesProvider {
|
|
4
|
+
private readonly rulesStorage;
|
|
5
|
+
constructor(rulesStorage: RulesStorage);
|
|
6
|
+
getRoutes(): ApiRoute[];
|
|
7
|
+
}
|
|
8
|
+
export { ApiRuleRoutesProvider };
|
|
9
|
+
//# sourceMappingURL=apiRuleRoutesProvider.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"apiRuleRoutesProvider.d.ts","sourceRoot":"","sources":["../../../src/rules/api/apiRuleRoutesProvider.ts"],"names":[],"mappings":"AAcA,OAAO,KAAK,EAAE,QAAQ,EAAE,iBAAiB,EAAE,MAAM,oBAAoB,CAAC;AACtE,OAAO,KAAK,EAAE,YAAY,EAAE,MAAM,4BAA4B,CAAC;AAK/D,cAAM,qBAAsB,YAAW,iBAAiB;IACpC,OAAO,CAAC,QAAQ,CAAC,YAAY;gBAAZ,YAAY,EAAE,YAAY;IAEvD,SAAS,IAAI,QAAQ,EAAE;CAY9B;AAED,OAAO,EAAE,qBAAqB,EAAE,CAAC"}
|
|
@@ -0,0 +1,22 @@
|
|
|
1
|
+
import { apiRulePaths } from "./apiRulePaths.js";
|
|
2
|
+
import { ApiDeleteManyRulesEndpoint } from "./deleteMany/apiDeleteManyRulesEndpoint.js";
|
|
3
|
+
import { ApiInsertManyRulesEndpoint } from "./insertMany/apiInsertManyRulesEndpoint.js";
|
|
4
|
+
class ApiRuleRoutesProvider {
|
|
5
|
+
constructor(rulesStorage) {
|
|
6
|
+
this.rulesStorage = rulesStorage;
|
|
7
|
+
}
|
|
8
|
+
getRoutes() {
|
|
9
|
+
return [
|
|
10
|
+
{
|
|
11
|
+
path: apiRulePaths.INSERT_MANY,
|
|
12
|
+
endpoint: new ApiInsertManyRulesEndpoint(this.rulesStorage),
|
|
13
|
+
},
|
|
14
|
+
{
|
|
15
|
+
path: apiRulePaths.DELETE_MANY,
|
|
16
|
+
endpoint: new ApiDeleteManyRulesEndpoint(this.rulesStorage),
|
|
17
|
+
},
|
|
18
|
+
];
|
|
19
|
+
}
|
|
20
|
+
}
|
|
21
|
+
export { ApiRuleRoutesProvider };
|
|
22
|
+
//# sourceMappingURL=apiRuleRoutesProvider.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"apiRuleRoutesProvider.js","sourceRoot":"","sources":["../../../src/rules/api/apiRuleRoutesProvider.ts"],"names":[],"mappings":"AAgBA,OAAO,EAAE,YAAY,EAAE,MAAM,mBAAmB,CAAC;AACjD,OAAO,EAAE,0BAA0B,EAAE,MAAM,4CAA4C,CAAC;AACxF,OAAO,EAAE,0BAA0B,EAAE,MAAM,4CAA4C,CAAC;AAExF,MAAM,qBAAqB;IAC1B,YAAoC,YAA0B;QAA1B,iBAAY,GAAZ,YAAY,CAAc;IAAG,CAAC;IAE3D,SAAS;QACf,OAAO;YACN;gBACC,IAAI,EAAE,YAAY,CAAC,WAAW;gBAC9B,QAAQ,EAAE,IAAI,0BAA0B,CAAC,IAAI,CAAC,YAAY,CAAC;aAC3D;YACD;gBACC,IAAI,EAAE,YAAY,CAAC,WAAW;gBAC9B,QAAQ,EAAE,IAAI,0BAA0B,CAAC,IAAI,CAAC,YAAY,CAAC;aAC3D;SACD,CAAC;IACH,CAAC;CACD;AAED,OAAO,EAAE,qBAAqB,EAAE,CAAC"}
|
|
@@ -0,0 +1,159 @@
|
|
|
1
|
+
declare const apiDeleteManyRulesArgsSchema: import("zod").ZodArray<import("zod").ZodObject<{
|
|
2
|
+
clientId: import("zod").ZodOptional<import("zod").ZodString>;
|
|
3
|
+
userIp: import("zod").ZodOptional<import("zod").ZodObject<{
|
|
4
|
+
v4: import("zod").ZodOptional<import("zod").ZodObject<{
|
|
5
|
+
asNumeric: import("zod").ZodBigInt;
|
|
6
|
+
asString: import("zod").ZodString;
|
|
7
|
+
mask: import("zod").ZodOptional<import("zod").ZodObject<{
|
|
8
|
+
rangeMinAsNumeric: import("zod").ZodBigInt;
|
|
9
|
+
rangeMaxAsNumeric: import("zod").ZodBigInt;
|
|
10
|
+
asNumeric: import("zod").ZodNumber;
|
|
11
|
+
}, "strip", import("zod").ZodTypeAny, {
|
|
12
|
+
rangeMinAsNumeric: bigint;
|
|
13
|
+
rangeMaxAsNumeric: bigint;
|
|
14
|
+
asNumeric: number;
|
|
15
|
+
}, {
|
|
16
|
+
rangeMinAsNumeric: bigint;
|
|
17
|
+
rangeMaxAsNumeric: bigint;
|
|
18
|
+
asNumeric: number;
|
|
19
|
+
}>>;
|
|
20
|
+
}, "strip", import("zod").ZodTypeAny, {
|
|
21
|
+
asNumeric: bigint;
|
|
22
|
+
asString: string;
|
|
23
|
+
mask?: {
|
|
24
|
+
rangeMinAsNumeric: bigint;
|
|
25
|
+
rangeMaxAsNumeric: bigint;
|
|
26
|
+
asNumeric: number;
|
|
27
|
+
} | undefined;
|
|
28
|
+
}, {
|
|
29
|
+
asNumeric: bigint;
|
|
30
|
+
asString: string;
|
|
31
|
+
mask?: {
|
|
32
|
+
rangeMinAsNumeric: bigint;
|
|
33
|
+
rangeMaxAsNumeric: bigint;
|
|
34
|
+
asNumeric: number;
|
|
35
|
+
} | undefined;
|
|
36
|
+
}>>;
|
|
37
|
+
v6: import("zod").ZodOptional<import("zod").ZodObject<{
|
|
38
|
+
asNumericString: import("zod").ZodString;
|
|
39
|
+
asString: import("zod").ZodString;
|
|
40
|
+
mask: import("zod").ZodOptional<import("zod").ZodObject<{
|
|
41
|
+
rangeMinAsNumericString: import("zod").ZodString;
|
|
42
|
+
rangeMaxAsNumericString: import("zod").ZodString;
|
|
43
|
+
asNumeric: import("zod").ZodNumber;
|
|
44
|
+
}, "strip", import("zod").ZodTypeAny, {
|
|
45
|
+
asNumeric: number;
|
|
46
|
+
rangeMinAsNumericString: string;
|
|
47
|
+
rangeMaxAsNumericString: string;
|
|
48
|
+
}, {
|
|
49
|
+
asNumeric: number;
|
|
50
|
+
rangeMinAsNumericString: string;
|
|
51
|
+
rangeMaxAsNumericString: string;
|
|
52
|
+
}>>;
|
|
53
|
+
}, "strip", import("zod").ZodTypeAny, {
|
|
54
|
+
asString: string;
|
|
55
|
+
asNumericString: string;
|
|
56
|
+
mask?: {
|
|
57
|
+
asNumeric: number;
|
|
58
|
+
rangeMinAsNumericString: string;
|
|
59
|
+
rangeMaxAsNumericString: string;
|
|
60
|
+
} | undefined;
|
|
61
|
+
}, {
|
|
62
|
+
asString: string;
|
|
63
|
+
asNumericString: string;
|
|
64
|
+
mask?: {
|
|
65
|
+
asNumeric: number;
|
|
66
|
+
rangeMinAsNumericString: string;
|
|
67
|
+
rangeMaxAsNumericString: string;
|
|
68
|
+
} | undefined;
|
|
69
|
+
}>>;
|
|
70
|
+
}, "strip", import("zod").ZodTypeAny, {
|
|
71
|
+
v4?: {
|
|
72
|
+
asNumeric: bigint;
|
|
73
|
+
asString: string;
|
|
74
|
+
mask?: {
|
|
75
|
+
rangeMinAsNumeric: bigint;
|
|
76
|
+
rangeMaxAsNumeric: bigint;
|
|
77
|
+
asNumeric: number;
|
|
78
|
+
} | undefined;
|
|
79
|
+
} | undefined;
|
|
80
|
+
v6?: {
|
|
81
|
+
asString: string;
|
|
82
|
+
asNumericString: string;
|
|
83
|
+
mask?: {
|
|
84
|
+
asNumeric: number;
|
|
85
|
+
rangeMinAsNumericString: string;
|
|
86
|
+
rangeMaxAsNumericString: string;
|
|
87
|
+
} | undefined;
|
|
88
|
+
} | undefined;
|
|
89
|
+
}, {
|
|
90
|
+
v4?: {
|
|
91
|
+
asNumeric: bigint;
|
|
92
|
+
asString: string;
|
|
93
|
+
mask?: {
|
|
94
|
+
rangeMinAsNumeric: bigint;
|
|
95
|
+
rangeMaxAsNumeric: bigint;
|
|
96
|
+
asNumeric: number;
|
|
97
|
+
} | undefined;
|
|
98
|
+
} | undefined;
|
|
99
|
+
v6?: {
|
|
100
|
+
asString: string;
|
|
101
|
+
asNumericString: string;
|
|
102
|
+
mask?: {
|
|
103
|
+
asNumeric: number;
|
|
104
|
+
rangeMinAsNumericString: string;
|
|
105
|
+
rangeMaxAsNumericString: string;
|
|
106
|
+
} | undefined;
|
|
107
|
+
} | undefined;
|
|
108
|
+
}>>;
|
|
109
|
+
userId: import("zod").ZodOptional<import("zod").ZodString>;
|
|
110
|
+
}, "strip", import("zod").ZodTypeAny, {
|
|
111
|
+
clientId?: string | undefined;
|
|
112
|
+
userIp?: {
|
|
113
|
+
v4?: {
|
|
114
|
+
asNumeric: bigint;
|
|
115
|
+
asString: string;
|
|
116
|
+
mask?: {
|
|
117
|
+
rangeMinAsNumeric: bigint;
|
|
118
|
+
rangeMaxAsNumeric: bigint;
|
|
119
|
+
asNumeric: number;
|
|
120
|
+
} | undefined;
|
|
121
|
+
} | undefined;
|
|
122
|
+
v6?: {
|
|
123
|
+
asString: string;
|
|
124
|
+
asNumericString: string;
|
|
125
|
+
mask?: {
|
|
126
|
+
asNumeric: number;
|
|
127
|
+
rangeMinAsNumericString: string;
|
|
128
|
+
rangeMaxAsNumericString: string;
|
|
129
|
+
} | undefined;
|
|
130
|
+
} | undefined;
|
|
131
|
+
} | undefined;
|
|
132
|
+
userId?: string | undefined;
|
|
133
|
+
}, {
|
|
134
|
+
clientId?: string | undefined;
|
|
135
|
+
userIp?: {
|
|
136
|
+
v4?: {
|
|
137
|
+
asNumeric: bigint;
|
|
138
|
+
asString: string;
|
|
139
|
+
mask?: {
|
|
140
|
+
rangeMinAsNumeric: bigint;
|
|
141
|
+
rangeMaxAsNumeric: bigint;
|
|
142
|
+
asNumeric: number;
|
|
143
|
+
} | undefined;
|
|
144
|
+
} | undefined;
|
|
145
|
+
v6?: {
|
|
146
|
+
asString: string;
|
|
147
|
+
asNumericString: string;
|
|
148
|
+
mask?: {
|
|
149
|
+
asNumeric: number;
|
|
150
|
+
rangeMinAsNumericString: string;
|
|
151
|
+
rangeMaxAsNumericString: string;
|
|
152
|
+
} | undefined;
|
|
153
|
+
} | undefined;
|
|
154
|
+
} | undefined;
|
|
155
|
+
userId?: string | undefined;
|
|
156
|
+
}>, "many">;
|
|
157
|
+
type ApiDeleteManyRulesArgsSchema = typeof apiDeleteManyRulesArgsSchema;
|
|
158
|
+
export { apiDeleteManyRulesArgsSchema, type ApiDeleteManyRulesArgsSchema };
|
|
159
|
+
//# sourceMappingURL=apiDeleteManyRulesArgsSchema.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"apiDeleteManyRulesArgsSchema.d.ts","sourceRoot":"","sources":["../../../../src/rules/api/deleteMany/apiDeleteManyRulesArgsSchema.ts"],"names":[],"mappings":"AAiBA,QAAA,MAAM,4BAA4B;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;WAMjC,CAAC;AAEF,KAAK,4BAA4B,GAAG,OAAO,4BAA4B,CAAC;AAExE,OAAO,EAAE,4BAA4B,EAAE,KAAK,4BAA4B,EAAE,CAAC"}
|
|
@@ -0,0 +1,9 @@
|
|
|
1
|
+
import { array, object, string } from "zod";
|
|
2
|
+
import { ruleIpSchema } from "../../rule/ip/ruleIpSchema.js";
|
|
3
|
+
const apiDeleteManyRulesArgsSchema = array(object({
|
|
4
|
+
clientId: string().optional(),
|
|
5
|
+
userIp: ruleIpSchema.optional(),
|
|
6
|
+
userId: string().optional(),
|
|
7
|
+
}));
|
|
8
|
+
export { apiDeleteManyRulesArgsSchema };
|
|
9
|
+
//# sourceMappingURL=apiDeleteManyRulesArgsSchema.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"apiDeleteManyRulesArgsSchema.js","sourceRoot":"","sources":["../../../../src/rules/api/deleteMany/apiDeleteManyRulesArgsSchema.ts"],"names":[],"mappings":"AAcA,OAAO,EAAE,KAAK,EAAE,MAAM,EAAE,MAAM,EAAE,MAAM,KAAK,CAAC;AAC5C,OAAO,EAAE,YAAY,EAAE,MAAM,+BAA+B,CAAC;AAE7D,MAAM,4BAA4B,GAAG,KAAK,CACzC,MAAM,CAAC;IACN,QAAQ,EAAE,MAAM,EAAE,CAAC,QAAQ,EAAE;IAC7B,MAAM,EAAE,YAAY,CAAC,QAAQ,EAAE;IAC/B,MAAM,EAAE,MAAM,EAAE,CAAC,QAAQ,EAAE;CAC3B,CAAC,CACF,CAAC;AAIF,OAAO,EAAE,4BAA4B,EAAqC,CAAC"}
|
|
@@ -0,0 +1,12 @@
|
|
|
1
|
+
import { type ApiEndpoint, type ApiEndpointResponse } from "@prosopo/api-route";
|
|
2
|
+
import type { z } from "zod";
|
|
3
|
+
import type { RulesStorage } from "../../storage/rulesStorage.js";
|
|
4
|
+
import { type ApiDeleteManyRulesArgsSchema } from "./apiDeleteManyRulesArgsSchema.js";
|
|
5
|
+
declare class ApiDeleteManyRulesEndpoint implements ApiEndpoint<ApiDeleteManyRulesArgsSchema> {
|
|
6
|
+
private readonly rulesStorage;
|
|
7
|
+
constructor(rulesStorage: RulesStorage);
|
|
8
|
+
processRequest(args: z.infer<ApiDeleteManyRulesArgsSchema>): Promise<ApiEndpointResponse>;
|
|
9
|
+
getRequestArgsSchema(): ApiDeleteManyRulesArgsSchema;
|
|
10
|
+
}
|
|
11
|
+
export { ApiDeleteManyRulesEndpoint };
|
|
12
|
+
//# sourceMappingURL=apiDeleteManyRulesEndpoint.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"apiDeleteManyRulesEndpoint.d.ts","sourceRoot":"","sources":["../../../../src/rules/api/deleteMany/apiDeleteManyRulesEndpoint.ts"],"names":[],"mappings":"AAcA,OAAO,EACN,KAAK,WAAW,EAChB,KAAK,mBAAmB,EAExB,MAAM,oBAAoB,CAAC;AAC5B,OAAO,KAAK,EAAE,CAAC,EAAE,MAAM,KAAK,CAAC;AAC7B,OAAO,KAAK,EAAE,YAAY,EAAE,MAAM,+BAA+B,CAAC;AAClE,OAAO,EACN,KAAK,4BAA4B,EAEjC,MAAM,mCAAmC,CAAC;AAE3C,cAAM,0BACL,YAAW,WAAW,CAAC,4BAA4B,CAAC;IAEjC,OAAO,CAAC,QAAQ,CAAC,YAAY;gBAAZ,YAAY,EAAE,YAAY;IAExD,cAAc,CACnB,IAAI,EAAE,CAAC,CAAC,KAAK,CAAC,4BAA4B,CAAC,GACzC,OAAO,CAAC,mBAAmB,CAAC;IAQxB,oBAAoB,IAAI,4BAA4B;CAG3D;AAED,OAAO,EAAE,0BAA0B,EAAE,CAAC"}
|
|
@@ -0,0 +1,18 @@
|
|
|
1
|
+
import { ApiEndpointResponseStatus, } from "@prosopo/api-route";
|
|
2
|
+
import { apiDeleteManyRulesArgsSchema, } from "./apiDeleteManyRulesArgsSchema.js";
|
|
3
|
+
class ApiDeleteManyRulesEndpoint {
|
|
4
|
+
constructor(rulesStorage) {
|
|
5
|
+
this.rulesStorage = rulesStorage;
|
|
6
|
+
}
|
|
7
|
+
async processRequest(args) {
|
|
8
|
+
await this.rulesStorage.deleteMany(args);
|
|
9
|
+
return {
|
|
10
|
+
status: ApiEndpointResponseStatus.SUCCESS,
|
|
11
|
+
};
|
|
12
|
+
}
|
|
13
|
+
getRequestArgsSchema() {
|
|
14
|
+
return apiDeleteManyRulesArgsSchema;
|
|
15
|
+
}
|
|
16
|
+
}
|
|
17
|
+
export { ApiDeleteManyRulesEndpoint };
|
|
18
|
+
//# sourceMappingURL=apiDeleteManyRulesEndpoint.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"apiDeleteManyRulesEndpoint.js","sourceRoot":"","sources":["../../../../src/rules/api/deleteMany/apiDeleteManyRulesEndpoint.ts"],"names":[],"mappings":"AAcA,OAAO,EAGN,yBAAyB,GACzB,MAAM,oBAAoB,CAAC;AAG5B,OAAO,EAEN,4BAA4B,GAC5B,MAAM,mCAAmC,CAAC;AAE3C,MAAM,0BAA0B;IAG/B,YAAoC,YAA0B;QAA1B,iBAAY,GAAZ,YAAY,CAAc;IAAG,CAAC;IAElE,KAAK,CAAC,cAAc,CACnB,IAA2C;QAE3C,MAAM,IAAI,CAAC,YAAY,CAAC,UAAU,CAAC,IAAI,CAAC,CAAC;QAEzC,OAAO;YACN,MAAM,EAAE,yBAAyB,CAAC,OAAO;SACzC,CAAC;IACH,CAAC;IAEM,oBAAoB;QAC1B,OAAO,4BAA4B,CAAC;IACrC,CAAC;CACD;AAED,OAAO,EAAE,0BAA0B,EAAE,CAAC"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"getExpressApiRuleRateLimits.d.ts","sourceRoot":"","sources":["../../../src/rules/api/getExpressApiRuleRateLimits.ts"],"names":[],"mappings":"AAgBA,QAAA,MAAM,2BAA2B;;;;;CAsBhC,CAAC;AAEF,OAAO,EAAE,2BAA2B,EAAE,CAAC"}
|
|
@@ -0,0 +1,21 @@
|
|
|
1
|
+
import { apiRulePaths } from "./apiRulePaths.js";
|
|
2
|
+
const getExpressApiRuleRateLimits = () => {
|
|
3
|
+
const defaultWindowsMs = 60000;
|
|
4
|
+
const defaultLimit = 5;
|
|
5
|
+
return {
|
|
6
|
+
[apiRulePaths.INSERT_MANY]: {
|
|
7
|
+
windowMs: process.env.PROSOPO_USER_ACCESS_POLICY_RULE_INSERT_MANY_WINDOW ||
|
|
8
|
+
defaultWindowsMs,
|
|
9
|
+
limit: process.env.PROSOPO_USER_ACCESS_POLICY_RULE_INSERT_MANY_LIMIT ||
|
|
10
|
+
defaultLimit,
|
|
11
|
+
},
|
|
12
|
+
[apiRulePaths.DELETE_MANY]: {
|
|
13
|
+
windowMs: process.env.PROSOPO_USER_ACCESS_POLICY_RULE_DELETE_MANY_WINDOW ||
|
|
14
|
+
defaultWindowsMs,
|
|
15
|
+
limit: process.env.PROSOPO_USER_ACCESS_POLICY_RULE_DELETE_MANY_LIMIT ||
|
|
16
|
+
defaultLimit,
|
|
17
|
+
},
|
|
18
|
+
};
|
|
19
|
+
};
|
|
20
|
+
export { getExpressApiRuleRateLimits };
|
|
21
|
+
//# sourceMappingURL=getExpressApiRuleRateLimits.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"getExpressApiRuleRateLimits.js","sourceRoot":"","sources":["../../../src/rules/api/getExpressApiRuleRateLimits.ts"],"names":[],"mappings":"AAcA,OAAO,EAAE,YAAY,EAAE,MAAM,mBAAmB,CAAC;AAEjD,MAAM,2BAA2B,GAAG,GAAG,EAAE;IACxC,MAAM,gBAAgB,GAAG,KAAK,CAAC;IAC/B,MAAM,YAAY,GAAG,CAAC,CAAC;IAEvB,OAAO;QACN,CAAC,YAAY,CAAC,WAAW,CAAC,EAAE;YAC3B,QAAQ,EACP,OAAO,CAAC,GAAG,CAAC,kDAAkD;gBAC9D,gBAAgB;YACjB,KAAK,EACJ,OAAO,CAAC,GAAG,CAAC,iDAAiD;gBAC7D,YAAY;SACb;QACD,CAAC,YAAY,CAAC,WAAW,CAAC,EAAE;YAC3B,QAAQ,EACP,OAAO,CAAC,GAAG,CAAC,kDAAkD;gBAC9D,gBAAgB;YACjB,KAAK,EACJ,OAAO,CAAC,GAAG,CAAC,iDAAiD;gBAC7D,YAAY;SACb;KACD,CAAC;AACH,CAAC,CAAC;AAEF,OAAO,EAAE,2BAA2B,EAAE,CAAC"}
|
|
@@ -0,0 +1,199 @@
|
|
|
1
|
+
declare const apiInsertManyRulesArgsSchema: import("zod").ZodObject<{
|
|
2
|
+
isUserBlocked: import("zod").ZodBoolean;
|
|
3
|
+
clientId: import("zod").ZodOptional<import("zod").ZodString>;
|
|
4
|
+
description: import("zod").ZodOptional<import("zod").ZodString>;
|
|
5
|
+
userIps: import("zod").ZodOptional<import("zod").ZodArray<import("zod").ZodObject<{
|
|
6
|
+
v4: import("zod").ZodOptional<import("zod").ZodObject<{
|
|
7
|
+
asNumeric: import("zod").ZodBigInt;
|
|
8
|
+
asString: import("zod").ZodString;
|
|
9
|
+
mask: import("zod").ZodOptional<import("zod").ZodObject<{
|
|
10
|
+
rangeMinAsNumeric: import("zod").ZodBigInt;
|
|
11
|
+
rangeMaxAsNumeric: import("zod").ZodBigInt;
|
|
12
|
+
asNumeric: import("zod").ZodNumber;
|
|
13
|
+
}, "strip", import("zod").ZodTypeAny, {
|
|
14
|
+
rangeMinAsNumeric: bigint;
|
|
15
|
+
rangeMaxAsNumeric: bigint;
|
|
16
|
+
asNumeric: number;
|
|
17
|
+
}, {
|
|
18
|
+
rangeMinAsNumeric: bigint;
|
|
19
|
+
rangeMaxAsNumeric: bigint;
|
|
20
|
+
asNumeric: number;
|
|
21
|
+
}>>;
|
|
22
|
+
}, "strip", import("zod").ZodTypeAny, {
|
|
23
|
+
asNumeric: bigint;
|
|
24
|
+
asString: string;
|
|
25
|
+
mask?: {
|
|
26
|
+
rangeMinAsNumeric: bigint;
|
|
27
|
+
rangeMaxAsNumeric: bigint;
|
|
28
|
+
asNumeric: number;
|
|
29
|
+
} | undefined;
|
|
30
|
+
}, {
|
|
31
|
+
asNumeric: bigint;
|
|
32
|
+
asString: string;
|
|
33
|
+
mask?: {
|
|
34
|
+
rangeMinAsNumeric: bigint;
|
|
35
|
+
rangeMaxAsNumeric: bigint;
|
|
36
|
+
asNumeric: number;
|
|
37
|
+
} | undefined;
|
|
38
|
+
}>>;
|
|
39
|
+
v6: import("zod").ZodOptional<import("zod").ZodObject<{
|
|
40
|
+
asNumericString: import("zod").ZodString;
|
|
41
|
+
asString: import("zod").ZodString;
|
|
42
|
+
mask: import("zod").ZodOptional<import("zod").ZodObject<{
|
|
43
|
+
rangeMinAsNumericString: import("zod").ZodString;
|
|
44
|
+
rangeMaxAsNumericString: import("zod").ZodString;
|
|
45
|
+
asNumeric: import("zod").ZodNumber;
|
|
46
|
+
}, "strip", import("zod").ZodTypeAny, {
|
|
47
|
+
asNumeric: number;
|
|
48
|
+
rangeMinAsNumericString: string;
|
|
49
|
+
rangeMaxAsNumericString: string;
|
|
50
|
+
}, {
|
|
51
|
+
asNumeric: number;
|
|
52
|
+
rangeMinAsNumericString: string;
|
|
53
|
+
rangeMaxAsNumericString: string;
|
|
54
|
+
}>>;
|
|
55
|
+
}, "strip", import("zod").ZodTypeAny, {
|
|
56
|
+
asString: string;
|
|
57
|
+
asNumericString: string;
|
|
58
|
+
mask?: {
|
|
59
|
+
asNumeric: number;
|
|
60
|
+
rangeMinAsNumericString: string;
|
|
61
|
+
rangeMaxAsNumericString: string;
|
|
62
|
+
} | undefined;
|
|
63
|
+
}, {
|
|
64
|
+
asString: string;
|
|
65
|
+
asNumericString: string;
|
|
66
|
+
mask?: {
|
|
67
|
+
asNumeric: number;
|
|
68
|
+
rangeMinAsNumericString: string;
|
|
69
|
+
rangeMaxAsNumericString: string;
|
|
70
|
+
} | undefined;
|
|
71
|
+
}>>;
|
|
72
|
+
}, "strip", import("zod").ZodTypeAny, {
|
|
73
|
+
v4?: {
|
|
74
|
+
asNumeric: bigint;
|
|
75
|
+
asString: string;
|
|
76
|
+
mask?: {
|
|
77
|
+
rangeMinAsNumeric: bigint;
|
|
78
|
+
rangeMaxAsNumeric: bigint;
|
|
79
|
+
asNumeric: number;
|
|
80
|
+
} | undefined;
|
|
81
|
+
} | undefined;
|
|
82
|
+
v6?: {
|
|
83
|
+
asString: string;
|
|
84
|
+
asNumericString: string;
|
|
85
|
+
mask?: {
|
|
86
|
+
asNumeric: number;
|
|
87
|
+
rangeMinAsNumericString: string;
|
|
88
|
+
rangeMaxAsNumericString: string;
|
|
89
|
+
} | undefined;
|
|
90
|
+
} | undefined;
|
|
91
|
+
}, {
|
|
92
|
+
v4?: {
|
|
93
|
+
asNumeric: bigint;
|
|
94
|
+
asString: string;
|
|
95
|
+
mask?: {
|
|
96
|
+
rangeMinAsNumeric: bigint;
|
|
97
|
+
rangeMaxAsNumeric: bigint;
|
|
98
|
+
asNumeric: number;
|
|
99
|
+
} | undefined;
|
|
100
|
+
} | undefined;
|
|
101
|
+
v6?: {
|
|
102
|
+
asString: string;
|
|
103
|
+
asNumericString: string;
|
|
104
|
+
mask?: {
|
|
105
|
+
asNumeric: number;
|
|
106
|
+
rangeMinAsNumericString: string;
|
|
107
|
+
rangeMaxAsNumericString: string;
|
|
108
|
+
} | undefined;
|
|
109
|
+
} | undefined;
|
|
110
|
+
}>, "many">>;
|
|
111
|
+
userIds: import("zod").ZodOptional<import("zod").ZodArray<import("zod").ZodString, "many">>;
|
|
112
|
+
config: import("zod").ZodOptional<import("zod").ZodObject<{
|
|
113
|
+
imageCaptcha: import("zod").ZodOptional<import("zod").ZodObject<{
|
|
114
|
+
solvedCount: import("zod").ZodOptional<import("zod").ZodNumber>;
|
|
115
|
+
unsolvedCount: import("zod").ZodOptional<import("zod").ZodNumber>;
|
|
116
|
+
}, "strip", import("zod").ZodTypeAny, {
|
|
117
|
+
solvedCount?: number | undefined;
|
|
118
|
+
unsolvedCount?: number | undefined;
|
|
119
|
+
}, {
|
|
120
|
+
solvedCount?: number | undefined;
|
|
121
|
+
unsolvedCount?: number | undefined;
|
|
122
|
+
}>>;
|
|
123
|
+
}, "strip", import("zod").ZodTypeAny, {
|
|
124
|
+
imageCaptcha?: {
|
|
125
|
+
solvedCount?: number | undefined;
|
|
126
|
+
unsolvedCount?: number | undefined;
|
|
127
|
+
} | undefined;
|
|
128
|
+
}, {
|
|
129
|
+
imageCaptcha?: {
|
|
130
|
+
solvedCount?: number | undefined;
|
|
131
|
+
unsolvedCount?: number | undefined;
|
|
132
|
+
} | undefined;
|
|
133
|
+
}>>;
|
|
134
|
+
}, "strip", import("zod").ZodTypeAny, {
|
|
135
|
+
isUserBlocked: boolean;
|
|
136
|
+
clientId?: string | undefined;
|
|
137
|
+
description?: string | undefined;
|
|
138
|
+
userIps?: {
|
|
139
|
+
v4?: {
|
|
140
|
+
asNumeric: bigint;
|
|
141
|
+
asString: string;
|
|
142
|
+
mask?: {
|
|
143
|
+
rangeMinAsNumeric: bigint;
|
|
144
|
+
rangeMaxAsNumeric: bigint;
|
|
145
|
+
asNumeric: number;
|
|
146
|
+
} | undefined;
|
|
147
|
+
} | undefined;
|
|
148
|
+
v6?: {
|
|
149
|
+
asString: string;
|
|
150
|
+
asNumericString: string;
|
|
151
|
+
mask?: {
|
|
152
|
+
asNumeric: number;
|
|
153
|
+
rangeMinAsNumericString: string;
|
|
154
|
+
rangeMaxAsNumericString: string;
|
|
155
|
+
} | undefined;
|
|
156
|
+
} | undefined;
|
|
157
|
+
}[] | undefined;
|
|
158
|
+
userIds?: string[] | undefined;
|
|
159
|
+
config?: {
|
|
160
|
+
imageCaptcha?: {
|
|
161
|
+
solvedCount?: number | undefined;
|
|
162
|
+
unsolvedCount?: number | undefined;
|
|
163
|
+
} | undefined;
|
|
164
|
+
} | undefined;
|
|
165
|
+
}, {
|
|
166
|
+
isUserBlocked: boolean;
|
|
167
|
+
clientId?: string | undefined;
|
|
168
|
+
description?: string | undefined;
|
|
169
|
+
userIps?: {
|
|
170
|
+
v4?: {
|
|
171
|
+
asNumeric: bigint;
|
|
172
|
+
asString: string;
|
|
173
|
+
mask?: {
|
|
174
|
+
rangeMinAsNumeric: bigint;
|
|
175
|
+
rangeMaxAsNumeric: bigint;
|
|
176
|
+
asNumeric: number;
|
|
177
|
+
} | undefined;
|
|
178
|
+
} | undefined;
|
|
179
|
+
v6?: {
|
|
180
|
+
asString: string;
|
|
181
|
+
asNumericString: string;
|
|
182
|
+
mask?: {
|
|
183
|
+
asNumeric: number;
|
|
184
|
+
rangeMinAsNumericString: string;
|
|
185
|
+
rangeMaxAsNumericString: string;
|
|
186
|
+
} | undefined;
|
|
187
|
+
} | undefined;
|
|
188
|
+
}[] | undefined;
|
|
189
|
+
userIds?: string[] | undefined;
|
|
190
|
+
config?: {
|
|
191
|
+
imageCaptcha?: {
|
|
192
|
+
solvedCount?: number | undefined;
|
|
193
|
+
unsolvedCount?: number | undefined;
|
|
194
|
+
} | undefined;
|
|
195
|
+
} | undefined;
|
|
196
|
+
}>;
|
|
197
|
+
type ApiInsertManyRulesArgsSchema = typeof apiInsertManyRulesArgsSchema;
|
|
198
|
+
export { apiInsertManyRulesArgsSchema, type ApiInsertManyRulesArgsSchema };
|
|
199
|
+
//# sourceMappingURL=apiInsertManyRulesArgsSchema.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"apiInsertManyRulesArgsSchema.d.ts","sourceRoot":"","sources":["../../../../src/rules/api/insertMany/apiInsertManyRulesArgsSchema.ts"],"names":[],"mappings":"AAkBA,QAAA,MAAM,4BAA4B;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;EAOhC,CAAC;AAEH,KAAK,4BAA4B,GAAG,OAAO,4BAA4B,CAAC;AAExE,OAAO,EAAE,4BAA4B,EAAE,KAAK,4BAA4B,EAAE,CAAC"}
|
|
@@ -0,0 +1,13 @@
|
|
|
1
|
+
import { boolean, object, string } from "zod";
|
|
2
|
+
import { ruleConfigSchema } from "../../rule/config/ruleConfigSchema.js";
|
|
3
|
+
import { ruleIpSchema } from "../../rule/ip/ruleIpSchema.js";
|
|
4
|
+
const apiInsertManyRulesArgsSchema = object({
|
|
5
|
+
isUserBlocked: boolean(),
|
|
6
|
+
clientId: string().optional(),
|
|
7
|
+
description: string().optional(),
|
|
8
|
+
userIps: ruleIpSchema.array().optional(),
|
|
9
|
+
userIds: string().array().optional(),
|
|
10
|
+
config: ruleConfigSchema.optional(),
|
|
11
|
+
});
|
|
12
|
+
export { apiInsertManyRulesArgsSchema };
|
|
13
|
+
//# sourceMappingURL=apiInsertManyRulesArgsSchema.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"apiInsertManyRulesArgsSchema.js","sourceRoot":"","sources":["../../../../src/rules/api/insertMany/apiInsertManyRulesArgsSchema.ts"],"names":[],"mappings":"AAcA,OAAO,EAAE,OAAO,EAAE,MAAM,EAAE,MAAM,EAAE,MAAM,KAAK,CAAC;AAC9C,OAAO,EAAE,gBAAgB,EAAE,MAAM,uCAAuC,CAAC;AACzE,OAAO,EAAE,YAAY,EAAE,MAAM,+BAA+B,CAAC;AAE7D,MAAM,4BAA4B,GAAG,MAAM,CAAC;IAC3C,aAAa,EAAE,OAAO,EAAE;IACxB,QAAQ,EAAE,MAAM,EAAE,CAAC,QAAQ,EAAE;IAC7B,WAAW,EAAE,MAAM,EAAE,CAAC,QAAQ,EAAE;IAChC,OAAO,EAAE,YAAY,CAAC,KAAK,EAAE,CAAC,QAAQ,EAAE;IACxC,OAAO,EAAE,MAAM,EAAE,CAAC,KAAK,EAAE,CAAC,QAAQ,EAAE;IACpC,MAAM,EAAE,gBAAgB,CAAC,QAAQ,EAAE;CACnC,CAAC,CAAC;AAIH,OAAO,EAAE,4BAA4B,EAAqC,CAAC"}
|