@omiron33/omi-neuron-web 0.1.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (55) hide show
  1. package/README.md +55 -0
  2. package/dist/api/index.cjs +943 -0
  3. package/dist/api/index.cjs.map +1 -0
  4. package/dist/api/index.d.cts +140 -0
  5. package/dist/api/index.d.ts +140 -0
  6. package/dist/api/index.js +934 -0
  7. package/dist/api/index.js.map +1 -0
  8. package/dist/chunk-BSOSHBDR.cjs +300 -0
  9. package/dist/chunk-BSOSHBDR.cjs.map +1 -0
  10. package/dist/chunk-COO66N7H.cjs +950 -0
  11. package/dist/chunk-COO66N7H.cjs.map +1 -0
  12. package/dist/chunk-FXKXMSLY.cjs +270 -0
  13. package/dist/chunk-FXKXMSLY.cjs.map +1 -0
  14. package/dist/chunk-PSDVPB7Y.js +289 -0
  15. package/dist/chunk-PSDVPB7Y.js.map +1 -0
  16. package/dist/chunk-RQCGONPN.js +937 -0
  17. package/dist/chunk-RQCGONPN.js.map +1 -0
  18. package/dist/chunk-RTSFO7BW.cjs +592 -0
  19. package/dist/chunk-RTSFO7BW.cjs.map +1 -0
  20. package/dist/chunk-TFLMPBX7.js +262 -0
  21. package/dist/chunk-TFLMPBX7.js.map +1 -0
  22. package/dist/chunk-XNR42GCJ.js +547 -0
  23. package/dist/chunk-XNR42GCJ.js.map +1 -0
  24. package/dist/cli/index.cjs +571 -0
  25. package/dist/cli/index.cjs.map +1 -0
  26. package/dist/cli/index.d.cts +1 -0
  27. package/dist/cli/index.d.ts +1 -0
  28. package/dist/cli/index.js +563 -0
  29. package/dist/cli/index.js.map +1 -0
  30. package/dist/database-B0vplyA4.d.cts +41 -0
  31. package/dist/database-B0vplyA4.d.ts +41 -0
  32. package/dist/edge-BzsYe2Ed.d.cts +269 -0
  33. package/dist/edge-BzsYe2Ed.d.ts +269 -0
  34. package/dist/index.cjs +895 -0
  35. package/dist/index.cjs.map +1 -0
  36. package/dist/index.d.cts +1484 -0
  37. package/dist/index.d.ts +1484 -0
  38. package/dist/index.js +654 -0
  39. package/dist/index.js.map +1 -0
  40. package/dist/migration/index.cjs +32 -0
  41. package/dist/migration/index.cjs.map +1 -0
  42. package/dist/migration/index.d.cts +51 -0
  43. package/dist/migration/index.d.ts +51 -0
  44. package/dist/migration/index.js +3 -0
  45. package/dist/migration/index.js.map +1 -0
  46. package/dist/query-helpers-D8po5Mn-.d.cts +777 -0
  47. package/dist/query-helpers-DvQTA2_Z.d.ts +777 -0
  48. package/dist/visualization/index.cjs +485 -0
  49. package/dist/visualization/index.cjs.map +1 -0
  50. package/dist/visualization/index.d.cts +134 -0
  51. package/dist/visualization/index.d.ts +134 -0
  52. package/dist/visualization/index.js +460 -0
  53. package/dist/visualization/index.js.map +1 -0
  54. package/docker/docker-compose.template.yml +28 -0
  55. package/package.json +116 -0
