@omiron33/omi-neuron-web 0.1.0 → 0.1.1
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 +6 -2
- package/dist/NeuronWeb-BS4yLYQf.d.cts +85 -0
- package/dist/NeuronWeb-pWxbA_oL.d.ts +85 -0
- package/dist/api/index.cjs +32 -32
- package/dist/api/index.js +1 -1
- package/dist/chunk-2WP2AEZC.cjs +545 -0
- package/dist/chunk-2WP2AEZC.cjs.map +1 -0
- package/dist/{chunk-XNR42GCJ.js → chunk-6LW4KNAU.js} +2 -2
- package/dist/{chunk-XNR42GCJ.js.map → chunk-6LW4KNAU.js.map} +1 -1
- package/dist/chunk-DMF2DKZA.js +519 -0
- package/dist/chunk-DMF2DKZA.js.map +1 -0
- package/dist/{chunk-RTSFO7BW.cjs → chunk-OBZGUYGW.cjs} +2 -2
- package/dist/{chunk-RTSFO7BW.cjs.map → chunk-OBZGUYGW.cjs.map} +1 -1
- package/dist/cli/index.cjs +4 -4
- package/dist/cli/index.cjs.map +1 -1
- package/dist/cli/index.js +4 -4
- package/dist/cli/index.js.map +1 -1
- package/dist/index.cjs +51 -46
- package/dist/index.cjs.map +1 -1
- package/dist/index.d.cts +2 -1
- package/dist/index.d.ts +2 -1
- package/dist/index.js +5 -4
- package/dist/index.js.map +1 -1
- package/dist/visualization/index.cjs +21 -478
- package/dist/visualization/index.cjs.map +1 -1
- package/dist/visualization/index.d.cts +8 -75
- package/dist/visualization/index.d.ts +8 -75
- package/dist/visualization/index.js +1 -458
- package/dist/visualization/index.js.map +1 -1
- package/package.json +2 -2
|
@@ -1 +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"]}
|
|
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-OBZGUYGW.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\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"]}
|
package/dist/cli/index.cjs
CHANGED
|
@@ -54,12 +54,12 @@ async function writeTemplateFile(filePath, template, values, force = false) {
|
|
|
54
54
|
}
|
|
55
55
|
|
|
56
56
|
// src/cli/commands/init.ts
|
|
57
|
-
var CONFIG_TEMPLATE = `import { defineNeuronConfig, DEFAULT_ANALYSIS_SETTINGS, DEFAULT_VISUALIZATION_SETTINGS } from 'omi-neuron-web';
|
|
57
|
+
var CONFIG_TEMPLATE = `import { defineNeuronConfig, DEFAULT_ANALYSIS_SETTINGS, DEFAULT_VISUALIZATION_SETTINGS } from '@omiron33/omi-neuron-web';
|
|
58
58
|
|
|
59
59
|
export default defineNeuronConfig({
|
|
60
60
|
instance: {
|
|
61
61
|
name: '{{INSTANCE_NAME}}',
|
|
62
|
-
version: '0.1.
|
|
62
|
+
version: '0.1.1',
|
|
63
63
|
repoName: '{{REPO_NAME}}',
|
|
64
64
|
},
|
|
65
65
|
visualization: DEFAULT_VISUALIZATION_SETTINGS,
|
|
@@ -116,7 +116,7 @@ volumes:
|
|
|
116
116
|
{{REPO_NAME}}_neuron_data:
|
|
117
117
|
name: {{REPO_NAME}}_neuron_data
|
|
118
118
|
`;
|
|
119
|
-
var API_ROUTE_TEMPLATE = `import { createNeuronRoutes } from 'omi-neuron-web/api';
|
|
119
|
+
var API_ROUTE_TEMPLATE = `import { createNeuronRoutes } from '@omiron33/omi-neuron-web/api';
|
|
120
120
|
import config from '../../../../neuron.config';
|
|
121
121
|
|
|
122
122
|
const routes = createNeuronRoutes(config);
|
|
@@ -479,7 +479,7 @@ var validateCommand = new commander.Command("validate").description("Validate co
|
|
|
479
479
|
}
|
|
480
480
|
});
|
|
481
481
|
var CONFIG_FILE = path2__default.default.resolve("neuron.config.ts");
|
|
482
|
-
var serializeConfig = (config) => `import { defineNeuronConfig } from 'omi-neuron-web';
|
|
482
|
+
var serializeConfig = (config) => `import { defineNeuronConfig } from '@omiron33/omi-neuron-web';
|
|
483
483
|
|
|
484
484
|
export default defineNeuronConfig(${JSON.stringify(
|
|
485
485
|
config,
|
package/dist/cli/index.cjs.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"sources":["../../src/cli/utils/logger.ts","../../src/cli/utils/templates.ts","../../src/cli/commands/init.ts","../../src/cli/utils/config.ts","../../src/cli/utils/prompts.ts","../../src/cli/utils/spinner.ts","../../src/cli/commands/db.ts","../../src/cli/commands/analyze.ts","../../src/cli/commands/validate.ts","../../src/cli/commands/config.ts","../../src/cli/index.ts"],"names":["chalk","output","path","fs","Command","pathToFileURL","createInterface","input","DockerManager","Database","MigrationRunner","buildConnectionString","EventBus","EmbeddingsService","ClusteringEngine","RelationshipEngine","AnalysisPipeline","program"],"mappings":";;;;;;;;;;;;;;;;;;;;AAEO,IAAM,MAAA,GAAS;AAAA,EACpB,IAAA,EAAM,CAAC,OAAA,KAAoB;AACzB,IAAA,OAAA,CAAQ,IAAIA,sBAAA,CAAM,IAAA,CAAK,CAAA,aAAA,EAAgB,OAAO,EAAE,CAAC,CAAA;AAAA,EACnD,CAAA;AAAA,EACA,OAAA,EAAS,CAAC,OAAA,KAAoB;AAC5B,IAAA,OAAA,CAAQ,IAAIA,sBAAA,CAAM,KAAA,CAAM,CAAA,aAAA,EAAgB,OAAO,EAAE,CAAC,CAAA;AAAA,EACpD,CAAA;AAAA,EACA,IAAA,EAAM,CAAC,OAAA,KAAoB;AACzB,IAAA,OAAA,CAAQ,KAAKA,sBAAA,CAAM,MAAA,CAAO,CAAA,aAAA,EAAgB,OAAO,EAAE,CAAC,CAAA;AAAA,EACtD,CAAA;AAAA,EACA,KAAA,EAAO,CAAC,OAAA,KAAoB;AAC1B,IAAA,OAAA,CAAQ,MAAMA,sBAAA,CAAM,GAAA,CAAI,CAAA,aAAA,EAAgB,OAAO,EAAE,CAAC,CAAA;AAAA,EACpD;AACF,CAAA;ACZO,IAAM,cAAA,GAAiB,CAAC,QAAA,EAAkB,MAAA,KAA2C;AAC1F,EAAA,IAAIC,OAAAA,GAAS,QAAA;AACb,EAAA,KAAA,MAAW,CAAC,GAAA,EAAK,KAAK,KAAK,MAAA,CAAO,OAAA,CAAQ,MAAM,CAAA,EAAG;AACjD,IAAAA,OAAAA,GAASA,OAAAA,CAAO,OAAA,CAAQ,IAAI,MAAA,CAAO,KAAK,GAAG,CAAA,EAAA,CAAA,EAAM,GAAG,CAAA,EAAG,KAAK,CAAA;AAAA,EAC9D;AACA,EAAA,OAAOA,OAAAA;AACT,CAAA;AAEA,eAAsB,iBAAA,CACpB,QAAA,EACA,QAAA,EACA,MAAA,EACA,QAAQ,KAAA,EACO;AACf,EAAA,MAAM,QAAA,GAAWC,sBAAA,CAAK,OAAA,CAAQ,QAAQ,CAAA;AACtC,EAAA,MAAMC,mBAAA,CAAG,MAAMD,sBAAA,CAAK,OAAA,CAAQ,QAAQ,CAAA,EAAG,EAAE,SAAA,EAAW,IAAA,EAAM,CAAA;AAC1D,EAAA,IAAI;AACF,IAAA,MAAMC,mBAAA,CAAG,OAAO,QAAQ,CAAA;AACxB,IAAA,IAAI,CAAC,KAAA,EAAO;AACV,MAAA,MAAM,IAAI,KAAA,CAAM,CAAA,qBAAA,EAAwB,QAAQ,CAAA,CAAE,CAAA;AAAA,IACpD;AAAA,EACF,CAAA,CAAA,MAAQ;AAAA,EAER;AAEA,EAAA,MAAM,OAAA,GAAU,cAAA,CAAe,QAAA,EAAU,MAAM,CAAA;AAC/C,EAAA,MAAMA,mBAAA,CAAG,SAAA,CAAU,QAAA,EAAU,OAAA,EAAS,MAAM,CAAA;AAC9C;;;ACxBA,IAAM,eAAA,GAAkB,CAAA;;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,CAAA;AAkCxB,IAAM,YAAA,GAAe,CAAA;AAAA;AAAA;AAAA,CAAA;AAKrB,IAAM,eAAA,GAAkB,CAAA;;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;;AAAA;AAAA;AAAA;AAAA,CAAA;AA0BxB,IAAM,kBAAA,GAAqB,CAAA;AAAA;;AAAA;;AAAA;AAAA;AAAA,CAAA;AASpB,IAAM,cAAc,IAAIC,iBAAA,CAAQ,MAAM,CAAA,CAC1C,WAAA,CAAY,2CAA2C,CAAA,CACvD,MAAA,CAAO,eAAA,EAAiB,yCAAyC,EACjE,MAAA,CAAO,eAAA,EAAiB,mCAAmC,MAAM,CAAA,CACjE,OAAO,eAAA,EAAiB,6BAA6B,CAAA,CACrD,MAAA,CAAO,cAAc,gCAAgC,CAAA,CACrD,OAAO,eAAA,EAAiB,iCAAiC,EACzD,MAAA,CAAO,kBAAA,EAAoB,+BAAA,EAAiC,OAAO,EACnE,MAAA,CAAO,SAAA,EAAW,0BAA0B,CAAA,CAC5C,MAAA,CAAO,OAAO,OAAA,KAAY;AACzB,EAAA,MAAM,QAAA,GAAWF,sBAAAA,CAAK,QAAA,CAAS,OAAA,CAAQ,KAAK,CAAA;AAC5C,EAAA,MAAM,YAAA,GAAe,QAAQ,IAAA,IAAQ,QAAA;AACrC,EAAA,MAAM,IAAA,GAAO,MAAA,CAAO,OAAA,CAAQ,IAAA,IAAQ,IAAI,CAAA;AAExC,EAAA,IAAI,CAAC,QAAQ,UAAA,EAAY;AACvB,IAAA,MAAM,iBAAA;AAAA,MACJA,sBAAAA,CAAK,IAAA,CAAK,OAAA,CAAQ,GAAA,IAAO,kBAAkB,CAAA;AAAA,MAC3C,eAAA;AAAA,MACA;AAAA,QACE,aAAA,EAAe,YAAA;AAAA,QACf,SAAA,EAAW,QAAA;AAAA,QACX,OAAA,EAAS,OAAO,IAAI;AAAA,OACtB;AAAA,MACA,OAAA,CAAQ;AAAA,KACV;AACA,IAAA,MAAA,CAAO,QAAQ,0BAA0B,CAAA;AAAA,EAC3C;AAEA,EAAA,IAAI,CAAC,QAAQ,UAAA,EAAY;AACvB,IAAA,MAAM,iBAAA;AAAA,MACJA,sBAAAA,CAAK,IAAA,CAAK,OAAA,CAAQ,GAAA,IAAO,2BAA2B,CAAA;AAAA,MACpD,eAAA;AAAA,MACA;AAAA,QACE,SAAA,EAAW,QAAA;AAAA,QACX,OAAA,EAAS,OAAO,IAAI;AAAA,OACtB;AAAA,MACA,OAAA,CAAQ;AAAA,KACV;AACA,IAAA,MAAA,CAAO,QAAQ,mCAAmC,CAAA;AAAA,EACpD;AAEA,EAAA,MAAM,iBAAA;AAAA,IACJA,sBAAAA,CAAK,IAAA,CAAK,OAAA,CAAQ,GAAA,IAAO,mBAAmB,CAAA;AAAA,IAC5C,YAAA;AAAA,IACA,EAAC;AAAA,IACD,OAAA,CAAQ;AAAA,GACV;AACA,EAAA,MAAA,CAAO,QAAQ,2BAA2B,CAAA;AAE1C,EAAA,IAAI,CAAC,QAAQ,OAAA,EAAS;AACpB,IAAA,MAAM,OAAA,GAAUA,sBAAAA,CAAK,IAAA,CAAK,OAAA,CAAQ,GAAA,IAAO,OAAA,CAAQ,MAAA,EAAQ,KAAA,EAAO,QAAA,EAAU,WAAW,CAAA;AACrF,IAAA,MAAMC,oBAAG,KAAA,CAAM,OAAA,EAAS,EAAE,SAAA,EAAW,MAAM,CAAA;AAC3C,IAAA,MAAMA,mBAAAA,CAAG,UAAUD,sBAAAA,CAAK,IAAA,CAAK,SAAS,UAAU,CAAA,EAAG,oBAAoB,MAAM,CAAA;AAC7E,IAAA,MAAA,CAAO,QAAQ,gCAAgC,CAAA;AAAA,EACjD;AAEA,EAAA,MAAA,CAAO,KAAK,0BAA0B,CAAA;AACxC,CAAC,CAAA;AC1HH,eAAsB,gBAAA,GAAiD;AACrE,EAAA,MAAM,UAAA,GAAaA,sBAAAA,CAAK,OAAA,CAAQ,kBAAkB,CAAA;AAClD,EAAA,IAAI;AACF,IAAA,MAAMC,mBAAAA,CAAG,OAAO,UAAU,CAAA;AAAA,EAC5B,CAAA,CAAA,MAAQ;AACN,IAAA,OAAO,IAAA;AAAA,EACT;AAEA,EAAA,IAAI;AACF,IAAA,MAAM,SAAS,MAAM,OAAOE,iBAAA,CAAc,UAAU,EAAE,QAAA,EAAS,CAAA;AAC/D,IAAA,OAAO,OAAO,OAAA,IAAW,MAAA;AAAA,EAC3B,SAAS,KAAA,EAAO;AACd,IAAA,MAAM,IAAI,KAAA;AAAA,MACR,CAAA,4EAAA,EAA+E,MAAA,CAAO,KAAK,CAAC,CAAA;AAAA,KAC9F;AAAA,EACF;AACF;AAEA,eAAsB,iBAAiB,SAAA,EAAoD;AACzF,EAAA,MAAM,WAAW,SAAA,EAAW,QAAA,IAAYH,uBAAK,QAAA,CAAS,OAAA,CAAQ,KAAK,CAAA;AACnE,EAAA,IAAI,MAAA,GAA8B,IAAA;AAElC,EAAA,IAAI;AACF,IAAA,MAAA,GAAS,MAAM,gBAAA,EAAiB;AAAA,EAClC,CAAA,CAAA,MAAQ;AACN,IAAA,MAAA,GAAS,IAAA;AAAA,EACX;AAEA,EAAA,OAAO;AAAA,IACL,QAAA;AAAA,IACA,IAAA,EACE,SAAA,EAAW,IAAA,IACX,MAAA,EAAQ,QAAA,EAAU,IAAA,KACjB,OAAA,CAAQ,GAAA,CAAI,OAAA,GAAU,MAAA,CAAO,OAAA,CAAQ,GAAA,CAAI,OAAO,CAAA,GAAI,IAAA,CAAA;AAAA,IACvD,aAAA,EAAe,SAAA,EAAW,aAAA,IAAiB,MAAA,EAAQ,QAAA,EAAU,aAAA;AAAA,IAC7D,aAAa,SAAA,EAAW,WAAA,IAAe,QAAQ,QAAA,EAAU,GAAA,IAAO,QAAQ,GAAA,CAAI,YAAA;AAAA,IAC5E,cAAc,SAAA,EAAW,YAAA,IAAgB,QAAQ,QAAA,EAAU,IAAA,IAAQ,QAAQ,GAAA,CAAI,OAAA;AAAA,IAC/E,kBACE,SAAA,EAAW,gBAAA,IAAoB,QAAQ,QAAA,EAAU,QAAA,IAAY,QAAQ,GAAA,CAAI,WAAA;AAAA,IAC3E,cAAc,SAAA,EAAW,YAAA,IAAgB,QAAQ,QAAA,EAAU,QAAA,IAAY,QAAQ,GAAA,CAAI;AAAA,GACrF;AACF;ACrDA,eAAsB,cAAc,OAAA,EAAmC;AACrE,EAAA,MAAM,EAAA,GAAKI,wBAAA,CAAgB,SAAEC,eAAA,UAAON,kBAAQ,CAAA;AAC5C,EAAA,MAAM,SAAS,MAAM,EAAA,CAAG,QAAA,CAAS,CAAA,EAAG,OAAO,CAAA,QAAA,CAAU,CAAA;AACrD,EAAA,EAAA,CAAG,KAAA,EAAM;AACT,EAAA,OAAO,MAAA,CAAO,IAAA,EAAK,CAAE,WAAA,EAAY,KAAM,GAAA;AACzC;;;ACNO,IAAM,UAAN,MAAc;AAAA,EAMnB,YAAoB,OAAA,EAAiB;AAAjB,IAAA,IAAA,CAAA,OAAA,GAAA,OAAA;AAAA,EAAkB;AAAA,EAL9B,KAAA,GAAsB,SAAA;AAAA,EACtB,UAAA,GAAoC,IAAA;AAAA,EACpC,MAAA,GAAS,CAAC,GAAA,EAAK,IAAA,EAAM,KAAK,GAAG,CAAA;AAAA,EAC7B,UAAA,GAAa,CAAA;AAAA,EAIrB,KAAA,GAAc;AACZ,IAAA,IAAI,IAAA,CAAK,UAAU,SAAA,EAAW;AAC9B,IAAA,IAAA,CAAK,KAAA,GAAQ,SAAA;AACb,IAAA,IAAA,CAAK,UAAA,GAAa,YAAY,MAAM;AAClC,MAAA,MAAM,QAAQ,IAAA,CAAK,MAAA,CAAO,KAAK,UAAA,GAAa,IAAA,CAAK,OAAO,MAAM,CAAA;AAC9D,MAAA,IAAA,CAAK,UAAA,IAAc,CAAA;AACnB,MAAA,OAAA,CAAQ,OAAO,KAAA,CAAM,CAAA,EAAA,EAAK,KAAK,CAAA,CAAA,EAAI,IAAA,CAAK,OAAO,CAAA,CAAE,CAAA;AAAA,IACnD,GAAG,GAAG,CAAA;AAAA,EACR;AAAA,EAEA,IAAA,CAAK,OAAA,GAAU,IAAA,EAAM,YAAA,EAA6B;AAChD,IAAA,IAAI,KAAK,UAAA,EAAY;AACnB,MAAA,aAAA,CAAc,KAAK,UAAU,CAAA;AAAA,IAC/B;AACA,IAAA,IAAA,CAAK,KAAA,GAAQ,SAAA;AACb,IAAA,MAAM,MAAA,GAAS,UAAU,QAAA,GAAM,QAAA;AAC/B,IAAA,OAAA,CAAQ,OAAO,KAAA,CAAM,CAAA,EAAA,EAAK,MAAM,CAAA,CAAA,EAAI,YAAA,IAAgB,KAAK,OAAO;AAAA,CAAI,CAAA;AAAA,EACtE;AACF,CAAA;;;ACnBA,IAAM,qBAAA,GAAwB,CAAC,MAAA,KAMzB;AACJ,EAAA,IAAI,MAAA,CAAO,WAAA,EAAa,OAAO,MAAA,CAAO,WAAA;AACtC,EAAA,MAAM,IAAA,GAAO,OAAO,YAAA,IAAgB,QAAA;AACpC,EAAA,MAAM,QAAA,GAAW,OAAO,gBAAA,IAAoB,YAAA;AAC5C,EAAA,MAAM,QAAA,GAAW,OAAO,YAAA,IAAgB,YAAA;AACxC,EAAA,OAAO,CAAA,aAAA,EAAgB,IAAI,CAAA,CAAA,EAAI,QAAQ,cAAc,MAAA,CAAO,IAAI,IAAI,QAAQ,CAAA,CAAA;AAC9E,CAAA;AAEO,IAAM,YAAY,IAAIG,iBAAAA,CAAQ,IAAI,CAAA,CACtC,WAAA,CAAY,8BAA8B,CAAA,CAC1C,UAAA;AAAA,EACC,IAAIA,kBAAQ,IAAI,CAAA,CACb,YAAY,4BAA4B,CAAA,CACxC,MAAA,CAAO,eAAA,EAAiB,eAAe,CAAA,CACvC,OAAO,kBAAA,EAAoB,0BAA0B,EACrD,MAAA,CAAO,QAAA,EAAU,sBAAsB,IAAI,CAAA,CAC3C,MAAA,CAAO,OAAO,OAAA,KAAY;AACzB,IAAA,MAAM,MAAA,GAAS,MAAM,gBAAA,CAAiB;AAAA,MACpC,MAAM,OAAA,CAAQ,IAAA,GAAO,MAAA,CAAO,OAAA,CAAQ,IAAI,CAAA,GAAI;AAAA,KAC7C,CAAA;AACD,IAAA,MAAM,MAAA,GAAS,IAAII,+BAAA,CAAc;AAAA,MAC/B,UAAU,MAAA,CAAO,QAAA;AAAA,MACjB,MAAM,MAAA,CAAO,IAAA;AAAA,MACb,eAAe,MAAA,CAAO,aAAA;AAAA,MACtB,MAAM,MAAA,CAAO,YAAA;AAAA,MACb,UAAU,MAAA,CAAO,gBAAA;AAAA,MACjB,UAAU,MAAA,CAAO;AAAA,KAClB,CAAA;AACD,IAAA,MAAM,OAAA,GAAU,IAAI,OAAA,CAAQ,+BAA+B,CAAA;AAC3D,IAAA,OAAA,CAAQ,KAAA,EAAM;AACd,IAAA,MAAM,OAAO,KAAA,CAAM;AAAA,MACjB,eAAe,OAAA,CAAQ,aAAA;AAAA,MACvB,cAAc,OAAA,CAAQ;AAAA,KACvB,CAAA;AACD,IAAA,OAAA,CAAQ,IAAA,CAAK,MAAM,gBAAgB,CAAA;AACnC,IAAA,MAAM,gBAAA,GAAmB,MAAM,MAAA,CAAO,mBAAA,EAAoB;AAC1D,IAAA,MAAA,CAAO,IAAA,CAAK,CAAA,mBAAA,EAAsB,gBAAgB,CAAA,CAAE,CAAA;AAAA,EACtD,CAAC;AACL,CAAA,CACC,UAAA;AAAA,EACC,IAAIJ,iBAAAA,CAAQ,MAAM,CAAA,CACf,WAAA,CAAY,2BAA2B,CAAA,CACvC,MAAA,CAAO,kBAAA,EAAoB,8BAA8B,CAAA,CACzD,MAAA,CAAO,OAAO,OAAA,KAAY;AACzB,IAAA,MAAM,MAAA,GAAS,MAAM,gBAAA,EAAiB;AACtC,IAAA,MAAM,MAAA,GAAS,IAAII,+BAAA,CAAc;AAAA,MAC/B,UAAU,MAAA,CAAO,QAAA;AAAA,MACjB,MAAM,MAAA,CAAO,IAAA;AAAA,MACb,eAAe,MAAA,CAAO;AAAA,KACvB,CAAA;AACD,IAAA,MAAM,OAAO,IAAA,CAAK,EAAE,aAAA,EAAe,OAAA,CAAQ,eAAe,CAAA;AAC1D,IAAA,MAAA,CAAO,QAAQ,4BAA4B,CAAA;AAAA,EAC7C,CAAC;AACL,CAAA,CACC,UAAA;AAAA,EACC,IAAIJ,iBAAAA,CAAQ,SAAS,CAAA,CAClB,WAAA,CAAY,gBAAgB,CAAA,CAC5B,MAAA,CAAO,UAAA,EAAY,kBAAkB,CAAA,CACrC,MAAA,CAAO,sBAAsB,uBAAuB,CAAA,CACpD,MAAA,CAAO,gBAAA,EAAkB,6BAA6B,CAAA,CACtD,MAAA,CAAO,WAAA,EAAa,4BAA4B,CAAA,CAChD,MAAA,CAAO,OAAO,OAAA,KAAY;AACzB,IAAA,MAAM,MAAA,GAAS,MAAM,gBAAA,EAAiB;AACtC,IAAA,MAAM,EAAA,GAAK,IAAIK,0BAAA,CAAS;AAAA,MACtB,gBAAA,EAAkB,sBAAsB,MAAM;AAAA,KAC/C,CAAA;AACD,IAAA,MAAM,MAAA,GAAS,IAAIC,iCAAA,CAAgB,EAAE,CAAA;AAErC,IAAA,IAAI,QAAQ,MAAA,EAAQ;AAClB,MAAA,MAAM,MAAA,GAAS,MAAM,MAAA,CAAO,SAAA,EAAU;AACtC,MAAA,MAAA,CAAO,OAAA,CAAQ,CAAC,IAAA,KAAS;AACvB,QAAA,MAAA,CAAO,IAAA,CAAK,CAAA,EAAG,IAAA,CAAK,OAAO,CAAA,CAAA,EAAI,KAAK,IAAI,CAAA,GAAA,EAAM,IAAA,CAAK,MAAM,CAAA,CAAE,CAAA;AAAA,MAC7D,CAAC,CAAA;AACD,MAAA;AAAA,IACF;AAEA,IAAA,IAAI,QAAQ,MAAA,EAAQ;AAClB,MAAA,MAAM,MAAM,MAAM,MAAA,CAAO,OAAO,OAAA,CAAQ,QAAA,GAAW,SAAS,IAAI,CAAA;AAChE,MAAA,MAAA,CAAO,IAAA,CAAK,GAAA,CAAI,IAAA,CAAK,MAAM,CAAC,CAAA;AAC5B,MAAA;AAAA,IACF;AAEA,IAAA,IAAI,QAAQ,QAAA,EAAU;AACpB,MAAA,MAAM,MAAA,CAAO,KAAK,EAAE,KAAA,EAAO,OAAO,OAAA,CAAQ,QAAQ,GAAG,CAAA;AACrD,MAAA,MAAA,CAAO,QAAQ,mBAAmB,CAAA;AAClC,MAAA;AAAA,IACF;AAEA,IAAA,MAAM,OAAO,EAAA,CAAG,EAAE,EAAA,EAAI,OAAA,CAAQ,IAAI,CAAA;AAClC,IAAA,MAAA,CAAO,QAAQ,qBAAqB,CAAA;AAAA,EACtC,CAAC;AACL,CAAA,CACC,UAAA;AAAA,EACC,IAAIN,iBAAAA,CAAQ,QAAQ,CAAA,CACjB,WAAA,CAAY,sBAAsB,CAAA,CAClC,MAAA,CAAO,QAAA,EAAU,aAAa,EAC9B,MAAA,CAAO,WAAA,EAAa,eAAe,CAAA,CACnC,MAAA,CAAO,OAAO,OAAA,KAAY;AACzB,IAAA,MAAM,MAAA,GAAS,MAAM,gBAAA,EAAiB;AACtC,IAAA,MAAM,MAAA,GAAS,IAAII,+BAAA,CAAc;AAAA,MAC/B,UAAU,MAAA,CAAO,QAAA;AAAA,MACjB,MAAM,MAAA,CAAO,IAAA;AAAA,MACb,eAAe,MAAA,CAAO;AAAA,KACvB,CAAA;AACD,IAAA,MAAM,MAAA,GAAS,MAAM,MAAA,CAAO,WAAA,EAAY;AAExC,IAAA,IAAI,QAAQ,IAAA,EAAM;AAChB,MAAA,OAAA,CAAQ,IAAI,IAAA,CAAK,SAAA,CAAU,MAAA,EAAQ,IAAA,EAAM,CAAC,CAAC,CAAA;AAC3C,MAAA;AAAA,IACF;AAEA,IAAA,MAAA,CAAO,IAAA,CAAK,CAAA,mBAAA,EAAsB,MAAA,CAAO,gBAAgB,CAAA,CAAE,CAAA;AAC3D,IAAA,MAAA,CAAO,IAAA,CAAK,CAAA,gBAAA,EAAmB,MAAA,CAAO,aAAa,CAAA,CAAE,CAAA;AACrD,IAAA,IAAI,QAAQ,OAAA,EAAS;AACnB,MAAA,MAAM,KAAA,GAAQ,MAAM,MAAA,CAAO,QAAA,EAAS;AACpC,MAAA,MAAA,CAAO,KAAK,CAAA,OAAA,EAAU,IAAA,CAAK,SAAA,CAAU,KAAK,CAAC,CAAA,CAAE,CAAA;AAAA,IAC/C;AAAA,EACF,CAAC;AACL,CAAA,CACC,UAAA;AAAA,EACC,IAAIJ,iBAAAA,CAAQ,OAAO,CAAA,CAChB,WAAA,CAAY,uBAAuB,CAAA,CACnC,MAAA,CAAO,WAAA,EAAa,0BAA0B,CAAA,CAC9C,MAAA,CAAO,OAAO,OAAA,KAAY;AACzB,IAAA,IAAI,CAAC,QAAQ,OAAA,EAAS;AACpB,MAAA,MAAM,SAAA,GAAY,MAAM,aAAA,CAAc,sDAAsD,CAAA;AAC5F,MAAA,IAAI,CAAC,SAAA,EAAW;AAAA,IAClB;AACA,IAAA,MAAM,MAAA,GAAS,MAAM,gBAAA,EAAiB;AACtC,IAAA,MAAM,EAAA,GAAK,IAAIK,0BAAA,CAAS;AAAA,MACtB,gBAAA,EAAkB,sBAAsB,MAAM;AAAA,KAC/C,CAAA;AACD,IAAA,MAAM,MAAA,GAAS,IAAIC,iCAAA,CAAgB,EAAE,CAAA;AACrC,IAAA,MAAM,OAAO,KAAA,EAAM;AACnB,IAAA,MAAA,CAAO,QAAQ,yBAAyB,CAAA;AAAA,EAC1C,CAAC;AACL,CAAA,CACC,UAAA;AAAA,EACC,IAAIN,kBAAQ,MAAM,CAAA,CACf,YAAY,gCAAgC,CAAA,CAC5C,MAAA,CAAO,eAAA,EAAiB,kBAAkB,CAAA,CAC1C,OAAO,SAAA,EAAW,sBAAsB,EACxC,MAAA,CAAO,aAAA,EAAe,2BAA2B,IAAI,CAAA,CACrD,MAAA,CAAO,OAAO,OAAA,KAAY;AACzB,IAAA,MAAM,MAAA,GAAS,MAAM,gBAAA,EAAiB;AACtC,IAAA,MAAM,EAAA,GAAK,IAAIK,0BAAA,CAAS;AAAA,MACtB,gBAAA,EAAkB,sBAAsB,MAAM;AAAA,KAC/C,CAAA;AACD,IAAA,IAAI,QAAQ,KAAA,EAAO;AACjB,MAAA,MAAM,EAAA,CAAG,QAAQ,mBAAmB,CAAA;AACpC,MAAA,MAAM,EAAA,CAAG,QAAQ,mBAAmB,CAAA;AAAA,IACtC;AACA,IAAA,MAAM,KAAA,GAAQ,MAAA,CAAO,OAAA,CAAQ,KAAA,IAAS,EAAE,CAAA;AACxC,IAAA,KAAA,IAAS,CAAA,GAAI,CAAA,EAAG,CAAA,GAAI,KAAA,EAAO,KAAK,CAAA,EAAG;AACjC,MAAA,MAAM,EAAA,CAAG,OAAA;AAAA,QACP,0FAAA;AAAA,QACA,CAAC,CAAA,KAAA,EAAQ,CAAA,GAAI,CAAC,CAAA,CAAA,EAAI,CAAA,UAAA,EAAa,CAAA,GAAI,CAAC,CAAA,CAAA,EAAI,SAAA,EAAW,SAAA,EAAW,EAAE;AAAA,OAClE;AAAA,IACF;AACA,IAAA,MAAA,CAAO,QAAQ,oBAAoB,CAAA;AAAA,EACrC,CAAC;AACL,CAAA;ACtKF,IAAME,sBAAAA,GAAwB,CAAC,MAAA,KAMzB;AACJ,EAAA,IAAI,MAAA,CAAO,WAAA,EAAa,OAAO,MAAA,CAAO,WAAA;AACtC,EAAA,MAAM,IAAA,GAAO,OAAO,YAAA,IAAgB,QAAA;AACpC,EAAA,MAAM,QAAA,GAAW,OAAO,gBAAA,IAAoB,YAAA;AAC5C,EAAA,MAAM,QAAA,GAAW,OAAO,YAAA,IAAgB,YAAA;AACxC,EAAA,OAAO,CAAA,aAAA,EAAgB,IAAI,CAAA,CAAA,EAAI,QAAQ,cAAc,MAAA,CAAO,IAAI,IAAI,QAAQ,CAAA,CAAA;AAC9E,CAAA;AAEA,eAAe,aAAA,GAA2C;AACxD,EAAA,MAAM,MAAA,GAAS,MAAM,gBAAA,EAAiB;AACtC,EAAA,MAAM,EAAA,GAAK,IAAIF,0BAAA,CAAS,EAAE,kBAAkBE,sBAAAA,CAAsB,MAAM,GAAG,CAAA;AAC3E,EAAA,MAAM,MAAA,GAAS,IAAIC,0BAAA,EAAS;AAE5B,EAAA,MAAM,aAAa,IAAIC,mCAAA;AAAA,IACrB;AAAA,MACE,YAAA,EAAc,OAAA,CAAQ,GAAA,CAAI,cAAA,IAAkB,EAAA;AAAA,MAC5C,KAAA,EAAO,wBAAA;AAAA,MACP,SAAA,EAAW,EAAA;AAAA,MACX,SAAA,EAAW,EAAA;AAAA,MACX,QAAA,EAAU,KAAA;AAAA,MACV,UAAA,EAAY;AAAA,KACd;AAAA,IACA;AAAA,GACF;AAEA,EAAA,MAAM,UAAA,GAAa,IAAIC,kCAAA,CAAiB,EAAA,EAAI,UAAU,CAAA;AACtD,EAAA,MAAM,aAAA,GAAgB,IAAIC,oCAAA,CAAmB,EAAA,EAAI;AAAA,IAC/C,KAAA,EAAO,aAAA;AAAA,IACP,aAAA,EAAe,GAAA;AAAA,IACf,UAAA,EAAY,EAAA;AAAA,IACZ,mBAAA,EAAqB,IAAA;AAAA,IACrB,eAAA,EAAiB,KAAA;AAAA,IACjB,SAAA,EAAW,EAAA;AAAA,IACX,SAAA,EAAW;AAAA,GACZ,CAAA;AAED,EAAA,OAAO,IAAIC,kCAAA,CAAiB,EAAA,EAAI,UAAA,EAAY,UAAA,EAAY,eAAe,MAAM,CAAA;AAC/E;AAEO,IAAM,iBAAiB,IAAIZ,iBAAAA,CAAQ,SAAS,CAAA,CAChD,WAAA,CAAY,mBAAmB,CAAA,CAC/B,UAAA;AAAA,EACC,IAAIA,iBAAAA,CAAQ,YAAY,CAAA,CACrB,WAAA,CAAY,qBAAqB,CAAA,CACjC,MAAA,CAAO,kBAAA,EAAoB,0BAA0B,EACrD,MAAA,CAAO,SAAA,EAAW,qBAAqB,CAAA,CACvC,MAAA,CAAO,OAAO,OAAA,KAAY;AACzB,IAAA,MAAM,QAAA,GAAW,MAAM,aAAA,EAAc;AACrC,IAAA,MAAM,UAAU,OAAA,CAAQ,OAAA,GAAU,QAAQ,OAAA,CAAQ,KAAA,CAAM,GAAG,CAAA,GAAI,MAAA;AAC/D,IAAA,MAAM,SAAS,aAAA,CAAc,EAAE,SAAS,cAAA,EAAgB,OAAA,CAAQ,OAAO,CAAA;AACvE,IAAA,MAAA,CAAO,QAAQ,qBAAqB,CAAA;AAAA,EACtC,CAAC;AACL,CAAA,CACC,UAAA;AAAA,EACC,IAAIA,iBAAAA,CAAQ,SAAS,EAClB,WAAA,CAAY,gBAAgB,EAC5B,MAAA,CAAO,aAAA,EAAe,oBAAoB,CAAA,CAC1C,OAAO,mBAAA,EAAqB,8BAAA,EAAgC,QAAQ,CAAA,CACpE,MAAA,CAAO,OAAO,OAAA,KAAY;AACzB,IAAA,MAAM,QAAA,GAAW,MAAM,aAAA,EAAc;AACrC,IAAA,MAAM,SAAS,aAAA,CAAc;AAAA,MAC3B,cAAc,OAAA,CAAQ,KAAA,GAAQ,MAAA,CAAO,OAAA,CAAQ,KAAK,CAAA,GAAI,MAAA;AAAA,MACtD,qBAAqB,OAAA,CAAQ;AAAA,KAC9B,CAAA;AACD,IAAA,MAAA,CAAO,QAAQ,qBAAqB,CAAA;AAAA,EACtC,CAAC;AACL,CAAA,CACC,UAAA;AAAA,EACC,IAAIA,iBAAAA,CAAQ,eAAe,EACxB,WAAA,CAAY,qBAAqB,EACjC,MAAA,CAAO,iBAAA,EAAmB,sBAAA,EAAwB,KAAK,EACvD,MAAA,CAAO,WAAA,EAAa,qBAAqB,CAAA,CACzC,MAAA,CAAO,OAAO,OAAA,KAAY;AACzB,IAAA,MAAM,QAAA,GAAW,MAAM,aAAA,EAAc;AACrC,IAAA,MAAM,SAAS,gBAAA,CAAiB;AAAA,MAC9B,qBAAA,EAAuB,MAAA,CAAO,OAAA,CAAQ,SAAS;AAAA,KAChD,CAAA;AACD,IAAA,MAAA,CAAO,QAAQ,iCAAiC,CAAA;AAAA,EAClD,CAAC;AACL,CAAA,CACC,UAAA;AAAA,EACC,IAAIA,iBAAAA,CAAQ,MAAM,CAAA,CACf,WAAA,CAAY,4BAA4B,CAAA,CACxC,MAAA,CAAO,SAAA,EAAW,qBAAqB,CAAA,CACvC,MAAA,CAAO,OAAO,OAAA,KAAY;AACzB,IAAA,MAAM,QAAA,GAAW,MAAM,aAAA,EAAc;AACrC,IAAA,MAAM,SAAS,OAAA,CAAQ,EAAE,cAAA,EAAgB,OAAA,CAAQ,OAAO,CAAA;AACxD,IAAA,MAAA,CAAO,QAAQ,4BAA4B,CAAA;AAAA,EAC7C,CAAC;AACL,CAAA;AChGF,IAAMO,sBAAAA,GAAwB,CAAC,MAAA,KAMzB;AACJ,EAAA,IAAI,MAAA,CAAO,WAAA,EAAa,OAAO,MAAA,CAAO,WAAA;AACtC,EAAA,MAAM,IAAA,GAAO,OAAO,YAAA,IAAgB,QAAA;AACpC,EAAA,MAAM,QAAA,GAAW,OAAO,gBAAA,IAAoB,YAAA;AAC5C,EAAA,MAAM,QAAA,GAAW,OAAO,YAAA,IAAgB,YAAA;AACxC,EAAA,OAAO,CAAA,aAAA,EAAgB,IAAI,CAAA,CAAA,EAAI,QAAQ,cAAc,MAAA,CAAO,IAAI,IAAI,QAAQ,CAAA,CAAA;AAC9E,CAAA;AAEO,IAAM,kBAAkB,IAAIP,iBAAAA,CAAQ,UAAU,CAAA,CAClD,WAAA,CAAY,kCAAkC,CAAA,CAC9C,MAAA,CAAO,OAAA,EAAS,uBAAuB,EACvC,MAAA,CAAO,WAAA,EAAa,0BAA0B,CAAA,CAC9C,MAAA,CAAO,OAAO,OAAA,KAAY;AACzB,EAAA,MAAM,MAAA,GAAS,MAAM,gBAAA,EAAiB;AACtC,EAAA,IAAI,QAAA,GAAW,KAAA;AAEf,EAAA,MAAM,UAAA,GAAaF,sBAAAA,CAAK,OAAA,CAAQ,kBAAkB,CAAA;AAClD,EAAA,IAAI;AACF,IAAA,MAAMC,mBAAAA,CAAG,OAAO,UAAU,CAAA;AAC1B,IAAA,MAAA,CAAO,QAAQ,yBAAyB,CAAA;AAAA,EAC1C,CAAA,CAAA,MAAQ;AACN,IAAA,QAAA,GAAW,IAAA;AACX,IAAA,MAAA,CAAO,MAAM,4BAA4B,CAAA;AAAA,EAC3C;AAEA,EAAA,IAAI;AACF,IAAA,MAAM,MAAA,GAAS,IAAIK,+BAAA,CAAc,EAAE,QAAA,EAAU,OAAO,QAAA,EAAU,IAAA,EAAM,MAAA,CAAO,IAAA,EAAM,CAAA;AACjF,IAAA,MAAM,MAAA,GAAS,MAAM,MAAA,CAAO,WAAA,EAAY;AACxC,IAAA,MAAA,CAAO,IAAA,CAAK,CAAA,0BAAA,EAA6B,MAAA,CAAO,gBAAgB,CAAA,CAAE,CAAA;AAClE,IAAA,MAAA,CAAO,IAAA,CAAK,CAAA,gBAAA,EAAmB,MAAA,CAAO,aAAa,CAAA,CAAE,CAAA;AAAA,EACvD,SAAS,KAAA,EAAO;AACd,IAAA,QAAA,GAAW,IAAA;AACX,IAAA,MAAA,CAAO,KAAA,CAAM,CAAA,qBAAA,EAAwB,MAAA,CAAO,KAAK,CAAC,CAAA,CAAE,CAAA;AAAA,EACtD;AAEA,EAAA,IAAI;AACF,IAAA,MAAM,EAAA,GAAK,IAAIC,0BAAA,CAAS,EAAE,kBAAkBE,sBAAAA,CAAsB,MAAM,GAAG,CAAA;AAC3E,IAAA,MAAM,GAAG,OAAA,EAAQ;AACjB,IAAA,MAAA,CAAO,QAAQ,wBAAwB,CAAA;AACvC,IAAA,MAAM,MAAA,GAAS,IAAID,iCAAA,CAAgB,EAAE,CAAA;AACrC,IAAA,MAAM,OAAA,GAAU,MAAM,MAAA,CAAO,UAAA,EAAW;AACxC,IAAA,IAAI,OAAA,CAAQ,SAAS,CAAA,EAAG;AACtB,MAAA,MAAA,CAAO,IAAA,CAAK,CAAA,oBAAA,EAAuB,OAAA,CAAQ,GAAA,CAAI,CAAC,CAAA,KAAM,CAAA,CAAE,OAAO,CAAA,CAAE,IAAA,CAAK,IAAI,CAAC,CAAA,CAAE,CAAA;AAAA,IAC/E,CAAA,MAAO;AACL,MAAA,MAAA,CAAO,QAAQ,uBAAuB,CAAA;AAAA,IACxC;AAAA,EACF,SAAS,KAAA,EAAO;AACd,IAAA,QAAA,GAAW,IAAA;AACX,IAAA,MAAA,CAAO,KAAA,CAAM,CAAA,uBAAA,EAA0B,MAAA,CAAO,KAAK,CAAC,CAAA,CAAE,CAAA;AAAA,EACxD;AAEA,EAAA,IAAI,CAAC,OAAA,CAAQ,GAAA,CAAI,cAAA,EAAgB;AAC/B,IAAA,MAAA,CAAO,KAAK,wBAAwB,CAAA;AACpC,IAAA,IAAI,QAAQ,GAAA,EAAK;AACf,MAAA,MAAA,CAAO,KAAK,2DAA2D,CAAA;AAAA,IACzE;AAAA,EACF;AAEA,EAAA,IAAI,QAAA,EAAU;AACZ,IAAA,OAAA,CAAQ,QAAA,GAAW,CAAA;AAAA,EACrB;AACF,CAAC,CAAA;ACtEH,IAAM,WAAA,GAAcR,sBAAAA,CAAK,OAAA,CAAQ,kBAAkB,CAAA;AAEnD,IAAM,eAAA,GAAkB,CAAC,MAAA,KAA4B,CAAA;;AAAA,kCAAA,EAA6F,IAAA,CAAK,SAAA;AAAA,EACrJ,MAAA;AAAA,EACA,IAAA;AAAA,EACA;AACF,CAAC,CAAA;AAAA,CAAA;AAED,IAAM,cAAA,GAAiB,CAAC,GAAA,EAA8B,GAAA,KAAyB;AAC7E,EAAA,OAAO,IAAI,KAAA,CAAM,GAAG,EAAE,MAAA,CAAO,CAAC,KAAK,IAAA,KAAS;AAC1C,IAAA,IAAI,GAAA,IAAO,OAAO,GAAA,KAAQ,QAAA,IAAY,QAAQ,GAAA,EAAK;AACjD,MAAA,OAAQ,IAAgC,IAAI,CAAA;AAAA,IAC9C;AACA,IAAA,OAAO,MAAA;AAAA,EACT,GAAG,GAAc,CAAA;AACnB,CAAA;AAEA,IAAM,cAAA,GAAiB,CAAC,GAAA,EAA8B,GAAA,EAAa,KAAA,KAAyB;AAC1F,EAAA,MAAM,KAAA,GAAQ,GAAA,CAAI,KAAA,CAAM,GAAG,CAAA;AAC3B,EAAA,IAAI,OAAA,GAAU,GAAA;AACd,EAAA,KAAA,IAAS,IAAI,CAAA,EAAG,CAAA,GAAI,MAAM,MAAA,GAAS,CAAA,EAAG,KAAK,CAAA,EAAG;AAC5C,IAAA,MAAM,IAAA,GAAO,MAAM,CAAC,CAAA;AACpB,IAAA,IAAI,CAAC,QAAQ,IAAI,CAAA,IAAK,OAAO,OAAA,CAAQ,IAAI,MAAM,QAAA,EAAU;AACvD,MAAA,OAAA,CAAQ,IAAI,IAAI,EAAC;AAAA,IACnB;AACA,IAAA,OAAA,GAAU,QAAQ,IAAI,CAAA;AAAA,EACxB;AACA,EAAA,OAAA,CAAQ,KAAA,CAAM,KAAA,CAAM,MAAA,GAAS,CAAC,CAAC,CAAA,GAAI,KAAA;AACrC,CAAA;AAEO,IAAM,gBAAgB,IAAIE,iBAAAA,CAAQ,QAAQ,CAAA,CAC9C,WAAA,CAAY,yBAAyB,CAAA,CACrC,UAAA;AAAA,EACC,IAAIA,iBAAAA,CAAQ,KAAK,CAAA,CACd,QAAA,CAAS,SAAS,cAAc,CAAA,CAChC,MAAA,CAAO,OAAO,GAAA,KAAQ;AACrB,IAAA,MAAM,MAAA,GAAS,MAAM,gBAAA,EAAiB;AACtC,IAAA,IAAI,CAAC,MAAA,EAAQ;AACX,MAAA,MAAA,CAAO,MAAM,4BAA4B,CAAA;AACzC,MAAA;AAAA,IACF;AACA,IAAA,MAAM,KAAA,GAAQ,cAAA,CAAe,MAAA,EAA8C,GAAG,CAAA;AAC9E,IAAA,OAAA,CAAQ,IAAI,IAAA,CAAK,SAAA,CAAU,KAAA,EAAO,IAAA,EAAM,CAAC,CAAC,CAAA;AAAA,EAC5C,CAAC;AACL,CAAA,CACC,UAAA;AAAA,EACC,IAAIA,iBAAAA,CAAQ,KAAK,CAAA,CACd,SAAS,OAAA,EAAS,cAAc,CAAA,CAChC,QAAA,CAAS,WAAW,cAAc,CAAA,CAClC,MAAA,CAAO,OAAO,KAAK,KAAA,KAAU;AAC5B,IAAA,MAAM,MAAA,GAAS,MAAM,gBAAA,EAAiB;AACtC,IAAA,IAAI,CAAC,MAAA,EAAQ;AACX,MAAA,MAAA,CAAO,MAAM,4BAA4B,CAAA;AACzC,MAAA;AAAA,IACF;AACA,IAAA,MAAM,MAAA,GAAS,IAAA,CAAK,KAAA,CAAM,KAAK,CAAA;AAC/B,IAAA,MAAM,OAAA,GAAU,EAAE,GAAI,MAAA,EAA8C;AACpE,IAAA,cAAA,CAAe,OAAA,EAAS,KAAK,MAAM,CAAA;AACnC,IAAA,MAAMD,oBAAG,SAAA,CAAU,WAAA,EAAa,eAAA,CAAgB,OAAO,GAAG,MAAM,CAAA;AAChE,IAAA,MAAA,CAAO,OAAA,CAAQ,CAAA,QAAA,EAAW,GAAG,CAAA,CAAE,CAAA;AAAA,EACjC,CAAC;AACL,CAAA,CACC,UAAA;AAAA,EACC,IAAIC,iBAAAA,CAAQ,MAAM,CAAA,CAAE,OAAO,YAAY;AACrC,IAAA,MAAM,MAAA,GAAS,MAAM,gBAAA,EAAiB;AACtC,IAAA,IAAI,CAAC,MAAA,EAAQ;AACX,MAAA,MAAA,CAAO,MAAM,4BAA4B,CAAA;AACzC,MAAA;AAAA,IACF;AACA,IAAA,OAAA,CAAQ,IAAI,IAAA,CAAK,SAAA,CAAU,MAAA,EAAQ,IAAA,EAAM,CAAC,CAAC,CAAA;AAAA,EAC7C,CAAC;AACH,CAAA,CACC,UAAA;AAAA,EACC,IAAIA,iBAAAA,CAAQ,OAAO,CAAA,CAChB,MAAA,CAAO,uBAAuB,kBAAkB,CAAA,CAChD,MAAA,CAAO,OAAO,OAAA,KAAY;AACzB,IAAA,MAAM,MAAA,GAAS,MAAM,gBAAA,EAAiB;AACtC,IAAA,IAAI,CAAC,MAAA,EAAQ;AACX,MAAA,MAAA,CAAO,MAAM,4BAA4B,CAAA;AACzC,MAAA;AAAA,IACF;AACA,IAAA,MAAM,OAAA,GAAU,EAAE,GAAI,MAAA,EAA8C;AACpE,IAAA,IAAI,QAAQ,OAAA,EAAS;AACnB,MAAA,OAAO,OAAA,CAAQ,QAAQ,OAAO,CAAA;AAAA,IAChC,CAAA,MAAO;AACL,MAAA,KAAA,MAAW,GAAA,IAAO,MAAA,CAAO,IAAA,CAAK,OAAO,CAAA,EAAG;AACtC,QAAA,OAAO,QAAQ,GAAG,CAAA;AAAA,MACpB;AAAA,IACF;AACA,IAAA,MAAMD,oBAAG,SAAA,CAAU,WAAA,EAAa,eAAA,CAAgB,OAAO,GAAG,MAAM,CAAA;AAChE,IAAA,MAAA,CAAO,QAAQ,cAAc,CAAA;AAAA,EAC/B,CAAC;AACL,CAAA;;;AC1FFc,iBAAA,CACG,KAAK,YAAY,CAAA,CACjB,YAAY,gCAAgC,CAAA,CAC5C,QAAQ,OAAO,CAAA;AAElBA,iBAAA,CAAQ,WAAW,WAAW,CAAA;AAC9BA,iBAAA,CAAQ,WAAW,SAAS,CAAA;AAC5BA,iBAAA,CAAQ,WAAW,cAAc,CAAA;AACjCA,iBAAA,CAAQ,WAAW,eAAe,CAAA;AAClCA,iBAAA,CAAQ,WAAW,aAAa,CAAA;AAEhCA,iBAAA,CAAQ,KAAA,EAAM","file":"index.cjs","sourcesContent":["import chalk from 'chalk';\n\nexport const logger = {\n info: (message: string) => {\n console.log(chalk.cyan(`[omi-neuron] ${message}`));\n },\n success: (message: string) => {\n console.log(chalk.green(`[omi-neuron] ${message}`));\n },\n warn: (message: string) => {\n console.warn(chalk.yellow(`[omi-neuron] ${message}`));\n },\n error: (message: string) => {\n console.error(chalk.red(`[omi-neuron] ${message}`));\n },\n};\n","import fs from 'node:fs/promises';\nimport path from 'node:path';\n\nexport const renderTemplate = (template: string, values: Record<string, string>): string => {\n let output = template;\n for (const [key, value] of Object.entries(values)) {\n output = output.replace(new RegExp(`{{${key}}}`, 'g'), value);\n }\n return output;\n};\n\nexport async function writeTemplateFile(\n filePath: string,\n template: string,\n values: Record<string, string>,\n force = false\n): Promise<void> {\n const resolved = path.resolve(filePath);\n await fs.mkdir(path.dirname(resolved), { recursive: true });\n try {\n await fs.access(resolved);\n if (!force) {\n throw new Error(`File already exists: ${resolved}`);\n }\n } catch {\n // File does not exist; continue.\n }\n\n const content = renderTemplate(template, values);\n await fs.writeFile(resolved, content, 'utf8');\n}\n","import path from 'node:path';\nimport fs from 'node:fs/promises';\nimport { Command } from 'commander';\nimport { logger } from '../utils/logger';\nimport { writeTemplateFile } from '../utils/templates';\n\nconst CONFIG_TEMPLATE = `import { defineNeuronConfig, DEFAULT_ANALYSIS_SETTINGS, DEFAULT_VISUALIZATION_SETTINGS } from 'omi-neuron-web';\n\nexport default defineNeuronConfig({\n instance: {\n name: '{{INSTANCE_NAME}}',\n version: '0.1.0',\n repoName: '{{REPO_NAME}}',\n },\n visualization: DEFAULT_VISUALIZATION_SETTINGS,\n analysis: DEFAULT_ANALYSIS_SETTINGS,\n nodeTypes: [],\n domains: [],\n relationshipTypes: [],\n openai: {\n apiKey: process.env.OPENAI_API_KEY ?? '',\n },\n database: {\n mode: 'docker',\n port: {{DB_PORT}},\n user: 'neuron',\n password: 'neuron_dev',\n database: 'neuron_web',\n },\n api: {\n basePath: '/api/neuron',\n enableCors: false,\n },\n logging: {\n level: 'info',\n prettyPrint: true,\n },\n});\n`;\n\nconst ENV_TEMPLATE = `# omi-neuron-web environment variables\nOPENAI_API_KEY=\nDATABASE_URL=\n`;\n\nconst DOCKER_TEMPLATE = `version: '3.8'\n\nservices:\n pg-{{REPO_NAME}}:\n image: pgvector/pgvector:pg16\n container_name: pg-{{REPO_NAME}}\n restart: unless-stopped\n environment:\n POSTGRES_USER: neuron\n POSTGRES_PASSWORD: neuron_dev\n POSTGRES_DB: neuron_web\n ports:\n - \"{{DB_PORT}}:5432\"\n volumes:\n - {{REPO_NAME}}_neuron_data:/var/lib/postgresql/data\n healthcheck:\n test: [\"CMD-SHELL\", \"pg_isready -U neuron -d neuron_web\"]\n interval: 10s\n timeout: 5s\n retries: 5\n\nvolumes:\n {{REPO_NAME}}_neuron_data:\n name: {{REPO_NAME}}_neuron_data\n`;\n\nconst API_ROUTE_TEMPLATE = `import { createNeuronRoutes } from 'omi-neuron-web/api';\nimport config from '../../../../neuron.config';\n\nconst routes = createNeuronRoutes(config);\n\nexport const GET = routes.health.GET;\nexport const POST = routes.health.GET;\n`;\n\nexport const initCommand = new Command('init')\n .description('Initialize omi-neuron-web in your project')\n .option('--name <name>', 'Instance name (default: directory name)')\n .option('--port <port>', 'PostgreSQL port (default: 5433)', '5433')\n .option('--skip-docker', \"Don't generate Docker files\")\n .option('--skip-api', \"Don't generate API route files\")\n .option('--skip-config', \"Don't generate neuron.config.ts\")\n .option('--app-dir <path>', 'Path to Next.js app directory', './app')\n .option('--force', 'Overwrite existing files')\n .action(async (options) => {\n const repoName = path.basename(process.cwd());\n const instanceName = options.name ?? repoName;\n const port = Number(options.port ?? 5433);\n\n if (!options.skipConfig) {\n await writeTemplateFile(\n path.join(process.cwd(), 'neuron.config.ts'),\n CONFIG_TEMPLATE,\n {\n INSTANCE_NAME: instanceName,\n REPO_NAME: repoName,\n DB_PORT: String(port),\n },\n options.force\n );\n logger.success('Created neuron.config.ts');\n }\n\n if (!options.skipDocker) {\n await writeTemplateFile(\n path.join(process.cwd(), 'docker-compose.neuron.yml'),\n DOCKER_TEMPLATE,\n {\n REPO_NAME: repoName,\n DB_PORT: String(port),\n },\n options.force\n );\n logger.success('Created docker-compose.neuron.yml');\n }\n\n await writeTemplateFile(\n path.join(process.cwd(), '.env.neuron.local'),\n ENV_TEMPLATE,\n {},\n options.force\n );\n logger.success('Created .env.neuron.local');\n\n if (!options.skipApi) {\n const apiPath = path.join(process.cwd(), options.appDir, 'api', 'neuron', '[...path]');\n await fs.mkdir(apiPath, { recursive: true });\n await fs.writeFile(path.join(apiPath, 'route.ts'), API_ROUTE_TEMPLATE, 'utf8');\n logger.success('Created Next.js API route stub');\n }\n\n logger.info('Initialization complete.');\n });\n","import path from 'node:path';\nimport { pathToFileURL } from 'node:url';\nimport fs from 'node:fs/promises';\nimport type { NeuronConfig } from '../../core/types/settings';\n\nexport interface CliConfig {\n repoName: string;\n port: number;\n containerName?: string;\n databaseUrl?: string;\n databaseUser?: string;\n databasePassword?: string;\n databaseName?: string;\n}\n\nexport async function loadNeuronConfig(): Promise<NeuronConfig | null> {\n const configPath = path.resolve('neuron.config.ts');\n try {\n await fs.access(configPath);\n } catch {\n return null;\n }\n\n try {\n const module = await import(pathToFileURL(configPath).toString());\n return module.default ?? module;\n } catch (error) {\n throw new Error(\n `Unable to load neuron.config.ts. Consider transpiling or using a JS config. ${String(error)}`\n );\n }\n}\n\nexport async function resolveCliConfig(overrides?: Partial<CliConfig>): Promise<CliConfig> {\n const repoName = overrides?.repoName ?? path.basename(process.cwd());\n let config: NeuronConfig | null = null;\n\n try {\n config = await loadNeuronConfig();\n } catch {\n config = null;\n }\n\n return {\n repoName,\n port:\n overrides?.port ??\n config?.database?.port ??\n (process.env.DB_PORT ? Number(process.env.DB_PORT) : 5433),\n containerName: overrides?.containerName ?? config?.database?.containerName,\n databaseUrl: overrides?.databaseUrl ?? config?.database?.url ?? process.env.DATABASE_URL,\n databaseUser: overrides?.databaseUser ?? config?.database?.user ?? process.env.DB_USER,\n databasePassword:\n overrides?.databasePassword ?? config?.database?.password ?? process.env.DB_PASSWORD,\n databaseName: overrides?.databaseName ?? config?.database?.database ?? process.env.DB_NAME,\n };\n}\n","import { createInterface } from 'node:readline/promises';\nimport { stdin as input, stdout as output } from 'node:process';\n\nexport async function confirmPrompt(message: string): Promise<boolean> {\n const rl = createInterface({ input, output });\n const answer = await rl.question(`${message} (y/N): `);\n rl.close();\n return answer.trim().toLowerCase() === 'y';\n}\n","type SpinnerState = 'running' | 'stopped';\n\nexport class Spinner {\n private state: SpinnerState = 'stopped';\n private intervalId: NodeJS.Timeout | null = null;\n private frames = ['-', '\\\\', '|', '/'];\n private frameIndex = 0;\n\n constructor(private message: string) {}\n\n start(): void {\n if (this.state === 'running') return;\n this.state = 'running';\n this.intervalId = setInterval(() => {\n const frame = this.frames[this.frameIndex % this.frames.length];\n this.frameIndex += 1;\n process.stdout.write(`\\r${frame} ${this.message}`);\n }, 120);\n }\n\n stop(success = true, finalMessage?: string): void {\n if (this.intervalId) {\n clearInterval(this.intervalId);\n }\n this.state = 'stopped';\n const symbol = success ? '✓' : '✗';\n process.stdout.write(`\\r${symbol} ${finalMessage ?? this.message}\\n`);\n }\n}\n","import { Command } from 'commander';\nimport { DockerManager } from '../../storage/docker-manager';\nimport { Database } from '../../storage/database';\nimport { MigrationRunner } from '../../storage/migrations/runner';\nimport { resolveCliConfig } from '../utils/config';\nimport { logger } from '../utils/logger';\nimport { confirmPrompt } from '../utils/prompts';\nimport { Spinner } from '../utils/spinner';\n\nconst buildConnectionString = (config: {\n databaseUrl?: string;\n databaseUser?: string;\n databasePassword?: string;\n databaseName?: string;\n port: number;\n}) => {\n if (config.databaseUrl) return config.databaseUrl;\n const user = config.databaseUser ?? 'neuron';\n const password = config.databasePassword ?? 'neuron_dev';\n const database = config.databaseName ?? 'neuron_web';\n return `postgresql://${user}:${password}@localhost:${config.port}/${database}`;\n};\n\nexport const dbCommand = new Command('db')\n .description('Database management commands')\n .addCommand(\n new Command('up')\n .description('Start PostgreSQL container')\n .option('--port <port>', 'Override port')\n .option('--force-recreate', 'Force recreate container')\n .option('--wait', 'Wait for readiness', true)\n .action(async (options) => {\n const config = await resolveCliConfig({\n port: options.port ? Number(options.port) : undefined,\n });\n const docker = new DockerManager({\n repoName: config.repoName,\n port: config.port,\n containerName: config.containerName,\n user: config.databaseUser,\n password: config.databasePassword,\n database: config.databaseName,\n });\n const spinner = new Spinner('Starting PostgreSQL container');\n spinner.start();\n await docker.start({\n forceRecreate: options.forceRecreate,\n waitForReady: options.wait,\n });\n spinner.stop(true, 'Database ready');\n const connectionString = await docker.getConnectionString();\n logger.info(`Connection string: ${connectionString}`);\n })\n )\n .addCommand(\n new Command('down')\n .description('Stop PostgreSQL container')\n .option('--remove-volumes', 'Remove volumes (destructive)')\n .action(async (options) => {\n const config = await resolveCliConfig();\n const docker = new DockerManager({\n repoName: config.repoName,\n port: config.port,\n containerName: config.containerName,\n });\n await docker.stop({ removeVolumes: options.removeVolumes });\n logger.success('Database container stopped');\n })\n )\n .addCommand(\n new Command('migrate')\n .description('Run migrations')\n .option('--status', 'Show status only')\n .option('--rollback <count>', 'Rollback N migrations')\n .option('--to <version>', 'Migrate to specific version')\n .option('--dry-run', 'Show SQL without executing')\n .action(async (options) => {\n const config = await resolveCliConfig();\n const db = new Database({\n connectionString: buildConnectionString(config),\n });\n const runner = new MigrationRunner(db);\n\n if (options.status) {\n const status = await runner.getStatus();\n status.forEach((item) => {\n logger.info(`${item.version} ${item.name} - ${item.status}`);\n });\n return;\n }\n\n if (options.dryRun) {\n const sql = await runner.dryRun(options.rollback ? 'down' : 'up');\n logger.info(sql.join('\\n\\n'));\n return;\n }\n\n if (options.rollback) {\n await runner.down({ count: Number(options.rollback) });\n logger.success('Rollback complete');\n return;\n }\n\n await runner.up({ to: options.to });\n logger.success('Migrations complete');\n })\n )\n .addCommand(\n new Command('status')\n .description('Show database status')\n .option('--json', 'Output JSON')\n .option('--verbose', 'Include stats')\n .action(async (options) => {\n const config = await resolveCliConfig();\n const docker = new DockerManager({\n repoName: config.repoName,\n port: config.port,\n containerName: config.containerName,\n });\n const health = await docker.healthCheck();\n\n if (options.json) {\n console.log(JSON.stringify(health, null, 2));\n return;\n }\n\n logger.info(`Container running: ${health.containerRunning}`);\n logger.info(`Database ready: ${health.databaseReady}`);\n if (options.verbose) {\n const stats = await docker.getStats();\n logger.info(`Stats: ${JSON.stringify(stats)}`);\n }\n })\n )\n .addCommand(\n new Command('reset')\n .description('Reset database schema')\n .option('--confirm', 'Skip confirmation prompt')\n .action(async (options) => {\n if (!options.confirm) {\n const confirmed = await confirmPrompt('This will drop and reapply all migrations. Continue?');\n if (!confirmed) return;\n }\n const config = await resolveCliConfig();\n const db = new Database({\n connectionString: buildConnectionString(config),\n });\n const runner = new MigrationRunner(db);\n await runner.reset();\n logger.success('Database reset complete');\n })\n )\n .addCommand(\n new Command('seed')\n .description('Seed database with sample data')\n .option('--file <path>', 'Custom seed file')\n .option('--clear', 'Clear before seeding')\n .option('--count <n>', 'Number of example nodes', '10')\n .action(async (options) => {\n const config = await resolveCliConfig();\n const db = new Database({\n connectionString: buildConnectionString(config),\n });\n if (options.clear) {\n await db.execute('DELETE FROM edges');\n await db.execute('DELETE FROM nodes');\n }\n const count = Number(options.count ?? 10);\n for (let i = 0; i < count; i += 1) {\n await db.execute(\n 'INSERT INTO nodes (slug, label, node_type, domain, metadata) VALUES ($1, $2, $3, $4, $5)',\n [`seed-${i + 1}`, `Seed Node ${i + 1}`, 'concept', 'general', {}]\n );\n }\n logger.success('Seed data inserted');\n })\n );\n","import { Command } from 'commander';\nimport { Database } from '../../storage/database';\nimport { resolveCliConfig } from '../utils/config';\nimport { logger } from '../utils/logger';\nimport { EventBus } from '../../core/events/event-bus';\nimport { EmbeddingsService } from '../../core/analysis/embeddings-service';\nimport { ClusteringEngine } from '../../core/analysis/clustering-engine';\nimport { RelationshipEngine } from '../../core/analysis/relationship-engine';\nimport { AnalysisPipeline } from '../../core/analysis/pipeline';\n\nconst buildConnectionString = (config: {\n databaseUrl?: string;\n databaseUser?: string;\n databasePassword?: string;\n databaseName?: string;\n port: number;\n}) => {\n if (config.databaseUrl) return config.databaseUrl;\n const user = config.databaseUser ?? 'neuron';\n const password = config.databasePassword ?? 'neuron_dev';\n const database = config.databaseName ?? 'neuron_web';\n return `postgresql://${user}:${password}@localhost:${config.port}/${database}`;\n};\n\nasync function buildPipeline(): Promise<AnalysisPipeline> {\n const config = await resolveCliConfig();\n const db = new Database({ connectionString: buildConnectionString(config) });\n const events = new EventBus();\n\n const embeddings = new EmbeddingsService(\n {\n openaiApiKey: process.env.OPENAI_API_KEY ?? '',\n model: 'text-embedding-3-small',\n batchSize: 20,\n rateLimit: 60,\n cacheTTL: 86400,\n maxRetries: 3,\n },\n db\n );\n\n const clustering = new ClusteringEngine(db, embeddings);\n const relationships = new RelationshipEngine(db, {\n model: 'gpt-4o-mini',\n minConfidence: 0.7,\n maxPerNode: 10,\n similarityThreshold: 0.75,\n includeExisting: false,\n batchSize: 10,\n rateLimit: 30,\n });\n\n return new AnalysisPipeline(db, embeddings, clustering, relationships, events);\n}\n\nexport const analyzeCommand = new Command('analyze')\n .description('Analysis commands')\n .addCommand(\n new Command('embeddings')\n .description('Generate embeddings')\n .option('--node-ids <ids>', 'Comma-separated node IDs')\n .option('--force', 'Regenerate existing')\n .action(async (options) => {\n const pipeline = await buildPipeline();\n const nodeIds = options.nodeIds ? options.nodeIds.split(',') : undefined;\n await pipeline.runEmbeddings({ nodeIds, forceRecompute: options.force });\n logger.success('Embeddings complete');\n })\n )\n .addCommand(\n new Command('cluster')\n .description('Run clustering')\n .option('--count <n>', 'Number of clusters')\n .option('--algorithm <alg>', 'kmeans, dbscan, hierarchical', 'kmeans')\n .action(async (options) => {\n const pipeline = await buildPipeline();\n await pipeline.runClustering({\n clusterCount: options.count ? Number(options.count) : undefined,\n clusteringAlgorithm: options.algorithm,\n });\n logger.success('Clustering complete');\n })\n )\n .addCommand(\n new Command('relationships')\n .description('Infer relationships')\n .option('--threshold <n>', 'Min confidence (0-1)', '0.7')\n .option('--dry-run', 'Show without saving')\n .action(async (options) => {\n const pipeline = await buildPipeline();\n await pipeline.runRelationships({\n relationshipThreshold: Number(options.threshold),\n });\n logger.success('Relationship inference complete');\n })\n )\n .addCommand(\n new Command('full')\n .description('Run full analysis pipeline')\n .option('--force', 'Force recompute all')\n .action(async (options) => {\n const pipeline = await buildPipeline();\n await pipeline.runFull({ forceRecompute: options.force });\n logger.success('Analysis pipeline complete');\n })\n );\n","import { Command } from 'commander';\nimport fs from 'node:fs/promises';\nimport path from 'node:path';\nimport { DockerManager } from '../../storage/docker-manager';\nimport { Database } from '../../storage/database';\nimport { MigrationRunner } from '../../storage/migrations/runner';\nimport { resolveCliConfig } from '../utils/config';\nimport { logger } from '../utils/logger';\n\nconst buildConnectionString = (config: {\n databaseUrl?: string;\n databaseUser?: string;\n databasePassword?: string;\n databaseName?: string;\n port: number;\n}) => {\n if (config.databaseUrl) return config.databaseUrl;\n const user = config.databaseUser ?? 'neuron';\n const password = config.databasePassword ?? 'neuron_dev';\n const database = config.databaseName ?? 'neuron_web';\n return `postgresql://${user}:${password}@localhost:${config.port}/${database}`;\n};\n\nexport const validateCommand = new Command('validate')\n .description('Validate configuration and setup')\n .option('--fix', 'Attempt to fix issues')\n .option('--verbose', 'Show detailed validation')\n .action(async (options) => {\n const config = await resolveCliConfig();\n let hasError = false;\n\n const configPath = path.resolve('neuron.config.ts');\n try {\n await fs.access(configPath);\n logger.success('neuron.config.ts exists');\n } catch {\n hasError = true;\n logger.error('neuron.config.ts not found');\n }\n\n try {\n const docker = new DockerManager({ repoName: config.repoName, port: config.port });\n const health = await docker.healthCheck();\n logger.info(`Docker container running: ${health.containerRunning}`);\n logger.info(`Database ready: ${health.databaseReady}`);\n } catch (error) {\n hasError = true;\n logger.error(`Docker check failed: ${String(error)}`);\n }\n\n try {\n const db = new Database({ connectionString: buildConnectionString(config) });\n await db.connect();\n logger.success('Database connection ok');\n const runner = new MigrationRunner(db);\n const pending = await runner.getPending();\n if (pending.length > 0) {\n logger.warn(`Pending migrations: ${pending.map((m) => m.version).join(', ')}`);\n } else {\n logger.success('Migrations up to date');\n }\n } catch (error) {\n hasError = true;\n logger.error(`Database check failed: ${String(error)}`);\n }\n\n if (!process.env.OPENAI_API_KEY) {\n logger.warn('OPENAI_API_KEY not set');\n if (options.fix) {\n logger.info('Set OPENAI_API_KEY in your environment to enable analysis');\n }\n }\n\n if (hasError) {\n process.exitCode = 1;\n }\n });\n","import { Command } from 'commander';\nimport fs from 'node:fs/promises';\nimport path from 'node:path';\nimport { loadNeuronConfig } from '../utils/config';\nimport { logger } from '../utils/logger';\n\nconst CONFIG_FILE = path.resolve('neuron.config.ts');\n\nconst serializeConfig = (config: unknown): string => `import { defineNeuronConfig } from 'omi-neuron-web';\\n\\nexport default defineNeuronConfig(${JSON.stringify(\n config,\n null,\n 2\n)});\\n`;\n\nconst getNestedValue = (obj: Record<string, unknown>, key: string): unknown => {\n return key.split('.').reduce((acc, part) => {\n if (acc && typeof acc === 'object' && part in acc) {\n return (acc as Record<string, unknown>)[part];\n }\n return undefined;\n }, obj as unknown);\n};\n\nconst setNestedValue = (obj: Record<string, unknown>, key: string, value: unknown): void => {\n const parts = key.split('.');\n let current = obj;\n for (let i = 0; i < parts.length - 1; i += 1) {\n const part = parts[i];\n if (!current[part] || typeof current[part] !== 'object') {\n current[part] = {};\n }\n current = current[part] as Record<string, unknown>;\n }\n current[parts[parts.length - 1]] = value;\n};\n\nexport const configCommand = new Command('config')\n .description('Manage neuron.config.ts')\n .addCommand(\n new Command('get')\n .argument('<key>', 'Dot path key')\n .action(async (key) => {\n const config = await loadNeuronConfig();\n if (!config) {\n logger.error('neuron.config.ts not found');\n return;\n }\n const value = getNestedValue(config as unknown as Record<string, unknown>, key);\n console.log(JSON.stringify(value, null, 2));\n })\n )\n .addCommand(\n new Command('set')\n .argument('<key>', 'Dot path key')\n .argument('<value>', 'Value (JSON)')\n .action(async (key, value) => {\n const config = await loadNeuronConfig();\n if (!config) {\n logger.error('neuron.config.ts not found');\n return;\n }\n const parsed = JSON.parse(value);\n const updated = { ...(config as unknown as Record<string, unknown>) };\n setNestedValue(updated, key, parsed);\n await fs.writeFile(CONFIG_FILE, serializeConfig(updated), 'utf8');\n logger.success(`Updated ${key}`);\n })\n )\n .addCommand(\n new Command('list').action(async () => {\n const config = await loadNeuronConfig();\n if (!config) {\n logger.error('neuron.config.ts not found');\n return;\n }\n console.log(JSON.stringify(config, null, 2));\n })\n )\n .addCommand(\n new Command('reset')\n .option('--section <section>', 'Section to reset')\n .action(async (options) => {\n const config = await loadNeuronConfig();\n if (!config) {\n logger.error('neuron.config.ts not found');\n return;\n }\n const updated = { ...(config as unknown as Record<string, unknown>) };\n if (options.section) {\n delete updated[options.section];\n } else {\n for (const key of Object.keys(updated)) {\n delete updated[key];\n }\n }\n await fs.writeFile(CONFIG_FILE, serializeConfig(updated), 'utf8');\n logger.success('Config reset');\n })\n );\n","#!/usr/bin/env node\nimport { program } from 'commander';\nimport { initCommand } from './commands/init';\nimport { dbCommand } from './commands/db';\nimport { analyzeCommand } from './commands/analyze';\nimport { validateCommand } from './commands/validate';\nimport { configCommand } from './commands/config';\n\nprogram\n .name('omi-neuron')\n .description('CLI for omi-neuron-web library')\n .version('0.1.0');\n\nprogram.addCommand(initCommand);\nprogram.addCommand(dbCommand);\nprogram.addCommand(analyzeCommand);\nprogram.addCommand(validateCommand);\nprogram.addCommand(configCommand);\n\nprogram.parse();\n"]}
|
|
1
|
+
{"version":3,"sources":["../../src/cli/utils/logger.ts","../../src/cli/utils/templates.ts","../../src/cli/commands/init.ts","../../src/cli/utils/config.ts","../../src/cli/utils/prompts.ts","../../src/cli/utils/spinner.ts","../../src/cli/commands/db.ts","../../src/cli/commands/analyze.ts","../../src/cli/commands/validate.ts","../../src/cli/commands/config.ts","../../src/cli/index.ts"],"names":["chalk","output","path","fs","Command","pathToFileURL","createInterface","input","DockerManager","Database","MigrationRunner","buildConnectionString","EventBus","EmbeddingsService","ClusteringEngine","RelationshipEngine","AnalysisPipeline","program"],"mappings":"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","file":"index.cjs","sourcesContent":["import chalk from 'chalk';\n\nexport const logger = {\n info: (message: string) => {\n console.log(chalk.cyan(`[omi-neuron] ${message}`));\n },\n success: (message: string) => {\n console.log(chalk.green(`[omi-neuron] ${message}`));\n },\n warn: (message: string) => {\n console.warn(chalk.yellow(`[omi-neuron] ${message}`));\n },\n error: (message: string) => {\n console.error(chalk.red(`[omi-neuron] ${message}`));\n },\n};\n","import fs from 'node:fs/promises';\nimport path from 'node:path';\n\nexport const renderTemplate = (template: string, values: Record<string, string>): string => {\n let output = template;\n for (const [key, value] of Object.entries(values)) {\n output = output.replace(new RegExp(`{{${key}}}`, 'g'), value);\n }\n return output;\n};\n\nexport async function writeTemplateFile(\n filePath: string,\n template: string,\n values: Record<string, string>,\n force = false\n): Promise<void> {\n const resolved = path.resolve(filePath);\n await fs.mkdir(path.dirname(resolved), { recursive: true });\n try {\n await fs.access(resolved);\n if (!force) {\n throw new Error(`File already exists: ${resolved}`);\n }\n } catch {\n // File does not exist; continue.\n }\n\n const content = renderTemplate(template, values);\n await fs.writeFile(resolved, content, 'utf8');\n}\n","import path from 'node:path';\nimport fs from 'node:fs/promises';\nimport { Command } from 'commander';\nimport { logger } from '../utils/logger';\nimport { writeTemplateFile } from '../utils/templates';\n\nconst CONFIG_TEMPLATE = `import { defineNeuronConfig, DEFAULT_ANALYSIS_SETTINGS, DEFAULT_VISUALIZATION_SETTINGS } from '@omiron33/omi-neuron-web';\n\nexport default defineNeuronConfig({\n instance: {\n name: '{{INSTANCE_NAME}}',\n version: '0.1.1',\n repoName: '{{REPO_NAME}}',\n },\n visualization: DEFAULT_VISUALIZATION_SETTINGS,\n analysis: DEFAULT_ANALYSIS_SETTINGS,\n nodeTypes: [],\n domains: [],\n relationshipTypes: [],\n openai: {\n apiKey: process.env.OPENAI_API_KEY ?? '',\n },\n database: {\n mode: 'docker',\n port: {{DB_PORT}},\n user: 'neuron',\n password: 'neuron_dev',\n database: 'neuron_web',\n },\n api: {\n basePath: '/api/neuron',\n enableCors: false,\n },\n logging: {\n level: 'info',\n prettyPrint: true,\n },\n});\n`;\n\nconst ENV_TEMPLATE = `# omi-neuron-web environment variables\nOPENAI_API_KEY=\nDATABASE_URL=\n`;\n\nconst DOCKER_TEMPLATE = `version: '3.8'\n\nservices:\n pg-{{REPO_NAME}}:\n image: pgvector/pgvector:pg16\n container_name: pg-{{REPO_NAME}}\n restart: unless-stopped\n environment:\n POSTGRES_USER: neuron\n POSTGRES_PASSWORD: neuron_dev\n POSTGRES_DB: neuron_web\n ports:\n - \"{{DB_PORT}}:5432\"\n volumes:\n - {{REPO_NAME}}_neuron_data:/var/lib/postgresql/data\n healthcheck:\n test: [\"CMD-SHELL\", \"pg_isready -U neuron -d neuron_web\"]\n interval: 10s\n timeout: 5s\n retries: 5\n\nvolumes:\n {{REPO_NAME}}_neuron_data:\n name: {{REPO_NAME}}_neuron_data\n`;\n\nconst API_ROUTE_TEMPLATE = `import { createNeuronRoutes } from '@omiron33/omi-neuron-web/api';\nimport config from '../../../../neuron.config';\n\nconst routes = createNeuronRoutes(config);\n\nexport const GET = routes.health.GET;\nexport const POST = routes.health.GET;\n`;\n\nexport const initCommand = new Command('init')\n .description('Initialize omi-neuron-web in your project')\n .option('--name <name>', 'Instance name (default: directory name)')\n .option('--port <port>', 'PostgreSQL port (default: 5433)', '5433')\n .option('--skip-docker', \"Don't generate Docker files\")\n .option('--skip-api', \"Don't generate API route files\")\n .option('--skip-config', \"Don't generate neuron.config.ts\")\n .option('--app-dir <path>', 'Path to Next.js app directory', './app')\n .option('--force', 'Overwrite existing files')\n .action(async (options) => {\n const repoName = path.basename(process.cwd());\n const instanceName = options.name ?? repoName;\n const port = Number(options.port ?? 5433);\n\n if (!options.skipConfig) {\n await writeTemplateFile(\n path.join(process.cwd(), 'neuron.config.ts'),\n CONFIG_TEMPLATE,\n {\n INSTANCE_NAME: instanceName,\n REPO_NAME: repoName,\n DB_PORT: String(port),\n },\n options.force\n );\n logger.success('Created neuron.config.ts');\n }\n\n if (!options.skipDocker) {\n await writeTemplateFile(\n path.join(process.cwd(), 'docker-compose.neuron.yml'),\n DOCKER_TEMPLATE,\n {\n REPO_NAME: repoName,\n DB_PORT: String(port),\n },\n options.force\n );\n logger.success('Created docker-compose.neuron.yml');\n }\n\n await writeTemplateFile(\n path.join(process.cwd(), '.env.neuron.local'),\n ENV_TEMPLATE,\n {},\n options.force\n );\n logger.success('Created .env.neuron.local');\n\n if (!options.skipApi) {\n const apiPath = path.join(process.cwd(), options.appDir, 'api', 'neuron', '[...path]');\n await fs.mkdir(apiPath, { recursive: true });\n await fs.writeFile(path.join(apiPath, 'route.ts'), API_ROUTE_TEMPLATE, 'utf8');\n logger.success('Created Next.js API route stub');\n }\n\n logger.info('Initialization complete.');\n });\n","import path from 'node:path';\nimport { pathToFileURL } from 'node:url';\nimport fs from 'node:fs/promises';\nimport type { NeuronConfig } from '../../core/types/settings';\n\nexport interface CliConfig {\n repoName: string;\n port: number;\n containerName?: string;\n databaseUrl?: string;\n databaseUser?: string;\n databasePassword?: string;\n databaseName?: string;\n}\n\nexport async function loadNeuronConfig(): Promise<NeuronConfig | null> {\n const configPath = path.resolve('neuron.config.ts');\n try {\n await fs.access(configPath);\n } catch {\n return null;\n }\n\n try {\n const module = await import(pathToFileURL(configPath).toString());\n return module.default ?? module;\n } catch (error) {\n throw new Error(\n `Unable to load neuron.config.ts. Consider transpiling or using a JS config. ${String(error)}`\n );\n }\n}\n\nexport async function resolveCliConfig(overrides?: Partial<CliConfig>): Promise<CliConfig> {\n const repoName = overrides?.repoName ?? path.basename(process.cwd());\n let config: NeuronConfig | null = null;\n\n try {\n config = await loadNeuronConfig();\n } catch {\n config = null;\n }\n\n return {\n repoName,\n port:\n overrides?.port ??\n config?.database?.port ??\n (process.env.DB_PORT ? Number(process.env.DB_PORT) : 5433),\n containerName: overrides?.containerName ?? config?.database?.containerName,\n databaseUrl: overrides?.databaseUrl ?? config?.database?.url ?? process.env.DATABASE_URL,\n databaseUser: overrides?.databaseUser ?? config?.database?.user ?? process.env.DB_USER,\n databasePassword:\n overrides?.databasePassword ?? config?.database?.password ?? process.env.DB_PASSWORD,\n databaseName: overrides?.databaseName ?? config?.database?.database ?? process.env.DB_NAME,\n };\n}\n","import { createInterface } from 'node:readline/promises';\nimport { stdin as input, stdout as output } from 'node:process';\n\nexport async function confirmPrompt(message: string): Promise<boolean> {\n const rl = createInterface({ input, output });\n const answer = await rl.question(`${message} (y/N): `);\n rl.close();\n return answer.trim().toLowerCase() === 'y';\n}\n","type SpinnerState = 'running' | 'stopped';\n\nexport class Spinner {\n private state: SpinnerState = 'stopped';\n private intervalId: NodeJS.Timeout | null = null;\n private frames = ['-', '\\\\', '|', '/'];\n private frameIndex = 0;\n\n constructor(private message: string) {}\n\n start(): void {\n if (this.state === 'running') return;\n this.state = 'running';\n this.intervalId = setInterval(() => {\n const frame = this.frames[this.frameIndex % this.frames.length];\n this.frameIndex += 1;\n process.stdout.write(`\\r${frame} ${this.message}`);\n }, 120);\n }\n\n stop(success = true, finalMessage?: string): void {\n if (this.intervalId) {\n clearInterval(this.intervalId);\n }\n this.state = 'stopped';\n const symbol = success ? '✓' : '✗';\n process.stdout.write(`\\r${symbol} ${finalMessage ?? this.message}\\n`);\n }\n}\n","import { Command } from 'commander';\nimport { DockerManager } from '../../storage/docker-manager';\nimport { Database } from '../../storage/database';\nimport { MigrationRunner } from '../../storage/migrations/runner';\nimport { resolveCliConfig } from '../utils/config';\nimport { logger } from '../utils/logger';\nimport { confirmPrompt } from '../utils/prompts';\nimport { Spinner } from '../utils/spinner';\n\nconst buildConnectionString = (config: {\n databaseUrl?: string;\n databaseUser?: string;\n databasePassword?: string;\n databaseName?: string;\n port: number;\n}) => {\n if (config.databaseUrl) return config.databaseUrl;\n const user = config.databaseUser ?? 'neuron';\n const password = config.databasePassword ?? 'neuron_dev';\n const database = config.databaseName ?? 'neuron_web';\n return `postgresql://${user}:${password}@localhost:${config.port}/${database}`;\n};\n\nexport const dbCommand = new Command('db')\n .description('Database management commands')\n .addCommand(\n new Command('up')\n .description('Start PostgreSQL container')\n .option('--port <port>', 'Override port')\n .option('--force-recreate', 'Force recreate container')\n .option('--wait', 'Wait for readiness', true)\n .action(async (options) => {\n const config = await resolveCliConfig({\n port: options.port ? Number(options.port) : undefined,\n });\n const docker = new DockerManager({\n repoName: config.repoName,\n port: config.port,\n containerName: config.containerName,\n user: config.databaseUser,\n password: config.databasePassword,\n database: config.databaseName,\n });\n const spinner = new Spinner('Starting PostgreSQL container');\n spinner.start();\n await docker.start({\n forceRecreate: options.forceRecreate,\n waitForReady: options.wait,\n });\n spinner.stop(true, 'Database ready');\n const connectionString = await docker.getConnectionString();\n logger.info(`Connection string: ${connectionString}`);\n })\n )\n .addCommand(\n new Command('down')\n .description('Stop PostgreSQL container')\n .option('--remove-volumes', 'Remove volumes (destructive)')\n .action(async (options) => {\n const config = await resolveCliConfig();\n const docker = new DockerManager({\n repoName: config.repoName,\n port: config.port,\n containerName: config.containerName,\n });\n await docker.stop({ removeVolumes: options.removeVolumes });\n logger.success('Database container stopped');\n })\n )\n .addCommand(\n new Command('migrate')\n .description('Run migrations')\n .option('--status', 'Show status only')\n .option('--rollback <count>', 'Rollback N migrations')\n .option('--to <version>', 'Migrate to specific version')\n .option('--dry-run', 'Show SQL without executing')\n .action(async (options) => {\n const config = await resolveCliConfig();\n const db = new Database({\n connectionString: buildConnectionString(config),\n });\n const runner = new MigrationRunner(db);\n\n if (options.status) {\n const status = await runner.getStatus();\n status.forEach((item) => {\n logger.info(`${item.version} ${item.name} - ${item.status}`);\n });\n return;\n }\n\n if (options.dryRun) {\n const sql = await runner.dryRun(options.rollback ? 'down' : 'up');\n logger.info(sql.join('\\n\\n'));\n return;\n }\n\n if (options.rollback) {\n await runner.down({ count: Number(options.rollback) });\n logger.success('Rollback complete');\n return;\n }\n\n await runner.up({ to: options.to });\n logger.success('Migrations complete');\n })\n )\n .addCommand(\n new Command('status')\n .description('Show database status')\n .option('--json', 'Output JSON')\n .option('--verbose', 'Include stats')\n .action(async (options) => {\n const config = await resolveCliConfig();\n const docker = new DockerManager({\n repoName: config.repoName,\n port: config.port,\n containerName: config.containerName,\n });\n const health = await docker.healthCheck();\n\n if (options.json) {\n console.log(JSON.stringify(health, null, 2));\n return;\n }\n\n logger.info(`Container running: ${health.containerRunning}`);\n logger.info(`Database ready: ${health.databaseReady}`);\n if (options.verbose) {\n const stats = await docker.getStats();\n logger.info(`Stats: ${JSON.stringify(stats)}`);\n }\n })\n )\n .addCommand(\n new Command('reset')\n .description('Reset database schema')\n .option('--confirm', 'Skip confirmation prompt')\n .action(async (options) => {\n if (!options.confirm) {\n const confirmed = await confirmPrompt('This will drop and reapply all migrations. Continue?');\n if (!confirmed) return;\n }\n const config = await resolveCliConfig();\n const db = new Database({\n connectionString: buildConnectionString(config),\n });\n const runner = new MigrationRunner(db);\n await runner.reset();\n logger.success('Database reset complete');\n })\n )\n .addCommand(\n new Command('seed')\n .description('Seed database with sample data')\n .option('--file <path>', 'Custom seed file')\n .option('--clear', 'Clear before seeding')\n .option('--count <n>', 'Number of example nodes', '10')\n .action(async (options) => {\n const config = await resolveCliConfig();\n const db = new Database({\n connectionString: buildConnectionString(config),\n });\n if (options.clear) {\n await db.execute('DELETE FROM edges');\n await db.execute('DELETE FROM nodes');\n }\n const count = Number(options.count ?? 10);\n for (let i = 0; i < count; i += 1) {\n await db.execute(\n 'INSERT INTO nodes (slug, label, node_type, domain, metadata) VALUES ($1, $2, $3, $4, $5)',\n [`seed-${i + 1}`, `Seed Node ${i + 1}`, 'concept', 'general', {}]\n );\n }\n logger.success('Seed data inserted');\n })\n );\n","import { Command } from 'commander';\nimport { Database } from '../../storage/database';\nimport { resolveCliConfig } from '../utils/config';\nimport { logger } from '../utils/logger';\nimport { EventBus } from '../../core/events/event-bus';\nimport { EmbeddingsService } from '../../core/analysis/embeddings-service';\nimport { ClusteringEngine } from '../../core/analysis/clustering-engine';\nimport { RelationshipEngine } from '../../core/analysis/relationship-engine';\nimport { AnalysisPipeline } from '../../core/analysis/pipeline';\n\nconst buildConnectionString = (config: {\n databaseUrl?: string;\n databaseUser?: string;\n databasePassword?: string;\n databaseName?: string;\n port: number;\n}) => {\n if (config.databaseUrl) return config.databaseUrl;\n const user = config.databaseUser ?? 'neuron';\n const password = config.databasePassword ?? 'neuron_dev';\n const database = config.databaseName ?? 'neuron_web';\n return `postgresql://${user}:${password}@localhost:${config.port}/${database}`;\n};\n\nasync function buildPipeline(): Promise<AnalysisPipeline> {\n const config = await resolveCliConfig();\n const db = new Database({ connectionString: buildConnectionString(config) });\n const events = new EventBus();\n\n const embeddings = new EmbeddingsService(\n {\n openaiApiKey: process.env.OPENAI_API_KEY ?? '',\n model: 'text-embedding-3-small',\n batchSize: 20,\n rateLimit: 60,\n cacheTTL: 86400,\n maxRetries: 3,\n },\n db\n );\n\n const clustering = new ClusteringEngine(db, embeddings);\n const relationships = new RelationshipEngine(db, {\n model: 'gpt-4o-mini',\n minConfidence: 0.7,\n maxPerNode: 10,\n similarityThreshold: 0.75,\n includeExisting: false,\n batchSize: 10,\n rateLimit: 30,\n });\n\n return new AnalysisPipeline(db, embeddings, clustering, relationships, events);\n}\n\nexport const analyzeCommand = new Command('analyze')\n .description('Analysis commands')\n .addCommand(\n new Command('embeddings')\n .description('Generate embeddings')\n .option('--node-ids <ids>', 'Comma-separated node IDs')\n .option('--force', 'Regenerate existing')\n .action(async (options) => {\n const pipeline = await buildPipeline();\n const nodeIds = options.nodeIds ? options.nodeIds.split(',') : undefined;\n await pipeline.runEmbeddings({ nodeIds, forceRecompute: options.force });\n logger.success('Embeddings complete');\n })\n )\n .addCommand(\n new Command('cluster')\n .description('Run clustering')\n .option('--count <n>', 'Number of clusters')\n .option('--algorithm <alg>', 'kmeans, dbscan, hierarchical', 'kmeans')\n .action(async (options) => {\n const pipeline = await buildPipeline();\n await pipeline.runClustering({\n clusterCount: options.count ? Number(options.count) : undefined,\n clusteringAlgorithm: options.algorithm,\n });\n logger.success('Clustering complete');\n })\n )\n .addCommand(\n new Command('relationships')\n .description('Infer relationships')\n .option('--threshold <n>', 'Min confidence (0-1)', '0.7')\n .option('--dry-run', 'Show without saving')\n .action(async (options) => {\n const pipeline = await buildPipeline();\n await pipeline.runRelationships({\n relationshipThreshold: Number(options.threshold),\n });\n logger.success('Relationship inference complete');\n })\n )\n .addCommand(\n new Command('full')\n .description('Run full analysis pipeline')\n .option('--force', 'Force recompute all')\n .action(async (options) => {\n const pipeline = await buildPipeline();\n await pipeline.runFull({ forceRecompute: options.force });\n logger.success('Analysis pipeline complete');\n })\n );\n","import { Command } from 'commander';\nimport fs from 'node:fs/promises';\nimport path from 'node:path';\nimport { DockerManager } from '../../storage/docker-manager';\nimport { Database } from '../../storage/database';\nimport { MigrationRunner } from '../../storage/migrations/runner';\nimport { resolveCliConfig } from '../utils/config';\nimport { logger } from '../utils/logger';\n\nconst buildConnectionString = (config: {\n databaseUrl?: string;\n databaseUser?: string;\n databasePassword?: string;\n databaseName?: string;\n port: number;\n}) => {\n if (config.databaseUrl) return config.databaseUrl;\n const user = config.databaseUser ?? 'neuron';\n const password = config.databasePassword ?? 'neuron_dev';\n const database = config.databaseName ?? 'neuron_web';\n return `postgresql://${user}:${password}@localhost:${config.port}/${database}`;\n};\n\nexport const validateCommand = new Command('validate')\n .description('Validate configuration and setup')\n .option('--fix', 'Attempt to fix issues')\n .option('--verbose', 'Show detailed validation')\n .action(async (options) => {\n const config = await resolveCliConfig();\n let hasError = false;\n\n const configPath = path.resolve('neuron.config.ts');\n try {\n await fs.access(configPath);\n logger.success('neuron.config.ts exists');\n } catch {\n hasError = true;\n logger.error('neuron.config.ts not found');\n }\n\n try {\n const docker = new DockerManager({ repoName: config.repoName, port: config.port });\n const health = await docker.healthCheck();\n logger.info(`Docker container running: ${health.containerRunning}`);\n logger.info(`Database ready: ${health.databaseReady}`);\n } catch (error) {\n hasError = true;\n logger.error(`Docker check failed: ${String(error)}`);\n }\n\n try {\n const db = new Database({ connectionString: buildConnectionString(config) });\n await db.connect();\n logger.success('Database connection ok');\n const runner = new MigrationRunner(db);\n const pending = await runner.getPending();\n if (pending.length > 0) {\n logger.warn(`Pending migrations: ${pending.map((m) => m.version).join(', ')}`);\n } else {\n logger.success('Migrations up to date');\n }\n } catch (error) {\n hasError = true;\n logger.error(`Database check failed: ${String(error)}`);\n }\n\n if (!process.env.OPENAI_API_KEY) {\n logger.warn('OPENAI_API_KEY not set');\n if (options.fix) {\n logger.info('Set OPENAI_API_KEY in your environment to enable analysis');\n }\n }\n\n if (hasError) {\n process.exitCode = 1;\n }\n });\n","import { Command } from 'commander';\nimport fs from 'node:fs/promises';\nimport path from 'node:path';\nimport { loadNeuronConfig } from '../utils/config';\nimport { logger } from '../utils/logger';\n\nconst CONFIG_FILE = path.resolve('neuron.config.ts');\n\nconst serializeConfig = (config: unknown): string => `import { defineNeuronConfig } from '@omiron33/omi-neuron-web';\\n\\nexport default defineNeuronConfig(${JSON.stringify(\n config,\n null,\n 2\n)});\\n`;\n\nconst getNestedValue = (obj: Record<string, unknown>, key: string): unknown => {\n return key.split('.').reduce((acc, part) => {\n if (acc && typeof acc === 'object' && part in acc) {\n return (acc as Record<string, unknown>)[part];\n }\n return undefined;\n }, obj as unknown);\n};\n\nconst setNestedValue = (obj: Record<string, unknown>, key: string, value: unknown): void => {\n const parts = key.split('.');\n let current = obj;\n for (let i = 0; i < parts.length - 1; i += 1) {\n const part = parts[i];\n if (!current[part] || typeof current[part] !== 'object') {\n current[part] = {};\n }\n current = current[part] as Record<string, unknown>;\n }\n current[parts[parts.length - 1]] = value;\n};\n\nexport const configCommand = new Command('config')\n .description('Manage neuron.config.ts')\n .addCommand(\n new Command('get')\n .argument('<key>', 'Dot path key')\n .action(async (key) => {\n const config = await loadNeuronConfig();\n if (!config) {\n logger.error('neuron.config.ts not found');\n return;\n }\n const value = getNestedValue(config as unknown as Record<string, unknown>, key);\n console.log(JSON.stringify(value, null, 2));\n })\n )\n .addCommand(\n new Command('set')\n .argument('<key>', 'Dot path key')\n .argument('<value>', 'Value (JSON)')\n .action(async (key, value) => {\n const config = await loadNeuronConfig();\n if (!config) {\n logger.error('neuron.config.ts not found');\n return;\n }\n const parsed = JSON.parse(value);\n const updated = { ...(config as unknown as Record<string, unknown>) };\n setNestedValue(updated, key, parsed);\n await fs.writeFile(CONFIG_FILE, serializeConfig(updated), 'utf8');\n logger.success(`Updated ${key}`);\n })\n )\n .addCommand(\n new Command('list').action(async () => {\n const config = await loadNeuronConfig();\n if (!config) {\n logger.error('neuron.config.ts not found');\n return;\n }\n console.log(JSON.stringify(config, null, 2));\n })\n )\n .addCommand(\n new Command('reset')\n .option('--section <section>', 'Section to reset')\n .action(async (options) => {\n const config = await loadNeuronConfig();\n if (!config) {\n logger.error('neuron.config.ts not found');\n return;\n }\n const updated = { ...(config as unknown as Record<string, unknown>) };\n if (options.section) {\n delete updated[options.section];\n } else {\n for (const key of Object.keys(updated)) {\n delete updated[key];\n }\n }\n await fs.writeFile(CONFIG_FILE, serializeConfig(updated), 'utf8');\n logger.success('Config reset');\n })\n );\n","#!/usr/bin/env node\nimport { program } from 'commander';\nimport { initCommand } from './commands/init';\nimport { dbCommand } from './commands/db';\nimport { analyzeCommand } from './commands/analyze';\nimport { validateCommand } from './commands/validate';\nimport { configCommand } from './commands/config';\n\nprogram\n .name('omi-neuron')\n .description('CLI for omi-neuron-web library')\n .version('0.1.0');\n\nprogram.addCommand(initCommand);\nprogram.addCommand(dbCommand);\nprogram.addCommand(analyzeCommand);\nprogram.addCommand(validateCommand);\nprogram.addCommand(configCommand);\n\nprogram.parse();\n\n"]}
|
package/dist/cli/index.js
CHANGED
|
@@ -46,12 +46,12 @@ async function writeTemplateFile(filePath, template, values, force = false) {
|
|
|
46
46
|
}
|
|
47
47
|
|
|
48
48
|
// src/cli/commands/init.ts
|
|
49
|
-
var CONFIG_TEMPLATE = `import { defineNeuronConfig, DEFAULT_ANALYSIS_SETTINGS, DEFAULT_VISUALIZATION_SETTINGS } from 'omi-neuron-web';
|
|
49
|
+
var CONFIG_TEMPLATE = `import { defineNeuronConfig, DEFAULT_ANALYSIS_SETTINGS, DEFAULT_VISUALIZATION_SETTINGS } from '@omiron33/omi-neuron-web';
|
|
50
50
|
|
|
51
51
|
export default defineNeuronConfig({
|
|
52
52
|
instance: {
|
|
53
53
|
name: '{{INSTANCE_NAME}}',
|
|
54
|
-
version: '0.1.
|
|
54
|
+
version: '0.1.1',
|
|
55
55
|
repoName: '{{REPO_NAME}}',
|
|
56
56
|
},
|
|
57
57
|
visualization: DEFAULT_VISUALIZATION_SETTINGS,
|
|
@@ -108,7 +108,7 @@ volumes:
|
|
|
108
108
|
{{REPO_NAME}}_neuron_data:
|
|
109
109
|
name: {{REPO_NAME}}_neuron_data
|
|
110
110
|
`;
|
|
111
|
-
var API_ROUTE_TEMPLATE = `import { createNeuronRoutes } from 'omi-neuron-web/api';
|
|
111
|
+
var API_ROUTE_TEMPLATE = `import { createNeuronRoutes } from '@omiron33/omi-neuron-web/api';
|
|
112
112
|
import config from '../../../../neuron.config';
|
|
113
113
|
|
|
114
114
|
const routes = createNeuronRoutes(config);
|
|
@@ -471,7 +471,7 @@ var validateCommand = new Command("validate").description("Validate configuratio
|
|
|
471
471
|
}
|
|
472
472
|
});
|
|
473
473
|
var CONFIG_FILE = path2.resolve("neuron.config.ts");
|
|
474
|
-
var serializeConfig = (config) => `import { defineNeuronConfig } from 'omi-neuron-web';
|
|
474
|
+
var serializeConfig = (config) => `import { defineNeuronConfig } from '@omiron33/omi-neuron-web';
|
|
475
475
|
|
|
476
476
|
export default defineNeuronConfig(${JSON.stringify(
|
|
477
477
|
config,
|