0agent 1.0.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/README.md +164 -0
- package/bin/0agent.js +614 -0
- package/package.json +59 -0
- package/packages/core/dist/bootstrap/BootstrapProtocol.d.ts +37 -0
- package/packages/core/dist/bootstrap/BootstrapProtocol.d.ts.map +1 -0
- package/packages/core/dist/bootstrap/BootstrapProtocol.js +82 -0
- package/packages/core/dist/bootstrap/BootstrapProtocol.js.map +1 -0
- package/packages/core/dist/bootstrap/GraphConstructor.d.ts +44 -0
- package/packages/core/dist/bootstrap/GraphConstructor.d.ts.map +1 -0
- package/packages/core/dist/bootstrap/GraphConstructor.js +160 -0
- package/packages/core/dist/bootstrap/GraphConstructor.js.map +1 -0
- package/packages/core/dist/bootstrap/HypothesisManager.d.ts +50 -0
- package/packages/core/dist/bootstrap/HypothesisManager.d.ts.map +1 -0
- package/packages/core/dist/bootstrap/HypothesisManager.js +108 -0
- package/packages/core/dist/bootstrap/HypothesisManager.js.map +1 -0
- package/packages/core/dist/bootstrap/StagedMutations.d.ts +50 -0
- package/packages/core/dist/bootstrap/StagedMutations.d.ts.map +1 -0
- package/packages/core/dist/bootstrap/StagedMutations.js +80 -0
- package/packages/core/dist/bootstrap/StagedMutations.js.map +1 -0
- package/packages/core/dist/concurrency/EdgeWeightUpdater.d.ts +16 -0
- package/packages/core/dist/concurrency/EdgeWeightUpdater.d.ts.map +1 -0
- package/packages/core/dist/concurrency/EdgeWeightUpdater.js +57 -0
- package/packages/core/dist/concurrency/EdgeWeightUpdater.js.map +1 -0
- package/packages/core/dist/concurrency/SessionSnapshot.d.ts +63 -0
- package/packages/core/dist/concurrency/SessionSnapshot.d.ts.map +1 -0
- package/packages/core/dist/concurrency/SessionSnapshot.js +124 -0
- package/packages/core/dist/concurrency/SessionSnapshot.js.map +1 -0
- package/packages/core/dist/embedding/HNSWIndex.d.ts +37 -0
- package/packages/core/dist/embedding/HNSWIndex.d.ts.map +1 -0
- package/packages/core/dist/embedding/HNSWIndex.js +86 -0
- package/packages/core/dist/embedding/HNSWIndex.js.map +1 -0
- package/packages/core/dist/embedding/MultimodalEmbedder.d.ts +24 -0
- package/packages/core/dist/embedding/MultimodalEmbedder.d.ts.map +1 -0
- package/packages/core/dist/embedding/MultimodalEmbedder.js +75 -0
- package/packages/core/dist/embedding/MultimodalEmbedder.js.map +1 -0
- package/packages/core/dist/embedding/adapters/NomicAdapter.d.ts +7 -0
- package/packages/core/dist/embedding/adapters/NomicAdapter.d.ts.map +1 -0
- package/packages/core/dist/embedding/adapters/NomicAdapter.js +11 -0
- package/packages/core/dist/embedding/adapters/NomicAdapter.js.map +1 -0
- package/packages/core/dist/embedding/adapters/OllamaAdapter.d.ts +19 -0
- package/packages/core/dist/embedding/adapters/OllamaAdapter.d.ts.map +1 -0
- package/packages/core/dist/embedding/adapters/OllamaAdapter.js +27 -0
- package/packages/core/dist/embedding/adapters/OllamaAdapter.js.map +1 -0
- package/packages/core/dist/embedding/adapters/OpenAIAdapter.d.ts +14 -0
- package/packages/core/dist/embedding/adapters/OpenAIAdapter.d.ts.map +1 -0
- package/packages/core/dist/embedding/adapters/OpenAIAdapter.js +48 -0
- package/packages/core/dist/embedding/adapters/OpenAIAdapter.js.map +1 -0
- package/packages/core/dist/engine/CreditAttribution.d.ts +47 -0
- package/packages/core/dist/engine/CreditAttribution.d.ts.map +1 -0
- package/packages/core/dist/engine/CreditAttribution.js +196 -0
- package/packages/core/dist/engine/CreditAttribution.js.map +1 -0
- package/packages/core/dist/engine/DecayScheduler.d.ts +45 -0
- package/packages/core/dist/engine/DecayScheduler.d.ts.map +1 -0
- package/packages/core/dist/engine/DecayScheduler.js +115 -0
- package/packages/core/dist/engine/DecayScheduler.js.map +1 -0
- package/packages/core/dist/engine/InferenceEngine.d.ts +95 -0
- package/packages/core/dist/engine/InferenceEngine.d.ts.map +1 -0
- package/packages/core/dist/engine/InferenceEngine.js +242 -0
- package/packages/core/dist/engine/InferenceEngine.js.map +1 -0
- package/packages/core/dist/engine/SelectionPolicy.d.ts +29 -0
- package/packages/core/dist/engine/SelectionPolicy.d.ts.map +1 -0
- package/packages/core/dist/engine/SelectionPolicy.js +58 -0
- package/packages/core/dist/engine/SelectionPolicy.js.map +1 -0
- package/packages/core/dist/engine/SelfImprovementEngine.d.ts +58 -0
- package/packages/core/dist/engine/SelfImprovementEngine.d.ts.map +1 -0
- package/packages/core/dist/engine/SelfImprovementEngine.js +265 -0
- package/packages/core/dist/engine/SelfImprovementEngine.js.map +1 -0
- package/packages/core/dist/engine/SelfImprovementPrompt.d.ts +10 -0
- package/packages/core/dist/engine/SelfImprovementPrompt.d.ts.map +1 -0
- package/packages/core/dist/engine/SelfImprovementPrompt.js +193 -0
- package/packages/core/dist/engine/SelfImprovementPrompt.js.map +1 -0
- package/packages/core/dist/engine/WeightPropagation.d.ts +77 -0
- package/packages/core/dist/engine/WeightPropagation.d.ts.map +1 -0
- package/packages/core/dist/engine/WeightPropagation.js +101 -0
- package/packages/core/dist/engine/WeightPropagation.js.map +1 -0
- package/packages/core/dist/engine/WorkflowSuggestionEngine.d.ts +26 -0
- package/packages/core/dist/engine/WorkflowSuggestionEngine.d.ts.map +1 -0
- package/packages/core/dist/engine/WorkflowSuggestionEngine.js +54 -0
- package/packages/core/dist/engine/WorkflowSuggestionEngine.js.map +1 -0
- package/packages/core/dist/entity/AliasIndex.d.ts +39 -0
- package/packages/core/dist/entity/AliasIndex.d.ts.map +1 -0
- package/packages/core/dist/entity/AliasIndex.js +81 -0
- package/packages/core/dist/entity/AliasIndex.js.map +1 -0
- package/packages/core/dist/entity/ContextActivator.d.ts +53 -0
- package/packages/core/dist/entity/ContextActivator.d.ts.map +1 -0
- package/packages/core/dist/entity/ContextActivator.js +163 -0
- package/packages/core/dist/entity/ContextActivator.js.map +1 -0
- package/packages/core/dist/entity/EntityHierarchy.d.ts +48 -0
- package/packages/core/dist/entity/EntityHierarchy.d.ts.map +1 -0
- package/packages/core/dist/entity/EntityHierarchy.js +134 -0
- package/packages/core/dist/entity/EntityHierarchy.js.map +1 -0
- package/packages/core/dist/entity/EntityResolutionPipeline.d.ts +48 -0
- package/packages/core/dist/entity/EntityResolutionPipeline.d.ts.map +1 -0
- package/packages/core/dist/entity/EntityResolutionPipeline.js +221 -0
- package/packages/core/dist/entity/EntityResolutionPipeline.js.map +1 -0
- package/packages/core/dist/entity/MCPEnrichedResolver.d.ts +17 -0
- package/packages/core/dist/entity/MCPEnrichedResolver.d.ts.map +1 -0
- package/packages/core/dist/entity/MCPEnrichedResolver.js +19 -0
- package/packages/core/dist/entity/MCPEnrichedResolver.js.map +1 -0
- package/packages/core/dist/entity/NodeResolutionService.d.ts +46 -0
- package/packages/core/dist/entity/NodeResolutionService.d.ts.map +1 -0
- package/packages/core/dist/entity/NodeResolutionService.js +150 -0
- package/packages/core/dist/entity/NodeResolutionService.js.map +1 -0
- package/packages/core/dist/entity/PersonalityAccumulator.d.ts +41 -0
- package/packages/core/dist/entity/PersonalityAccumulator.d.ts.map +1 -0
- package/packages/core/dist/entity/PersonalityAccumulator.js +126 -0
- package/packages/core/dist/entity/PersonalityAccumulator.js.map +1 -0
- package/packages/core/dist/entity/PersonalityProfile.d.ts +31 -0
- package/packages/core/dist/entity/PersonalityProfile.d.ts.map +1 -0
- package/packages/core/dist/entity/PersonalityProfile.js +94 -0
- package/packages/core/dist/entity/PersonalityProfile.js.map +1 -0
- package/packages/core/dist/entity/index.d.ts +4 -0
- package/packages/core/dist/entity/index.d.ts.map +1 -0
- package/packages/core/dist/entity/index.js +4 -0
- package/packages/core/dist/entity/index.js.map +1 -0
- package/packages/core/dist/graph/GraphEdge.d.ts +37 -0
- package/packages/core/dist/graph/GraphEdge.d.ts.map +1 -0
- package/packages/core/dist/graph/GraphEdge.js +29 -0
- package/packages/core/dist/graph/GraphEdge.js.map +1 -0
- package/packages/core/dist/graph/GraphNode.d.ts +52 -0
- package/packages/core/dist/graph/GraphNode.d.ts.map +1 -0
- package/packages/core/dist/graph/GraphNode.js +41 -0
- package/packages/core/dist/graph/GraphNode.js.map +1 -0
- package/packages/core/dist/graph/GraphQuery.d.ts +46 -0
- package/packages/core/dist/graph/GraphQuery.d.ts.map +1 -0
- package/packages/core/dist/graph/GraphQuery.js +47 -0
- package/packages/core/dist/graph/GraphQuery.js.map +1 -0
- package/packages/core/dist/graph/KnowledgeGraph.d.ts +38 -0
- package/packages/core/dist/graph/KnowledgeGraph.d.ts.map +1 -0
- package/packages/core/dist/graph/KnowledgeGraph.js +345 -0
- package/packages/core/dist/graph/KnowledgeGraph.js.map +1 -0
- package/packages/core/dist/graph/SubGraph.d.ts +36 -0
- package/packages/core/dist/graph/SubGraph.d.ts.map +1 -0
- package/packages/core/dist/graph/SubGraph.js +86 -0
- package/packages/core/dist/graph/SubGraph.js.map +1 -0
- package/packages/core/dist/index.d.ts +54 -0
- package/packages/core/dist/index.d.ts.map +1 -0
- package/packages/core/dist/index.js +62 -0
- package/packages/core/dist/index.js.map +1 -0
- package/packages/core/dist/maintenance/CompactionOrchestrator.d.ts +22 -0
- package/packages/core/dist/maintenance/CompactionOrchestrator.d.ts.map +1 -0
- package/packages/core/dist/maintenance/CompactionOrchestrator.js +62 -0
- package/packages/core/dist/maintenance/CompactionOrchestrator.js.map +1 -0
- package/packages/core/dist/maintenance/EdgePruner.d.ts +20 -0
- package/packages/core/dist/maintenance/EdgePruner.d.ts.map +1 -0
- package/packages/core/dist/maintenance/EdgePruner.js +65 -0
- package/packages/core/dist/maintenance/EdgePruner.js.map +1 -0
- package/packages/core/dist/maintenance/GraphCheckpoint.d.ts +51 -0
- package/packages/core/dist/maintenance/GraphCheckpoint.d.ts.map +1 -0
- package/packages/core/dist/maintenance/GraphCheckpoint.js +81 -0
- package/packages/core/dist/maintenance/GraphCheckpoint.js.map +1 -0
- package/packages/core/dist/maintenance/GraphRollback.d.ts +36 -0
- package/packages/core/dist/maintenance/GraphRollback.d.ts.map +1 -0
- package/packages/core/dist/maintenance/GraphRollback.js +154 -0
- package/packages/core/dist/maintenance/GraphRollback.js.map +1 -0
- package/packages/core/dist/maintenance/NodeDeduplicator.d.ts +26 -0
- package/packages/core/dist/maintenance/NodeDeduplicator.d.ts.map +1 -0
- package/packages/core/dist/maintenance/NodeDeduplicator.js +171 -0
- package/packages/core/dist/maintenance/NodeDeduplicator.js.map +1 -0
- package/packages/core/dist/maintenance/SubgraphArchiver.d.ts +18 -0
- package/packages/core/dist/maintenance/SubgraphArchiver.d.ts.map +1 -0
- package/packages/core/dist/maintenance/SubgraphArchiver.js +180 -0
- package/packages/core/dist/maintenance/SubgraphArchiver.js.map +1 -0
- package/packages/core/dist/memory/ArchivalMemory.d.ts +28 -0
- package/packages/core/dist/memory/ArchivalMemory.d.ts.map +1 -0
- package/packages/core/dist/memory/ArchivalMemory.js +26 -0
- package/packages/core/dist/memory/ArchivalMemory.js.map +1 -0
- package/packages/core/dist/memory/BlinkingMemory.d.ts +34 -0
- package/packages/core/dist/memory/BlinkingMemory.d.ts.map +1 -0
- package/packages/core/dist/memory/BlinkingMemory.js +44 -0
- package/packages/core/dist/memory/BlinkingMemory.js.map +1 -0
- package/packages/core/dist/memory/WorkingMemory.d.ts +38 -0
- package/packages/core/dist/memory/WorkingMemory.d.ts.map +1 -0
- package/packages/core/dist/memory/WorkingMemory.js +70 -0
- package/packages/core/dist/memory/WorkingMemory.js.map +1 -0
- package/packages/core/dist/storage/ObjectStore.d.ts +24 -0
- package/packages/core/dist/storage/ObjectStore.d.ts.map +1 -0
- package/packages/core/dist/storage/ObjectStore.js +50 -0
- package/packages/core/dist/storage/ObjectStore.js.map +1 -0
- package/packages/core/dist/storage/TraceStore.d.ts +16 -0
- package/packages/core/dist/storage/TraceStore.d.ts.map +1 -0
- package/packages/core/dist/storage/TraceStore.js +19 -0
- package/packages/core/dist/storage/TraceStore.js.map +1 -0
- package/packages/core/dist/storage/WeightEventLog.d.ts +11 -0
- package/packages/core/dist/storage/WeightEventLog.d.ts.map +1 -0
- package/packages/core/dist/storage/WeightEventLog.js +16 -0
- package/packages/core/dist/storage/WeightEventLog.js.map +1 -0
- package/packages/core/dist/storage/adapters/SQLiteAdapter.d.ts +86 -0
- package/packages/core/dist/storage/adapters/SQLiteAdapter.d.ts.map +1 -0
- package/packages/core/dist/storage/adapters/SQLiteAdapter.js +514 -0
- package/packages/core/dist/storage/adapters/SQLiteAdapter.js.map +1 -0
- package/packages/core/dist/trace/DeferredTrace.d.ts +43 -0
- package/packages/core/dist/trace/DeferredTrace.d.ts.map +1 -0
- package/packages/core/dist/trace/DeferredTrace.js +44 -0
- package/packages/core/dist/trace/DeferredTrace.js.map +1 -0
- package/packages/core/dist/trace/OutcomeTrace.d.ts +38 -0
- package/packages/core/dist/trace/OutcomeTrace.d.ts.map +1 -0
- package/packages/core/dist/trace/OutcomeTrace.js +9 -0
- package/packages/core/dist/trace/OutcomeTrace.js.map +1 -0
- package/packages/core/dist/trace/SkillTraceDecorator.d.ts +25 -0
- package/packages/core/dist/trace/SkillTraceDecorator.d.ts.map +1 -0
- package/packages/core/dist/trace/SkillTraceDecorator.js +41 -0
- package/packages/core/dist/trace/SkillTraceDecorator.js.map +1 -0
- package/packages/core/dist/trace/TraceReplay.d.ts +25 -0
- package/packages/core/dist/trace/TraceReplay.d.ts.map +1 -0
- package/packages/core/dist/trace/TraceReplay.js +40 -0
- package/packages/core/dist/trace/TraceReplay.js.map +1 -0
- package/packages/core/dist/trace/TraversalLedger.d.ts +33 -0
- package/packages/core/dist/trace/TraversalLedger.d.ts.map +1 -0
- package/packages/core/dist/trace/TraversalLedger.js +61 -0
- package/packages/core/dist/trace/TraversalLedger.js.map +1 -0
- package/packages/core/dist/types/SelfImprovement.d.ts +174 -0
- package/packages/core/dist/types/SelfImprovement.d.ts.map +1 -0
- package/packages/core/dist/types/SelfImprovement.js +23 -0
- package/packages/core/dist/types/SelfImprovement.js.map +1 -0
- package/packages/core/dist/types/SkillDefinition.d.ts +68 -0
- package/packages/core/dist/types/SkillDefinition.d.ts.map +1 -0
- package/packages/core/dist/types/SkillDefinition.js +12 -0
- package/packages/core/dist/types/SkillDefinition.js.map +1 -0
- package/packages/daemon/dist/BackgroundWorkers.d.ts +55 -0
- package/packages/daemon/dist/BackgroundWorkers.d.ts.map +1 -0
- package/packages/daemon/dist/BackgroundWorkers.js +121 -0
- package/packages/daemon/dist/BackgroundWorkers.js.map +1 -0
- package/packages/daemon/dist/EntityScopedContext.d.ts +22 -0
- package/packages/daemon/dist/EntityScopedContext.d.ts.map +1 -0
- package/packages/daemon/dist/EntityScopedContext.js +85 -0
- package/packages/daemon/dist/EntityScopedContext.js.map +1 -0
- package/packages/daemon/dist/HTTPServer.d.ts +27 -0
- package/packages/daemon/dist/HTTPServer.d.ts.map +1 -0
- package/packages/daemon/dist/HTTPServer.js +62 -0
- package/packages/daemon/dist/HTTPServer.js.map +1 -0
- package/packages/daemon/dist/SessionManager.d.ts +95 -0
- package/packages/daemon/dist/SessionManager.d.ts.map +1 -0
- package/packages/daemon/dist/SessionManager.js +205 -0
- package/packages/daemon/dist/SessionManager.js.map +1 -0
- package/packages/daemon/dist/SkillRegistry.d.ts +34 -0
- package/packages/daemon/dist/SkillRegistry.d.ts.map +1 -0
- package/packages/daemon/dist/SkillRegistry.js +90 -0
- package/packages/daemon/dist/SkillRegistry.js.map +1 -0
- package/packages/daemon/dist/SkillVariableResolver.d.ts +24 -0
- package/packages/daemon/dist/SkillVariableResolver.d.ts.map +1 -0
- package/packages/daemon/dist/SkillVariableResolver.js +85 -0
- package/packages/daemon/dist/SkillVariableResolver.js.map +1 -0
- package/packages/daemon/dist/WebSocketEvents.d.ts +107 -0
- package/packages/daemon/dist/WebSocketEvents.d.ts.map +1 -0
- package/packages/daemon/dist/WebSocketEvents.js +111 -0
- package/packages/daemon/dist/WebSocketEvents.js.map +1 -0
- package/packages/daemon/dist/ZeroAgentDaemon.d.ts +39 -0
- package/packages/daemon/dist/ZeroAgentDaemon.d.ts.map +1 -0
- package/packages/daemon/dist/ZeroAgentDaemon.js +161 -0
- package/packages/daemon/dist/ZeroAgentDaemon.js.map +1 -0
- package/packages/daemon/dist/config/ConfigSchema.d.ts +631 -0
- package/packages/daemon/dist/config/ConfigSchema.d.ts.map +1 -0
- package/packages/daemon/dist/config/ConfigSchema.js +107 -0
- package/packages/daemon/dist/config/ConfigSchema.js.map +1 -0
- package/packages/daemon/dist/config/DaemonConfig.d.ts +10 -0
- package/packages/daemon/dist/config/DaemonConfig.d.ts.map +1 -0
- package/packages/daemon/dist/config/DaemonConfig.js +34 -0
- package/packages/daemon/dist/config/DaemonConfig.js.map +1 -0
- package/packages/daemon/dist/index.d.ts +10 -0
- package/packages/daemon/dist/index.d.ts.map +1 -0
- package/packages/daemon/dist/index.js +8 -0
- package/packages/daemon/dist/index.js.map +1 -0
- package/packages/daemon/dist/routes/entities.d.ts +6 -0
- package/packages/daemon/dist/routes/entities.d.ts.map +1 -0
- package/packages/daemon/dist/routes/entities.js +54 -0
- package/packages/daemon/dist/routes/entities.js.map +1 -0
- package/packages/daemon/dist/routes/graph.d.ts +6 -0
- package/packages/daemon/dist/routes/graph.d.ts.map +1 -0
- package/packages/daemon/dist/routes/graph.js +61 -0
- package/packages/daemon/dist/routes/graph.js.map +1 -0
- package/packages/daemon/dist/routes/health.d.ts +15 -0
- package/packages/daemon/dist/routes/health.d.ts.map +1 -0
- package/packages/daemon/dist/routes/health.js +11 -0
- package/packages/daemon/dist/routes/health.js.map +1 -0
- package/packages/daemon/dist/routes/sessions.d.ts +6 -0
- package/packages/daemon/dist/routes/sessions.d.ts.map +1 -0
- package/packages/daemon/dist/routes/sessions.js +43 -0
- package/packages/daemon/dist/routes/sessions.js.map +1 -0
- package/packages/daemon/dist/routes/skills.d.ts +6 -0
- package/packages/daemon/dist/routes/skills.d.ts.map +1 -0
- package/packages/daemon/dist/routes/skills.js +62 -0
- package/packages/daemon/dist/routes/skills.js.map +1 -0
- package/packages/daemon/dist/routes/subagents.d.ts +3 -0
- package/packages/daemon/dist/routes/subagents.d.ts.map +1 -0
- package/packages/daemon/dist/routes/subagents.js +14 -0
- package/packages/daemon/dist/routes/subagents.js.map +1 -0
- package/packages/daemon/dist/routes/traces.d.ts +6 -0
- package/packages/daemon/dist/routes/traces.d.ts.map +1 -0
- package/packages/daemon/dist/routes/traces.js +31 -0
- package/packages/daemon/dist/routes/traces.js.map +1 -0
- package/packages/daemon/dist/start.d.ts +7 -0
- package/packages/daemon/dist/start.d.ts.map +1 -0
- package/packages/daemon/dist/start.js +24 -0
- package/packages/daemon/dist/start.js.map +1 -0
- package/packages/mcp-hub/dist/FilteredProxy.d.ts +20 -0
- package/packages/mcp-hub/dist/FilteredProxy.d.ts.map +1 -0
- package/packages/mcp-hub/dist/FilteredProxy.js +43 -0
- package/packages/mcp-hub/dist/FilteredProxy.js.map +1 -0
- package/packages/mcp-hub/dist/MCPDiscovery.d.ts +18 -0
- package/packages/mcp-hub/dist/MCPDiscovery.d.ts.map +1 -0
- package/packages/mcp-hub/dist/MCPDiscovery.js +86 -0
- package/packages/mcp-hub/dist/MCPDiscovery.js.map +1 -0
- package/packages/mcp-hub/dist/MCPHub.d.ts +48 -0
- package/packages/mcp-hub/dist/MCPHub.d.ts.map +1 -0
- package/packages/mcp-hub/dist/MCPHub.js +100 -0
- package/packages/mcp-hub/dist/MCPHub.js.map +1 -0
- package/packages/mcp-hub/dist/builtin/BrowserMCP.d.ts +6 -0
- package/packages/mcp-hub/dist/builtin/BrowserMCP.d.ts.map +1 -0
- package/packages/mcp-hub/dist/builtin/BrowserMCP.js +69 -0
- package/packages/mcp-hub/dist/builtin/BrowserMCP.js.map +1 -0
- package/packages/mcp-hub/dist/builtin/FilesystemMCP.d.ts +11 -0
- package/packages/mcp-hub/dist/builtin/FilesystemMCP.d.ts.map +1 -0
- package/packages/mcp-hub/dist/builtin/FilesystemMCP.js +104 -0
- package/packages/mcp-hub/dist/builtin/FilesystemMCP.js.map +1 -0
- package/packages/mcp-hub/dist/builtin/MemoryMCP.d.ts +9 -0
- package/packages/mcp-hub/dist/builtin/MemoryMCP.d.ts.map +1 -0
- package/packages/mcp-hub/dist/builtin/MemoryMCP.js +185 -0
- package/packages/mcp-hub/dist/builtin/MemoryMCP.js.map +1 -0
- package/packages/mcp-hub/dist/builtin/ShellMCP.d.ts +8 -0
- package/packages/mcp-hub/dist/builtin/ShellMCP.d.ts.map +1 -0
- package/packages/mcp-hub/dist/builtin/ShellMCP.js +74 -0
- package/packages/mcp-hub/dist/builtin/ShellMCP.js.map +1 -0
- package/packages/mcp-hub/dist/index.d.ts +9 -0
- package/packages/mcp-hub/dist/index.d.ts.map +1 -0
- package/packages/mcp-hub/dist/index.js +8 -0
- package/packages/mcp-hub/dist/index.js.map +1 -0
- package/packages/mcp-hub/dist/types.d.ts +30 -0
- package/packages/mcp-hub/dist/types.d.ts.map +1 -0
- package/packages/mcp-hub/dist/types.js +2 -0
- package/packages/mcp-hub/dist/types.js.map +1 -0
- package/packages/subagent/dist/CapabilityToken.d.ts +66 -0
- package/packages/subagent/dist/CapabilityToken.d.ts.map +1 -0
- package/packages/subagent/dist/CapabilityToken.js +120 -0
- package/packages/subagent/dist/CapabilityToken.js.map +1 -0
- package/packages/subagent/dist/ResourceDefaults.d.ts +16 -0
- package/packages/subagent/dist/ResourceDefaults.d.ts.map +1 -0
- package/packages/subagent/dist/ResourceDefaults.js +68 -0
- package/packages/subagent/dist/ResourceDefaults.js.map +1 -0
- package/packages/subagent/dist/SkillInputResolver.d.ts +30 -0
- package/packages/subagent/dist/SkillInputResolver.d.ts.map +1 -0
- package/packages/subagent/dist/SkillInputResolver.js +59 -0
- package/packages/subagent/dist/SkillInputResolver.js.map +1 -0
- package/packages/subagent/dist/SkillInvoker.d.ts +33 -0
- package/packages/subagent/dist/SkillInvoker.d.ts.map +1 -0
- package/packages/subagent/dist/SkillInvoker.js +69 -0
- package/packages/subagent/dist/SkillInvoker.js.map +1 -0
- package/packages/subagent/dist/SubagentOrchestrator.d.ts +52 -0
- package/packages/subagent/dist/SubagentOrchestrator.d.ts.map +1 -0
- package/packages/subagent/dist/SubagentOrchestrator.js +198 -0
- package/packages/subagent/dist/SubagentOrchestrator.js.map +1 -0
- package/packages/subagent/dist/SubagentResult.d.ts +34 -0
- package/packages/subagent/dist/SubagentResult.d.ts.map +1 -0
- package/packages/subagent/dist/SubagentResult.js +21 -0
- package/packages/subagent/dist/SubagentResult.js.map +1 -0
- package/packages/subagent/dist/Watchdog.d.ts +23 -0
- package/packages/subagent/dist/Watchdog.d.ts.map +1 -0
- package/packages/subagent/dist/Watchdog.js +44 -0
- package/packages/subagent/dist/Watchdog.js.map +1 -0
- package/packages/subagent/dist/index.d.ts +15 -0
- package/packages/subagent/dist/index.d.ts.map +1 -0
- package/packages/subagent/dist/index.js +23 -0
- package/packages/subagent/dist/index.js.map +1 -0
- package/packages/subagent/dist/sandbox/BwrapBackend.d.ts +14 -0
- package/packages/subagent/dist/sandbox/BwrapBackend.d.ts.map +1 -0
- package/packages/subagent/dist/sandbox/BwrapBackend.js +171 -0
- package/packages/subagent/dist/sandbox/BwrapBackend.js.map +1 -0
- package/packages/subagent/dist/sandbox/CloudBackend.d.ts +28 -0
- package/packages/subagent/dist/sandbox/CloudBackend.d.ts.map +1 -0
- package/packages/subagent/dist/sandbox/CloudBackend.js +52 -0
- package/packages/subagent/dist/sandbox/CloudBackend.js.map +1 -0
- package/packages/subagent/dist/sandbox/DockerBackend.d.ts +14 -0
- package/packages/subagent/dist/sandbox/DockerBackend.d.ts.map +1 -0
- package/packages/subagent/dist/sandbox/DockerBackend.js +149 -0
- package/packages/subagent/dist/sandbox/DockerBackend.js.map +1 -0
- package/packages/subagent/dist/sandbox/FirecrackerBackend.d.ts +17 -0
- package/packages/subagent/dist/sandbox/FirecrackerBackend.d.ts.map +1 -0
- package/packages/subagent/dist/sandbox/FirecrackerBackend.js +54 -0
- package/packages/subagent/dist/sandbox/FirecrackerBackend.js.map +1 -0
- package/packages/subagent/dist/sandbox/PodmanBackend.d.ts +13 -0
- package/packages/subagent/dist/sandbox/PodmanBackend.d.ts.map +1 -0
- package/packages/subagent/dist/sandbox/PodmanBackend.js +144 -0
- package/packages/subagent/dist/sandbox/PodmanBackend.js.map +1 -0
- package/packages/subagent/dist/sandbox/ProcessBackend.d.ts +16 -0
- package/packages/subagent/dist/sandbox/ProcessBackend.d.ts.map +1 -0
- package/packages/subagent/dist/sandbox/ProcessBackend.js +152 -0
- package/packages/subagent/dist/sandbox/ProcessBackend.js.map +1 -0
- package/packages/subagent/dist/sandbox/SandboxManager.d.ts +17 -0
- package/packages/subagent/dist/sandbox/SandboxManager.d.ts.map +1 -0
- package/packages/subagent/dist/sandbox/SandboxManager.js +45 -0
- package/packages/subagent/dist/sandbox/SandboxManager.js.map +1 -0
- package/packages/subagent/dist/sandbox/types.d.ts +35 -0
- package/packages/subagent/dist/sandbox/types.d.ts.map +1 -0
- package/packages/subagent/dist/sandbox/types.js +5 -0
- package/packages/subagent/dist/sandbox/types.js.map +1 -0
- package/packages/subagent-runtime/dist/AgentLoop.d.ts +46 -0
- package/packages/subagent-runtime/dist/AgentLoop.d.ts.map +1 -0
- package/packages/subagent-runtime/dist/AgentLoop.js +85 -0
- package/packages/subagent-runtime/dist/AgentLoop.js.map +1 -0
- package/packages/subagent-runtime/dist/MCPProxy.d.ts +24 -0
- package/packages/subagent-runtime/dist/MCPProxy.d.ts.map +1 -0
- package/packages/subagent-runtime/dist/MCPProxy.js +31 -0
- package/packages/subagent-runtime/dist/MCPProxy.js.map +1 -0
- package/packages/subagent-runtime/dist/OutputChannel.d.ts +10 -0
- package/packages/subagent-runtime/dist/OutputChannel.d.ts.map +1 -0
- package/packages/subagent-runtime/dist/OutputChannel.js +14 -0
- package/packages/subagent-runtime/dist/OutputChannel.js.map +1 -0
- package/packages/subagent-runtime/dist/ResourceTracker.d.ts +29 -0
- package/packages/subagent-runtime/dist/ResourceTracker.d.ts.map +1 -0
- package/packages/subagent-runtime/dist/ResourceTracker.js +46 -0
- package/packages/subagent-runtime/dist/ResourceTracker.js.map +1 -0
- package/packages/subagent-runtime/dist/TokenValidator.d.ts +17 -0
- package/packages/subagent-runtime/dist/TokenValidator.d.ts.map +1 -0
- package/packages/subagent-runtime/dist/TokenValidator.js +29 -0
- package/packages/subagent-runtime/dist/TokenValidator.js.map +1 -0
- package/packages/subagent-runtime/dist/index.d.ts +6 -0
- package/packages/subagent-runtime/dist/index.d.ts.map +1 -0
- package/packages/subagent-runtime/dist/index.js +11 -0
- package/packages/subagent-runtime/dist/index.js.map +1 -0
- package/packages/subagent-runtime/dist/main.d.ts +2 -0
- package/packages/subagent-runtime/dist/main.d.ts.map +1 -0
- package/packages/subagent-runtime/dist/main.js +102 -0
- package/packages/subagent-runtime/dist/main.js.map +1 -0
- package/seeds/b2b-outbound/package.json +6 -0
- package/seeds/research/package.json +6 -0
- package/seeds/software-engineering/install.ts +78 -0
- package/seeds/software-engineering/package.json +6 -0
- package/seeds/software-engineering/sprint-workflow.json +102 -0
- package/skills/build.yaml +97 -0
- package/skills/debug.yaml +117 -0
- package/skills/design-review.yaml +119 -0
- package/skills/doc.yaml +107 -0
- package/skills/office-hours.yaml +76 -0
- package/skills/plan-ceo-review.yaml +84 -0
- package/skills/plan-eng-review.yaml +96 -0
- package/skills/qa.yaml +116 -0
- package/skills/refactor.yaml +125 -0
- package/skills/research.yaml +108 -0
- package/skills/retro.yaml +106 -0
- package/skills/review.yaml +101 -0
- package/skills/security-audit.yaml +114 -0
- package/skills/ship.yaml +108 -0
- package/skills/test-writer.yaml +131 -0
|
@@ -0,0 +1,154 @@
|
|
|
1
|
+
export class GraphRollback {
|
|
2
|
+
graph;
|
|
3
|
+
adapter;
|
|
4
|
+
weightLog;
|
|
5
|
+
checkpointManager;
|
|
6
|
+
constructor(graph, adapter, weightLog, checkpointManager) {
|
|
7
|
+
this.graph = graph;
|
|
8
|
+
this.adapter = adapter;
|
|
9
|
+
this.weightLog = weightLog;
|
|
10
|
+
this.checkpointManager = checkpointManager;
|
|
11
|
+
}
|
|
12
|
+
/**
|
|
13
|
+
* Dispatch to the appropriate rollback strategy based on mode.
|
|
14
|
+
*/
|
|
15
|
+
async rollback(mode) {
|
|
16
|
+
switch (mode.type) {
|
|
17
|
+
case 'checkpoint':
|
|
18
|
+
return this.rollbackToCheckpoint(mode.checkpoint_id);
|
|
19
|
+
case 'trace':
|
|
20
|
+
return this.rollbackTrace(mode.trace_id);
|
|
21
|
+
case 'verifier':
|
|
22
|
+
return this.rollbackVerifier(mode.verifier_name);
|
|
23
|
+
}
|
|
24
|
+
}
|
|
25
|
+
// ── Mode 1: Checkpoint ──────────────────────────────────────────────
|
|
26
|
+
//
|
|
27
|
+
// Reverse all weight_events created after the checkpoint timestamp.
|
|
28
|
+
// For each event (newest first): restore the edge to event.old_weight.
|
|
29
|
+
// Re-insert any nodes/edges from the checkpoint snapshot that no longer
|
|
30
|
+
// exist in the live graph.
|
|
31
|
+
async rollbackToCheckpoint(checkpointId) {
|
|
32
|
+
const checkpoint = this.checkpointManager.get(checkpointId);
|
|
33
|
+
if (!checkpoint) {
|
|
34
|
+
throw new Error(`Checkpoint not found: ${checkpointId}`);
|
|
35
|
+
}
|
|
36
|
+
const snapshot = await this.checkpointManager.getSnapshot(checkpointId);
|
|
37
|
+
if (!snapshot) {
|
|
38
|
+
throw new Error(`Checkpoint snapshot could not be loaded: ${checkpointId}`);
|
|
39
|
+
}
|
|
40
|
+
const result = {
|
|
41
|
+
mode: { type: 'checkpoint', checkpoint_id: checkpointId },
|
|
42
|
+
edges_reverted: 0,
|
|
43
|
+
nodes_restored: 0,
|
|
44
|
+
traces_undone: 0,
|
|
45
|
+
weight_events_reversed: 0,
|
|
46
|
+
};
|
|
47
|
+
// Collect all weight events after the checkpoint timestamp by scanning
|
|
48
|
+
// edges present in the snapshot. We go through each snapshot edge and
|
|
49
|
+
// check its event history.
|
|
50
|
+
const eventsAfterCheckpoint = [];
|
|
51
|
+
const snapshotEdgeIds = new Set(snapshot.edges.map((e) => e.id));
|
|
52
|
+
// Also check edges that might exist now but not in the snapshot
|
|
53
|
+
const currentEdges = this.graph.getAllEdges();
|
|
54
|
+
const allEdgeIds = new Set([
|
|
55
|
+
...snapshotEdgeIds,
|
|
56
|
+
...currentEdges.map((e) => e.id),
|
|
57
|
+
]);
|
|
58
|
+
for (const edgeId of allEdgeIds) {
|
|
59
|
+
const events = this.weightLog.getByEdge(edgeId);
|
|
60
|
+
for (const evt of events) {
|
|
61
|
+
if (evt.created_at > checkpoint.created_at) {
|
|
62
|
+
eventsAfterCheckpoint.push(evt);
|
|
63
|
+
}
|
|
64
|
+
}
|
|
65
|
+
}
|
|
66
|
+
// Sort newest first and reverse each event
|
|
67
|
+
eventsAfterCheckpoint.sort((a, b) => b.created_at - a.created_at);
|
|
68
|
+
for (const evt of eventsAfterCheckpoint) {
|
|
69
|
+
const edge = this.adapter.getEdge(evt.edge_id);
|
|
70
|
+
if (edge) {
|
|
71
|
+
this.adapter.forceUpdateEdgeWeight(evt.edge_id, evt.old_weight);
|
|
72
|
+
result.edges_reverted++;
|
|
73
|
+
}
|
|
74
|
+
result.weight_events_reversed++;
|
|
75
|
+
}
|
|
76
|
+
// Re-insert nodes from snapshot that are missing in the live graph
|
|
77
|
+
for (const snapshotNode of snapshot.nodes) {
|
|
78
|
+
const existing = this.graph.getNode(snapshotNode.id);
|
|
79
|
+
if (!existing) {
|
|
80
|
+
this.graph.addNode(snapshotNode);
|
|
81
|
+
result.nodes_restored++;
|
|
82
|
+
}
|
|
83
|
+
}
|
|
84
|
+
// Re-insert edges from snapshot that are missing in the live graph
|
|
85
|
+
for (const snapshotEdge of snapshot.edges) {
|
|
86
|
+
const existing = this.adapter.getEdge(snapshotEdge.id);
|
|
87
|
+
if (!existing) {
|
|
88
|
+
this.graph.addEdge(snapshotEdge);
|
|
89
|
+
result.edges_reverted++;
|
|
90
|
+
}
|
|
91
|
+
}
|
|
92
|
+
return result;
|
|
93
|
+
}
|
|
94
|
+
// ── Mode 2: Trace ──────────────────────────────────────────────────
|
|
95
|
+
//
|
|
96
|
+
// Reverse all weight_events associated with this trace_id.
|
|
97
|
+
// For each (newest first): restore the edge to event.old_weight.
|
|
98
|
+
async rollbackTrace(traceId) {
|
|
99
|
+
const events = this.weightLog.getByTrace(traceId);
|
|
100
|
+
const result = {
|
|
101
|
+
mode: { type: 'trace', trace_id: traceId },
|
|
102
|
+
edges_reverted: 0,
|
|
103
|
+
nodes_restored: 0,
|
|
104
|
+
traces_undone: 1,
|
|
105
|
+
weight_events_reversed: 0,
|
|
106
|
+
};
|
|
107
|
+
if (events.length === 0) {
|
|
108
|
+
result.traces_undone = 0;
|
|
109
|
+
return result;
|
|
110
|
+
}
|
|
111
|
+
// Sort newest first to reverse in correct order
|
|
112
|
+
const sorted = [...events].sort((a, b) => b.created_at - a.created_at);
|
|
113
|
+
for (const evt of sorted) {
|
|
114
|
+
const edge = this.adapter.getEdge(evt.edge_id);
|
|
115
|
+
if (edge) {
|
|
116
|
+
this.adapter.forceUpdateEdgeWeight(evt.edge_id, evt.old_weight);
|
|
117
|
+
result.edges_reverted++;
|
|
118
|
+
}
|
|
119
|
+
result.weight_events_reversed++;
|
|
120
|
+
}
|
|
121
|
+
return result;
|
|
122
|
+
}
|
|
123
|
+
// ── Mode 3: Verifier ──────────────────────────────────────────────
|
|
124
|
+
//
|
|
125
|
+
// Find all traces whose metadata references this verifier name,
|
|
126
|
+
// then rollback each trace individually.
|
|
127
|
+
async rollbackVerifier(verifierName) {
|
|
128
|
+
const result = {
|
|
129
|
+
mode: { type: 'verifier', verifier_name: verifierName },
|
|
130
|
+
edges_reverted: 0,
|
|
131
|
+
nodes_restored: 0,
|
|
132
|
+
traces_undone: 0,
|
|
133
|
+
weight_events_reversed: 0,
|
|
134
|
+
};
|
|
135
|
+
// Query all traces (paginated scan) and filter for ones resolved by this verifier.
|
|
136
|
+
// The verifier name is stored in trace metadata under "verifier" or "verifier_name".
|
|
137
|
+
const allTraces = this.adapter.queryTraces({ limit: 100_000 });
|
|
138
|
+
const matchingTraces = allTraces.filter((t) => {
|
|
139
|
+
const meta = t.metadata;
|
|
140
|
+
return (meta.verifier === verifierName ||
|
|
141
|
+
meta.verifier_name === verifierName ||
|
|
142
|
+
meta.resolved_by === verifierName);
|
|
143
|
+
});
|
|
144
|
+
for (const trace of matchingTraces) {
|
|
145
|
+
const traceResult = await this.rollbackTrace(trace.id);
|
|
146
|
+
result.edges_reverted += traceResult.edges_reverted;
|
|
147
|
+
result.nodes_restored += traceResult.nodes_restored;
|
|
148
|
+
result.traces_undone += traceResult.traces_undone;
|
|
149
|
+
result.weight_events_reversed += traceResult.weight_events_reversed;
|
|
150
|
+
}
|
|
151
|
+
return result;
|
|
152
|
+
}
|
|
153
|
+
}
|
|
154
|
+
//# sourceMappingURL=GraphRollback.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"GraphRollback.js","sourceRoot":"","sources":["../../src/maintenance/GraphRollback.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,26 @@
|
|
|
1
|
+
import type { KnowledgeGraph } from '../graph/KnowledgeGraph.js';
|
|
2
|
+
export interface DeduplicationConfig {
|
|
3
|
+
cosine_threshold: number;
|
|
4
|
+
dry_run: boolean;
|
|
5
|
+
}
|
|
6
|
+
export interface MergeCandidate {
|
|
7
|
+
node_a_id: string;
|
|
8
|
+
node_b_id: string;
|
|
9
|
+
similarity: number;
|
|
10
|
+
surviving_node_id: string;
|
|
11
|
+
removed_node_id: string;
|
|
12
|
+
}
|
|
13
|
+
export interface DeduplicationResult {
|
|
14
|
+
merged_count: number;
|
|
15
|
+
candidates_found: number;
|
|
16
|
+
candidates: MergeCandidate[];
|
|
17
|
+
}
|
|
18
|
+
export declare class NodeDeduplicator {
|
|
19
|
+
private graph;
|
|
20
|
+
constructor(graph: KnowledgeGraph);
|
|
21
|
+
run(config?: Partial<DeduplicationConfig>): DeduplicationResult;
|
|
22
|
+
mergeNodes(candidate: MergeCandidate): void;
|
|
23
|
+
private cosineSimilarity;
|
|
24
|
+
private deepMerge;
|
|
25
|
+
}
|
|
26
|
+
//# sourceMappingURL=NodeDeduplicator.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"NodeDeduplicator.d.ts","sourceRoot":"","sources":["../../src/maintenance/NodeDeduplicator.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,cAAc,EAAE,MAAM,4BAA4B,CAAC;AAIjE,MAAM,WAAW,mBAAmB;IAClC,gBAAgB,EAAE,MAAM,CAAC;IACzB,OAAO,EAAE,OAAO,CAAC;CAClB;AAED,MAAM,WAAW,cAAc;IAC7B,SAAS,EAAE,MAAM,CAAC;IAClB,SAAS,EAAE,MAAM,CAAC;IAClB,UAAU,EAAE,MAAM,CAAC;IACnB,iBAAiB,EAAE,MAAM,CAAC;IAC1B,eAAe,EAAE,MAAM,CAAC;CACzB;AAED,MAAM,WAAW,mBAAmB;IAClC,YAAY,EAAE,MAAM,CAAC;IACrB,gBAAgB,EAAE,MAAM,CAAC;IACzB,UAAU,EAAE,cAAc,EAAE,CAAC;CAC9B;AAOD,qBAAa,gBAAgB;IACf,OAAO,CAAC,KAAK;gBAAL,KAAK,EAAE,cAAc;IAEzC,GAAG,CAAC,MAAM,CAAC,EAAE,OAAO,CAAC,mBAAmB,CAAC,GAAG,mBAAmB;IAwE/D,UAAU,CAAC,SAAS,EAAE,cAAc,GAAG,IAAI;IA4E3C,OAAO,CAAC,gBAAgB;IAmBxB,OAAO,CAAC,SAAS;CA6BlB"}
|
|
@@ -0,0 +1,171 @@
|
|
|
1
|
+
const DEFAULT_CONFIG = {
|
|
2
|
+
cosine_threshold: 0.92,
|
|
3
|
+
dry_run: false,
|
|
4
|
+
};
|
|
5
|
+
export class NodeDeduplicator {
|
|
6
|
+
graph;
|
|
7
|
+
constructor(graph) {
|
|
8
|
+
this.graph = graph;
|
|
9
|
+
}
|
|
10
|
+
run(config) {
|
|
11
|
+
const cfg = { ...DEFAULT_CONFIG, ...config };
|
|
12
|
+
const result = {
|
|
13
|
+
merged_count: 0,
|
|
14
|
+
candidates_found: 0,
|
|
15
|
+
candidates: [],
|
|
16
|
+
};
|
|
17
|
+
// Collect all nodes that have embeddings, grouped by type
|
|
18
|
+
const allEdges = this.graph.getAllEdges();
|
|
19
|
+
const nodeIds = new Set();
|
|
20
|
+
for (const edge of allEdges) {
|
|
21
|
+
nodeIds.add(edge.from_node);
|
|
22
|
+
nodeIds.add(edge.to_node);
|
|
23
|
+
}
|
|
24
|
+
// Also gather nodes from the graph by resolving each unique id
|
|
25
|
+
const nodesWithEmbeddings = [];
|
|
26
|
+
for (const id of nodeIds) {
|
|
27
|
+
const node = this.graph.getNode(id);
|
|
28
|
+
if (node && node.embedding) {
|
|
29
|
+
nodesWithEmbeddings.push(node);
|
|
30
|
+
}
|
|
31
|
+
}
|
|
32
|
+
// Track which nodes have been removed so we don't merge already-removed nodes
|
|
33
|
+
const removedIds = new Set();
|
|
34
|
+
// Pairwise cosine similarity (O(n^2) — acceptable for weekly maintenance)
|
|
35
|
+
for (let i = 0; i < nodesWithEmbeddings.length; i++) {
|
|
36
|
+
if (removedIds.has(nodesWithEmbeddings[i].id))
|
|
37
|
+
continue;
|
|
38
|
+
for (let j = i + 1; j < nodesWithEmbeddings.length; j++) {
|
|
39
|
+
if (removedIds.has(nodesWithEmbeddings[j].id))
|
|
40
|
+
continue;
|
|
41
|
+
const nodeA = nodesWithEmbeddings[i];
|
|
42
|
+
const nodeB = nodesWithEmbeddings[j];
|
|
43
|
+
// Never merge different types
|
|
44
|
+
if (nodeA.type !== nodeB.type)
|
|
45
|
+
continue;
|
|
46
|
+
const similarity = this.cosineSimilarity(nodeA.embedding, nodeB.embedding);
|
|
47
|
+
if (similarity < cfg.cosine_threshold)
|
|
48
|
+
continue;
|
|
49
|
+
// Surviving node = higher visit_count
|
|
50
|
+
const surviving = nodeA.visit_count >= nodeB.visit_count ? nodeA : nodeB;
|
|
51
|
+
const removed = surviving === nodeA ? nodeB : nodeA;
|
|
52
|
+
const candidate = {
|
|
53
|
+
node_a_id: nodeA.id,
|
|
54
|
+
node_b_id: nodeB.id,
|
|
55
|
+
similarity,
|
|
56
|
+
surviving_node_id: surviving.id,
|
|
57
|
+
removed_node_id: removed.id,
|
|
58
|
+
};
|
|
59
|
+
result.candidates_found++;
|
|
60
|
+
result.candidates.push(candidate);
|
|
61
|
+
if (!cfg.dry_run) {
|
|
62
|
+
this.mergeNodes(candidate);
|
|
63
|
+
removedIds.add(removed.id);
|
|
64
|
+
result.merged_count++;
|
|
65
|
+
}
|
|
66
|
+
}
|
|
67
|
+
}
|
|
68
|
+
return result;
|
|
69
|
+
}
|
|
70
|
+
mergeNodes(candidate) {
|
|
71
|
+
const surviving = this.graph.getNode(candidate.surviving_node_id);
|
|
72
|
+
const removed = this.graph.getNode(candidate.removed_node_id);
|
|
73
|
+
if (!surviving || !removed)
|
|
74
|
+
return;
|
|
75
|
+
// Merge visit counts
|
|
76
|
+
const newVisitCount = surviving.visit_count + removed.visit_count;
|
|
77
|
+
// Deep merge metadata (surviving wins conflicts)
|
|
78
|
+
const newMetadata = this.deepMerge(removed.metadata, surviving.metadata);
|
|
79
|
+
this.graph.updateNode(surviving.id, {
|
|
80
|
+
metadata: { ...newMetadata, _visit_count_merged: newVisitCount },
|
|
81
|
+
});
|
|
82
|
+
// We need to update visit_count — but updateNode only supports label/metadata/embedding fields.
|
|
83
|
+
// Re-read, delete, and re-insert with correct visit_count via the node itself.
|
|
84
|
+
const updatedSurviving = this.graph.getNode(surviving.id);
|
|
85
|
+
if (updatedSurviving) {
|
|
86
|
+
// Manually fix visit_count through delete/re-add cycle
|
|
87
|
+
this.graph.deleteNode(surviving.id);
|
|
88
|
+
updatedSurviving.visit_count = newVisitCount;
|
|
89
|
+
updatedSurviving.metadata = newMetadata;
|
|
90
|
+
delete updatedSurviving.metadata._visit_count_merged;
|
|
91
|
+
this.graph.addNode(updatedSurviving);
|
|
92
|
+
}
|
|
93
|
+
// Re-point all edges from removed node → surviving node
|
|
94
|
+
const removedEdges = this.graph.getEdgesByNode(removed.id, 'both');
|
|
95
|
+
for (const edge of removedEdges) {
|
|
96
|
+
const isFrom = edge.from_node === removed.id;
|
|
97
|
+
const newFrom = isFrom ? surviving.id : edge.from_node;
|
|
98
|
+
const newTo = isFrom ? edge.to_node : surviving.id;
|
|
99
|
+
// Skip self-loops that would form
|
|
100
|
+
if (newFrom === newTo) {
|
|
101
|
+
this.graph.deleteEdge(edge.id);
|
|
102
|
+
continue;
|
|
103
|
+
}
|
|
104
|
+
// Check if a duplicate edge already exists between these nodes
|
|
105
|
+
const existingEdges = this.graph.getEdgesBetween(newFrom, newTo);
|
|
106
|
+
const duplicateEdge = existingEdges.find((e) => e.type === edge.type);
|
|
107
|
+
if (duplicateEdge) {
|
|
108
|
+
// Merge weights: take max weight, sum traversal counts
|
|
109
|
+
const mergedWeight = Math.max(duplicateEdge.weight, edge.weight);
|
|
110
|
+
const mergedTraversalCount = duplicateEdge.traversal_count + edge.traversal_count;
|
|
111
|
+
// Delete both and re-create merged edge
|
|
112
|
+
this.graph.deleteEdge(edge.id);
|
|
113
|
+
this.graph.deleteEdge(duplicateEdge.id);
|
|
114
|
+
const mergedEdge = {
|
|
115
|
+
...duplicateEdge,
|
|
116
|
+
weight: mergedWeight,
|
|
117
|
+
traversal_count: mergedTraversalCount,
|
|
118
|
+
};
|
|
119
|
+
this.graph.addEdge(mergedEdge);
|
|
120
|
+
}
|
|
121
|
+
else {
|
|
122
|
+
// Re-point edge
|
|
123
|
+
this.graph.deleteEdge(edge.id);
|
|
124
|
+
const repointed = {
|
|
125
|
+
...edge,
|
|
126
|
+
from_node: newFrom,
|
|
127
|
+
to_node: newTo,
|
|
128
|
+
};
|
|
129
|
+
this.graph.addEdge(repointed);
|
|
130
|
+
}
|
|
131
|
+
}
|
|
132
|
+
// Delete the removed node
|
|
133
|
+
this.graph.deleteNode(removed.id);
|
|
134
|
+
}
|
|
135
|
+
cosineSimilarity(a, b) {
|
|
136
|
+
if (a.length !== b.length)
|
|
137
|
+
return 0;
|
|
138
|
+
let dotProduct = 0;
|
|
139
|
+
let normA = 0;
|
|
140
|
+
let normB = 0;
|
|
141
|
+
for (let i = 0; i < a.length; i++) {
|
|
142
|
+
dotProduct += a[i] * b[i];
|
|
143
|
+
normA += a[i] * a[i];
|
|
144
|
+
normB += b[i] * b[i];
|
|
145
|
+
}
|
|
146
|
+
const denominator = Math.sqrt(normA) * Math.sqrt(normB);
|
|
147
|
+
if (denominator === 0)
|
|
148
|
+
return 0;
|
|
149
|
+
return dotProduct / denominator;
|
|
150
|
+
}
|
|
151
|
+
deepMerge(base, override) {
|
|
152
|
+
const result = { ...base };
|
|
153
|
+
for (const key of Object.keys(override)) {
|
|
154
|
+
const baseVal = base[key];
|
|
155
|
+
const overrideVal = override[key];
|
|
156
|
+
if (typeof baseVal === 'object' &&
|
|
157
|
+
baseVal !== null &&
|
|
158
|
+
!Array.isArray(baseVal) &&
|
|
159
|
+
typeof overrideVal === 'object' &&
|
|
160
|
+
overrideVal !== null &&
|
|
161
|
+
!Array.isArray(overrideVal)) {
|
|
162
|
+
result[key] = this.deepMerge(baseVal, overrideVal);
|
|
163
|
+
}
|
|
164
|
+
else {
|
|
165
|
+
result[key] = overrideVal;
|
|
166
|
+
}
|
|
167
|
+
}
|
|
168
|
+
return result;
|
|
169
|
+
}
|
|
170
|
+
}
|
|
171
|
+
//# sourceMappingURL=NodeDeduplicator.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"NodeDeduplicator.js","sourceRoot":"","sources":["../../src/maintenance/NodeDeduplicator.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,18 @@
|
|
|
1
|
+
import type { KnowledgeGraph } from '../graph/KnowledgeGraph.js';
|
|
2
|
+
import type { ObjectStore } from '../storage/ObjectStore.js';
|
|
3
|
+
export interface ArchivalConfig {
|
|
4
|
+
inactive_days: number;
|
|
5
|
+
dry_run: boolean;
|
|
6
|
+
}
|
|
7
|
+
export interface ArchivalResult {
|
|
8
|
+
archived_count: number;
|
|
9
|
+
archived_subgraph_ids: string[];
|
|
10
|
+
}
|
|
11
|
+
export declare class SubgraphArchiver {
|
|
12
|
+
private graph;
|
|
13
|
+
private objectStore;
|
|
14
|
+
constructor(graph: KnowledgeGraph, objectStore: ObjectStore);
|
|
15
|
+
archiveCold(config?: Partial<ArchivalConfig>): Promise<ArchivalResult>;
|
|
16
|
+
restore(entityId: string): Promise<boolean>;
|
|
17
|
+
}
|
|
18
|
+
//# sourceMappingURL=SubgraphArchiver.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"SubgraphArchiver.d.ts","sourceRoot":"","sources":["../../src/maintenance/SubgraphArchiver.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,cAAc,EAAE,MAAM,4BAA4B,CAAC;AACjE,OAAO,KAAK,EAAE,WAAW,EAAE,MAAM,2BAA2B,CAAC;AAK7D,MAAM,WAAW,cAAc;IAC7B,aAAa,EAAE,MAAM,CAAC;IACtB,OAAO,EAAE,OAAO,CAAC;CAClB;AAED,MAAM,WAAW,cAAc;IAC7B,cAAc,EAAE,MAAM,CAAC;IACvB,qBAAqB,EAAE,MAAM,EAAE,CAAC;CACjC;AAcD,qBAAa,gBAAgB;IAEzB,OAAO,CAAC,KAAK;IACb,OAAO,CAAC,WAAW;gBADX,KAAK,EAAE,cAAc,EACrB,WAAW,EAAE,WAAW;IAG5B,WAAW,CAAC,MAAM,CAAC,EAAE,OAAO,CAAC,cAAc,CAAC,GAAG,OAAO,CAAC,cAAc,CAAC;IAyItE,OAAO,CAAC,QAAQ,EAAE,MAAM,GAAG,OAAO,CAAC,OAAO,CAAC;CAkDlD"}
|
|
@@ -0,0 +1,180 @@
|
|
|
1
|
+
import { NodeType } from '../graph/GraphNode.js';
|
|
2
|
+
const DEFAULT_CONFIG = {
|
|
3
|
+
inactive_days: 30,
|
|
4
|
+
dry_run: false,
|
|
5
|
+
};
|
|
6
|
+
export class SubgraphArchiver {
|
|
7
|
+
graph;
|
|
8
|
+
objectStore;
|
|
9
|
+
constructor(graph, objectStore) {
|
|
10
|
+
this.graph = graph;
|
|
11
|
+
this.objectStore = objectStore;
|
|
12
|
+
}
|
|
13
|
+
async archiveCold(config) {
|
|
14
|
+
const cfg = { ...DEFAULT_CONFIG, ...config };
|
|
15
|
+
const result = {
|
|
16
|
+
archived_count: 0,
|
|
17
|
+
archived_subgraph_ids: [],
|
|
18
|
+
};
|
|
19
|
+
const inactiveThresholdMs = cfg.inactive_days * 24 * 60 * 60 * 1000;
|
|
20
|
+
const now = Date.now();
|
|
21
|
+
// Find entity nodes not accessed in inactive_days
|
|
22
|
+
const allEdges = this.graph.getAllEdges();
|
|
23
|
+
const nodeIds = new Set();
|
|
24
|
+
for (const edge of allEdges) {
|
|
25
|
+
nodeIds.add(edge.from_node);
|
|
26
|
+
nodeIds.add(edge.to_node);
|
|
27
|
+
}
|
|
28
|
+
const entityNodes = [];
|
|
29
|
+
for (const id of nodeIds) {
|
|
30
|
+
const node = this.graph.getNode(id);
|
|
31
|
+
if (node &&
|
|
32
|
+
node.type === NodeType.ENTITY &&
|
|
33
|
+
now - node.last_seen >= inactiveThresholdMs) {
|
|
34
|
+
entityNodes.push(node);
|
|
35
|
+
}
|
|
36
|
+
}
|
|
37
|
+
for (const entity of entityNodes) {
|
|
38
|
+
// Get the subgraph rooted at this entity
|
|
39
|
+
let subgraph;
|
|
40
|
+
try {
|
|
41
|
+
subgraph = this.graph.getSubGraph(entity.id, 2);
|
|
42
|
+
}
|
|
43
|
+
catch {
|
|
44
|
+
// Entity may have been removed by a prior archival in this run
|
|
45
|
+
continue;
|
|
46
|
+
}
|
|
47
|
+
const nodes = [];
|
|
48
|
+
const edges = [];
|
|
49
|
+
// Collect nodes from the subgraph
|
|
50
|
+
// SubGraph stores nodes/edges internally; walk via the entity's edges
|
|
51
|
+
const subgraphEdges = this.graph.getEdgesByNode(entity.id, 'both');
|
|
52
|
+
const visitedNodes = new Set([entity.id]);
|
|
53
|
+
const nodeQueue = [entity.id];
|
|
54
|
+
// BFS to depth 2
|
|
55
|
+
let depth = 0;
|
|
56
|
+
while (nodeQueue.length > 0 && depth < 2) {
|
|
57
|
+
const levelSize = nodeQueue.length;
|
|
58
|
+
for (let i = 0; i < levelSize; i++) {
|
|
59
|
+
const currentId = nodeQueue.shift();
|
|
60
|
+
const currentEdges = this.graph.getEdgesByNode(currentId, 'both');
|
|
61
|
+
for (const edge of currentEdges) {
|
|
62
|
+
if (!edges.find((e) => e.id === edge.id)) {
|
|
63
|
+
edges.push(edge);
|
|
64
|
+
}
|
|
65
|
+
const neighborId = edge.from_node === currentId ? edge.to_node : edge.from_node;
|
|
66
|
+
if (!visitedNodes.has(neighborId)) {
|
|
67
|
+
visitedNodes.add(neighborId);
|
|
68
|
+
const neighborNode = this.graph.getNode(neighborId);
|
|
69
|
+
if (neighborNode) {
|
|
70
|
+
nodeQueue.push(neighborId);
|
|
71
|
+
}
|
|
72
|
+
}
|
|
73
|
+
}
|
|
74
|
+
}
|
|
75
|
+
depth++;
|
|
76
|
+
}
|
|
77
|
+
// Gather all visited nodes
|
|
78
|
+
for (const nodeId of visitedNodes) {
|
|
79
|
+
const node = this.graph.getNode(nodeId);
|
|
80
|
+
if (node) {
|
|
81
|
+
// Serialize embedding for JSON storage
|
|
82
|
+
nodes.push({
|
|
83
|
+
...node,
|
|
84
|
+
embedding: node.embedding
|
|
85
|
+
? new Float32Array(node.embedding)
|
|
86
|
+
: null,
|
|
87
|
+
});
|
|
88
|
+
}
|
|
89
|
+
}
|
|
90
|
+
const archive = {
|
|
91
|
+
entity_id: entity.id,
|
|
92
|
+
nodes,
|
|
93
|
+
edges,
|
|
94
|
+
archived_at: now,
|
|
95
|
+
};
|
|
96
|
+
// Serialize to JSON — convert Float32Array to regular arrays for storage
|
|
97
|
+
const serialized = JSON.stringify(archive, (_key, value) => {
|
|
98
|
+
if (value instanceof Float32Array) {
|
|
99
|
+
return { __type: 'Float32Array', data: Array.from(value) };
|
|
100
|
+
}
|
|
101
|
+
return value;
|
|
102
|
+
});
|
|
103
|
+
if (!cfg.dry_run) {
|
|
104
|
+
// Store in object store
|
|
105
|
+
await this.objectStore.put(Buffer.from(serialized, 'utf-8'), {
|
|
106
|
+
prefix: 'archived-subgraphs',
|
|
107
|
+
extension: `.${entity.id}.json`,
|
|
108
|
+
});
|
|
109
|
+
// Remove nodes and edges from the live graph
|
|
110
|
+
for (const edge of edges) {
|
|
111
|
+
try {
|
|
112
|
+
this.graph.deleteEdge(edge.id);
|
|
113
|
+
}
|
|
114
|
+
catch {
|
|
115
|
+
// Edge may already be deleted
|
|
116
|
+
}
|
|
117
|
+
}
|
|
118
|
+
for (const node of nodes) {
|
|
119
|
+
try {
|
|
120
|
+
this.graph.deleteNode(node.id);
|
|
121
|
+
}
|
|
122
|
+
catch {
|
|
123
|
+
// Node may already be deleted
|
|
124
|
+
}
|
|
125
|
+
}
|
|
126
|
+
}
|
|
127
|
+
result.archived_count++;
|
|
128
|
+
result.archived_subgraph_ids.push(entity.id);
|
|
129
|
+
}
|
|
130
|
+
return result;
|
|
131
|
+
}
|
|
132
|
+
async restore(entityId) {
|
|
133
|
+
// Attempt to read the archived subgraph from the object store
|
|
134
|
+
// The reference uses a known prefix pattern
|
|
135
|
+
let data;
|
|
136
|
+
try {
|
|
137
|
+
// We need to find the archive by entity ID — scan known prefix
|
|
138
|
+
const ref = `archived-subgraphs/${entityId}`;
|
|
139
|
+
// The object store uses UUID-based names, so we stored with extension containing entity id
|
|
140
|
+
// Try reading with the entity-based key
|
|
141
|
+
const exists = await this.objectStore.exists(ref);
|
|
142
|
+
if (!exists) {
|
|
143
|
+
return false;
|
|
144
|
+
}
|
|
145
|
+
data = await this.objectStore.get(ref);
|
|
146
|
+
}
|
|
147
|
+
catch {
|
|
148
|
+
return false;
|
|
149
|
+
}
|
|
150
|
+
const archive = JSON.parse(data.toString('utf-8'), (_key, value) => {
|
|
151
|
+
if (value && typeof value === 'object' && value.__type === 'Float32Array') {
|
|
152
|
+
return new Float32Array(value.data);
|
|
153
|
+
}
|
|
154
|
+
return value;
|
|
155
|
+
});
|
|
156
|
+
// Re-insert nodes into the live graph
|
|
157
|
+
for (const node of archive.nodes) {
|
|
158
|
+
const existing = this.graph.getNode(node.id);
|
|
159
|
+
if (!existing) {
|
|
160
|
+
this.graph.addNode(node);
|
|
161
|
+
}
|
|
162
|
+
}
|
|
163
|
+
// Re-insert edges into the live graph
|
|
164
|
+
for (const edge of archive.edges) {
|
|
165
|
+
const existing = this.graph.getEdge(edge.id);
|
|
166
|
+
if (!existing) {
|
|
167
|
+
this.graph.addEdge(edge);
|
|
168
|
+
}
|
|
169
|
+
}
|
|
170
|
+
// Clean up the archived file
|
|
171
|
+
try {
|
|
172
|
+
await this.objectStore.delete(`archived-subgraphs/${entityId}`);
|
|
173
|
+
}
|
|
174
|
+
catch {
|
|
175
|
+
// Best effort cleanup
|
|
176
|
+
}
|
|
177
|
+
return true;
|
|
178
|
+
}
|
|
179
|
+
}
|
|
180
|
+
//# sourceMappingURL=SubgraphArchiver.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"SubgraphArchiver.js","sourceRoot":"","sources":["../../src/maintenance/SubgraphArchiver.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,28 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* ArchivalMemory — Long-term compressed summaries for 0agent Phase 4.
|
|
3
|
+
*
|
|
4
|
+
* Stored in ObjectStore. Phase 4 stub: interface defined,
|
|
5
|
+
* full ObjectStore integration deferred to Phase 5.
|
|
6
|
+
*/
|
|
7
|
+
export interface ArchivalEntry {
|
|
8
|
+
id: string;
|
|
9
|
+
/** Period label, e.g. "2026-03-W12" */
|
|
10
|
+
period: string;
|
|
11
|
+
summary: string;
|
|
12
|
+
entity_ids: string[];
|
|
13
|
+
/** ObjectStore reference key */
|
|
14
|
+
object_ref: string;
|
|
15
|
+
created_at: number;
|
|
16
|
+
}
|
|
17
|
+
export declare class ArchivalMemory {
|
|
18
|
+
private entries;
|
|
19
|
+
/** Append an archival entry. */
|
|
20
|
+
add(entry: ArchivalEntry): void;
|
|
21
|
+
/** Find an entry by period label. */
|
|
22
|
+
getByPeriod(period: string): ArchivalEntry | undefined;
|
|
23
|
+
/** Get the N most recent entries. */
|
|
24
|
+
getRecent(n: number): ArchivalEntry[];
|
|
25
|
+
/** Total number of archival entries. */
|
|
26
|
+
get size(): number;
|
|
27
|
+
}
|
|
28
|
+
//# sourceMappingURL=ArchivalMemory.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"ArchivalMemory.d.ts","sourceRoot":"","sources":["../../src/memory/ArchivalMemory.ts"],"names":[],"mappings":"AAAA;;;;;GAKG;AAEH,MAAM,WAAW,aAAa;IAC5B,EAAE,EAAE,MAAM,CAAC;IACX,uCAAuC;IACvC,MAAM,EAAE,MAAM,CAAC;IACf,OAAO,EAAE,MAAM,CAAC;IAChB,UAAU,EAAE,MAAM,EAAE,CAAC;IACrB,gCAAgC;IAChC,UAAU,EAAE,MAAM,CAAC;IACnB,UAAU,EAAE,MAAM,CAAC;CACpB;AAED,qBAAa,cAAc;IACzB,OAAO,CAAC,OAAO,CAAuB;IAEtC,gCAAgC;IAChC,GAAG,CAAC,KAAK,EAAE,aAAa,GAAG,IAAI;IAI/B,qCAAqC;IACrC,WAAW,CAAC,MAAM,EAAE,MAAM,GAAG,aAAa,GAAG,SAAS;IAItD,qCAAqC;IACrC,SAAS,CAAC,CAAC,EAAE,MAAM,GAAG,aAAa,EAAE;IAIrC,wCAAwC;IACxC,IAAI,IAAI,IAAI,MAAM,CAEjB;CACF"}
|
|
@@ -0,0 +1,26 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* ArchivalMemory — Long-term compressed summaries for 0agent Phase 4.
|
|
3
|
+
*
|
|
4
|
+
* Stored in ObjectStore. Phase 4 stub: interface defined,
|
|
5
|
+
* full ObjectStore integration deferred to Phase 5.
|
|
6
|
+
*/
|
|
7
|
+
export class ArchivalMemory {
|
|
8
|
+
entries = [];
|
|
9
|
+
/** Append an archival entry. */
|
|
10
|
+
add(entry) {
|
|
11
|
+
this.entries.push(entry);
|
|
12
|
+
}
|
|
13
|
+
/** Find an entry by period label. */
|
|
14
|
+
getByPeriod(period) {
|
|
15
|
+
return this.entries.find((e) => e.period === period);
|
|
16
|
+
}
|
|
17
|
+
/** Get the N most recent entries. */
|
|
18
|
+
getRecent(n) {
|
|
19
|
+
return this.entries.slice(-n);
|
|
20
|
+
}
|
|
21
|
+
/** Total number of archival entries. */
|
|
22
|
+
get size() {
|
|
23
|
+
return this.entries.length;
|
|
24
|
+
}
|
|
25
|
+
}
|
|
26
|
+
//# sourceMappingURL=ArchivalMemory.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"ArchivalMemory.js","sourceRoot":"","sources":["../../src/memory/ArchivalMemory.ts"],"names":[],"mappings":"AAAA;;;;;GAKG;AAaH,MAAM,OAAO,cAAc;IACjB,OAAO,GAAoB,EAAE,CAAC;IAEtC,gCAAgC;IAChC,GAAG,CAAC,KAAoB;QACtB,IAAI,CAAC,OAAO,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC;IAC3B,CAAC;IAED,qCAAqC;IACrC,WAAW,CAAC,MAAc;QACxB,OAAO,IAAI,CAAC,OAAO,CAAC,IAAI,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC,CAAC,MAAM,KAAK,MAAM,CAAC,CAAC;IACvD,CAAC;IAED,qCAAqC;IACrC,SAAS,CAAC,CAAS;QACjB,OAAO,IAAI,CAAC,OAAO,CAAC,KAAK,CAAC,CAAC,CAAC,CAAC,CAAC;IAChC,CAAC;IAED,wCAAwC;IACxC,IAAI,IAAI;QACN,OAAO,IAAI,CAAC,OAAO,CAAC,MAAM,CAAC;IAC7B,CAAC;CACF"}
|