@tonycasey/lisa 2.25.4 → 2.27.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/dist/lib/application/handlers/PromptSubmitHandler.d.ts.map +1 -1
- package/dist/lib/application/handlers/PromptSubmitHandler.js +2 -2
- package/dist/lib/application/handlers/PromptSubmitHandler.js.map +1 -1
- package/dist/lib/application/handlers/SessionStartHandler.d.ts +8 -24
- package/dist/lib/application/handlers/SessionStartHandler.d.ts.map +1 -1
- package/dist/lib/application/handlers/SessionStartHandler.js +43 -31
- package/dist/lib/application/handlers/SessionStartHandler.js.map +1 -1
- package/dist/lib/application/handlers/SessionStopHandler.d.ts.map +1 -1
- package/dist/lib/application/handlers/SessionStopHandler.js +2 -3
- package/dist/lib/application/handlers/SessionStopHandler.js.map +1 -1
- package/dist/lib/application/handlers/pr/PrPollHandler.d.ts +1 -2
- package/dist/lib/application/handlers/pr/PrPollHandler.d.ts.map +1 -1
- package/dist/lib/application/handlers/pr/PrPollHandler.js +3 -4
- package/dist/lib/application/handlers/pr/PrPollHandler.js.map +1 -1
- package/dist/lib/application/handlers/pr/PrRememberHandler.d.ts +1 -2
- package/dist/lib/application/handlers/pr/PrRememberHandler.d.ts.map +1 -1
- package/dist/lib/application/handlers/pr/PrRememberHandler.js +2 -3
- package/dist/lib/application/handlers/pr/PrRememberHandler.js.map +1 -1
- package/dist/lib/application/services/GitExtractorService.d.ts +22 -0
- package/dist/lib/application/services/GitExtractorService.d.ts.map +1 -0
- package/dist/lib/application/services/GitExtractorService.js +232 -0
- package/dist/lib/application/services/GitExtractorService.js.map +1 -0
- package/dist/lib/application/services/GitIndexingService.d.ts +25 -0
- package/dist/lib/application/services/GitIndexingService.d.ts.map +1 -0
- package/dist/lib/application/services/GitIndexingService.js +175 -0
- package/dist/lib/application/services/GitIndexingService.js.map +1 -0
- package/dist/lib/application/services/GitTriageService.d.ts +45 -0
- package/dist/lib/application/services/GitTriageService.d.ts.map +1 -0
- package/dist/lib/application/services/GitTriageService.js +360 -0
- package/dist/lib/application/services/GitTriageService.js.map +1 -0
- package/dist/lib/application/services/MemoryContextLoader.d.ts +7 -16
- package/dist/lib/application/services/MemoryContextLoader.d.ts.map +1 -1
- package/dist/lib/application/services/MemoryContextLoader.js +12 -75
- package/dist/lib/application/services/MemoryContextLoader.js.map +1 -1
- package/dist/lib/application/services/RepoProfileService.d.ts +37 -0
- package/dist/lib/application/services/RepoProfileService.d.ts.map +1 -0
- package/dist/lib/application/services/RepoProfileService.js +388 -0
- package/dist/lib/application/services/RepoProfileService.js.map +1 -0
- package/dist/lib/application/services/SessionContextFormatter.d.ts +11 -1
- package/dist/lib/application/services/SessionContextFormatter.d.ts.map +1 -1
- package/dist/lib/application/services/SessionContextFormatter.js +59 -3
- package/dist/lib/application/services/SessionContextFormatter.js.map +1 -1
- package/dist/lib/application/services/index.d.ts +2 -0
- package/dist/lib/application/services/index.d.ts.map +1 -1
- package/dist/lib/application/services/index.js +7 -1
- package/dist/lib/application/services/index.js.map +1 -1
- package/dist/lib/cli.d.ts +2 -2
- package/dist/lib/cli.d.ts.map +1 -1
- package/dist/lib/cli.js +4 -52
- package/dist/lib/cli.js.map +1 -1
- package/dist/lib/commands/doctor.d.ts +5 -12
- package/dist/lib/commands/doctor.d.ts.map +1 -1
- package/dist/lib/commands/doctor.js +60 -280
- package/dist/lib/commands/doctor.js.map +1 -1
- package/dist/lib/commands/index.d.ts +2 -3
- package/dist/lib/commands/index.d.ts.map +1 -1
- package/dist/lib/commands/index.js +2 -7
- package/dist/lib/commands/index.js.map +1 -1
- package/dist/lib/commands/init.d.ts +2 -8
- package/dist/lib/commands/init.d.ts.map +1 -1
- package/dist/lib/commands/init.js +13 -67
- package/dist/lib/commands/init.js.map +1 -1
- package/dist/lib/commands/knowledge.d.ts.map +1 -1
- package/dist/lib/commands/knowledge.js +1 -2
- package/dist/lib/commands/knowledge.js.map +1 -1
- package/dist/lib/commands/pr.d.ts.map +1 -1
- package/dist/lib/commands/pr.js +20 -21
- package/dist/lib/commands/pr.js.map +1 -1
- package/dist/lib/commands/shared/constants.d.ts +1 -15
- package/dist/lib/commands/shared/constants.d.ts.map +1 -1
- package/dist/lib/commands/shared/constants.js +2 -5
- package/dist/lib/commands/shared/constants.js.map +1 -1
- package/dist/lib/commands/shared/index.d.ts +1 -1
- package/dist/lib/commands/shared/index.d.ts.map +1 -1
- package/dist/lib/commands/shared/index.js +1 -3
- package/dist/lib/commands/shared/index.js.map +1 -1
- package/dist/lib/commands/skills.d.ts +1 -1
- package/dist/lib/commands/skills.js +5 -5
- package/dist/lib/commands/skills.js.map +1 -1
- package/dist/lib/domain/interfaces/ICommitEnricher.d.ts +81 -0
- package/dist/lib/domain/interfaces/ICommitEnricher.d.ts.map +1 -0
- package/dist/lib/domain/interfaces/ICommitEnricher.js +33 -0
- package/dist/lib/domain/interfaces/ICommitEnricher.js.map +1 -0
- package/dist/lib/domain/interfaces/IConsolidationService.d.ts +3 -2
- package/dist/lib/domain/interfaces/IConsolidationService.d.ts.map +1 -1
- package/dist/lib/domain/interfaces/ICurationService.d.ts +3 -2
- package/dist/lib/domain/interfaces/ICurationService.d.ts.map +1 -1
- package/dist/lib/domain/interfaces/IFileSystem.d.ts +28 -0
- package/dist/lib/domain/interfaces/IFileSystem.d.ts.map +1 -0
- package/dist/lib/domain/interfaces/IFileSystem.js +12 -0
- package/dist/lib/domain/interfaces/IFileSystem.js.map +1 -0
- package/dist/lib/domain/interfaces/IGitClient.d.ts +86 -0
- package/dist/lib/domain/interfaces/IGitClient.d.ts.map +1 -1
- package/dist/lib/domain/interfaces/IGitExtractor.d.ts +160 -0
- package/dist/lib/domain/interfaces/IGitExtractor.d.ts.map +1 -0
- package/dist/lib/domain/interfaces/IGitExtractor.js +37 -0
- package/dist/lib/domain/interfaces/IGitExtractor.js.map +1 -0
- package/dist/lib/domain/interfaces/IGitIndexingService.d.ts +69 -0
- package/dist/lib/domain/interfaces/IGitIndexingService.d.ts.map +1 -0
- package/dist/lib/domain/interfaces/IGitIndexingService.js +43 -0
- package/dist/lib/domain/interfaces/IGitIndexingService.js.map +1 -0
- package/dist/lib/domain/interfaces/IGitMemClient.d.ts +44 -0
- package/dist/lib/domain/interfaces/IGitMemClient.d.ts.map +1 -0
- package/dist/lib/domain/interfaces/IGitMemClient.js +9 -0
- package/dist/lib/domain/interfaces/IGitMemClient.js.map +1 -0
- package/dist/lib/domain/interfaces/IGitTriageService.d.ts +180 -0
- package/dist/lib/domain/interfaces/IGitTriageService.d.ts.map +1 -0
- package/dist/lib/domain/interfaces/IGitTriageService.js +12 -0
- package/dist/lib/domain/interfaces/IGitTriageService.js.map +1 -0
- package/dist/lib/domain/interfaces/ILisaServices.d.ts +0 -9
- package/dist/lib/domain/interfaces/ILisaServices.d.ts.map +1 -1
- package/dist/lib/domain/interfaces/IMemoryService.d.ts +14 -89
- package/dist/lib/domain/interfaces/IMemoryService.d.ts.map +1 -1
- package/dist/lib/domain/interfaces/INlCurationService.d.ts +4 -4
- package/dist/lib/domain/interfaces/INlCurationService.d.ts.map +1 -1
- package/dist/lib/domain/interfaces/IRecursionService.d.ts +3 -2
- package/dist/lib/domain/interfaces/IRecursionService.d.ts.map +1 -1
- package/dist/lib/domain/interfaces/IRepoProfileService.d.ts +132 -0
- package/dist/lib/domain/interfaces/IRepoProfileService.d.ts.map +1 -0
- package/dist/lib/domain/interfaces/IRepoProfileService.js +25 -0
- package/dist/lib/domain/interfaces/IRepoProfileService.js.map +1 -0
- package/dist/lib/domain/interfaces/ISummarizationService.d.ts +4 -3
- package/dist/lib/domain/interfaces/ISummarizationService.d.ts.map +1 -1
- package/dist/lib/domain/interfaces/ITaskService.d.ts +11 -16
- package/dist/lib/domain/interfaces/ITaskService.d.ts.map +1 -1
- package/dist/lib/domain/interfaces/dal/IMemoryRepository.d.ts +0 -1
- package/dist/lib/domain/interfaces/dal/IMemoryRepository.d.ts.map +1 -1
- package/dist/lib/domain/interfaces/dal/IRepositoryRouter.d.ts +1 -1
- package/dist/lib/domain/interfaces/dal/IRepositoryRouter.js +2 -2
- package/dist/lib/domain/interfaces/dal/IRepositoryRouter.js.map +1 -1
- package/dist/lib/domain/interfaces/events/IMemoryEvent.d.ts +6 -4
- package/dist/lib/domain/interfaces/events/IMemoryEvent.d.ts.map +1 -1
- package/dist/lib/domain/interfaces/events/IMemoryEvent.js +2 -4
- package/dist/lib/domain/interfaces/events/IMemoryEvent.js.map +1 -1
- package/dist/lib/domain/interfaces/index.d.ts +9 -3
- package/dist/lib/domain/interfaces/index.d.ts.map +1 -1
- package/dist/lib/domain/interfaces/index.js +13 -1
- package/dist/lib/domain/interfaces/index.js.map +1 -1
- package/dist/lib/infrastructure/adapters/claude/session-start.d.ts +1 -0
- package/dist/lib/infrastructure/adapters/claude/session-start.d.ts.map +1 -1
- package/dist/lib/infrastructure/adapters/claude/session-start.js +18 -4
- package/dist/lib/infrastructure/adapters/claude/session-start.js.map +1 -1
- package/dist/lib/infrastructure/adapters/gitmem/GitMemAdapter.d.ts +22 -0
- package/dist/lib/infrastructure/adapters/gitmem/GitMemAdapter.d.ts.map +1 -0
- package/dist/lib/infrastructure/adapters/gitmem/GitMemAdapter.js +88 -0
- package/dist/lib/infrastructure/adapters/gitmem/GitMemAdapter.js.map +1 -0
- package/dist/lib/infrastructure/adapters/gitmem/GitMemTaskAdapter.d.ts +19 -0
- package/dist/lib/infrastructure/adapters/gitmem/GitMemTaskAdapter.d.ts.map +1 -0
- package/dist/lib/infrastructure/adapters/gitmem/GitMemTaskAdapter.js +109 -0
- package/dist/lib/infrastructure/adapters/gitmem/GitMemTaskAdapter.js.map +1 -0
- package/dist/lib/infrastructure/adapters/gitmem/index.d.ts +3 -0
- package/dist/lib/infrastructure/adapters/gitmem/index.d.ts.map +1 -0
- package/dist/lib/infrastructure/adapters/gitmem/index.js +8 -0
- package/dist/lib/infrastructure/adapters/gitmem/index.js.map +1 -0
- package/dist/lib/infrastructure/dal/connections/index.d.ts +0 -4
- package/dist/lib/infrastructure/dal/connections/index.d.ts.map +1 -1
- package/dist/lib/infrastructure/dal/connections/index.js +2 -10
- package/dist/lib/infrastructure/dal/connections/index.js.map +1 -1
- package/dist/lib/infrastructure/dal/index.d.ts +4 -22
- package/dist/lib/infrastructure/dal/index.d.ts.map +1 -1
- package/dist/lib/infrastructure/dal/index.js +3 -37
- package/dist/lib/infrastructure/dal/index.js.map +1 -1
- package/dist/lib/infrastructure/dal/repositories/index.d.ts +1 -3
- package/dist/lib/infrastructure/dal/repositories/index.d.ts.map +1 -1
- package/dist/lib/infrastructure/dal/repositories/index.js +2 -12
- package/dist/lib/infrastructure/dal/repositories/index.js.map +1 -1
- package/dist/lib/infrastructure/dal/repositories/neo4j/index.d.ts +0 -2
- package/dist/lib/infrastructure/dal/repositories/neo4j/index.d.ts.map +1 -1
- package/dist/lib/infrastructure/dal/repositories/neo4j/index.js +2 -6
- package/dist/lib/infrastructure/dal/repositories/neo4j/index.js.map +1 -1
- package/dist/lib/infrastructure/di/ServiceFactory.d.ts +2 -9
- package/dist/lib/infrastructure/di/ServiceFactory.d.ts.map +1 -1
- package/dist/lib/infrastructure/di/bootstrap.d.ts +3 -1
- package/dist/lib/infrastructure/di/bootstrap.d.ts.map +1 -1
- package/dist/lib/infrastructure/di/bootstrap.js +29 -131
- package/dist/lib/infrastructure/di/bootstrap.js.map +1 -1
- package/dist/lib/infrastructure/di/tokens.d.ts +0 -20
- package/dist/lib/infrastructure/di/tokens.d.ts.map +1 -1
- package/dist/lib/infrastructure/di/tokens.js +0 -11
- package/dist/lib/infrastructure/di/tokens.js.map +1 -1
- package/dist/lib/infrastructure/git/GitClient.d.ts +11 -1
- package/dist/lib/infrastructure/git/GitClient.d.ts.map +1 -1
- package/dist/lib/infrastructure/git/GitClient.js +137 -0
- package/dist/lib/infrastructure/git/GitClient.js.map +1 -1
- package/dist/lib/infrastructure/git-mem/GitMemClient.d.ts +37 -0
- package/dist/lib/infrastructure/git-mem/GitMemClient.d.ts.map +1 -0
- package/dist/lib/infrastructure/git-mem/GitMemClient.js +151 -0
- package/dist/lib/infrastructure/git-mem/GitMemClient.js.map +1 -0
- package/dist/lib/infrastructure/git-mem/GitMemFactory.d.ts +36 -0
- package/dist/lib/infrastructure/git-mem/GitMemFactory.d.ts.map +1 -0
- package/dist/lib/infrastructure/git-mem/GitMemFactory.js +56 -0
- package/dist/lib/infrastructure/git-mem/GitMemFactory.js.map +1 -0
- package/dist/lib/infrastructure/git-mem/index.d.ts +7 -0
- package/dist/lib/infrastructure/git-mem/index.d.ts.map +1 -0
- package/dist/lib/infrastructure/git-mem/index.js +13 -0
- package/dist/lib/infrastructure/git-mem/index.js.map +1 -0
- package/dist/lib/infrastructure/git-mem/types.d.ts +90 -0
- package/dist/lib/infrastructure/git-mem/types.d.ts.map +1 -0
- package/dist/lib/infrastructure/git-mem/types.js +9 -0
- package/dist/lib/infrastructure/git-mem/types.js.map +1 -0
- package/dist/lib/infrastructure/github/GitHubDataFetcher.d.ts +21 -0
- package/dist/lib/infrastructure/github/GitHubDataFetcher.d.ts.map +1 -0
- package/dist/lib/infrastructure/github/GitHubDataFetcher.js +111 -0
- package/dist/lib/infrastructure/github/GitHubDataFetcher.js.map +1 -0
- package/dist/lib/infrastructure/index.d.ts +0 -1
- package/dist/lib/infrastructure/index.d.ts.map +1 -1
- package/dist/lib/infrastructure/index.js +1 -3
- package/dist/lib/infrastructure/index.js.map +1 -1
- package/dist/lib/infrastructure/logging/Logger.d.ts +13 -1
- package/dist/lib/infrastructure/logging/Logger.d.ts.map +1 -1
- package/dist/lib/infrastructure/logging/Logger.js +25 -7
- package/dist/lib/infrastructure/logging/Logger.js.map +1 -1
- package/dist/lib/infrastructure/logging/factory.d.ts +5 -1
- package/dist/lib/infrastructure/logging/factory.d.ts.map +1 -1
- package/dist/lib/infrastructure/logging/factory.js +3 -0
- package/dist/lib/infrastructure/logging/factory.js.map +1 -1
- package/dist/lib/infrastructure/logging/index.d.ts +1 -1
- package/dist/lib/infrastructure/logging/index.d.ts.map +1 -1
- package/dist/lib/infrastructure/logging/index.js.map +1 -1
- package/dist/lib/infrastructure/services/CommitEnricher.d.ts +26 -0
- package/dist/lib/infrastructure/services/CommitEnricher.d.ts.map +1 -0
- package/dist/lib/infrastructure/services/CommitEnricher.js +214 -0
- package/dist/lib/infrastructure/services/CommitEnricher.js.map +1 -0
- package/dist/lib/infrastructure/services/CurationService.d.ts.map +1 -1
- package/dist/lib/infrastructure/services/CurationService.js +4 -4
- package/dist/lib/infrastructure/services/CurationService.js.map +1 -1
- package/dist/lib/infrastructure/services/GitMemMemoryService.d.ts +24 -0
- package/dist/lib/infrastructure/services/GitMemMemoryService.d.ts.map +1 -0
- package/dist/lib/infrastructure/services/GitMemMemoryService.js +114 -0
- package/dist/lib/infrastructure/services/GitMemMemoryService.js.map +1 -0
- package/dist/lib/infrastructure/services/GitMemTaskService.d.ts +24 -0
- package/dist/lib/infrastructure/services/GitMemTaskService.d.ts.map +1 -0
- package/dist/lib/infrastructure/services/GitMemTaskService.js +142 -0
- package/dist/lib/infrastructure/services/GitMemTaskService.js.map +1 -0
- package/dist/lib/infrastructure/services/LlmGuard.d.ts.map +1 -1
- package/dist/lib/infrastructure/services/LlmGuard.js +44 -13
- package/dist/lib/infrastructure/services/LlmGuard.js.map +1 -1
- package/dist/lib/infrastructure/services/NlCurationService.d.ts.map +1 -1
- package/dist/lib/infrastructure/services/NlCurationService.js +12 -12
- package/dist/lib/infrastructure/services/NlCurationService.js.map +1 -1
- package/dist/lib/infrastructure/services/NodeFileSystem.d.ts +12 -0
- package/dist/lib/infrastructure/services/NodeFileSystem.d.ts.map +1 -0
- package/dist/lib/infrastructure/services/NodeFileSystem.js +40 -0
- package/dist/lib/infrastructure/services/NodeFileSystem.js.map +1 -0
- package/dist/lib/infrastructure/services/RecursionService.d.ts +1 -1
- package/dist/lib/infrastructure/services/RecursionService.d.ts.map +1 -1
- package/dist/lib/infrastructure/services/RecursionService.js +8 -8
- package/dist/lib/infrastructure/services/RecursionService.js.map +1 -1
- package/dist/lib/infrastructure/services/SkillMemoryService.d.ts +26 -0
- package/dist/lib/infrastructure/services/SkillMemoryService.d.ts.map +1 -0
- package/dist/lib/infrastructure/services/SkillMemoryService.js +317 -0
- package/dist/lib/infrastructure/services/SkillMemoryService.js.map +1 -0
- package/dist/lib/infrastructure/services/SkillPromptService.d.ts +16 -0
- package/dist/lib/infrastructure/services/SkillPromptService.d.ts.map +1 -0
- package/dist/lib/infrastructure/services/SkillPromptService.js +53 -0
- package/dist/lib/infrastructure/services/SkillPromptService.js.map +1 -0
- package/dist/lib/infrastructure/services/SkillTaskService.d.ts +32 -0
- package/dist/lib/infrastructure/services/SkillTaskService.d.ts.map +1 -0
- package/dist/lib/infrastructure/services/SkillTaskService.js +214 -0
- package/dist/lib/infrastructure/services/SkillTaskService.js.map +1 -0
- package/dist/lib/infrastructure/services/SummarizationService.d.ts.map +1 -1
- package/dist/lib/infrastructure/services/SummarizationService.js +3 -5
- package/dist/lib/infrastructure/services/SummarizationService.js.map +1 -1
- package/dist/lib/infrastructure/services/index.d.ts +7 -4
- package/dist/lib/infrastructure/services/index.d.ts.map +1 -1
- package/dist/lib/infrastructure/services/index.js +31 -13
- package/dist/lib/infrastructure/services/index.js.map +1 -1
- package/dist/lib/infrastructure/services/patterns/HeuristicPatterns.d.ts +72 -0
- package/dist/lib/infrastructure/services/patterns/HeuristicPatterns.d.ts.map +1 -0
- package/dist/lib/infrastructure/services/patterns/HeuristicPatterns.js +261 -0
- package/dist/lib/infrastructure/services/patterns/HeuristicPatterns.js.map +1 -0
- package/dist/lib/infrastructure/services/prompts/commit-extraction.d.ts +26 -0
- package/dist/lib/infrastructure/services/prompts/commit-extraction.d.ts.map +1 -0
- package/dist/lib/infrastructure/services/prompts/commit-extraction.js +151 -0
- package/dist/lib/infrastructure/services/prompts/commit-extraction.js.map +1 -0
- package/dist/lib/{skills/shared/services/interfaces/IMemoryService.d.ts → infrastructure/services/skill-interfaces/ISkillMemoryService.d.ts} +38 -47
- package/dist/lib/infrastructure/services/skill-interfaces/ISkillMemoryService.d.ts.map +1 -0
- package/dist/lib/{domain/interfaces/IMcpClient.js → infrastructure/services/skill-interfaces/ISkillMemoryService.js} +1 -1
- package/dist/lib/infrastructure/services/skill-interfaces/ISkillMemoryService.js.map +1 -0
- package/dist/lib/infrastructure/services/skill-interfaces/ISkillPromptService.d.ts +48 -0
- package/dist/lib/infrastructure/services/skill-interfaces/ISkillPromptService.d.ts.map +1 -0
- package/dist/lib/infrastructure/services/skill-interfaces/ISkillPromptService.js +10 -0
- package/dist/lib/infrastructure/services/skill-interfaces/ISkillPromptService.js.map +1 -0
- package/dist/lib/{skills/shared/services/interfaces/ITaskService.d.ts → infrastructure/services/skill-interfaces/ISkillTaskService.d.ts} +29 -27
- package/dist/lib/infrastructure/services/skill-interfaces/ISkillTaskService.d.ts.map +1 -0
- package/dist/lib/infrastructure/services/skill-interfaces/ISkillTaskService.js +13 -0
- package/dist/lib/infrastructure/services/skill-interfaces/ISkillTaskService.js.map +1 -0
- package/dist/lib/infrastructure/services/skill-interfaces/index.d.ts +16 -0
- package/dist/lib/infrastructure/services/skill-interfaces/index.d.ts.map +1 -0
- package/dist/lib/infrastructure/services/skill-interfaces/index.js +11 -0
- package/dist/lib/infrastructure/services/skill-interfaces/index.js.map +1 -0
- package/dist/lib/scanner/reviewer.js +2 -2
- package/dist/lib/scanner/reviewer.js.map +1 -1
- package/dist/lib/skills/github/bump-version.d.ts +14 -0
- package/dist/lib/skills/github/bump-version.d.ts.map +1 -0
- package/dist/lib/skills/{git → github}/bump-version.js +22 -1
- package/dist/lib/skills/github/bump-version.js.map +1 -0
- package/dist/lib/skills/github/github.d.ts +0 -1
- package/dist/lib/skills/github/github.d.ts.map +1 -1
- package/dist/lib/skills/github/github.js +15 -45
- package/dist/lib/skills/github/github.js.map +1 -1
- package/dist/lib/skills/memory/memory.js +5 -9
- package/dist/lib/skills/memory/memory.js.map +1 -1
- package/dist/lib/skills/prompt/prompt.d.ts +4 -1
- package/dist/lib/skills/prompt/prompt.d.ts.map +1 -1
- package/dist/lib/skills/prompt/prompt.js +10 -11
- package/dist/lib/skills/prompt/prompt.js.map +1 -1
- package/dist/lib/skills/{init-review → review}/ai-enrich.d.ts +3 -0
- package/dist/lib/skills/review/ai-enrich.d.ts.map +1 -0
- package/dist/lib/skills/{init-review → review}/ai-enrich.js +6 -6
- package/dist/lib/skills/review/ai-enrich.js.map +1 -0
- package/dist/lib/skills/review/init-review.d.ts.map +1 -0
- package/dist/lib/skills/review/init-review.js.map +1 -0
- package/dist/lib/skills/shared/clients/index.d.ts +4 -3
- package/dist/lib/skills/shared/clients/index.d.ts.map +1 -1
- package/dist/lib/skills/shared/clients/index.js +7 -10
- package/dist/lib/skills/shared/clients/index.js.map +1 -1
- package/dist/lib/skills/shared/clients/interfaces/index.d.ts +0 -3
- package/dist/lib/skills/shared/clients/interfaces/index.d.ts.map +1 -1
- package/dist/lib/skills/shared/clients/interfaces/index.js +0 -3
- package/dist/lib/skills/shared/clients/interfaces/index.js.map +1 -1
- package/dist/lib/skills/shared/index.d.ts +3 -2
- package/dist/lib/skills/shared/index.d.ts.map +1 -1
- package/dist/lib/skills/shared/index.js +3 -2
- package/dist/lib/skills/shared/index.js.map +1 -1
- package/dist/lib/skills/shared/services/GitHubSyncService.d.ts +4 -0
- package/dist/lib/skills/shared/services/GitHubSyncService.d.ts.map +1 -1
- package/dist/lib/skills/shared/services/GitHubSyncService.js +7 -7
- package/dist/lib/skills/shared/services/GitHubSyncService.js.map +1 -1
- package/dist/lib/skills/shared/services/MemoryCliService.d.ts +0 -2
- package/dist/lib/skills/shared/services/MemoryCliService.d.ts.map +1 -1
- package/dist/lib/skills/shared/services/MemoryCliService.js +11 -17
- package/dist/lib/skills/shared/services/MemoryCliService.js.map +1 -1
- package/dist/lib/skills/shared/services/StorageService.d.ts.map +1 -1
- package/dist/lib/skills/shared/services/StorageService.js +6 -2
- package/dist/lib/skills/shared/services/StorageService.js.map +1 -1
- package/dist/lib/skills/shared/services/TaskCliService.d.ts +3 -3
- package/dist/lib/skills/shared/services/TaskCliService.d.ts.map +1 -1
- package/dist/lib/skills/shared/services/TaskCliService.js +10 -14
- package/dist/lib/skills/shared/services/TaskCliService.js.map +1 -1
- package/dist/lib/skills/shared/services/index.d.ts +8 -4
- package/dist/lib/skills/shared/services/index.d.ts.map +1 -1
- package/dist/lib/skills/shared/services/index.js +15 -10
- package/dist/lib/skills/shared/services/index.js.map +1 -1
- package/dist/lib/skills/shared/services/interfaces/index.d.ts +4 -2
- package/dist/lib/skills/shared/services/interfaces/index.d.ts.map +1 -1
- package/dist/lib/skills/shared/services/interfaces/index.js +4 -2
- package/dist/lib/skills/shared/services/interfaces/index.js.map +1 -1
- package/dist/lib/skills/shared/utils/index.d.ts +0 -1
- package/dist/lib/skills/shared/utils/index.d.ts.map +1 -1
- package/dist/lib/skills/shared/utils/index.js +1 -9
- package/dist/lib/skills/shared/utils/index.js.map +1 -1
- package/dist/lib/skills/tasks/tasks.d.ts +9 -6
- package/dist/lib/skills/tasks/tasks.d.ts.map +1 -1
- package/dist/lib/skills/tasks/tasks.js +17 -17
- package/dist/lib/skills/tasks/tasks.js.map +1 -1
- package/dist/opencode/lisa.js +62391 -14984
- package/dist/package.json +5 -4
- package/dist/project/.lisa/.env.template +12 -9
- package/dist/project/.lisa/rules/shared/git-rules.md +13 -12
- package/dist/project/.lisa/skills/github/SKILL.md +121 -3
- package/dist/project/.lisa/skills/github/pr-description-template.txt +8 -0
- package/dist/project/.lisa/skills/pr/SKILL.md +1 -2
- package/dist/project/.lisa/skills/pr/pr-description-template.txt +8 -0
- package/dist/project/.lisa/skills/{init-review → review}/SKILL.md +9 -9
- package/package.json +5 -4
- package/dist/lib/commands/docker.d.ts +0 -20
- package/dist/lib/commands/docker.d.ts.map +0 -1
- package/dist/lib/commands/docker.js +0 -27
- package/dist/lib/commands/docker.js.map +0 -1
- package/dist/lib/domain/interfaces/IMcpClient.d.ts +0 -44
- package/dist/lib/domain/interfaces/IMcpClient.d.ts.map +0 -1
- package/dist/lib/domain/interfaces/IMcpClient.js.map +0 -1
- package/dist/lib/infrastructure/dal/RepositoryFactory.d.ts +0 -71
- package/dist/lib/infrastructure/dal/RepositoryFactory.d.ts.map +0 -1
- package/dist/lib/infrastructure/dal/RepositoryFactory.js +0 -134
- package/dist/lib/infrastructure/dal/RepositoryFactory.js.map +0 -1
- package/dist/lib/infrastructure/dal/connections/McpConnectionManager.d.ts +0 -56
- package/dist/lib/infrastructure/dal/connections/McpConnectionManager.d.ts.map +0 -1
- package/dist/lib/infrastructure/dal/connections/McpConnectionManager.js +0 -98
- package/dist/lib/infrastructure/dal/connections/McpConnectionManager.js.map +0 -1
- package/dist/lib/infrastructure/dal/connections/ZepConnectionManager.d.ts +0 -53
- package/dist/lib/infrastructure/dal/connections/ZepConnectionManager.d.ts.map +0 -1
- package/dist/lib/infrastructure/dal/connections/ZepConnectionManager.js +0 -168
- package/dist/lib/infrastructure/dal/connections/ZepConnectionManager.js.map +0 -1
- package/dist/lib/infrastructure/dal/repositories/mcp/McpMemoryRepository.d.ts +0 -64
- package/dist/lib/infrastructure/dal/repositories/mcp/McpMemoryRepository.d.ts.map +0 -1
- package/dist/lib/infrastructure/dal/repositories/mcp/McpMemoryRepository.js +0 -145
- package/dist/lib/infrastructure/dal/repositories/mcp/McpMemoryRepository.js.map +0 -1
- package/dist/lib/infrastructure/dal/repositories/mcp/McpTaskRepository.d.ts +0 -60
- package/dist/lib/infrastructure/dal/repositories/mcp/McpTaskRepository.d.ts.map +0 -1
- package/dist/lib/infrastructure/dal/repositories/mcp/McpTaskRepository.js +0 -186
- package/dist/lib/infrastructure/dal/repositories/mcp/McpTaskRepository.js.map +0 -1
- package/dist/lib/infrastructure/dal/repositories/mcp/index.d.ts +0 -6
- package/dist/lib/infrastructure/dal/repositories/mcp/index.d.ts.map +0 -1
- package/dist/lib/infrastructure/dal/repositories/mcp/index.js +0 -11
- package/dist/lib/infrastructure/dal/repositories/mcp/index.js.map +0 -1
- package/dist/lib/infrastructure/dal/repositories/neo4j/Neo4jMemoryRepository.d.ts +0 -69
- package/dist/lib/infrastructure/dal/repositories/neo4j/Neo4jMemoryRepository.d.ts.map +0 -1
- package/dist/lib/infrastructure/dal/repositories/neo4j/Neo4jMemoryRepository.js +0 -299
- package/dist/lib/infrastructure/dal/repositories/neo4j/Neo4jMemoryRepository.js.map +0 -1
- package/dist/lib/infrastructure/dal/repositories/neo4j/Neo4jTaskRepository.d.ts +0 -49
- package/dist/lib/infrastructure/dal/repositories/neo4j/Neo4jTaskRepository.d.ts.map +0 -1
- package/dist/lib/infrastructure/dal/repositories/neo4j/Neo4jTaskRepository.js +0 -193
- package/dist/lib/infrastructure/dal/repositories/neo4j/Neo4jTaskRepository.js.map +0 -1
- package/dist/lib/infrastructure/dal/repositories/zep/ZepMemoryRepository.d.ts +0 -55
- package/dist/lib/infrastructure/dal/repositories/zep/ZepMemoryRepository.d.ts.map +0 -1
- package/dist/lib/infrastructure/dal/repositories/zep/ZepMemoryRepository.js +0 -165
- package/dist/lib/infrastructure/dal/repositories/zep/ZepMemoryRepository.js.map +0 -1
- package/dist/lib/infrastructure/dal/repositories/zep/ZepTaskRepository.d.ts +0 -58
- package/dist/lib/infrastructure/dal/repositories/zep/ZepTaskRepository.d.ts.map +0 -1
- package/dist/lib/infrastructure/dal/repositories/zep/ZepTaskRepository.js +0 -210
- package/dist/lib/infrastructure/dal/repositories/zep/ZepTaskRepository.js.map +0 -1
- package/dist/lib/infrastructure/dal/repositories/zep/index.d.ts +0 -6
- package/dist/lib/infrastructure/dal/repositories/zep/index.d.ts.map +0 -1
- package/dist/lib/infrastructure/dal/repositories/zep/index.js +0 -11
- package/dist/lib/infrastructure/dal/repositories/zep/index.js.map +0 -1
- package/dist/lib/infrastructure/dal/routing/RepositoryRouter.d.ts +0 -73
- package/dist/lib/infrastructure/dal/routing/RepositoryRouter.d.ts.map +0 -1
- package/dist/lib/infrastructure/dal/routing/RepositoryRouter.js +0 -170
- package/dist/lib/infrastructure/dal/routing/RepositoryRouter.js.map +0 -1
- package/dist/lib/infrastructure/dal/routing/index.d.ts +0 -5
- package/dist/lib/infrastructure/dal/routing/index.d.ts.map +0 -1
- package/dist/lib/infrastructure/dal/routing/index.js +0 -10
- package/dist/lib/infrastructure/dal/routing/index.js.map +0 -1
- package/dist/lib/infrastructure/mcp/McpClient.d.ts +0 -71
- package/dist/lib/infrastructure/mcp/McpClient.d.ts.map +0 -1
- package/dist/lib/infrastructure/mcp/McpClient.js +0 -221
- package/dist/lib/infrastructure/mcp/McpClient.js.map +0 -1
- package/dist/lib/infrastructure/mcp/index.d.ts +0 -5
- package/dist/lib/infrastructure/mcp/index.d.ts.map +0 -1
- package/dist/lib/infrastructure/mcp/index.js +0 -9
- package/dist/lib/infrastructure/mcp/index.js.map +0 -1
- package/dist/lib/infrastructure/services/ConsolidationService.d.ts +0 -21
- package/dist/lib/infrastructure/services/ConsolidationService.d.ts.map +0 -1
- package/dist/lib/infrastructure/services/ConsolidationService.js +0 -134
- package/dist/lib/infrastructure/services/ConsolidationService.js.map +0 -1
- package/dist/lib/infrastructure/services/DeduplicationService.d.ts +0 -21
- package/dist/lib/infrastructure/services/DeduplicationService.d.ts.map +0 -1
- package/dist/lib/infrastructure/services/DeduplicationService.js +0 -111
- package/dist/lib/infrastructure/services/DeduplicationService.js.map +0 -1
- package/dist/lib/infrastructure/services/MemoryService.d.ts +0 -96
- package/dist/lib/infrastructure/services/MemoryService.d.ts.map +0 -1
- package/dist/lib/infrastructure/services/MemoryService.js +0 -486
- package/dist/lib/infrastructure/services/MemoryService.js.map +0 -1
- package/dist/lib/infrastructure/services/TaskService.d.ts +0 -38
- package/dist/lib/infrastructure/services/TaskService.d.ts.map +0 -1
- package/dist/lib/infrastructure/services/TaskService.js +0 -227
- package/dist/lib/infrastructure/services/TaskService.js.map +0 -1
- package/dist/lib/skills/common/group-id.d.ts +0 -49
- package/dist/lib/skills/common/group-id.d.ts.map +0 -1
- package/dist/lib/skills/common/group-id.js +0 -194
- package/dist/lib/skills/common/group-id.js.map +0 -1
- package/dist/lib/skills/git/bump-version.d.ts +0 -9
- package/dist/lib/skills/git/bump-version.d.ts.map +0 -1
- package/dist/lib/skills/git/bump-version.js.map +0 -1
- package/dist/lib/skills/init-review/ai-enrich.d.ts.map +0 -1
- package/dist/lib/skills/init-review/ai-enrich.js.map +0 -1
- package/dist/lib/skills/init-review/init-review.d.ts.map +0 -1
- package/dist/lib/skills/init-review/init-review.js.map +0 -1
- package/dist/lib/skills/shared/clients/McpClient.d.ts +0 -26
- package/dist/lib/skills/shared/clients/McpClient.d.ts.map +0 -1
- package/dist/lib/skills/shared/clients/McpClient.js +0 -162
- package/dist/lib/skills/shared/clients/McpClient.js.map +0 -1
- package/dist/lib/skills/shared/clients/Neo4jClient.d.ts +0 -15
- package/dist/lib/skills/shared/clients/Neo4jClient.d.ts.map +0 -1
- package/dist/lib/skills/shared/clients/Neo4jClient.js +0 -139
- package/dist/lib/skills/shared/clients/Neo4jClient.js.map +0 -1
- package/dist/lib/skills/shared/clients/ZepClient.d.ts +0 -14
- package/dist/lib/skills/shared/clients/ZepClient.d.ts.map +0 -1
- package/dist/lib/skills/shared/clients/ZepClient.js +0 -238
- package/dist/lib/skills/shared/clients/ZepClient.js.map +0 -1
- package/dist/lib/skills/shared/clients/interfaces/IMcpClient.d.ts +0 -56
- package/dist/lib/skills/shared/clients/interfaces/IMcpClient.d.ts.map +0 -1
- package/dist/lib/skills/shared/clients/interfaces/IMcpClient.js +0 -3
- package/dist/lib/skills/shared/clients/interfaces/IMcpClient.js.map +0 -1
- package/dist/lib/skills/shared/clients/interfaces/INeo4jClient.d.ts +0 -59
- package/dist/lib/skills/shared/clients/interfaces/INeo4jClient.d.ts.map +0 -1
- package/dist/lib/skills/shared/clients/interfaces/INeo4jClient.js +0 -3
- package/dist/lib/skills/shared/clients/interfaces/INeo4jClient.js.map +0 -1
- package/dist/lib/skills/shared/clients/interfaces/IZepClient.d.ts +0 -152
- package/dist/lib/skills/shared/clients/interfaces/IZepClient.d.ts.map +0 -1
- package/dist/lib/skills/shared/clients/interfaces/IZepClient.js +0 -3
- package/dist/lib/skills/shared/clients/interfaces/IZepClient.js.map +0 -1
- package/dist/lib/skills/shared/group-id.d.ts +0 -2
- package/dist/lib/skills/shared/group-id.d.ts.map +0 -1
- package/dist/lib/skills/shared/group-id.js +0 -18
- package/dist/lib/skills/shared/group-id.js.map +0 -1
- package/dist/lib/skills/shared/services/MemoryService.d.ts +0 -24
- package/dist/lib/skills/shared/services/MemoryService.d.ts.map +0 -1
- package/dist/lib/skills/shared/services/MemoryService.js +0 -574
- package/dist/lib/skills/shared/services/MemoryService.js.map +0 -1
- package/dist/lib/skills/shared/services/PromptService.d.ts +0 -28
- package/dist/lib/skills/shared/services/PromptService.d.ts.map +0 -1
- package/dist/lib/skills/shared/services/PromptService.js +0 -53
- package/dist/lib/skills/shared/services/PromptService.js.map +0 -1
- package/dist/lib/skills/shared/services/TaskService.d.ts +0 -24
- package/dist/lib/skills/shared/services/TaskService.d.ts.map +0 -1
- package/dist/lib/skills/shared/services/TaskService.js +0 -388
- package/dist/lib/skills/shared/services/TaskService.js.map +0 -1
- package/dist/lib/skills/shared/services/interfaces/IMemoryService.d.ts.map +0 -1
- package/dist/lib/skills/shared/services/interfaces/IMemoryService.js +0 -3
- package/dist/lib/skills/shared/services/interfaces/IMemoryService.js.map +0 -1
- package/dist/lib/skills/shared/services/interfaces/ITaskService.d.ts.map +0 -1
- package/dist/lib/skills/shared/services/interfaces/ITaskService.js +0 -7
- package/dist/lib/skills/shared/services/interfaces/ITaskService.js.map +0 -1
- package/dist/lib/skills/shared/utils/group-id.d.ts +0 -64
- package/dist/lib/skills/shared/utils/group-id.d.ts.map +0 -1
- package/dist/lib/skills/shared/utils/group-id.js +0 -176
- package/dist/lib/skills/shared/utils/group-id.js.map +0 -1
- package/dist/project/.lisa/docker/docker-compose.graphiti.yml +0 -45
- package/dist/project/.lisa/skills/git/SKILL.md +0 -171
- /package/dist/lib/skills/{init-review → review}/init-review.d.ts +0 -0
- /package/dist/lib/skills/{init-review → review}/init-review.js +0 -0
|
@@ -3,10 +3,20 @@ import type { ILogger, ILoggerOptions, LogLevel, IStructuredLog, IStructuredLogg
|
|
|
3
3
|
* Default logger configuration.
|
|
4
4
|
*/
|
|
5
5
|
export declare const DEFAULT_LOGGER_OPTIONS: ILoggerOptions;
|
|
6
|
+
/**
|
|
7
|
+
* Extended logger options with async support.
|
|
8
|
+
*/
|
|
9
|
+
export interface ILoggerOptionsExtended extends ILoggerOptions {
|
|
10
|
+
/** Use async file writes (fire-and-forget, non-blocking). Default: false. */
|
|
11
|
+
asyncWrites?: boolean;
|
|
12
|
+
}
|
|
6
13
|
/**
|
|
7
14
|
* Simple file-based logger implementation.
|
|
8
15
|
* Writes single-line formatted logs with optional colorized console output.
|
|
9
16
|
* Also implements IStructuredLogger for standardized event logging.
|
|
17
|
+
*
|
|
18
|
+
* Supports async (non-blocking) file writes for performance-sensitive contexts
|
|
19
|
+
* like Claude Code hooks where latency matters.
|
|
10
20
|
*/
|
|
11
21
|
export declare class Logger implements ILogger, IStructuredLogger {
|
|
12
22
|
private readonly options;
|
|
@@ -14,7 +24,8 @@ export declare class Logger implements ILogger, IStructuredLogger {
|
|
|
14
24
|
private readonly logFile;
|
|
15
25
|
private readonly bindings;
|
|
16
26
|
private readonly boundContext;
|
|
17
|
-
|
|
27
|
+
private readonly asyncWrites;
|
|
28
|
+
constructor(options: ILoggerOptionsExtended, _pinoInstance?: unknown, // Kept for API compatibility
|
|
18
29
|
getCorrelationId?: () => string | undefined, bindings?: Record<string, unknown>, boundContext?: ILogContext);
|
|
19
30
|
/**
|
|
20
31
|
* Ensure log directory exists.
|
|
@@ -30,6 +41,7 @@ export declare class Logger implements ILogger, IStructuredLogger {
|
|
|
30
41
|
private formatContext;
|
|
31
42
|
/**
|
|
32
43
|
* Write a log entry.
|
|
44
|
+
* Uses async (fire-and-forget) writes when asyncWrites is enabled.
|
|
33
45
|
*/
|
|
34
46
|
private writeLog;
|
|
35
47
|
trace(message: string, context?: Record<string, unknown>): void;
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"Logger.d.ts","sourceRoot":"","sources":["../../../../src/lib/infrastructure/logging/Logger.ts"],"names":[],"mappings":"AAEA,OAAO,KAAK,EACV,OAAO,EACP,cAAc,EACd,QAAQ,EACR,cAAc,EACd,iBAAiB,EACjB,WAAW,EACX,QAAQ,EACT,MAAM,yBAAyB,CAAC;AAGjC;;GAEG;AACH,eAAO,MAAM,sBAAsB,EAAE,cAMpC,CAAC;
|
|
1
|
+
{"version":3,"file":"Logger.d.ts","sourceRoot":"","sources":["../../../../src/lib/infrastructure/logging/Logger.ts"],"names":[],"mappings":"AAEA,OAAO,KAAK,EACV,OAAO,EACP,cAAc,EACd,QAAQ,EACR,cAAc,EACd,iBAAiB,EACjB,WAAW,EACX,QAAQ,EACT,MAAM,yBAAyB,CAAC;AAGjC;;GAEG;AACH,eAAO,MAAM,sBAAsB,EAAE,cAMpC,CAAC;AAEF;;GAEG;AACH,MAAM,WAAW,sBAAuB,SAAQ,cAAc;IAC5D,6EAA6E;IAC7E,WAAW,CAAC,EAAE,OAAO,CAAC;CACvB;AA4DD;;;;;;;GAOG;AACH,qBAAa,MAAO,YAAW,OAAO,EAAE,iBAAiB;IACvD,OAAO,CAAC,QAAQ,CAAC,OAAO,CAAyB;IACjD,OAAO,CAAC,QAAQ,CAAC,gBAAgB,CAA2B;IAC5D,OAAO,CAAC,QAAQ,CAAC,OAAO,CAAS;IACjC,OAAO,CAAC,QAAQ,CAAC,QAAQ,CAA0B;IACnD,OAAO,CAAC,QAAQ,CAAC,YAAY,CAAc;IAC3C,OAAO,CAAC,QAAQ,CAAC,WAAW,CAAU;gBAGpC,OAAO,EAAE,sBAAsB,EAC/B,aAAa,CAAC,EAAE,OAAO,EAAE,6BAA6B;IACtD,gBAAgB,CAAC,EAAE,MAAM,MAAM,GAAG,SAAS,EAC3C,QAAQ,CAAC,EAAE,MAAM,CAAC,MAAM,EAAE,OAAO,CAAC,EAClC,YAAY,CAAC,EAAE,WAAW;IAc5B;;OAEG;IACH,OAAO,CAAC,YAAY;IAUpB;;OAEG;IACH,OAAO,CAAC,SAAS;IAIjB;;OAEG;IACH,OAAO,CAAC,aAAa;IAUrB;;;OAGG;IACH,OAAO,CAAC,QAAQ;IAwChB,KAAK,CAAC,OAAO,EAAE,MAAM,EAAE,OAAO,CAAC,EAAE,MAAM,CAAC,MAAM,EAAE,OAAO,CAAC,GAAG,IAAI;IAI/D,KAAK,CAAC,OAAO,EAAE,MAAM,EAAE,OAAO,CAAC,EAAE,MAAM,CAAC,MAAM,EAAE,OAAO,CAAC,GAAG,IAAI;IAI/D,IAAI,CAAC,OAAO,EAAE,MAAM,EAAE,OAAO,CAAC,EAAE,MAAM,CAAC,MAAM,EAAE,OAAO,CAAC,GAAG,IAAI;IAI9D,IAAI,CAAC,OAAO,EAAE,MAAM,EAAE,OAAO,CAAC,EAAE,MAAM,CAAC,MAAM,EAAE,OAAO,CAAC,GAAG,IAAI;IAI9D,KAAK,CAAC,OAAO,EAAE,MAAM,EAAE,OAAO,CAAC,EAAE,MAAM,CAAC,MAAM,EAAE,OAAO,CAAC,GAAG,IAAI;IAI/D,KAAK,CAAC,OAAO,EAAE,MAAM,EAAE,OAAO,CAAC,EAAE,MAAM,CAAC,MAAM,EAAE,OAAO,CAAC,GAAG,IAAI;IAI/D,KAAK,CAAC,QAAQ,EAAE,MAAM,CAAC,MAAM,EAAE,OAAO,CAAC,GAAG,OAAO;IAcjD;;;;;;;OAOG;IACH,OAAO,CAAC,mBAAmB;IA0B3B;;OAEG;IACH,QAAQ,CAAC,GAAG,EAAE,cAAc,GAAG,IAAI;IAKnC;;OAEG;IACH,aAAa,CAAC,GAAG,EAAE,cAAc,GAAG,IAAI;IAKxC;;OAEG;IACH,YAAY,CAAC,GAAG,EAAE,cAAc,GAAG,IAAI;IAKvC;;OAEG;IACH,aAAa,CAAC,GAAG,EAAE,cAAc,GAAG,IAAI;IAKxC;;OAEG;IACH,WAAW,CAAC,OAAO,EAAE,WAAW,GAAG,iBAAiB;IAUpD;;OAEG;IACH,cAAc,CACZ,KAAK,EAAE,QAAQ,GAAG,MAAM,EACxB,OAAO,CAAC,EAAE,WAAW,GACpB,CAAC,MAAM,CAAC,EAAE;QAAE,IAAI,CAAC,EAAE,MAAM,CAAC,MAAM,EAAE,OAAO,CAAC,CAAC;QAAC,KAAK,CAAC,EAAE,MAAM,CAAA;KAAE,KAAK,IAAI;IAoCxE,cAAc,CAAC,KAAK,EAAE,QAAQ,GAAG,OAAO;CAGzC;AAED;;GAEG;AACH,qBAAa,UAAW,YAAW,OAAO,EAAE,iBAAiB;IAC3D,KAAK,CAAC,QAAQ,EAAE,MAAM,EAAE,QAAQ,CAAC,EAAE,MAAM,CAAC,MAAM,EAAE,OAAO,CAAC,GAAG,IAAI;IAIjE,KAAK,CAAC,QAAQ,EAAE,MAAM,EAAE,QAAQ,CAAC,EAAE,MAAM,CAAC,MAAM,EAAE,OAAO,CAAC,GAAG,IAAI;IAIjE,IAAI,CAAC,QAAQ,EAAE,MAAM,EAAE,QAAQ,CAAC,EAAE,MAAM,CAAC,MAAM,EAAE,OAAO,CAAC,GAAG,IAAI;IAIhE,IAAI,CAAC,QAAQ,EAAE,MAAM,EAAE,QAAQ,CAAC,EAAE,MAAM,CAAC,MAAM,EAAE,OAAO,CAAC,GAAG,IAAI;IAIhE,KAAK,CAAC,QAAQ,EAAE,MAAM,EAAE,QAAQ,CAAC,EAAE,MAAM,CAAC,MAAM,EAAE,OAAO,CAAC,GAAG,IAAI;IAIjE,KAAK,CAAC,QAAQ,EAAE,MAAM,EAAE,QAAQ,CAAC,EAAE,MAAM,CAAC,MAAM,EAAE,OAAO,CAAC,GAAG,IAAI;IAIjE,KAAK,CAAC,SAAS,EAAE,MAAM,CAAC,MAAM,EAAE,OAAO,CAAC,GAAG,OAAO;IAIlD,cAAc,CAAC,MAAM,EAAE,QAAQ,GAAG,OAAO;IAKzC,QAAQ,CAAC,IAAI,EAAE,cAAc,GAAG,IAAI;IAIpC,aAAa,CAAC,IAAI,EAAE,cAAc,GAAG,IAAI;IAIzC,YAAY,CAAC,IAAI,EAAE,cAAc,GAAG,IAAI;IAIxC,aAAa,CAAC,IAAI,EAAE,cAAc,GAAG,IAAI;IAIzC,WAAW,CAAC,QAAQ,EAAE,WAAW,GAAG,iBAAiB;IAIrD,cAAc,CACZ,MAAM,EAAE,QAAQ,GAAG,MAAM,EACzB,QAAQ,CAAC,EAAE,WAAW,GACrB,CAAC,MAAM,CAAC,EAAE;QAAE,IAAI,CAAC,EAAE,MAAM,CAAC,MAAM,EAAE,OAAO,CAAC,CAAC;QAAC,KAAK,CAAC,EAAE,MAAM,CAAA;KAAE,KAAK,IAAI;CAKzE"}
|
|
@@ -74,6 +74,9 @@ function getDateString() {
|
|
|
74
74
|
* Simple file-based logger implementation.
|
|
75
75
|
* Writes single-line formatted logs with optional colorized console output.
|
|
76
76
|
* Also implements IStructuredLogger for standardized event logging.
|
|
77
|
+
*
|
|
78
|
+
* Supports async (non-blocking) file writes for performance-sensitive contexts
|
|
79
|
+
* like Claude Code hooks where latency matters.
|
|
77
80
|
*/
|
|
78
81
|
class Logger {
|
|
79
82
|
constructor(options, _pinoInstance, // Kept for API compatibility
|
|
@@ -82,6 +85,7 @@ class Logger {
|
|
|
82
85
|
this.getCorrelationId = getCorrelationId ?? (() => undefined);
|
|
83
86
|
this.bindings = bindings ?? {};
|
|
84
87
|
this.boundContext = boundContext ?? {};
|
|
88
|
+
this.asyncWrites = options.asyncWrites ?? false;
|
|
85
89
|
// Ensure log directory exists
|
|
86
90
|
const logDir = path_1.default.resolve(options.logDir);
|
|
87
91
|
this.ensureLogDir(logDir);
|
|
@@ -121,6 +125,7 @@ class Logger {
|
|
|
121
125
|
}
|
|
122
126
|
/**
|
|
123
127
|
* Write a log entry.
|
|
128
|
+
* Uses async (fire-and-forget) writes when asyncWrites is enabled.
|
|
124
129
|
*/
|
|
125
130
|
writeLog(level, levelStr, message, context) {
|
|
126
131
|
if (!this.shouldLog(level))
|
|
@@ -130,14 +135,27 @@ class Logger {
|
|
|
130
135
|
// File output: plain single-line format
|
|
131
136
|
if (this.options.enableFile) {
|
|
132
137
|
const fileLine = `${timestamp} ${levelStr.padEnd(5)} ${message}${contextStr}\n`;
|
|
133
|
-
|
|
134
|
-
|
|
138
|
+
if (this.asyncWrites) {
|
|
139
|
+
// Fire-and-forget async write - doesn't block the event loop
|
|
140
|
+
void (async () => {
|
|
141
|
+
try {
|
|
142
|
+
await fs_1.default.promises.appendFile(this.logFile, fileLine);
|
|
143
|
+
}
|
|
144
|
+
catch {
|
|
145
|
+
// Silently ignore errors
|
|
146
|
+
}
|
|
147
|
+
})();
|
|
135
148
|
}
|
|
136
|
-
|
|
137
|
-
|
|
149
|
+
else {
|
|
150
|
+
try {
|
|
151
|
+
fs_1.default.appendFileSync(this.logFile, fileLine);
|
|
152
|
+
}
|
|
153
|
+
catch {
|
|
154
|
+
// Silently fail if we can't write to the file
|
|
155
|
+
}
|
|
138
156
|
}
|
|
139
157
|
}
|
|
140
|
-
// Console output: colorized
|
|
158
|
+
// Console output: colorized (always sync, goes to stderr)
|
|
141
159
|
if (this.options.enableConsole) {
|
|
142
160
|
const color = LEVEL_COLORS[levelStr] || COLORS.reset;
|
|
143
161
|
const consoleLine = `${COLORS.dim}${timestamp}${COLORS.reset} ${color}${levelStr.padEnd(5)}${COLORS.reset} ${message}${COLORS.gray}${contextStr}${COLORS.reset}`;
|
|
@@ -163,7 +181,7 @@ class Logger {
|
|
|
163
181
|
this.writeLog('fatal', 'FATAL', message, context);
|
|
164
182
|
}
|
|
165
183
|
child(bindings) {
|
|
166
|
-
return new Logger(this.options, undefined, this.getCorrelationId, { ...this.bindings, ...bindings }, this.boundContext);
|
|
184
|
+
return new Logger({ ...this.options, asyncWrites: this.asyncWrites }, undefined, this.getCorrelationId, { ...this.bindings, ...bindings }, this.boundContext);
|
|
167
185
|
}
|
|
168
186
|
// ============================================================================
|
|
169
187
|
// IStructuredLogger Implementation
|
|
@@ -228,7 +246,7 @@ class Logger {
|
|
|
228
246
|
* Create a child logger with bound context.
|
|
229
247
|
*/
|
|
230
248
|
withContext(context) {
|
|
231
|
-
return new Logger(this.options, undefined, this.getCorrelationId, this.bindings, { ...this.boundContext, ...context });
|
|
249
|
+
return new Logger({ ...this.options, asyncWrites: this.asyncWrites }, undefined, this.getCorrelationId, this.bindings, { ...this.boundContext, ...context });
|
|
232
250
|
}
|
|
233
251
|
/**
|
|
234
252
|
* Start a timed operation and return a function to complete it.
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"Logger.js","sourceRoot":"","sources":["../../../../src/lib/infrastructure/logging/Logger.ts"],"names":[],"mappings":";;;;;;AAAA,gDAAwB;AACxB,4CAAoB;AAUpB,wDAAgF;AAEhF;;GAEG;AACU,QAAA,sBAAsB,GAAmB;IACpD,KAAK,EAAE,MAAM;IACb,MAAM,EAAE,YAAY;IACpB,aAAa,EAAE,IAAI;IACnB,UAAU,EAAE,IAAI;IAChB,aAAa,EAAE,CAAC;CACjB,CAAC;
|
|
1
|
+
{"version":3,"file":"Logger.js","sourceRoot":"","sources":["../../../../src/lib/infrastructure/logging/Logger.ts"],"names":[],"mappings":"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"}
|
|
@@ -1,4 +1,5 @@
|
|
|
1
1
|
import type { ILogger, ILoggerOptions } from '../../domain/interfaces';
|
|
2
|
+
import { type ILoggerOptionsExtended } from './Logger';
|
|
2
3
|
/**
|
|
3
4
|
* Load logger options from environment.
|
|
4
5
|
* Priority: process.env > .lisa/.env > defaults
|
|
@@ -16,9 +17,12 @@ export declare function loadLoggerOptions(lisaDir?: string): ILoggerOptions;
|
|
|
16
17
|
* const logger = createLogger();
|
|
17
18
|
* const serviceLog = logger.child({ service: 'memory' });
|
|
18
19
|
* serviceLog.info('Loading memories');
|
|
20
|
+
*
|
|
21
|
+
* // For hooks (non-blocking):
|
|
22
|
+
* const asyncLogger = createLogger({ asyncWrites: true });
|
|
19
23
|
* ```
|
|
20
24
|
*/
|
|
21
|
-
export declare function createLogger(options?: Partial<
|
|
25
|
+
export declare function createLogger(options?: Partial<ILoggerOptionsExtended>): ILogger;
|
|
22
26
|
/**
|
|
23
27
|
* Create a null logger (no-op).
|
|
24
28
|
* Useful for testing or when logging should be disabled.
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"factory.d.ts","sourceRoot":"","sources":["../../../../src/lib/infrastructure/logging/factory.ts"],"names":[],"mappings":"AAEA,OAAO,KAAK,EAAE,OAAO,EAAE,cAAc,EAAY,MAAM,yBAAyB,CAAC;
|
|
1
|
+
{"version":3,"file":"factory.d.ts","sourceRoot":"","sources":["../../../../src/lib/infrastructure/logging/factory.ts"],"names":[],"mappings":"AAEA,OAAO,KAAK,EAAE,OAAO,EAAE,cAAc,EAAY,MAAM,yBAAyB,CAAC;AACjF,OAAO,EAA8C,KAAK,sBAAsB,EAAE,MAAM,UAAU,CAAC;AA6BnG;;;GAGG;AACH,wBAAgB,iBAAiB,CAAC,OAAO,CAAC,EAAE,MAAM,GAAG,cAAc,CAgDlE;AAED;;;;;;;;;;;;;;;;GAgBG;AACH,wBAAgB,YAAY,CAAC,OAAO,CAAC,EAAE,OAAO,CAAC,sBAAsB,CAAC,GAAG,OAAO,CAO/E;AAED;;;GAGG;AACH,wBAAgB,gBAAgB,IAAI,OAAO,CAE1C;AAQD;;;GAGG;AACH,wBAAgB,gBAAgB,IAAI,OAAO,CAK1C;AAED;;GAEG;AACH,wBAAgB,kBAAkB,IAAI,IAAI,CAEzC"}
|
|
@@ -87,6 +87,9 @@ function loadLoggerOptions(lisaDir) {
|
|
|
87
87
|
* const logger = createLogger();
|
|
88
88
|
* const serviceLog = logger.child({ service: 'memory' });
|
|
89
89
|
* serviceLog.info('Loading memories');
|
|
90
|
+
*
|
|
91
|
+
* // For hooks (non-blocking):
|
|
92
|
+
* const asyncLogger = createLogger({ asyncWrites: true });
|
|
90
93
|
* ```
|
|
91
94
|
*/
|
|
92
95
|
function createLogger(options) {
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"factory.js","sourceRoot":"","sources":["../../../../src/lib/infrastructure/logging/factory.ts"],"names":[],"mappings":";;;;;AAoCA,8CAgDC;
|
|
1
|
+
{"version":3,"file":"factory.js","sourceRoot":"","sources":["../../../../src/lib/infrastructure/logging/factory.ts"],"names":[],"mappings":"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"}
|
|
@@ -22,7 +22,7 @@
|
|
|
22
22
|
* });
|
|
23
23
|
* ```
|
|
24
24
|
*/
|
|
25
|
-
export { Logger, NullLogger, DEFAULT_LOGGER_OPTIONS } from './Logger';
|
|
25
|
+
export { Logger, NullLogger, DEFAULT_LOGGER_OPTIONS, type ILoggerOptionsExtended } from './Logger';
|
|
26
26
|
export { createLogger, createNullLogger, getDefaultLogger, resetDefaultLogger, loadLoggerOptions, } from './factory';
|
|
27
27
|
export { withCorrelation, getCorrelationId, getLogContext, extendLogContext, generateCorrelationId, type ILogContext, } from './context';
|
|
28
28
|
//# sourceMappingURL=index.d.ts.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../../../src/lib/infrastructure/logging/index.ts"],"names":[],"mappings":"AAAA;;;;;;;;;;;;;;;;;;;;;;;GAuBG;AAGH,OAAO,EAAE,MAAM,EAAE,UAAU,EAAE,sBAAsB,EAAE,MAAM,UAAU,CAAC;
|
|
1
|
+
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../../../src/lib/infrastructure/logging/index.ts"],"names":[],"mappings":"AAAA;;;;;;;;;;;;;;;;;;;;;;;GAuBG;AAGH,OAAO,EAAE,MAAM,EAAE,UAAU,EAAE,sBAAsB,EAAE,KAAK,sBAAsB,EAAE,MAAM,UAAU,CAAC;AAGnG,OAAO,EACL,YAAY,EACZ,gBAAgB,EAChB,gBAAgB,EAChB,kBAAkB,EAClB,iBAAiB,GAClB,MAAM,WAAW,CAAC;AAGnB,OAAO,EACL,eAAe,EACf,gBAAgB,EAChB,aAAa,EACb,gBAAgB,EAChB,qBAAqB,EACrB,KAAK,WAAW,GACjB,MAAM,WAAW,CAAC"}
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"index.js","sourceRoot":"","sources":["../../../../src/lib/infrastructure/logging/index.ts"],"names":[],"mappings":";AAAA;;;;;;;;;;;;;;;;;;;;;;;GAuBG;;;AAEH,yBAAyB;AACzB,
|
|
1
|
+
{"version":3,"file":"index.js","sourceRoot":"","sources":["../../../../src/lib/infrastructure/logging/index.ts"],"names":[],"mappings":";AAAA;;;;;;;;;;;;;;;;;;;;;;;GAuBG;;;AAEH,yBAAyB;AACzB,mCAAmG;AAA1F,gGAAA,MAAM,OAAA;AAAE,oGAAA,UAAU,OAAA;AAAE,gHAAA,sBAAsB,OAAA;AAEnD,oBAAoB;AACpB,qCAMmB;AALjB,uGAAA,YAAY,OAAA;AACZ,2GAAA,gBAAgB,OAAA;AAChB,2GAAA,gBAAgB,OAAA;AAChB,6GAAA,kBAAkB,OAAA;AAClB,4GAAA,iBAAiB,OAAA;AAGnB,sBAAsB;AACtB,qCAOmB;AANjB,0GAAA,eAAe,OAAA;AACf,2GAAA,gBAAgB,OAAA;AAChB,wGAAA,aAAa,OAAA;AACb,2GAAA,gBAAgB,OAAA;AAChB,gHAAA,qBAAqB,OAAA"}
|
|
@@ -0,0 +1,26 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* Commit Enricher Implementation.
|
|
3
|
+
*
|
|
4
|
+
* LLM-powered extraction of structured facts from git commits.
|
|
5
|
+
* Takes high-interest commits from GitTriageService and extracts
|
|
6
|
+
* meaningful facts (features, decisions, refactors, etc.) for memory.
|
|
7
|
+
*
|
|
8
|
+
* Error Handling:
|
|
9
|
+
* - Graceful fallback: if the LLM call fails for any reason, returns
|
|
10
|
+
* an empty result — never blocks session start or git triage.
|
|
11
|
+
* - Error messages are sanitized (first line only) to avoid logging
|
|
12
|
+
* raw API response bodies which may contain sensitive data.
|
|
13
|
+
*
|
|
14
|
+
* Part of LISA-8: Phase 2 Git-Powered Memory Enrichment.
|
|
15
|
+
*/
|
|
16
|
+
import type { ILlmGuard } from '../../domain/interfaces/ILlmGuard';
|
|
17
|
+
import type { ILogger } from '../../domain/interfaces/ILogger';
|
|
18
|
+
import type { ICommitEnricher } from '../../domain/interfaces/ICommitEnricher';
|
|
19
|
+
/**
|
|
20
|
+
* Create a commit enricher.
|
|
21
|
+
*
|
|
22
|
+
* @param llmGuard - LLM guard for policy-enforced completions
|
|
23
|
+
* @param logger - Optional logger
|
|
24
|
+
*/
|
|
25
|
+
export declare function createCommitEnricher(llmGuard: ILlmGuard, logger?: ILogger): ICommitEnricher;
|
|
26
|
+
//# sourceMappingURL=CommitEnricher.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"CommitEnricher.d.ts","sourceRoot":"","sources":["../../../../src/lib/infrastructure/services/CommitEnricher.ts"],"names":[],"mappings":"AAAA;;;;;;;;;;;;;;GAcG;AAEH,OAAO,KAAK,EAAE,SAAS,EAAE,MAAM,mCAAmC,CAAC;AAEnE,OAAO,KAAK,EAAE,OAAO,EAAE,MAAM,iCAAiC,CAAC;AAE/D,OAAO,KAAK,EACV,eAAe,EAKhB,MAAM,yCAAyC,CAAC;AAejD;;;;;GAKG;AACH,wBAAgB,oBAAoB,CAClC,QAAQ,EAAE,SAAS,EACnB,MAAM,CAAC,EAAE,OAAO,GACf,eAAe,CA0EjB"}
|
|
@@ -0,0 +1,214 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
/**
|
|
3
|
+
* Commit Enricher Implementation.
|
|
4
|
+
*
|
|
5
|
+
* LLM-powered extraction of structured facts from git commits.
|
|
6
|
+
* Takes high-interest commits from GitTriageService and extracts
|
|
7
|
+
* meaningful facts (features, decisions, refactors, etc.) for memory.
|
|
8
|
+
*
|
|
9
|
+
* Error Handling:
|
|
10
|
+
* - Graceful fallback: if the LLM call fails for any reason, returns
|
|
11
|
+
* an empty result — never blocks session start or git triage.
|
|
12
|
+
* - Error messages are sanitized (first line only) to avoid logging
|
|
13
|
+
* raw API response bodies which may contain sensitive data.
|
|
14
|
+
*
|
|
15
|
+
* Part of LISA-8: Phase 2 Git-Powered Memory Enrichment.
|
|
16
|
+
*/
|
|
17
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
18
|
+
exports.createCommitEnricher = createCommitEnricher;
|
|
19
|
+
const ICommitEnricher_1 = require("../../domain/interfaces/ICommitEnricher");
|
|
20
|
+
const IMemoryQuality_1 = require("../../domain/interfaces/types/IMemoryQuality");
|
|
21
|
+
const commit_extraction_1 = require("./prompts/commit-extraction");
|
|
22
|
+
/** Default maximum commits to process in one batch. */
|
|
23
|
+
const DEFAULT_MAX_COMMITS = 5;
|
|
24
|
+
/** Default maximum tokens for the LLM call. */
|
|
25
|
+
const DEFAULT_MAX_TOKENS = 4096;
|
|
26
|
+
/** Empty usage stats for fallback results. */
|
|
27
|
+
const EMPTY_USAGE = { inputTokens: 0, outputTokens: 0, totalTokens: 0 };
|
|
28
|
+
/**
|
|
29
|
+
* Create a commit enricher.
|
|
30
|
+
*
|
|
31
|
+
* @param llmGuard - LLM guard for policy-enforced completions
|
|
32
|
+
* @param logger - Optional logger
|
|
33
|
+
*/
|
|
34
|
+
function createCommitEnricher(llmGuard, logger) {
|
|
35
|
+
return {
|
|
36
|
+
async enrich(commits, options = {}) {
|
|
37
|
+
try {
|
|
38
|
+
// Filter out commits that should be skipped (use shortSha for consistency)
|
|
39
|
+
const skipShas = new Set(options.skipShas ?? []);
|
|
40
|
+
const filteredCommits = commits.filter(c => !skipShas.has(c.commit.shortSha));
|
|
41
|
+
if (filteredCommits.length === 0) {
|
|
42
|
+
return {
|
|
43
|
+
facts: [],
|
|
44
|
+
commitsProcessed: 0,
|
|
45
|
+
commitsSkipped: commits.length,
|
|
46
|
+
usage: EMPTY_USAGE,
|
|
47
|
+
};
|
|
48
|
+
}
|
|
49
|
+
// Limit to maxCommits (guard against <= 0)
|
|
50
|
+
const maxCommits = Math.max(0, options.maxCommits ?? DEFAULT_MAX_COMMITS);
|
|
51
|
+
const toProcess = filteredCommits.slice(0, maxCommits);
|
|
52
|
+
// Fast-return for empty toProcess to avoid wasting LLM tokens
|
|
53
|
+
if (toProcess.length === 0) {
|
|
54
|
+
return {
|
|
55
|
+
facts: [],
|
|
56
|
+
commitsProcessed: 0,
|
|
57
|
+
commitsSkipped: commits.length,
|
|
58
|
+
usage: EMPTY_USAGE,
|
|
59
|
+
};
|
|
60
|
+
}
|
|
61
|
+
const skipped = commits.length - toProcess.length;
|
|
62
|
+
// Build allowed SHAs set for validation (both full and short)
|
|
63
|
+
const allowedShas = new Set(toProcess.flatMap(c => [c.commit.sha, c.commit.shortSha].filter(Boolean)));
|
|
64
|
+
const prompt = (0, commit_extraction_1.buildCommitExtractionPrompt)(toProcess, options);
|
|
65
|
+
const response = await llmGuard.complete(prompt.user, 'extraction', {
|
|
66
|
+
systemPrompt: prompt.system,
|
|
67
|
+
temperature: 0.3,
|
|
68
|
+
maxTokens: options.maxTokens ?? DEFAULT_MAX_TOKENS,
|
|
69
|
+
});
|
|
70
|
+
const parsed = parseCommitExtractionResponse(response.text, options, allowedShas);
|
|
71
|
+
return {
|
|
72
|
+
facts: parsed.facts,
|
|
73
|
+
commitsProcessed: toProcess.length,
|
|
74
|
+
commitsSkipped: skipped,
|
|
75
|
+
usage: response.usage,
|
|
76
|
+
};
|
|
77
|
+
}
|
|
78
|
+
catch (error) {
|
|
79
|
+
// Sanitize error message to avoid logging raw API response bodies
|
|
80
|
+
const errorMsg = error instanceof Error
|
|
81
|
+
? error.message.split('\n')[0] // Take only first line
|
|
82
|
+
: 'Unknown error';
|
|
83
|
+
logger?.warn('Commit enrichment failed, returning empty result', {
|
|
84
|
+
error: errorMsg,
|
|
85
|
+
});
|
|
86
|
+
return {
|
|
87
|
+
facts: [],
|
|
88
|
+
commitsProcessed: 0,
|
|
89
|
+
commitsSkipped: commits.length,
|
|
90
|
+
usage: EMPTY_USAGE,
|
|
91
|
+
};
|
|
92
|
+
}
|
|
93
|
+
},
|
|
94
|
+
};
|
|
95
|
+
}
|
|
96
|
+
/**
|
|
97
|
+
* Parse and validate the LLM extraction response.
|
|
98
|
+
*
|
|
99
|
+
* Expects JSON with `{ facts: [...] }`.
|
|
100
|
+
* Invalid facts are silently dropped.
|
|
101
|
+
*
|
|
102
|
+
* @param allowedShas - Optional set of valid SHAs to reject hallucinated commits
|
|
103
|
+
*/
|
|
104
|
+
function parseCommitExtractionResponse(responseText, options = {}, allowedShas) {
|
|
105
|
+
// Try to extract JSON from the response
|
|
106
|
+
const jsonText = extractJson(responseText);
|
|
107
|
+
if (!jsonText) {
|
|
108
|
+
return { facts: [] };
|
|
109
|
+
}
|
|
110
|
+
let parsed;
|
|
111
|
+
try {
|
|
112
|
+
parsed = JSON.parse(jsonText);
|
|
113
|
+
}
|
|
114
|
+
catch {
|
|
115
|
+
return { facts: [] };
|
|
116
|
+
}
|
|
117
|
+
if (typeof parsed !== 'object' || parsed === null) {
|
|
118
|
+
return { facts: [] };
|
|
119
|
+
}
|
|
120
|
+
const obj = parsed;
|
|
121
|
+
const rawFacts = Array.isArray(obj.facts) ? obj.facts : [];
|
|
122
|
+
const allowedTypes = options.extractTypes;
|
|
123
|
+
const facts = [];
|
|
124
|
+
for (const raw of rawFacts) {
|
|
125
|
+
const fact = validateCommitFact(raw, allowedTypes, allowedShas);
|
|
126
|
+
if (fact) {
|
|
127
|
+
facts.push(fact);
|
|
128
|
+
}
|
|
129
|
+
}
|
|
130
|
+
return { facts };
|
|
131
|
+
}
|
|
132
|
+
/**
|
|
133
|
+
* Extract JSON from LLM response text.
|
|
134
|
+
* Handles responses that may have text before/after the JSON block.
|
|
135
|
+
* Uses progressive try-parse from each '{' to handle braces inside strings.
|
|
136
|
+
*/
|
|
137
|
+
function extractJson(text) {
|
|
138
|
+
const trimmed = text.trim();
|
|
139
|
+
// Try each '{' as a potential JSON start
|
|
140
|
+
let start = trimmed.indexOf('{');
|
|
141
|
+
while (start !== -1) {
|
|
142
|
+
// Try parsing progressively longer substrings from this start
|
|
143
|
+
for (let end = trimmed.lastIndexOf('}'); end > start; end = trimmed.lastIndexOf('}', end - 1)) {
|
|
144
|
+
const candidate = trimmed.slice(start, end + 1);
|
|
145
|
+
try {
|
|
146
|
+
JSON.parse(candidate);
|
|
147
|
+
return candidate;
|
|
148
|
+
}
|
|
149
|
+
catch {
|
|
150
|
+
// Try a shorter substring
|
|
151
|
+
}
|
|
152
|
+
}
|
|
153
|
+
start = trimmed.indexOf('{', start + 1);
|
|
154
|
+
}
|
|
155
|
+
return null;
|
|
156
|
+
}
|
|
157
|
+
/**
|
|
158
|
+
* Validate a single extracted commit fact from the LLM response.
|
|
159
|
+
* Returns null for invalid facts.
|
|
160
|
+
*
|
|
161
|
+
* @param allowedShas - Optional set of valid SHAs to reject hallucinated commits
|
|
162
|
+
*/
|
|
163
|
+
function validateCommitFact(raw, allowedTypes, allowedShas) {
|
|
164
|
+
if (typeof raw !== 'object' || raw === null)
|
|
165
|
+
return null;
|
|
166
|
+
const obj = raw;
|
|
167
|
+
// Text is required and must be non-empty
|
|
168
|
+
if (typeof obj.text !== 'string' || obj.text.trim().length === 0)
|
|
169
|
+
return null;
|
|
170
|
+
// Type must be valid
|
|
171
|
+
if (typeof obj.type !== 'string' || !(0, ICommitEnricher_1.isValidCommitFactType)(obj.type))
|
|
172
|
+
return null;
|
|
173
|
+
// If type filter specified, enforce it
|
|
174
|
+
if (allowedTypes && allowedTypes.length > 0 && !allowedTypes.includes(obj.type)) {
|
|
175
|
+
return null;
|
|
176
|
+
}
|
|
177
|
+
// commitSha is required
|
|
178
|
+
if (typeof obj.commitSha !== 'string' || obj.commitSha.trim().length === 0)
|
|
179
|
+
return null;
|
|
180
|
+
const commitSha = obj.commitSha.trim();
|
|
181
|
+
// Reject facts with unknown SHAs (LLM may hallucinate)
|
|
182
|
+
if (allowedShas && !allowedShas.has(commitSha))
|
|
183
|
+
return null;
|
|
184
|
+
// Confidence must be valid (default to 'medium' if missing)
|
|
185
|
+
let confidence = 'medium';
|
|
186
|
+
if (typeof obj.confidence === 'string') {
|
|
187
|
+
if ((0, IMemoryQuality_1.isValidConfidence)(obj.confidence)) {
|
|
188
|
+
confidence = obj.confidence;
|
|
189
|
+
}
|
|
190
|
+
// If invalid confidence string, keep default 'medium'
|
|
191
|
+
}
|
|
192
|
+
// Tags must be string array (default to empty)
|
|
193
|
+
const tags = [];
|
|
194
|
+
if (Array.isArray(obj.tags)) {
|
|
195
|
+
for (const tag of obj.tags) {
|
|
196
|
+
if (typeof tag === 'string' && tag.trim().length > 0) {
|
|
197
|
+
tags.push(tag.trim());
|
|
198
|
+
}
|
|
199
|
+
}
|
|
200
|
+
}
|
|
201
|
+
// Rationale is optional
|
|
202
|
+
const rationale = typeof obj.rationale === 'string' && obj.rationale.trim().length > 0
|
|
203
|
+
? obj.rationale.trim()
|
|
204
|
+
: undefined;
|
|
205
|
+
return {
|
|
206
|
+
text: obj.text.trim(),
|
|
207
|
+
type: obj.type,
|
|
208
|
+
confidence,
|
|
209
|
+
tags,
|
|
210
|
+
commitSha,
|
|
211
|
+
rationale,
|
|
212
|
+
};
|
|
213
|
+
}
|
|
214
|
+
//# sourceMappingURL=CommitEnricher.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"CommitEnricher.js","sourceRoot":"","sources":["../../../../src/lib/infrastructure/services/CommitEnricher.ts"],"names":[],"mappings":"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"}
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"CurationService.d.ts","sourceRoot":"","sources":["../../../../src/lib/infrastructure/services/CurationService.ts"],"names":[],"mappings":"AAAA;;;;;;;;;GASG;AAGH,OAAO,KAAK,EAAE,gBAAgB,EAAgB,MAAM,0CAA0C,CAAC;AAC/F,OAAO,KAAK,EAAE,aAAa,EAAE,MAAM,wCAAwC,CAAC;AAwC5E;;;;;;;GAOG;AACH,wBAAgB,mBAAmB,CAAC,SAAS,EAAE,MAAM,GAAG,IAAI,GAAG,SAAS,EAAE,GAAG,GAAE,IAAiB,GAAG,MAAM,CAcxG;AAED;;;;GAIG;AACH,wBAAgB,qBAAqB,CACnC,YAAY,EAAE,aAAa,GAC1B,gBAAgB,
|
|
1
|
+
{"version":3,"file":"CurationService.d.ts","sourceRoot":"","sources":["../../../../src/lib/infrastructure/services/CurationService.ts"],"names":[],"mappings":"AAAA;;;;;;;;;GASG;AAGH,OAAO,KAAK,EAAE,gBAAgB,EAAgB,MAAM,0CAA0C,CAAC;AAC/F,OAAO,KAAK,EAAE,aAAa,EAAE,MAAM,wCAAwC,CAAC;AAwC5E;;;;;;;GAOG;AACH,wBAAgB,mBAAmB,CAAC,SAAS,EAAE,MAAM,GAAG,IAAI,GAAG,SAAS,EAAE,GAAG,GAAE,IAAiB,GAAG,MAAM,CAcxG;AAED;;;;GAIG;AACH,wBAAgB,qBAAqB,CACnC,YAAY,EAAE,aAAa,GAC1B,gBAAgB,CAoDlB"}
|
|
@@ -71,18 +71,18 @@ function computeRecencyBonus(createdAt, now = new Date()) {
|
|
|
71
71
|
*/
|
|
72
72
|
function createCurationService(memoryWriter) {
|
|
73
73
|
return {
|
|
74
|
-
async markFact(
|
|
74
|
+
async markFact(uuid, mark) {
|
|
75
75
|
const curationTag = (0, ICurationService_1.resolveCurationTag)(mark);
|
|
76
76
|
// Add the curation tag to the fact
|
|
77
|
-
await memoryWriter.addFact(
|
|
77
|
+
await memoryWriter.addFact(`__curate:${uuid}`, [curationTag]);
|
|
78
78
|
// Side effects by mark
|
|
79
79
|
if (mark === 'deprecated') {
|
|
80
|
-
await memoryWriter.expireFact(
|
|
80
|
+
await memoryWriter.expireFact(uuid);
|
|
81
81
|
}
|
|
82
82
|
if (mark === 'authoritative') {
|
|
83
83
|
// Promote confidence to verified
|
|
84
84
|
const confidenceTag = (0, IMemoryQuality_1.resolveConfidenceTag)('verified');
|
|
85
|
-
await memoryWriter.addFact(
|
|
85
|
+
await memoryWriter.addFact(`__promote:${uuid}`, [confidenceTag]);
|
|
86
86
|
}
|
|
87
87
|
},
|
|
88
88
|
computeQualityScore(item) {
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"CurationService.js","sourceRoot":"","sources":["../../../../src/lib/infrastructure/services/CurationService.ts"],"names":[],"mappings":";AAAA;;;;;;;;;GASG;;AAoDH,kDAcC;AAOD,
|
|
1
|
+
{"version":3,"file":"CurationService.js","sourceRoot":"","sources":["../../../../src/lib/infrastructure/services/CurationService.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,24 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* GitMemMemoryService
|
|
3
|
+
*
|
|
4
|
+
* Adapter that maps Lisa's IMemoryService interface to git-mem's MemoryService.
|
|
5
|
+
* git-mem stores memories as JSON in git notes (refs/notes/mem).
|
|
6
|
+
*/
|
|
7
|
+
import type { IMemoryService as IGitMemMemoryService } from 'git-mem/dist/index';
|
|
8
|
+
import type { IMemoryService } from '../../domain/interfaces/IMemoryService';
|
|
9
|
+
import type { IMemoryItem, IMemoryResult } from '../../domain/interfaces/types/IMemoryResult';
|
|
10
|
+
import type { IMemorySaveOptions } from '../../domain/interfaces/dal/IMemoryRepository';
|
|
11
|
+
import type { IMemoryDateOptions } from '../../domain/interfaces/IMemoryService';
|
|
12
|
+
export declare class GitMemMemoryService implements IMemoryService {
|
|
13
|
+
private readonly gitMem;
|
|
14
|
+
constructor(gitMem: IGitMemMemoryService);
|
|
15
|
+
loadMemory(_timeoutMs?: number): Promise<IMemoryResult>;
|
|
16
|
+
loadFactsDateOrdered(limit?: number, options?: IMemoryDateOptions): Promise<IMemoryItem[]>;
|
|
17
|
+
searchFacts(query: string, limit?: number): Promise<IMemoryItem[]>;
|
|
18
|
+
saveMemory(facts: readonly string[]): Promise<void>;
|
|
19
|
+
addFact(fact: string, tags?: readonly string[]): Promise<void>;
|
|
20
|
+
addFactWithLifecycle(fact: string, options: IMemorySaveOptions): Promise<void>;
|
|
21
|
+
expireFact(uuid: string): Promise<void>;
|
|
22
|
+
cleanupExpired(): Promise<number>;
|
|
23
|
+
}
|
|
24
|
+
//# sourceMappingURL=GitMemMemoryService.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"GitMemMemoryService.d.ts","sourceRoot":"","sources":["../../../../src/lib/infrastructure/services/GitMemMemoryService.ts"],"names":[],"mappings":"AAAA;;;;;GAKG;AAEH,OAAO,KAAK,EACV,cAAc,IAAI,oBAAoB,EAEvC,MAAM,oBAAoB,CAAC;AAE5B,OAAO,KAAK,EAAE,cAAc,EAAE,MAAM,wCAAwC,CAAC;AAC7E,OAAO,KAAK,EAAE,WAAW,EAAE,aAAa,EAAE,MAAM,6CAA6C,CAAC;AAC9F,OAAO,KAAK,EAAE,kBAAkB,EAAE,MAAM,+CAA+C,CAAC;AACxF,OAAO,KAAK,EAAE,kBAAkB,EAAE,MAAM,wCAAwC,CAAC;AAuDjF,qBAAa,mBAAoB,YAAW,cAAc;IAC5C,OAAO,CAAC,QAAQ,CAAC,MAAM;gBAAN,MAAM,EAAE,oBAAoB;IAEnD,UAAU,CACd,UAAU,CAAC,EAAE,MAAM,GAClB,OAAO,CAAC,aAAa,CAAC;IAoBnB,oBAAoB,CACxB,KAAK,CAAC,EAAE,MAAM,EACd,OAAO,CAAC,EAAE,kBAAkB,GAC3B,OAAO,CAAC,WAAW,EAAE,CAAC;IAmBnB,WAAW,CACf,KAAK,EAAE,MAAM,EACb,KAAK,CAAC,EAAE,MAAM,GACb,OAAO,CAAC,WAAW,EAAE,CAAC;IAKnB,UAAU,CAAC,KAAK,EAAE,SAAS,MAAM,EAAE,GAAG,OAAO,CAAC,IAAI,CAAC;IAMnD,OAAO,CACX,IAAI,EAAE,MAAM,EACZ,IAAI,CAAC,EAAE,SAAS,MAAM,EAAE,GACvB,OAAO,CAAC,IAAI,CAAC;IAMV,oBAAoB,CACxB,IAAI,EAAE,MAAM,EACZ,OAAO,EAAE,kBAAkB,GAC1B,OAAO,CAAC,IAAI,CAAC;IAUV,UAAU,CAAC,IAAI,EAAE,MAAM,GAAG,OAAO,CAAC,IAAI,CAAC;IAIvC,cAAc,IAAI,OAAO,CAAC,MAAM,CAAC;CAIxC"}
|