@nest-omni/core 4.1.3-2 → 4.1.3-4
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/audit/audit.module.d.ts +10 -0
- package/audit/audit.module.js +15 -0
- package/audit/controllers/audit.controller.d.ts +24 -0
- package/audit/controllers/audit.controller.js +24 -0
- package/audit/decorators/audit-controller.decorator.d.ts +8 -0
- package/audit/decorators/audit-controller.decorator.js +9 -0
- package/audit/decorators/audit-operation.decorator.d.ts +45 -0
- package/audit/decorators/audit-operation.decorator.js +49 -0
- package/audit/decorators/entity-audit.decorator.d.ts +8 -0
- package/audit/decorators/entity-audit.decorator.js +9 -0
- package/audit/dto/audit-log-query.dto.d.ts +3 -0
- package/audit/dto/audit-log-query.dto.js +3 -0
- package/audit/dto/begin-transaction.dto.d.ts +3 -0
- package/audit/dto/begin-transaction.dto.js +3 -0
- package/audit/dto/compare-entities.dto.d.ts +3 -0
- package/audit/dto/compare-entities.dto.js +3 -0
- package/audit/dto/pre-check-restore.dto.d.ts +3 -0
- package/audit/dto/pre-check-restore.dto.js +3 -0
- package/audit/dto/restore-entity.dto.d.ts +3 -0
- package/audit/dto/restore-entity.dto.js +3 -0
- package/audit/entities/entity-audit-log.entity.d.ts +3 -0
- package/audit/entities/entity-audit-log.entity.js +3 -0
- package/audit/entities/entity-transaction.entity.d.ts +3 -0
- package/audit/entities/entity-transaction.entity.js +3 -0
- package/audit/entities/manual-operation-log.entity.d.ts +4 -0
- package/audit/entities/manual-operation-log.entity.js +4 -0
- package/audit/entities/operation-template.entity.d.ts +4 -0
- package/audit/entities/operation-template.entity.js +4 -0
- package/audit/enums/audit.enums.d.ts +17 -2
- package/audit/enums/audit.enums.js +15 -0
- package/audit/index.js +10 -0
- package/audit/interceptors/audit.interceptor.d.ts +15 -0
- package/audit/interceptors/audit.interceptor.js +23 -1
- package/audit/interfaces/audit.interfaces.d.ts +42 -0
- package/audit/services/audit-context.service.d.ts +15 -0
- package/audit/services/audit-context.service.js +15 -0
- package/audit/services/audit-strategy.service.d.ts +6 -0
- package/audit/services/audit-strategy.service.js +13 -0
- package/audit/services/entity-audit.service.d.ts +57 -0
- package/audit/services/entity-audit.service.js +91 -0
- package/audit/services/manual-audit-log.service.d.ts +124 -0
- package/audit/services/manual-audit-log.service.js +138 -0
- package/audit/services/multi-database.service.d.ts +12 -0
- package/audit/services/multi-database.service.js +12 -0
- package/audit/services/operation-description.service.d.ts +59 -0
- package/audit/services/operation-description.service.js +76 -2
- package/audit/services/transaction-audit.service.d.ts +30 -0
- package/audit/services/transaction-audit.service.js +47 -0
- package/audit/subscribers/entity-audit.subscriber.d.ts +15 -0
- package/audit/subscribers/entity-audit.subscriber.js +29 -1
- package/cache/cache-metrics.service.d.ts +67 -0
- package/cache/cache-metrics.service.js +68 -4
- package/cache/cache-serialization.service.d.ts +31 -0
- package/cache/cache-serialization.service.js +25 -0
- package/cache/cache.constants.d.ts +9 -0
- package/cache/cache.constants.js +9 -0
- package/cache/cache.health.d.ts +26 -0
- package/cache/cache.health.js +30 -0
- package/cache/cache.module.d.ts +86 -0
- package/cache/cache.module.js +71 -0
- package/cache/cache.service.d.ts +140 -0
- package/cache/cache.service.js +157 -0
- package/cache/cache.warmup.service.d.ts +39 -0
- package/cache/cache.warmup.service.js +32 -0
- package/cache/decorators/cache-evict.decorator.d.ts +47 -0
- package/cache/decorators/cache-evict.decorator.js +56 -0
- package/cache/decorators/cache-put.decorator.d.ts +34 -0
- package/cache/decorators/cache-put.decorator.js +39 -0
- package/cache/decorators/cacheable.decorator.d.ts +40 -0
- package/cache/decorators/cacheable.decorator.js +55 -0
- package/cache/dependencies/callback.dependency.d.ts +33 -0
- package/cache/dependencies/callback.dependency.js +39 -1
- package/cache/dependencies/chain.dependency.d.ts +28 -0
- package/cache/dependencies/chain.dependency.js +34 -0
- package/cache/dependencies/db.dependency.d.ts +45 -0
- package/cache/dependencies/db.dependency.js +48 -1
- package/cache/dependencies/file.dependency.d.ts +32 -0
- package/cache/dependencies/file.dependency.js +34 -0
- package/cache/dependencies/tag.dependency.d.ts +36 -0
- package/cache/dependencies/tag.dependency.js +36 -0
- package/cache/dependencies/time.dependency.d.ts +43 -0
- package/cache/dependencies/time.dependency.js +43 -0
- package/cache/examples/basic-usage.d.ts +15 -0
- package/cache/examples/basic-usage.js +62 -8
- package/cache/index.js +9 -0
- package/cache/interfaces/cache-dependency.interface.d.ts +53 -0
- package/cache/interfaces/cache-options.interface.d.ts +81 -0
- package/cache/interfaces/cache-options.interface.js +6 -0
- package/cache/interfaces/cache-provider.interface.d.ts +78 -0
- package/cache/providers/base-cache.provider.d.ts +14 -0
- package/cache/providers/base-cache.provider.js +16 -0
- package/cache/providers/cls-cache.provider.d.ts +20 -0
- package/cache/providers/cls-cache.provider.js +28 -0
- package/cache/providers/memory-cache.provider.d.ts +23 -0
- package/cache/providers/memory-cache.provider.js +26 -0
- package/cache/providers/redis-cache.provider.d.ts +26 -0
- package/cache/providers/redis-cache.provider.js +29 -0
- package/cache/utils/dependency-manager.util.d.ts +52 -0
- package/cache/utils/dependency-manager.util.js +59 -0
- package/cache/utils/key-generator.util.d.ts +42 -0
- package/cache/utils/key-generator.util.js +53 -1
- package/common/abstract.entity.d.ts +14 -0
- package/common/abstract.entity.js +14 -0
- package/common/boilerplate.polyfill.d.ts +142 -0
- package/common/boilerplate.polyfill.js +17 -0
- package/common/dto/dto-container.d.ts +16 -0
- package/common/dto/dto-container.js +20 -0
- package/common/dto/dto-decorators.d.ts +18 -0
- package/common/dto/dto-decorators.js +14 -0
- package/common/dto/dto-extensions.d.ts +11 -0
- package/common/dto/dto-extensions.js +9 -0
- package/common/dto/dto-service-accessor.d.ts +17 -0
- package/common/dto/dto-service-accessor.js +18 -0
- package/common/dto/dto-transformer.d.ts +12 -0
- package/common/dto/dto-transformer.js +9 -0
- package/common/dto/index.js +2 -0
- package/common/examples/paginate-and-map.example.d.ts +6 -0
- package/common/examples/paginate-and-map.example.js +26 -0
- package/common/utils.d.ts +15 -0
- package/common/utils.js +15 -0
- package/constants/language-code.js +1 -0
- package/decorators/field.decorators.js +8 -1
- package/decorators/property.decorators.js +1 -0
- package/decorators/public-route.decorator.js +1 -0
- package/decorators/transform.decorators.d.ts +27 -0
- package/decorators/transform.decorators.js +29 -0
- package/decorators/translate.decorator.js +1 -0
- package/decorators/user.decorator.js +1 -0
- package/decorators/validator.decorators.d.ts +8 -18
- package/decorators/validator.decorators.js +22 -190
- package/filters/constraint-errors.js +1 -0
- package/helpers/common.helper.d.ts +13 -0
- package/helpers/common.helper.js +13 -0
- package/http-client/config/http-client.config.d.ts +15 -0
- package/http-client/config/http-client.config.js +25 -9
- package/http-client/decorators/http-client.decorators.d.ts +63 -0
- package/http-client/decorators/http-client.decorators.js +71 -3
- package/http-client/entities/http-log.entity.d.ts +229 -0
- package/http-client/entities/http-log.entity.js +6 -1
- package/http-client/errors/http-client.errors.d.ts +57 -0
- package/http-client/errors/http-client.errors.js +58 -0
- package/http-client/examples/advanced-usage.example.d.ts +41 -0
- package/http-client/examples/advanced-usage.example.js +68 -24
- package/http-client/examples/auth-with-waiting-lock.example.d.ts +31 -0
- package/http-client/examples/auth-with-waiting-lock.example.js +52 -5
- package/http-client/examples/basic-usage.example.d.ts +60 -0
- package/http-client/examples/basic-usage.example.js +60 -0
- package/http-client/examples/multi-api-configuration.example.d.ts +60 -0
- package/http-client/examples/multi-api-configuration.example.js +76 -5
- package/http-client/http-client.module.d.ts +13 -0
- package/http-client/http-client.module.js +19 -0
- package/http-client/index.js +8 -0
- package/http-client/interfaces/api-client-config.interface.d.ts +125 -0
- package/http-client/interfaces/api-client-config.interface.js +3 -0
- package/http-client/interfaces/http-client-config.interface.d.ts +60 -0
- package/http-client/services/api-client-registry.service.d.ts +57 -0
- package/http-client/services/api-client-registry.service.js +84 -1
- package/http-client/services/cache.service.d.ts +52 -0
- package/http-client/services/cache.service.js +72 -3
- package/http-client/services/circuit-breaker.service.d.ts +46 -0
- package/http-client/services/circuit-breaker.service.js +52 -0
- package/http-client/services/http-client.service.d.ts +67 -0
- package/http-client/services/http-client.service.js +105 -4
- package/http-client/services/http-log-query.service.d.ts +83 -0
- package/http-client/services/http-log-query.service.js +122 -1
- package/http-client/services/http-replay.service.d.ts +101 -0
- package/http-client/services/http-replay.service.js +86 -0
- package/http-client/services/log-cleanup.service.d.ts +63 -0
- package/http-client/services/log-cleanup.service.js +54 -2
- package/http-client/services/logging.service.d.ts +40 -0
- package/http-client/services/logging.service.js +53 -0
- package/http-client/utils/call-stack-extractor.util.d.ts +37 -0
- package/http-client/utils/call-stack-extractor.util.js +48 -0
- package/http-client/utils/context-extractor.util.d.ts +49 -0
- package/http-client/utils/context-extractor.util.js +52 -0
- package/http-client/utils/curl-generator.util.d.ts +21 -0
- package/http-client/utils/curl-generator.util.js +44 -3
- package/http-client/utils/request-id.util.d.ts +18 -0
- package/http-client/utils/request-id.util.js +20 -0
- package/http-client/utils/retry-recorder.util.d.ts +42 -0
- package/http-client/utils/retry-recorder.util.js +44 -0
- package/index.js +8 -0
- package/interceptors/translation-interceptor.service.js +5 -0
- package/package.json +1 -1
- package/providers/context.provider.js +2 -0
- package/providers/generator.provider.d.ts +4 -0
- package/providers/generator.provider.js +4 -0
- package/redis-lock/examples/lock-strategy.examples.d.ts +89 -0
- package/redis-lock/examples/lock-strategy.examples.js +130 -15
- package/redis-lock/index.js +3 -0
- package/redis-lock/redis-lock.decorator.d.ts +101 -0
- package/redis-lock/redis-lock.decorator.js +120 -0
- package/redis-lock/redis-lock.module.d.ts +60 -0
- package/redis-lock/redis-lock.module.js +46 -0
- package/redis-lock/redis-lock.service.d.ts +251 -0
- package/redis-lock/redis-lock.service.js +219 -3
- package/setup/bootstrap.setup.js +20 -0
- package/setup/mode.setup.d.ts +44 -0
- package/setup/mode.setup.js +44 -0
- package/setup/schedule.decorator.d.ts +226 -0
- package/setup/schedule.decorator.js +214 -1
- package/setup/worker.decorator.d.ts +86 -0
- package/setup/worker.decorator.js +88 -0
- package/shared/serviceRegistryModule.js +5 -1
- package/shared/services/api-config.service.d.ts +3 -0
- package/shared/services/api-config.service.js +20 -9
- package/validator-json/decorators.d.ts +17 -0
- package/validator-json/decorators.js +17 -2
- package/validator-json/default.d.ts +6 -0
- package/validator-json/default.js +30 -2
- package/validator-json/defaultConverters.js +1 -0
- package/validator-json/options.d.ts +23 -0
- package/validators/common-validators.d.ts +143 -0
- package/validators/common-validators.js +249 -0
- package/validators/custom-validate.examples.d.ts +23 -0
- package/validators/custom-validate.examples.js +78 -6
- package/validators/custom-validate.validator.d.ts +107 -0
- package/validators/custom-validate.validator.js +84 -0
- package/validators/index.d.ts +1 -0
- package/validators/index.js +1 -0
- package/validators/is-exists.validator.d.ts +11 -0
- package/validators/is-exists.validator.js +22 -0
- package/validators/is-unique.validator.d.ts +11 -0
- package/validators/is-unique.validator.js +31 -3
- package/validators/skip-empty.validator.d.ts +5 -0
- package/validators/skip-empty.validator.js +5 -0
- package/vault/interfaces/vault-options.interface.d.ts +9 -0
- package/vault/vault-config.loader.d.ts +30 -0
- package/vault/vault-config.loader.js +48 -1
- package/vault/vault-config.service.d.ts +53 -0
- package/vault/vault-config.service.js +57 -0
- package/vault/vault.module.d.ts +4 -0
- package/vault/vault.module.js +4 -0
- package/decorators/examples/validation-decorators.example.d.ts +0 -69
- package/decorators/examples/validation-decorators.example.js +0 -331
|
@@ -10,21 +10,37 @@ var __awaiter = (this && this.__awaiter) || function (thisArg, _arguments, P, ge
|
|
|
10
10
|
};
|
|
11
11
|
Object.defineProperty(exports, "__esModule", { value: true });
|
|
12
12
|
exports.BaseCacheProvider = void 0;
|
|
13
|
+
/**
|
|
14
|
+
* Base cache provider with common utility methods
|
|
15
|
+
*/
|
|
13
16
|
class BaseCacheProvider {
|
|
17
|
+
/**
|
|
18
|
+
* Get multiple values at once
|
|
19
|
+
* Default implementation - can be overridden for better performance
|
|
20
|
+
*/
|
|
14
21
|
mget(keys) {
|
|
15
22
|
return __awaiter(this, void 0, void 0, function* () {
|
|
16
23
|
const promises = keys.map((key) => this.get(key));
|
|
17
24
|
return Promise.all(promises);
|
|
18
25
|
});
|
|
19
26
|
}
|
|
27
|
+
/**
|
|
28
|
+
* Set multiple values at once
|
|
29
|
+
* Default implementation - can be overridden for better performance
|
|
30
|
+
*/
|
|
20
31
|
mset(items, ttl) {
|
|
21
32
|
return __awaiter(this, void 0, void 0, function* () {
|
|
22
33
|
const promises = items.map((item) => this.set(item.key, item.value, ttl));
|
|
23
34
|
yield Promise.all(promises);
|
|
24
35
|
});
|
|
25
36
|
}
|
|
37
|
+
/**
|
|
38
|
+
* Convert wildcard pattern to RegExp
|
|
39
|
+
*/
|
|
26
40
|
patternToRegex(pattern) {
|
|
41
|
+
// Escape special regex characters except *
|
|
27
42
|
const escaped = pattern.replace(/[.+?^${}()|[\]\\]/g, '\\$&');
|
|
43
|
+
// Convert * to .*
|
|
28
44
|
const regexPattern = escaped.replace(/\*/g, '.*');
|
|
29
45
|
return new RegExp(`^${regexPattern}$`);
|
|
30
46
|
}
|
|
@@ -1,4 +1,12 @@
|
|
|
1
1
|
import { BaseCacheProvider } from './base-cache.provider';
|
|
2
|
+
/**
|
|
3
|
+
* CLS (Continuation Local Storage) cache provider
|
|
4
|
+
*
|
|
5
|
+
* This is the L1 cache layer - request-scoped caching using nestjs-cls.
|
|
6
|
+
* Data stored here is only available within the same request context.
|
|
7
|
+
*
|
|
8
|
+
* Fastest cache layer but limited to single request lifecycle.
|
|
9
|
+
*/
|
|
2
10
|
export declare class ClsCacheProvider extends BaseCacheProvider {
|
|
3
11
|
private static readonly CACHE_PREFIX;
|
|
4
12
|
private static readonly KEYS_SET;
|
|
@@ -9,8 +17,20 @@ export declare class ClsCacheProvider extends BaseCacheProvider {
|
|
|
9
17
|
deletePattern(pattern: string): Promise<number>;
|
|
10
18
|
clear(): Promise<void>;
|
|
11
19
|
has(key: string): Promise<boolean>;
|
|
20
|
+
/**
|
|
21
|
+
* Get full key with prefix
|
|
22
|
+
*/
|
|
12
23
|
private getFullKey;
|
|
24
|
+
/**
|
|
25
|
+
* Add key to tracked keys set
|
|
26
|
+
*/
|
|
13
27
|
private addKeyToSet;
|
|
28
|
+
/**
|
|
29
|
+
* Remove key from tracked keys set
|
|
30
|
+
*/
|
|
14
31
|
private removeKeyFromSet;
|
|
32
|
+
/**
|
|
33
|
+
* Get all tracked keys
|
|
34
|
+
*/
|
|
15
35
|
private getAllKeys;
|
|
16
36
|
}
|
|
@@ -12,6 +12,14 @@ Object.defineProperty(exports, "__esModule", { value: true });
|
|
|
12
12
|
exports.ClsCacheProvider = void 0;
|
|
13
13
|
const nestjs_cls_1 = require("nestjs-cls");
|
|
14
14
|
const base_cache_provider_1 = require("./base-cache.provider");
|
|
15
|
+
/**
|
|
16
|
+
* CLS (Continuation Local Storage) cache provider
|
|
17
|
+
*
|
|
18
|
+
* This is the L1 cache layer - request-scoped caching using nestjs-cls.
|
|
19
|
+
* Data stored here is only available within the same request context.
|
|
20
|
+
*
|
|
21
|
+
* Fastest cache layer but limited to single request lifecycle.
|
|
22
|
+
*/
|
|
15
23
|
class ClsCacheProvider extends base_cache_provider_1.BaseCacheProvider {
|
|
16
24
|
getName() {
|
|
17
25
|
return 'CLS';
|
|
@@ -25,6 +33,7 @@ class ClsCacheProvider extends base_cache_provider_1.BaseCacheProvider {
|
|
|
25
33
|
if (!cached) {
|
|
26
34
|
return null;
|
|
27
35
|
}
|
|
36
|
+
// Check TTL
|
|
28
37
|
if (cached.expiresAt && Date.now() > cached.expiresAt) {
|
|
29
38
|
yield this.delete(key);
|
|
30
39
|
return null;
|
|
@@ -32,6 +41,7 @@ class ClsCacheProvider extends base_cache_provider_1.BaseCacheProvider {
|
|
|
32
41
|
return cached.value;
|
|
33
42
|
}
|
|
34
43
|
catch (_a) {
|
|
44
|
+
// CLS might not be available (e.g., outside request context)
|
|
35
45
|
return null;
|
|
36
46
|
}
|
|
37
47
|
});
|
|
@@ -46,9 +56,11 @@ class ClsCacheProvider extends base_cache_provider_1.BaseCacheProvider {
|
|
|
46
56
|
cached.expiresAt = Date.now() + ttl;
|
|
47
57
|
}
|
|
48
58
|
store.set(fullKey, cached);
|
|
59
|
+
// Track this key for cleanup
|
|
49
60
|
this.addKeyToSet(key);
|
|
50
61
|
}
|
|
51
62
|
catch (_a) {
|
|
63
|
+
// CLS might not be available, silently fail
|
|
52
64
|
}
|
|
53
65
|
});
|
|
54
66
|
}
|
|
@@ -64,6 +76,7 @@ class ClsCacheProvider extends base_cache_provider_1.BaseCacheProvider {
|
|
|
64
76
|
}
|
|
65
77
|
}
|
|
66
78
|
catch (_a) {
|
|
79
|
+
// CLS might not be available, silently fail
|
|
67
80
|
}
|
|
68
81
|
});
|
|
69
82
|
}
|
|
@@ -90,6 +103,7 @@ class ClsCacheProvider extends base_cache_provider_1.BaseCacheProvider {
|
|
|
90
103
|
yield this.delete(allKeys);
|
|
91
104
|
}
|
|
92
105
|
catch (_a) {
|
|
106
|
+
// CLS might not be available, silently fail
|
|
93
107
|
}
|
|
94
108
|
});
|
|
95
109
|
}
|
|
@@ -99,9 +113,15 @@ class ClsCacheProvider extends base_cache_provider_1.BaseCacheProvider {
|
|
|
99
113
|
return value !== null;
|
|
100
114
|
});
|
|
101
115
|
}
|
|
116
|
+
/**
|
|
117
|
+
* Get full key with prefix
|
|
118
|
+
*/
|
|
102
119
|
getFullKey(key) {
|
|
103
120
|
return `${ClsCacheProvider.CACHE_PREFIX}${key}`;
|
|
104
121
|
}
|
|
122
|
+
/**
|
|
123
|
+
* Add key to tracked keys set
|
|
124
|
+
*/
|
|
105
125
|
addKeyToSet(key) {
|
|
106
126
|
try {
|
|
107
127
|
const store = nestjs_cls_1.ClsServiceManager.getClsService();
|
|
@@ -110,8 +130,12 @@ class ClsCacheProvider extends base_cache_provider_1.BaseCacheProvider {
|
|
|
110
130
|
store.set(ClsCacheProvider.KEYS_SET, keys);
|
|
111
131
|
}
|
|
112
132
|
catch (_a) {
|
|
133
|
+
// Ignore
|
|
113
134
|
}
|
|
114
135
|
}
|
|
136
|
+
/**
|
|
137
|
+
* Remove key from tracked keys set
|
|
138
|
+
*/
|
|
115
139
|
removeKeyFromSet(key) {
|
|
116
140
|
try {
|
|
117
141
|
const store = nestjs_cls_1.ClsServiceManager.getClsService();
|
|
@@ -122,8 +146,12 @@ class ClsCacheProvider extends base_cache_provider_1.BaseCacheProvider {
|
|
|
122
146
|
}
|
|
123
147
|
}
|
|
124
148
|
catch (_a) {
|
|
149
|
+
// Ignore
|
|
125
150
|
}
|
|
126
151
|
}
|
|
152
|
+
/**
|
|
153
|
+
* Get all tracked keys
|
|
154
|
+
*/
|
|
127
155
|
getAllKeys() {
|
|
128
156
|
try {
|
|
129
157
|
const store = nestjs_cls_1.ClsServiceManager.getClsService();
|
|
@@ -1,4 +1,12 @@
|
|
|
1
1
|
import { BaseCacheProvider } from './base-cache.provider';
|
|
2
|
+
/**
|
|
3
|
+
* Memory cache provider using native Map with TTL support
|
|
4
|
+
*
|
|
5
|
+
* This is the L2 cache layer - process-level caching.
|
|
6
|
+
* Data is stored in memory and shared across all requests in the same process.
|
|
7
|
+
*
|
|
8
|
+
* Faster than Redis but not shared across multiple processes/servers.
|
|
9
|
+
*/
|
|
2
10
|
export declare class MemoryCacheProvider extends BaseCacheProvider {
|
|
3
11
|
private cache;
|
|
4
12
|
private keys;
|
|
@@ -15,10 +23,25 @@ export declare class MemoryCacheProvider extends BaseCacheProvider {
|
|
|
15
23
|
deletePattern(pattern: string): Promise<number>;
|
|
16
24
|
clear(): Promise<void>;
|
|
17
25
|
has(key: string): Promise<boolean>;
|
|
26
|
+
/**
|
|
27
|
+
* Get all keys (for debugging/testing)
|
|
28
|
+
*/
|
|
18
29
|
getAllKeys(): string[];
|
|
30
|
+
/**
|
|
31
|
+
* Get cache size
|
|
32
|
+
*/
|
|
19
33
|
getSize(): number;
|
|
34
|
+
/**
|
|
35
|
+
* Clean up expired items (optional maintenance method)
|
|
36
|
+
*/
|
|
20
37
|
cleanup(): number;
|
|
38
|
+
/**
|
|
39
|
+
* Optimized mget with batch cleanup
|
|
40
|
+
*/
|
|
21
41
|
mget<T>(keys: string[]): Promise<(T | null)[]>;
|
|
42
|
+
/**
|
|
43
|
+
* Optimized mset
|
|
44
|
+
*/
|
|
22
45
|
mset(items: Array<{
|
|
23
46
|
key: string;
|
|
24
47
|
value: any;
|
|
@@ -11,6 +11,14 @@ var __awaiter = (this && this.__awaiter) || function (thisArg, _arguments, P, ge
|
|
|
11
11
|
Object.defineProperty(exports, "__esModule", { value: true });
|
|
12
12
|
exports.MemoryCacheProvider = void 0;
|
|
13
13
|
const base_cache_provider_1 = require("./base-cache.provider");
|
|
14
|
+
/**
|
|
15
|
+
* Memory cache provider using native Map with TTL support
|
|
16
|
+
*
|
|
17
|
+
* This is the L2 cache layer - process-level caching.
|
|
18
|
+
* Data is stored in memory and shared across all requests in the same process.
|
|
19
|
+
*
|
|
20
|
+
* Faster than Redis but not shared across multiple processes/servers.
|
|
21
|
+
*/
|
|
14
22
|
class MemoryCacheProvider extends base_cache_provider_1.BaseCacheProvider {
|
|
15
23
|
constructor(options) {
|
|
16
24
|
super();
|
|
@@ -29,6 +37,7 @@ class MemoryCacheProvider extends base_cache_provider_1.BaseCacheProvider {
|
|
|
29
37
|
if (!item) {
|
|
30
38
|
return null;
|
|
31
39
|
}
|
|
40
|
+
// Check if item has expired
|
|
32
41
|
if (item.expiresAt && Date.now() > item.expiresAt) {
|
|
33
42
|
this.cache.delete(key);
|
|
34
43
|
this.keys.delete(key);
|
|
@@ -110,6 +119,7 @@ class MemoryCacheProvider extends base_cache_provider_1.BaseCacheProvider {
|
|
|
110
119
|
if (!item) {
|
|
111
120
|
return false;
|
|
112
121
|
}
|
|
122
|
+
// Check if item has expired
|
|
113
123
|
if (item.expiresAt && Date.now() > item.expiresAt) {
|
|
114
124
|
this.cache.delete(key);
|
|
115
125
|
this.keys.delete(key);
|
|
@@ -122,12 +132,21 @@ class MemoryCacheProvider extends base_cache_provider_1.BaseCacheProvider {
|
|
|
122
132
|
}
|
|
123
133
|
});
|
|
124
134
|
}
|
|
135
|
+
/**
|
|
136
|
+
* Get all keys (for debugging/testing)
|
|
137
|
+
*/
|
|
125
138
|
getAllKeys() {
|
|
126
139
|
return Array.from(this.keys);
|
|
127
140
|
}
|
|
141
|
+
/**
|
|
142
|
+
* Get cache size
|
|
143
|
+
*/
|
|
128
144
|
getSize() {
|
|
129
145
|
return this.keys.size;
|
|
130
146
|
}
|
|
147
|
+
/**
|
|
148
|
+
* Clean up expired items (optional maintenance method)
|
|
149
|
+
*/
|
|
131
150
|
cleanup() {
|
|
132
151
|
let cleaned = 0;
|
|
133
152
|
const now = Date.now();
|
|
@@ -140,6 +159,9 @@ class MemoryCacheProvider extends base_cache_provider_1.BaseCacheProvider {
|
|
|
140
159
|
}
|
|
141
160
|
return cleaned;
|
|
142
161
|
}
|
|
162
|
+
/**
|
|
163
|
+
* Optimized mget with batch cleanup
|
|
164
|
+
*/
|
|
143
165
|
mget(keys) {
|
|
144
166
|
return __awaiter(this, void 0, void 0, function* () {
|
|
145
167
|
const results = [];
|
|
@@ -150,6 +172,7 @@ class MemoryCacheProvider extends base_cache_provider_1.BaseCacheProvider {
|
|
|
150
172
|
results.push(null);
|
|
151
173
|
continue;
|
|
152
174
|
}
|
|
175
|
+
// Check if item has expired
|
|
153
176
|
if (item.expiresAt && now > item.expiresAt) {
|
|
154
177
|
this.cache.delete(key);
|
|
155
178
|
this.keys.delete(key);
|
|
@@ -161,6 +184,9 @@ class MemoryCacheProvider extends base_cache_provider_1.BaseCacheProvider {
|
|
|
161
184
|
return results;
|
|
162
185
|
});
|
|
163
186
|
}
|
|
187
|
+
/**
|
|
188
|
+
* Optimized mset
|
|
189
|
+
*/
|
|
164
190
|
mset(items, ttl) {
|
|
165
191
|
return __awaiter(this, void 0, void 0, function* () {
|
|
166
192
|
const promises = items.map((item) => this.set(item.key, item.value, ttl));
|
|
@@ -1,6 +1,17 @@
|
|
|
1
1
|
import type Redis from 'ioredis';
|
|
2
2
|
import { BaseCacheProvider } from './base-cache.provider';
|
|
3
|
+
/**
|
|
4
|
+
* Token for injecting Redis client
|
|
5
|
+
*/
|
|
3
6
|
export declare const REDIS_CLIENT: unique symbol;
|
|
7
|
+
/**
|
|
8
|
+
* Redis cache provider using ioredis
|
|
9
|
+
*
|
|
10
|
+
* This is the L3 cache layer - distributed caching using Redis.
|
|
11
|
+
* Data is persisted in Redis and shared across all processes/servers.
|
|
12
|
+
*
|
|
13
|
+
* Slowest but most persistent and widely shared cache layer.
|
|
14
|
+
*/
|
|
4
15
|
export declare class RedisCacheProvider extends BaseCacheProvider {
|
|
5
16
|
private readonly redis?;
|
|
6
17
|
private readonly keyPrefix;
|
|
@@ -12,12 +23,27 @@ export declare class RedisCacheProvider extends BaseCacheProvider {
|
|
|
12
23
|
deletePattern(pattern: string): Promise<number>;
|
|
13
24
|
clear(): Promise<void>;
|
|
14
25
|
has(key: string): Promise<boolean>;
|
|
26
|
+
/**
|
|
27
|
+
* Batch get using Redis MGET
|
|
28
|
+
*/
|
|
15
29
|
mget<T>(keys: string[]): Promise<(T | null)[]>;
|
|
30
|
+
/**
|
|
31
|
+
* Batch set using Redis pipeline
|
|
32
|
+
*/
|
|
16
33
|
mset(items: Array<{
|
|
17
34
|
key: string;
|
|
18
35
|
value: any;
|
|
19
36
|
}>, ttl?: number): Promise<void>;
|
|
37
|
+
/**
|
|
38
|
+
* Check if Redis client is available
|
|
39
|
+
*/
|
|
20
40
|
isAvailable(): boolean;
|
|
41
|
+
/**
|
|
42
|
+
* Get Redis client (for advanced usage)
|
|
43
|
+
*/
|
|
21
44
|
getClient(): Redis | undefined;
|
|
45
|
+
/**
|
|
46
|
+
* Get full key with prefix
|
|
47
|
+
*/
|
|
22
48
|
private getFullKey;
|
|
23
49
|
}
|
|
@@ -24,7 +24,18 @@ Object.defineProperty(exports, "__esModule", { value: true });
|
|
|
24
24
|
exports.RedisCacheProvider = exports.REDIS_CLIENT = void 0;
|
|
25
25
|
const common_1 = require("@nestjs/common");
|
|
26
26
|
const base_cache_provider_1 = require("./base-cache.provider");
|
|
27
|
+
/**
|
|
28
|
+
* Token for injecting Redis client
|
|
29
|
+
*/
|
|
27
30
|
exports.REDIS_CLIENT = Symbol('REDIS_CLIENT');
|
|
31
|
+
/**
|
|
32
|
+
* Redis cache provider using ioredis
|
|
33
|
+
*
|
|
34
|
+
* This is the L3 cache layer - distributed caching using Redis.
|
|
35
|
+
* Data is persisted in Redis and shared across all processes/servers.
|
|
36
|
+
*
|
|
37
|
+
* Slowest but most persistent and widely shared cache layer.
|
|
38
|
+
*/
|
|
28
39
|
let RedisCacheProvider = class RedisCacheProvider extends base_cache_provider_1.BaseCacheProvider {
|
|
29
40
|
constructor(redis) {
|
|
30
41
|
super();
|
|
@@ -65,6 +76,7 @@ let RedisCacheProvider = class RedisCacheProvider extends base_cache_provider_1.
|
|
|
65
76
|
const fullKey = this.getFullKey(key);
|
|
66
77
|
const serialized = JSON.stringify(value);
|
|
67
78
|
if (ttl && ttl > 0) {
|
|
79
|
+
// TTL in milliseconds, Redis expects seconds
|
|
68
80
|
yield this.redis.setex(fullKey, Math.ceil(ttl / 1000), serialized);
|
|
69
81
|
}
|
|
70
82
|
else {
|
|
@@ -102,6 +114,7 @@ let RedisCacheProvider = class RedisCacheProvider extends base_cache_provider_1.
|
|
|
102
114
|
const fullPattern = this.getFullKey(pattern);
|
|
103
115
|
let cursor = '0';
|
|
104
116
|
let deletedCount = 0;
|
|
117
|
+
// Use SCAN to find matching keys (more efficient than KEYS)
|
|
105
118
|
do {
|
|
106
119
|
const [nextCursor, keys] = yield this.redis.scan(cursor, 'MATCH', fullPattern, 'COUNT', 100);
|
|
107
120
|
cursor = nextCursor;
|
|
@@ -124,6 +137,7 @@ let RedisCacheProvider = class RedisCacheProvider extends base_cache_provider_1.
|
|
|
124
137
|
return;
|
|
125
138
|
}
|
|
126
139
|
try {
|
|
140
|
+
// Clear all keys with our prefix
|
|
127
141
|
yield this.deletePattern('*');
|
|
128
142
|
}
|
|
129
143
|
catch (error) {
|
|
@@ -146,6 +160,9 @@ let RedisCacheProvider = class RedisCacheProvider extends base_cache_provider_1.
|
|
|
146
160
|
}
|
|
147
161
|
});
|
|
148
162
|
}
|
|
163
|
+
/**
|
|
164
|
+
* Batch get using Redis MGET
|
|
165
|
+
*/
|
|
149
166
|
mget(keys) {
|
|
150
167
|
return __awaiter(this, void 0, void 0, function* () {
|
|
151
168
|
if (!this.redis || keys.length === 0) {
|
|
@@ -172,6 +189,9 @@ let RedisCacheProvider = class RedisCacheProvider extends base_cache_provider_1.
|
|
|
172
189
|
}
|
|
173
190
|
});
|
|
174
191
|
}
|
|
192
|
+
/**
|
|
193
|
+
* Batch set using Redis pipeline
|
|
194
|
+
*/
|
|
175
195
|
mset(items, ttl) {
|
|
176
196
|
return __awaiter(this, void 0, void 0, function* () {
|
|
177
197
|
if (!this.redis || items.length === 0) {
|
|
@@ -196,12 +216,21 @@ let RedisCacheProvider = class RedisCacheProvider extends base_cache_provider_1.
|
|
|
196
216
|
}
|
|
197
217
|
});
|
|
198
218
|
}
|
|
219
|
+
/**
|
|
220
|
+
* Check if Redis client is available
|
|
221
|
+
*/
|
|
199
222
|
isAvailable() {
|
|
200
223
|
return !!this.redis && this.redis.status === 'ready';
|
|
201
224
|
}
|
|
225
|
+
/**
|
|
226
|
+
* Get Redis client (for advanced usage)
|
|
227
|
+
*/
|
|
202
228
|
getClient() {
|
|
203
229
|
return this.redis;
|
|
204
230
|
}
|
|
231
|
+
/**
|
|
232
|
+
* Get full key with prefix
|
|
233
|
+
*/
|
|
205
234
|
getFullKey(key) {
|
|
206
235
|
return `${this.keyPrefix}${key}`;
|
|
207
236
|
}
|
|
@@ -1,15 +1,67 @@
|
|
|
1
1
|
import type { CacheDependency, DependencyData } from '../interfaces';
|
|
2
|
+
/**
|
|
3
|
+
* Wrapper for cached value with dependency data
|
|
4
|
+
*/
|
|
2
5
|
export interface CachedValueWithDependencies<T> {
|
|
3
6
|
value: T;
|
|
4
7
|
dependencies?: DependencyData[];
|
|
5
8
|
cachedAt: number;
|
|
6
9
|
}
|
|
10
|
+
/**
|
|
11
|
+
* Utility class for managing cache dependencies
|
|
12
|
+
*/
|
|
7
13
|
export declare class DependencyManager {
|
|
14
|
+
/**
|
|
15
|
+
* Wrap a value with its dependencies
|
|
16
|
+
*
|
|
17
|
+
* @param value - The value to cache
|
|
18
|
+
* @param dependencies - Array of dependencies
|
|
19
|
+
* @returns Wrapped value with dependency data
|
|
20
|
+
*/
|
|
8
21
|
static wrapWithDependencies<T>(value: T, dependencies?: CacheDependency[]): Promise<CachedValueWithDependencies<T>>;
|
|
22
|
+
/**
|
|
23
|
+
* Capture current state of all dependencies
|
|
24
|
+
*
|
|
25
|
+
* @param dependencies - Array of dependencies
|
|
26
|
+
* @returns Array of dependency data snapshots
|
|
27
|
+
*/
|
|
9
28
|
static captureDependencies(dependencies: CacheDependency[]): Promise<DependencyData[]>;
|
|
29
|
+
/**
|
|
30
|
+
* Check if any dependencies have changed
|
|
31
|
+
*
|
|
32
|
+
* @param dependencies - Current dependencies
|
|
33
|
+
* @param cachedDependencies - Previously captured dependency data
|
|
34
|
+
* @returns true if any dependency has changed
|
|
35
|
+
*/
|
|
10
36
|
static areDependenciesChanged(dependencies: CacheDependency[], cachedDependencies?: DependencyData[]): Promise<boolean>;
|
|
37
|
+
/**
|
|
38
|
+
* Unwrap cached value and validate dependencies
|
|
39
|
+
*
|
|
40
|
+
* @param wrapped - Wrapped cached value
|
|
41
|
+
* @param dependencies - Current dependencies to check
|
|
42
|
+
* @returns Unwrapped value if valid, null if dependencies changed
|
|
43
|
+
*/
|
|
11
44
|
static unwrapAndValidate<T>(wrapped: CachedValueWithDependencies<T> | null, dependencies?: CacheDependency[]): Promise<T | null>;
|
|
45
|
+
/**
|
|
46
|
+
* Get which dependencies have changed
|
|
47
|
+
*
|
|
48
|
+
* @param dependencies - Current dependencies
|
|
49
|
+
* @param cachedDependencies - Previously captured dependency data
|
|
50
|
+
* @returns Array of changed dependency keys
|
|
51
|
+
*/
|
|
12
52
|
static getChangedDependencies(dependencies: CacheDependency[], cachedDependencies?: DependencyData[]): Promise<string[]>;
|
|
53
|
+
/**
|
|
54
|
+
* Serialize dependencies for storage
|
|
55
|
+
*
|
|
56
|
+
* @param dependencies - Dependency data
|
|
57
|
+
* @returns Serialized string
|
|
58
|
+
*/
|
|
13
59
|
static serializeDependencies(dependencies: DependencyData[]): string;
|
|
60
|
+
/**
|
|
61
|
+
* Deserialize dependencies from storage
|
|
62
|
+
*
|
|
63
|
+
* @param serialized - Serialized string
|
|
64
|
+
* @returns Dependency data array
|
|
65
|
+
*/
|
|
14
66
|
static deserializeDependencies(serialized: string): DependencyData[];
|
|
15
67
|
}
|
|
@@ -10,7 +10,17 @@ var __awaiter = (this && this.__awaiter) || function (thisArg, _arguments, P, ge
|
|
|
10
10
|
};
|
|
11
11
|
Object.defineProperty(exports, "__esModule", { value: true });
|
|
12
12
|
exports.DependencyManager = void 0;
|
|
13
|
+
/**
|
|
14
|
+
* Utility class for managing cache dependencies
|
|
15
|
+
*/
|
|
13
16
|
class DependencyManager {
|
|
17
|
+
/**
|
|
18
|
+
* Wrap a value with its dependencies
|
|
19
|
+
*
|
|
20
|
+
* @param value - The value to cache
|
|
21
|
+
* @param dependencies - Array of dependencies
|
|
22
|
+
* @returns Wrapped value with dependency data
|
|
23
|
+
*/
|
|
14
24
|
static wrapWithDependencies(value, dependencies) {
|
|
15
25
|
return __awaiter(this, void 0, void 0, function* () {
|
|
16
26
|
const wrapped = {
|
|
@@ -23,6 +33,12 @@ class DependencyManager {
|
|
|
23
33
|
return wrapped;
|
|
24
34
|
});
|
|
25
35
|
}
|
|
36
|
+
/**
|
|
37
|
+
* Capture current state of all dependencies
|
|
38
|
+
*
|
|
39
|
+
* @param dependencies - Array of dependencies
|
|
40
|
+
* @returns Array of dependency data snapshots
|
|
41
|
+
*/
|
|
26
42
|
static captureDependencies(dependencies) {
|
|
27
43
|
return __awaiter(this, void 0, void 0, function* () {
|
|
28
44
|
const results = [];
|
|
@@ -36,6 +52,7 @@ class DependencyManager {
|
|
|
36
52
|
});
|
|
37
53
|
}
|
|
38
54
|
catch (error) {
|
|
55
|
+
// Store error state
|
|
39
56
|
results.push({
|
|
40
57
|
key: dep.getKey(),
|
|
41
58
|
data: {
|
|
@@ -48,44 +65,67 @@ class DependencyManager {
|
|
|
48
65
|
return results;
|
|
49
66
|
});
|
|
50
67
|
}
|
|
68
|
+
/**
|
|
69
|
+
* Check if any dependencies have changed
|
|
70
|
+
*
|
|
71
|
+
* @param dependencies - Current dependencies
|
|
72
|
+
* @param cachedDependencies - Previously captured dependency data
|
|
73
|
+
* @returns true if any dependency has changed
|
|
74
|
+
*/
|
|
51
75
|
static areDependenciesChanged(dependencies, cachedDependencies) {
|
|
52
76
|
return __awaiter(this, void 0, void 0, function* () {
|
|
77
|
+
// No dependencies means never changed
|
|
53
78
|
if (!dependencies || dependencies.length === 0) {
|
|
54
79
|
return false;
|
|
55
80
|
}
|
|
81
|
+
// No cached dependency data means changed (first time)
|
|
56
82
|
if (!cachedDependencies || cachedDependencies.length === 0) {
|
|
57
83
|
return true;
|
|
58
84
|
}
|
|
85
|
+
// Different number of dependencies means changed
|
|
59
86
|
if (dependencies.length !== cachedDependencies.length) {
|
|
60
87
|
return true;
|
|
61
88
|
}
|
|
89
|
+
// Check each dependency
|
|
62
90
|
for (let i = 0; i < dependencies.length; i++) {
|
|
63
91
|
const dep = dependencies[i];
|
|
64
92
|
const cached = cachedDependencies[i];
|
|
93
|
+
// Key mismatch means dependencies changed
|
|
65
94
|
if (dep.getKey() !== cached.key) {
|
|
66
95
|
return true;
|
|
67
96
|
}
|
|
68
97
|
try {
|
|
98
|
+
// Check if this dependency has changed
|
|
69
99
|
const changed = yield dep.isChanged(cached.data);
|
|
70
100
|
if (changed) {
|
|
71
101
|
return true;
|
|
72
102
|
}
|
|
73
103
|
}
|
|
74
104
|
catch (_a) {
|
|
105
|
+
// If check fails, consider it changed to be safe
|
|
75
106
|
return true;
|
|
76
107
|
}
|
|
77
108
|
}
|
|
78
109
|
return false;
|
|
79
110
|
});
|
|
80
111
|
}
|
|
112
|
+
/**
|
|
113
|
+
* Unwrap cached value and validate dependencies
|
|
114
|
+
*
|
|
115
|
+
* @param wrapped - Wrapped cached value
|
|
116
|
+
* @param dependencies - Current dependencies to check
|
|
117
|
+
* @returns Unwrapped value if valid, null if dependencies changed
|
|
118
|
+
*/
|
|
81
119
|
static unwrapAndValidate(wrapped, dependencies) {
|
|
82
120
|
return __awaiter(this, void 0, void 0, function* () {
|
|
83
121
|
if (!wrapped) {
|
|
84
122
|
return null;
|
|
85
123
|
}
|
|
124
|
+
// No dependencies to check, return value
|
|
86
125
|
if (!dependencies || dependencies.length === 0) {
|
|
87
126
|
return wrapped.value;
|
|
88
127
|
}
|
|
128
|
+
// Check if dependencies have changed
|
|
89
129
|
const changed = yield this.areDependenciesChanged(dependencies, wrapped.dependencies);
|
|
90
130
|
if (changed) {
|
|
91
131
|
return null;
|
|
@@ -93,6 +133,13 @@ class DependencyManager {
|
|
|
93
133
|
return wrapped.value;
|
|
94
134
|
});
|
|
95
135
|
}
|
|
136
|
+
/**
|
|
137
|
+
* Get which dependencies have changed
|
|
138
|
+
*
|
|
139
|
+
* @param dependencies - Current dependencies
|
|
140
|
+
* @param cachedDependencies - Previously captured dependency data
|
|
141
|
+
* @returns Array of changed dependency keys
|
|
142
|
+
*/
|
|
96
143
|
static getChangedDependencies(dependencies, cachedDependencies) {
|
|
97
144
|
return __awaiter(this, void 0, void 0, function* () {
|
|
98
145
|
if (!dependencies || dependencies.length === 0) {
|
|
@@ -121,6 +168,12 @@ class DependencyManager {
|
|
|
121
168
|
return changed;
|
|
122
169
|
});
|
|
123
170
|
}
|
|
171
|
+
/**
|
|
172
|
+
* Serialize dependencies for storage
|
|
173
|
+
*
|
|
174
|
+
* @param dependencies - Dependency data
|
|
175
|
+
* @returns Serialized string
|
|
176
|
+
*/
|
|
124
177
|
static serializeDependencies(dependencies) {
|
|
125
178
|
try {
|
|
126
179
|
return JSON.stringify(dependencies);
|
|
@@ -129,6 +182,12 @@ class DependencyManager {
|
|
|
129
182
|
return '[]';
|
|
130
183
|
}
|
|
131
184
|
}
|
|
185
|
+
/**
|
|
186
|
+
* Deserialize dependencies from storage
|
|
187
|
+
*
|
|
188
|
+
* @param serialized - Serialized string
|
|
189
|
+
* @returns Dependency data array
|
|
190
|
+
*/
|
|
132
191
|
static deserializeDependencies(serialized) {
|
|
133
192
|
try {
|
|
134
193
|
return JSON.parse(serialized);
|
|
@@ -1,10 +1,52 @@
|
|
|
1
1
|
import type { CacheKeyOptions } from '../interfaces';
|
|
2
|
+
/**
|
|
3
|
+
* Utility class for generating cache keys
|
|
4
|
+
*/
|
|
2
5
|
export declare class KeyGenerator {
|
|
6
|
+
/**
|
|
7
|
+
* Generate cache key from options and method arguments
|
|
8
|
+
*
|
|
9
|
+
* @param options - Cache key options
|
|
10
|
+
* @param args - Method arguments
|
|
11
|
+
* @returns Generated cache key
|
|
12
|
+
*/
|
|
3
13
|
static generate(options: CacheKeyOptions, args: any[]): string;
|
|
14
|
+
/**
|
|
15
|
+
* Generate key from method arguments
|
|
16
|
+
*
|
|
17
|
+
* @param args - Method arguments
|
|
18
|
+
* @returns Serialized key
|
|
19
|
+
*/
|
|
4
20
|
static generateFromArgs(args: any[]): string;
|
|
21
|
+
/**
|
|
22
|
+
* Normalize key (remove invalid characters, enforce length limits)
|
|
23
|
+
*
|
|
24
|
+
* @param key - Raw key
|
|
25
|
+
* @param maxLength - Maximum key length (default 250)
|
|
26
|
+
* @returns Normalized key
|
|
27
|
+
*/
|
|
5
28
|
static normalize(key: string, maxLength?: number): string;
|
|
29
|
+
/**
|
|
30
|
+
* Add namespace to key
|
|
31
|
+
*
|
|
32
|
+
* @param key - Original key
|
|
33
|
+
* @param namespace - Namespace
|
|
34
|
+
* @returns Namespaced key
|
|
35
|
+
*/
|
|
6
36
|
static addNamespace(key: string, namespace?: string): string;
|
|
37
|
+
/**
|
|
38
|
+
* Generate hash code for a string
|
|
39
|
+
*
|
|
40
|
+
* @param str - Input string
|
|
41
|
+
* @returns Hash code as string
|
|
42
|
+
*/
|
|
7
43
|
static hashCode(str: string): string;
|
|
44
|
+
/**
|
|
45
|
+
* Parse pattern into segments for matching
|
|
46
|
+
*
|
|
47
|
+
* @param pattern - Pattern with wildcards
|
|
48
|
+
* @returns Pattern segments
|
|
49
|
+
*/
|
|
8
50
|
static parsePattern(pattern: string): {
|
|
9
51
|
prefix: string;
|
|
10
52
|
suffix: string;
|