@@ -0,0 +1 @@
1
+ {"version":3,"sources":["../src/core/types/settings.ts","../src/core/schemas/node.ts","../src/core/schemas/edge.ts","../src/core/schemas/analysis.ts","../src/core/schemas/settings.ts","../src/core/schemas/api.ts","../src/core/analysis/scoring-engine.ts","../src/storage/factory.ts","../src/storage/query-helpers.ts"],"names":["slugify","z","Database"],"mappings":"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","file":"chunk-RTSFO7BW.cjs","sourcesContent":["/**\n * Settings Types for omi-neuron-web\n * Complete configuration schema for the library\n */\n\nimport type { ClusteringAlgorithm } from './cluster';\n\n/**\n * Embedding model options\n */\nexport type EmbeddingModel =\n | 'text-embedding-ada-002'\n | 'text-embedding-3-small'\n | 'text-embedding-3-large';\n\n/**\n * Performance mode for visualization\n */\nexport type PerformanceMode = 'auto' | 'normal' | 'degraded' | 'fallback';\n\n/**\n * Node type configuration\n */\nexport interface NodeTypeConfig {\n /** Type identifier */\n type: string;\n /** Human-readable label */\n label: string;\n /** Optional description */\n description?: string;\n /** Default domain for this type */\n defaultDomain: string;\n /** Icon name or emoji */\n icon?: string;\n /** Color hex code */\n color?: string;\n /** Custom AI prompt for analyzing this type */\n analysisPrompt?: string;\n}\n\n/**\n * Domain configuration for visualization\n */\nexport interface DomainConfig {\n /** Domain key */\n key: string;\n /** Human-readable label */\n label: string;\n /** Color hex code */\n color: string;\n /** Optional description */\n description?: string;\n}\n\n/**\n * Relationship type configuration\n */\nexport interface RelationshipTypeConfig {\n /** Type identifier */\n type: string;\n /** Human-readable label */\n label: string;\n /** Optional description */\n description?: string;\n /** Whether this type is bidirectional */\n bidirectional: boolean;\n /** Optional color hex code */\n color?: string;\n}\n\n/**\n * Visualization settings - all API-modifiable\n */\nexport interface VisualizationSettings {\n // Colors\n /** Domain to color mapping */\n domainColors: Record<string, string>;\n /** Default color for unknown domains */\n defaultDomainColor: string;\n /** Default edge color */\n edgeColor: string;\n /** Active/highlighted edge color */\n edgeActiveColor: string;\n /** Scene background color */\n backgroundColor: string;\n\n // Camera\n /** Initial camera position [x, y, z] */\n defaultCameraPosition: [number, number, number];\n /** Initial camera target [x, y, z] */\n defaultCameraTarget: [number, number, number];\n /** Minimum zoom distance */\n minZoomDistance: number;\n /** Maximum zoom distance */\n maxZoomDistance: number;\n\n // Rendering\n /** Enable starfield background */\n enableStarfield: boolean;\n /** Number of stars in starfield */\n starfieldCount: number;\n /** Distance at which labels appear */\n labelDistance: number;\n /** Maximum number of visible labels */\n maxVisibleLabels: number;\n\n // Performance\n /** Performance mode selection */\n performanceMode: PerformanceMode;\n /** Node count threshold for degraded mode */\n nodeCountThreshold: number;\n /** Maximum device pixel ratio */\n pixelRatioCap: number;\n\n // Animations\n /** Enable animations */\n enableAnimations: boolean;\n /** Focus tween duration in ms */\n focusTweenDuration: number;\n /** Filter transition duration in ms */\n filterTransitionDuration: number;\n\n // Interaction\n /** Enable hover effects */\n enableHover: boolean;\n /** Enable click handling */\n enableClick: boolean;\n /** Enable double-click handling */\n enableDoubleClick: boolean;\n /** Enable panning */\n enablePan: boolean;\n /** Enable zooming */\n enableZoom: boolean;\n /** Enable rotation */\n enableRotate: boolean;\n}\n\n/**\n * Analysis settings\n */\nexport interface AnalysisSettings {\n // Embeddings\n /** OpenAI embedding model */\n embeddingModel: EmbeddingModel;\n /** Embedding dimensions (must match model) */\n embeddingDimensions: number;\n /** Batch size for API calls */\n embeddingBatchSize: number;\n /** Cache TTL in seconds */\n embeddingCacheTTL: number;\n\n // Clustering\n /** Clustering algorithm */\n clusteringAlgorithm: ClusteringAlgorithm;\n /** Default number of clusters */\n defaultClusterCount: number;\n /** Minimum cluster size */\n minClusterSize: number;\n /** Similarity threshold for cluster assignment */\n clusterSimilarityThreshold: number;\n\n // Relationship inference\n /** Model for relationship inference */\n relationshipInferenceModel: string;\n /** Minimum confidence to create relationship */\n relationshipMinConfidence: number;\n /** Maximum relationships per node */\n relationshipMaxPerNode: number;\n\n // Rate limiting\n /** OpenAI requests per minute */\n openaiRateLimit: number;\n /** Maximum concurrent analysis jobs */\n maxConcurrentAnalysis: number;\n}\n\n/**\n * Instance settings\n */\nexport interface InstanceSettings {\n /** Human-readable instance name */\n name: string;\n /** Library version */\n version: string;\n /** Used for pg-{repoName} database naming */\n repoName: string;\n}\n\n/**\n * Database settings\n */\nexport interface DatabaseSettings {\n /** 'docker' for managed, 'external' for BYO */\n mode: 'docker' | 'external';\n /** Port to expose (Docker mode) */\n port: number;\n /** Container name override */\n containerName?: string;\n /** Docker image */\n image?: string;\n /** Database user */\n user?: string;\n /** Database password */\n password?: string;\n /** Database name */\n database?: string;\n /** Connection URL (external mode) */\n url?: string;\n /** Connection pool settings */\n pool?: {\n min: number;\n max: number;\n idleTimeoutMs: number;\n connectionTimeoutMs: number;\n };\n /** Resource limits (Docker mode) */\n resources?: {\n memoryLimit: string;\n cpuLimit?: string;\n };\n}\n\n/**\n * API settings\n */\nexport interface ApiSettings {\n /** Base path for API routes */\n basePath: string;\n /** Enable CORS */\n enableCors: boolean;\n /** Rate limiting configuration */\n rateLimit?: {\n windowMs: number;\n max: number;\n };\n}\n\n/**\n * Logging settings\n */\nexport interface LoggingSettings {\n /** Log level */\n level: 'debug' | 'info' | 'warn' | 'error';\n /** Pretty print logs */\n prettyPrint: boolean;\n}\n\n/**\n * Complete settings schema - stored in database and repo config\n */\nexport interface NeuronSettings {\n /** Instance identification */\n instance: InstanceSettings;\n /** Visualization settings (API-modifiable) */\n visualization: VisualizationSettings;\n /** Analysis settings */\n analysis: AnalysisSettings;\n /** Node type configuration */\n nodeTypes: NodeTypeConfig[];\n /** Domain configuration */\n domains: DomainConfig[];\n /** Relationship type configuration */\n relationshipTypes: RelationshipTypeConfig[];\n}\n\n/**\n * Full configuration including non-runtime settings\n */\nexport interface NeuronConfig extends NeuronSettings {\n /** OpenAI configuration */\n openai: {\n apiKey: string;\n organization?: string;\n requestsPerMinute?: number;\n maxRetries?: number;\n };\n /** Database configuration */\n database: DatabaseSettings;\n /** API configuration */\n api: ApiSettings;\n /** Logging configuration */\n logging: LoggingSettings;\n}\n\n/**\n * Partial settings for updates\n */\nexport interface NeuronSettingsUpdate {\n visualization?: Partial<VisualizationSettings>;\n analysis?: Partial<AnalysisSettings>;\n nodeTypes?: NodeTypeConfig[];\n domains?: DomainConfig[];\n relationshipTypes?: RelationshipTypeConfig[];\n}\n\n/**\n * Default visualization settings\n */\nexport const DEFAULT_VISUALIZATION_SETTINGS: VisualizationSettings = {\n domainColors: {},\n defaultDomainColor: '#c0c5ff',\n edgeColor: '#4d4d55',\n edgeActiveColor: '#c6d4ff',\n backgroundColor: '#020314',\n defaultCameraPosition: [4, 8, 20],\n defaultCameraTarget: [0, 0, 0],\n minZoomDistance: 4,\n maxZoomDistance: 42,\n enableStarfield: true,\n starfieldCount: 1200,\n labelDistance: 26,\n maxVisibleLabels: 50,\n performanceMode: 'auto',\n nodeCountThreshold: 120,\n pixelRatioCap: 2,\n enableAnimations: true,\n focusTweenDuration: 800,\n filterTransitionDuration: 650,\n enableHover: true,\n enableClick: true,\n enableDoubleClick: true,\n enablePan: true,\n enableZoom: true,\n enableRotate: true,\n};\n\n/**\n * Default analysis settings\n */\nexport const DEFAULT_ANALYSIS_SETTINGS: AnalysisSettings = {\n embeddingModel: 'text-embedding-3-small',\n embeddingDimensions: 1536,\n embeddingBatchSize: 20,\n embeddingCacheTTL: 86400,\n clusteringAlgorithm: 'kmeans',\n defaultClusterCount: 8,\n minClusterSize: 3,\n clusterSimilarityThreshold: 0.75,\n relationshipInferenceModel: 'gpt-4o-mini',\n relationshipMinConfidence: 0.7,\n relationshipMaxPerNode: 10,\n openaiRateLimit: 60,\n maxConcurrentAnalysis: 5,\n};\n\n","import slugify from 'slugify';\nimport { z } from 'zod';\n\nconst slugTransform = (label: string) =>\n slugify(label, { lower: true, strict: true, trim: true }).slice(0, 255);\n\nexport const nodeTierSchema = z.enum(['primary', 'secondary', 'tertiary', 'insight']);\n\nexport const nodeCreateSchema = z\n .object({\n slug: z.string().min(1).max(255).optional(),\n label: z.string().min(1).max(500),\n nodeType: z.string().min(1).max(100).optional(),\n domain: z.string().min(1).max(100).optional(),\n summary: z.string().max(1000).optional(),\n description: z.string().optional(),\n content: z.string().optional(),\n metadata: z.record(z.string(), z.unknown()).optional(),\n tier: nodeTierSchema.optional(),\n })\n .transform((data) => ({\n ...data,\n slug: data.slug ?? slugTransform(data.label),\n }));\n\nexport const nodeUpdateSchema = z.object({\n label: z.string().min(1).max(500).optional(),\n summary: z.string().max(1000).optional(),\n description: z.string().optional(),\n content: z.string().optional(),\n metadata: z.record(z.string(), z.unknown()).optional(),\n domain: z.string().min(1).max(100).optional(),\n tier: nodeTierSchema.optional(),\n positionOverride: z.tuple([z.number(), z.number(), z.number()]).nullable().optional(),\n});\n\nexport const nodeBatchCreateSchema = z.object({\n nodes: z.array(nodeCreateSchema),\n options: z\n .object({\n skipDuplicates: z.boolean().optional(),\n updateOnConflict: z.boolean().optional(),\n autoAnalyze: z.boolean().optional(),\n analysisDepth: z.enum(['embeddings', 'cluster', 'full']).optional(),\n })\n .optional(),\n});\n\nexport const nodeFilterSchema = z.object({\n page: z.coerce.number().int().min(1).optional(),\n limit: z.coerce.number().int().min(1).max(1000).optional(),\n nodeType: z.union([z.string(), z.array(z.string())]).optional(),\n domain: z.union([z.string(), z.array(z.string())]).optional(),\n clusterId: z.string().uuid().optional(),\n analysisStatus: z.string().optional(),\n search: z.string().optional(),\n sortBy: z.enum(['createdAt', 'updatedAt', 'label', 'connectionCount']).optional(),\n sortOrder: z.enum(['asc', 'desc']).optional(),\n includeEmbeddings: z.coerce.boolean().optional(),\n includeStats: z.coerce.boolean().optional(),\n});\n\nexport type NodeCreateInput = z.infer<typeof nodeCreateSchema>;\nexport type NodeUpdateInput = z.infer<typeof nodeUpdateSchema>;\nexport type NodeBatchCreateInput = z.infer<typeof nodeBatchCreateSchema>;\nexport type NodeFilterInput = z.infer<typeof nodeFilterSchema>;\n","import { z } from 'zod';\n\nexport const edgeEvidenceSchema = z.object({\n type: z.enum(['text', 'url', 'citation', 'ai_inference']),\n content: z.string().min(1),\n confidence: z.number().min(0).max(1).optional(),\n sourceId: z.string().optional(),\n metadata: z.record(z.string(), z.unknown()).optional(),\n});\n\nexport const edgeCreateSchema = z.object({\n fromNodeId: z.string().uuid(),\n toNodeId: z.string().uuid(),\n relationshipType: z.string().optional(),\n strength: z.number().min(0).max(1).optional(),\n confidence: z.number().min(0).max(1).optional(),\n evidence: z.array(edgeEvidenceSchema).optional(),\n label: z.string().max(255).optional(),\n description: z.string().optional(),\n metadata: z.record(z.string(), z.unknown()).optional(),\n bidirectional: z.boolean().optional(),\n});\n\nexport const edgeUpdateSchema = z.object({\n strength: z.number().min(0).max(1).optional(),\n confidence: z.number().min(0).max(1).optional(),\n relationshipType: z.string().optional(),\n label: z.string().max(255).optional(),\n description: z.string().optional(),\n evidence: z.array(edgeEvidenceSchema).optional(),\n metadata: z.record(z.string(), z.unknown()).optional(),\n});\n\nexport const edgeFilterSchema = z.object({\n page: z.coerce.number().int().min(1).optional(),\n limit: z.coerce.number().int().min(1).max(1000).optional(),\n fromNodeId: z.string().uuid().optional(),\n toNodeId: z.string().uuid().optional(),\n nodeId: z.string().uuid().optional(),\n relationshipType: z.union([z.string(), z.array(z.string())]).optional(),\n source: z.enum(['manual', 'ai_inferred', 'imported']).optional(),\n minStrength: z.coerce.number().min(0).max(1).optional(),\n minConfidence: z.coerce.number().min(0).max(1).optional(),\n});\n\nexport type EdgeEvidenceInput = z.infer<typeof edgeEvidenceSchema>;\nexport type EdgeCreateInput = z.infer<typeof edgeCreateSchema>;\nexport type EdgeUpdateInput = z.infer<typeof edgeUpdateSchema>;\nexport type EdgeFilterInput = z.infer<typeof edgeFilterSchema>;\n","import { z } from 'zod';\n\nexport const analysisOptionsSchema = z.object({\n nodeIds: z.array(z.string().uuid()).optional(),\n forceRecompute: z.boolean().optional(),\n skipEmbeddings: z.boolean().optional(),\n embeddingModel: z.string().optional(),\n skipClustering: z.boolean().optional(),\n clusterCount: z.coerce.number().int().min(1).optional(),\n clusteringAlgorithm: z.enum(['kmeans', 'dbscan', 'hierarchical']).optional(),\n skipRelationships: z.boolean().optional(),\n relationshipThreshold: z.coerce.number().min(0).max(1).optional(),\n maxRelationshipsPerNode: z.coerce.number().int().min(1).optional(),\n});\n\nexport const analysisRequestSchema = z.object({\n action: z.enum(['embeddings', 'cluster', 'infer_relationships', 'full']),\n options: analysisOptionsSchema.optional(),\n});\n\nexport type AnalysisOptionsInput = z.infer<typeof analysisOptionsSchema>;\nexport type AnalysisRequestInput = z.infer<typeof analysisRequestSchema>;\n","import { z } from 'zod';\n\nconst colorSchema = z.string().min(1);\n\nexport const nodeTypeConfigSchema = z.object({\n type: z.string().min(1),\n label: z.string().min(1),\n description: z.string().optional(),\n defaultDomain: z.string().min(1),\n icon: z.string().optional(),\n color: colorSchema.optional(),\n analysisPrompt: z.string().optional(),\n});\n\nexport const domainConfigSchema = z.object({\n key: z.string().min(1),\n label: z.string().min(1),\n color: colorSchema,\n description: z.string().optional(),\n});\n\nexport const relationshipTypeConfigSchema = z.object({\n type: z.string().min(1),\n label: z.string().min(1),\n description: z.string().optional(),\n bidirectional: z.boolean(),\n color: colorSchema.optional(),\n});\n\nexport const visualizationSettingsSchema = z.object({\n domainColors: z.record(z.string(), colorSchema),\n defaultDomainColor: colorSchema,\n edgeColor: colorSchema,\n edgeActiveColor: colorSchema,\n backgroundColor: colorSchema,\n defaultCameraPosition: z.tuple([z.number(), z.number(), z.number()]),\n defaultCameraTarget: z.tuple([z.number(), z.number(), z.number()]),\n minZoomDistance: z.number(),\n maxZoomDistance: z.number(),\n enableStarfield: z.boolean(),\n starfieldCount: z.number().int().min(0),\n labelDistance: z.number().min(0),\n maxVisibleLabels: z.number().int().min(0),\n performanceMode: z.enum(['auto', 'normal', 'degraded', 'fallback']),\n nodeCountThreshold: z.number().int().min(0),\n pixelRatioCap: z.number().min(0.5),\n enableAnimations: z.boolean(),\n focusTweenDuration: z.number().int().min(0),\n filterTransitionDuration: z.number().int().min(0),\n enableHover: z.boolean(),\n enableClick: z.boolean(),\n enableDoubleClick: z.boolean(),\n enablePan: z.boolean(),\n enableZoom: z.boolean(),\n enableRotate: z.boolean(),\n});\n\nexport const analysisSettingsSchema = z.object({\n embeddingModel: z.enum(['text-embedding-ada-002', 'text-embedding-3-small', 'text-embedding-3-large']),\n embeddingDimensions: z.number().int().min(1),\n embeddingBatchSize: z.number().int().min(1),\n embeddingCacheTTL: z.number().int().min(0),\n clusteringAlgorithm: z.enum(['kmeans', 'dbscan', 'hierarchical']),\n defaultClusterCount: z.number().int().min(1),\n minClusterSize: z.number().int().min(1),\n clusterSimilarityThreshold: z.number().min(0).max(1),\n relationshipInferenceModel: z.string().min(1),\n relationshipMinConfidence: z.number().min(0).max(1),\n relationshipMaxPerNode: z.number().int().min(1),\n openaiRateLimit: z.number().int().min(1),\n maxConcurrentAnalysis: z.number().int().min(1),\n});\n\nconst instanceSettingsSchema = z.object({\n name: z.string().min(1),\n version: z.string().min(1),\n repoName: z.string().min(1),\n});\n\nexport const databaseSettingsSchema = z.object({\n mode: z.enum(['docker', 'external']),\n port: z.number().int().min(1).max(65535),\n containerName: z.string().optional(),\n image: z.string().optional(),\n user: z.string().optional(),\n password: z.string().optional(),\n database: z.string().optional(),\n url: z.string().optional(),\n pool: z\n .object({\n min: z.number().int().min(0),\n max: z.number().int().min(1),\n idleTimeoutMs: z.number().int().min(0),\n connectionTimeoutMs: z.number().int().min(0),\n })\n .optional(),\n resources: z\n .object({\n memoryLimit: z.string().min(1),\n cpuLimit: z.string().optional(),\n })\n .optional(),\n});\n\nconst apiSettingsSchema = z.object({\n basePath: z.string().min(1),\n enableCors: z.boolean(),\n rateLimit: z\n .object({\n windowMs: z.number().int().min(1),\n max: z.number().int().min(1),\n })\n .optional(),\n});\n\nconst loggingSettingsSchema = z.object({\n level: z.enum(['debug', 'info', 'warn', 'error']),\n prettyPrint: z.boolean(),\n});\n\nexport const neuronSettingsSchema = z.object({\n instance: instanceSettingsSchema,\n visualization: visualizationSettingsSchema,\n analysis: analysisSettingsSchema,\n nodeTypes: z.array(nodeTypeConfigSchema),\n domains: z.array(domainConfigSchema),\n relationshipTypes: z.array(relationshipTypeConfigSchema),\n});\n\nexport const neuronSettingsUpdateSchema = z.object({\n visualization: visualizationSettingsSchema.partial().optional(),\n analysis: analysisSettingsSchema.partial().optional(),\n nodeTypes: z.array(nodeTypeConfigSchema).optional(),\n domains: z.array(domainConfigSchema).optional(),\n relationshipTypes: z.array(relationshipTypeConfigSchema).optional(),\n});\n\nexport const neuronConfigSchema = neuronSettingsSchema.extend({\n openai: z.object({\n apiKey: z.string().min(1),\n organization: z.string().optional(),\n requestsPerMinute: z.number().int().min(1).optional(),\n maxRetries: z.number().int().min(0).optional(),\n }),\n database: databaseSettingsSchema,\n api: apiSettingsSchema,\n logging: loggingSettingsSchema,\n});\n\nexport type NodeTypeConfigInput = z.infer<typeof nodeTypeConfigSchema>;\nexport type DomainConfigInput = z.infer<typeof domainConfigSchema>;\nexport type RelationshipTypeConfigInput = z.infer<typeof relationshipTypeConfigSchema>;\nexport type VisualizationSettingsInput = z.infer<typeof visualizationSettingsSchema>;\nexport type AnalysisSettingsInput = z.infer<typeof analysisSettingsSchema>;\nexport type DatabaseSettingsInput = z.infer<typeof databaseSettingsSchema>;\nexport type NeuronSettingsInput = z.infer<typeof neuronSettingsSchema>;\nexport type NeuronSettingsUpdateInput = z.infer<typeof neuronSettingsUpdateSchema>;\nexport type NeuronConfigInput = z.infer<typeof neuronConfigSchema>;\n","import { z } from 'zod';\n\nexport const paginationSchema = z.object({\n page: z.coerce.number().int().min(1).optional(),\n limit: z.coerce.number().int().min(1).max(1000).optional(),\n});\n\nexport const listNodesParamsSchema = paginationSchema.extend({\n nodeType: z.union([z.string(), z.array(z.string())]).optional(),\n domain: z.union([z.string(), z.array(z.string())]).optional(),\n clusterId: z.string().uuid().optional(),\n analysisStatus: z.string().optional(),\n search: z.string().optional(),\n sortBy: z.enum(['createdAt', 'updatedAt', 'label', 'connectionCount']).optional(),\n sortOrder: z.enum(['asc', 'desc']).optional(),\n includeEmbeddings: z.coerce.boolean().optional(),\n includeStats: z.coerce.boolean().optional(),\n});\n\nexport const listEdgesParamsSchema = paginationSchema.extend({\n fromNodeId: z.string().uuid().optional(),\n toNodeId: z.string().uuid().optional(),\n nodeId: z.string().uuid().optional(),\n relationshipType: z.union([z.string(), z.array(z.string())]).optional(),\n source: z.enum(['manual', 'ai_inferred', 'imported']).optional(),\n minStrength: z.coerce.number().min(0).max(1).optional(),\n minConfidence: z.coerce.number().min(0).max(1).optional(),\n});\n\nexport const getGraphParamsSchema = z.object({\n nodeTypes: z.union([z.string(), z.array(z.string())]).optional(),\n domains: z.union([z.string(), z.array(z.string())]).optional(),\n clusterIds: z.union([z.string(), z.array(z.string())]).optional(),\n nodeIds: z.union([z.string(), z.array(z.string())]).optional(),\n depth: z.coerce.number().int().min(1).optional(),\n minEdgeStrength: z.coerce.number().min(0).max(1).optional(),\n relationshipTypes: z.union([z.string(), z.array(z.string())]).optional(),\n maxNodes: z.coerce.number().int().min(1).optional(),\n includeOrphanNodes: z.coerce.boolean().optional(),\n});\n\nexport const expandGraphRequestSchema = z.object({\n fromNodeIds: z.array(z.string().uuid()),\n depth: z.coerce.number().int().min(1),\n direction: z.enum(['outbound', 'inbound', 'both']),\n maxNodes: z.coerce.number().int().min(1).optional(),\n});\n\nexport const findPathRequestSchema = z.object({\n fromNodeId: z.string().uuid(),\n toNodeId: z.string().uuid(),\n maxDepth: z.coerce.number().int().min(1).optional(),\n algorithm: z.enum(['shortest', 'all']).optional(),\n});\n\nexport const semanticSearchRequestSchema = z.object({\n query: z.string().min(1),\n nodeTypes: z.array(z.string()).optional(),\n domains: z.array(z.string()).optional(),\n limit: z.coerce.number().int().min(1).optional(),\n});\n\nexport const findSimilarRequestSchema = z.object({\n nodeId: z.string().uuid(),\n limit: z.coerce.number().int().min(1).optional(),\n excludeConnected: z.coerce.boolean().optional(),\n});\n\nexport type PaginationInput = z.infer<typeof paginationSchema>;\nexport type ListNodesParamsInput = z.infer<typeof listNodesParamsSchema>;\nexport type ListEdgesParamsInput = z.infer<typeof listEdgesParamsSchema>;\nexport type GetGraphParamsInput = z.infer<typeof getGraphParamsSchema>;\nexport type ExpandGraphRequestInput = z.infer<typeof expandGraphRequestSchema>;\nexport type FindPathRequestInput = z.infer<typeof findPathRequestSchema>;\nexport type SemanticSearchRequestInput = z.infer<typeof semanticSearchRequestSchema>;\nexport type FindSimilarRequestInput = z.infer<typeof findSimilarRequestSchema>;\n","import type { Database } from '../../storage/database';\nimport type { NeuronNode } from '../types/node';\n\nexport interface ScoringConfig {\n similarityWeight: number;\n connectionWeight: number;\n recencyWeight: number;\n domainBoost: number;\n}\n\nexport interface ScoredNode {\n node: NeuronNode;\n score: number;\n breakdown: {\n similarity: number;\n connections: number;\n recency: number;\n domainMatch: number;\n };\n}\n\nconst DEFAULT_CONFIG: ScoringConfig = {\n similarityWeight: 0.6,\n connectionWeight: 0.2,\n recencyWeight: 0.1,\n domainBoost: 0.1,\n};\n\nexport class ScoringEngine {\n private config: ScoringConfig;\n\n constructor(private db: Database, config?: ScoringConfig) {\n this.config = { ...DEFAULT_CONFIG, ...(config ?? {}) };\n }\n\n cosineSimilarity(a: number[], b: number[]): number {\n let dot = 0;\n let magA = 0;\n let magB = 0;\n for (let i = 0; i < a.length; i += 1) {\n dot += a[i] * b[i];\n magA += a[i] * a[i];\n magB += b[i] * b[i];\n }\n if (magA === 0 || magB === 0) return 0;\n return dot / (Math.sqrt(magA) * Math.sqrt(magB));\n }\n\n async semanticSimilarity(nodeA: string, nodeB: string): Promise<number> {\n const rows = await this.db.query<{ similarity: number }>(\n 'SELECT 1 - (a.embedding <=> b.embedding) as similarity FROM nodes a JOIN nodes b ON b.id = $2 WHERE a.id = $1',\n [nodeA, nodeB]\n );\n return rows[0]?.similarity ?? 0;\n }\n\n async scoreForQuery(queryEmbedding: number[], nodeIds?: string[]): Promise<ScoredNode[]> {\n const filterClause = nodeIds?.length ? 'AND id = ANY($2)' : '';\n const values = nodeIds?.length ? [queryEmbedding, nodeIds] : [queryEmbedding];\n const nodes = await this.db.query<NeuronNode & { similarity: number }>(\n `SELECT *, 1 - (embedding <=> $1) as similarity FROM nodes WHERE embedding IS NOT NULL ${filterClause} ORDER BY embedding <=> $1`,\n values\n );\n\n return nodes.map((node) => this.applyScoring(node, node.similarity ?? 0));\n }\n\n async findSimilar(nodeId: string, limit = 10, excludeConnected = false): Promise<ScoredNode[]> {\n const base = excludeConnected\n ? `SELECT id FROM nodes WHERE id NOT IN (SELECT to_node_id FROM edges WHERE from_node_id = $1)`\n : `SELECT id FROM nodes WHERE id != $1`;\n const nodes = await this.db.query<NeuronNode & { similarity: number }>(\n `SELECT n.*, 1 - (n.embedding <=> (SELECT embedding FROM nodes WHERE id = $1)) as similarity\n FROM nodes n\n WHERE n.embedding IS NOT NULL AND n.id IN (${base})\n ORDER BY n.embedding <=> (SELECT embedding FROM nodes WHERE id = $1)\n LIMIT $2`,\n [nodeId, limit]\n );\n\n return nodes.map((node) => this.applyScoring(node, node.similarity ?? 0));\n }\n\n async calculateNodeImportance(nodeId: string): Promise<number> {\n const row = await this.db.queryOne<{ importance: number }>(\n `WITH edge_weights AS (\n SELECT to_node_id, SUM(strength) as total_inbound\n FROM edges\n GROUP BY to_node_id\n )\n SELECT COALESCE(ew.total_inbound, 0) + (n.connection_count * 0.1) as importance\n FROM nodes n\n LEFT JOIN edge_weights ew ON n.id = ew.to_node_id\n WHERE n.id = $1`,\n [nodeId]\n );\n return row?.importance ?? 0;\n }\n\n async rankAllNodes(): Promise<Array<{ nodeId: string; importance: number }>> {\n const rows = await this.db.query<{ id: string; importance: number }>(\n `WITH edge_weights AS (\n SELECT to_node_id, SUM(strength) as total_inbound\n FROM edges\n GROUP BY to_node_id\n )\n SELECT n.id, COALESCE(ew.total_inbound, 0) + (n.connection_count * 0.1) as importance\n FROM nodes n\n LEFT JOIN edge_weights ew ON n.id = ew.to_node_id\n ORDER BY importance DESC`\n );\n return rows.map((row) => ({ nodeId: row.id, importance: row.importance }));\n }\n\n async scoreRelevance(\n sourceNodeId: string,\n candidateNodeIds: string[],\n context?: string\n ): Promise<ScoredNode[]> {\n const nodes = await this.db.query<NeuronNode & { similarity: number }>(\n `SELECT *, 1 - (embedding <=> (SELECT embedding FROM nodes WHERE id = $1)) as similarity\n FROM nodes\n WHERE embedding IS NOT NULL AND id = ANY($2)\n ORDER BY embedding <=> (SELECT embedding FROM nodes WHERE id = $1)`,\n [sourceNodeId, candidateNodeIds]\n );\n\n return nodes.map((node) => {\n const base = this.applyScoring(node, node.similarity ?? 0);\n if (context) {\n base.score += this.config.domainBoost * 0.1;\n }\n return base;\n });\n }\n\n private applyScoring(node: NeuronNode & { similarity?: number }, similarity: number): ScoredNode {\n const connections = node.connectionCount ?? 0;\n const recency = node.updatedAt ? Math.max(0, 1 - (Date.now() - new Date(node.updatedAt).getTime()) / (1000 * 60 * 60 * 24 * 30)) : 0;\n const domainMatch = 0;\n\n const score =\n similarity * this.config.similarityWeight +\n connections * this.config.connectionWeight +\n recency * this.config.recencyWeight +\n domainMatch * this.config.domainBoost;\n\n return {\n node,\n score,\n breakdown: {\n similarity,\n connections,\n recency,\n domainMatch,\n },\n };\n }\n}\n","import type { NeuronConfig } from '../core/types/settings';\nimport { Database, type DatabaseConfig } from './database';\n\nlet singleton: Database | null = null;\n\nexport function createDatabase(config: NeuronConfig): Database {\n const dbConfig: DatabaseConfig = {\n connectionString: config.database.url,\n host: config.database.mode === 'docker' ? 'localhost' : undefined,\n port: config.database.port,\n user: config.database.user,\n password: config.database.password,\n database: config.database.database,\n pool: config.database.pool,\n };\n\n return new Database(dbConfig);\n}\n\nexport function createDatabaseFromEnv(): Database {\n const dbConfig: DatabaseConfig = {\n connectionString: process.env.DATABASE_URL,\n host: process.env.DB_HOST,\n port: process.env.DB_PORT ? Number(process.env.DB_PORT) : undefined,\n user: process.env.DB_USER,\n password: process.env.DB_PASSWORD,\n database: process.env.DB_NAME,\n };\n\n return new Database(dbConfig);\n}\n\nexport function getDatabase(config?: DatabaseConfig): Database {\n if (!singleton) {\n singleton = new Database(config ?? {});\n }\n\n return singleton;\n}\n\nexport function resetDatabaseSingleton(): void {\n singleton = null;\n}\n","export type WhereClause = Record<string, unknown>;\n\nexport interface SelectOptions {\n limit?: number;\n offset?: number;\n orderBy?: string;\n orderDirection?: 'asc' | 'desc';\n}\n\nexport const buildWhereClause = (where?: WhereClause, startIndex = 1) => {\n if (!where || Object.keys(where).length === 0) {\n return { clause: '', values: [], nextIndex: startIndex };\n }\n\n const keys = Object.keys(where);\n const values: unknown[] = [];\n const conditions = keys.map((key, idx) => {\n values.push(where[key]);\n return `${key} = $${startIndex + idx}`;\n });\n\n return {\n clause: `WHERE ${conditions.join(' AND ')}`,\n values,\n nextIndex: startIndex + keys.length,\n };\n};\n\nexport const buildInsert = (table: string, data: Record<string, unknown>) => {\n const keys = Object.keys(data);\n const values = Object.values(data);\n const columns = keys.map((key) => `\"${key}\"`).join(', ');\n const placeholders = keys.map((_, idx) => `$${idx + 1}`).join(', ');\n\n return {\n sql: `INSERT INTO ${table} (${columns}) VALUES (${placeholders}) RETURNING *`,\n values,\n };\n};\n\nexport const buildUpdate = (\n table: string,\n data: Record<string, unknown>,\n where: WhereClause\n) => {\n const keys = Object.keys(data);\n const values = Object.values(data);\n const setClause = keys.map((key, idx) => `\"${key}\" = $${idx + 1}`).join(', ');\n\n const whereResult = buildWhereClause(where, keys.length + 1);\n\n return {\n sql: `UPDATE ${table} SET ${setClause} ${whereResult.clause} RETURNING *`,\n values: [...values, ...whereResult.values],\n };\n};\n\nexport const buildSelect = (\n table: string,\n columns: string[] | '*',\n where?: WhereClause,\n options?: SelectOptions\n) => {\n const columnList = columns === '*' ? '*' : columns.map((col) => `\"${col}\"`).join(', ');\n const whereResult = buildWhereClause(where);\n const orderClause = options?.orderBy\n ? `ORDER BY ${options.orderBy} ${options.orderDirection ?? 'asc'}`\n : '';\n const limitClause = options?.limit ? `LIMIT ${options.limit}` : '';\n const offsetClause = options?.offset ? `OFFSET ${options.offset}` : '';\n\n return {\n sql: `SELECT ${columnList} FROM ${table} ${whereResult.clause} ${orderClause} ${limitClause} ${offsetClause}`.trim(),\n values: whereResult.values,\n };\n};\n\nexport const buildDelete = (table: string, where: WhereClause) => {\n const whereResult = buildWhereClause(where);\n return {\n sql: `DELETE FROM ${table} ${whereResult.clause}`,\n values: whereResult.values,\n };\n};\n"]}
@@ -0,0 +1,262 @@
1
+ import { execFile } from 'child_process';
2
+ import { promisify } from 'util';
3
+ import fs from 'fs/promises';
4
+ import path from 'path';
5
+ import net from 'net';
6
+
7
+ var execFileAsync = promisify(execFile);
8
+ var DEFAULTS = {
9
+ image: "pgvector/pgvector:pg16",
10
+ user: "neuron",
11
+ password: "neuron_dev",
12
+ database: "neuron_web",
13
+ memoryLimit: "1g"
14
+ };
15
+ var DockerManager = class {
16
+ config;
17
+ composeFilePath;
18
+ constructor(config) {
19
+ this.config = { ...config };
20
+ this.composeFilePath = path.join(process.cwd(), "docker", "docker-compose.neuron.yml");
21
+ }
22
+ async start(options) {
23
+ await this.assertDockerAvailable();
24
+ await this.ensureComposeFile();
25
+ const port = await this.ensurePortAvailable(this.config.port);
26
+ if (port !== this.config.port) {
27
+ this.config.port = port;
28
+ await this.ensureComposeFile();
29
+ }
30
+ const compose = await this.getComposeCommand();
31
+ const args = ["-f", this.composeFilePath, "up", "-d"];
32
+ if (options?.forceRecreate) {
33
+ args.push("--force-recreate");
34
+ }
35
+ await execFileAsync(compose.cmd, [...compose.args, ...args]);
36
+ if (options?.waitForReady ?? true) {
37
+ await this.waitForReady(options?.timeoutMs ?? 6e4);
38
+ }
39
+ }
40
+ async stop(options) {
41
+ await this.assertDockerAvailable();
42
+ const compose = await this.getComposeCommand();
43
+ const args = ["-f", this.composeFilePath, "down"];
44
+ if (options?.removeVolumes) {
45
+ args.push("-v");
46
+ }
47
+ await execFileAsync(compose.cmd, [...compose.args, ...args]);
48
+ }
49
+ async ensureRunning(options) {
50
+ const running = await this.isRunning();
51
+ if (!running) {
52
+ await this.start({ waitForReady: options?.waitForReady });
53
+ return;
54
+ }
55
+ if (options?.waitForReady ?? true) {
56
+ await this.waitForReady(6e4);
57
+ }
58
+ }
59
+ async isRunning() {
60
+ try {
61
+ const status = await this.inspectContainer();
62
+ return Boolean(status?.State?.Running);
63
+ } catch {
64
+ return false;
65
+ }
66
+ }
67
+ async healthCheck() {
68
+ const connectionString = await this.getConnectionString();
69
+ const containerRunning = await this.isRunning();
70
+ if (!containerRunning) {
71
+ return {
72
+ containerRunning: false,
73
+ databaseReady: false,
74
+ connectionString,
75
+ details: "Container not running"
76
+ };
77
+ }
78
+ try {
79
+ await this.execPgIsReady();
80
+ return {
81
+ containerRunning: true,
82
+ databaseReady: true,
83
+ connectionString
84
+ };
85
+ } catch (error) {
86
+ return {
87
+ containerRunning: true,
88
+ databaseReady: false,
89
+ connectionString,
90
+ details: error instanceof Error ? error.message : String(error)
91
+ };
92
+ }
93
+ }
94
+ async getStats() {
95
+ const containerName = this.getContainerName();
96
+ const { stdout } = await execFileAsync("docker", [
97
+ "stats",
98
+ containerName,
99
+ "--no-stream",
100
+ "--format",
101
+ "{{json .}}"
102
+ ]);
103
+ const trimmed = stdout.trim();
104
+ if (!trimmed) {
105
+ return {};
106
+ }
107
+ try {
108
+ const parsed = JSON.parse(trimmed);
109
+ return {
110
+ cpuPercent: parsed.CPUPerc,
111
+ memoryUsage: parsed.MemUsage,
112
+ memoryPercent: parsed.MemPerc,
113
+ netIO: parsed.NetIO,
114
+ blockIO: parsed.BlockIO
115
+ };
116
+ } catch {
117
+ return {};
118
+ }
119
+ }
120
+ async getConnectionString() {
121
+ const user = this.config.user ?? DEFAULTS.user;
122
+ const password = this.config.password ?? DEFAULTS.password;
123
+ const database = this.config.database ?? DEFAULTS.database;
124
+ const port = this.config.port;
125
+ return `postgresql://${user}:${password}@localhost:${port}/${database}`;
126
+ }
127
+ async getLogs(options) {
128
+ const containerName = this.getContainerName();
129
+ const args = ["logs"];
130
+ if (options?.tail) {
131
+ args.push("--tail", String(options.tail));
132
+ }
133
+ if (options?.since) {
134
+ args.push("--since", options.since);
135
+ }
136
+ args.push(containerName);
137
+ const { stdout } = await execFileAsync("docker", args);
138
+ return stdout;
139
+ }
140
+ async execSql(sql) {
141
+ const containerName = this.getContainerName();
142
+ const user = this.config.user ?? DEFAULTS.user;
143
+ const database = this.config.database ?? DEFAULTS.database;
144
+ const { stdout } = await execFileAsync("docker", [
145
+ "exec",
146
+ containerName,
147
+ "psql",
148
+ "-U",
149
+ user,
150
+ "-d",
151
+ database,
152
+ "-c",
153
+ sql
154
+ ]);
155
+ return stdout;
156
+ }
157
+ async updatePort(newPort) {
158
+ this.config.port = newPort;
159
+ await this.ensureComposeFile();
160
+ }
161
+ async assertDockerAvailable() {
162
+ try {
163
+ await execFileAsync("docker", ["--version"]);
164
+ } catch {
165
+ throw new Error(
166
+ "Docker is not available. Install Docker Desktop: https://www.docker.com/products/docker-desktop/"
167
+ );
168
+ }
169
+ }
170
+ async getComposeCommand() {
171
+ try {
172
+ await execFileAsync("docker", ["compose", "version"]);
173
+ return { cmd: "docker", args: ["compose"] };
174
+ } catch {
175
+ return { cmd: "docker-compose", args: [] };
176
+ }
177
+ }
178
+ getContainerName() {
179
+ return this.config.containerName ?? `pg-${this.config.repoName}`;
180
+ }
181
+ getVolumeName() {
182
+ return `${this.config.repoName}_neuron_data`;
183
+ }
184
+ async ensureComposeFile() {
185
+ const templatePath = path.join(process.cwd(), "docker", "docker-compose.template.yml");
186
+ const template = await fs.readFile(templatePath, "utf8");
187
+ const rendered = this.renderTemplate(template);
188
+ await fs.mkdir(path.dirname(this.composeFilePath), { recursive: true });
189
+ await fs.writeFile(this.composeFilePath, rendered, "utf8");
190
+ }
191
+ renderTemplate(template) {
192
+ const image = this.config.image ?? DEFAULTS.image;
193
+ const user = this.config.user ?? DEFAULTS.user;
194
+ const password = this.config.password ?? DEFAULTS.password;
195
+ const database = this.config.database ?? DEFAULTS.database;
196
+ const memoryLimit = this.config.memoryLimit ?? DEFAULTS.memoryLimit;
197
+ const containerName = this.getContainerName();
198
+ const volumeName = this.getVolumeName();
199
+ return template.replace(/{{REPO_NAME}}/g, this.config.repoName).replace(/{{DB_PORT}}/g, String(this.config.port)).replace(/{{DB_USER}}/g, user).replace(/{{DB_PASSWORD}}/g, password).replace(/{{DB_NAME}}/g, database).replace(/{{VOLUME_NAME}}/g, volumeName).replace(/{{MEMORY_LIMIT}}/g, memoryLimit).replace(/{{IMAGE_NAME}}/g, image).replace(/{{CONTAINER_NAME}}/g, containerName);
200
+ }
201
+ async ensurePortAvailable(port) {
202
+ const candidates = [port, 5432, 5433, 5434, 5435, 5436, 5437];
203
+ for (const candidate of candidates) {
204
+ if (await this.isPortAvailable(candidate)) {
205
+ return candidate;
206
+ }
207
+ }
208
+ throw new Error(`No available PostgreSQL ports found. Tried: ${candidates.join(", ")}`);
209
+ }
210
+ async isPortAvailable(port) {
211
+ return new Promise((resolve) => {
212
+ const server = net.createServer();
213
+ server.once("error", () => resolve(false));
214
+ server.once("listening", () => {
215
+ server.close(() => resolve(true));
216
+ });
217
+ server.listen(port, "127.0.0.1");
218
+ });
219
+ }
220
+ async waitForReady(timeoutMs) {
221
+ const start = Date.now();
222
+ let delay = 500;
223
+ while (Date.now() - start < timeoutMs) {
224
+ try {
225
+ await this.execPgIsReady();
226
+ return;
227
+ } catch {
228
+ await new Promise((resolve) => setTimeout(resolve, delay));
229
+ delay = Math.min(delay * 1.5, 3e3);
230
+ }
231
+ }
232
+ throw new Error("Database did not become ready within timeout");
233
+ }
234
+ async execPgIsReady() {
235
+ const containerName = this.getContainerName();
236
+ const user = this.config.user ?? DEFAULTS.user;
237
+ const database = this.config.database ?? DEFAULTS.database;
238
+ await execFileAsync("docker", [
239
+ "exec",
240
+ containerName,
241
+ "pg_isready",
242
+ "-U",
243
+ user,
244
+ "-d",
245
+ database
246
+ ]);
247
+ }
248
+ async inspectContainer() {
249
+ const containerName = this.getContainerName();
250
+ try {
251
+ const { stdout } = await execFileAsync("docker", ["inspect", containerName]);
252
+ const parsed = JSON.parse(stdout);
253
+ return parsed?.[0] ?? null;
254
+ } catch {
255
+ return null;
256
+ }
257
+ }
258
+ };
259
+
260
+ export { DockerManager };
261
+ //# sourceMappingURL=chunk-TFLMPBX7.js.map
262
+ //# sourceMappingURL=chunk-TFLMPBX7.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"sources":["../src/storage/docker-manager.ts"],"names":[],"mappings":"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","file":"chunk-TFLMPBX7.js","sourcesContent":["import { execFile } from 'node:child_process';\nimport { promisify } from 'node:util';\nimport fs from 'node:fs/promises';\nimport path from 'node:path';\nimport net from 'node:net';\n\nconst execFileAsync = promisify(execFile);\n\nexport interface DockerConfig {\n repoName: string;\n port: number;\n containerName?: string;\n image?: string;\n user?: string;\n password?: string;\n database?: string;\n memoryLimit?: string;\n}\n\nexport interface StartOptions {\n forceRecreate?: boolean;\n waitForReady?: boolean;\n timeoutMs?: number;\n}\n\nexport interface StopOptions {\n removeVolumes?: boolean;\n timeoutMs?: number;\n}\n\nexport interface EnsureOptions {\n waitForReady?: boolean;\n}\n\nexport interface HealthCheckResult {\n containerRunning: boolean;\n databaseReady: boolean;\n connectionString: string;\n details?: string;\n}\n\nexport interface ContainerStats {\n cpuPercent?: string;\n memoryUsage?: string;\n memoryPercent?: string;\n netIO?: string;\n blockIO?: string;\n}\n\nexport interface LogOptions {\n tail?: number;\n since?: string;\n}\n\ninterface ComposeCommand {\n cmd: string;\n args: string[];\n}\n\nconst DEFAULTS = {\n image: 'pgvector/pgvector:pg16',\n user: 'neuron',\n password: 'neuron_dev',\n database: 'neuron_web',\n memoryLimit: '1g',\n};\n\nexport class DockerManager {\n private config: DockerConfig;\n private composeFilePath: string;\n\n constructor(config: DockerConfig) {\n this.config = { ...config };\n this.composeFilePath = path.join(process.cwd(), 'docker', 'docker-compose.neuron.yml');\n }\n\n async start(options?: StartOptions): Promise<void> {\n await this.assertDockerAvailable();\n await this.ensureComposeFile();\n\n const port = await this.ensurePortAvailable(this.config.port);\n if (port !== this.config.port) {\n this.config.port = port;\n await this.ensureComposeFile();\n }\n\n const compose = await this.getComposeCommand();\n const args = ['-f', this.composeFilePath, 'up', '-d'];\n if (options?.forceRecreate) {\n args.push('--force-recreate');\n }\n\n await execFileAsync(compose.cmd, [...compose.args, ...args]);\n\n if (options?.waitForReady ?? true) {\n await this.waitForReady(options?.timeoutMs ?? 60_000);\n }\n }\n\n async stop(options?: StopOptions): Promise<void> {\n await this.assertDockerAvailable();\n const compose = await this.getComposeCommand();\n const args = ['-f', this.composeFilePath, 'down'];\n if (options?.removeVolumes) {\n args.push('-v');\n }\n await execFileAsync(compose.cmd, [...compose.args, ...args]);\n }\n\n async ensureRunning(options?: EnsureOptions): Promise<void> {\n const running = await this.isRunning();\n if (!running) {\n await this.start({ waitForReady: options?.waitForReady });\n return;\n }\n\n if (options?.waitForReady ?? true) {\n await this.waitForReady(60_000);\n }\n }\n\n async isRunning(): Promise<boolean> {\n try {\n const status = await this.inspectContainer();\n return Boolean((status as { State?: { Running?: boolean } } | null)?.State?.Running);\n } catch {\n return false;\n }\n }\n\n async healthCheck(): Promise<HealthCheckResult> {\n const connectionString = await this.getConnectionString();\n const containerRunning = await this.isRunning();\n if (!containerRunning) {\n return {\n containerRunning: false,\n databaseReady: false,\n connectionString,\n details: 'Container not running',\n };\n }\n\n try {\n await this.execPgIsReady();\n return {\n containerRunning: true,\n databaseReady: true,\n connectionString,\n };\n } catch (error) {\n return {\n containerRunning: true,\n databaseReady: false,\n connectionString,\n details: error instanceof Error ? error.message : String(error),\n };\n }\n }\n\n async getStats(): Promise<ContainerStats> {\n const containerName = this.getContainerName();\n const { stdout } = await execFileAsync('docker', [\n 'stats',\n containerName,\n '--no-stream',\n '--format',\n '{{json .}}',\n ]);\n const trimmed = stdout.trim();\n if (!trimmed) {\n return {};\n }\n\n try {\n const parsed = JSON.parse(trimmed);\n return {\n cpuPercent: parsed.CPUPerc,\n memoryUsage: parsed.MemUsage,\n memoryPercent: parsed.MemPerc,\n netIO: parsed.NetIO,\n blockIO: parsed.BlockIO,\n };\n } catch {\n return {};\n }\n }\n\n async getConnectionString(): Promise<string> {\n const user = this.config.user ?? DEFAULTS.user;\n const password = this.config.password ?? DEFAULTS.password;\n const database = this.config.database ?? DEFAULTS.database;\n const port = this.config.port;\n return `postgresql://${user}:${password}@localhost:${port}/${database}`;\n }\n\n async getLogs(options?: LogOptions): Promise<string> {\n const containerName = this.getContainerName();\n const args = ['logs'];\n if (options?.tail) {\n args.push('--tail', String(options.tail));\n }\n if (options?.since) {\n args.push('--since', options.since);\n }\n args.push(containerName);\n const { stdout } = await execFileAsync('docker', args);\n return stdout;\n }\n\n async execSql(sql: string): Promise<string> {\n const containerName = this.getContainerName();\n const user = this.config.user ?? DEFAULTS.user;\n const database = this.config.database ?? DEFAULTS.database;\n const { stdout } = await execFileAsync('docker', [\n 'exec',\n containerName,\n 'psql',\n '-U',\n user,\n '-d',\n database,\n '-c',\n sql,\n ]);\n return stdout;\n }\n\n async updatePort(newPort: number): Promise<void> {\n this.config.port = newPort;\n await this.ensureComposeFile();\n }\n\n private async assertDockerAvailable(): Promise<void> {\n try {\n await execFileAsync('docker', ['--version']);\n } catch {\n throw new Error(\n 'Docker is not available. Install Docker Desktop: https://www.docker.com/products/docker-desktop/'\n );\n }\n }\n\n private async getComposeCommand(): Promise<ComposeCommand> {\n try {\n await execFileAsync('docker', ['compose', 'version']);\n return { cmd: 'docker', args: ['compose'] };\n } catch {\n return { cmd: 'docker-compose', args: [] };\n }\n }\n\n private getContainerName(): string {\n return this.config.containerName ?? `pg-${this.config.repoName}`;\n }\n\n private getVolumeName(): string {\n return `${this.config.repoName}_neuron_data`;\n }\n\n private async ensureComposeFile(): Promise<void> {\n const templatePath = path.join(process.cwd(), 'docker', 'docker-compose.template.yml');\n const template = await fs.readFile(templatePath, 'utf8');\n const rendered = this.renderTemplate(template);\n await fs.mkdir(path.dirname(this.composeFilePath), { recursive: true });\n await fs.writeFile(this.composeFilePath, rendered, 'utf8');\n }\n\n private renderTemplate(template: string): string {\n const image = this.config.image ?? DEFAULTS.image;\n const user = this.config.user ?? DEFAULTS.user;\n const password = this.config.password ?? DEFAULTS.password;\n const database = this.config.database ?? DEFAULTS.database;\n const memoryLimit = this.config.memoryLimit ?? DEFAULTS.memoryLimit;\n const containerName = this.getContainerName();\n const volumeName = this.getVolumeName();\n\n return template\n .replace(/{{REPO_NAME}}/g, this.config.repoName)\n .replace(/{{DB_PORT}}/g, String(this.config.port))\n .replace(/{{DB_USER}}/g, user)\n .replace(/{{DB_PASSWORD}}/g, password)\n .replace(/{{DB_NAME}}/g, database)\n .replace(/{{VOLUME_NAME}}/g, volumeName)\n .replace(/{{MEMORY_LIMIT}}/g, memoryLimit)\n .replace(/{{IMAGE_NAME}}/g, image)\n .replace(/{{CONTAINER_NAME}}/g, containerName);\n }\n\n private async ensurePortAvailable(port: number): Promise<number> {\n const candidates = [port, 5432, 5433, 5434, 5435, 5436, 5437];\n for (const candidate of candidates) {\n if (await this.isPortAvailable(candidate)) {\n return candidate;\n }\n }\n throw new Error(`No available PostgreSQL ports found. Tried: ${candidates.join(', ')}`);\n }\n\n private async isPortAvailable(port: number): Promise<boolean> {\n return new Promise((resolve) => {\n const server = net.createServer();\n server.once('error', () => resolve(false));\n server.once('listening', () => {\n server.close(() => resolve(true));\n });\n server.listen(port, '127.0.0.1');\n });\n }\n\n private async waitForReady(timeoutMs: number): Promise<void> {\n const start = Date.now();\n let delay = 500;\n while (Date.now() - start < timeoutMs) {\n try {\n await this.execPgIsReady();\n return;\n } catch {\n await new Promise((resolve) => setTimeout(resolve, delay));\n delay = Math.min(delay * 1.5, 3000);\n }\n }\n throw new Error('Database did not become ready within timeout');\n }\n\n private async execPgIsReady(): Promise<void> {\n const containerName = this.getContainerName();\n const user = this.config.user ?? DEFAULTS.user;\n const database = this.config.database ?? DEFAULTS.database;\n await execFileAsync('docker', [\n 'exec',\n containerName,\n 'pg_isready',\n '-U',\n user,\n '-d',\n database,\n ]);\n }\n\n private async inspectContainer(): Promise<Record<string, unknown> | null> {\n const containerName = this.getContainerName();\n try {\n const { stdout } = await execFileAsync('docker', ['inspect', containerName]);\n const parsed = JSON.parse(stdout);\n return parsed?.[0] ?? null;\n } catch {\n return null;\n }\n }\n}\n"]}