nexus-agents 2.77.12 → 2.78.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/dist/{child-mcp-config-MJMUF7TL.js → child-mcp-config-CTO2MBRM.js} +3 -4
- package/dist/{child-mcp-config-MJMUF7TL.js.map → child-mcp-config-CTO2MBRM.js.map} +1 -1
- package/dist/{chunk-YJ2IGAD2.js → chunk-2UYTFLMO.js} +2 -2
- package/dist/{chunk-6AY5DK4E.js → chunk-2YPG6PDG.js} +3 -3
- package/dist/{chunk-3VWMM6UF.js → chunk-3NIPH6UP.js} +2 -2
- package/dist/{chunk-L3TPDTP3.js → chunk-4N33QZLH.js} +13 -15
- package/dist/{chunk-L3TPDTP3.js.map → chunk-4N33QZLH.js.map} +1 -1
- package/dist/{chunk-JN6UWGHH.js → chunk-5O6XLBPP.js} +2 -2
- package/dist/{chunk-ERWXGXV2.js → chunk-6TFTVW77.js} +3 -3
- package/dist/{chunk-2IAWMNNB.js → chunk-6WBTNZAY.js} +183 -87
- package/dist/chunk-6WBTNZAY.js.map +1 -0
- package/dist/{chunk-GOT7OAL5.js → chunk-7BMOZJYS.js} +29 -5
- package/dist/chunk-7BMOZJYS.js.map +1 -0
- package/dist/{chunk-C2LLQ6TW.js → chunk-7XCUZI4G.js} +4 -4
- package/dist/chunk-7XCUZI4G.js.map +1 -0
- package/dist/{chunk-TDV5ALHY.js → chunk-D6TM2VHX.js} +3 -3
- package/dist/{chunk-PWTJGGKB.js → chunk-DLXT23AC.js} +2 -2
- package/dist/chunk-DNO2INX5.js +276 -0
- package/dist/chunk-DNO2INX5.js.map +1 -0
- package/dist/{chunk-G2CSKBY5.js → chunk-FJWWSVWB.js} +29 -6
- package/dist/chunk-FJWWSVWB.js.map +1 -0
- package/dist/{chunk-DSQ5XM4O.js → chunk-FVPYP5DD.js} +4 -4
- package/dist/{chunk-MGLWPN2I.js → chunk-GONMG4NM.js} +2 -2
- package/dist/{chunk-XYA3DPWJ.js → chunk-GTGDVBLW.js} +5 -5
- package/dist/{chunk-YQMQSJQK.js → chunk-HYU4GZY6.js} +2 -2
- package/dist/{chunk-3DH5SLFH.js → chunk-K2QILJG4.js} +6 -6
- package/dist/{chunk-5WHWKY32.js → chunk-KT5FIBWS.js} +2 -2
- package/dist/{chunk-DIB6V67T.js → chunk-L6SCKLGO.js} +3 -3
- package/dist/{chunk-IPWCD22D.js → chunk-PLX6FCFC.js} +2 -2
- package/dist/chunk-PQHVC4BD.js +639 -0
- package/dist/chunk-PQHVC4BD.js.map +1 -0
- package/dist/chunk-Q5CFPIJ5.js +5581 -0
- package/dist/chunk-Q5CFPIJ5.js.map +1 -0
- package/dist/{chunk-G6ZPVADX.js → chunk-SD76JZBG.js} +2 -2
- package/dist/{chunk-Y2CP4Z5B.js → chunk-SWFJU3W2.js} +220 -4580
- package/dist/chunk-SWFJU3W2.js.map +1 -0
- package/dist/{chunk-3MRM53T4.js → chunk-WDYCIJWN.js} +640 -470
- package/dist/chunk-WDYCIJWN.js.map +1 -0
- package/dist/{chunk-CM3TORGV.js → chunk-YXWGEIQR.js} +2 -2
- package/dist/{chunk-7NK7BTWP.js → chunk-ZVCED4Z4.js} +2 -2
- package/dist/cli-circuit-breaker-I74ZQ44Q.js +13 -0
- package/dist/cli.js +109 -58
- package/dist/cli.js.map +1 -1
- package/dist/{composite-router-S6E26BCI.js → composite-router-V3OC57IE.js} +3 -4
- package/dist/consensus-vote-ESFPGEJE.js +30 -0
- package/dist/context-retriever-MB3D7KS6.js +18 -0
- package/dist/dist-NIXVXYIH.js +42 -0
- package/dist/doctor-deep-KQ765XZA.js +12 -0
- package/dist/expert-bridge-JKLC57IC.js +10 -0
- package/dist/factory-BUUXNGIB.js +14 -0
- package/dist/{factory-X3VKIGKP.js → factory-LHHYDVZX.js} +5 -6
- package/dist/index.d.ts +72 -8
- package/dist/index.js +208 -316
- package/dist/index.js.map +1 -1
- package/dist/{init-opencode-CFE7M6XA.js → init-opencode-GXZN2W5S.js} +6 -7
- package/dist/{init-opencode-CFE7M6XA.js.map → init-opencode-GXZN2W5S.js.map} +1 -1
- package/dist/issue-triage-RMXPDZ2K.js +15 -0
- package/dist/{learning-persistence-N6ILD2HX.js → learning-persistence-Q3HTOGTU.js} +2 -3
- package/dist/outcome-store-adapter-QRFJJIKB.js +57 -0
- package/dist/outcome-store-adapter-QRFJJIKB.js.map +1 -0
- package/dist/{registry-command-RPPC7N2K.js → registry-command-6E4YKAMT.js} +3 -4
- package/dist/{registry-command-RPPC7N2K.js.map → registry-command-6E4YKAMT.js.map} +1 -1
- package/dist/{repo-security-plan-7ZCDVH5O.js → repo-security-plan-AGRU72DL.js} +4 -5
- package/dist/research-helpers-synthesize-K2UCJQQG.js +13 -0
- package/dist/{routing-memory-5VTX7LQX.js → routing-memory-3B6DDZ76.js} +3 -4
- package/dist/{session-memory-7XBV6BMY.js → session-memory-L7EQIY2O.js} +4 -5
- package/dist/{setup-command-3ZTEPKDA.js → setup-command-VYV4RFWW.js} +11 -12
- package/dist/setup-config-EQT24DD4.js +10 -0
- package/dist/{setup-custom-api-WM5W5AY5.js → setup-custom-api-IBDV654K.js} +5 -6
- package/dist/{setup-custom-api-WM5W5AY5.js.map → setup-custom-api-IBDV654K.js.map} +1 -1
- package/dist/tool-memory-6HCHQLAN.js +19 -0
- package/dist/{weather-report-YJMVKJGA.js → weather-report-ER3WUZ7S.js} +3 -4
- package/package.json +3 -2
- package/dist/adaptive-memory-EI564K4C.js +0 -16
- package/dist/chunk-2IAWMNNB.js.map +0 -1
- package/dist/chunk-3MRM53T4.js.map +0 -1
- package/dist/chunk-BJ2OMC7P.js +0 -944
- package/dist/chunk-BJ2OMC7P.js.map +0 -1
- package/dist/chunk-C2LLQ6TW.js.map +0 -1
- package/dist/chunk-G2CSKBY5.js.map +0 -1
- package/dist/chunk-GOT7OAL5.js.map +0 -1
- package/dist/chunk-I7ORMAO7.js +0 -32
- package/dist/chunk-I7ORMAO7.js.map +0 -1
- package/dist/chunk-Y2CP4Z5B.js.map +0 -1
- package/dist/cli-circuit-breaker-YX4BWZD5.js +0 -14
- package/dist/consensus-vote-MUQ4HPIF.js +0 -30
- package/dist/doctor-deep-BRU5ZUJI.js +0 -13
- package/dist/expert-bridge-ZPNVLJVN.js +0 -11
- package/dist/factory-A7DTCCUY.js +0 -15
- package/dist/issue-triage-6XD6CVPB.js +0 -16
- package/dist/mobimem-CG2MNS7V.js +0 -14
- package/dist/nexus-data-dir-77UO7N6J.js +0 -12
- package/dist/research-helpers-synthesize-36TUTUUA.js +0 -14
- package/dist/setup-config-EI5KROA3.js +0 -11
- /package/dist/{chunk-YJ2IGAD2.js.map → chunk-2UYTFLMO.js.map} +0 -0
- /package/dist/{chunk-6AY5DK4E.js.map → chunk-2YPG6PDG.js.map} +0 -0
- /package/dist/{chunk-3VWMM6UF.js.map → chunk-3NIPH6UP.js.map} +0 -0
- /package/dist/{chunk-JN6UWGHH.js.map → chunk-5O6XLBPP.js.map} +0 -0
- /package/dist/{chunk-ERWXGXV2.js.map → chunk-6TFTVW77.js.map} +0 -0
- /package/dist/{chunk-TDV5ALHY.js.map → chunk-D6TM2VHX.js.map} +0 -0
- /package/dist/{chunk-PWTJGGKB.js.map → chunk-DLXT23AC.js.map} +0 -0
- /package/dist/{chunk-DSQ5XM4O.js.map → chunk-FVPYP5DD.js.map} +0 -0
- /package/dist/{chunk-MGLWPN2I.js.map → chunk-GONMG4NM.js.map} +0 -0
- /package/dist/{chunk-XYA3DPWJ.js.map → chunk-GTGDVBLW.js.map} +0 -0
- /package/dist/{chunk-YQMQSJQK.js.map → chunk-HYU4GZY6.js.map} +0 -0
- /package/dist/{chunk-3DH5SLFH.js.map → chunk-K2QILJG4.js.map} +0 -0
- /package/dist/{chunk-5WHWKY32.js.map → chunk-KT5FIBWS.js.map} +0 -0
- /package/dist/{chunk-DIB6V67T.js.map → chunk-L6SCKLGO.js.map} +0 -0
- /package/dist/{chunk-IPWCD22D.js.map → chunk-PLX6FCFC.js.map} +0 -0
- /package/dist/{chunk-G6ZPVADX.js.map → chunk-SD76JZBG.js.map} +0 -0
- /package/dist/{chunk-CM3TORGV.js.map → chunk-YXWGEIQR.js.map} +0 -0
- /package/dist/{chunk-7NK7BTWP.js.map → chunk-ZVCED4Z4.js.map} +0 -0
- /package/dist/{adaptive-memory-EI564K4C.js.map → cli-circuit-breaker-I74ZQ44Q.js.map} +0 -0
- /package/dist/{cli-circuit-breaker-YX4BWZD5.js.map → composite-router-V3OC57IE.js.map} +0 -0
- /package/dist/{composite-router-S6E26BCI.js.map → consensus-vote-ESFPGEJE.js.map} +0 -0
- /package/dist/{consensus-vote-MUQ4HPIF.js.map → context-retriever-MB3D7KS6.js.map} +0 -0
- /package/dist/{doctor-deep-BRU5ZUJI.js.map → dist-NIXVXYIH.js.map} +0 -0
- /package/dist/{expert-bridge-ZPNVLJVN.js.map → doctor-deep-KQ765XZA.js.map} +0 -0
- /package/dist/{factory-A7DTCCUY.js.map → expert-bridge-JKLC57IC.js.map} +0 -0
- /package/dist/{factory-X3VKIGKP.js.map → factory-BUUXNGIB.js.map} +0 -0
- /package/dist/{issue-triage-6XD6CVPB.js.map → factory-LHHYDVZX.js.map} +0 -0
- /package/dist/{learning-persistence-N6ILD2HX.js.map → issue-triage-RMXPDZ2K.js.map} +0 -0
- /package/dist/{mobimem-CG2MNS7V.js.map → learning-persistence-Q3HTOGTU.js.map} +0 -0
- /package/dist/{nexus-data-dir-77UO7N6J.js.map → repo-security-plan-AGRU72DL.js.map} +0 -0
- /package/dist/{repo-security-plan-7ZCDVH5O.js.map → research-helpers-synthesize-K2UCJQQG.js.map} +0 -0
- /package/dist/{research-helpers-synthesize-36TUTUUA.js.map → routing-memory-3B6DDZ76.js.map} +0 -0
- /package/dist/{routing-memory-5VTX7LQX.js.map → session-memory-L7EQIY2O.js.map} +0 -0
- /package/dist/{session-memory-7XBV6BMY.js.map → setup-command-VYV4RFWW.js.map} +0 -0
- /package/dist/{setup-command-3ZTEPKDA.js.map → setup-config-EQT24DD4.js.map} +0 -0
- /package/dist/{setup-config-EI5KROA3.js.map → tool-memory-6HCHQLAN.js.map} +0 -0
- /package/dist/{weather-report-YJMVKJGA.js.map → weather-report-ER3WUZ7S.js.map} +0 -0
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"sources":["../../nexus-memory/src/telemetry.ts","../../nexus-memory/src/backends/memory.ts","../../nexus-memory/src/backends/sqlite.ts","../../nexus-memory/src/registry.ts","../../nexus-memory/src/factory.ts","../../nexus-memory/src/importer.ts"],"sourcesContent":["/**\n * Memory telemetry — aggregated counters (default) + opt-in full-audit mode.\n *\n * Phase 2 vote (#2768) settled on **C**: per-`{domain, op}` counters in\n * steady state, full per-event payloads when `NEXUS_MEMORY_AUDIT_MODE=audit`.\n *\n * The catfish-mitigation requirement is honored: audit mode emits\n * `{ op, keySummary, payloadSummary, resultSummary, cli, durationMs, hit }`\n * — not just counters — so an incident replay can reconstruct individual\n * ops. Summaries are truncated to keep emission cheap.\n *\n * @module nexus-memory/telemetry\n */\n\nimport type { MemoryEvent, MemoryEventCounters, MemoryEventListener } from './types.js';\n\nconst KEY_SUMMARY_LIMIT = 120;\nconst PAYLOAD_SUMMARY_LIMIT = 240;\n\n/** Per-`{domain, op}` rolling counters. */\nconst counters = new Map<string, MemoryEventCounters>();\nconst listeners = new Set<MemoryEventListener>();\n\n/** Audit mode is opt-in via env. Checked once per emission so the env\n * can be toggled at runtime by tests via `process.env`. */\nfunction isAuditMode(): boolean {\n return process.env['NEXUS_MEMORY_AUDIT_MODE'] === 'audit';\n}\n\nfunction counterKey(domain: string, op: MemoryEvent['op']): string {\n return `${domain}::${op}`;\n}\n\nfunction truncate(value: unknown, limit: number): string {\n let s: string;\n if (typeof value === 'string') {\n s = value;\n } else if (value === undefined) {\n s = '<undefined>';\n } else if (value === null) {\n s = '<null>';\n } else {\n try {\n s = JSON.stringify(value);\n } catch {\n s = '<unserializable>';\n }\n }\n return s.length > limit ? `${s.slice(0, limit - 1)}…` : s;\n}\n\ninterface RecordedEvent extends Omit<\n MemoryEvent,\n 'keySummary' | 'payloadSummary' | 'resultSummary'\n> {\n readonly key?: unknown;\n readonly payload?: unknown;\n readonly result?: unknown;\n}\n\nfunction updateCounter(event: RecordedEvent): void {\n const ck = counterKey(event.domain, event.op);\n const existing = counters.get(ck);\n const hitDelta = event.hit === true ? 1 : 0;\n counters.set(ck, {\n domain: event.domain,\n op: event.op,\n count: (existing?.count ?? 0) + 1,\n hitCount: (existing?.hitCount ?? 0) + hitDelta,\n totalDurationMs: (existing?.totalDurationMs ?? 0) + event.durationMs,\n maxDurationMs: Math.max(existing?.maxDurationMs ?? 0, event.durationMs),\n });\n}\n\nfunction buildPublicEvent(event: RecordedEvent, audit: boolean): MemoryEvent {\n return {\n domain: event.domain,\n op: event.op,\n durationMs: event.durationMs,\n ...(event.cli !== undefined && { cli: event.cli }),\n ...(event.hit !== undefined && { hit: event.hit }),\n ...(audit &&\n event.key !== undefined && {\n keySummary: truncate(event.key, KEY_SUMMARY_LIMIT),\n }),\n ...(audit &&\n event.payload !== undefined && {\n payloadSummary: truncate(event.payload, PAYLOAD_SUMMARY_LIMIT),\n }),\n ...(audit &&\n event.result !== undefined && {\n resultSummary: truncate(event.result, PAYLOAD_SUMMARY_LIMIT),\n }),\n };\n}\n\n/**\n * Record a memory operation. Updates counters always; emits the event\n * to subscribers always (subscribers get the full event in audit mode,\n * the aggregate-only event otherwise).\n *\n * Implementation note: the `op` argument is the typed `MemoryEvent['op']`\n * literal — backends never pass an unknown string here.\n */\nexport function recordMemoryEvent(event: RecordedEvent): void {\n updateCounter(event);\n const publicEvent = buildPublicEvent(event, isAuditMode());\n for (const listener of listeners) {\n try {\n listener(publicEvent);\n } catch {\n // Subscriber failures must never affect memory operations.\n }\n }\n}\n\n/** Snapshot of current counters. Returned array is a copy. */\nexport function getMemoryEventCounters(): readonly MemoryEventCounters[] {\n return [...counters.values()];\n}\n\n/** Subscribe to the per-event stream. Returns an unsubscribe function. */\nexport function subscribeToMemoryEvents(listener: MemoryEventListener): () => void {\n listeners.add(listener);\n return () => {\n listeners.delete(listener);\n };\n}\n\n/**\n * Reset counters + drop all subscribers. Tests should call this in\n * `beforeEach` to keep state from leaking.\n */\nexport function resetMemoryTelemetry(): void {\n counters.clear();\n listeners.clear();\n}\n","/**\n * In-memory backend — primarily for tests, but also used as the cold-archive\n * fallback when no `dbPath` is provided.\n *\n * Implements {@link IMemoryBackend}; passes the same contract test as\n * {@link SqliteBackend}.\n *\n * @module nexus-memory/backends/memory\n */\n\nimport type { z } from 'zod';\nimport { recordMemoryEvent } from '../telemetry.js';\nimport type { BackendStats, IMemoryBackend, QueryFilter, WriteMeta } from '../types.js';\n\ninterface Row<TValue> {\n readonly value: TValue;\n readonly cli?: string;\n readonly source?: string;\n readonly timestamp: number;\n readonly trustTier?: 1 | 2 | 3 | 4;\n}\n\nexport interface InMemoryBackendOptions<TValue> {\n readonly domain: string;\n /**\n * Optional Zod schema. Phase 2 vote mitigation #1 (security dissent):\n * when supplied, every `write()` validates the value first; invalid\n * payloads throw `MemoryValidationError`.\n */\n readonly schema?: z.ZodType<TValue>;\n}\n\nexport class MemoryValidationError extends Error {\n constructor(domain: string, cause: unknown) {\n super(`nexus-memory: write rejected for domain \"${domain}\": ${String(cause)}`);\n this.name = 'MemoryValidationError';\n }\n}\n\nfunction buildInMemoryRow<TValue>(value: TValue, meta: WriteMeta | undefined): Row<TValue> {\n return {\n value,\n ...(meta?.cli !== undefined && { cli: meta.cli }),\n ...(meta?.source !== undefined && { source: meta.source }),\n timestamp: meta?.timestamp ?? Date.now(),\n ...(meta?.trustTier !== undefined && { trustTier: meta.trustTier }),\n };\n}\n\n/** Apply `where`, `orderBy`, `limit` to an in-memory row set. Extracted from\n * `query` to satisfy the eslint complexity gate. */\nfunction applyInMemoryFilter<T>(values: T[], filter?: QueryFilter<T>): T[] {\n let out = values;\n if (filter?.where !== undefined) {\n const where = filter.where;\n out = out.filter((v) => {\n for (const [k, expected] of Object.entries(where)) {\n if ((v as Record<string, unknown>)[k] !== expected) return false;\n }\n return true;\n });\n }\n if (filter?.orderBy !== undefined) {\n const orderBy = filter.orderBy;\n const dir = filter.orderDir === 'desc' ? -1 : 1;\n out = [...out].sort((a, b) => {\n const av = (a as Record<string | symbol | number, unknown>)[orderBy];\n const bv = (b as Record<string | symbol | number, unknown>)[orderBy];\n if (av === bv) return 0;\n if (av === undefined || av === null) return 1;\n if (bv === undefined || bv === null) return -1;\n return (av < bv ? -1 : 1) * dir;\n });\n }\n if (filter?.limit !== undefined) {\n out = out.slice(0, filter.limit);\n }\n return out;\n}\n\nexport class InMemoryBackend<TKey, TValue> implements IMemoryBackend<TKey, TValue> {\n readonly domain: string;\n private readonly rows = new Map<TKey, Row<TValue>>();\n private readonly schema?: z.ZodType<TValue>;\n private closed = false;\n\n constructor(options: InMemoryBackendOptions<TValue>) {\n this.domain = options.domain;\n if (options.schema !== undefined) {\n this.schema = options.schema;\n }\n }\n\n async read(key: TKey): Promise<TValue | undefined> {\n this.assertOpen();\n const start = Date.now();\n const row = this.rows.get(key);\n recordMemoryEvent({\n domain: this.domain,\n op: 'read',\n hit: row !== undefined,\n durationMs: Date.now() - start,\n key,\n result: row?.value,\n });\n return Promise.resolve(row?.value);\n }\n\n private validate(value: TValue): void {\n if (this.schema === undefined) return;\n const result = this.schema.safeParse(value);\n if (!result.success) {\n throw new MemoryValidationError(this.domain, result.error);\n }\n }\n\n async write(key: TKey, value: TValue, meta?: WriteMeta): Promise<void> {\n this.assertOpen();\n const start = Date.now();\n this.validate(value);\n this.rows.set(key, buildInMemoryRow(value, meta));\n recordMemoryEvent({\n domain: this.domain,\n op: 'write',\n ...(meta?.cli !== undefined && { cli: meta.cli }),\n durationMs: Date.now() - start,\n key,\n payload: value,\n });\n return Promise.resolve();\n }\n\n async query(filter?: QueryFilter<TValue>): Promise<readonly TValue[]> {\n this.assertOpen();\n const start = Date.now();\n let rows = [...this.rows.values()];\n if (filter?.cli !== undefined) {\n rows = rows.filter((r) => r.cli === filter.cli);\n }\n const values = applyInMemoryFilter(\n rows.map((r) => r.value),\n filter\n );\n recordMemoryEvent({\n domain: this.domain,\n op: 'query',\n hit: values.length > 0,\n ...(filter?.cli !== undefined && { cli: filter.cli }),\n durationMs: Date.now() - start,\n key: filter,\n result: { count: values.length },\n });\n return Promise.resolve(values);\n }\n\n async delete(key: TKey): Promise<boolean> {\n this.assertOpen();\n const start = Date.now();\n const removed = this.rows.delete(key);\n recordMemoryEvent({\n domain: this.domain,\n op: 'delete',\n hit: removed,\n durationMs: Date.now() - start,\n key,\n });\n return Promise.resolve(removed);\n }\n\n async stats(): Promise<BackendStats> {\n this.assertOpen();\n const start = Date.now();\n const timestamps = [...this.rows.values()].map((r) => r.timestamp);\n const result: BackendStats = {\n domain: this.domain,\n count: this.rows.size,\n oldestTimestamp: timestamps.length > 0 ? Math.min(...timestamps) : null,\n newestTimestamp: timestamps.length > 0 ? Math.max(...timestamps) : null,\n };\n recordMemoryEvent({\n domain: this.domain,\n op: 'stats',\n durationMs: Date.now() - start,\n result,\n });\n return Promise.resolve(result);\n }\n\n async close(): Promise<void> {\n this.closed = true;\n this.rows.clear();\n return Promise.resolve();\n }\n\n private assertOpen(): void {\n if (this.closed) {\n throw new Error(`nexus-memory: backend \"${this.domain}\" is closed`);\n }\n }\n}\n","/**\n * SQLite backend — async wrapper over `better-sqlite3` (which is sync).\n *\n * One table per domain (Phase 2 vote shape C, hot-table side). The schema\n * is intentionally minimal: `key`, `value` (JSON-serialized), `cli`,\n * `source`, `timestamp`, `trust_tier`. Hot-path backends extending this\n * will add typed columns and indexes for query performance.\n *\n * Async surface: every method returns `Promise<T>` so we can swap in a\n * network-backed implementation later without changing callers. The\n * actual SQLite ops are sync inside.\n *\n * @module nexus-memory/backends/sqlite\n */\n\nimport Database, { type Database as DatabaseType, type Statement } from 'better-sqlite3';\nimport type { z } from 'zod';\nimport { recordMemoryEvent } from '../telemetry.js';\nimport type { BackendStats, IMemoryBackend, QueryFilter, WriteMeta } from '../types.js';\nimport { MemoryValidationError } from './memory.js';\n\nexport interface SqliteBackendOptions<TValue> {\n readonly domain: string;\n /** Absolute path to the SQLite file. Use `':memory:'` for tests. */\n readonly dbPath: string;\n /**\n * Zod schema for cold-archive validation (Phase 2 vote mitigation #1).\n * When supplied, every `write()` validates first.\n */\n readonly schema?: z.ZodType<TValue>;\n /** Pre-existing database handle. Used by `MemoryRegistry` to share a single connection. */\n readonly db?: DatabaseType;\n}\n\ninterface SqliteRow {\n readonly key: string;\n readonly value: string;\n readonly cli: string | null;\n readonly source: string | null;\n readonly timestamp: number;\n readonly trust_tier: number | null;\n}\n\nfunction buildWriteRow(\n key: unknown,\n value: unknown,\n meta: WriteMeta | undefined\n): Record<string, string | number | null> {\n return {\n key: keyToString(key),\n value: JSON.stringify(value),\n cli: meta?.cli ?? null,\n source: meta?.source ?? null,\n timestamp: meta?.timestamp ?? Date.now(),\n trust_tier: meta?.trustTier ?? null,\n };\n}\n\n/** Stringify a key so SQLite primary-key lookups stay simple. */\nfunction keyToString(key: unknown): string {\n if (typeof key === 'string') return key;\n if (typeof key === 'number' || typeof key === 'boolean') return String(key);\n return JSON.stringify(key);\n}\n\n/** Apply `where`, `orderBy`, `limit` to an in-memory row set. Extracted from\n * `query` to satisfy the eslint complexity gate. */\nfunction applyQueryFilter<T>(values: T[], filter?: QueryFilter<T>): T[] {\n let out = values;\n if (filter?.where !== undefined) {\n const where = filter.where;\n out = out.filter((v) => {\n for (const [k, expected] of Object.entries(where)) {\n if ((v as Record<string, unknown>)[k] !== expected) return false;\n }\n return true;\n });\n }\n if (filter?.orderBy !== undefined) {\n const orderBy = filter.orderBy;\n const dir = filter.orderDir === 'desc' ? -1 : 1;\n out = [...out].sort((a, b) => {\n const av = (a as Record<string | symbol | number, unknown>)[orderBy];\n const bv = (b as Record<string | symbol | number, unknown>)[orderBy];\n if (av === bv) return 0;\n if (av === undefined || av === null) return 1;\n if (bv === undefined || bv === null) return -1;\n return (av < bv ? -1 : 1) * dir;\n });\n }\n if (filter?.limit !== undefined) {\n out = out.slice(0, filter.limit);\n }\n return out;\n}\n\nexport class SqliteBackend<TKey, TValue> implements IMemoryBackend<TKey, TValue> {\n readonly domain: string;\n private readonly db: DatabaseType;\n private readonly ownsDb: boolean;\n private readonly schema?: z.ZodType<TValue>;\n private readonly stmts: {\n read: Statement;\n write: Statement;\n delete: Statement;\n count: Statement;\n bounds: Statement;\n queryAll: Statement;\n };\n private closed = false;\n\n constructor(options: SqliteBackendOptions<TValue>) {\n this.domain = options.domain;\n if (options.db !== undefined) {\n this.db = options.db;\n this.ownsDb = false;\n } else {\n const db = new Database(options.dbPath);\n (db as unknown as { pragma(s: string): void }).pragma('journal_mode = WAL');\n this.db = db;\n this.ownsDb = true;\n }\n if (options.schema !== undefined) {\n this.schema = options.schema;\n }\n this.ensureTable();\n this.stmts = this.prepareStatements();\n }\n\n private ensureTable(): void {\n // Table name = domain. Domain comes from in-tree code, never untrusted input,\n // so direct interpolation is safe; still validate the shape defensively.\n if (!/^[a-z][a-z0-9_]{0,63}$/i.test(this.domain)) {\n throw new Error(\n `nexus-memory: invalid domain \"${this.domain}\" — must match [a-zA-Z][a-zA-Z0-9_]{0,63}`\n );\n }\n this.db.exec(`\n CREATE TABLE IF NOT EXISTS ${this.domain} (\n key TEXT PRIMARY KEY,\n value TEXT NOT NULL,\n cli TEXT,\n source TEXT,\n timestamp INTEGER NOT NULL,\n trust_tier INTEGER\n );\n CREATE INDEX IF NOT EXISTS ${this.domain}_cli ON ${this.domain}(cli);\n CREATE INDEX IF NOT EXISTS ${this.domain}_timestamp ON ${this.domain}(timestamp);\n `);\n }\n\n private prepareStatements(): SqliteBackend<TKey, TValue>['stmts'] {\n return {\n read: this.db.prepare(\n `SELECT key, value, cli, source, timestamp, trust_tier FROM ${this.domain} WHERE key = ?`\n ),\n write: this.db.prepare(\n `INSERT INTO ${this.domain} (key, value, cli, source, timestamp, trust_tier)\n VALUES (@key, @value, @cli, @source, @timestamp, @trust_tier)\n ON CONFLICT(key) DO UPDATE SET\n value = excluded.value,\n cli = excluded.cli,\n source = excluded.source,\n timestamp = excluded.timestamp,\n trust_tier = excluded.trust_tier`\n ),\n delete: this.db.prepare(`DELETE FROM ${this.domain} WHERE key = ?`),\n count: this.db.prepare(`SELECT COUNT(*) AS count FROM ${this.domain}`),\n bounds: this.db.prepare(\n `SELECT MIN(timestamp) AS oldest, MAX(timestamp) AS newest FROM ${this.domain}`\n ),\n queryAll: this.db.prepare(\n `SELECT key, value, cli, source, timestamp, trust_tier FROM ${this.domain}`\n ),\n };\n }\n\n async read(key: TKey): Promise<TValue | undefined> {\n this.assertOpen();\n const start = Date.now();\n const row = this.stmts.read.get(keyToString(key)) as SqliteRow | undefined;\n const value = row !== undefined ? (JSON.parse(row.value) as TValue) : undefined;\n recordMemoryEvent({\n domain: this.domain,\n op: 'read',\n hit: value !== undefined,\n ...(row?.cli !== null && row?.cli !== undefined && { cli: row.cli as never }),\n durationMs: Date.now() - start,\n key,\n result: value,\n });\n return Promise.resolve(value);\n }\n\n private validate(value: TValue): void {\n if (this.schema === undefined) return;\n const result = this.schema.safeParse(value);\n if (!result.success) {\n throw new MemoryValidationError(this.domain, result.error);\n }\n }\n\n async write(key: TKey, value: TValue, meta?: WriteMeta): Promise<void> {\n this.assertOpen();\n const start = Date.now();\n this.validate(value);\n this.stmts.write.run(buildWriteRow(key, value, meta));\n recordMemoryEvent({\n domain: this.domain,\n op: 'write',\n ...(meta?.cli !== undefined && { cli: meta.cli }),\n durationMs: Date.now() - start,\n key,\n payload: value,\n });\n return Promise.resolve();\n }\n\n async query(filter?: QueryFilter<TValue>): Promise<readonly TValue[]> {\n this.assertOpen();\n const start = Date.now();\n // Phase 3 keeps query simple — full table scan with in-process filter.\n // Hot-path backends will override or extend with indexed columns.\n let rows = this.stmts.queryAll.all() as SqliteRow[];\n if (filter?.cli !== undefined) {\n rows = rows.filter((r) => r.cli === filter.cli);\n }\n let values = rows.map((r) => JSON.parse(r.value) as TValue);\n values = applyQueryFilter(values, filter);\n recordMemoryEvent({\n domain: this.domain,\n op: 'query',\n hit: values.length > 0,\n ...(filter?.cli !== undefined && { cli: filter.cli }),\n durationMs: Date.now() - start,\n key: filter,\n result: { count: values.length },\n });\n return Promise.resolve(values);\n }\n\n async delete(key: TKey): Promise<boolean> {\n this.assertOpen();\n const start = Date.now();\n const result = this.stmts.delete.run(keyToString(key));\n const removed = result.changes > 0;\n recordMemoryEvent({\n domain: this.domain,\n op: 'delete',\n hit: removed,\n durationMs: Date.now() - start,\n key,\n });\n return Promise.resolve(removed);\n }\n\n async stats(): Promise<BackendStats> {\n this.assertOpen();\n const start = Date.now();\n const countRow = this.stmts.count.get() as { count: number };\n const boundsRow = this.stmts.bounds.get() as { oldest: number | null; newest: number | null };\n const result: BackendStats = {\n domain: this.domain,\n count: countRow.count,\n oldestTimestamp: boundsRow.oldest,\n newestTimestamp: boundsRow.newest,\n };\n recordMemoryEvent({\n domain: this.domain,\n op: 'stats',\n durationMs: Date.now() - start,\n result,\n });\n return Promise.resolve(result);\n }\n\n async close(): Promise<void> {\n if (this.closed) return Promise.resolve();\n this.closed = true;\n if (this.ownsDb) this.db.close();\n return Promise.resolve();\n }\n\n private assertOpen(): void {\n if (this.closed) {\n throw new Error(`nexus-memory: backend \"${this.domain}\" is closed`);\n }\n }\n}\n","/**\n * MemoryRegistry — the single entry point for accessing memory backends.\n *\n * Every concept-space (experience, outcomes, beliefs, …) registers a\n * backend; callers reach it via `registry.get('experience')` or, more\n * commonly, the typed accessors that wrap the registry.\n *\n * Sharing a SQLite connection across backends keeps WAL-mode behavior\n * coherent — one writer thread, many tables.\n *\n * @module nexus-memory/registry\n */\n\nimport Database, { type Database as DatabaseType } from 'better-sqlite3';\nimport type { z } from 'zod';\nimport { InMemoryBackend } from './backends/memory.js';\nimport { SqliteBackend } from './backends/sqlite.js';\nimport type { IMemoryBackend } from './types.js';\n\nexport interface MemoryRegistryOptions {\n /**\n * SQLite file path. Use `':memory:'` for tests. When omitted, the\n * registry creates `InMemoryBackend` instances and never touches disk\n * — the standard test-isolation pattern (Phase 2 acceptance criterion).\n */\n readonly dbPath?: string;\n}\n\nexport interface RegisterBackendOptions<TValue> {\n /** Stable domain identifier. Becomes the SQLite table name. */\n readonly domain: string;\n /** Optional Zod schema for cold-archive validation. */\n readonly schema?: z.ZodType<TValue>;\n}\n\n/**\n * The registry. One per `dbPath` (or one in-memory registry per test).\n * `MemoryRegistry.get(domain)` is `O(1)` after registration.\n */\nexport class MemoryRegistry {\n private readonly backends = new Map<string, IMemoryBackend<unknown, unknown>>();\n private readonly db?: DatabaseType;\n private closed = false;\n\n constructor(options: MemoryRegistryOptions = {}) {\n if (options.dbPath !== undefined) {\n const db = new Database(options.dbPath);\n (db as unknown as { pragma(s: string): void }).pragma('journal_mode = WAL');\n this.db = db;\n }\n }\n\n /**\n * Register a backend for `domain`. Throws on duplicate domain.\n *\n * When the registry has a `dbPath`, the new backend is SQLite-backed\n * and shares the registry's connection. Otherwise, an `InMemoryBackend`\n * is created (used for tests).\n */\n register<TKey, TValue>(options: RegisterBackendOptions<TValue>): IMemoryBackend<TKey, TValue> {\n this.assertOpen();\n if (this.backends.has(options.domain)) {\n throw new Error(`nexus-memory: domain \"${options.domain}\" already registered`);\n }\n const backend: IMemoryBackend<TKey, TValue> =\n this.db !== undefined\n ? new SqliteBackend<TKey, TValue>({\n domain: options.domain,\n dbPath: '<shared>', // unused when db is supplied\n db: this.db,\n ...(options.schema !== undefined && { schema: options.schema }),\n })\n : new InMemoryBackend<TKey, TValue>({\n domain: options.domain,\n ...(options.schema !== undefined && { schema: options.schema }),\n });\n // eslint-disable-next-line @typescript-eslint/no-unnecessary-type-assertion -- TypeScript narrows the union type here, but the Map needs the lifted IMemoryBackend<unknown, unknown>; the assertion documents the variance and survives future contract changes.\n this.backends.set(options.domain, backend as IMemoryBackend<unknown, unknown>);\n return backend;\n }\n\n /**\n * Attach an externally-managed {@link IMemoryBackend}. Use this when the\n * backend owns its own storage (e.g., a pre-existing SQLite file under\n * `~/.nexus-agents/memory/agentic.db`) and you want it discoverable\n * through the registry without changing its persistence.\n *\n * Phase 5–7 of the memory-unification epic use this to bring the\n * tool-memory backends (`agentic`, `adaptive`, `typed`, `belief`),\n * OutcomeStore, SICA, skills, etc. under a unified observability\n * contract without rewriting their internals. Each attached backend\n * still owns its own `.db` (or JSONL, etc.) until a follow-up migration\n * folds the storage in fully.\n */\n attach<TKey, TValue>(\n domain: string,\n backend: IMemoryBackend<TKey, TValue>\n ): IMemoryBackend<TKey, TValue> {\n this.assertOpen();\n if (this.backends.has(domain)) {\n throw new Error(`nexus-memory: domain \"${domain}\" already registered`);\n }\n // eslint-disable-next-line @typescript-eslint/no-unnecessary-type-assertion -- See `register`.\n this.backends.set(domain, backend as IMemoryBackend<unknown, unknown>);\n return backend;\n }\n\n /**\n * Get a previously-registered backend. Returns `undefined` if the\n * domain isn't registered — callers should treat that as \"not yet\n * migrated to the unified contract.\"\n */\n get<TKey, TValue>(domain: string): IMemoryBackend<TKey, TValue> | undefined {\n this.assertOpen();\n const backend = this.backends.get(domain);\n return backend as IMemoryBackend<TKey, TValue> | undefined;\n }\n\n /** List all registered domains. Useful for `memory_stats`-style readers. */\n domains(): readonly string[] {\n return [...this.backends.keys()];\n }\n\n /**\n * Close every registered backend and the shared SQLite handle. After\n * `close()` the registry rejects all further operations.\n */\n async close(): Promise<void> {\n if (this.closed) return;\n this.closed = true;\n for (const backend of this.backends.values()) {\n await backend.close();\n }\n this.backends.clear();\n if (this.db !== undefined) this.db.close();\n }\n\n private assertOpen(): void {\n if (this.closed) {\n throw new Error('nexus-memory: registry is closed');\n }\n }\n}\n\n// ============================================================================\n// Singleton accessor\n// ============================================================================\n\nlet sharedRegistry: MemoryRegistry | null = null;\n\n/**\n * Get the process-wide shared registry. Initializes on first call with\n * `dbPath` from `NEXUS_DATA_DIR` (defaults to `~/.nexus-agents/memory/memory.db`)\n * unless `setMemoryRegistry` was called first.\n *\n * Test code should call `setMemoryRegistry(createInMemoryMemoryRegistry())`\n * in `beforeEach` — this matches the existing `setOutcomeStore` pattern.\n */\nexport function getMemoryRegistry(): MemoryRegistry {\n if (sharedRegistry === null) {\n // Default path resolution happens here, NOT at module load — so tests\n // that call `setMemoryRegistry` before any `getMemoryRegistry` see\n // their in-memory instance, not a side-effectful production path.\n const dbPath = resolveDefaultDbPath();\n sharedRegistry = new MemoryRegistry({ dbPath });\n }\n return sharedRegistry;\n}\n\n/**\n * Inject a registry. Used by tests to swap in `InMemoryBackend`-backed\n * registries. After test, call again with `null` to reset, or call\n * `closeMemoryRegistry()` to dispose.\n */\nexport function setMemoryRegistry(registry: MemoryRegistry | null): void {\n sharedRegistry = registry;\n}\n\n/** Close + null out the shared registry. Idempotent. */\nexport async function closeMemoryRegistry(): Promise<void> {\n if (sharedRegistry !== null) {\n await sharedRegistry.close();\n sharedRegistry = null;\n }\n}\n\nfunction resolveDefaultDbPath(): string {\n // Match `nexus-agents`'s `nexusDataPath` convention without importing it\n // (keep nexus-memory free of inter-package deps for nexus-eval-* reuse).\n const root = process.env['NEXUS_DATA_DIR'] ?? `${process.env['HOME'] ?? '/tmp'}/.nexus-agents`;\n return `${root}/memory/memory.db`;\n}\n","/**\n * Test factories. Production code uses {@link getMemoryRegistry} from\n * `./registry.js`; tests use these helpers to avoid touching disk.\n *\n * @module nexus-memory/factory\n */\n\nimport { MemoryRegistry } from './registry.js';\n\n/**\n * Create a registry that lives entirely in memory. Every `register()`\n * call returns an {@link InMemoryBackend}; nothing is persisted.\n *\n * Use this in `beforeEach`:\n *\n * ```ts\n * beforeEach(() => {\n * setMemoryRegistry(createInMemoryMemoryRegistry());\n * });\n * afterEach(async () => {\n * await closeMemoryRegistry();\n * });\n * ```\n */\nexport function createInMemoryMemoryRegistry(): MemoryRegistry {\n return new MemoryRegistry({\n /* no dbPath → InMemoryBackend per domain */\n });\n}\n\n/**\n * Create a SQLite-backed registry rooted at `dbPath`. Pass `':memory:'`\n * for tests that need to exercise the SQLite code path (e.g.,\n * migration tests, parity tests).\n */\nexport function createSqliteMemoryRegistry(dbPath: string): MemoryRegistry {\n return new MemoryRegistry({ dbPath });\n}\n","/**\n * One-shot importer scaffold. Each Phase 4+ migration registers its own\n * importer here; the registry runs them on first launch (after a marker\n * file check) and renames source files to `.bak.<timestamp>` once\n * complete.\n *\n * This file ships the skeleton + the marker-file logic; concrete\n * importers (MobiMem JSON, OutcomeStore JSONL, agentic.db, etc.) plug in\n * during their respective migration phases.\n *\n * @module nexus-memory/importer\n */\n\nimport { existsSync, mkdirSync, renameSync, writeFileSync } from 'node:fs';\nimport { dirname, join } from 'node:path';\nimport type { MemoryRegistry } from './registry.js';\n\nexport interface ImporterRun {\n readonly domain: string;\n readonly rowsImported: number;\n readonly sourcePathBackup: string | null;\n}\n\nexport interface Importer {\n /** Stable identifier — used in the marker filename to track completion. */\n readonly id: string;\n /** Logical domain this importer targets in the registry. */\n readonly domain: string;\n /**\n * Run the import. Implementations: (1) check if source data exists,\n * (2) parse + validate it, (3) write rows into the registry's backend,\n * (4) rename source to `.bak.<timestamp>` and return the backup path.\n * Idempotent — if marker file says we already ran, the registry skips it.\n */\n run(registry: MemoryRegistry): Promise<ImporterRun>;\n}\n\nconst importers = new Map<string, Importer>();\n\n/** Register an importer. Phase 4+ migrations call this at module load. */\nexport function registerImporter(importer: Importer): void {\n if (importers.has(importer.id)) {\n throw new Error(`nexus-memory: importer \"${importer.id}\" already registered`);\n }\n importers.set(importer.id, importer);\n}\n\n/** For tests: clear all registered importers. */\nexport function resetImporters(): void {\n importers.clear();\n}\n\n/** Snapshot of registered importer IDs. */\nexport function listImporters(): readonly string[] {\n return [...importers.keys()];\n}\n\nexport interface RunImportersOptions {\n /**\n * Directory holding `.imported-{id}` marker files. Defaults to the\n * registry's data dir; tests should override.\n */\n readonly markerDir: string;\n /** Skip the marker check (forces re-run). Tests only. */\n readonly force?: boolean;\n}\n\n/**\n * Run every registered importer that hasn't yet completed (per marker\n * file). Returns the list of runs that actually executed.\n *\n * Failures are NOT fatal — a single importer's exception is logged via\n * the returned `errors` array; other importers still get a chance to run.\n */\nexport async function runImporters(\n registry: MemoryRegistry,\n options: RunImportersOptions\n): Promise<{ runs: readonly ImporterRun[]; errors: readonly { id: string; error: Error }[] }> {\n mkdirSync(options.markerDir, { recursive: true });\n const runs: ImporterRun[] = [];\n const errors: { id: string; error: Error }[] = [];\n for (const importer of importers.values()) {\n const marker = join(options.markerDir, `.imported-${importer.id}`);\n if (options.force !== true && existsSync(marker)) continue;\n try {\n const run = await importer.run(registry);\n writeMarker(marker, run);\n runs.push(run);\n } catch (err) {\n errors.push({ id: importer.id, error: err instanceof Error ? err : new Error(String(err)) });\n }\n }\n return { runs, errors };\n}\n\nfunction writeMarker(path: string, run: ImporterRun): void {\n mkdirSync(dirname(path), { recursive: true });\n writeFileSync(\n path,\n JSON.stringify({ ...run, completedAt: new Date().toISOString() }, null, 2),\n 'utf-8'\n );\n}\n\n/**\n * Rename a source file to `.bak.<unix-timestamp>`. Used by concrete\n * importers after a successful migration. Returns the backup path, or\n * `null` when the source doesn't exist.\n */\nexport function backupSourceFile(sourcePath: string): string | null {\n if (!existsSync(sourcePath)) return null;\n const backup = `${sourcePath}.bak.${String(Date.now())}`;\n renameSync(sourcePath, backup);\n return backup;\n}\n"],"mappings":";AEeA,OAAO,cAAiE;ACFxE,OAAOA,eAAiD;AEAxD,SAAS,YAAY,WAAW,YAAY,qBAAqB;AACjE,SAAS,SAAS,YAAY;ALE9B,IAAM,oBAAoB;AAC1B,IAAM,wBAAwB;AAG9B,IAAM,WAAW,oBAAI,IAAiC;AACtD,IAAM,YAAY,oBAAI,IAAyB;AAI/C,SAAS,cAAuB;AAC9B,SAAO,QAAQ,IAAI,yBAAyB,MAAM;AACpD;AAEA,SAAS,WAAW,QAAgB,IAA+B;AACjE,SAAO,GAAG,MAAM,KAAK,EAAE;AACzB;AAEA,SAAS,SAAS,OAAgB,OAAuB;AACvD,MAAI;AACJ,MAAI,OAAO,UAAU,UAAU;AAC7B,QAAI;EACN,WAAW,UAAU,QAAW;AAC9B,QAAI;EACN,WAAW,UAAU,MAAM;AACzB,QAAI;EACN,OAAO;AACL,QAAI;AACF,UAAI,KAAK,UAAU,KAAK;IAC1B,QAAQ;AACN,UAAI;IACN;EACF;AACA,SAAO,EAAE,SAAS,QAAQ,GAAG,EAAE,MAAM,GAAG,QAAQ,CAAC,CAAC,WAAM;AAC1D;AAWA,SAAS,cAAc,OAA4B;AACjD,QAAM,KAAK,WAAW,MAAM,QAAQ,MAAM,EAAE;AAC5C,QAAM,WAAW,SAAS,IAAI,EAAE;AAChC,QAAM,WAAW,MAAM,QAAQ,OAAO,IAAI;AAC1C,WAAS,IAAI,IAAI;IACf,QAAQ,MAAM;IACd,IAAI,MAAM;IACV,QAAQ,UAAU,SAAS,KAAK;IAChC,WAAW,UAAU,YAAY,KAAK;IACtC,kBAAkB,UAAU,mBAAmB,KAAK,MAAM;IAC1D,eAAe,KAAK,IAAI,UAAU,iBAAiB,GAAG,MAAM,UAAU;EACxE,CAAC;AACH;AAEA,SAAS,iBAAiB,OAAsB,OAA6B;AAC3E,SAAO;IACL,QAAQ,MAAM;IACd,IAAI,MAAM;IACV,YAAY,MAAM;IAClB,GAAI,MAAM,QAAQ,UAAa,EAAE,KAAK,MAAM,IAAI;IAChD,GAAI,MAAM,QAAQ,UAAa,EAAE,KAAK,MAAM,IAAI;IAChD,GAAI,SACF,MAAM,QAAQ,UAAa;MACzB,YAAY,SAAS,MAAM,KAAK,iBAAiB;IACnD;IACF,GAAI,SACF,MAAM,YAAY,UAAa;MAC7B,gBAAgB,SAAS,MAAM,SAAS,qBAAqB;IAC/D;IACF,GAAI,SACF,MAAM,WAAW,UAAa;MAC5B,eAAe,SAAS,MAAM,QAAQ,qBAAqB;IAC7D;EACJ;AACF;AAUO,SAAS,kBAAkB,OAA4B;AAC5D,gBAAc,KAAK;AACnB,QAAM,cAAc,iBAAiB,OAAO,YAAY,CAAC;AACzD,aAAW,YAAY,WAAW;AAChC,QAAI;AACF,eAAS,WAAW;IACtB,QAAQ;IAER;EACF;AACF;AAGO,SAAS,yBAAyD;AACvE,SAAO,CAAC,GAAG,SAAS,OAAO,CAAC;AAC9B;AAGO,SAAS,wBAAwB,UAA2C;AACjF,YAAU,IAAI,QAAQ;AACtB,SAAO,MAAM;AACX,cAAU,OAAO,QAAQ;EAC3B;AACF;AAMO,SAAS,uBAA6B;AAC3C,WAAS,MAAM;AACf,YAAU,MAAM;AAClB;ACxGO,IAAM,wBAAN,cAAoC,MAAM;EAC/C,YAAY,QAAgB,OAAgB;AAC1C,UAAM,4CAA4C,MAAM,MAAM,OAAO,KAAK,CAAC,EAAE;AAC7E,SAAK,OAAO;EACd;AACF;AAEA,SAAS,iBAAyB,OAAe,MAA0C;AACzF,SAAO;IACL;IACA,GAAI,MAAM,QAAQ,UAAa,EAAE,KAAK,KAAK,IAAI;IAC/C,GAAI,MAAM,WAAW,UAAa,EAAE,QAAQ,KAAK,OAAO;IACxD,WAAW,MAAM,aAAa,KAAK,IAAI;IACvC,GAAI,MAAM,cAAc,UAAa,EAAE,WAAW,KAAK,UAAU;EACnE;AACF;AAIA,SAAS,oBAAuB,QAAa,QAA8B;AACzE,MAAI,MAAM;AACV,MAAI,QAAQ,UAAU,QAAW;AAC/B,UAAM,QAAQ,OAAO;AACrB,UAAM,IAAI,OAAO,CAAC,MAAM;AACtB,iBAAW,CAAC,GAAG,QAAQ,KAAK,OAAO,QAAQ,KAAK,GAAG;AACjD,YAAK,EAA8B,CAAC,MAAM,SAAU,QAAO;MAC7D;AACA,aAAO;IACT,CAAC;EACH;AACA,MAAI,QAAQ,YAAY,QAAW;AACjC,UAAM,UAAU,OAAO;AACvB,UAAM,MAAM,OAAO,aAAa,SAAS,KAAK;AAC9C,UAAM,CAAC,GAAG,GAAG,EAAE,KAAK,CAAC,GAAG,MAAM;AAC5B,YAAM,KAAM,EAAgD,OAAO;AACnE,YAAM,KAAM,EAAgD,OAAO;AACnE,UAAI,OAAO,GAAI,QAAO;AACtB,UAAI,OAAO,UAAa,OAAO,KAAM,QAAO;AAC5C,UAAI,OAAO,UAAa,OAAO,KAAM,QAAO;AAC5C,cAAQ,KAAK,KAAK,KAAK,KAAK;IAC9B,CAAC;EACH;AACA,MAAI,QAAQ,UAAU,QAAW;AAC/B,UAAM,IAAI,MAAM,GAAG,OAAO,KAAK;EACjC;AACA,SAAO;AACT;AAEO,IAAM,kBAAN,MAA4E;EACxE;EACQ,OAAO,oBAAI,IAAuB;EAClC;EACT,SAAS;EAEjB,YAAY,SAAyC;AACnD,SAAK,SAAS,QAAQ;AACtB,QAAI,QAAQ,WAAW,QAAW;AAChC,WAAK,SAAS,QAAQ;IACxB;EACF;EAEA,MAAM,KAAK,KAAwC;AACjD,SAAK,WAAW;AAChB,UAAM,QAAQ,KAAK,IAAI;AACvB,UAAM,MAAM,KAAK,KAAK,IAAI,GAAG;AAC7B,sBAAkB;MAChB,QAAQ,KAAK;MACb,IAAI;MACJ,KAAK,QAAQ;MACb,YAAY,KAAK,IAAI,IAAI;MACzB;MACA,QAAQ,KAAK;IACf,CAAC;AACD,WAAO,QAAQ,QAAQ,KAAK,KAAK;EACnC;EAEQ,SAAS,OAAqB;AACpC,QAAI,KAAK,WAAW,OAAW;AAC/B,UAAM,SAAS,KAAK,OAAO,UAAU,KAAK;AAC1C,QAAI,CAAC,OAAO,SAAS;AACnB,YAAM,IAAI,sBAAsB,KAAK,QAAQ,OAAO,KAAK;IAC3D;EACF;EAEA,MAAM,MAAM,KAAW,OAAe,MAAiC;AACrE,SAAK,WAAW;AAChB,UAAM,QAAQ,KAAK,IAAI;AACvB,SAAK,SAAS,KAAK;AACnB,SAAK,KAAK,IAAI,KAAK,iBAAiB,OAAO,IAAI,CAAC;AAChD,sBAAkB;MAChB,QAAQ,KAAK;MACb,IAAI;MACJ,GAAI,MAAM,QAAQ,UAAa,EAAE,KAAK,KAAK,IAAI;MAC/C,YAAY,KAAK,IAAI,IAAI;MACzB;MACA,SAAS;IACX,CAAC;AACD,WAAO,QAAQ,QAAQ;EACzB;EAEA,MAAM,MAAM,QAA0D;AACpE,SAAK,WAAW;AAChB,UAAM,QAAQ,KAAK,IAAI;AACvB,QAAI,OAAO,CAAC,GAAG,KAAK,KAAK,OAAO,CAAC;AACjC,QAAI,QAAQ,QAAQ,QAAW;AAC7B,aAAO,KAAK,OAAO,CAAC,MAAM,EAAE,QAAQ,OAAO,GAAG;IAChD;AACA,UAAM,SAAS;MACb,KAAK,IAAI,CAAC,MAAM,EAAE,KAAK;MACvB;IACF;AACA,sBAAkB;MAChB,QAAQ,KAAK;MACb,IAAI;MACJ,KAAK,OAAO,SAAS;MACrB,GAAI,QAAQ,QAAQ,UAAa,EAAE,KAAK,OAAO,IAAI;MACnD,YAAY,KAAK,IAAI,IAAI;MACzB,KAAK;MACL,QAAQ,EAAE,OAAO,OAAO,OAAO;IACjC,CAAC;AACD,WAAO,QAAQ,QAAQ,MAAM;EAC/B;EAEA,MAAM,OAAO,KAA6B;AACxC,SAAK,WAAW;AAChB,UAAM,QAAQ,KAAK,IAAI;AACvB,UAAM,UAAU,KAAK,KAAK,OAAO,GAAG;AACpC,sBAAkB;MAChB,QAAQ,KAAK;MACb,IAAI;MACJ,KAAK;MACL,YAAY,KAAK,IAAI,IAAI;MACzB;IACF,CAAC;AACD,WAAO,QAAQ,QAAQ,OAAO;EAChC;EAEA,MAAM,QAA+B;AACnC,SAAK,WAAW;AAChB,UAAM,QAAQ,KAAK,IAAI;AACvB,UAAM,aAAa,CAAC,GAAG,KAAK,KAAK,OAAO,CAAC,EAAE,IAAI,CAAC,MAAM,EAAE,SAAS;AACjE,UAAM,SAAuB;MAC3B,QAAQ,KAAK;MACb,OAAO,KAAK,KAAK;MACjB,iBAAiB,WAAW,SAAS,IAAI,KAAK,IAAI,GAAG,UAAU,IAAI;MACnE,iBAAiB,WAAW,SAAS,IAAI,KAAK,IAAI,GAAG,UAAU,IAAI;IACrE;AACA,sBAAkB;MAChB,QAAQ,KAAK;MACb,IAAI;MACJ,YAAY,KAAK,IAAI,IAAI;MACzB;IACF,CAAC;AACD,WAAO,QAAQ,QAAQ,MAAM;EAC/B;EAEA,MAAM,QAAuB;AAC3B,SAAK,SAAS;AACd,SAAK,KAAK,MAAM;AAChB,WAAO,QAAQ,QAAQ;EACzB;EAEQ,aAAmB;AACzB,QAAI,KAAK,QAAQ;AACf,YAAM,IAAI,MAAM,0BAA0B,KAAK,MAAM,aAAa;IACpE;EACF;AACF;AC5JA,SAAS,cACP,KACA,OACA,MACwC;AACxC,SAAO;IACL,KAAK,YAAY,GAAG;IACpB,OAAO,KAAK,UAAU,KAAK;IAC3B,KAAK,MAAM,OAAO;IAClB,QAAQ,MAAM,UAAU;IACxB,WAAW,MAAM,aAAa,KAAK,IAAI;IACvC,YAAY,MAAM,aAAa;EACjC;AACF;AAGA,SAAS,YAAY,KAAsB;AACzC,MAAI,OAAO,QAAQ,SAAU,QAAO;AACpC,MAAI,OAAO,QAAQ,YAAY,OAAO,QAAQ,UAAW,QAAO,OAAO,GAAG;AAC1E,SAAO,KAAK,UAAU,GAAG;AAC3B;AAIA,SAAS,iBAAoB,QAAa,QAA8B;AACtE,MAAI,MAAM;AACV,MAAI,QAAQ,UAAU,QAAW;AAC/B,UAAM,QAAQ,OAAO;AACrB,UAAM,IAAI,OAAO,CAAC,MAAM;AACtB,iBAAW,CAAC,GAAG,QAAQ,KAAK,OAAO,QAAQ,KAAK,GAAG;AACjD,YAAK,EAA8B,CAAC,MAAM,SAAU,QAAO;MAC7D;AACA,aAAO;IACT,CAAC;EACH;AACA,MAAI,QAAQ,YAAY,QAAW;AACjC,UAAM,UAAU,OAAO;AACvB,UAAM,MAAM,OAAO,aAAa,SAAS,KAAK;AAC9C,UAAM,CAAC,GAAG,GAAG,EAAE,KAAK,CAAC,GAAG,MAAM;AAC5B,YAAM,KAAM,EAAgD,OAAO;AACnE,YAAM,KAAM,EAAgD,OAAO;AACnE,UAAI,OAAO,GAAI,QAAO;AACtB,UAAI,OAAO,UAAa,OAAO,KAAM,QAAO;AAC5C,UAAI,OAAO,UAAa,OAAO,KAAM,QAAO;AAC5C,cAAQ,KAAK,KAAK,KAAK,KAAK;IAC9B,CAAC;EACH;AACA,MAAI,QAAQ,UAAU,QAAW;AAC/B,UAAM,IAAI,MAAM,GAAG,OAAO,KAAK;EACjC;AACA,SAAO;AACT;AAEO,IAAM,gBAAN,MAA0E;EACtE;EACQ;EACA;EACA;EACA;EAQT,SAAS;EAEjB,YAAY,SAAuC;AACjD,SAAK,SAAS,QAAQ;AACtB,QAAI,QAAQ,OAAO,QAAW;AAC5B,WAAK,KAAK,QAAQ;AAClB,WAAK,SAAS;IAChB,OAAO;AACL,YAAM,KAAK,IAAI,SAAS,QAAQ,MAAM;AACrC,SAA8C,OAAO,oBAAoB;AAC1E,WAAK,KAAK;AACV,WAAK,SAAS;IAChB;AACA,QAAI,QAAQ,WAAW,QAAW;AAChC,WAAK,SAAS,QAAQ;IACxB;AACA,SAAK,YAAY;AACjB,SAAK,QAAQ,KAAK,kBAAkB;EACtC;EAEQ,cAAoB;AAG1B,QAAI,CAAC,0BAA0B,KAAK,KAAK,MAAM,GAAG;AAChD,YAAM,IAAI;QACR,iCAAiC,KAAK,MAAM;MAC9C;IACF;AACA,SAAK,GAAG,KAAK;mCACkB,KAAK,MAAM;;;;;;;;mCAQX,KAAK,MAAM,WAAW,KAAK,MAAM;mCACjC,KAAK,MAAM,iBAAiB,KAAK,MAAM;KACrE;EACH;EAEQ,oBAA0D;AAChE,WAAO;MACL,MAAM,KAAK,GAAG;QACZ,8DAA8D,KAAK,MAAM;MAC3E;MACA,OAAO,KAAK,GAAG;QACb,eAAe,KAAK,MAAM;;;;;;;;MAQ5B;MACA,QAAQ,KAAK,GAAG,QAAQ,eAAe,KAAK,MAAM,gBAAgB;MAClE,OAAO,KAAK,GAAG,QAAQ,iCAAiC,KAAK,MAAM,EAAE;MACrE,QAAQ,KAAK,GAAG;QACd,kEAAkE,KAAK,MAAM;MAC/E;MACA,UAAU,KAAK,GAAG;QAChB,8DAA8D,KAAK,MAAM;MAC3E;IACF;EACF;EAEA,MAAM,KAAK,KAAwC;AACjD,SAAK,WAAW;AAChB,UAAM,QAAQ,KAAK,IAAI;AACvB,UAAM,MAAM,KAAK,MAAM,KAAK,IAAI,YAAY,GAAG,CAAC;AAChD,UAAM,QAAQ,QAAQ,SAAa,KAAK,MAAM,IAAI,KAAK,IAAe;AACtE,sBAAkB;MAChB,QAAQ,KAAK;MACb,IAAI;MACJ,KAAK,UAAU;MACf,GAAI,KAAK,QAAQ,QAAQ,KAAK,QAAQ,UAAa,EAAE,KAAK,IAAI,IAAa;MAC3E,YAAY,KAAK,IAAI,IAAI;MACzB;MACA,QAAQ;IACV,CAAC;AACD,WAAO,QAAQ,QAAQ,KAAK;EAC9B;EAEQ,SAAS,OAAqB;AACpC,QAAI,KAAK,WAAW,OAAW;AAC/B,UAAM,SAAS,KAAK,OAAO,UAAU,KAAK;AAC1C,QAAI,CAAC,OAAO,SAAS;AACnB,YAAM,IAAI,sBAAsB,KAAK,QAAQ,OAAO,KAAK;IAC3D;EACF;EAEA,MAAM,MAAM,KAAW,OAAe,MAAiC;AACrE,SAAK,WAAW;AAChB,UAAM,QAAQ,KAAK,IAAI;AACvB,SAAK,SAAS,KAAK;AACnB,SAAK,MAAM,MAAM,IAAI,cAAc,KAAK,OAAO,IAAI,CAAC;AACpD,sBAAkB;MAChB,QAAQ,KAAK;MACb,IAAI;MACJ,GAAI,MAAM,QAAQ,UAAa,EAAE,KAAK,KAAK,IAAI;MAC/C,YAAY,KAAK,IAAI,IAAI;MACzB;MACA,SAAS;IACX,CAAC;AACD,WAAO,QAAQ,QAAQ;EACzB;EAEA,MAAM,MAAM,QAA0D;AACpE,SAAK,WAAW;AAChB,UAAM,QAAQ,KAAK,IAAI;AAGvB,QAAI,OAAO,KAAK,MAAM,SAAS,IAAI;AACnC,QAAI,QAAQ,QAAQ,QAAW;AAC7B,aAAO,KAAK,OAAO,CAAC,MAAM,EAAE,QAAQ,OAAO,GAAG;IAChD;AACA,QAAI,SAAS,KAAK,IAAI,CAAC,MAAM,KAAK,MAAM,EAAE,KAAK,CAAW;AAC1D,aAAS,iBAAiB,QAAQ,MAAM;AACxC,sBAAkB;MAChB,QAAQ,KAAK;MACb,IAAI;MACJ,KAAK,OAAO,SAAS;MACrB,GAAI,QAAQ,QAAQ,UAAa,EAAE,KAAK,OAAO,IAAI;MACnD,YAAY,KAAK,IAAI,IAAI;MACzB,KAAK;MACL,QAAQ,EAAE,OAAO,OAAO,OAAO;IACjC,CAAC;AACD,WAAO,QAAQ,QAAQ,MAAM;EAC/B;EAEA,MAAM,OAAO,KAA6B;AACxC,SAAK,WAAW;AAChB,UAAM,QAAQ,KAAK,IAAI;AACvB,UAAM,SAAS,KAAK,MAAM,OAAO,IAAI,YAAY,GAAG,CAAC;AACrD,UAAM,UAAU,OAAO,UAAU;AACjC,sBAAkB;MAChB,QAAQ,KAAK;MACb,IAAI;MACJ,KAAK;MACL,YAAY,KAAK,IAAI,IAAI;MACzB;IACF,CAAC;AACD,WAAO,QAAQ,QAAQ,OAAO;EAChC;EAEA,MAAM,QAA+B;AACnC,SAAK,WAAW;AAChB,UAAM,QAAQ,KAAK,IAAI;AACvB,UAAM,WAAW,KAAK,MAAM,MAAM,IAAI;AACtC,UAAM,YAAY,KAAK,MAAM,OAAO,IAAI;AACxC,UAAM,SAAuB;MAC3B,QAAQ,KAAK;MACb,OAAO,SAAS;MAChB,iBAAiB,UAAU;MAC3B,iBAAiB,UAAU;IAC7B;AACA,sBAAkB;MAChB,QAAQ,KAAK;MACb,IAAI;MACJ,YAAY,KAAK,IAAI,IAAI;MACzB;IACF,CAAC;AACD,WAAO,QAAQ,QAAQ,MAAM;EAC/B;EAEA,MAAM,QAAuB;AAC3B,QAAI,KAAK,OAAQ,QAAO,QAAQ,QAAQ;AACxC,SAAK,SAAS;AACd,QAAI,KAAK,OAAQ,MAAK,GAAG,MAAM;AAC/B,WAAO,QAAQ,QAAQ;EACzB;EAEQ,aAAmB;AACzB,QAAI,KAAK,QAAQ;AACf,YAAM,IAAI,MAAM,0BAA0B,KAAK,MAAM,aAAa;IACpE;EACF;AACF;ACzPO,IAAM,iBAAN,MAAqB;EACT,WAAW,oBAAI,IAA8C;EAC7D;EACT,SAAS;EAEjB,YAAY,UAAiC,CAAC,GAAG;AAC/C,QAAI,QAAQ,WAAW,QAAW;AAChC,YAAM,KAAK,IAAIA,UAAS,QAAQ,MAAM;AACrC,SAA8C,OAAO,oBAAoB;AAC1E,WAAK,KAAK;IACZ;EACF;;;;;;;;EASA,SAAuB,SAAuE;AAC5F,SAAK,WAAW;AAChB,QAAI,KAAK,SAAS,IAAI,QAAQ,MAAM,GAAG;AACrC,YAAM,IAAI,MAAM,yBAAyB,QAAQ,MAAM,sBAAsB;IAC/E;AACA,UAAM,UACJ,KAAK,OAAO,SACR,IAAI,cAA4B;MAC9B,QAAQ,QAAQ;MAChB,QAAQ;;MACR,IAAI,KAAK;MACT,GAAI,QAAQ,WAAW,UAAa,EAAE,QAAQ,QAAQ,OAAO;IAC/D,CAAC,IACD,IAAI,gBAA8B;MAChC,QAAQ,QAAQ;MAChB,GAAI,QAAQ,WAAW,UAAa,EAAE,QAAQ,QAAQ,OAAO;IAC/D,CAAC;AAEP,SAAK,SAAS,IAAI,QAAQ,QAAQ,OAA2C;AAC7E,WAAO;EACT;;;;;;;;;;;;;;EAeA,OACE,QACA,SAC8B;AAC9B,SAAK,WAAW;AAChB,QAAI,KAAK,SAAS,IAAI,MAAM,GAAG;AAC7B,YAAM,IAAI,MAAM,yBAAyB,MAAM,sBAAsB;IACvE;AAEA,SAAK,SAAS,IAAI,QAAQ,OAA2C;AACrE,WAAO;EACT;;;;;;EAOA,IAAkB,QAA0D;AAC1E,SAAK,WAAW;AAChB,UAAM,UAAU,KAAK,SAAS,IAAI,MAAM;AACxC,WAAO;EACT;;EAGA,UAA6B;AAC3B,WAAO,CAAC,GAAG,KAAK,SAAS,KAAK,CAAC;EACjC;;;;;EAMA,MAAM,QAAuB;AAC3B,QAAI,KAAK,OAAQ;AACjB,SAAK,SAAS;AACd,eAAW,WAAW,KAAK,SAAS,OAAO,GAAG;AAC5C,YAAM,QAAQ,MAAM;IACtB;AACA,SAAK,SAAS,MAAM;AACpB,QAAI,KAAK,OAAO,OAAW,MAAK,GAAG,MAAM;EAC3C;EAEQ,aAAmB;AACzB,QAAI,KAAK,QAAQ;AACf,YAAM,IAAI,MAAM,kCAAkC;IACpD;EACF;AACF;AAMA,IAAI,iBAAwC;AAUrC,SAAS,oBAAoC;AAClD,MAAI,mBAAmB,MAAM;AAI3B,UAAM,SAAS,qBAAqB;AACpC,qBAAiB,IAAI,eAAe,EAAE,OAAO,CAAC;EAChD;AACA,SAAO;AACT;AAOO,SAAS,kBAAkB,UAAuC;AACvE,mBAAiB;AACnB;AAGA,eAAsB,sBAAqC;AACzD,MAAI,mBAAmB,MAAM;AAC3B,UAAM,eAAe,MAAM;AAC3B,qBAAiB;EACnB;AACF;AAEA,SAAS,uBAA+B;AAGtC,QAAM,OAAO,QAAQ,IAAI,gBAAgB,KAAK,GAAG,QAAQ,IAAI,MAAM,KAAK,MAAM;AAC9E,SAAO,GAAG,IAAI;AAChB;ACvKO,SAAS,+BAA+C;AAC7D,SAAO,IAAI,eAAe;;EAE1B,CAAC;AACH;AAOO,SAAS,2BAA2B,QAAgC;AACzE,SAAO,IAAI,eAAe,EAAE,OAAO,CAAC;AACtC;ACAA,IAAM,YAAY,oBAAI,IAAsB;AAGrC,SAAS,iBAAiB,UAA0B;AACzD,MAAI,UAAU,IAAI,SAAS,EAAE,GAAG;AAC9B,UAAM,IAAI,MAAM,2BAA2B,SAAS,EAAE,sBAAsB;EAC9E;AACA,YAAU,IAAI,SAAS,IAAI,QAAQ;AACrC;AAGO,SAAS,iBAAuB;AACrC,YAAU,MAAM;AAClB;AAGO,SAAS,gBAAmC;AACjD,SAAO,CAAC,GAAG,UAAU,KAAK,CAAC;AAC7B;AAmBA,eAAsB,aACpB,UACA,SAC4F;AAC5F,YAAU,QAAQ,WAAW,EAAE,WAAW,KAAK,CAAC;AAChD,QAAM,OAAsB,CAAC;AAC7B,QAAM,SAAyC,CAAC;AAChD,aAAW,YAAY,UAAU,OAAO,GAAG;AACzC,UAAM,SAAS,KAAK,QAAQ,WAAW,aAAa,SAAS,EAAE,EAAE;AACjE,QAAI,QAAQ,UAAU,QAAQ,WAAW,MAAM,EAAG;AAClD,QAAI;AACF,YAAM,MAAM,MAAM,SAAS,IAAI,QAAQ;AACvC,kBAAY,QAAQ,GAAG;AACvB,WAAK,KAAK,GAAG;IACf,SAAS,KAAK;AACZ,aAAO,KAAK,EAAE,IAAI,SAAS,IAAI,OAAO,eAAe,QAAQ,MAAM,IAAI,MAAM,OAAO,GAAG,CAAC,EAAE,CAAC;IAC7F;EACF;AACA,SAAO,EAAE,MAAM,OAAO;AACxB;AAEA,SAAS,YAAY,MAAc,KAAwB;AACzD,YAAU,QAAQ,IAAI,GAAG,EAAE,WAAW,KAAK,CAAC;AAC5C;IACE;IACA,KAAK,UAAU,EAAE,GAAG,KAAK,cAAa,oBAAI,KAAK,GAAE,YAAY,EAAE,GAAG,MAAM,CAAC;IACzE;EACF;AACF;AAOO,SAAS,iBAAiB,YAAmC;AAClE,MAAI,CAAC,WAAW,UAAU,EAAG,QAAO;AACpC,QAAM,SAAS,GAAG,UAAU,QAAQ,OAAO,KAAK,IAAI,CAAC,CAAC;AACtD,aAAW,YAAY,MAAM;AAC7B,SAAO;AACT;","names":["Database"]}
|