@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.
Files changed (272) hide show
  1. package/CHANGELOG.md +56 -0
  2. package/README.md +494 -111
  3. package/data/agents/code-reviewer.md +8 -1
  4. package/data/agents/research-assistant.md +8 -1
  5. package/data/agents/task-manager.md +8 -1
  6. package/data/ensembles/business-advisor.md +8 -1
  7. package/data/ensembles/creative-studio.md +8 -1
  8. package/data/ensembles/development-team.md +8 -1
  9. package/data/ensembles/security-analysis-team.md +8 -1
  10. package/data/memories/conversation-history.md +8 -1
  11. package/data/memories/learning-progress.md +8 -1
  12. package/data/memories/project-context.md +8 -1
  13. package/data/personas/business-consultant.md +8 -1
  14. package/data/personas/creative-writer.md +8 -1
  15. package/data/personas/debug-detective.md +8 -1
  16. package/data/personas/eli5-explainer.md +8 -1
  17. package/data/personas/security-analyst.md +8 -1
  18. package/data/personas/technical-analyst.md +8 -1
  19. package/data/skills/code-review.md +8 -1
  20. package/data/skills/creative-writing.md +8 -1
  21. package/data/skills/data-analysis.md +8 -1
  22. package/data/skills/penetration-testing.md +8 -1
  23. package/data/skills/research.md +8 -1
  24. package/data/skills/threat-modeling.md +8 -1
  25. package/data/skills/translation.md +8 -1
  26. package/data/templates/code-documentation.md +8 -1
  27. package/data/templates/email-professional.md +8 -1
  28. package/data/templates/meeting-notes.md +8 -1
  29. package/data/templates/penetration-test-report.md +8 -1
  30. package/data/templates/project-brief.md +8 -1
  31. package/data/templates/report-executive.md +8 -1
  32. package/data/templates/security-vulnerability-report.md +8 -1
  33. package/data/templates/threat-assessment-report.md +8 -1
  34. package/dist/auth/GitHubAuthManager.d.ts +6 -1
  35. package/dist/auth/GitHubAuthManager.d.ts.map +1 -1
  36. package/dist/auth/GitHubAuthManager.js +45 -18
  37. package/dist/benchmarks/IndexPerformanceBenchmark.d.ts +98 -0
  38. package/dist/benchmarks/IndexPerformanceBenchmark.d.ts.map +1 -0
  39. package/dist/benchmarks/IndexPerformanceBenchmark.js +531 -0
  40. package/dist/cache/CollectionCache.d.ts.map +1 -1
  41. package/dist/cache/CollectionCache.js +13 -3
  42. package/dist/cache/CollectionIndexCache.d.ts +77 -0
  43. package/dist/cache/CollectionIndexCache.d.ts.map +1 -0
  44. package/dist/cache/CollectionIndexCache.js +349 -0
  45. package/dist/cache/LRUCache.d.ts +93 -0
  46. package/dist/cache/LRUCache.d.ts.map +1 -0
  47. package/dist/cache/LRUCache.js +299 -0
  48. package/dist/cache/index.d.ts +1 -0
  49. package/dist/cache/index.d.ts.map +1 -1
  50. package/dist/cache/index.js +2 -1
  51. package/dist/collection/CollectionBrowser.d.ts +21 -1
  52. package/dist/collection/CollectionBrowser.d.ts.map +1 -1
  53. package/dist/collection/CollectionBrowser.js +130 -10
  54. package/dist/collection/CollectionIndexManager.d.ts +151 -0
  55. package/dist/collection/CollectionIndexManager.d.ts.map +1 -0
  56. package/dist/collection/CollectionIndexManager.js +499 -0
  57. package/dist/collection/CollectionSearch.d.ts +55 -0
  58. package/dist/collection/CollectionSearch.d.ts.map +1 -1
  59. package/dist/collection/CollectionSearch.js +338 -13
  60. package/dist/collection/CollectionSeeder.d.ts.map +1 -1
  61. package/dist/collection/CollectionSeeder.js +38 -1
  62. package/dist/collection/ElementInstaller.d.ts +31 -0
  63. package/dist/collection/ElementInstaller.d.ts.map +1 -1
  64. package/dist/collection/ElementInstaller.js +77 -15
  65. package/dist/collection/PersonaSubmitter.d.ts +1 -1
  66. package/dist/collection/PersonaSubmitter.d.ts.map +1 -1
  67. package/dist/collection/PersonaSubmitter.js +2 -2
  68. package/dist/collection/index.d.ts +1 -0
  69. package/dist/collection/index.d.ts.map +1 -1
  70. package/dist/collection/index.js +2 -1
  71. package/dist/config/ConfigManager.d.ts +78 -0
  72. package/dist/config/ConfigManager.d.ts.map +1 -0
  73. package/dist/config/ConfigManager.js +216 -0
  74. package/dist/config/element-types.d.ts +135 -0
  75. package/dist/config/element-types.d.ts.map +1 -0
  76. package/dist/config/element-types.js +108 -0
  77. package/dist/config/index.d.ts +2 -0
  78. package/dist/config/index.d.ts.map +1 -1
  79. package/dist/config/index.js +3 -1
  80. package/dist/config/portfolio-constants.d.ts +83 -0
  81. package/dist/config/portfolio-constants.d.ts.map +1 -0
  82. package/dist/config/portfolio-constants.js +99 -0
  83. package/dist/elements/BaseElement.d.ts +14 -2
  84. package/dist/elements/BaseElement.d.ts.map +1 -1
  85. package/dist/elements/BaseElement.js +88 -6
  86. package/dist/elements/agents/Agent.d.ts +10 -1
  87. package/dist/elements/agents/Agent.d.ts.map +1 -1
  88. package/dist/elements/agents/Agent.js +66 -19
  89. package/dist/elements/agents/AgentManager.d.ts +2 -0
  90. package/dist/elements/agents/AgentManager.d.ts.map +1 -1
  91. package/dist/elements/agents/AgentManager.js +12 -10
  92. package/dist/elements/skills/Skill.d.ts +10 -1
  93. package/dist/elements/skills/Skill.d.ts.map +1 -1
  94. package/dist/elements/skills/Skill.js +40 -3
  95. package/dist/elements/skills/SkillManager.d.ts +1 -0
  96. package/dist/elements/skills/SkillManager.d.ts.map +1 -1
  97. package/dist/elements/skills/SkillManager.js +10 -4
  98. package/dist/elements/templates/Template.d.ts +10 -1
  99. package/dist/elements/templates/Template.d.ts.map +1 -1
  100. package/dist/elements/templates/Template.js +35 -18
  101. package/dist/elements/templates/TemplateManager.d.ts +1 -1
  102. package/dist/elements/templates/TemplateManager.d.ts.map +1 -1
  103. package/dist/elements/templates/TemplateManager.js +6 -5
  104. package/dist/generated/version.d.ts +2 -2
  105. package/dist/generated/version.js +3 -3
  106. package/dist/index.barrel.d.ts +1 -2
  107. package/dist/index.barrel.d.ts.map +1 -1
  108. package/dist/index.barrel.js +2 -4
  109. package/dist/index.d.ts +143 -25
  110. package/dist/index.d.ts.map +1 -1
  111. package/dist/index.js +1883 -310
  112. package/dist/persona/PersonaElement.d.ts +10 -0
  113. package/dist/persona/PersonaElement.d.ts.map +1 -1
  114. package/dist/persona/PersonaElement.js +55 -32
  115. package/dist/persona/PersonaElementManager.d.ts.map +1 -1
  116. package/dist/persona/PersonaElementManager.js +13 -11
  117. package/dist/persona/PersonaLoader.d.ts.map +1 -1
  118. package/dist/persona/PersonaLoader.js +8 -2
  119. package/dist/persona/export-import/PersonaImporter.d.ts.map +1 -1
  120. package/dist/persona/export-import/PersonaImporter.js +24 -5
  121. package/dist/persona/export-import/PersonaSharer.d.ts +21 -0
  122. package/dist/persona/export-import/PersonaSharer.d.ts.map +1 -1
  123. package/dist/persona/export-import/PersonaSharer.js +198 -22
  124. package/dist/portfolio/DefaultElementProvider.d.ts +90 -0
  125. package/dist/portfolio/DefaultElementProvider.d.ts.map +1 -1
  126. package/dist/portfolio/DefaultElementProvider.js +499 -7
  127. package/dist/portfolio/GitHubPortfolioIndexer.d.ts +129 -0
  128. package/dist/portfolio/GitHubPortfolioIndexer.d.ts.map +1 -0
  129. package/dist/portfolio/GitHubPortfolioIndexer.js +475 -0
  130. package/dist/portfolio/MigrationManager.d.ts.map +1 -1
  131. package/dist/portfolio/MigrationManager.js +136 -3
  132. package/dist/portfolio/PortfolioIndexManager.d.ts +130 -0
  133. package/dist/portfolio/PortfolioIndexManager.d.ts.map +1 -0
  134. package/dist/portfolio/PortfolioIndexManager.js +478 -0
  135. package/dist/portfolio/PortfolioManager.d.ts +5 -0
  136. package/dist/portfolio/PortfolioManager.d.ts.map +1 -1
  137. package/dist/portfolio/PortfolioManager.js +61 -20
  138. package/dist/portfolio/PortfolioRepoManager.d.ts +75 -0
  139. package/dist/portfolio/PortfolioRepoManager.d.ts.map +1 -0
  140. package/dist/portfolio/PortfolioRepoManager.js +337 -0
  141. package/dist/portfolio/UnifiedIndexManager.d.ts +388 -0
  142. package/dist/portfolio/UnifiedIndexManager.d.ts.map +1 -0
  143. package/dist/portfolio/UnifiedIndexManager.js +1434 -0
  144. package/dist/portfolio/index.d.ts +15 -0
  145. package/dist/portfolio/index.d.ts.map +1 -0
  146. package/dist/portfolio/index.js +15 -0
  147. package/dist/portfolio/types.d.ts +7 -0
  148. package/dist/portfolio/types.d.ts.map +1 -1
  149. package/dist/portfolio/types.js +6 -1
  150. package/dist/security/InputValidator.d.ts.map +1 -1
  151. package/dist/security/InputValidator.js +50 -48
  152. package/dist/security/audit/SecurityAuditor.d.ts.map +1 -1
  153. package/dist/security/audit/SecurityAuditor.js +17 -9
  154. package/dist/security/audit/config/suppressions.d.ts.map +1 -1
  155. package/dist/security/audit/config/suppressions.js +19 -3
  156. package/dist/security/contentValidator.d.ts +2 -0
  157. package/dist/security/contentValidator.d.ts.map +1 -1
  158. package/dist/security/contentValidator.js +115 -4
  159. package/dist/security/secureYamlParser.d.ts +1 -0
  160. package/dist/security/secureYamlParser.d.ts.map +1 -1
  161. package/dist/security/secureYamlParser.js +29 -7
  162. package/dist/security/securityMonitor.d.ts +1 -1
  163. package/dist/security/securityMonitor.d.ts.map +1 -1
  164. package/dist/security/securityMonitor.js +1 -1
  165. package/dist/security/tokenManager.d.ts +1 -1
  166. package/dist/security/tokenManager.d.ts.map +1 -1
  167. package/dist/security/tokenManager.js +30 -10
  168. package/dist/server/ServerSetup.d.ts +22 -2
  169. package/dist/server/ServerSetup.d.ts.map +1 -1
  170. package/dist/server/ServerSetup.js +77 -12
  171. package/dist/server/tools/AuthTools.d.ts.map +1 -1
  172. package/dist/server/tools/AuthTools.js +33 -1
  173. package/dist/server/tools/BuildInfoTools.d.ts +25 -0
  174. package/dist/server/tools/BuildInfoTools.d.ts.map +1 -0
  175. package/dist/server/tools/BuildInfoTools.js +36 -0
  176. package/dist/server/tools/CollectionTools.d.ts.map +1 -1
  177. package/dist/server/tools/CollectionTools.js +55 -46
  178. package/dist/server/tools/ConfigTools.d.ts.map +1 -1
  179. package/dist/server/tools/ConfigTools.js +29 -1
  180. package/dist/server/tools/PersonaTools.d.ts +4 -2
  181. package/dist/server/tools/PersonaTools.d.ts.map +1 -1
  182. package/dist/server/tools/PersonaTools.js +5 -152
  183. package/dist/server/tools/PortfolioTools.d.ts +12 -0
  184. package/dist/server/tools/PortfolioTools.d.ts.map +1 -0
  185. package/dist/server/tools/PortfolioTools.js +221 -0
  186. package/dist/server/tools/index.d.ts +3 -1
  187. package/dist/server/tools/index.d.ts.map +1 -1
  188. package/dist/server/tools/index.js +4 -2
  189. package/dist/server/types.d.ts +40 -5
  190. package/dist/server/types.d.ts.map +1 -1
  191. package/dist/server/types.js +1 -1
  192. package/dist/services/BuildInfoService.d.ts +84 -0
  193. package/dist/services/BuildInfoService.d.ts.map +1 -0
  194. package/dist/services/BuildInfoService.js +271 -0
  195. package/dist/tools/portfolio/PortfolioElementAdapter.d.ts +54 -0
  196. package/dist/tools/portfolio/PortfolioElementAdapter.d.ts.map +1 -0
  197. package/dist/tools/portfolio/PortfolioElementAdapter.js +229 -0
  198. package/dist/tools/portfolio/submitToPortfolioTool.d.ts +164 -0
  199. package/dist/tools/portfolio/submitToPortfolioTool.d.ts.map +1 -0
  200. package/dist/tools/portfolio/submitToPortfolioTool.js +1523 -0
  201. package/dist/tools/portfolio/types.d.ts +41 -0
  202. package/dist/tools/portfolio/types.d.ts.map +1 -0
  203. package/dist/tools/portfolio/types.js +15 -0
  204. package/dist/types/collection.d.ts +51 -0
  205. package/dist/types/collection.d.ts.map +1 -1
  206. package/dist/types/collection.js +1 -1
  207. package/dist/utils/EarlyTerminationSearch.d.ts +41 -0
  208. package/dist/utils/EarlyTerminationSearch.d.ts.map +1 -0
  209. package/dist/utils/EarlyTerminationSearch.js +164 -0
  210. package/dist/utils/ErrorHandler.d.ts +86 -0
  211. package/dist/utils/ErrorHandler.d.ts.map +1 -0
  212. package/dist/utils/ErrorHandler.js +201 -0
  213. package/dist/utils/FileDiscoveryUtil.d.ts +53 -0
  214. package/dist/utils/FileDiscoveryUtil.d.ts.map +1 -0
  215. package/dist/utils/FileDiscoveryUtil.js +169 -0
  216. package/dist/utils/GitHubRateLimiter.d.ts +88 -0
  217. package/dist/utils/GitHubRateLimiter.d.ts.map +1 -0
  218. package/dist/utils/GitHubRateLimiter.js +315 -0
  219. package/dist/utils/PerformanceMonitor.d.ts +134 -0
  220. package/dist/utils/PerformanceMonitor.d.ts.map +1 -0
  221. package/dist/utils/PerformanceMonitor.js +347 -0
  222. package/dist/utils/RateLimiter.d.ts.map +1 -0
  223. package/dist/utils/RateLimiter.js +172 -0
  224. package/dist/utils/SecureDownloader.d.ts +241 -0
  225. package/dist/utils/SecureDownloader.d.ts.map +1 -0
  226. package/dist/utils/SecureDownloader.js +759 -0
  227. package/dist/utils/ToolCache.d.ts +82 -0
  228. package/dist/utils/ToolCache.d.ts.map +1 -0
  229. package/dist/utils/ToolCache.js +196 -0
  230. package/dist/utils/errorCodes.d.ts +136 -0
  231. package/dist/utils/errorCodes.d.ts.map +1 -0
  232. package/dist/utils/errorCodes.js +87 -0
  233. package/dist/utils/index.d.ts +3 -0
  234. package/dist/utils/index.d.ts.map +1 -1
  235. package/dist/utils/index.js +4 -1
  236. package/dist/utils/installation.d.ts +1 -1
  237. package/dist/utils/installation.d.ts.map +1 -1
  238. package/dist/utils/installation.js +9 -8
  239. package/dist/utils/searchUtils.d.ts +31 -0
  240. package/dist/utils/searchUtils.d.ts.map +1 -1
  241. package/dist/utils/searchUtils.js +62 -1
  242. package/package.json +17 -7
  243. package/dist/config/updateConfig.d.ts +0 -84
  244. package/dist/config/updateConfig.d.ts.map +0 -1
  245. package/dist/config/updateConfig.js +0 -148
  246. package/dist/server/tools/UpdateTools.d.ts +0 -10
  247. package/dist/server/tools/UpdateTools.d.ts.map +0 -1
  248. package/dist/server/tools/UpdateTools.js +0 -85
  249. package/dist/update/BackupManager.d.ts +0 -63
  250. package/dist/update/BackupManager.d.ts.map +0 -1
  251. package/dist/update/BackupManager.js +0 -370
  252. package/dist/update/DependencyChecker.d.ts +0 -41
  253. package/dist/update/DependencyChecker.d.ts.map +0 -1
  254. package/dist/update/DependencyChecker.js +0 -132
  255. package/dist/update/RateLimiter.d.ts.map +0 -1
  256. package/dist/update/RateLimiter.js +0 -172
  257. package/dist/update/SignatureVerifier.d.ts +0 -71
  258. package/dist/update/SignatureVerifier.d.ts.map +0 -1
  259. package/dist/update/SignatureVerifier.js +0 -214
  260. package/dist/update/UpdateChecker.d.ts +0 -132
  261. package/dist/update/UpdateChecker.d.ts.map +0 -1
  262. package/dist/update/UpdateChecker.js +0 -506
  263. package/dist/update/UpdateManager.d.ts +0 -60
  264. package/dist/update/UpdateManager.d.ts.map +0 -1
  265. package/dist/update/UpdateManager.js +0 -730
  266. package/dist/update/VersionManager.d.ts +0 -31
  267. package/dist/update/VersionManager.d.ts.map +0 -1
  268. package/dist/update/VersionManager.js +0 -181
  269. package/dist/update/index.d.ts +0 -9
  270. package/dist/update/index.d.ts.map +0 -1
  271. package/dist/update/index.js +0 -9
  272. /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}"]}
