@lucern/graph-sync 0.3.0-alpha.10

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.
@@ -0,0 +1 @@
1
+ {"version":3,"sources":["../src/convex.ts","../src/neo4jQueries.ts"],"names":[],"mappings":"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","file":"neo4jQueries.js","sourcesContent":["import {\n actionGeneric,\n anyApi,\n componentsGeneric,\n httpActionGeneric,\n internalActionGeneric,\n internalMutationGeneric,\n internalQueryGeneric,\n mutationGeneric,\n queryGeneric,\n} from \"convex/server\";\nimport type { GenericId } from \"convex/values\";\n\nexport const api = anyApi as any;\nexport const components = componentsGeneric() as any;\nexport const internal = anyApi as any;\n\nexport type TableNames = string;\nexport type Id<TableName extends TableNames = string> = GenericId<TableName>;\nexport type Doc<TableName extends TableNames = string> = any;\nexport type DataModel = any;\nexport type ActionCtx = any;\nexport type DatabaseReader = any;\nexport type DatabaseWriter = any;\nexport type MutationCtx = any;\nexport type QueryCtx = any;\n\ntype ConvexFunctionBuilder = <Definition extends {\n handler?: (...args: any[]) => any;\n}>(\n definition: Definition\n) => any;\n\nexport const action = actionGeneric as unknown as ConvexFunctionBuilder;\nexport const httpAction = httpActionGeneric as unknown as ConvexFunctionBuilder;\nexport const internalAction =\n internalActionGeneric as unknown as ConvexFunctionBuilder;\nexport const internalMutation =\n internalMutationGeneric as unknown as ConvexFunctionBuilder;\nexport const internalQuery =\n internalQueryGeneric as unknown as ConvexFunctionBuilder;\nexport const mutation = mutationGeneric as unknown as ConvexFunctionBuilder;\nexport const query = queryGeneric as unknown as ConvexFunctionBuilder;\n","/**\n * Neo4j Graph Queries\n *\n * Convex actions that execute graph queries against Neo4j.\n * These provide graph intelligence that's hard/impossible in Convex alone:\n * - Multi-hop traversals\n * - Path finding\n * - Cross-theme patterns\n * - Contradiction detection\n *\n * Architecture:\n * - Convex action calls a tenant-owned query proxy route\n * - Query proxy executes a predefined Cypher query\n * - Results return to the Convex caller\n */\n\nimport { v } from \"convex/values\";\nimport { permissiveReturn } from \"@lucern/contracts/schema-helpers/validators\";\nimport { action } from \"./convex\";\n\n// =============================================================================\n// HELPER: Safe integer conversion\n// =============================================================================\n\n/**\n * Safely convert any value to an integer.\n * Handles: number, float, string, string float, undefined, null\n */\nfunction toInt(value: unknown, defaultValue: number): number {\n if (value === undefined || value === null) {\n return defaultValue;\n }\n const parsed = Number(value);\n return Number.isFinite(parsed) ? Math.floor(parsed) : defaultValue;\n}\n\n// =============================================================================\n// HELPER: URL Validation (SSRF Prevention)\n// =============================================================================\n\n/**\n * Validate that a URL is safe to send credentials to.\n * Prevents accidental credential leakage to non-HTTPS hosts. Operators may add\n * a stricter comma-delimited host allowlist with\n * LUCERN_GRAPH_SYNC_ALLOWED_PROXY_HOSTS.\n */\nfunction isAllowedProxyUrl(urlString: string): boolean {\n try {\n const url = new URL(urlString);\n const isLocalhost =\n url.hostname === \"localhost\" || url.hostname === \"127.0.0.1\";\n if (!isLocalhost && url.protocol !== \"https:\") {\n return false;\n }\n if (url.username || url.password) {\n return false;\n }\n\n const configuredHosts = (\n process.env.LUCERN_GRAPH_SYNC_ALLOWED_PROXY_HOSTS || \"\"\n )\n .split(\",\")\n .map((host) => host.trim().toLowerCase())\n .filter(Boolean);\n if (configuredHosts.length === 0) {\n return true;\n }\n\n const hostname = url.hostname.toLowerCase();\n return configuredHosts.some((host) =>\n host.startsWith(\".\") ? hostname.endsWith(host) : hostname === host\n );\n } catch {\n console.warn(\"[Neo4j Queries] Rejected malformed proxy URL\", urlString);\n return false;\n }\n}\n\ntype Neo4jQueryTransportSuccess = Readonly<{\n success: true;\n data: unknown[];\n}>;\n\ntype Neo4jQueryTransportFailure = Readonly<{\n success: false;\n error: string;\n}>;\n\ntype Neo4jQueryTransportResult =\n | Neo4jQueryTransportSuccess\n | Neo4jQueryTransportFailure;\n\nfunction createNeo4jQueryTransportSuccess(\n data: unknown[]\n): Neo4jQueryTransportSuccess {\n return { success: true, data };\n}\n\nfunction createNeo4jQueryTransportFailure(\n error: string\n): Neo4jQueryTransportFailure {\n return { success: false, error };\n}\n\nfunction resolveProxyBaseUrl(apiBaseUrl?: string): string | null {\n const resolved =\n apiBaseUrl ||\n process.env.LUCERN_GRAPH_SYNC_QUERY_BASE_URL ||\n process.env.NEXT_PUBLIC_APP_URL;\n const normalized = resolved?.trim();\n return normalized ? normalized.replace(/\\/+$/u, \"\") : null;\n}\n\nfunction buildProxyEndpoint(proxyBaseUrl: string): string {\n const endpoint = new URL(proxyBaseUrl);\n if (!endpoint.pathname.endsWith(\"/api/neo4j-query\")) {\n endpoint.pathname = `${endpoint.pathname.replace(/\\/+$/u, \"\")}/api/neo4j-query`;\n }\n return endpoint.toString();\n}\n\n// =============================================================================\n// HELPER: Call Neo4j Query API\n// =============================================================================\n\nasync function callNeo4jQuery(\n queryName: string,\n params: Record<string, unknown>,\n apiBaseUrl?: string\n): Promise<Neo4jQueryTransportResult> {\n const proxyUrl = resolveProxyBaseUrl(apiBaseUrl);\n if (!proxyUrl) {\n return createNeo4jQueryTransportFailure(\n \"Neo4j query proxy URL not configured\"\n );\n }\n\n if (!isAllowedProxyUrl(proxyUrl)) {\n console.error(\n \"[Neo4j Queries] Blocked request to disallowed URL:\",\n proxyUrl\n );\n return createNeo4jQueryTransportFailure(\"Invalid proxy URL\");\n }\n\n const syncSecret = process.env.NEO4J_SYNC_SECRET;\n\n if (!syncSecret) {\n console.error(\"[Neo4j Queries] NEO4J_SYNC_SECRET not configured\");\n return createNeo4jQueryTransportFailure(\n \"Neo4j sync secret not configured\"\n );\n }\n\n try {\n const explicitTenant =\n typeof params.tenantId === \"string\" ? params.tenantId.trim() : \"\";\n const scopedTopic =\n typeof params.topicId === \"string\" ? params.topicId.trim() : \"\";\n const legacyProject =\n typeof params.projectId === \"string\" ? params.projectId.trim() : \"\";\n const scopedTopicId = scopedTopic || legacyProject;\n const projectTenant = scopedTopicId ? `project:${scopedTopicId}` : \"\";\n const defaultTenant = process.env.LUCERN_DEFAULT_TENANT_ID?.trim() || \"\";\n const tenantId = explicitTenant || projectTenant || defaultTenant;\n if (!tenantId) {\n return createNeo4jQueryTransportFailure(\n \"Missing required tenant context (tenantId or topicId)\"\n );\n }\n const scopedParams = { ...params, tenantId };\n\n // Build headers - include bypass secret for Vercel SSO on preview deployments\n const headers: Record<string, string> = {\n \"Content-Type\": \"application/json\",\n Authorization: `Bearer ${syncSecret}`,\n };\n\n // Add Vercel protection bypass for preview environments\n // This allows Convex to call preview API routes that are behind SSO\n const bypassSecret = process.env.VERCEL_AUTOMATION_BYPASS_SECRET;\n if (bypassSecret && apiBaseUrl) {\n // Only add bypass header when calling non-production URLs\n headers[\"x-vercel-protection-bypass\"] = bypassSecret;\n }\n\n // Add 10 second timeout to prevent hanging\n const controller = new AbortController();\n const timeoutId = setTimeout(() => controller.abort(), 10_000);\n\n try {\n const response = await fetch(buildProxyEndpoint(proxyUrl), {\n method: \"POST\",\n headers,\n body: JSON.stringify({ queryName, params: scopedParams }),\n signal: controller.signal,\n });\n\n clearTimeout(timeoutId);\n const result = await response.json();\n\n if (!response.ok) {\n return createNeo4jQueryTransportFailure(result.error || \"Query failed\");\n }\n\n return createNeo4jQueryTransportSuccess(result.data || []);\n } catch (fetchError) {\n clearTimeout(timeoutId);\n if (fetchError instanceof Error && fetchError.name === \"AbortError\") {\n console.warn(\"[Neo4j Queries] Request timed out for:\", queryName);\n return createNeo4jQueryTransportFailure(\"Query timed out (10s)\");\n }\n throw fetchError;\n }\n } catch (error) {\n console.error(\"[Neo4j Queries] Error in callNeo4jQuery:\", queryName, error);\n return createNeo4jQueryTransportFailure(\n error instanceof Error\n ? error.message\n : \"Network error connecting to query proxy\"\n );\n }\n}\n\nfunction withTopicScope<T extends Record<string, unknown>>(\n args: { topicId?: string },\n params: T\n): T & { topicId?: string } {\n return args.topicId ? { ...params, topicId: args.topicId } : params;\n}\n\n// =============================================================================\n// GRAPH QUERIES\n// =============================================================================\n\n/**\n * Get the full lineage of a node (what it was derived/extracted from)\n * Uses Neo4j for efficient multi-hop traversal up to 10 levels deep\n */\nexport const getNodeLineageGraph = action({\n args: {\n globalId: v.string(),\n apiBaseUrl: v.optional(v.string()),\n topicId: v.optional(v.string()),\n },\n returns: permissiveReturn,\n handler: async (_ctx, args) => {\n const result = await callNeo4jQuery(\n \"nodeLineage\",\n withTopicScope(args, {\n globalId: args.globalId,\n }),\n args.apiBaseUrl\n );\n\n if (!result.success) {\n console.error(\"[Neo4j] Lineage query failed:\", result.error);\n return { lineage: [], error: result.error };\n }\n\n // Extract lineage from first result\n const lineage =\n (result.data?.[0] as { lineage?: unknown[] })?.lineage || [];\n return { lineage };\n },\n});\n\n/**\n * Get nodes connected to a given node within N hops\n * Much more powerful than Convex's single-hop queries\n */\nexport const getConnectedNodesGraph = action({\n args: {\n globalId: v.string(),\n maxHops: v.optional(v.number()),\n limit: v.optional(v.number()),\n apiBaseUrl: v.optional(v.string()),\n topicId: v.optional(v.string()),\n },\n returns: permissiveReturn,\n handler: async (_ctx, args) => {\n // Ensure numeric params are integers (Neo4j requires integers, not floats)\n const maxHops = Math.min(toInt(args.maxHops, 2), 5);\n const limit = toInt(args.limit, 50);\n\n const result = await callNeo4jQuery(\n \"connectedNodes\",\n withTopicScope(args, {\n globalId: args.globalId,\n maxHops,\n limit,\n }),\n args.apiBaseUrl\n );\n\n if (!result.success) {\n console.error(\"[Neo4j] Connected nodes query failed:\", result.error);\n return { nodes: [], error: result.error };\n }\n\n return { nodes: result.data || [] };\n },\n});\n\n/**\n * Get all beliefs that belong to a theme\n */\nexport const getThemeBeliefsGraph = action({\n args: {\n themeGlobalId: v.string(),\n },\n returns: permissiveReturn,\n handler: async (_ctx, args) => {\n const result = await callNeo4jQuery(\"themeBeliefs\", {\n themeGlobalId: args.themeGlobalId,\n });\n\n if (!result.success) {\n return { beliefs: [], error: result.error };\n }\n\n return {\n beliefs: result.data?.map((r) => (r as { belief: unknown }).belief) || [],\n };\n },\n});\n\n/**\n * Get evidence that supports a belief (through question chain OR direct link)\n */\nexport const getBeliefEvidenceGraph = action({\n args: {\n beliefGlobalId: v.string(),\n apiBaseUrl: v.optional(v.string()),\n topicId: v.optional(v.string()),\n },\n returns: permissiveReturn,\n handler: async (_ctx, args) => {\n const result = await callNeo4jQuery(\n \"beliefEvidence\",\n withTopicScope(args, {\n beliefGlobalId: args.beliefGlobalId,\n }),\n args.apiBaseUrl\n );\n\n if (!result.success) {\n return { evidence: [], error: result.error };\n }\n\n return {\n evidence:\n result.data?.map((r) => (r as { evidence: unknown }).evidence) || [],\n };\n },\n});\n\n/**\n * Find beliefs that appear in multiple themes (cross-cutting insights)\n */\nexport const getCrossThemeBeliefs = action({\n args: {\n limit: v.optional(v.number()),\n apiBaseUrl: v.optional(v.string()),\n topicId: v.optional(v.string()),\n },\n returns: permissiveReturn,\n handler: async (_ctx, args) => {\n const result = await callNeo4jQuery(\n \"crossThemeBeliefs\",\n withTopicScope(args, {\n limit: toInt(args.limit, 20),\n }),\n args.apiBaseUrl\n );\n\n if (!result.success) {\n return { beliefs: [], error: result.error };\n }\n\n return {\n beliefs: result.data?.map((r) => (r as { belief: unknown }).belief) || [],\n };\n },\n});\n\n/**\n * Find potential contradictions in the knowledge graph\n * Evidence that tests conflicting beliefs\n */\nexport const findPotentialContradictions = action({\n args: {\n limit: v.optional(v.number()),\n apiBaseUrl: v.optional(v.string()),\n topicId: v.optional(v.string()),\n },\n returns: permissiveReturn,\n handler: async (_ctx, args) => {\n const result = await callNeo4jQuery(\n \"potentialContradictions\",\n withTopicScope(args, {\n limit: toInt(args.limit, 10),\n }),\n args.apiBaseUrl\n );\n\n if (!result.success) {\n return { contradictions: [], error: result.error };\n }\n\n return {\n contradictions:\n result.data?.map(\n (r) => (r as { contradiction: unknown }).contradiction\n ) || [],\n };\n },\n});\n\n/**\n * Get the full subgraph for a theme (all connected beliefs, questions, evidence)\n */\nexport const getThemeSubgraph = action({\n args: {\n themeGlobalId: v.string(),\n apiBaseUrl: v.optional(v.string()),\n topicId: v.optional(v.string()),\n },\n returns: permissiveReturn,\n handler: async (_ctx, args) => {\n const result = await callNeo4jQuery(\n \"themeSubgraph\",\n withTopicScope(args, {\n themeGlobalId: args.themeGlobalId,\n }),\n args.apiBaseUrl\n );\n\n if (!result.success) {\n return { subgraph: null, error: result.error };\n }\n\n return {\n subgraph: (result.data?.[0] as { subgraph: unknown })?.subgraph || null,\n };\n },\n});\n\n/**\n * Find the path from evidence to a belief (how does this evidence support this belief?)\n */\nexport const getEvidenceToBeliefPath = action({\n args: {\n evidenceGlobalId: v.string(),\n beliefGlobalId: v.string(),\n apiBaseUrl: v.optional(v.string()),\n topicId: v.optional(v.string()),\n },\n returns: permissiveReturn,\n handler: async (_ctx, args) => {\n const result = await callNeo4jQuery(\n \"evidenceToBeliefPath\",\n withTopicScope(args, {\n evidenceGlobalId: args.evidenceGlobalId,\n beliefGlobalId: args.beliefGlobalId,\n }),\n args.apiBaseUrl\n );\n\n if (!result.success) {\n return { path: null, error: result.error };\n }\n\n // Query returns: { pathResult: { nodes: [...], relationships: [...], length: N } }\n const pathResult = result.data?.[0] as {\n pathResult?: {\n nodes?: unknown[];\n relationships?: string[];\n length?: number;\n };\n };\n\n if (!pathResult?.pathResult) {\n return { path: null, error: \"No path found between evidence and belief\" };\n }\n\n return {\n path: {\n nodes: pathResult.pathResult.nodes || [],\n relationships: pathResult.pathResult.relationships || [],\n length: pathResult.pathResult.length || 0,\n },\n };\n },\n});\n\n/**\n * Get stats for a theme (counts of beliefs, questions, evidence)\n */\nexport const getThemeStats = action({\n args: {\n themeGlobalId: v.string(),\n },\n returns: permissiveReturn,\n handler: async (_ctx, args) => {\n const result = await callNeo4jQuery(\"themeStats\", {\n themeGlobalId: args.themeGlobalId,\n });\n\n if (!result.success) {\n return { stats: null, error: result.error };\n }\n\n return { stats: (result.data?.[0] as { stats: unknown })?.stats || null };\n },\n});\n\n/**\n * Get candidate theme-to-valuechain mappings\n * Returns all themes and value chains for manual or AI-assisted matching\n */\nexport const getThemeValueChainCandidates = action({\n args: {\n limit: v.optional(v.number()),\n apiBaseUrl: v.optional(v.string()),\n topicId: v.optional(v.string()),\n },\n returns: permissiveReturn,\n handler: async (_ctx, args) => {\n const result = await callNeo4jQuery(\n \"themeValueChainCandidates\",\n withTopicScope(args, {\n limit: toInt(args.limit, 100),\n }),\n args.apiBaseUrl\n );\n\n if (!result.success) {\n return { candidates: [], error: result.error };\n }\n\n return {\n candidates:\n result.data?.map((r) => (r as { candidate: unknown }).candidate) || [],\n };\n },\n});\n\n// =============================================================================\n// RELATIONSHIP QUERIES\n// =============================================================================\n\n/**\n * Find themes that impact a specific company\n */\nexport const getThemesImpactingCompany = action({\n args: {\n companyName: v.string(),\n limit: v.optional(v.number()),\n },\n returns: permissiveReturn,\n handler: async (_ctx, args) => {\n const result = await callNeo4jQuery(\"themesImpactingCompany\", {\n companyName: args.companyName,\n limit: toInt(args.limit, 20),\n });\n\n if (!result.success) {\n return { results: [], error: result.error };\n }\n\n return { results: result.data || [] };\n },\n});\n\n/**\n * Find companies related to a theme\n */\nexport const getCompaniesByTheme = action({\n args: {\n themeName: v.string(),\n limit: v.optional(v.number()),\n },\n returns: permissiveReturn,\n handler: async (_ctx, args) => {\n const result = await callNeo4jQuery(\"companiesByTheme\", {\n themeName: args.themeName,\n limit: toInt(args.limit, 50),\n });\n\n if (!result.success) {\n return { results: [], error: result.error };\n }\n\n return { results: result.data || [] };\n },\n});\n\n/**\n * Find questions about a value chain\n */\nexport const getQuestionsByValueChain = action({\n args: {\n valueChainName: v.string(),\n limit: v.optional(v.number()),\n },\n returns: permissiveReturn,\n handler: async (_ctx, args) => {\n const result = await callNeo4jQuery(\"questionsByValueChain\", {\n valueChainName: args.valueChainName,\n limit: toInt(args.limit, 50),\n });\n\n if (!result.success) {\n return { results: [], error: result.error };\n }\n\n return { results: result.data || [] };\n },\n});\n\n/**\n * Find questions about a theme\n */\nexport const getQuestionsByTheme = action({\n args: {\n themeName: v.string(),\n limit: v.optional(v.number()),\n },\n returns: permissiveReturn,\n handler: async (_ctx, args) => {\n const result = await callNeo4jQuery(\"questionsByTheme\", {\n themeName: args.themeName,\n limit: toInt(args.limit, 50),\n });\n\n if (!result.success) {\n return { results: [], error: result.error };\n }\n\n return { results: result.data || [] };\n },\n});\n\n/**\n * Find people/contacts related to a theme\n */\nexport const getPeopleByTheme = action({\n args: {\n themeName: v.string(),\n limit: v.optional(v.number()),\n },\n returns: permissiveReturn,\n handler: async (_ctx, args) => {\n const result = await callNeo4jQuery(\"peopleByTheme\", {\n themeName: args.themeName,\n limit: toInt(args.limit, 50),\n });\n\n if (!result.success) {\n return { results: [], error: result.error };\n }\n\n return { results: result.data || [] };\n },\n});\n\n/**\n * Find people at a specific company\n */\nexport const getPeopleByCompany = action({\n args: {\n companyName: v.string(),\n limit: v.optional(v.number()),\n },\n returns: permissiveReturn,\n handler: async (_ctx, args) => {\n const result = await callNeo4jQuery(\"peopleByCompany\", {\n companyName: args.companyName,\n limit: toInt(args.limit, 50),\n });\n\n if (!result.success) {\n return { results: [], error: result.error };\n }\n\n return { results: result.data || [] };\n },\n});\n\n/**\n * Find value chains for a theme\n */\nexport const getValueChainsByTheme = action({\n args: {\n themeName: v.string(),\n limit: v.optional(v.number()),\n },\n returns: permissiveReturn,\n handler: async (_ctx, args) => {\n const result = await callNeo4jQuery(\"valueChainsByTheme\", {\n themeName: args.themeName,\n limit: toInt(args.limit, 20),\n });\n\n if (!result.success) {\n return { results: [], error: result.error };\n }\n\n return { results: result.data || [] };\n },\n});\n\n/**\n * Find functions in a value chain\n */\nexport const getFunctionsByValueChain = action({\n args: {\n valueChainName: v.string(),\n limit: v.optional(v.number()),\n },\n returns: permissiveReturn,\n handler: async (_ctx, args) => {\n const result = await callNeo4jQuery(\"functionsByValueChain\", {\n valueChainName: args.valueChainName,\n limit: toInt(args.limit, 50),\n });\n\n if (!result.success) {\n return { results: [], error: result.error };\n }\n\n return { results: result.data || [] };\n },\n});\n\n/**\n * Find beliefs about a company\n */\nexport const getBeliefsByCompany = action({\n args: {\n companyName: v.string(),\n limit: v.optional(v.number()),\n },\n returns: permissiveReturn,\n handler: async (_ctx, args) => {\n const result = await callNeo4jQuery(\"beliefsByCompany\", {\n companyName: args.companyName,\n limit: toInt(args.limit, 30),\n });\n\n if (!result.success) {\n return { results: [], error: result.error };\n }\n\n return { results: result.data || [] };\n },\n});\n\n/**\n * Find evidence about a company\n */\nexport const getEvidenceByCompany = action({\n args: {\n companyName: v.string(),\n limit: v.optional(v.number()),\n },\n returns: permissiveReturn,\n handler: async (_ctx, args) => {\n const result = await callNeo4jQuery(\"evidenceByCompany\", {\n companyName: args.companyName,\n limit: toInt(args.limit, 50),\n });\n\n if (!result.success) {\n return { results: [], error: result.error };\n }\n\n return { results: result.data || [] };\n },\n});\n\n/**\n * Search all nodes by text\n */\nexport const searchAllNodes = action({\n args: {\n searchText: v.string(),\n limit: v.optional(v.number()),\n },\n returns: permissiveReturn,\n handler: async (_ctx, args) => {\n const result = await callNeo4jQuery(\"searchAllNodes\", {\n searchText: args.searchText,\n limit: toInt(args.limit, 50),\n });\n\n if (!result.success) {\n return { results: [], error: result.error };\n }\n\n return { results: result.data || [] };\n },\n});\n\n/**\n * Get all relationships from a node\n */\nexport const getNodeRelationships = action({\n args: {\n globalId: v.optional(v.string()),\n searchText: v.optional(v.string()),\n limit: v.optional(v.number()),\n },\n returns: permissiveReturn,\n handler: async (_ctx, args) => {\n const result = await callNeo4jQuery(\"nodeRelationships\", {\n globalId: args.globalId || \"\",\n searchText: args.searchText || \"\",\n limit: toInt(args.limit, 50),\n });\n\n if (!result.success) {\n return { results: [], error: result.error };\n }\n\n return { results: result.data || [] };\n },\n});\n\n/**\n * Get graph statistics (node counts by type)\n */\nexport const getGraphStats = action({\n args: {},\n returns: permissiveReturn,\n handler: async () => {\n const result = await callNeo4jQuery(\"graphStats\", {});\n\n if (!result.success) {\n return { stats: [], error: result.error };\n }\n\n return { stats: result.data || [] };\n },\n});\n\n/**\n * Flexible graph query - routes to appropriate query based on intent\n * This is the main entry point for natural language graph queries\n */\nexport const queryGraph = action({\n args: {\n queryType: v.union(\n v.literal(\"themesImpactingCompany\"),\n v.literal(\"companiesByTheme\"),\n v.literal(\"questionsByValueChain\"),\n v.literal(\"questionsByTheme\"),\n v.literal(\"peopleByTheme\"),\n v.literal(\"peopleByCompany\"),\n v.literal(\"valueChainsByTheme\"),\n v.literal(\"functionsByValueChain\"),\n v.literal(\"beliefsByCompany\"),\n v.literal(\"evidenceByCompany\"),\n v.literal(\"searchAllNodes\"),\n v.literal(\"nodeRelationships\"),\n v.literal(\"graphStats\")\n ),\n params: v.object({\n companyName: v.optional(v.string()),\n themeName: v.optional(v.string()),\n valueChainName: v.optional(v.string()),\n searchText: v.optional(v.string()),\n globalId: v.optional(v.string()),\n limit: v.optional(v.number()),\n }),\n apiBaseUrl: v.optional(v.string()),\n topicId: v.optional(v.string()),\n },\n returns: permissiveReturn,\n handler: async (_ctx, args) => {\n // Ensure limit is an integer (JavaScript may pass floats)\n const limit = toInt(args.params.limit, 30);\n\n // Validate required params based on query type\n const themeRequiredQueries = [\n \"questionsByTheme\",\n \"peopleByTheme\",\n \"companiesByTheme\",\n \"valueChainsByTheme\",\n ];\n const companyRequiredQueries = [\n \"themesImpactingCompany\",\n \"peopleByCompany\",\n \"beliefsByCompany\",\n \"evidenceByCompany\",\n ];\n const valueChainRequiredQueries = [\n \"questionsByValueChain\",\n \"functionsByValueChain\",\n ];\n\n if (\n themeRequiredQueries.includes(args.queryType) &&\n !args.params.themeName\n ) {\n return {\n results: [],\n error: `Query type '${args.queryType}' requires 'themeName' parameter`,\n };\n }\n if (\n companyRequiredQueries.includes(args.queryType) &&\n !args.params.companyName\n ) {\n return {\n results: [],\n error: `Query type '${args.queryType}' requires 'companyName' parameter`,\n };\n }\n if (\n valueChainRequiredQueries.includes(args.queryType) &&\n !args.params.valueChainName\n ) {\n return {\n results: [],\n error: `Query type '${args.queryType}' requires 'valueChainName' parameter`,\n };\n }\n\n const result = await callNeo4jQuery(\n args.queryType,\n withTopicScope(args, {\n ...args.params,\n limit,\n }),\n args.apiBaseUrl\n );\n\n if (!result.success) {\n return { results: [], error: result.error };\n }\n\n return { results: result.data || [] };\n },\n});\n\n// =============================================================================\n// CLASSIFICATION-POWERED QUERIES (Logic Machine)\n// These leverage the new epistemic classification fields\n// =============================================================================\n\n/**\n * Get high-priority questions (critical/high) that test beliefs\n */\nexport const getHighPriorityQuestions = action({\n args: {\n limit: v.optional(v.number()),\n apiBaseUrl: v.optional(v.string()),\n topicId: v.optional(v.string()),},\n returns: permissiveReturn,\n handler: async (_ctx, args) => {\n const result = await callNeo4jQuery(\n \"highPriorityQuestions\",\n withTopicScope(args, {\n limit: toInt(args.limit, 50),\n }),\n args.apiBaseUrl\n );\n\n if (!result.success) {\n return { questions: [], error: result.error };\n }\n\n return { questions: result.data || [] };\n },\n});\n\n/**\n * Get evidence filtered by methodology (expert_interview, customer_interview, etc.)\n */\nexport const getEvidenceByMethodology = action({\n args: {\n methodology: v.string(),\n limit: v.optional(v.number()),\n apiBaseUrl: v.optional(v.string()),\n topicId: v.optional(v.string()),},\n returns: permissiveReturn,\n handler: async (_ctx, args) => {\n const result = await callNeo4jQuery(\n \"evidenceByMethodology\",\n withTopicScope(args, {\n methodology: args.methodology,\n limit: toInt(args.limit, 50),\n }),\n args.apiBaseUrl\n );\n\n if (!result.success) {\n return { evidence: [], error: result.error };\n }\n\n return { evidence: result.data || [] };\n },\n});\n\n/**\n * Get proprietary/early evidence (information asymmetry advantage)\n */\nexport const getProprietaryEvidence = action({\n args: {\n limit: v.optional(v.number()),\n apiBaseUrl: v.optional(v.string()),\n topicId: v.optional(v.string()),},\n returns: permissiveReturn,\n handler: async (_ctx, args) => {\n const result = await callNeo4jQuery(\n \"proprietaryEvidence\",\n withTopicScope(args, {\n limit: toInt(args.limit, 50),\n }),\n args.apiBaseUrl\n );\n\n if (!result.success) {\n return { evidence: [], error: result.error };\n }\n\n return { evidence: result.data || [] };\n },\n});\n\n/**\n * Get beliefs by epistemic status (hypothesis, emerging, established, challenged, etc.)\n */\nexport const getBeliefsByEpistemicStatus = action({\n args: {\n epistemicStatus: v.string(),\n limit: v.optional(v.number()),\n apiBaseUrl: v.optional(v.string()),\n topicId: v.optional(v.string()),},\n returns: permissiveReturn,\n handler: async (_ctx, args) => {\n const result = await callNeo4jQuery(\n \"beliefsByEpistemicStatus\",\n withTopicScope(args, {\n epistemicStatus: args.epistemicStatus,\n limit: toInt(args.limit, 50),\n }),\n args.apiBaseUrl\n );\n\n if (!result.success) {\n return { beliefs: [], error: result.error };\n }\n\n return { beliefs: result.data || [] };\n },\n});\n\n/**\n * Get challenged beliefs that need attention\n */\nexport const getChallengedBeliefs = action({\n args: {\n limit: v.optional(v.number()),\n apiBaseUrl: v.optional(v.string()),\n topicId: v.optional(v.string()),},\n returns: permissiveReturn,\n handler: async (_ctx, args) => {\n const result = await callNeo4jQuery(\n \"challengedBeliefs\",\n withTopicScope(args, {\n limit: toInt(args.limit, 30),\n }),\n args.apiBaseUrl\n );\n\n if (!result.success) {\n return { beliefs: [], error: result.error };\n }\n\n return { beliefs: result.data || [] };\n },\n});\n\n/**\n * Get predictions with deadlines\n */\nexport const getPredictions = action({\n args: {\n limit: v.optional(v.number()),\n apiBaseUrl: v.optional(v.string()),\n topicId: v.optional(v.string()),},\n returns: permissiveReturn,\n handler: async (_ctx, args) => {\n const result = await callNeo4jQuery(\n \"predictions\",\n withTopicScope(args, {\n limit: toInt(args.limit, 50),\n }),\n args.apiBaseUrl\n );\n\n if (!result.success) {\n return { predictions: [], error: result.error };\n }\n\n return { predictions: result.data || [] };\n },\n});\n\n/**\n * Get causal chains (edges with causal reasoning method)\n */\nexport const getCausalChains = action({\n args: {\n limit: v.optional(v.number()),\n apiBaseUrl: v.optional(v.string()),\n topicId: v.optional(v.string()),},\n returns: permissiveReturn,\n handler: async (_ctx, args) => {\n const result = await callNeo4jQuery(\n \"causalChains\",\n withTopicScope(args, {\n limit: toInt(args.limit, 50),\n }),\n args.apiBaseUrl\n );\n\n if (!result.success) {\n return { chains: [], error: result.error };\n }\n\n return { chains: result.data || [] };\n },\n});\n\n/**\n * Get necessary evidence for beliefs (logicalRole = necessary or necessary_sufficient)\n */\nexport const getNecessaryEvidence = action({\n args: {\n limit: v.optional(v.number()),\n apiBaseUrl: v.optional(v.string()),\n topicId: v.optional(v.string()),},\n returns: permissiveReturn,\n handler: async (_ctx, args) => {\n const result = await callNeo4jQuery(\n \"necessaryEvidence\",\n withTopicScope(args, {\n limit: toInt(args.limit, 50),\n }),\n args.apiBaseUrl\n );\n\n if (!result.success) {\n return { results: [], error: result.error };\n }\n\n return { results: result.data || [] };\n },\n});\n\n/**\n * Get falsification questions (designed to disprove beliefs)\n */\nexport const getFalsificationQuestions = action({\n args: {\n limit: v.optional(v.number()),\n apiBaseUrl: v.optional(v.string()),\n topicId: v.optional(v.string()),},\n returns: permissiveReturn,\n handler: async (_ctx, args) => {\n const result = await callNeo4jQuery(\n \"falsificationQuestions\",\n withTopicScope(args, {\n limit: toInt(args.limit, 50),\n }),\n args.apiBaseUrl\n );\n\n if (!result.success) {\n return { questions: [], error: result.error };\n }\n\n return { questions: result.data || [] };\n },\n});\n\n// =============================================================================\n// KILLER QUERIES - COGNITIVE BIAS DETECTION\n// =============================================================================\n\n/**\n * Detect confirmation bias in beliefs.\n * Returns beliefs with high supporting:contradicting evidence ratio.\n */\nexport const getConfirmationBiasScore = action({\n args: {\n limit: v.optional(v.number()),\n apiBaseUrl: v.optional(v.string()),\n topicId: v.optional(v.string()),\n },\n returns: permissiveReturn,\n handler: async (_ctx, args) => {\n const result = await callNeo4jQuery(\n \"confirmationBiasScore\",\n {\n ...(args.topicId ? { topicId: args.topicId } : {}),\n limit: toInt(args.limit, 30),\n },\n args.apiBaseUrl\n );\n\n if (!result.success) {\n return { results: [], error: result.error };\n }\n\n return { results: result.data || [] };\n },\n});\n\n/**\n * Detect anchoring bias - old beliefs that never got challenged or forked.\n */\nexport const getAnchoringBiasDetection = action({\n args: {\n limit: v.optional(v.number()),\n apiBaseUrl: v.optional(v.string()),\n topicId: v.optional(v.string()),},\n returns: permissiveReturn,\n handler: async (_ctx, args) => {\n const result = await callNeo4jQuery(\n \"anchoringBiasDetection\",\n withTopicScope(args, {\n limit: toInt(args.limit, 30),\n }),\n args.apiBaseUrl\n );\n\n if (!result.success) {\n return { results: [], error: result.error };\n }\n\n return { results: result.data || [] };\n },\n});\n\n/**\n * Detect source concentration risk - beliefs where all evidence traces to single source.\n */\nexport const getSourceConcentrationRisk = action({\n args: {\n limit: v.optional(v.number()),\n apiBaseUrl: v.optional(v.string()),\n topicId: v.optional(v.string()),},\n returns: permissiveReturn,\n handler: async (_ctx, args) => {\n const result = await callNeo4jQuery(\n \"sourceConcentrationRisk\",\n withTopicScope(args, {\n limit: toInt(args.limit, 30),\n }),\n args.apiBaseUrl\n );\n\n if (!result.success) {\n return { results: [], error: result.error };\n }\n\n return { results: result.data || [] };\n },\n});\n\n// =============================================================================\n// KILLER QUERIES - THESIS STRESS TESTING\n// =============================================================================\n\n/**\n * Find the minimum falsification set - smallest set of beliefs that would collapse the thesis.\n */\nexport const getMinimumFalsificationSet = action({\n args: {\n apiBaseUrl: v.optional(v.string()),\n topicId: v.optional(v.string()),},\n returns: permissiveReturn,\n handler: async (_ctx, args) => {\n const result = await callNeo4jQuery(\n \"minimumFalsificationSet\",\n withTopicScope(args, {}),\n args.apiBaseUrl\n );\n\n if (!result.success) {\n return { result: null, error: result.error };\n }\n\n // Extract from result array (single result expected)\n const data = result.data;\n return { result: Array.isArray(data) && data.length > 0 ? data[0] : null };\n },\n});\n\n/**\n * Get contradiction tension map - all unresolved tensions in the graph.\n */\nexport const getContradictionTensionMap = action({\n args: {\n limit: v.optional(v.number()),\n apiBaseUrl: v.optional(v.string()),\n topicId: v.optional(v.string()),},\n returns: permissiveReturn,\n handler: async (_ctx, args) => {\n const result = await callNeo4jQuery(\n \"contradictionTensionMap\",\n withTopicScope(args, {\n limit: toInt(args.limit, 30),\n }),\n args.apiBaseUrl\n );\n\n if (!result.success) {\n return { results: [], error: result.error };\n }\n\n return { results: result.data || [] };\n },\n});\n\n// =============================================================================\n// KILLER QUERIES - EPISTEMIC HEALTH\n// =============================================================================\n\n/**\n * Get reasoning depth score - how deep is the evidence chain for each belief?\n */\nexport const getReasoningDepthScore = action({\n args: {\n limit: v.optional(v.number()),\n apiBaseUrl: v.optional(v.string()),\n topicId: v.optional(v.string()),},\n returns: permissiveReturn,\n handler: async (_ctx, args) => {\n const result = await callNeo4jQuery(\n \"reasoningDepthScore\",\n withTopicScope(args, {\n limit: toInt(args.limit, 50),\n }),\n args.apiBaseUrl\n );\n\n if (!result.success) {\n return { results: [], error: result.error };\n }\n\n return { results: result.data || [] };\n },\n});\n\n/**\n * Get knowledge frontier - open questions on the boundary of what we know.\n */\nexport const getKnowledgeFrontier = action({\n args: {\n limit: v.optional(v.number()),\n apiBaseUrl: v.optional(v.string()),\n topicId: v.optional(v.string()),},\n returns: permissiveReturn,\n handler: async (_ctx, args) => {\n const result = await callNeo4jQuery(\n \"knowledgeFrontier\",\n withTopicScope(args, {\n limit: toInt(args.limit, 30),\n }),\n args.apiBaseUrl\n );\n\n if (!result.success) {\n return { results: [], error: result.error };\n }\n\n return { results: result.data || [] };\n },\n});\n\n/**\n * Get belief half-life analysis - how long do beliefs survive before being superseded?\n */\nexport const getBeliefHalfLife = action({\n args: {\n apiBaseUrl: v.optional(v.string()),\n topicId: v.optional(v.string()),},\n returns: permissiveReturn,\n handler: async (_ctx, args) => {\n const result = await callNeo4jQuery(\n \"beliefHalfLife\",\n withTopicScope(args, {}),\n args.apiBaseUrl\n );\n\n if (!result.success) {\n return { result: null, error: result.error };\n }\n\n // Single result expected\n const data = result.data;\n return { result: Array.isArray(data) && data.length > 0 ? data[0] : null };\n },\n});\n\n// =============================================================================\n// KILLER QUERIES - OPERATIONAL INTELLIGENCE\n// =============================================================================\n\n/**\n * Get meeting prep brief for a person at a company.\n */\nexport const getMeetingPrepBrief = action({\n args: {\n personGlobalId: v.string(),\n apiBaseUrl: v.optional(v.string()),\n topicId: v.optional(v.string()),},\n returns: permissiveReturn,\n handler: async (_ctx, args) => {\n const result = await callNeo4jQuery(\n \"meetingPrepBrief\",\n withTopicScope(args, {\n personGlobalId: args.personGlobalId,\n }),\n args.apiBaseUrl\n );\n\n if (!result.success) {\n return { brief: null, error: result.error };\n }\n\n // Single result expected\n const data = result.data;\n return { brief: Array.isArray(data) && data.length > 0 ? data[0] : null };\n },\n});\n\n/**\n * Get proprietary signals - our unique insights not in public discourse.\n */\nexport const getProprietarySignals = action({\n args: {\n limit: v.optional(v.number()),\n apiBaseUrl: v.optional(v.string()),\n topicId: v.optional(v.string()),},\n returns: permissiveReturn,\n handler: async (_ctx, args) => {\n const result = await callNeo4jQuery(\n \"proprietarySignals\",\n withTopicScope(args, {\n limit: toInt(args.limit, 30),\n }),\n args.apiBaseUrl\n );\n\n if (!result.success) {\n return { results: [], error: result.error };\n }\n\n return { results: result.data || [] };\n },\n});\n\n/**\n * Get portfolio conviction dashboard - aggregate conviction metrics across all themes.\n */\nexport const getPortfolioConviction = action({\n args: {\n limit: v.optional(v.number()),\n apiBaseUrl: v.optional(v.string()),\n topicId: v.optional(v.string()),},\n returns: permissiveReturn,\n handler: async (_ctx, args) => {\n const result = await callNeo4jQuery(\n \"portfolioConviction\",\n withTopicScope(args, {\n limit: toInt(args.limit, 50),\n }),\n args.apiBaseUrl\n );\n\n if (!result.success) {\n return { portfolio: [], error: result.error };\n }\n\n return { portfolio: result.data || [] };\n },\n});\n\n/**\n * Get stale themes - themes with no recent activity.\n */\nexport const getStaleThemes = action({\n args: {\n limit: v.optional(v.number()),\n apiBaseUrl: v.optional(v.string()),\n topicId: v.optional(v.string()),},\n returns: permissiveReturn,\n handler: async (_ctx, args) => {\n const result = await callNeo4jQuery(\n \"staleThemes\",\n withTopicScope(args, {\n limit: toInt(args.limit, 30),\n }),\n args.apiBaseUrl\n );\n\n if (!result.success) {\n return { themes: [], error: result.error };\n }\n\n return { themes: result.data || [] };\n },\n});\n\n/**\n * Get missing question detection - high-confidence beliefs with no testing questions.\n */\nexport const getMissingQuestionDetection = action({\n args: {\n limit: v.optional(v.number()),\n apiBaseUrl: v.optional(v.string()),\n topicId: v.optional(v.string()),},\n returns: permissiveReturn,\n handler: async (_ctx, args) => {\n const result = await callNeo4jQuery(\n \"missingQuestionDetection\",\n withTopicScope(args, {\n limit: toInt(args.limit, 30),\n }),\n args.apiBaseUrl\n );\n\n if (!result.success) {\n return { results: [], error: result.error };\n }\n\n return { results: result.data || [] };\n },\n});\n\n/**\n * Get surprise detection - evidence that surprised us (high surprise score).\n */\nexport const getSurpriseDetection = action({\n args: {\n limit: v.optional(v.number()),\n apiBaseUrl: v.optional(v.string()),\n topicId: v.optional(v.string()),},\n returns: permissiveReturn,\n handler: async (_ctx, args) => {\n const result = await callNeo4jQuery(\n \"surpriseDetection\",\n withTopicScope(args, {\n limit: toInt(args.limit, 30),\n }),\n args.apiBaseUrl\n );\n\n if (!result.success) {\n return { results: [], error: result.error };\n }\n\n return { results: result.data || [] };\n },\n});\n\n/**\n * Get non-consensus beliefs - beliefs where we diverge from market consensus.\n */\nexport const getNonConsensusBeliefs = action({\n args: {\n limit: v.optional(v.number()),\n apiBaseUrl: v.optional(v.string()),\n topicId: v.optional(v.string()),},\n returns: permissiveReturn,\n handler: async (_ctx, args) => {\n const result = await callNeo4jQuery(\n \"nonConsensusBeliefs\",\n withTopicScope(args, {\n limit: toInt(args.limit, 30),\n }),\n args.apiBaseUrl\n );\n\n if (!result.success) {\n return { results: [], error: result.error };\n }\n\n return { results: result.data || [] };\n },\n});\n\n// =============================================================================\n// HYBRID SEMANTIC + STRUCTURAL QUERIES (Neo4j Vector Indexes)\n// =============================================================================\n\n/** Expected embedding dimensions (llama-text-embed-v2). */\nconst EMBEDDING_DIMENSIONS = 1024;\n\n/** Valid Neo4j vector index names. */\nconst VALID_INDEX_NAMES = new Set([\n \"belief_embedding_index\",\n \"question_embedding_index\",\n \"evidence_embedding_index\",\n \"theme_embedding_index\",\n \"source_embedding_index\",\n \"synthesis_embedding_index\",\n]);\n\n/** Clamp a number to [min, max]. */\nfunction clamp(value: number, min: number, max: number): number {\n return Math.max(min, Math.min(max, value));\n}\n\n/**\n * Semantic search with graph context — find nodes by embedding similarity\n * and return their graph neighborhood for context.\n */\nexport const semanticSearch = action({\n args: {\n embedding: v.array(v.float64()),\n indexName: v.optional(v.string()),\n topK: v.optional(v.number()),\n minScore: v.optional(v.number()),\n apiBaseUrl: v.optional(v.string()),\n topicId: v.optional(v.string()),},\n returns: permissiveReturn,\n handler: async (_ctx, args) => {\n // SECURITY: Validate embedding dimensions\n if (args.embedding.length !== EMBEDDING_DIMENSIONS) {\n return {\n results: [],\n error: `Embedding must be ${EMBEDDING_DIMENSIONS} dimensions, got ${args.embedding.length}`,\n };\n }\n\n // SECURITY: Validate index name against known set\n const indexName = args.indexName || \"belief_embedding_index\";\n if (!VALID_INDEX_NAMES.has(indexName)) {\n return { results: [], error: `Invalid index name: ${indexName}` };\n }\n\n const result = await callNeo4jQuery(\n \"semanticSearch\",\n {\n embedding: args.embedding,\n indexName,\n topK: toInt(args.topK, 10),\n minScore: clamp(args.minScore ?? 0.5, 0, 1),\n },\n args.apiBaseUrl\n );\n\n if (!result.success) {\n return { results: [], error: result.error };\n }\n\n return { results: result.data || [] };\n },\n});\n\n/**\n * Find semantic orphans — nodes structurally connected but semantically\n * distant from their graph neighbors.\n */\nexport const getSemanticOrphans = action({\n args: {\n threshold: v.optional(v.number()),\n limit: v.optional(v.number()),\n apiBaseUrl: v.optional(v.string()),\n topicId: v.optional(v.string()),},\n returns: permissiveReturn,\n handler: async (_ctx, args) => {\n const result = await callNeo4jQuery(\n \"semanticOrphans\",\n withTopicScope(args, {\n threshold: clamp(args.threshold ?? 0.4, 0, 1),\n limit: toInt(args.limit, 20),\n }),\n args.apiBaseUrl\n );\n\n if (!result.success) {\n return { results: [], error: result.error };\n }\n\n return { results: result.data || [] };\n },\n});\n\n/**\n * Find soft contradictions — beliefs about the same topic (high embedding similarity)\n * but with divergent evidence or confidence.\n */\nexport const getSoftContradictions = action({\n args: {\n similarityThreshold: v.optional(v.number()),\n limit: v.optional(v.number()),\n apiBaseUrl: v.optional(v.string()),\n topicId: v.optional(v.string()),},\n returns: permissiveReturn,\n handler: async (_ctx, args) => {\n const result = await callNeo4jQuery(\n \"softContradictions\",\n withTopicScope(args, {\n similarityThreshold: clamp(args.similarityThreshold ?? 0.7, 0, 1),\n limit: toInt(args.limit, 20),\n }),\n args.apiBaseUrl\n );\n\n if (!result.success) {\n return { results: [], error: result.error };\n }\n\n return { results: result.data || [] };\n },\n});\n\n/**\n * Find semantic bridges — nodes semantically similar but graph-distant.\n * These represent potential missing connections.\n */\nexport const getSemanticBridges = action({\n args: {\n similarityThreshold: v.optional(v.number()),\n limit: v.optional(v.number()),\n apiBaseUrl: v.optional(v.string()),\n topicId: v.optional(v.string()),},\n returns: permissiveReturn,\n handler: async (_ctx, args) => {\n const result = await callNeo4jQuery(\n \"semanticBridges\",\n withTopicScope(args, {\n similarityThreshold: clamp(args.similarityThreshold ?? 0.7, 0, 1),\n limit: toInt(args.limit, 20),\n }),\n args.apiBaseUrl\n );\n\n if (!result.success) {\n return { results: [], error: result.error };\n }\n\n return { results: result.data || [] };\n },\n});\n\n/**\n * Graph-aware RAG search — semantic search that expands along graph structure\n * to pull in supporting context (evidence, themes, sources).\n */\nexport const graphAwareSearch = action({\n args: {\n embedding: v.array(v.float64()),\n indexName: v.optional(v.string()),\n topK: v.optional(v.number()),\n minScore: v.optional(v.number()),\n apiBaseUrl: v.optional(v.string()),\n topicId: v.optional(v.string()),},\n returns: permissiveReturn,\n handler: async (_ctx, args) => {\n // SECURITY: Validate embedding dimensions\n if (args.embedding.length !== EMBEDDING_DIMENSIONS) {\n return {\n results: [],\n error: `Embedding must be ${EMBEDDING_DIMENSIONS} dimensions, got ${args.embedding.length}`,\n };\n }\n\n // SECURITY: Validate index name against known set\n const indexName = args.indexName || \"belief_embedding_index\";\n if (!VALID_INDEX_NAMES.has(indexName)) {\n return { results: [], error: `Invalid index name: ${indexName}` };\n }\n\n const result = await callNeo4jQuery(\n \"graphAwareSearch\",\n withTopicScope(args, {\n embedding: args.embedding,\n indexName,\n topK: toInt(args.topK, 10),\n minScore: clamp(args.minScore ?? 0.5, 0, 1),\n }),\n args.apiBaseUrl\n );\n\n if (!result.success) {\n return { results: [], error: result.error };\n }\n\n return { results: result.data || [] };\n },\n});\n"]}
@@ -0,0 +1,20 @@
1
+ /**
2
+ * Vercel/Next route helper for the Neo4j query proxy.
3
+ *
4
+ * The helper accepts named Cypher only. It never accepts raw Cypher from a
5
+ * request body, which keeps tenant routes small without opening an injection
6
+ * surface.
7
+ */
8
+ type Neo4jNamedQuery = Readonly<{
9
+ cypher: string;
10
+ timeoutMs?: number;
11
+ }>;
12
+ type Neo4jQueryRegistry = Readonly<Record<string, Neo4jNamedQuery>>;
13
+ type Neo4jQueryRouteOptions = Readonly<{
14
+ queries: Neo4jQueryRegistry;
15
+ syncSecret?: string;
16
+ requireTenantContext?: boolean;
17
+ }>;
18
+ declare function createNeo4jQueryRouteHandler(options: Neo4jQueryRouteOptions): (request: Request) => Promise<Response>;
19
+
20
+ export { type Neo4jNamedQuery, type Neo4jQueryRegistry, type Neo4jQueryRouteOptions, createNeo4jQueryRouteHandler };
@@ -0,0 +1,187 @@
1
+ "use node";
2
+ import neo4j from 'neo4j-driver';
3
+
4
+ var driver = null;
5
+ function getDriver() {
6
+ if (!driver) {
7
+ const uri = process.env.NEO4J_URI;
8
+ const user = process.env.NEO4J_USER;
9
+ const password = process.env.NEO4J_PASSWORD;
10
+ if (!uri || !user || !password) {
11
+ throw new Error(
12
+ "[Neo4j Driver] Missing credentials. Set NEO4J_URI, NEO4J_USER, NEO4J_PASSWORD via `npx convex env set`"
13
+ );
14
+ }
15
+ driver = neo4j.driver(uri, neo4j.auth.basic(user, password), {
16
+ // Connection pool settings
17
+ maxConnectionPoolSize: 50,
18
+ connectionAcquisitionTimeout: 3e4,
19
+ // Logging
20
+ logging: {
21
+ level: "warn",
22
+ logger: (level, message) => console.log(`[Neo4j ${level}] ${message}`)
23
+ }
24
+ });
25
+ }
26
+ return driver;
27
+ }
28
+ var DEFAULT_QUERY_TIMEOUT_MS = 3e4;
29
+ function toNeo4jParams(params) {
30
+ const result = {};
31
+ for (const [key, value] of Object.entries(params)) {
32
+ if (typeof value === "number" && Number.isInteger(value)) {
33
+ result[key] = neo4j.int(value);
34
+ } else if (Array.isArray(value)) {
35
+ result[key] = value.map(
36
+ (v) => typeof v === "number" && Number.isInteger(v) ? neo4j.int(v) : v
37
+ );
38
+ } else {
39
+ result[key] = value;
40
+ }
41
+ }
42
+ return result;
43
+ }
44
+ async function runCypher(query, params = {}, timeoutMs = DEFAULT_QUERY_TIMEOUT_MS) {
45
+ const neo4jDriver = getDriver();
46
+ const session = neo4jDriver.session();
47
+ try {
48
+ const neo4jParams = toNeo4jParams(params);
49
+ const result = await session.run(query, neo4jParams, {
50
+ timeout: neo4j.int(timeoutMs)
51
+ });
52
+ return result.records.map((record) => {
53
+ const obj = {};
54
+ for (const key of record.keys) {
55
+ const field = String(key);
56
+ obj[field] = convertNeo4jValue(record.get(field));
57
+ }
58
+ return obj;
59
+ });
60
+ } finally {
61
+ await session.close();
62
+ }
63
+ }
64
+ function convertNeo4jValue(value) {
65
+ if (value === null || value === void 0) {
66
+ return null;
67
+ }
68
+ if (neo4j.isInt(value)) {
69
+ return neo4j.integer.toNumber(value);
70
+ }
71
+ if (neo4j.isDate(value) || neo4j.isDateTime(value) || neo4j.isTime(value)) {
72
+ return value.toString();
73
+ }
74
+ if (Array.isArray(value)) {
75
+ return value.map(convertNeo4jValue);
76
+ }
77
+ if (value && typeof value === "object" && "properties" in value) {
78
+ const nodeObj = value;
79
+ const result = {};
80
+ for (const [k, v] of Object.entries(nodeObj.properties)) {
81
+ result[k] = convertNeo4jValue(v);
82
+ }
83
+ return result;
84
+ }
85
+ if (typeof value === "object") {
86
+ const result = {};
87
+ for (const [k, v] of Object.entries(value)) {
88
+ result[k] = convertNeo4jValue(v);
89
+ }
90
+ return result;
91
+ }
92
+ return value;
93
+ }
94
+
95
+ // src/neo4jQueryRoute.ts
96
+ function jsonResponse(body, init) {
97
+ return new Response(JSON.stringify(body), {
98
+ ...init,
99
+ headers: {
100
+ "Content-Type": "application/json",
101
+ ...init?.headers
102
+ }
103
+ });
104
+ }
105
+ function readBearerSecret(request) {
106
+ const authorization = request.headers.get("authorization") ?? "";
107
+ const match = authorization.match(/^Bearer\s+(.+)$/iu);
108
+ return match?.[1]?.trim() || null;
109
+ }
110
+ function hasTenantContext(params) {
111
+ const tenantId = params.tenantId;
112
+ const topicId = params.topicId;
113
+ const projectId = params.projectId;
114
+ return [tenantId, topicId, projectId].some(
115
+ (value) => typeof value === "string" && value.trim().length > 0
116
+ );
117
+ }
118
+ function normalizeConnectedNodesQuery(queryName, params, queries) {
119
+ if (queryName !== "connectedNodes") {
120
+ return queryName;
121
+ }
122
+ const hops = typeof params.maxHops === "number" && Number.isFinite(params.maxHops) ? Math.min(Math.max(Math.floor(params.maxHops), 1), 5) : 2;
123
+ const aliased = `connectedNodes${hops}`;
124
+ return queries[aliased] ? aliased : queryName;
125
+ }
126
+ function createNeo4jQueryRouteHandler(options) {
127
+ return async function handleNeo4jQuery(request) {
128
+ const expectedSecret = options.syncSecret ?? process.env.NEO4J_SYNC_SECRET?.trim();
129
+ if (!expectedSecret) {
130
+ return jsonResponse(
131
+ { error: "Neo4j sync secret not configured" },
132
+ { status: 500 }
133
+ );
134
+ }
135
+ if (readBearerSecret(request) !== expectedSecret) {
136
+ return jsonResponse({ error: "Unauthorized" }, { status: 401 });
137
+ }
138
+ let body;
139
+ try {
140
+ body = await request.json();
141
+ } catch {
142
+ return jsonResponse({ error: "Invalid JSON body" }, { status: 400 });
143
+ }
144
+ if (typeof body.queryName !== "string" || body.queryName.length === 0) {
145
+ return jsonResponse({ error: "Missing queryName" }, { status: 400 });
146
+ }
147
+ const params = body.params && typeof body.params === "object" && !Array.isArray(body.params) ? body.params : {};
148
+ if ((options.requireTenantContext ?? true) && !hasTenantContext(params)) {
149
+ return jsonResponse(
150
+ { error: "Missing required tenant context" },
151
+ { status: 400 }
152
+ );
153
+ }
154
+ const queryName = normalizeConnectedNodesQuery(
155
+ body.queryName,
156
+ params,
157
+ options.queries
158
+ );
159
+ const query = options.queries[queryName];
160
+ if (!query) {
161
+ return jsonResponse(
162
+ { error: `Unknown query: ${body.queryName}` },
163
+ { status: 400 }
164
+ );
165
+ }
166
+ try {
167
+ const data = await runCypher(
168
+ query.cypher,
169
+ params,
170
+ query.timeoutMs ?? DEFAULT_QUERY_TIMEOUT_MS
171
+ );
172
+ return jsonResponse({ data, queryName });
173
+ } catch (error) {
174
+ return jsonResponse(
175
+ {
176
+ error: error instanceof Error ? error.message : "Neo4j query failed",
177
+ queryName
178
+ },
179
+ { status: 500 }
180
+ );
181
+ }
182
+ };
183
+ }
184
+
185
+ export { createNeo4jQueryRouteHandler };
186
+ //# sourceMappingURL=neo4jQueryRoute.js.map
187
+ //# sourceMappingURL=neo4jQueryRoute.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"sources":["../src/neo4jDriver.ts","../src/neo4jQueryRoute.ts"],"names":[],"mappings":"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","file":"neo4jQueryRoute.js","sourcesContent":["/**\n * neo4jDriver module implementation.\n */\n\n\"use node\";\n/**\n * Direct Neo4j Driver for Convex\n *\n * Uses the \"use node\" directive to enable Node.js runtime, allowing\n * direct use of the neo4j-driver package instead of HTTP proxies.\n *\n * Environment Variables (set per deployment via `npx convex env set`):\n * - NEO4J_URI: neo4j+s://xxx.databases.neo4j.io\n * - NEO4J_USER: neo4j\n * - NEO4J_PASSWORD: your-password\n *\n * @see /docs/architecture/UNIFIED_GRAPH_ARCHITECTURE.md\n */\n\nimport neo4j, { type Driver } from \"neo4j-driver\";\n\n// =============================================================================\n// VALID LABELS AND RELATIONSHIP TYPES (Security: Prevent Cypher Injection)\n// =============================================================================\n\nconst VALID_NODE_LABELS = new Set([\n // Ontological\n \"ValueChain\",\n \"Function\",\n \"FinSector\",\n \"Company\",\n \"Person\",\n \"Investor\",\n // Epistemic\n \"Theme\",\n \"Belief\",\n \"Question\",\n \"Evidence\",\n \"Source\",\n \"Decision\",\n \"Sprint\",\n \"Claim\",\n \"Synthesis\",\n \"Answer\",\n]);\n\nconst VALID_RELATIONSHIP_TYPES = new Set([\n // Cross-layer edges\n \"EXTRACTED_FROM\",\n \"ANSWERS\",\n \"RESPONDS_TO\",\n \"INFORMS\",\n \"QUALIFIES\",\n \"TESTS\",\n \"EXPLORES\",\n \"BASED_ON\",\n \"RELATES_TO_THESIS\",\n \"BELONGS_TO\",\n \"PLAYS_THEME\",\n // Same-layer edges\n \"SUPERSEDES\",\n \"SAME_AS\",\n \"DEPENDS_ON\",\n \"REINFORCES\",\n \"PARENT_OF\",\n \"CHILD_OF\",\n \"FALSIFIED_BY\",\n \"EXCLUSIVE_WITH\",\n \"COLLAPSES_IF\",\n \"CASCADE_FROM\",\n \"STRENGTHENED_BY\",\n \"WEAKENED_BY\",\n \"ALTERNATIVE_TO\",\n \"SUBSUMES\",\n \"VALIDATED_BY\",\n \"REQUIRED_FOR\",\n \"PREREQUISITE_FOR\",\n \"PARALLEL_TO\",\n \"CORROBORATES\",\n \"EXTENDS\",\n \"SAME_SOURCE_AS\",\n \"SAME_THEME_AS\",\n // Ontological\n \"EVALUATES\",\n \"PERSPECTIVE_ON\",\n \"WORKS_AT\",\n \"PARTICIPATES_IN\",\n \"PERFORMS\",\n \"FUNCTION_IN\",\n \"IMPACTS\",\n \"INVESTED_IN\",\n \"RAISED_FROM\",\n \"BASED_ON_BELIEF\",\n \"BASED_ON_QUESTION\",\n \"BLOCKED_BY_CONTRADICTION\",\n \"INFORMED_BY_THEME\",\n]);\n\nexport function validateLabel(label: string): void {\n if (!VALID_NODE_LABELS.has(label)) {\n throw new Error(\n `[Neo4j Security] Invalid node label: ${label}. Must be one of: ${Array.from(VALID_NODE_LABELS).join(\", \")}`\n );\n }\n}\n\nexport function validateRelType(relType: string): void {\n if (!VALID_RELATIONSHIP_TYPES.has(relType)) {\n throw new Error(\n `[Neo4j Security] Invalid relationship type: ${relType}. Must be one of: ${Array.from(VALID_RELATIONSHIP_TYPES).join(\", \")}`\n );\n }\n}\n\n// =============================================================================\n// DRIVER SINGLETON\n// =============================================================================\n\nlet driver: Driver | null = null;\n\nfunction getDriver(): Driver {\n if (!driver) {\n const uri = process.env.NEO4J_URI;\n const user = process.env.NEO4J_USER;\n const password = process.env.NEO4J_PASSWORD;\n\n if (!uri || !user || !password) {\n throw new Error(\n \"[Neo4j Driver] Missing credentials. Set NEO4J_URI, NEO4J_USER, NEO4J_PASSWORD via `npx convex env set`\"\n );\n }\n\n driver = neo4j.driver(uri, neo4j.auth.basic(user, password), {\n // Connection pool settings\n maxConnectionPoolSize: 50,\n connectionAcquisitionTimeout: 30_000,\n // Logging\n logging: {\n level: \"warn\",\n logger: (level, message) => console.log(`[Neo4j ${level}] ${message}`),\n },\n });\n }\n return driver;\n}\n\n// =============================================================================\n// QUERY CONFIGURATION\n// =============================================================================\n\n/**\n * Default query timeout in milliseconds.\n * Prevents expensive graph traversals from hanging indefinitely.\n */\nexport const DEFAULT_QUERY_TIMEOUT_MS = 30_000; // 30 seconds\n\n/**\n * Timeout for complex graph queries (cascade simulation, lineage traversal)\n */\nexport const COMPLEX_QUERY_TIMEOUT_MS = 60_000; // 60 seconds\n\n// =============================================================================\n// QUERY EXECUTION\n// =============================================================================\n\n/**\n * Convert JavaScript values to Neo4j-compatible types\n * Neo4j requires explicit integers, not floats\n */\nfunction toNeo4jParams(\n params: Record<string, unknown>\n): Record<string, unknown> {\n const result: Record<string, unknown> = {};\n for (const [key, value] of Object.entries(params)) {\n if (typeof value === \"number\" && Number.isInteger(value)) {\n // Convert JavaScript integers to Neo4j integers\n result[key] = neo4j.int(value);\n } else if (Array.isArray(value)) {\n result[key] = value.map((v) =>\n typeof v === \"number\" && Number.isInteger(v) ? neo4j.int(v) : v\n );\n } else {\n result[key] = value;\n }\n }\n return result;\n}\n\n/**\n * Execute a Cypher query and return results as typed objects\n *\n * @param query - Cypher query string\n * @param params - Query parameters\n * @param timeoutMs - Query timeout in milliseconds (default: 30s)\n */\nexport async function runCypher<T = Record<string, unknown>>(\n query: string,\n params: Record<string, unknown> = {},\n timeoutMs: number = DEFAULT_QUERY_TIMEOUT_MS\n): Promise<T[]> {\n const neo4jDriver = getDriver();\n const session = neo4jDriver.session();\n\n try {\n const neo4jParams = toNeo4jParams(params);\n const result = await session.run(query, neo4jParams, {\n timeout: neo4j.int(timeoutMs),\n });\n return result.records.map((record) => {\n const obj: Record<string, unknown> = {};\n for (const key of record.keys) {\n const field = String(key);\n obj[field] = convertNeo4jValue(record.get(field));\n }\n return obj as T;\n });\n } finally {\n await session.close();\n }\n}\n\n/**\n * Execute a write transaction (for mutations)\n *\n * @param query - Cypher query string\n * @param params - Query parameters\n * @param timeoutMs - Transaction timeout in milliseconds (default: 30s)\n */\nexport async function runWriteTransaction<T = Record<string, unknown>>(\n query: string,\n params: Record<string, unknown> = {},\n timeoutMs: number = DEFAULT_QUERY_TIMEOUT_MS\n): Promise<T[]> {\n const neo4jDriver = getDriver();\n const session = neo4jDriver.session();\n\n try {\n const neo4jParams = toNeo4jParams(params);\n const result = await session.executeWrite(\n async (tx) => {\n return await tx.run(query, neo4jParams);\n },\n { timeout: timeoutMs }\n );\n return result.records.map((record) => {\n const obj: Record<string, unknown> = {};\n for (const key of record.keys) {\n const field = String(key);\n obj[field] = convertNeo4jValue(record.get(field));\n }\n return obj as T;\n });\n } finally {\n await session.close();\n }\n}\n\n/**\n * Execute multiple queries in a single transaction\n *\n * @param queries - Array of queries with parameters\n * @param timeoutMs - Transaction timeout in milliseconds (default: 60s for batch)\n */\nexport async function runBatchTransaction(\n queries: Array<{ query: string; params: Record<string, unknown> }>,\n timeoutMs: number = COMPLEX_QUERY_TIMEOUT_MS\n): Promise<void> {\n const neo4jDriver = getDriver();\n const session = neo4jDriver.session();\n\n try {\n await session.executeWrite(\n async (tx) => {\n for (const { query, params } of queries) {\n await tx.run(query, params);\n }\n },\n { timeout: timeoutMs }\n );\n } finally {\n await session.close();\n }\n}\n\n// =============================================================================\n// NODE OPERATIONS\n// =============================================================================\n\n/**\n * Upsert a node by globalId\n */\nexport async function upsertNode(\n label: string,\n globalId: string,\n properties: Record<string, unknown>\n): Promise<void> {\n validateLabel(label); // Security: prevent Cypher injection\n await runWriteTransaction(\n `\n MERGE (n:${label} {globalId: $globalId})\n SET n += $properties\n SET n.updatedAt = timestamp()\n `,\n { globalId, properties }\n );\n}\n\n/**\n * Delete a node by globalId\n */\nexport async function deleteNode(globalId: string): Promise<void> {\n await runWriteTransaction(\n `\n MATCH (n {globalId: $globalId})\n DETACH DELETE n\n `,\n { globalId }\n );\n}\n\n/**\n * Batch upsert nodes\n */\nexport async function batchUpsertNodes(\n label: string,\n nodes: Array<{ globalId: string; properties: Record<string, unknown> }>\n): Promise<void> {\n if (nodes.length === 0) {\n return;\n }\n\n validateLabel(label); // Security: prevent Cypher injection\n await runWriteTransaction(\n `\n UNWIND $nodes as node\n MERGE (n:${label} {globalId: node.globalId})\n SET n += node.properties\n SET n.updatedAt = timestamp()\n `,\n { nodes }\n );\n}\n\n// =============================================================================\n// EDGE OPERATIONS\n// =============================================================================\n\n/**\n * Upsert an edge by globalId\n */\nexport async function upsertEdge(\n relType: string,\n globalId: string,\n fromGlobalId: string,\n toGlobalId: string,\n properties: Record<string, unknown> = {}\n): Promise<void> {\n validateRelType(relType); // Security: prevent Cypher injection\n await runWriteTransaction(\n `\n MATCH (from {globalId: $fromGlobalId})\n MATCH (to {globalId: $toGlobalId})\n MERGE (from)-[r:${relType} {globalId: $globalId}]->(to)\n SET r += $properties\n SET r.updatedAt = timestamp()\n `,\n { globalId, fromGlobalId, toGlobalId, properties }\n );\n}\n\n/**\n * Delete an edge by globalId\n */\nexport async function deleteEdge(globalId: string): Promise<void> {\n await runWriteTransaction(\n `\n MATCH ()-[r {globalId: $globalId}]->()\n DELETE r\n `,\n { globalId }\n );\n}\n\n/**\n * Batch upsert edges\n */\nexport async function batchUpsertEdges(\n edges: Array<{\n relType: string;\n globalId: string;\n fromGlobalId: string;\n toGlobalId: string;\n properties?: Record<string, unknown>;\n }>\n): Promise<void> {\n if (edges.length === 0) {\n return;\n }\n\n // Group by relationship type for efficient batching\n const byType = new Map<string, typeof edges>();\n for (const edge of edges) {\n const existing = byType.get(edge.relType) || [];\n existing.push(edge);\n byType.set(edge.relType, existing);\n }\n\n const queries: Array<{ query: string; params: Record<string, unknown> }> = [];\n for (const [relType, typeEdges] of byType) {\n queries.push({\n query: `\n UNWIND $edges as edge\n MATCH (from {globalId: edge.fromGlobalId})\n MATCH (to {globalId: edge.toGlobalId})\n MERGE (from)-[r:${relType} {globalId: edge.globalId}]->(to)\n SET r += edge.properties\n SET r.updatedAt = timestamp()\n `,\n params: {\n edges: typeEdges.map((e) => ({\n globalId: e.globalId,\n fromGlobalId: e.fromGlobalId,\n toGlobalId: e.toGlobalId,\n properties: e.properties || {},\n })),\n },\n });\n }\n\n await runBatchTransaction(queries);\n}\n\n// =============================================================================\n// HEALTH CHECK\n// =============================================================================\n\n/**\n * Check if Neo4j connection is healthy\n */\nexport async function healthCheck(): Promise<{\n healthy: boolean;\n nodeCount?: number;\n error?: string;\n}> {\n try {\n const result = await runCypher<{ count: number }>(\n \"MATCH (n) RETURN count(n) as count LIMIT 1\"\n );\n return {\n healthy: true,\n nodeCount: result[0]?.count || 0,\n };\n } catch (error) {\n return {\n healthy: false,\n error: error instanceof Error ? error.message : \"Unknown error\",\n };\n }\n}\n\n/**\n * Get connection info (for debugging)\n */\nexport function getConnectionInfo(): {\n uri: string | undefined;\n user: string | undefined;\n configured: boolean;\n} {\n return {\n uri: process.env.NEO4J_URI,\n user: process.env.NEO4J_USER,\n configured: Boolean(\n process.env.NEO4J_URI &&\n process.env.NEO4J_USER &&\n process.env.NEO4J_PASSWORD\n ),\n };\n}\n\n// =============================================================================\n// VALUE CONVERSION\n// =============================================================================\n\n/**\n * Convert Neo4j types to plain JavaScript\n */\nfunction convertNeo4jValue(value: unknown): unknown {\n if (value === null || value === undefined) {\n return null;\n }\n\n // Handle Neo4j Integer\n if (neo4j.isInt(value)) {\n return neo4j.integer.toNumber(value);\n }\n\n // Handle Neo4j Date/Time types\n if (neo4j.isDate(value) || neo4j.isDateTime(value) || neo4j.isTime(value)) {\n return value.toString();\n }\n\n // Handle arrays\n if (Array.isArray(value)) {\n return value.map(convertNeo4jValue);\n }\n\n // Handle Node objects\n if (value && typeof value === \"object\" && \"properties\" in value) {\n const nodeObj = value as { properties: Record<string, unknown> };\n const result: Record<string, unknown> = {};\n for (const [k, v] of Object.entries(nodeObj.properties)) {\n result[k] = convertNeo4jValue(v);\n }\n return result;\n }\n\n // Handle plain objects\n if (typeof value === \"object\") {\n const result: Record<string, unknown> = {};\n for (const [k, v] of Object.entries(value as Record<string, unknown>)) {\n result[k] = convertNeo4jValue(v);\n }\n return result;\n }\n\n return value;\n}\n\n// =============================================================================\n// CLEANUP\n// =============================================================================\n\n/**\n * Close the driver connection (for graceful shutdown)\n */\nexport async function closeDriver(): Promise<void> {\n if (driver) {\n await driver.close();\n driver = null;\n }\n}\n","/**\n * Vercel/Next route helper for the Neo4j query proxy.\n *\n * The helper accepts named Cypher only. It never accepts raw Cypher from a\n * request body, which keeps tenant routes small without opening an injection\n * surface.\n */\n\n\"use node\";\n\nimport { runCypher, DEFAULT_QUERY_TIMEOUT_MS } from \"./neo4jDriver\";\n\nexport type Neo4jNamedQuery = Readonly<{\n cypher: string;\n timeoutMs?: number;\n}>;\n\nexport type Neo4jQueryRegistry = Readonly<Record<string, Neo4jNamedQuery>>;\n\nexport type Neo4jQueryRouteOptions = Readonly<{\n queries: Neo4jQueryRegistry;\n syncSecret?: string;\n requireTenantContext?: boolean;\n}>;\n\ntype Neo4jQueryRequestBody = Readonly<{\n queryName?: unknown;\n params?: unknown;\n}>;\n\nfunction jsonResponse(body: unknown, init?: ResponseInit): Response {\n return new Response(JSON.stringify(body), {\n ...init,\n headers: {\n \"Content-Type\": \"application/json\",\n ...init?.headers,\n },\n });\n}\n\nfunction readBearerSecret(request: Request): string | null {\n const authorization = request.headers.get(\"authorization\") ?? \"\";\n const match = authorization.match(/^Bearer\\s+(.+)$/iu);\n return match?.[1]?.trim() || null;\n}\n\nfunction hasTenantContext(params: Record<string, unknown>): boolean {\n const tenantId = params.tenantId;\n const topicId = params.topicId;\n const projectId = params.projectId;\n return [tenantId, topicId, projectId].some(\n (value) => typeof value === \"string\" && value.trim().length > 0\n );\n}\n\nfunction normalizeConnectedNodesQuery(\n queryName: string,\n params: Record<string, unknown>,\n queries: Neo4jQueryRegistry\n): string {\n if (queryName !== \"connectedNodes\") {\n return queryName;\n }\n\n const hops =\n typeof params.maxHops === \"number\" && Number.isFinite(params.maxHops)\n ? Math.min(Math.max(Math.floor(params.maxHops), 1), 5)\n : 2;\n const aliased = `connectedNodes${hops}`;\n return queries[aliased] ? aliased : queryName;\n}\n\nexport function createNeo4jQueryRouteHandler(\n options: Neo4jQueryRouteOptions\n): (request: Request) => Promise<Response> {\n return async function handleNeo4jQuery(request: Request): Promise<Response> {\n const expectedSecret =\n options.syncSecret ?? process.env.NEO4J_SYNC_SECRET?.trim();\n if (!expectedSecret) {\n return jsonResponse(\n { error: \"Neo4j sync secret not configured\" },\n { status: 500 }\n );\n }\n\n if (readBearerSecret(request) !== expectedSecret) {\n return jsonResponse({ error: \"Unauthorized\" }, { status: 401 });\n }\n\n let body: Neo4jQueryRequestBody;\n try {\n body = (await request.json()) as Neo4jQueryRequestBody;\n } catch {\n return jsonResponse({ error: \"Invalid JSON body\" }, { status: 400 });\n }\n\n if (typeof body.queryName !== \"string\" || body.queryName.length === 0) {\n return jsonResponse({ error: \"Missing queryName\" }, { status: 400 });\n }\n\n const params =\n body.params && typeof body.params === \"object\" && !Array.isArray(body.params)\n ? (body.params as Record<string, unknown>)\n : {};\n if ((options.requireTenantContext ?? true) && !hasTenantContext(params)) {\n return jsonResponse(\n { error: \"Missing required tenant context\" },\n { status: 400 }\n );\n }\n\n const queryName = normalizeConnectedNodesQuery(\n body.queryName,\n params,\n options.queries\n );\n const query = options.queries[queryName];\n if (!query) {\n return jsonResponse(\n { error: `Unknown query: ${body.queryName}` },\n { status: 400 }\n );\n }\n\n try {\n const data = await runCypher(\n query.cypher,\n params,\n query.timeoutMs ?? DEFAULT_QUERY_TIMEOUT_MS\n );\n return jsonResponse({ data, queryName });\n } catch (error) {\n return jsonResponse(\n {\n error: error instanceof Error ? error.message : \"Neo4j query failed\",\n queryName,\n },\n { status: 500 }\n );\n }\n };\n}\n"]}
@@ -0,0 +1,29 @@
1
+ /**
2
+ * neo4jSync module implementation.
3
+ */
4
+ declare const syncNodeToNeo4j: any;
5
+ declare const syncEdgeToNeo4j: any;
6
+ declare const syncAllNodesToNeo4j: any;
7
+ declare const syncAllEdgesToNeo4j: any;
8
+ declare const backfillAllToNeo4j: any;
9
+ declare const processRetryQueue: any;
10
+ /**
11
+ * Sync an embedding vector to an existing Neo4j node.
12
+ * Called after saveEpistemicNodeEmbedding completes, ensuring the
13
+ * embedding reaches Neo4j even if the initial node sync ran before
14
+ * the embedding was generated.
15
+ */
16
+ declare const syncEmbeddingToNeo4j: any;
17
+ declare const checkNeo4jHealth: any;
18
+ /**
19
+ * Re-sync all epistemic nodes to Neo4j with updated properties (paginated)
20
+ * Use after adding new fields to the sync
21
+ */
22
+ declare const resyncAllNodes: any;
23
+ /**
24
+ * Re-sync all epistemic edges to Neo4j with updated properties (paginated)
25
+ * Use after adding new fields to the sync (e.g., classification fields)
26
+ */
27
+ declare const resyncAllEdges: any;
28
+
29
+ export { backfillAllToNeo4j, checkNeo4jHealth, processRetryQueue, resyncAllEdges, resyncAllNodes, syncAllEdgesToNeo4j, syncAllNodesToNeo4j, syncEdgeToNeo4j, syncEmbeddingToNeo4j, syncNodeToNeo4j };