@dollhousemcp/mcp-server 1.5.2 → 1.6.0
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 +56 -0
- package/README.md +494 -111
- package/data/agents/code-reviewer.md +8 -1
- package/data/agents/research-assistant.md +8 -1
- package/data/agents/task-manager.md +8 -1
- package/data/ensembles/business-advisor.md +8 -1
- package/data/ensembles/creative-studio.md +8 -1
- package/data/ensembles/development-team.md +8 -1
- package/data/ensembles/security-analysis-team.md +8 -1
- package/data/memories/conversation-history.md +8 -1
- package/data/memories/learning-progress.md +8 -1
- package/data/memories/project-context.md +8 -1
- package/data/personas/business-consultant.md +8 -1
- package/data/personas/creative-writer.md +8 -1
- package/data/personas/debug-detective.md +8 -1
- package/data/personas/eli5-explainer.md +8 -1
- package/data/personas/security-analyst.md +8 -1
- package/data/personas/technical-analyst.md +8 -1
- package/data/skills/code-review.md +8 -1
- package/data/skills/creative-writing.md +8 -1
- package/data/skills/data-analysis.md +8 -1
- package/data/skills/penetration-testing.md +8 -1
- package/data/skills/research.md +8 -1
- package/data/skills/threat-modeling.md +8 -1
- package/data/skills/translation.md +8 -1
- package/data/templates/code-documentation.md +8 -1
- package/data/templates/email-professional.md +8 -1
- package/data/templates/meeting-notes.md +8 -1
- package/data/templates/penetration-test-report.md +8 -1
- package/data/templates/project-brief.md +8 -1
- package/data/templates/report-executive.md +8 -1
- package/data/templates/security-vulnerability-report.md +8 -1
- package/data/templates/threat-assessment-report.md +8 -1
- package/dist/auth/GitHubAuthManager.d.ts +6 -1
- package/dist/auth/GitHubAuthManager.d.ts.map +1 -1
- package/dist/auth/GitHubAuthManager.js +45 -18
- package/dist/benchmarks/IndexPerformanceBenchmark.d.ts +98 -0
- package/dist/benchmarks/IndexPerformanceBenchmark.d.ts.map +1 -0
- package/dist/benchmarks/IndexPerformanceBenchmark.js +531 -0
- package/dist/cache/CollectionCache.d.ts.map +1 -1
- package/dist/cache/CollectionCache.js +13 -3
- package/dist/cache/CollectionIndexCache.d.ts +77 -0
- package/dist/cache/CollectionIndexCache.d.ts.map +1 -0
- package/dist/cache/CollectionIndexCache.js +349 -0
- package/dist/cache/LRUCache.d.ts +93 -0
- package/dist/cache/LRUCache.d.ts.map +1 -0
- package/dist/cache/LRUCache.js +299 -0
- package/dist/cache/index.d.ts +1 -0
- package/dist/cache/index.d.ts.map +1 -1
- package/dist/cache/index.js +2 -1
- package/dist/collection/CollectionBrowser.d.ts +21 -1
- package/dist/collection/CollectionBrowser.d.ts.map +1 -1
- package/dist/collection/CollectionBrowser.js +130 -10
- package/dist/collection/CollectionIndexManager.d.ts +151 -0
- package/dist/collection/CollectionIndexManager.d.ts.map +1 -0
- package/dist/collection/CollectionIndexManager.js +499 -0
- package/dist/collection/CollectionSearch.d.ts +55 -0
- package/dist/collection/CollectionSearch.d.ts.map +1 -1
- package/dist/collection/CollectionSearch.js +338 -13
- package/dist/collection/CollectionSeeder.d.ts.map +1 -1
- package/dist/collection/CollectionSeeder.js +38 -1
- package/dist/collection/ElementInstaller.d.ts +31 -0
- package/dist/collection/ElementInstaller.d.ts.map +1 -1
- package/dist/collection/ElementInstaller.js +77 -15
- package/dist/collection/PersonaSubmitter.d.ts +1 -1
- package/dist/collection/PersonaSubmitter.d.ts.map +1 -1
- package/dist/collection/PersonaSubmitter.js +2 -2
- package/dist/collection/index.d.ts +1 -0
- package/dist/collection/index.d.ts.map +1 -1
- package/dist/collection/index.js +2 -1
- package/dist/config/ConfigManager.d.ts +78 -0
- package/dist/config/ConfigManager.d.ts.map +1 -0
- package/dist/config/ConfigManager.js +216 -0
- package/dist/config/element-types.d.ts +135 -0
- package/dist/config/element-types.d.ts.map +1 -0
- package/dist/config/element-types.js +108 -0
- package/dist/config/index.d.ts +2 -0
- package/dist/config/index.d.ts.map +1 -1
- package/dist/config/index.js +3 -1
- package/dist/config/portfolio-constants.d.ts +83 -0
- package/dist/config/portfolio-constants.d.ts.map +1 -0
- package/dist/config/portfolio-constants.js +99 -0
- package/dist/elements/BaseElement.d.ts +14 -2
- package/dist/elements/BaseElement.d.ts.map +1 -1
- package/dist/elements/BaseElement.js +88 -6
- package/dist/elements/agents/Agent.d.ts +10 -1
- package/dist/elements/agents/Agent.d.ts.map +1 -1
- package/dist/elements/agents/Agent.js +66 -19
- package/dist/elements/agents/AgentManager.d.ts +2 -0
- package/dist/elements/agents/AgentManager.d.ts.map +1 -1
- package/dist/elements/agents/AgentManager.js +12 -10
- package/dist/elements/skills/Skill.d.ts +10 -1
- package/dist/elements/skills/Skill.d.ts.map +1 -1
- package/dist/elements/skills/Skill.js +40 -3
- package/dist/elements/skills/SkillManager.d.ts +1 -0
- package/dist/elements/skills/SkillManager.d.ts.map +1 -1
- package/dist/elements/skills/SkillManager.js +10 -4
- package/dist/elements/templates/Template.d.ts +10 -1
- package/dist/elements/templates/Template.d.ts.map +1 -1
- package/dist/elements/templates/Template.js +35 -18
- package/dist/elements/templates/TemplateManager.d.ts +1 -1
- package/dist/elements/templates/TemplateManager.d.ts.map +1 -1
- package/dist/elements/templates/TemplateManager.js +6 -5
- package/dist/generated/version.d.ts +2 -2
- package/dist/generated/version.js +3 -3
- package/dist/index.barrel.d.ts +1 -2
- package/dist/index.barrel.d.ts.map +1 -1
- package/dist/index.barrel.js +2 -4
- package/dist/index.d.ts +143 -25
- package/dist/index.d.ts.map +1 -1
- package/dist/index.js +1883 -310
- package/dist/persona/PersonaElement.d.ts +10 -0
- package/dist/persona/PersonaElement.d.ts.map +1 -1
- package/dist/persona/PersonaElement.js +55 -32
- package/dist/persona/PersonaElementManager.d.ts.map +1 -1
- package/dist/persona/PersonaElementManager.js +13 -11
- package/dist/persona/PersonaLoader.d.ts.map +1 -1
- package/dist/persona/PersonaLoader.js +8 -2
- package/dist/persona/export-import/PersonaImporter.d.ts.map +1 -1
- package/dist/persona/export-import/PersonaImporter.js +24 -5
- package/dist/persona/export-import/PersonaSharer.d.ts +21 -0
- package/dist/persona/export-import/PersonaSharer.d.ts.map +1 -1
- package/dist/persona/export-import/PersonaSharer.js +198 -22
- package/dist/portfolio/DefaultElementProvider.d.ts +90 -0
- package/dist/portfolio/DefaultElementProvider.d.ts.map +1 -1
- package/dist/portfolio/DefaultElementProvider.js +499 -7
- package/dist/portfolio/GitHubPortfolioIndexer.d.ts +129 -0
- package/dist/portfolio/GitHubPortfolioIndexer.d.ts.map +1 -0
- package/dist/portfolio/GitHubPortfolioIndexer.js +475 -0
- package/dist/portfolio/MigrationManager.d.ts.map +1 -1
- package/dist/portfolio/MigrationManager.js +136 -3
- package/dist/portfolio/PortfolioIndexManager.d.ts +130 -0
- package/dist/portfolio/PortfolioIndexManager.d.ts.map +1 -0
- package/dist/portfolio/PortfolioIndexManager.js +478 -0
- package/dist/portfolio/PortfolioManager.d.ts +5 -0
- package/dist/portfolio/PortfolioManager.d.ts.map +1 -1
- package/dist/portfolio/PortfolioManager.js +61 -20
- package/dist/portfolio/PortfolioRepoManager.d.ts +75 -0
- package/dist/portfolio/PortfolioRepoManager.d.ts.map +1 -0
- package/dist/portfolio/PortfolioRepoManager.js +337 -0
- package/dist/portfolio/UnifiedIndexManager.d.ts +388 -0
- package/dist/portfolio/UnifiedIndexManager.d.ts.map +1 -0
- package/dist/portfolio/UnifiedIndexManager.js +1434 -0
- package/dist/portfolio/index.d.ts +15 -0
- package/dist/portfolio/index.d.ts.map +1 -0
- package/dist/portfolio/index.js +15 -0
- package/dist/portfolio/types.d.ts +7 -0
- package/dist/portfolio/types.d.ts.map +1 -1
- package/dist/portfolio/types.js +6 -1
- package/dist/security/InputValidator.d.ts.map +1 -1
- package/dist/security/InputValidator.js +50 -48
- package/dist/security/audit/SecurityAuditor.d.ts.map +1 -1
- package/dist/security/audit/SecurityAuditor.js +17 -9
- package/dist/security/audit/config/suppressions.d.ts.map +1 -1
- package/dist/security/audit/config/suppressions.js +19 -3
- package/dist/security/contentValidator.d.ts +2 -0
- package/dist/security/contentValidator.d.ts.map +1 -1
- package/dist/security/contentValidator.js +115 -4
- package/dist/security/secureYamlParser.d.ts +1 -0
- package/dist/security/secureYamlParser.d.ts.map +1 -1
- package/dist/security/secureYamlParser.js +29 -7
- package/dist/security/securityMonitor.d.ts +1 -1
- package/dist/security/securityMonitor.d.ts.map +1 -1
- package/dist/security/securityMonitor.js +1 -1
- package/dist/security/tokenManager.d.ts +1 -1
- package/dist/security/tokenManager.d.ts.map +1 -1
- package/dist/security/tokenManager.js +30 -10
- package/dist/server/ServerSetup.d.ts +22 -2
- package/dist/server/ServerSetup.d.ts.map +1 -1
- package/dist/server/ServerSetup.js +77 -12
- package/dist/server/tools/AuthTools.d.ts.map +1 -1
- package/dist/server/tools/AuthTools.js +33 -1
- package/dist/server/tools/BuildInfoTools.d.ts +25 -0
- package/dist/server/tools/BuildInfoTools.d.ts.map +1 -0
- package/dist/server/tools/BuildInfoTools.js +36 -0
- package/dist/server/tools/CollectionTools.d.ts.map +1 -1
- package/dist/server/tools/CollectionTools.js +55 -46
- package/dist/server/tools/ConfigTools.d.ts.map +1 -1
- package/dist/server/tools/ConfigTools.js +29 -1
- package/dist/server/tools/PersonaTools.d.ts +4 -2
- package/dist/server/tools/PersonaTools.d.ts.map +1 -1
- package/dist/server/tools/PersonaTools.js +5 -152
- package/dist/server/tools/PortfolioTools.d.ts +12 -0
- package/dist/server/tools/PortfolioTools.d.ts.map +1 -0
- package/dist/server/tools/PortfolioTools.js +221 -0
- package/dist/server/tools/index.d.ts +3 -1
- package/dist/server/tools/index.d.ts.map +1 -1
- package/dist/server/tools/index.js +4 -2
- package/dist/server/types.d.ts +40 -5
- package/dist/server/types.d.ts.map +1 -1
- package/dist/server/types.js +1 -1
- package/dist/services/BuildInfoService.d.ts +84 -0
- package/dist/services/BuildInfoService.d.ts.map +1 -0
- package/dist/services/BuildInfoService.js +271 -0
- package/dist/tools/portfolio/PortfolioElementAdapter.d.ts +54 -0
- package/dist/tools/portfolio/PortfolioElementAdapter.d.ts.map +1 -0
- package/dist/tools/portfolio/PortfolioElementAdapter.js +229 -0
- package/dist/tools/portfolio/submitToPortfolioTool.d.ts +164 -0
- package/dist/tools/portfolio/submitToPortfolioTool.d.ts.map +1 -0
- package/dist/tools/portfolio/submitToPortfolioTool.js +1523 -0
- package/dist/tools/portfolio/types.d.ts +41 -0
- package/dist/tools/portfolio/types.d.ts.map +1 -0
- package/dist/tools/portfolio/types.js +15 -0
- package/dist/types/collection.d.ts +51 -0
- package/dist/types/collection.d.ts.map +1 -1
- package/dist/types/collection.js +1 -1
- package/dist/utils/EarlyTerminationSearch.d.ts +41 -0
- package/dist/utils/EarlyTerminationSearch.d.ts.map +1 -0
- package/dist/utils/EarlyTerminationSearch.js +164 -0
- package/dist/utils/ErrorHandler.d.ts +86 -0
- package/dist/utils/ErrorHandler.d.ts.map +1 -0
- package/dist/utils/ErrorHandler.js +201 -0
- package/dist/utils/FileDiscoveryUtil.d.ts +53 -0
- package/dist/utils/FileDiscoveryUtil.d.ts.map +1 -0
- package/dist/utils/FileDiscoveryUtil.js +169 -0
- package/dist/utils/GitHubRateLimiter.d.ts +88 -0
- package/dist/utils/GitHubRateLimiter.d.ts.map +1 -0
- package/dist/utils/GitHubRateLimiter.js +315 -0
- package/dist/utils/PerformanceMonitor.d.ts +134 -0
- package/dist/utils/PerformanceMonitor.d.ts.map +1 -0
- package/dist/utils/PerformanceMonitor.js +347 -0
- package/dist/utils/RateLimiter.d.ts.map +1 -0
- package/dist/utils/RateLimiter.js +172 -0
- package/dist/utils/SecureDownloader.d.ts +241 -0
- package/dist/utils/SecureDownloader.d.ts.map +1 -0
- package/dist/utils/SecureDownloader.js +759 -0
- package/dist/utils/ToolCache.d.ts +82 -0
- package/dist/utils/ToolCache.d.ts.map +1 -0
- package/dist/utils/ToolCache.js +196 -0
- package/dist/utils/errorCodes.d.ts +136 -0
- package/dist/utils/errorCodes.d.ts.map +1 -0
- package/dist/utils/errorCodes.js +87 -0
- package/dist/utils/index.d.ts +3 -0
- package/dist/utils/index.d.ts.map +1 -1
- package/dist/utils/index.js +4 -1
- package/dist/utils/installation.d.ts +1 -1
- package/dist/utils/installation.d.ts.map +1 -1
- package/dist/utils/installation.js +9 -8
- package/dist/utils/searchUtils.d.ts +31 -0
- package/dist/utils/searchUtils.d.ts.map +1 -1
- package/dist/utils/searchUtils.js +62 -1
- package/package.json +17 -7
- package/dist/config/updateConfig.d.ts +0 -84
- package/dist/config/updateConfig.d.ts.map +0 -1
- package/dist/config/updateConfig.js +0 -148
- package/dist/server/tools/UpdateTools.d.ts +0 -10
- package/dist/server/tools/UpdateTools.d.ts.map +0 -1
- package/dist/server/tools/UpdateTools.js +0 -85
- package/dist/update/BackupManager.d.ts +0 -63
- package/dist/update/BackupManager.d.ts.map +0 -1
- package/dist/update/BackupManager.js +0 -370
- package/dist/update/DependencyChecker.d.ts +0 -41
- package/dist/update/DependencyChecker.d.ts.map +0 -1
- package/dist/update/DependencyChecker.js +0 -132
- package/dist/update/RateLimiter.d.ts.map +0 -1
- package/dist/update/RateLimiter.js +0 -172
- package/dist/update/SignatureVerifier.d.ts +0 -71
- package/dist/update/SignatureVerifier.d.ts.map +0 -1
- package/dist/update/SignatureVerifier.js +0 -214
- package/dist/update/UpdateChecker.d.ts +0 -132
- package/dist/update/UpdateChecker.d.ts.map +0 -1
- package/dist/update/UpdateChecker.js +0 -506
- package/dist/update/UpdateManager.d.ts +0 -60
- package/dist/update/UpdateManager.d.ts.map +0 -1
- package/dist/update/UpdateManager.js +0 -730
- package/dist/update/VersionManager.d.ts +0 -31
- package/dist/update/VersionManager.d.ts.map +0 -1
- package/dist/update/VersionManager.js +0 -181
- package/dist/update/index.d.ts +0 -9
- package/dist/update/index.d.ts.map +0 -1
- package/dist/update/index.js +0 -9
- /package/dist/{update → utils}/RateLimiter.d.ts +0 -0
|
@@ -0,0 +1,93 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* High-performance LRU Cache with memory monitoring and automatic cleanup
|
|
3
|
+
* Optimized for large-scale indexing operations with configurable memory limits
|
|
4
|
+
*/
|
|
5
|
+
export interface LRUCacheOptions {
|
|
6
|
+
maxSize: number;
|
|
7
|
+
maxMemoryMB?: number;
|
|
8
|
+
ttlMs?: number;
|
|
9
|
+
onEviction?: (key: string, value: any) => void;
|
|
10
|
+
}
|
|
11
|
+
export interface CacheStats {
|
|
12
|
+
size: number;
|
|
13
|
+
maxSize: number;
|
|
14
|
+
hitCount: number;
|
|
15
|
+
missCount: number;
|
|
16
|
+
evictionCount: number;
|
|
17
|
+
memoryUsageMB: number;
|
|
18
|
+
hitRate: number;
|
|
19
|
+
}
|
|
20
|
+
export declare class LRUCache<T> {
|
|
21
|
+
private readonly maxSize;
|
|
22
|
+
private readonly maxMemoryBytes;
|
|
23
|
+
private readonly ttlMs;
|
|
24
|
+
private readonly onEviction?;
|
|
25
|
+
private cache;
|
|
26
|
+
private head;
|
|
27
|
+
private tail;
|
|
28
|
+
private currentMemoryBytes;
|
|
29
|
+
private hitCount;
|
|
30
|
+
private missCount;
|
|
31
|
+
private evictionCount;
|
|
32
|
+
constructor(options: LRUCacheOptions);
|
|
33
|
+
/**
|
|
34
|
+
* Get value from cache with automatic cleanup
|
|
35
|
+
*/
|
|
36
|
+
get(key: string): T | null;
|
|
37
|
+
/**
|
|
38
|
+
* Set value in cache with automatic eviction
|
|
39
|
+
*/
|
|
40
|
+
set(key: string, value: T): void;
|
|
41
|
+
/**
|
|
42
|
+
* Delete specific key from cache
|
|
43
|
+
*/
|
|
44
|
+
delete(key: string): boolean;
|
|
45
|
+
/**
|
|
46
|
+
* Check if key exists in cache
|
|
47
|
+
*/
|
|
48
|
+
has(key: string): boolean;
|
|
49
|
+
/**
|
|
50
|
+
* Clear all entries from cache
|
|
51
|
+
*/
|
|
52
|
+
clear(): void;
|
|
53
|
+
/**
|
|
54
|
+
* Get cache statistics
|
|
55
|
+
*/
|
|
56
|
+
getStats(): CacheStats;
|
|
57
|
+
/**
|
|
58
|
+
* Get all keys in access order (most recent first)
|
|
59
|
+
*/
|
|
60
|
+
keys(): string[];
|
|
61
|
+
/**
|
|
62
|
+
* Get current memory usage in MB
|
|
63
|
+
*/
|
|
64
|
+
getMemoryUsageMB(): number;
|
|
65
|
+
/**
|
|
66
|
+
* Manually trigger cleanup of expired entries
|
|
67
|
+
*/
|
|
68
|
+
cleanup(): number;
|
|
69
|
+
private moveToFront;
|
|
70
|
+
private addToFront;
|
|
71
|
+
private removeNode;
|
|
72
|
+
private evictIfNecessary;
|
|
73
|
+
private evictLeastRecentlyUsed;
|
|
74
|
+
private estimateSize;
|
|
75
|
+
}
|
|
76
|
+
/**
|
|
77
|
+
* Factory for creating optimized LRU caches for different use cases
|
|
78
|
+
*/
|
|
79
|
+
export declare class CacheFactory {
|
|
80
|
+
/**
|
|
81
|
+
* Create cache optimized for search results
|
|
82
|
+
*/
|
|
83
|
+
static createSearchResultCache<T>(options?: Partial<LRUCacheOptions>): LRUCache<T>;
|
|
84
|
+
/**
|
|
85
|
+
* Create cache optimized for index data
|
|
86
|
+
*/
|
|
87
|
+
static createIndexCache<T>(options?: Partial<LRUCacheOptions>): LRUCache<T>;
|
|
88
|
+
/**
|
|
89
|
+
* Create cache optimized for API responses
|
|
90
|
+
*/
|
|
91
|
+
static createAPICache<T>(options?: Partial<LRUCacheOptions>): LRUCache<T>;
|
|
92
|
+
}
|
|
93
|
+
//# sourceMappingURL=LRUCache.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"LRUCache.d.ts","sourceRoot":"","sources":["../../src/cache/LRUCache.ts"],"names":[],"mappings":"AAAA;;;GAGG;AAIH,MAAM,WAAW,eAAe;IAC9B,OAAO,EAAE,MAAM,CAAC;IAChB,WAAW,CAAC,EAAE,MAAM,CAAC;IACrB,KAAK,CAAC,EAAE,MAAM,CAAC;IACf,UAAU,CAAC,EAAE,CAAC,GAAG,EAAE,MAAM,EAAE,KAAK,EAAE,GAAG,KAAK,IAAI,CAAC;CAChD;AAED,MAAM,WAAW,UAAU;IACzB,IAAI,EAAE,MAAM,CAAC;IACb,OAAO,EAAE,MAAM,CAAC;IAChB,QAAQ,EAAE,MAAM,CAAC;IACjB,SAAS,EAAE,MAAM,CAAC;IAClB,aAAa,EAAE,MAAM,CAAC;IACtB,aAAa,EAAE,MAAM,CAAC;IACtB,OAAO,EAAE,MAAM,CAAC;CACjB;AAWD,qBAAa,QAAQ,CAAC,CAAC;IACrB,OAAO,CAAC,QAAQ,CAAC,OAAO,CAAS;IACjC,OAAO,CAAC,QAAQ,CAAC,cAAc,CAAS;IACxC,OAAO,CAAC,QAAQ,CAAC,KAAK,CAAS;IAC/B,OAAO,CAAC,QAAQ,CAAC,UAAU,CAAC,CAAkC;IAE9D,OAAO,CAAC,KAAK,CAAmC;IAChD,OAAO,CAAC,IAAI,CAA6B;IACzC,OAAO,CAAC,IAAI,CAA6B;IACzC,OAAO,CAAC,kBAAkB,CAAK;IAG/B,OAAO,CAAC,QAAQ,CAAK;IACrB,OAAO,CAAC,SAAS,CAAK;IACtB,OAAO,CAAC,aAAa,CAAK;gBAEd,OAAO,EAAE,eAAe;IAOpC;;OAEG;IACH,GAAG,CAAC,GAAG,EAAE,MAAM,GAAG,CAAC,GAAG,IAAI;IAqB1B;;OAEG;IACH,GAAG,CAAC,GAAG,EAAE,MAAM,EAAE,KAAK,EAAE,CAAC,GAAG,IAAI;IAgChC;;OAEG;IACH,MAAM,CAAC,GAAG,EAAE,MAAM,GAAG,OAAO;IAiB5B;;OAEG;IACH,GAAG,CAAC,GAAG,EAAE,MAAM,GAAG,OAAO;IAezB;;OAEG;IACH,KAAK,IAAI,IAAI;IAcb;;OAEG;IACH,QAAQ,IAAI,UAAU;IAYtB;;OAEG;IACH,IAAI,IAAI,MAAM,EAAE;IAYhB;;OAEG;IACH,gBAAgB,IAAI,MAAM;IAI1B;;OAEG;IACH,OAAO,IAAI,MAAM;IAuBjB,OAAO,CAAC,WAAW;IAYnB,OAAO,CAAC,UAAU;IAelB,OAAO,CAAC,UAAU;IAclB,OAAO,CAAC,gBAAgB;IAiBxB,OAAO,CAAC,sBAAsB;IAgB9B,OAAO,CAAC,YAAY;CA8BrB;AAED;;GAEG;AACH,qBAAa,YAAY;IACvB;;OAEG;IACH,MAAM,CAAC,uBAAuB,CAAC,CAAC,EAAE,OAAO,CAAC,EAAE,OAAO,CAAC,eAAe,CAAC,GAAG,QAAQ,CAAC,CAAC,CAAC;IASlF;;OAEG;IACH,MAAM,CAAC,gBAAgB,CAAC,CAAC,EAAE,OAAO,CAAC,EAAE,OAAO,CAAC,eAAe,CAAC,GAAG,QAAQ,CAAC,CAAC,CAAC;IAS3E;;OAEG;IACH,MAAM,CAAC,cAAc,CAAC,CAAC,EAAE,OAAO,CAAC,EAAE,OAAO,CAAC,eAAe,CAAC,GAAG,QAAQ,CAAC,CAAC,CAAC;CAQ1E"}
|
|
@@ -0,0 +1,299 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* High-performance LRU Cache with memory monitoring and automatic cleanup
|
|
3
|
+
* Optimized for large-scale indexing operations with configurable memory limits
|
|
4
|
+
*/
|
|
5
|
+
export class LRUCache {
|
|
6
|
+
maxSize;
|
|
7
|
+
maxMemoryBytes;
|
|
8
|
+
ttlMs;
|
|
9
|
+
onEviction;
|
|
10
|
+
cache = new Map();
|
|
11
|
+
head = null;
|
|
12
|
+
tail = null;
|
|
13
|
+
currentMemoryBytes = 0;
|
|
14
|
+
// Performance counters
|
|
15
|
+
hitCount = 0;
|
|
16
|
+
missCount = 0;
|
|
17
|
+
evictionCount = 0;
|
|
18
|
+
constructor(options) {
|
|
19
|
+
this.maxSize = options.maxSize;
|
|
20
|
+
this.maxMemoryBytes = (options.maxMemoryMB || 50) * 1024 * 1024; // Convert MB to bytes
|
|
21
|
+
this.ttlMs = options.ttlMs || 0; // 0 means no TTL
|
|
22
|
+
this.onEviction = options.onEviction;
|
|
23
|
+
}
|
|
24
|
+
/**
|
|
25
|
+
* Get value from cache with automatic cleanup
|
|
26
|
+
*/
|
|
27
|
+
get(key) {
|
|
28
|
+
const node = this.cache.get(key);
|
|
29
|
+
if (!node) {
|
|
30
|
+
this.missCount++;
|
|
31
|
+
return null;
|
|
32
|
+
}
|
|
33
|
+
// Check TTL if enabled
|
|
34
|
+
if (this.ttlMs > 0 && Date.now() - node.timestamp > this.ttlMs) {
|
|
35
|
+
this.delete(key);
|
|
36
|
+
this.missCount++;
|
|
37
|
+
return null;
|
|
38
|
+
}
|
|
39
|
+
// Move to front (most recently used)
|
|
40
|
+
this.moveToFront(node);
|
|
41
|
+
this.hitCount++;
|
|
42
|
+
return node.value;
|
|
43
|
+
}
|
|
44
|
+
/**
|
|
45
|
+
* Set value in cache with automatic eviction
|
|
46
|
+
*/
|
|
47
|
+
set(key, value) {
|
|
48
|
+
const existingNode = this.cache.get(key);
|
|
49
|
+
if (existingNode) {
|
|
50
|
+
// Update existing node
|
|
51
|
+
const oldSize = existingNode.size;
|
|
52
|
+
existingNode.value = value;
|
|
53
|
+
existingNode.timestamp = Date.now();
|
|
54
|
+
existingNode.size = this.estimateSize(value);
|
|
55
|
+
this.currentMemoryBytes += existingNode.size - oldSize;
|
|
56
|
+
this.moveToFront(existingNode);
|
|
57
|
+
}
|
|
58
|
+
else {
|
|
59
|
+
// Create new node
|
|
60
|
+
const newNode = {
|
|
61
|
+
key,
|
|
62
|
+
value,
|
|
63
|
+
prev: null,
|
|
64
|
+
next: null,
|
|
65
|
+
timestamp: Date.now(),
|
|
66
|
+
size: this.estimateSize(value)
|
|
67
|
+
};
|
|
68
|
+
this.cache.set(key, newNode);
|
|
69
|
+
this.currentMemoryBytes += newNode.size;
|
|
70
|
+
this.addToFront(newNode);
|
|
71
|
+
}
|
|
72
|
+
// Evict if necessary
|
|
73
|
+
this.evictIfNecessary();
|
|
74
|
+
}
|
|
75
|
+
/**
|
|
76
|
+
* Delete specific key from cache
|
|
77
|
+
*/
|
|
78
|
+
delete(key) {
|
|
79
|
+
const node = this.cache.get(key);
|
|
80
|
+
if (!node) {
|
|
81
|
+
return false;
|
|
82
|
+
}
|
|
83
|
+
this.removeNode(node);
|
|
84
|
+
this.cache.delete(key);
|
|
85
|
+
this.currentMemoryBytes -= node.size;
|
|
86
|
+
if (this.onEviction) {
|
|
87
|
+
this.onEviction(key, node.value);
|
|
88
|
+
}
|
|
89
|
+
return true;
|
|
90
|
+
}
|
|
91
|
+
/**
|
|
92
|
+
* Check if key exists in cache
|
|
93
|
+
*/
|
|
94
|
+
has(key) {
|
|
95
|
+
const node = this.cache.get(key);
|
|
96
|
+
if (!node) {
|
|
97
|
+
return false;
|
|
98
|
+
}
|
|
99
|
+
// Check TTL
|
|
100
|
+
if (this.ttlMs > 0 && Date.now() - node.timestamp > this.ttlMs) {
|
|
101
|
+
this.delete(key);
|
|
102
|
+
return false;
|
|
103
|
+
}
|
|
104
|
+
return true;
|
|
105
|
+
}
|
|
106
|
+
/**
|
|
107
|
+
* Clear all entries from cache
|
|
108
|
+
*/
|
|
109
|
+
clear() {
|
|
110
|
+
if (this.onEviction) {
|
|
111
|
+
for (const [key, node] of this.cache) {
|
|
112
|
+
this.onEviction(key, node.value);
|
|
113
|
+
}
|
|
114
|
+
}
|
|
115
|
+
this.cache.clear();
|
|
116
|
+
this.head = null;
|
|
117
|
+
this.tail = null;
|
|
118
|
+
this.currentMemoryBytes = 0;
|
|
119
|
+
this.evictionCount += this.cache.size;
|
|
120
|
+
}
|
|
121
|
+
/**
|
|
122
|
+
* Get cache statistics
|
|
123
|
+
*/
|
|
124
|
+
getStats() {
|
|
125
|
+
return {
|
|
126
|
+
size: this.cache.size,
|
|
127
|
+
maxSize: this.maxSize,
|
|
128
|
+
hitCount: this.hitCount,
|
|
129
|
+
missCount: this.missCount,
|
|
130
|
+
evictionCount: this.evictionCount,
|
|
131
|
+
memoryUsageMB: this.currentMemoryBytes / (1024 * 1024),
|
|
132
|
+
hitRate: this.hitCount + this.missCount > 0 ? this.hitCount / (this.hitCount + this.missCount) : 0
|
|
133
|
+
};
|
|
134
|
+
}
|
|
135
|
+
/**
|
|
136
|
+
* Get all keys in access order (most recent first)
|
|
137
|
+
*/
|
|
138
|
+
keys() {
|
|
139
|
+
const keys = [];
|
|
140
|
+
let current = this.head;
|
|
141
|
+
while (current) {
|
|
142
|
+
keys.push(current.key);
|
|
143
|
+
current = current.next;
|
|
144
|
+
}
|
|
145
|
+
return keys;
|
|
146
|
+
}
|
|
147
|
+
/**
|
|
148
|
+
* Get current memory usage in MB
|
|
149
|
+
*/
|
|
150
|
+
getMemoryUsageMB() {
|
|
151
|
+
return this.currentMemoryBytes / (1024 * 1024);
|
|
152
|
+
}
|
|
153
|
+
/**
|
|
154
|
+
* Manually trigger cleanup of expired entries
|
|
155
|
+
*/
|
|
156
|
+
cleanup() {
|
|
157
|
+
if (this.ttlMs <= 0) {
|
|
158
|
+
return 0;
|
|
159
|
+
}
|
|
160
|
+
const now = Date.now();
|
|
161
|
+
const keysToDelete = [];
|
|
162
|
+
for (const [key, node] of this.cache) {
|
|
163
|
+
if (now - node.timestamp > this.ttlMs) {
|
|
164
|
+
keysToDelete.push(key);
|
|
165
|
+
}
|
|
166
|
+
}
|
|
167
|
+
for (const key of keysToDelete) {
|
|
168
|
+
this.delete(key);
|
|
169
|
+
}
|
|
170
|
+
return keysToDelete.length;
|
|
171
|
+
}
|
|
172
|
+
// Private methods
|
|
173
|
+
moveToFront(node) {
|
|
174
|
+
if (node === this.head) {
|
|
175
|
+
return; // Already at front
|
|
176
|
+
}
|
|
177
|
+
// Remove from current position
|
|
178
|
+
this.removeNode(node);
|
|
179
|
+
// Add to front
|
|
180
|
+
this.addToFront(node);
|
|
181
|
+
}
|
|
182
|
+
addToFront(node) {
|
|
183
|
+
node.prev = null;
|
|
184
|
+
node.next = this.head;
|
|
185
|
+
if (this.head) {
|
|
186
|
+
this.head.prev = node;
|
|
187
|
+
}
|
|
188
|
+
this.head = node;
|
|
189
|
+
if (!this.tail) {
|
|
190
|
+
this.tail = node;
|
|
191
|
+
}
|
|
192
|
+
}
|
|
193
|
+
removeNode(node) {
|
|
194
|
+
if (node.prev) {
|
|
195
|
+
node.prev.next = node.next;
|
|
196
|
+
}
|
|
197
|
+
else {
|
|
198
|
+
this.head = node.next;
|
|
199
|
+
}
|
|
200
|
+
if (node.next) {
|
|
201
|
+
node.next.prev = node.prev;
|
|
202
|
+
}
|
|
203
|
+
else {
|
|
204
|
+
this.tail = node.prev;
|
|
205
|
+
}
|
|
206
|
+
}
|
|
207
|
+
evictIfNecessary() {
|
|
208
|
+
// Evict by size
|
|
209
|
+
while (this.cache.size > this.maxSize) {
|
|
210
|
+
this.evictLeastRecentlyUsed();
|
|
211
|
+
}
|
|
212
|
+
// Evict by memory
|
|
213
|
+
while (this.currentMemoryBytes > this.maxMemoryBytes && this.tail) {
|
|
214
|
+
this.evictLeastRecentlyUsed();
|
|
215
|
+
}
|
|
216
|
+
// Cleanup expired entries if TTL is enabled
|
|
217
|
+
if (this.ttlMs > 0 && Math.random() < 0.1) { // 10% chance to trigger cleanup
|
|
218
|
+
this.cleanup();
|
|
219
|
+
}
|
|
220
|
+
}
|
|
221
|
+
evictLeastRecentlyUsed() {
|
|
222
|
+
if (!this.tail) {
|
|
223
|
+
return;
|
|
224
|
+
}
|
|
225
|
+
const evicted = this.tail;
|
|
226
|
+
this.removeNode(evicted);
|
|
227
|
+
this.cache.delete(evicted.key);
|
|
228
|
+
this.currentMemoryBytes -= evicted.size;
|
|
229
|
+
this.evictionCount++;
|
|
230
|
+
if (this.onEviction) {
|
|
231
|
+
this.onEviction(evicted.key, evicted.value);
|
|
232
|
+
}
|
|
233
|
+
}
|
|
234
|
+
estimateSize(value) {
|
|
235
|
+
try {
|
|
236
|
+
// Simple estimation - can be improved with more sophisticated sizing
|
|
237
|
+
if (value === null || value === undefined) {
|
|
238
|
+
return 8; // Basic pointer size
|
|
239
|
+
}
|
|
240
|
+
if (typeof value === 'string') {
|
|
241
|
+
return value.length * 2; // UTF-16 characters
|
|
242
|
+
}
|
|
243
|
+
if (typeof value === 'number' || typeof value === 'boolean') {
|
|
244
|
+
return 8;
|
|
245
|
+
}
|
|
246
|
+
if (Array.isArray(value)) {
|
|
247
|
+
return value.reduce((acc, item) => acc + this.estimateSize(item), 32); // Array overhead
|
|
248
|
+
}
|
|
249
|
+
if (typeof value === 'object') {
|
|
250
|
+
// Rough estimation for objects
|
|
251
|
+
const jsonStr = JSON.stringify(value);
|
|
252
|
+
return jsonStr.length * 2 + 64; // String size + object overhead
|
|
253
|
+
}
|
|
254
|
+
return 64; // Default size for unknown types
|
|
255
|
+
}
|
|
256
|
+
catch {
|
|
257
|
+
return 64; // Fallback size
|
|
258
|
+
}
|
|
259
|
+
}
|
|
260
|
+
}
|
|
261
|
+
/**
|
|
262
|
+
* Factory for creating optimized LRU caches for different use cases
|
|
263
|
+
*/
|
|
264
|
+
export class CacheFactory {
|
|
265
|
+
/**
|
|
266
|
+
* Create cache optimized for search results
|
|
267
|
+
*/
|
|
268
|
+
static createSearchResultCache(options) {
|
|
269
|
+
return new LRUCache({
|
|
270
|
+
maxSize: 100,
|
|
271
|
+
maxMemoryMB: 10,
|
|
272
|
+
ttlMs: 5 * 60 * 1000, // 5 minutes
|
|
273
|
+
...options
|
|
274
|
+
});
|
|
275
|
+
}
|
|
276
|
+
/**
|
|
277
|
+
* Create cache optimized for index data
|
|
278
|
+
*/
|
|
279
|
+
static createIndexCache(options) {
|
|
280
|
+
return new LRUCache({
|
|
281
|
+
maxSize: 50,
|
|
282
|
+
maxMemoryMB: 25,
|
|
283
|
+
ttlMs: 15 * 60 * 1000, // 15 minutes
|
|
284
|
+
...options
|
|
285
|
+
});
|
|
286
|
+
}
|
|
287
|
+
/**
|
|
288
|
+
* Create cache optimized for API responses
|
|
289
|
+
*/
|
|
290
|
+
static createAPICache(options) {
|
|
291
|
+
return new LRUCache({
|
|
292
|
+
maxSize: 200,
|
|
293
|
+
maxMemoryMB: 5,
|
|
294
|
+
ttlMs: 10 * 60 * 1000, // 10 minutes
|
|
295
|
+
...options
|
|
296
|
+
});
|
|
297
|
+
}
|
|
298
|
+
}
|
|
299
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"LRUCache.js","sourceRoot":"","sources":["../../src/cache/LRUCache.ts"],"names":[],"mappings":"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","sourcesContent":["/**\n * High-performance LRU Cache with memory monitoring and automatic cleanup\n * Optimized for large-scale indexing operations with configurable memory limits\n */\n\nimport { logger } from '../utils/logger.js';\n\nexport interface LRUCacheOptions {\n  maxSize: number;\n  maxMemoryMB?: number;\n  ttlMs?: number;\n  onEviction?: (key: string, value: any) => void;\n}\n\nexport interface CacheStats {\n  size: number;\n  maxSize: number;\n  hitCount: number;\n  missCount: number;\n  evictionCount: number;\n  memoryUsageMB: number;\n  hitRate: number;\n}\n\ninterface CacheNode<T> {\n  key: string;\n  value: T;\n  prev: CacheNode<T> | null;\n  next: CacheNode<T> | null;\n  timestamp: number;\n  size: number; // Estimated size in bytes\n}\n\nexport class LRUCache<T> {\n  private readonly maxSize: number;\n  private readonly maxMemoryBytes: number;\n  private readonly ttlMs: number;\n  private readonly onEviction?: (key: string, value: T) => void;\n\n  private cache = new Map<string, CacheNode<T>>();\n  private head: CacheNode<T> | null = null;\n  private tail: CacheNode<T> | null = null;\n  private currentMemoryBytes = 0;\n\n  // Performance counters\n  private hitCount = 0;\n  private missCount = 0;\n  private evictionCount = 0;\n\n  constructor(options: LRUCacheOptions) {\n    this.maxSize = options.maxSize;\n    this.maxMemoryBytes = (options.maxMemoryMB || 50) * 1024 * 1024; // Convert MB to bytes\n    this.ttlMs = options.ttlMs || 0; // 0 means no TTL\n    this.onEviction = options.onEviction;\n  }\n\n  /**\n   * Get value from cache with automatic cleanup\n   */\n  get(key: string): T | null {\n    const node = this.cache.get(key);\n    \n    if (!node) {\n      this.missCount++;\n      return null;\n    }\n\n    // Check TTL if enabled\n    if (this.ttlMs > 0 && Date.now() - node.timestamp > this.ttlMs) {\n      this.delete(key);\n      this.missCount++;\n      return null;\n    }\n\n    // Move to front (most recently used)\n    this.moveToFront(node);\n    this.hitCount++;\n    return node.value;\n  }\n\n  /**\n   * Set value in cache with automatic eviction\n   */\n  set(key: string, value: T): void {\n    const existingNode = this.cache.get(key);\n    \n    if (existingNode) {\n      // Update existing node\n      const oldSize = existingNode.size;\n      existingNode.value = value;\n      existingNode.timestamp = Date.now();\n      existingNode.size = this.estimateSize(value);\n      \n      this.currentMemoryBytes += existingNode.size - oldSize;\n      this.moveToFront(existingNode);\n    } else {\n      // Create new node\n      const newNode: CacheNode<T> = {\n        key,\n        value,\n        prev: null,\n        next: null,\n        timestamp: Date.now(),\n        size: this.estimateSize(value)\n      };\n\n      this.cache.set(key, newNode);\n      this.currentMemoryBytes += newNode.size;\n      this.addToFront(newNode);\n    }\n\n    // Evict if necessary\n    this.evictIfNecessary();\n  }\n\n  /**\n   * Delete specific key from cache\n   */\n  delete(key: string): boolean {\n    const node = this.cache.get(key);\n    if (!node) {\n      return false;\n    }\n\n    this.removeNode(node);\n    this.cache.delete(key);\n    this.currentMemoryBytes -= node.size;\n\n    if (this.onEviction) {\n      this.onEviction(key, node.value);\n    }\n\n    return true;\n  }\n\n  /**\n   * Check if key exists in cache\n   */\n  has(key: string): boolean {\n    const node = this.cache.get(key);\n    if (!node) {\n      return false;\n    }\n\n    // Check TTL\n    if (this.ttlMs > 0 && Date.now() - node.timestamp > this.ttlMs) {\n      this.delete(key);\n      return false;\n    }\n\n    return true;\n  }\n\n  /**\n   * Clear all entries from cache\n   */\n  clear(): void {\n    if (this.onEviction) {\n      for (const [key, node] of this.cache) {\n        this.onEviction(key, node.value);\n      }\n    }\n\n    this.cache.clear();\n    this.head = null;\n    this.tail = null;\n    this.currentMemoryBytes = 0;\n    this.evictionCount += this.cache.size;\n  }\n\n  /**\n   * Get cache statistics\n   */\n  getStats(): CacheStats {\n    return {\n      size: this.cache.size,\n      maxSize: this.maxSize,\n      hitCount: this.hitCount,\n      missCount: this.missCount,\n      evictionCount: this.evictionCount,\n      memoryUsageMB: this.currentMemoryBytes / (1024 * 1024),\n      hitRate: this.hitCount + this.missCount > 0 ? this.hitCount / (this.hitCount + this.missCount) : 0\n    };\n  }\n\n  /**\n   * Get all keys in access order (most recent first)\n   */\n  keys(): string[] {\n    const keys: string[] = [];\n    let current = this.head;\n    \n    while (current) {\n      keys.push(current.key);\n      current = current.next;\n    }\n    \n    return keys;\n  }\n\n  /**\n   * Get current memory usage in MB\n   */\n  getMemoryUsageMB(): number {\n    return this.currentMemoryBytes / (1024 * 1024);\n  }\n\n  /**\n   * Manually trigger cleanup of expired entries\n   */\n  cleanup(): number {\n    if (this.ttlMs <= 0) {\n      return 0;\n    }\n\n    const now = Date.now();\n    const keysToDelete: string[] = [];\n\n    for (const [key, node] of this.cache) {\n      if (now - node.timestamp > this.ttlMs) {\n        keysToDelete.push(key);\n      }\n    }\n\n    for (const key of keysToDelete) {\n      this.delete(key);\n    }\n\n    return keysToDelete.length;\n  }\n\n  // Private methods\n\n  private moveToFront(node: CacheNode<T>): void {\n    if (node === this.head) {\n      return; // Already at front\n    }\n\n    // Remove from current position\n    this.removeNode(node);\n    \n    // Add to front\n    this.addToFront(node);\n  }\n\n  private addToFront(node: CacheNode<T>): void {\n    node.prev = null;\n    node.next = this.head;\n\n    if (this.head) {\n      this.head.prev = node;\n    }\n    \n    this.head = node;\n\n    if (!this.tail) {\n      this.tail = node;\n    }\n  }\n\n  private removeNode(node: CacheNode<T>): void {\n    if (node.prev) {\n      node.prev.next = node.next;\n    } else {\n      this.head = node.next;\n    }\n\n    if (node.next) {\n      node.next.prev = node.prev;\n    } else {\n      this.tail = node.prev;\n    }\n  }\n\n  private evictIfNecessary(): void {\n    // Evict by size\n    while (this.cache.size > this.maxSize) {\n      this.evictLeastRecentlyUsed();\n    }\n\n    // Evict by memory\n    while (this.currentMemoryBytes > this.maxMemoryBytes && this.tail) {\n      this.evictLeastRecentlyUsed();\n    }\n\n    // Cleanup expired entries if TTL is enabled\n    if (this.ttlMs > 0 && Math.random() < 0.1) { // 10% chance to trigger cleanup\n      this.cleanup();\n    }\n  }\n\n  private evictLeastRecentlyUsed(): void {\n    if (!this.tail) {\n      return;\n    }\n\n    const evicted = this.tail;\n    this.removeNode(evicted);\n    this.cache.delete(evicted.key);\n    this.currentMemoryBytes -= evicted.size;\n    this.evictionCount++;\n\n    if (this.onEviction) {\n      this.onEviction(evicted.key, evicted.value);\n    }\n  }\n\n  private estimateSize(value: T): number {\n    try {\n      // Simple estimation - can be improved with more sophisticated sizing\n      if (value === null || value === undefined) {\n        return 8; // Basic pointer size\n      }\n\n      if (typeof value === 'string') {\n        return value.length * 2; // UTF-16 characters\n      }\n\n      if (typeof value === 'number' || typeof value === 'boolean') {\n        return 8;\n      }\n\n      if (Array.isArray(value)) {\n        return value.reduce((acc, item) => acc + this.estimateSize(item), 32); // Array overhead\n      }\n\n      if (typeof value === 'object') {\n        // Rough estimation for objects\n        const jsonStr = JSON.stringify(value);\n        return jsonStr.length * 2 + 64; // String size + object overhead\n      }\n\n      return 64; // Default size for unknown types\n    } catch {\n      return 64; // Fallback size\n    }\n  }\n}\n\n/**\n * Factory for creating optimized LRU caches for different use cases\n */\nexport class CacheFactory {\n  /**\n   * Create cache optimized for search results\n   */\n  static createSearchResultCache<T>(options?: Partial<LRUCacheOptions>): LRUCache<T> {\n    return new LRUCache<T>({\n      maxSize: 100,\n      maxMemoryMB: 10,\n      ttlMs: 5 * 60 * 1000, // 5 minutes\n      ...options\n    });\n  }\n\n  /**\n   * Create cache optimized for index data\n   */\n  static createIndexCache<T>(options?: Partial<LRUCacheOptions>): LRUCache<T> {\n    return new LRUCache<T>({\n      maxSize: 50,\n      maxMemoryMB: 25,\n      ttlMs: 15 * 60 * 1000, // 15 minutes\n      ...options\n    });\n  }\n\n  /**\n   * Create cache optimized for API responses\n   */\n  static createAPICache<T>(options?: Partial<LRUCacheOptions>): LRUCache<T> {\n    return new LRUCache<T>({\n      maxSize: 200,\n      maxMemoryMB: 5,\n      ttlMs: 10 * 60 * 1000, // 10 minutes\n      ...options\n    });\n  }\n}"]}
|
package/dist/cache/index.d.ts
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../src/cache/index.ts"],"names":[],"mappings":"AAAA;;GAEG;AAEH,cAAc,eAAe,CAAC;AAC9B,cAAc,sBAAsB,CAAC"}
|
|
1
|
+
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../src/cache/index.ts"],"names":[],"mappings":"AAAA;;GAEG;AAEH,cAAc,eAAe,CAAC;AAC9B,cAAc,sBAAsB,CAAC;AACrC,cAAc,2BAA2B,CAAC"}
|
package/dist/cache/index.js
CHANGED
|
@@ -3,4 +3,5 @@
|
|
|
3
3
|
*/
|
|
4
4
|
export * from './APICache.js';
|
|
5
5
|
export * from './CollectionCache.js';
|
|
6
|
-
|
|
6
|
+
export * from './CollectionIndexCache.js';
|
|
7
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi9zcmMvY2FjaGUvaW5kZXgudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUE7O0dBRUc7QUFFSCxjQUFjLGVBQWUsQ0FBQztBQUM5QixjQUFjLHNCQUFzQixDQUFDO0FBQ3JDLGNBQWMsMkJBQTJCLENBQUMiLCJzb3VyY2VzQ29udGVudCI6WyIvKipcbiAqIENhY2hlIG1vZHVsZSBleHBvcnRzXG4gKi9cblxuZXhwb3J0ICogZnJvbSAnLi9BUElDYWNoZS5qcyc7XG5leHBvcnQgKiBmcm9tICcuL0NvbGxlY3Rpb25DYWNoZS5qcyc7XG5leHBvcnQgKiBmcm9tICcuL0NvbGxlY3Rpb25JbmRleENhY2hlLmpzJzsiXX0=
|
|
@@ -3,13 +3,16 @@
|
|
|
3
3
|
*/
|
|
4
4
|
import { GitHubClient } from './GitHubClient.js';
|
|
5
5
|
import { CollectionCache } from '../cache/CollectionCache.js';
|
|
6
|
+
import { CollectionIndexManager } from './CollectionIndexManager.js';
|
|
6
7
|
export declare class CollectionBrowser {
|
|
7
8
|
private githubClient;
|
|
8
9
|
private collectionCache;
|
|
10
|
+
private indexManager;
|
|
9
11
|
private baseUrl;
|
|
10
|
-
constructor(githubClient: GitHubClient, collectionCache?: CollectionCache);
|
|
12
|
+
constructor(githubClient: GitHubClient, collectionCache?: CollectionCache, indexManager?: CollectionIndexManager);
|
|
11
13
|
/**
|
|
12
14
|
* Browse collection content by section and type
|
|
15
|
+
* Uses CollectionIndexManager for fast browsing with background refresh
|
|
13
16
|
* Falls back to cached data when GitHub API is not available or not authenticated
|
|
14
17
|
* @param section - Top level section: library, showcase, or catalog
|
|
15
18
|
* @param type - Optional content type within the library section (personas, skills, etc.)
|
|
@@ -19,6 +22,23 @@ export declare class CollectionBrowser {
|
|
|
19
22
|
categories: any[];
|
|
20
23
|
sections?: any[];
|
|
21
24
|
}>;
|
|
25
|
+
/**
|
|
26
|
+
* Browse collection using the fast collection index
|
|
27
|
+
* Returns null if index is not available or browsing fails
|
|
28
|
+
*/
|
|
29
|
+
private browseFromIndex;
|
|
30
|
+
/**
|
|
31
|
+
* Get unique content types from collection index
|
|
32
|
+
*/
|
|
33
|
+
private getContentTypesFromIndex;
|
|
34
|
+
/**
|
|
35
|
+
* Get items from collection index by section and type
|
|
36
|
+
*/
|
|
37
|
+
private getItemsFromIndex;
|
|
38
|
+
/**
|
|
39
|
+
* Convert index entries to GitHub API format for compatibility
|
|
40
|
+
*/
|
|
41
|
+
private convertIndexItemsToGitHubFormat;
|
|
22
42
|
/**
|
|
23
43
|
* Browse collection from cached data
|
|
24
44
|
*/
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"CollectionBrowser.d.ts","sourceRoot":"","sources":["../../src/collection/CollectionBrowser.ts"],"names":[],"mappings":"AAAA;;GAEG;AAEH,OAAO,EAAE,YAAY,EAAE,MAAM,mBAAmB,CAAC;AACjD,OAAO,EAAE,eAAe,EAAkB,MAAM,6BAA6B,CAAC;
|
|
1
|
+
{"version":3,"file":"CollectionBrowser.d.ts","sourceRoot":"","sources":["../../src/collection/CollectionBrowser.ts"],"names":[],"mappings":"AAAA;;GAEG;AAEH,OAAO,EAAE,YAAY,EAAE,MAAM,mBAAmB,CAAC;AACjD,OAAO,EAAE,eAAe,EAAkB,MAAM,6BAA6B,CAAC;AAE9E,OAAO,EAAE,sBAAsB,EAAE,MAAM,6BAA6B,CAAC;AA+BrE,qBAAa,iBAAiB;IAC5B,OAAO,CAAC,YAAY,CAAe;IACnC,OAAO,CAAC,eAAe,CAAkB;IACzC,OAAO,CAAC,YAAY,CAAyB;IAC7C,OAAO,CAAC,OAAO,CAAmE;gBAEtE,YAAY,EAAE,YAAY,EAAE,eAAe,CAAC,EAAE,eAAe,EAAE,YAAY,CAAC,EAAE,sBAAsB;IAMhH;;;;;;OAMG;IACG,gBAAgB,CAAC,OAAO,CAAC,EAAE,MAAM,EAAE,IAAI,CAAC,EAAE,MAAM,GAAG,OAAO,CAAC;QAAE,KAAK,EAAE,GAAG,EAAE,CAAC;QAAC,UAAU,EAAE,GAAG,EAAE,CAAC;QAAC,QAAQ,CAAC,EAAE,GAAG,EAAE,CAAA;KAAE,CAAC;IA+DvH;;;OAGG;YACW,eAAe;IAiC7B;;OAEG;IACH,OAAO,CAAC,wBAAwB;IAiBhC;;OAEG;IACH,OAAO,CAAC,iBAAiB;IAiBzB;;OAEG;IACH,OAAO,CAAC,+BAA+B;IAWvC;;OAEG;YACW,eAAe;IAwC7B;;OAEG;IACH,OAAO,CAAC,kBAAkB;IAmB1B;;OAEG;IACH,OAAO,CAAC,wBAAwB;IAqBhC;;OAEG;IACH,OAAO,CAAC,oBAAoB;IAgB5B;;OAEG;IACH,OAAO,CAAC,+BAA+B;IAWvC;;OAEG;IACH,mBAAmB,CAAC,KAAK,EAAE,GAAG,EAAE,EAAE,UAAU,EAAE,GAAG,EAAE,EAAE,OAAO,CAAC,EAAE,MAAM,EAAE,IAAI,CAAC,EAAE,MAAM,EAAE,gBAAgB,GAAE,MAAW,GAAG,MAAM;CA6E7H"}
|