@@ -3,4 +3,5 @@
3
3
  */
4
4
  export * from './APICache.js';
5
5
  export * from './CollectionCache.js';
6
+ export * from './CollectionIndexCache.js';
6
7
  //# sourceMappingURL=index.d.ts.map
@@ -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"}
@@ -3,4 +3,5 @@
3
3
  */
4
4
  export * from './APICache.js';
5
5
  export * from './CollectionCache.js';
6
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi9zcmMvY2FjaGUvaW5kZXgudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUE7O0dBRUc7QUFFSCxjQUFjLGVBQWUsQ0FBQztBQUM5QixjQUFjLHNCQUFzQixDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiLyoqXG4gKiBDYWNoZSBtb2R1bGUgZXhwb3J0c1xuICovXG5cbmV4cG9ydCAqIGZyb20gJy4vQVBJQ2FjaGUuanMnO1xuZXhwb3J0ICogZnJvbSAnLi9Db2xsZWN0aW9uQ2FjaGUuanMnOyJdfQ==
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;AAI9E,qBAAa,iBAAiB;IAC5B,OAAO,CAAC,YAAY,CAAe;IACnC,OAAO,CAAC,eAAe,CAAkB;IACzC,OAAO,CAAC,OAAO,CAAmE;gBAEtE,YAAY,EAAE,YAAY,EAAE,eAAe,CAAC,EAAE,eAAe;IAKzE;;;;;OAKG;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;IAqDvH;;OAEG;YACW,eAAe;IAwC7B;;OAEG;IACH,OAAO,CAAC,kBAAkB;IAmB1B;;OAEG;IACH,OAAO,CAAC,wBAAwB;IAgBhC;;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;CAiF7H"}
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"}