@harperfast/harper 5.0.30 → 5.1.0-beta.2
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/README.md +11 -10
- package/agent/agent.ts +203 -0
- package/agent/loop.ts +205 -0
- package/agent/operations.ts +148 -0
- package/agent/session.ts +187 -0
- package/agent/tools/fsTools.ts +276 -0
- package/agent/tools/httpFetchTool.ts +112 -0
- package/agent/tools/scheduleTool.ts +68 -0
- package/agent/toolset.ts +43 -0
- package/agent/types.ts +85 -0
- package/bin/{BinObjects.js → BinObjects.ts} +4 -5
- package/bin/cliCredentials.ts +133 -0
- package/bin/cliOperations.ts +339 -0
- package/bin/copyDb.ts +10 -10
- package/bin/deployRenderer.ts +196 -0
- package/bin/{harper.js → harper.ts} +43 -19
- package/bin/{install.js → install.ts} +3 -3
- package/bin/lite.ts +2 -0
- package/bin/login.ts +134 -0
- package/bin/logout.ts +11 -0
- package/bin/mcp/client.ts +407 -0
- package/bin/mcp/doctor.ts +189 -0
- package/bin/mcp/index.ts +80 -0
- package/bin/mcp/options.ts +122 -0
- package/bin/mcp/printConfig.ts +89 -0
- package/bin/multipartBuilder.ts +74 -0
- package/bin/{restart.js → restart.ts} +27 -28
- package/bin/{run.js → run.ts} +41 -30
- package/bin/sseConsumer.ts +126 -0
- package/bin/{status.js → status.ts} +10 -10
- package/bin/{stop.js → stop.ts} +5 -5
- package/bin/upgrade.js +17 -24
- package/components/Application.ts +144 -18
- package/components/ApplicationScope.ts +2 -2
- package/components/ComponentV1.ts +2 -2
- package/components/EntryHandler.ts +159 -9
- package/components/OptionsWatcher.ts +75 -11
- package/components/Scope.ts +132 -18
- package/components/anthropic/index.ts +547 -0
- package/components/bedrock/index.ts +823 -0
- package/components/componentLoader.ts +64 -32
- package/components/deployLifecycle.ts +161 -0
- package/components/deploymentOperations.ts +173 -0
- package/components/deploymentRecorder.ts +427 -0
- package/components/deriveURLPath.ts +4 -4
- package/components/mcp/adapters/fastify.ts +87 -0
- package/components/mcp/adapters/harperHttp.ts +103 -0
- package/components/mcp/audit.ts +75 -0
- package/components/mcp/index.ts +134 -0
- package/components/mcp/jsonrpc.ts +134 -0
- package/components/mcp/lifecycle.ts +105 -0
- package/components/mcp/listChanged.ts +270 -0
- package/components/mcp/rateLimit.ts +217 -0
- package/components/mcp/resources.ts +607 -0
- package/components/mcp/session.ts +151 -0
- package/components/mcp/sessionRegistry.ts +140 -0
- package/components/mcp/toolRegistry.ts +294 -0
- package/components/mcp/tools/application.ts +761 -0
- package/components/mcp/tools/operations.ts +311 -0
- package/components/mcp/tools/schemas/derive.ts +356 -0
- package/components/mcp/tools/schemas/operationDescriptions.ts +241 -0
- package/components/mcp/tools/schemas/operations.ts +301 -0
- package/components/mcp/transport.ts +517 -0
- package/components/ollama/index.ts +316 -0
- package/components/openai/index.ts +563 -0
- package/components/operations.js +217 -60
- package/components/operationsValidation.js +12 -4
- package/components/packageComponent.ts +97 -29
- package/components/requestRestart.ts +17 -2
- package/components/status/crossThread.ts +14 -5
- package/components/status/errors.ts +1 -1
- package/config/RootConfigWatcher.ts +56 -2
- package/config/configUtils.js +29 -8
- package/config/harperConfigEnvVars.ts +1 -1
- package/config-root.schema.json +78 -4
- package/dataLayer/{CreateAttributeObject.js → CreateAttributeObject.ts} +4 -3
- package/dataLayer/{CreateTableObject.js → CreateTableObject.ts} +2 -1
- package/dataLayer/{DataLayerObjects.js → DataLayerObjects.ts} +17 -9
- package/dataLayer/{DeleteBeforeObject.js → DeleteBeforeObject.ts} +2 -1
- package/dataLayer/{DeleteObject.js → DeleteObject.ts} +3 -2
- package/dataLayer/{DropAttributeObject.js → DropAttributeObject.ts} +2 -1
- package/dataLayer/{GetBackupObject.js → GetBackupObject.ts} +3 -2
- package/dataLayer/{InsertObject.js → InsertObject.ts} +3 -2
- package/dataLayer/{ReadAuditLogObject.js → ReadAuditLogObject.ts} +3 -2
- package/dataLayer/{SQLSearch.js → SQLSearch.ts} +97 -43
- package/dataLayer/{SearchByConditionsObject.js → SearchByConditionsObject.ts} +5 -6
- package/dataLayer/{SearchByHashObject.js → SearchByHashObject.ts} +2 -1
- package/dataLayer/{SearchObject.js → SearchObject.ts} +2 -1
- package/dataLayer/{SqlSearchObject.js → SqlSearchObject.ts} +2 -1
- package/dataLayer/{UpdateObject.js → UpdateObject.ts} +3 -2
- package/dataLayer/{UpsertObject.js → UpsertObject.ts} +3 -2
- package/dataLayer/{bulkLoad.js → bulkLoad.ts} +40 -49
- package/dataLayer/{delete.js → delete.ts} +21 -26
- package/dataLayer/{export.js → export.ts} +22 -26
- package/dataLayer/{getBackup.js → getBackup.ts} +7 -9
- package/dataLayer/harperBridge/BridgeMethods.ts +102 -0
- package/dataLayer/harperBridge/ResourceBridge.ts +27 -26
- package/dataLayer/harperBridge/TableSizeObject.ts +1 -0
- package/dataLayer/harperBridge/bridgeUtility/insertUpdateValidate.js +4 -4
- package/dataLayer/harperBridge/{harperBridge.js → harperBridge.ts} +3 -3
- package/dataLayer/harperBridge/lmdbBridge/lmdbMethods/lmdbCreateAttribute.js +8 -6
- package/dataLayer/harperBridge/lmdbBridge/lmdbMethods/lmdbCreateRecords.js +4 -4
- package/dataLayer/harperBridge/lmdbBridge/lmdbMethods/lmdbCreateSchema.js +1 -1
- package/dataLayer/harperBridge/lmdbBridge/lmdbMethods/lmdbCreateTable.js +6 -4
- package/dataLayer/harperBridge/lmdbBridge/lmdbMethods/lmdbDeleteAuditLogsBefore.js +5 -4
- package/dataLayer/harperBridge/lmdbBridge/lmdbMethods/lmdbDeleteRecords.js +4 -4
- package/dataLayer/harperBridge/lmdbBridge/lmdbMethods/lmdbDropAttribute.js +6 -5
- package/dataLayer/harperBridge/lmdbBridge/lmdbMethods/lmdbDropSchema.js +5 -4
- package/dataLayer/harperBridge/lmdbBridge/lmdbMethods/lmdbDropTable.js +5 -5
- package/dataLayer/harperBridge/lmdbBridge/lmdbMethods/lmdbFlush.js +1 -1
- package/dataLayer/harperBridge/lmdbBridge/lmdbMethods/lmdbGetBackup.js +3 -3
- package/dataLayer/harperBridge/lmdbBridge/lmdbMethods/lmdbGetDataByHash.js +1 -1
- package/dataLayer/harperBridge/lmdbBridge/lmdbMethods/lmdbGetDataByValue.js +3 -2
- package/dataLayer/harperBridge/lmdbBridge/lmdbMethods/lmdbReadAuditLog.js +5 -5
- package/dataLayer/harperBridge/lmdbBridge/lmdbMethods/lmdbSearchByConditions.js +10 -8
- package/dataLayer/harperBridge/lmdbBridge/lmdbMethods/lmdbSearchByHash.js +1 -1
- package/dataLayer/harperBridge/lmdbBridge/lmdbMethods/lmdbSearchByValue.js +4 -3
- package/dataLayer/harperBridge/lmdbBridge/lmdbMethods/lmdbUpdateRecords.js +3 -3
- package/dataLayer/harperBridge/lmdbBridge/lmdbMethods/lmdbUpsertRecords.js +6 -5
- package/dataLayer/harperBridge/lmdbBridge/lmdbUtility/LMDBCreateAttributeObject.js +2 -1
- package/dataLayer/harperBridge/lmdbBridge/lmdbUtility/initializeHashSearch.js +3 -2
- package/dataLayer/harperBridge/lmdbBridge/lmdbUtility/initializePaths.js +2 -2
- package/dataLayer/harperBridge/lmdbBridge/lmdbUtility/lmdbCheckForNewAttributes.js +5 -4
- package/dataLayer/harperBridge/lmdbBridge/lmdbUtility/lmdbCreateTransactionsAuditEnvironment.js +6 -3
- package/dataLayer/harperBridge/lmdbBridge/lmdbUtility/lmdbGetTableSize.ts +1 -1
- package/dataLayer/harperBridge/lmdbBridge/lmdbUtility/lmdbProcessRows.js +4 -4
- package/dataLayer/harperBridge/lmdbBridge/lmdbUtility/lmdbSearch.js +5 -5
- package/dataLayer/harperBridge/lmdbBridge/lmdbUtility/lmdbWriteTransaction.js +4 -4
- package/dataLayer/{hdbInfoController.js → hdbInfoController.ts} +20 -26
- package/dataLayer/{insert.js → insert.ts} +24 -24
- package/dataLayer/{readAuditLog.js → readAuditLog.ts} +8 -10
- package/dataLayer/{schema.js → schema.ts} +32 -44
- package/dataLayer/{schemaDescribe.js → schemaDescribe.ts} +23 -26
- package/dataLayer/{search.js → search.ts} +9 -15
- package/dataLayer/{transaction.js → transaction.ts} +2 -5
- package/dataLayer/{update.js → update.ts} +19 -22
- package/dist/agent/agent.d.ts +35 -0
- package/dist/agent/agent.js +175 -0
- package/dist/agent/agent.js.map +1 -0
- package/dist/agent/loop.d.ts +34 -0
- package/dist/agent/loop.js +176 -0
- package/dist/agent/loop.js.map +1 -0
- package/dist/agent/operations.d.ts +17 -0
- package/dist/agent/operations.js +137 -0
- package/dist/agent/operations.js.map +1 -0
- package/dist/agent/session.d.ts +36 -0
- package/dist/agent/session.js +182 -0
- package/dist/agent/session.js.map +1 -0
- package/dist/agent/tools/fsTools.d.ts +19 -0
- package/dist/agent/tools/fsTools.js +286 -0
- package/dist/agent/tools/fsTools.js.map +1 -0
- package/dist/agent/tools/httpFetchTool.d.ts +9 -0
- package/dist/agent/tools/httpFetchTool.js +116 -0
- package/dist/agent/tools/httpFetchTool.js.map +1 -0
- package/dist/agent/tools/scheduleTool.d.ts +22 -0
- package/dist/agent/tools/scheduleTool.js +54 -0
- package/dist/agent/tools/scheduleTool.js.map +1 -0
- package/dist/agent/toolset.d.ts +24 -0
- package/dist/agent/toolset.js +33 -0
- package/dist/agent/toolset.js.map +1 -0
- package/dist/agent/types.d.ts +75 -0
- package/dist/agent/types.js +10 -0
- package/dist/agent/types.js.map +1 -0
- package/dist/bin/BinObjects.d.ts +2 -2
- package/dist/bin/BinObjects.js +6 -3
- package/dist/bin/BinObjects.js.map +1 -1
- package/dist/bin/cliCredentials.d.ts +27 -0
- package/dist/bin/cliCredentials.js +130 -0
- package/dist/bin/cliCredentials.js.map +1 -0
- package/dist/bin/cliOperations.d.ts +7 -7
- package/dist/bin/cliOperations.js +251 -37
- package/dist/bin/cliOperations.js.map +1 -1
- package/dist/bin/copyDb.js +16 -16
- package/dist/bin/copyDb.js.map +1 -1
- package/dist/bin/deployRenderer.d.ts +47 -0
- package/dist/bin/deployRenderer.js +185 -0
- package/dist/bin/deployRenderer.js.map +1 -0
- package/dist/bin/harper.d.ts +2 -1
- package/dist/bin/harper.js +87 -26
- package/dist/bin/harper.js.map +1 -1
- package/dist/bin/install.d.ts +1 -1
- package/dist/bin/install.js +41 -4
- package/dist/bin/install.js.map +1 -1
- package/dist/bin/lite.js +3 -4
- package/dist/bin/lite.js.map +1 -1
- package/dist/bin/login.d.ts +4 -0
- package/dist/bin/login.js +123 -0
- package/dist/bin/login.js.map +1 -0
- package/dist/bin/logout.d.ts +4 -0
- package/dist/bin/logout.js +16 -0
- package/dist/bin/logout.js.map +1 -0
- package/dist/bin/mcp/client.d.ts +34 -0
- package/dist/bin/mcp/client.js +395 -0
- package/dist/bin/mcp/client.js.map +1 -0
- package/dist/bin/mcp/doctor.d.ts +11 -0
- package/dist/bin/mcp/doctor.js +193 -0
- package/dist/bin/mcp/doctor.js.map +1 -0
- package/dist/bin/mcp/index.d.ts +10 -0
- package/dist/bin/mcp/index.js +81 -0
- package/dist/bin/mcp/index.js.map +1 -0
- package/dist/bin/mcp/options.d.ts +33 -0
- package/dist/bin/mcp/options.js +113 -0
- package/dist/bin/mcp/options.js.map +1 -0
- package/dist/bin/mcp/printConfig.d.ts +14 -0
- package/dist/bin/mcp/printConfig.js +85 -0
- package/dist/bin/mcp/printConfig.js.map +1 -0
- package/dist/bin/multipartBuilder.d.ts +26 -0
- package/dist/bin/multipartBuilder.js +55 -0
- package/dist/bin/multipartBuilder.js.map +1 -0
- package/dist/bin/restart.d.ts +3 -2
- package/dist/bin/restart.js +82 -45
- package/dist/bin/restart.js.map +1 -1
- package/dist/bin/run.d.ts +13 -9
- package/dist/bin/run.js +111 -65
- package/dist/bin/run.js.map +1 -1
- package/dist/bin/sseConsumer.d.ts +24 -0
- package/dist/bin/sseConsumer.js +127 -0
- package/dist/bin/sseConsumer.js.map +1 -0
- package/dist/bin/status.d.ts +1 -1
- package/dist/bin/status.js +48 -11
- package/dist/bin/status.js.map +1 -1
- package/dist/bin/stop.d.ts +1 -1
- package/dist/bin/stop.js +43 -6
- package/dist/bin/stop.js.map +1 -1
- package/dist/bin/upgrade.js +14 -22
- package/dist/bin/upgrade.js.map +1 -1
- package/dist/components/Application.d.ts +29 -17
- package/dist/components/Application.js +134 -28
- package/dist/components/Application.js.map +1 -1
- package/dist/components/ApplicationScope.js +2 -2
- package/dist/components/ComponentV1.d.ts +1 -1
- package/dist/components/ComponentV1.js +5 -5
- package/dist/components/ComponentV1.js.map +1 -1
- package/dist/components/EntryHandler.d.ts +26 -3
- package/dist/components/EntryHandler.js +153 -13
- package/dist/components/EntryHandler.js.map +1 -1
- package/dist/components/OptionsWatcher.d.ts +7 -2
- package/dist/components/OptionsWatcher.js +72 -10
- package/dist/components/OptionsWatcher.js.map +1 -1
- package/dist/components/Scope.d.ts +11 -6
- package/dist/components/Scope.js +112 -12
- package/dist/components/Scope.js.map +1 -1
- package/dist/components/anthropic/index.d.ts +40 -0
- package/dist/components/anthropic/index.js +428 -0
- package/dist/components/anthropic/index.js.map +1 -0
- package/dist/components/bedrock/index.d.ts +79 -0
- package/dist/components/bedrock/index.js +734 -0
- package/dist/components/bedrock/index.js.map +1 -0
- package/dist/components/componentLoader.d.ts +29 -0
- package/dist/components/componentLoader.js +65 -38
- package/dist/components/componentLoader.js.map +1 -1
- package/dist/components/deployLifecycle.d.ts +39 -0
- package/dist/components/deployLifecycle.js +156 -0
- package/dist/components/deployLifecycle.js.map +1 -0
- package/dist/components/deploymentOperations.d.ts +19 -0
- package/dist/components/deploymentOperations.js +185 -0
- package/dist/components/deploymentOperations.js.map +1 -0
- package/dist/components/deploymentRecorder.d.ts +97 -0
- package/dist/components/deploymentRecorder.js +425 -0
- package/dist/components/deploymentRecorder.js.map +1 -0
- package/dist/components/deriveURLPath.d.ts +2 -2
- package/dist/components/deriveURLPath.js +2 -2
- package/dist/components/deriveURLPath.js.map +1 -1
- package/dist/components/mcp/adapters/fastify.d.ts +35 -0
- package/dist/components/mcp/adapters/fastify.js +66 -0
- package/dist/components/mcp/adapters/fastify.js.map +1 -0
- package/dist/components/mcp/adapters/harperHttp.d.ts +38 -0
- package/dist/components/mcp/adapters/harperHttp.js +78 -0
- package/dist/components/mcp/adapters/harperHttp.js.map +1 -0
- package/dist/components/mcp/audit.d.ts +27 -0
- package/dist/components/mcp/audit.js +73 -0
- package/dist/components/mcp/audit.js.map +1 -0
- package/dist/components/mcp/index.d.ts +47 -0
- package/dist/components/mcp/index.js +109 -0
- package/dist/components/mcp/index.js.map +1 -0
- package/dist/components/mcp/jsonrpc.d.ts +71 -0
- package/dist/components/mcp/jsonrpc.js +93 -0
- package/dist/components/mcp/jsonrpc.js.map +1 -0
- package/dist/components/mcp/lifecycle.d.ts +69 -0
- package/dist/components/mcp/lifecycle.js +79 -0
- package/dist/components/mcp/lifecycle.js.map +1 -0
- package/dist/components/mcp/listChanged.d.ts +24 -0
- package/dist/components/mcp/listChanged.js +257 -0
- package/dist/components/mcp/listChanged.js.map +1 -0
- package/dist/components/mcp/rateLimit.d.ts +25 -0
- package/dist/components/mcp/rateLimit.js +226 -0
- package/dist/components/mcp/rateLimit.js.map +1 -0
- package/dist/components/mcp/resources.d.ts +90 -0
- package/dist/components/mcp/resources.js +526 -0
- package/dist/components/mcp/resources.js.map +1 -0
- package/dist/components/mcp/session.d.ts +36 -0
- package/dist/components/mcp/session.js +170 -0
- package/dist/components/mcp/session.js.map +1 -0
- package/dist/components/mcp/sessionRegistry.d.ts +63 -0
- package/dist/components/mcp/sessionRegistry.js +124 -0
- package/dist/components/mcp/sessionRegistry.js.map +1 -0
- package/dist/components/mcp/toolRegistry.d.ts +151 -0
- package/dist/components/mcp/toolRegistry.js +177 -0
- package/dist/components/mcp/toolRegistry.js.map +1 -0
- package/dist/components/mcp/tools/application.d.ts +72 -0
- package/dist/components/mcp/tools/application.js +660 -0
- package/dist/components/mcp/tools/application.js.map +1 -0
- package/dist/components/mcp/tools/operations.d.ts +23 -0
- package/dist/components/mcp/tools/operations.js +331 -0
- package/dist/components/mcp/tools/operations.js.map +1 -0
- package/dist/components/mcp/tools/schemas/derive.d.ts +50 -0
- package/dist/components/mcp/tools/schemas/derive.js +291 -0
- package/dist/components/mcp/tools/schemas/derive.js.map +1 -0
- package/dist/components/mcp/tools/schemas/operationDescriptions.d.ts +32 -0
- package/dist/components/mcp/tools/schemas/operationDescriptions.js +179 -0
- package/dist/components/mcp/tools/schemas/operationDescriptions.js.map +1 -0
- package/dist/components/mcp/tools/schemas/operations.d.ts +27 -0
- package/dist/components/mcp/tools/schemas/operations.js +299 -0
- package/dist/components/mcp/tools/schemas/operations.js.map +1 -0
- package/dist/components/mcp/transport.d.ts +38 -0
- package/dist/components/mcp/transport.js +467 -0
- package/dist/components/mcp/transport.js.map +1 -0
- package/dist/components/ollama/index.d.ts +46 -0
- package/dist/components/ollama/index.js +239 -0
- package/dist/components/ollama/index.js.map +1 -0
- package/dist/components/openai/index.d.ts +51 -0
- package/dist/components/openai/index.js +475 -0
- package/dist/components/openai/index.js.map +1 -0
- package/dist/components/operations.d.ts +6 -6
- package/dist/components/operations.js +205 -52
- package/dist/components/operations.js.map +1 -1
- package/dist/components/operationsValidation.d.ts +2 -2
- package/dist/components/operationsValidation.js +13 -4
- package/dist/components/operationsValidation.js.map +1 -1
- package/dist/components/packageComponent.d.ts +28 -6
- package/dist/components/packageComponent.js +87 -26
- package/dist/components/packageComponent.js.map +1 -1
- package/dist/components/requestRestart.d.ts +1 -0
- package/dist/components/requestRestart.js +12 -1
- package/dist/components/requestRestart.js.map +1 -1
- package/dist/components/status/crossThread.d.ts +5 -1
- package/dist/components/status/crossThread.js +12 -5
- package/dist/components/status/crossThread.js.map +1 -1
- package/dist/components/status/errors.js +7 -7
- package/dist/config/RootConfigWatcher.d.ts +3 -0
- package/dist/config/RootConfigWatcher.js +52 -1
- package/dist/config/RootConfigWatcher.js.map +1 -1
- package/dist/config/configUtils.js +31 -8
- package/dist/config/configUtils.js.map +1 -1
- package/dist/config/harperConfigEnvVars.js +1 -1
- package/dist/config/harperConfigEnvVars.js.map +1 -1
- package/dist/dataLayer/CreateAttributeObject.d.ts +3 -7
- package/dist/dataLayer/CreateAttributeObject.js +4 -3
- package/dist/dataLayer/CreateAttributeObject.js.map +1 -1
- package/dist/dataLayer/CreateTableObject.d.ts +2 -4
- package/dist/dataLayer/CreateTableObject.js +2 -1
- package/dist/dataLayer/CreateTableObject.js.map +1 -1
- package/dist/dataLayer/DataLayerObjects.d.ts +17 -16
- package/dist/dataLayer/DataLayerObjects.js +19 -5
- package/dist/dataLayer/DataLayerObjects.js.map +1 -1
- package/dist/dataLayer/DeleteBeforeObject.d.ts +3 -5
- package/dist/dataLayer/DeleteBeforeObject.js +2 -1
- package/dist/dataLayer/DeleteBeforeObject.js.map +1 -1
- package/dist/dataLayer/DeleteObject.d.ts +3 -7
- package/dist/dataLayer/DeleteObject.js +4 -3
- package/dist/dataLayer/DeleteObject.js.map +1 -1
- package/dist/dataLayer/DropAttributeObject.d.ts +2 -4
- package/dist/dataLayer/DropAttributeObject.js +2 -1
- package/dist/dataLayer/DropAttributeObject.js.map +1 -1
- package/dist/dataLayer/GetBackupObject.d.ts +3 -5
- package/dist/dataLayer/GetBackupObject.js +4 -3
- package/dist/dataLayer/GetBackupObject.js.map +1 -1
- package/dist/dataLayer/InsertObject.d.ts +3 -8
- package/dist/dataLayer/InsertObject.js +4 -3
- package/dist/dataLayer/InsertObject.js.map +1 -1
- package/dist/dataLayer/ReadAuditLogObject.d.ts +3 -7
- package/dist/dataLayer/ReadAuditLogObject.js +4 -3
- package/dist/dataLayer/ReadAuditLogObject.js.map +1 -1
- package/dist/dataLayer/SQLSearch.d.ts +68 -38
- package/dist/dataLayer/SQLSearch.js +140 -78
- package/dist/dataLayer/SQLSearch.js.map +1 -1
- package/dist/dataLayer/SearchByConditionsObject.d.ts +10 -58
- package/dist/dataLayer/SearchByConditionsObject.js +5 -7
- package/dist/dataLayer/SearchByConditionsObject.js.map +1 -1
- package/dist/dataLayer/SearchByHashObject.d.ts +3 -6
- package/dist/dataLayer/SearchByHashObject.js +2 -1
- package/dist/dataLayer/SearchByHashObject.js.map +1 -1
- package/dist/dataLayer/SearchObject.d.ts +3 -12
- package/dist/dataLayer/SearchObject.js +2 -1
- package/dist/dataLayer/SearchObject.js.map +1 -1
- package/dist/dataLayer/SqlSearchObject.d.ts +2 -4
- package/dist/dataLayer/SqlSearchObject.js +2 -1
- package/dist/dataLayer/SqlSearchObject.js.map +1 -1
- package/dist/dataLayer/UpdateObject.d.ts +3 -7
- package/dist/dataLayer/UpdateObject.js +4 -3
- package/dist/dataLayer/UpdateObject.js.map +1 -1
- package/dist/dataLayer/UpsertObject.d.ts +3 -7
- package/dist/dataLayer/UpsertObject.js +4 -3
- package/dist/dataLayer/UpsertObject.js.map +1 -1
- package/dist/dataLayer/bulkLoad.d.ts +4 -4
- package/dist/dataLayer/bulkLoad.js +122 -88
- package/dist/dataLayer/bulkLoad.js.map +1 -1
- package/dist/dataLayer/delete.d.ts +10 -11
- package/dist/dataLayer/delete.js +74 -39
- package/dist/dataLayer/delete.js.map +1 -1
- package/dist/dataLayer/export.d.ts +8 -8
- package/dist/dataLayer/export.js +90 -55
- package/dist/dataLayer/export.js.map +1 -1
- package/dist/dataLayer/getBackup.d.ts +4 -3
- package/dist/dataLayer/getBackup.js +43 -11
- package/dist/dataLayer/getBackup.js.map +1 -1
- package/dist/dataLayer/harperBridge/BridgeMethods.d.ts +39 -21
- package/dist/dataLayer/harperBridge/BridgeMethods.js +41 -20
- package/dist/dataLayer/harperBridge/BridgeMethods.js.map +1 -1
- package/dist/dataLayer/harperBridge/ResourceBridge.d.ts +2 -2
- package/dist/dataLayer/harperBridge/ResourceBridge.js +26 -25
- package/dist/dataLayer/harperBridge/ResourceBridge.js.map +1 -1
- package/dist/dataLayer/harperBridge/TableSizeObject.d.ts +1 -0
- package/dist/dataLayer/harperBridge/TableSizeObject.js.map +1 -1
- package/dist/dataLayer/harperBridge/bridgeUtility/insertUpdateValidate.d.ts +4 -4
- package/dist/dataLayer/harperBridge/bridgeUtility/insertUpdateValidate.js +4 -4
- package/dist/dataLayer/harperBridge/harperBridge.d.ts +2 -3
- package/dist/dataLayer/harperBridge/harperBridge.js +38 -4
- package/dist/dataLayer/harperBridge/harperBridge.js.map +1 -1
- package/dist/dataLayer/harperBridge/lmdbBridge/lmdbMethods/lmdbCreateAttribute.d.ts +1 -2
- package/dist/dataLayer/harperBridge/lmdbBridge/lmdbMethods/lmdbCreateAttribute.js +7 -6
- package/dist/dataLayer/harperBridge/lmdbBridge/lmdbMethods/lmdbCreateAttribute.js.map +1 -1
- package/dist/dataLayer/harperBridge/lmdbBridge/lmdbMethods/lmdbCreateRecords.d.ts +1 -2
- package/dist/dataLayer/harperBridge/lmdbBridge/lmdbMethods/lmdbCreateRecords.js +4 -4
- package/dist/dataLayer/harperBridge/lmdbBridge/lmdbMethods/lmdbCreateRecords.js.map +1 -1
- package/dist/dataLayer/harperBridge/lmdbBridge/lmdbMethods/lmdbCreateSchema.js +1 -1
- package/dist/dataLayer/harperBridge/lmdbBridge/lmdbMethods/lmdbCreateSchema.js.map +1 -1
- package/dist/dataLayer/harperBridge/lmdbBridge/lmdbMethods/lmdbCreateTable.js +5 -4
- package/dist/dataLayer/harperBridge/lmdbBridge/lmdbMethods/lmdbCreateTable.js.map +1 -1
- package/dist/dataLayer/harperBridge/lmdbBridge/lmdbMethods/lmdbDeleteAuditLogsBefore.d.ts +1 -2
- package/dist/dataLayer/harperBridge/lmdbBridge/lmdbMethods/lmdbDeleteAuditLogsBefore.js +4 -4
- package/dist/dataLayer/harperBridge/lmdbBridge/lmdbMethods/lmdbDeleteAuditLogsBefore.js.map +1 -1
- package/dist/dataLayer/harperBridge/lmdbBridge/lmdbMethods/lmdbDeleteRecords.js +4 -4
- package/dist/dataLayer/harperBridge/lmdbBridge/lmdbMethods/lmdbDropAttribute.d.ts +1 -2
- package/dist/dataLayer/harperBridge/lmdbBridge/lmdbMethods/lmdbDropAttribute.js +5 -5
- package/dist/dataLayer/harperBridge/lmdbBridge/lmdbMethods/lmdbDropAttribute.js.map +1 -1
- package/dist/dataLayer/harperBridge/lmdbBridge/lmdbMethods/lmdbDropSchema.js +4 -4
- package/dist/dataLayer/harperBridge/lmdbBridge/lmdbMethods/lmdbDropSchema.js.map +1 -1
- package/dist/dataLayer/harperBridge/lmdbBridge/lmdbMethods/lmdbDropTable.js +5 -5
- package/dist/dataLayer/harperBridge/lmdbBridge/lmdbMethods/lmdbDropTable.js.map +1 -1
- package/dist/dataLayer/harperBridge/lmdbBridge/lmdbMethods/lmdbFlush.js +1 -1
- package/dist/dataLayer/harperBridge/lmdbBridge/lmdbMethods/lmdbGetBackup.js +3 -3
- package/dist/dataLayer/harperBridge/lmdbBridge/lmdbMethods/lmdbGetDataByHash.js +1 -1
- package/dist/dataLayer/harperBridge/lmdbBridge/lmdbMethods/lmdbGetDataByValue.js +2 -2
- package/dist/dataLayer/harperBridge/lmdbBridge/lmdbMethods/lmdbGetDataByValue.js.map +1 -1
- package/dist/dataLayer/harperBridge/lmdbBridge/lmdbMethods/lmdbReadAuditLog.js +5 -5
- package/dist/dataLayer/harperBridge/lmdbBridge/lmdbMethods/lmdbSearchByConditions.d.ts +1 -2
- package/dist/dataLayer/harperBridge/lmdbBridge/lmdbMethods/lmdbSearchByConditions.js +8 -8
- package/dist/dataLayer/harperBridge/lmdbBridge/lmdbMethods/lmdbSearchByConditions.js.map +1 -1
- package/dist/dataLayer/harperBridge/lmdbBridge/lmdbMethods/lmdbSearchByHash.d.ts +1 -1
- package/dist/dataLayer/harperBridge/lmdbBridge/lmdbMethods/lmdbSearchByHash.js +1 -1
- package/dist/dataLayer/harperBridge/lmdbBridge/lmdbMethods/lmdbSearchByValue.d.ts +1 -2
- package/dist/dataLayer/harperBridge/lmdbBridge/lmdbMethods/lmdbSearchByValue.js +3 -3
- package/dist/dataLayer/harperBridge/lmdbBridge/lmdbMethods/lmdbSearchByValue.js.map +1 -1
- package/dist/dataLayer/harperBridge/lmdbBridge/lmdbMethods/lmdbUpdateRecords.js +3 -3
- package/dist/dataLayer/harperBridge/lmdbBridge/lmdbMethods/lmdbUpsertRecords.d.ts +1 -2
- package/dist/dataLayer/harperBridge/lmdbBridge/lmdbMethods/lmdbUpsertRecords.js +5 -5
- package/dist/dataLayer/harperBridge/lmdbBridge/lmdbMethods/lmdbUpsertRecords.js.map +1 -1
- package/dist/dataLayer/harperBridge/lmdbBridge/lmdbUtility/LMDBCreateAttributeObject.d.ts +1 -2
- package/dist/dataLayer/harperBridge/lmdbBridge/lmdbUtility/LMDBCreateAttributeObject.js +1 -1
- package/dist/dataLayer/harperBridge/lmdbBridge/lmdbUtility/LMDBCreateAttributeObject.js.map +1 -1
- package/dist/dataLayer/harperBridge/lmdbBridge/lmdbUtility/initializeHashSearch.js +2 -2
- package/dist/dataLayer/harperBridge/lmdbBridge/lmdbUtility/initializeHashSearch.js.map +1 -1
- package/dist/dataLayer/harperBridge/lmdbBridge/lmdbUtility/initializePaths.js +2 -2
- package/dist/dataLayer/harperBridge/lmdbBridge/lmdbUtility/lmdbCheckForNewAttributes.js +4 -4
- package/dist/dataLayer/harperBridge/lmdbBridge/lmdbUtility/lmdbCheckForNewAttributes.js.map +1 -1
- package/dist/dataLayer/harperBridge/lmdbBridge/lmdbUtility/lmdbCreateTransactionsAuditEnvironment.d.ts +1 -2
- package/dist/dataLayer/harperBridge/lmdbBridge/lmdbUtility/lmdbCreateTransactionsAuditEnvironment.js +5 -3
- package/dist/dataLayer/harperBridge/lmdbBridge/lmdbUtility/lmdbCreateTransactionsAuditEnvironment.js.map +1 -1
- package/dist/dataLayer/harperBridge/lmdbBridge/lmdbUtility/lmdbGetTableSize.js +2 -2
- package/dist/dataLayer/harperBridge/lmdbBridge/lmdbUtility/lmdbProcessRows.d.ts +1 -2
- package/dist/dataLayer/harperBridge/lmdbBridge/lmdbUtility/lmdbProcessRows.js +4 -4
- package/dist/dataLayer/harperBridge/lmdbBridge/lmdbUtility/lmdbProcessRows.js.map +1 -1
- package/dist/dataLayer/harperBridge/lmdbBridge/lmdbUtility/lmdbSearch.js +5 -5
- package/dist/dataLayer/harperBridge/lmdbBridge/lmdbUtility/lmdbWriteTransaction.js +4 -4
- package/dist/dataLayer/hdbInfoController.d.ts +4 -8
- package/dist/dataLayer/hdbInfoController.js +66 -31
- package/dist/dataLayer/hdbInfoController.js.map +1 -1
- package/dist/dataLayer/insert.d.ts +14 -26
- package/dist/dataLayer/insert.js +63 -28
- package/dist/dataLayer/insert.js.map +1 -1
- package/dist/dataLayer/readAuditLog.d.ts +1 -3
- package/dist/dataLayer/readAuditLog.js +45 -13
- package/dist/dataLayer/readAuditLog.js.map +1 -1
- package/dist/dataLayer/schema.d.ts +10 -10
- package/dist/dataLayer/schema.js +124 -89
- package/dist/dataLayer/schema.js.map +1 -1
- package/dist/dataLayer/schemaDescribe.d.ts +4 -4
- package/dist/dataLayer/schemaDescribe.js +78 -41
- package/dist/dataLayer/schemaDescribe.js.map +1 -1
- package/dist/dataLayer/search.d.ts +4 -4
- package/dist/dataLayer/search.js +12 -13
- package/dist/dataLayer/search.js.map +1 -1
- package/dist/dataLayer/transaction.d.ts +1 -1
- package/dist/dataLayer/transaction.js +3 -4
- package/dist/dataLayer/transaction.js.map +1 -1
- package/dist/dataLayer/update.d.ts +2 -8
- package/dist/dataLayer/update.js +53 -18
- package/dist/dataLayer/update.js.map +1 -1
- package/dist/globals.d.ts +1 -1
- package/dist/globals.js +1 -0
- package/dist/globals.js.map +1 -1
- package/dist/index.d.ts +4 -0
- package/dist/index.js +4 -1
- package/dist/index.js.map +1 -1
- package/dist/json/systemSchema.json +65 -0
- package/dist/launchServiceScripts/launchHarperDB.d.ts +1 -0
- package/dist/launchServiceScripts/launchHarperDB.js +3 -0
- package/dist/launchServiceScripts/launchHarperDB.js.map +1 -0
- package/dist/launchServiceScripts/utility/checkNodeVersion.js +3 -0
- package/dist/launchServiceScripts/utility/checkNodeVersion.js.map +1 -1
- package/dist/resources/DatabaseTransaction.d.ts +14 -6
- package/dist/resources/DatabaseTransaction.js +39 -15
- package/dist/resources/DatabaseTransaction.js.map +1 -1
- package/dist/resources/ErrorResource.d.ts +1 -1
- package/dist/resources/ErrorResource.js +3 -1
- package/dist/resources/ErrorResource.js.map +1 -1
- package/dist/resources/LMDBTransaction.d.ts +10 -13
- package/dist/resources/LMDBTransaction.js +18 -7
- package/dist/resources/LMDBTransaction.js.map +1 -1
- package/dist/resources/RecordEncoder.d.ts +10 -12
- package/dist/resources/RecordEncoder.js +38 -38
- package/dist/resources/RecordEncoder.js.map +1 -1
- package/dist/resources/RequestTarget.d.ts +1 -0
- package/dist/resources/RequestTarget.js.map +1 -1
- package/dist/resources/Resource.d.ts +25 -5
- package/dist/resources/Resource.js +43 -10
- package/dist/resources/Resource.js.map +1 -1
- package/dist/resources/ResourceInterface.d.ts +24 -5
- package/dist/resources/ResourceInterface.js +20 -0
- package/dist/resources/ResourceInterface.js.map +1 -1
- package/dist/resources/Resources.d.ts +3 -4
- package/dist/resources/Resources.js +7 -6
- package/dist/resources/Resources.js.map +1 -1
- package/dist/resources/RocksIndexStore.js +3 -0
- package/dist/resources/RocksIndexStore.js.map +1 -1
- package/dist/resources/RocksTransactionLogStore.d.ts +1 -1
- package/dist/resources/RocksTransactionLogStore.js +10 -3
- package/dist/resources/RocksTransactionLogStore.js.map +1 -1
- package/dist/resources/Table.d.ts +76 -329
- package/dist/resources/Table.js +306 -116
- package/dist/resources/Table.js.map +1 -1
- package/dist/resources/analytics/metadata.d.ts +1 -0
- package/dist/resources/analytics/metadata.js +1 -0
- package/dist/resources/analytics/metadata.js.map +1 -1
- package/dist/resources/analytics/read.d.ts +8 -1
- package/dist/resources/analytics/read.js +69 -8
- package/dist/resources/analytics/read.js.map +1 -1
- package/dist/resources/analytics/write.d.ts +28 -0
- package/dist/resources/analytics/write.js +232 -20
- package/dist/resources/analytics/write.js.map +1 -1
- package/dist/resources/auditStore.d.ts +18 -13
- package/dist/resources/auditStore.js +16 -8
- package/dist/resources/auditStore.js.map +1 -1
- package/dist/resources/blob.d.ts +16 -27
- package/dist/resources/blob.js +8 -8
- package/dist/resources/blob.js.map +1 -1
- package/dist/resources/dataLoader.d.ts +1 -1
- package/dist/resources/dataLoader.js +13 -13
- package/dist/resources/databases.d.ts +17 -0
- package/dist/resources/databases.js +175 -59
- package/dist/resources/databases.js.map +1 -1
- package/dist/resources/graphql.d.ts +1 -7
- package/dist/resources/graphql.js +267 -173
- package/dist/resources/graphql.js.map +1 -1
- package/dist/resources/indexes/HierarchicalNavigableSmallWorld.d.ts +17 -1
- package/dist/resources/indexes/HierarchicalNavigableSmallWorld.js +327 -59
- package/dist/resources/indexes/HierarchicalNavigableSmallWorld.js.map +1 -1
- package/dist/resources/indexes/vector.d.ts +1 -0
- package/dist/resources/indexes/vector.js +14 -0
- package/dist/resources/indexes/vector.js.map +1 -1
- package/dist/resources/jsonSchemaTypes.d.ts +60 -0
- package/dist/resources/jsonSchemaTypes.js +78 -0
- package/dist/resources/jsonSchemaTypes.js.map +1 -0
- package/dist/resources/loadEnv.d.ts +2 -5
- package/dist/resources/loadEnv.js +21 -18
- package/dist/resources/loadEnv.js.map +1 -1
- package/dist/resources/login.d.ts +2 -3
- package/dist/resources/login.js +5 -4
- package/dist/resources/login.js.map +1 -1
- package/dist/resources/models/Models.d.ts +45 -0
- package/dist/resources/models/Models.js +265 -0
- package/dist/resources/models/Models.js.map +1 -0
- package/dist/resources/models/TestBackend.d.ts +15 -0
- package/dist/resources/models/TestBackend.js +71 -0
- package/dist/resources/models/TestBackend.js.map +1 -0
- package/dist/resources/models/agentLoop.d.ts +125 -0
- package/dist/resources/models/agentLoop.js +746 -0
- package/dist/resources/models/agentLoop.js.map +1 -0
- package/dist/resources/models/analyticsTable.d.ts +65 -0
- package/dist/resources/models/analyticsTable.js +166 -0
- package/dist/resources/models/analyticsTable.js.map +1 -0
- package/dist/resources/models/backendHelpers.d.ts +57 -0
- package/dist/resources/models/backendHelpers.js +109 -0
- package/dist/resources/models/backendHelpers.js.map +1 -0
- package/dist/resources/models/backendRegistry.d.ts +36 -0
- package/dist/resources/models/backendRegistry.js +54 -0
- package/dist/resources/models/backendRegistry.js.map +1 -0
- package/dist/resources/models/bootstrap.d.ts +24 -0
- package/dist/resources/models/bootstrap.js +112 -0
- package/dist/resources/models/bootstrap.js.map +1 -0
- package/dist/resources/models/embedHook.d.ts +33 -0
- package/dist/resources/models/embedHook.js +127 -0
- package/dist/resources/models/embedHook.js.map +1 -0
- package/dist/resources/models/types.d.ts +301 -0
- package/dist/resources/models/types.js +11 -0
- package/dist/resources/models/types.js.map +1 -0
- package/dist/resources/openApi.js +74 -34
- package/dist/resources/openApi.js.map +1 -1
- package/dist/resources/replayLogs.js +7 -1
- package/dist/resources/replayLogs.js.map +1 -1
- package/dist/resources/replayLogsGuards.d.ts +9 -0
- package/dist/resources/replayLogsGuards.js +47 -0
- package/dist/resources/replayLogsGuards.js.map +1 -1
- package/dist/resources/roles.d.ts +1 -7
- package/dist/resources/roles.js +67 -71
- package/dist/resources/roles.js.map +1 -1
- package/dist/resources/search.d.ts +18 -1
- package/dist/resources/search.js +349 -140
- package/dist/resources/search.js.map +1 -1
- package/dist/resources/tracked.d.ts +1 -1
- package/dist/resources/tracked.js +23 -15
- package/dist/resources/tracked.js.map +1 -1
- package/dist/resources/transaction.d.ts +1 -1
- package/dist/resources/transaction.js +1 -1
- package/dist/resources/transaction.js.map +1 -1
- package/dist/resources/transactionBroadcast.d.ts +1 -1
- package/dist/resources/transactionBroadcast.js.map +1 -1
- package/dist/security/auth.d.ts +1 -5
- package/dist/security/auth.js +34 -25
- package/dist/security/auth.js.map +1 -1
- package/dist/security/certificateVerification/crlVerification.js +7 -1
- package/dist/security/certificateVerification/crlVerification.js.map +1 -1
- package/dist/security/cryptoHash.d.ts +2 -2
- package/dist/security/cryptoHash.js +37 -5
- package/dist/security/cryptoHash.js.map +1 -1
- package/dist/security/data_objects/PermissionAttributeResponseObject.d.ts +3 -4
- package/dist/security/data_objects/PermissionAttributeResponseObject.js +4 -1
- package/dist/security/data_objects/PermissionAttributeResponseObject.js.map +1 -1
- package/dist/security/data_objects/PermissionResponseObject.d.ts +9 -9
- package/dist/security/data_objects/PermissionResponseObject.js +15 -8
- package/dist/security/data_objects/PermissionResponseObject.js.map +1 -1
- package/dist/security/data_objects/PermissionTableResponseObject.d.ts +5 -6
- package/dist/security/data_objects/PermissionTableResponseObject.js +6 -1
- package/dist/security/data_objects/PermissionTableResponseObject.js.map +1 -1
- package/dist/security/fastifyAuth.d.ts +2 -2
- package/dist/security/fastifyAuth.js +131 -22
- package/dist/security/fastifyAuth.js.map +1 -1
- package/dist/security/impersonation.js +15 -15
- package/dist/security/jsLoader.js +18 -5
- package/dist/security/jsLoader.js.map +1 -1
- package/dist/security/keys.d.ts +45 -48
- package/dist/security/keys.js +160 -114
- package/dist/security/keys.js.map +1 -1
- package/dist/security/permissionsTranslator.js +2 -2
- package/dist/security/role.d.ts +5 -5
- package/dist/security/role.js +70 -35
- package/dist/security/role.js.map +1 -1
- package/dist/security/tokenAuthentication.d.ts +13 -0
- package/dist/security/tokenAuthentication.js +57 -27
- package/dist/security/tokenAuthentication.js.map +1 -1
- package/dist/security/user.js +74 -38
- package/dist/security/user.js.map +1 -1
- package/dist/server/DurableSubscriptionsSession.d.ts +4 -2
- package/dist/server/DurableSubscriptionsSession.js +71 -55
- package/dist/server/DurableSubscriptionsSession.js.map +1 -1
- package/dist/server/REST.d.ts +1 -8
- package/dist/server/REST.js +17 -16
- package/dist/server/REST.js.map +1 -1
- package/dist/server/Server.d.ts +23 -4
- package/dist/server/Server.js +1 -1
- package/dist/server/Server.js.map +1 -1
- package/dist/server/fastifyRoutes/helpers/getCORSOptions.js +1 -1
- package/dist/server/fastifyRoutes/helpers/getHeaderTimeoutConfig.js +1 -1
- package/dist/server/fastifyRoutes/helpers/getServerOptions.js +1 -1
- package/dist/server/fastifyRoutes.d.ts +1 -4
- package/dist/server/fastifyRoutes.js +34 -30
- package/dist/server/fastifyRoutes.js.map +1 -1
- package/dist/server/graphqlQuerying.d.ts +1 -1
- package/dist/server/graphqlQuerying.js +8 -7
- package/dist/server/graphqlQuerying.js.map +1 -1
- package/dist/server/http.d.ts +9 -4
- package/dist/server/http.js +523 -47
- package/dist/server/http.js.map +1 -1
- package/dist/server/itc/serverHandlers.js +66 -15
- package/dist/server/itc/serverHandlers.js.map +1 -1
- package/dist/server/jobs/JobObject.d.ts +3 -3
- package/dist/server/jobs/JobObject.js +53 -7
- package/dist/server/jobs/JobObject.js.map +1 -1
- package/dist/server/jobs/jobProcess.js +64 -24
- package/dist/server/jobs/jobProcess.js.map +1 -1
- package/dist/server/jobs/jobRunner.d.ts +7 -6
- package/dist/server/jobs/jobRunner.js +68 -30
- package/dist/server/jobs/jobRunner.js.map +1 -1
- package/dist/server/jobs/jobs.d.ts +18 -7
- package/dist/server/jobs/jobs.js +93 -61
- package/dist/server/jobs/jobs.js.map +1 -1
- package/dist/server/loadRootComponents.js +1 -1
- package/dist/server/middlewareChain.d.ts +80 -0
- package/dist/server/middlewareChain.js +252 -0
- package/dist/server/middlewareChain.js.map +1 -0
- package/dist/server/mqtt.d.ts +1 -8
- package/dist/server/mqtt.js +22 -17
- package/dist/server/mqtt.js.map +1 -1
- package/dist/server/nodeName.js +46 -13
- package/dist/server/nodeName.js.map +1 -1
- package/dist/server/operationsServer.d.ts +2 -2
- package/dist/server/operationsServer.js +106 -33
- package/dist/server/operationsServer.js.map +1 -1
- package/dist/server/serverHelpers/Headers.d.ts +4 -4
- package/dist/server/serverHelpers/Headers.js +2 -0
- package/dist/server/serverHelpers/Headers.js.map +1 -1
- package/dist/server/serverHelpers/JSONStream.d.ts +7 -1
- package/dist/server/serverHelpers/JSONStream.js +12 -3
- package/dist/server/serverHelpers/JSONStream.js.map +1 -1
- package/dist/server/serverHelpers/Request.d.ts +106 -8
- package/dist/server/serverHelpers/Request.js +370 -9
- package/dist/server/serverHelpers/Request.js.map +1 -1
- package/dist/server/serverHelpers/contentTypes.d.ts +1 -1
- package/dist/server/serverHelpers/contentTypes.js +36 -7
- package/dist/server/serverHelpers/contentTypes.js.map +1 -1
- package/dist/server/serverHelpers/multipartParser.d.ts +21 -0
- package/dist/server/serverHelpers/multipartParser.js +142 -0
- package/dist/server/serverHelpers/multipartParser.js.map +1 -0
- package/dist/server/serverHelpers/progressEmitter.d.ts +25 -0
- package/dist/server/serverHelpers/progressEmitter.js +103 -0
- package/dist/server/serverHelpers/progressEmitter.js.map +1 -0
- package/dist/server/serverHelpers/serverHandlers.d.ts +1 -1
- package/dist/server/serverHelpers/serverHandlers.js +38 -7
- package/dist/server/serverHelpers/serverHandlers.js.map +1 -1
- package/dist/server/serverHelpers/serverUtilities.d.ts +4 -2
- package/dist/server/serverHelpers/serverUtilities.js +97 -93
- package/dist/server/serverHelpers/serverUtilities.js.map +1 -1
- package/dist/server/static.js +8 -5
- package/dist/server/static.js.map +1 -1
- package/dist/server/status/index.js +3 -3
- package/dist/server/storageReclamation.d.ts +10 -0
- package/dist/server/storageReclamation.js +68 -9
- package/dist/server/storageReclamation.js.map +1 -1
- package/dist/server/threads/itc.js +7 -4
- package/dist/server/threads/itc.js.map +1 -1
- package/dist/server/threads/manageThreads.d.ts +1 -1
- package/dist/server/threads/manageThreads.js +110 -26
- package/dist/server/threads/manageThreads.js.map +1 -1
- package/dist/server/threads/socketRouter.d.ts +0 -1
- package/dist/server/threads/socketRouter.js +8 -271
- package/dist/server/threads/socketRouter.js.map +1 -1
- package/dist/server/threads/threadServer.d.ts +1 -0
- package/dist/server/threads/threadServer.js +360 -118
- package/dist/server/threads/threadServer.js.map +1 -1
- package/dist/server/threads/workerProcessGuard.d.ts +42 -0
- package/dist/server/threads/workerProcessGuard.js +114 -0
- package/dist/server/threads/workerProcessGuard.js.map +1 -0
- package/dist/server/throttle.js +17 -0
- package/dist/server/throttle.js.map +1 -1
- package/dist/sqlTranslator/SelectValidator.d.ts +21 -24
- package/dist/sqlTranslator/SelectValidator.js +86 -47
- package/dist/sqlTranslator/SelectValidator.js.map +1 -1
- package/dist/sqlTranslator/alasqlFunctionImporter.d.ts +6 -2
- package/dist/sqlTranslator/alasqlFunctionImporter.js +40 -3
- package/dist/sqlTranslator/alasqlFunctionImporter.js.map +1 -1
- package/dist/sqlTranslator/deleteTranslator.d.ts +4 -7
- package/dist/sqlTranslator/deleteTranslator.js +48 -14
- package/dist/sqlTranslator/deleteTranslator.js.map +1 -1
- package/dist/sqlTranslator/index.d.ts +10 -9
- package/dist/sqlTranslator/index.js +69 -30
- package/dist/sqlTranslator/index.js.map +1 -1
- package/dist/sqlTranslator/sql_statement_bucket.d.ts +10 -10
- package/dist/sqlTranslator/sql_statement_bucket.js +55 -13
- package/dist/sqlTranslator/sql_statement_bucket.js.map +1 -1
- package/dist/upgrade/UpgradeObjects.d.ts +2 -3
- package/dist/upgrade/UpgradeObjects.js +37 -4
- package/dist/upgrade/UpgradeObjects.js.map +1 -1
- package/dist/upgrade/directives/5-1-0.d.ts +6 -0
- package/dist/upgrade/directives/5-1-0.js +114 -0
- package/dist/upgrade/directives/5-1-0.js.map +1 -0
- package/dist/upgrade/directives/directivesController.d.ts +10 -10
- package/dist/upgrade/directives/directivesController.js +52 -11
- package/dist/upgrade/directives/directivesController.js.map +1 -1
- package/dist/upgrade/directivesManager.d.ts +1 -1
- package/dist/upgrade/directivesManager.js +53 -18
- package/dist/upgrade/directivesManager.js.map +1 -1
- package/dist/upgrade/upgradePrompt.d.ts +2 -8
- package/dist/upgrade/upgradePrompt.js +55 -60
- package/dist/upgrade/upgradePrompt.js.map +1 -1
- package/dist/upgrade/upgradeUtilities.d.ts +1 -1
- package/dist/upgrade/upgradeUtilities.js +37 -5
- package/dist/upgrade/upgradeUtilities.js.map +1 -1
- package/dist/utility/OperationFunctionCaller.d.ts +1 -1
- package/dist/utility/OperationFunctionCaller.js +45 -10
- package/dist/utility/OperationFunctionCaller.js.map +1 -1
- package/dist/utility/assignCmdEnvVariables.d.ts +1 -2
- package/dist/utility/assignCmdEnvVariables.js +8 -4
- package/dist/utility/assignCmdEnvVariables.js.map +1 -1
- package/dist/utility/common_utils.d.ts +80 -77
- package/dist/utility/common_utils.js +140 -79
- package/dist/utility/common_utils.js.map +1 -1
- package/dist/utility/environment/environmentManager.d.ts +12 -11
- package/dist/utility/environment/environmentManager.js +75 -29
- package/dist/utility/environment/environmentManager.js.map +1 -1
- package/dist/utility/environment/systemInformation.d.ts +4 -0
- package/dist/utility/environment/systemInformation.js +27 -16
- package/dist/utility/environment/systemInformation.js.map +1 -1
- package/dist/utility/errors/commonErrors.d.ts +192 -168
- package/dist/utility/errors/commonErrors.js +49 -18
- package/dist/utility/errors/commonErrors.js.map +1 -1
- package/dist/utility/errors/hdbError.d.ts +37 -51
- package/dist/utility/errors/hdbError.js +65 -26
- package/dist/utility/errors/hdbError.js.map +1 -1
- package/dist/utility/expandEnvVar.d.ts +61 -0
- package/dist/utility/expandEnvVar.js +113 -0
- package/dist/utility/expandEnvVar.js.map +1 -0
- package/dist/utility/functions/geo.js +2 -2
- package/dist/utility/functions/sql/alaSQLExtension.js +1 -1
- package/dist/utility/globalSchema.d.ts +13 -4
- package/dist/utility/globalSchema.js +14 -11
- package/dist/utility/globalSchema.js.map +1 -1
- package/dist/utility/hdbTerms.d.ts +54 -1
- package/dist/utility/hdbTerms.js +54 -1
- package/dist/utility/hdbTerms.js.map +1 -1
- package/dist/utility/install/checkJWTTokensExist.js +1 -1
- package/dist/utility/install/installer.d.ts +9 -12
- package/dist/utility/install/installer.js +117 -54
- package/dist/utility/install/installer.js.map +1 -1
- package/dist/utility/installation.js +3 -3
- package/dist/utility/lmdb/DBIDefinition.d.ts +4 -4
- package/dist/utility/lmdb/DBIDefinition.js +5 -1
- package/dist/utility/lmdb/DBIDefinition.js.map +1 -1
- package/dist/utility/lmdb/DeleteRecordsResponseObject.d.ts +3 -6
- package/dist/utility/lmdb/DeleteRecordsResponseObject.js +2 -1
- package/dist/utility/lmdb/DeleteRecordsResponseObject.js.map +1 -1
- package/dist/utility/lmdb/InsertRecordsResponseObject.d.ts +3 -5
- package/dist/utility/lmdb/InsertRecordsResponseObject.js +2 -1
- package/dist/utility/lmdb/InsertRecordsResponseObject.js.map +1 -1
- package/dist/utility/lmdb/OpenDBIObject.d.ts +12 -15
- package/dist/utility/lmdb/OpenDBIObject.js +68 -6
- package/dist/utility/lmdb/OpenDBIObject.js.map +1 -1
- package/dist/utility/lmdb/OpenEnvironmentObject.d.ts +5 -8
- package/dist/utility/lmdb/OpenEnvironmentObject.js +52 -4
- package/dist/utility/lmdb/OpenEnvironmentObject.js.map +1 -1
- package/dist/utility/lmdb/UpdateRecordsResponseObject.d.ts +3 -6
- package/dist/utility/lmdb/UpdateRecordsResponseObject.js +2 -1
- package/dist/utility/lmdb/UpdateRecordsResponseObject.js.map +1 -1
- package/dist/utility/lmdb/UpsertRecordsResponseObject.d.ts +3 -5
- package/dist/utility/lmdb/UpsertRecordsResponseObject.js +2 -1
- package/dist/utility/lmdb/UpsertRecordsResponseObject.js.map +1 -1
- package/dist/utility/lmdb/cleanLMDBMap.d.ts +1 -1
- package/dist/utility/lmdb/cleanLMDBMap.js +44 -7
- package/dist/utility/lmdb/cleanLMDBMap.js.map +1 -1
- package/dist/utility/lmdb/commonUtility.d.ts +8 -9
- package/dist/utility/lmdb/commonUtility.js +46 -17
- package/dist/utility/lmdb/commonUtility.js.map +1 -1
- package/dist/utility/lmdb/deleteUtility.d.ts +2 -3
- package/dist/utility/lmdb/deleteUtility.js +51 -16
- package/dist/utility/lmdb/deleteUtility.js.map +1 -1
- package/dist/utility/lmdb/environmentUtility.d.ts +69 -36
- package/dist/utility/lmdb/environmentUtility.js +91 -51
- package/dist/utility/lmdb/environmentUtility.js.map +1 -1
- package/dist/utility/lmdb/searchCursorFunctions.d.ts +19 -19
- package/dist/utility/lmdb/searchCursorFunctions.js +46 -14
- package/dist/utility/lmdb/searchCursorFunctions.js.map +1 -1
- package/dist/utility/lmdb/searchUtility.d.ts +142 -73
- package/dist/utility/lmdb/searchUtility.js +91 -55
- package/dist/utility/lmdb/searchUtility.js.map +1 -1
- package/dist/utility/lmdb/terms.d.ts +34 -34
- package/dist/utility/lmdb/terms.js +12 -22
- package/dist/utility/lmdb/terms.js.map +1 -1
- package/dist/utility/lmdb/writeUtility.d.ts +3 -6
- package/dist/utility/lmdb/writeUtility.js +61 -28
- package/dist/utility/lmdb/writeUtility.js.map +1 -1
- package/dist/utility/logging/harper_logger.d.ts +87 -103
- package/dist/utility/logging/harper_logger.js +177 -82
- package/dist/utility/logging/harper_logger.js.map +1 -1
- package/dist/utility/logging/logRotator.d.ts +2 -10
- package/dist/utility/logging/logRotator.js +67 -32
- package/dist/utility/logging/logRotator.js.map +1 -1
- package/dist/utility/logging/logger.js +4 -4
- package/dist/utility/logging/readLog.d.ts +1 -1
- package/dist/utility/logging/readLog.js +54 -17
- package/dist/utility/logging/readLog.js.map +1 -1
- package/dist/utility/logging/transactionLog.d.ts +2 -2
- package/dist/utility/logging/transactionLog.js +51 -16
- package/dist/utility/logging/transactionLog.js.map +1 -1
- package/dist/utility/mount_hdb.d.ts +1 -2
- package/dist/utility/mount_hdb.js +54 -17
- package/dist/utility/mount_hdb.js.map +1 -1
- package/dist/utility/npmUtilities.d.ts +1 -1
- package/dist/utility/npmUtilities.js +54 -19
- package/dist/utility/npmUtilities.js.map +1 -1
- package/dist/utility/operation_authorization.d.ts +36 -9
- package/dist/utility/operation_authorization.js +135 -86
- package/dist/utility/operation_authorization.js.map +1 -1
- package/dist/utility/packageUtils.d.ts +0 -2
- package/dist/utility/packageUtils.js +7 -17
- package/dist/utility/packageUtils.js.map +1 -1
- package/dist/utility/password.js +2 -2
- package/dist/utility/processManagement/processManagement.js +2 -2
- package/dist/utility/processManagement/servicesConfig.js +1 -1
- package/dist/utility/signalling.d.ts +2 -2
- package/dist/utility/signalling.js +51 -16
- package/dist/utility/signalling.js.map +1 -1
- package/dist/utility/watcherFallback.d.ts +36 -0
- package/dist/utility/watcherFallback.js +73 -0
- package/dist/utility/watcherFallback.js.map +1 -0
- package/dist/validation/analyticsValidator.d.ts +1 -0
- package/dist/validation/analyticsValidator.js +80 -0
- package/dist/validation/analyticsValidator.js.map +1 -0
- package/dist/validation/bulkDeleteValidator.d.ts +1 -2
- package/dist/validation/bulkDeleteValidator.js +49 -11
- package/dist/validation/bulkDeleteValidator.js.map +1 -1
- package/dist/validation/check_permissions.d.ts +1 -2
- package/dist/validation/check_permissions.js +38 -3
- package/dist/validation/check_permissions.js.map +1 -1
- package/dist/validation/common_validators.d.ts +20 -20
- package/dist/validation/common_validators.js +62 -31
- package/dist/validation/common_validators.js.map +1 -1
- package/dist/validation/configValidator.d.ts +4 -4
- package/dist/validation/configValidator.js +189 -54
- package/dist/validation/configValidator.js.map +1 -1
- package/dist/validation/deleteValidator.d.ts +1 -2
- package/dist/validation/deleteValidator.js +49 -11
- package/dist/validation/deleteValidator.js.map +1 -1
- package/dist/validation/fileLoadValidator.d.ts +4 -4
- package/dist/validation/fileLoadValidator.js +67 -32
- package/dist/validation/fileLoadValidator.js.map +1 -1
- package/dist/validation/insertValidator.d.ts +1 -2
- package/dist/validation/insertValidator.js +48 -10
- package/dist/validation/insertValidator.js.map +1 -1
- package/dist/validation/installValidator.d.ts +2 -2
- package/dist/validation/installValidator.js +47 -10
- package/dist/validation/installValidator.js.map +1 -1
- package/dist/validation/readLogValidator.d.ts +1 -2
- package/dist/validation/readLogValidator.js +60 -22
- package/dist/validation/readLogValidator.js.map +1 -1
- package/dist/validation/role_validation.d.ts +3 -3
- package/dist/validation/role_validation.js +55 -19
- package/dist/validation/role_validation.js.map +1 -1
- package/dist/validation/schemaMetadataValidator.d.ts +3 -4
- package/dist/validation/schemaMetadataValidator.js +11 -12
- package/dist/validation/schemaMetadataValidator.js.map +1 -1
- package/dist/validation/searchValidator.d.ts +1 -2
- package/dist/validation/searchValidator.js +82 -43
- package/dist/validation/searchValidator.js.map +1 -1
- package/dist/validation/statusValidator.d.ts +1 -1
- package/dist/validation/transactionLogValidator.d.ts +3 -3
- package/dist/validation/transactionLogValidator.js +52 -17
- package/dist/validation/transactionLogValidator.js.map +1 -1
- package/dist/validation/user_validation.d.ts +3 -3
- package/dist/validation/user_validation.js +38 -6
- package/dist/validation/user_validation.js.map +1 -1
- package/dist/validation/validationWrapper.d.ts +3 -3
- package/dist/validation/validationWrapper.js +4 -5
- package/dist/validation/validationWrapper.js.map +1 -1
- package/index.ts +5 -0
- package/json/systemSchema.json +65 -0
- package/launchServiceScripts/utility/checkNodeVersion.js +2 -0
- package/package.json +38 -24
- package/resources/DESIGN.md +98 -0
- package/resources/DatabaseTransaction.ts +58 -30
- package/resources/ErrorResource.ts +2 -1
- package/resources/LMDBTransaction.ts +38 -29
- package/resources/RecordEncoder.ts +41 -39
- package/resources/RequestTarget.ts +2 -0
- package/resources/Resource.ts +96 -56
- package/resources/ResourceInterface.ts +44 -21
- package/resources/Resources.ts +8 -8
- package/resources/RocksIndexStore.ts +3 -0
- package/resources/RocksTransactionLogStore.ts +13 -4
- package/resources/Table.ts +440 -223
- package/resources/analytics/metadata.ts +1 -0
- package/resources/analytics/read.ts +99 -10
- package/resources/analytics/write.ts +240 -17
- package/resources/auditStore.ts +30 -19
- package/resources/blob.ts +53 -53
- package/resources/dataLoader.ts +4 -4
- package/resources/databases.ts +208 -74
- package/resources/graphql.ts +267 -165
- package/resources/indexes/HierarchicalNavigableSmallWorld.ts +310 -65
- package/resources/indexes/vector.ts +17 -0
- package/resources/jsonSchemaTypes.ts +102 -0
- package/resources/loadEnv.ts +21 -17
- package/resources/login.ts +5 -3
- package/resources/models/Models.ts +304 -0
- package/resources/models/TestBackend.ts +83 -0
- package/resources/models/agentLoop.ts +895 -0
- package/resources/models/analyticsTable.ts +199 -0
- package/resources/models/backendHelpers.ts +116 -0
- package/resources/models/backendRegistry.ts +66 -0
- package/resources/models/bootstrap.ts +135 -0
- package/resources/models/embedHook.ts +138 -0
- package/resources/models/types.ts +296 -0
- package/resources/openApi.ts +65 -31
- package/resources/replayLogs.ts +20 -9
- package/resources/replayLogsGuards.ts +45 -0
- package/resources/roles.ts +62 -67
- package/resources/search.ts +355 -135
- package/resources/tracked.ts +18 -9
- package/resources/transaction.ts +8 -8
- package/resources/transactionBroadcast.ts +3 -3
- package/schema.graphql +7 -0
- package/security/auth.ts +35 -26
- package/security/certificateVerification/crlVerification.ts +11 -4
- package/security/{cryptoHash.js → cryptoHash.ts} +3 -8
- package/security/data_objects/{PermissionAttributeResponseObject.js → PermissionAttributeResponseObject.ts} +4 -4
- package/security/data_objects/{PermissionResponseObject.js → PermissionResponseObject.ts} +12 -11
- package/security/data_objects/{PermissionTableResponseObject.js → PermissionTableResponseObject.ts} +6 -4
- package/security/{fastifyAuth.js → fastifyAuth.ts} +93 -20
- package/security/impersonation.ts +3 -3
- package/security/jsLoader.ts +22 -8
- package/security/{keys.js → keys.ts} +113 -121
- package/security/permissionsTranslator.js +2 -2
- package/security/{role.js → role.ts} +26 -33
- package/security/tokenAuthentication.ts +34 -7
- package/security/user.ts +26 -22
- package/server/DESIGN.md +139 -0
- package/server/DurableSubscriptionsSession.ts +67 -50
- package/server/REST.ts +120 -107
- package/server/Server.ts +31 -12
- package/server/fastifyRoutes/helpers/getCORSOptions.js +1 -1
- package/server/fastifyRoutes/helpers/getHeaderTimeoutConfig.js +1 -1
- package/server/fastifyRoutes/helpers/getServerOptions.js +1 -1
- package/server/fastifyRoutes.ts +37 -33
- package/server/graphqlQuerying.ts +6 -5
- package/server/http.ts +517 -26
- package/server/itc/serverHandlers.js +75 -14
- package/server/jobs/{JobObject.js → JobObject.ts} +13 -6
- package/server/jobs/{jobProcess.js → jobProcess.ts} +20 -16
- package/server/jobs/{jobRunner.js → jobRunner.ts} +20 -21
- package/server/jobs/{jobs.js → jobs.ts} +41 -44
- package/server/loadRootComponents.js +1 -1
- package/server/middlewareChain.ts +270 -0
- package/server/mqtt.ts +35 -26
- package/server/nodeName.ts +3 -1
- package/server/operationsServer.ts +85 -10
- package/server/serverHelpers/Headers.ts +10 -8
- package/server/serverHelpers/JSONStream.ts +15 -5
- package/server/serverHelpers/Request.ts +370 -13
- package/server/serverHelpers/contentTypes.ts +42 -11
- package/server/serverHelpers/multipartParser.ts +152 -0
- package/server/serverHelpers/progressEmitter.ts +110 -0
- package/server/serverHelpers/serverHandlers.js +43 -7
- package/server/serverHelpers/serverUtilities.ts +40 -30
- package/server/static.ts +9 -6
- package/server/status/index.ts +2 -2
- package/server/storageReclamation.ts +39 -2
- package/server/threads/itc.js +7 -4
- package/server/threads/manageThreads.js +100 -26
- package/server/threads/socketRouter.ts +12 -275
- package/server/threads/threadServer.js +345 -105
- package/server/threads/workerProcessGuard.ts +93 -0
- package/server/throttle.ts +18 -0
- package/sqlTranslator/{SelectValidator.js → SelectValidator.ts} +41 -49
- package/sqlTranslator/{alasqlFunctionImporter.js → alasqlFunctionImporter.ts} +5 -5
- package/sqlTranslator/{deleteTranslator.js → deleteTranslator.ts} +13 -18
- package/sqlTranslator/{index.js → index.ts} +30 -33
- package/sqlTranslator/{sql_statement_bucket.js → sql_statement_bucket.ts} +49 -20
- package/static/README.md +10 -9
- package/static/defaultConfig.yaml +0 -1
- package/studio/web/assets/{index-CybLScHg.js → index-Dqr9oVhe.js} +5 -5
- package/studio/web/assets/index-Dqr9oVhe.js.map +1 -0
- package/studio/web/assets/{index.lazy-DKx5-iXF.js → index.lazy-CpKcKb7M.js} +2 -2
- package/studio/web/assets/{index.lazy-DKx5-iXF.js.map → index.lazy-CpKcKb7M.js.map} +1 -1
- package/studio/web/assets/{profile-BOjes0Wl.js → profile-C1cujdsg.js} +2 -2
- package/studio/web/assets/{profile-BOjes0Wl.js.map → profile-C1cujdsg.js.map} +1 -1
- package/studio/web/assets/{status-EWKUIrjT.js → status-CTiIIQlY.js} +2 -2
- package/studio/web/assets/{status-EWKUIrjT.js.map → status-CTiIIQlY.js.map} +1 -1
- package/studio/web/index.html +1 -1
- package/upgrade/{UpgradeObjects.js → UpgradeObjects.ts} +3 -6
- package/upgrade/directives/5-1-0.ts +89 -0
- package/upgrade/directives/{directivesController.js → directivesController.ts} +16 -16
- package/upgrade/{directivesManager.js → directivesManager.ts} +7 -11
- package/upgrade/{upgradePrompt.js → upgradePrompt.ts} +6 -54
- package/upgrade/{upgradeUtilities.js → upgradeUtilities.ts} +3 -7
- package/utility/{OperationFunctionCaller.js → OperationFunctionCaller.ts} +7 -7
- package/utility/{assignCmdEnvVariables.js → assignCmdEnvVariables.ts} +6 -8
- package/utility/{common_utils.js → common_utils.ts} +113 -139
- package/utility/environment/{environmentManager.js → environmentManager.ts} +34 -33
- package/utility/environment/systemInformation.ts +18 -4
- package/utility/errors/{commonErrors.js → commonErrors.ts} +9 -9
- package/utility/errors/{hdbError.js → hdbError.ts} +39 -45
- package/utility/expandEnvVar.ts +110 -0
- package/utility/functions/geo.js +2 -2
- package/utility/functions/sql/alaSQLExtension.js +1 -1
- package/utility/globalSchema.ts +30 -0
- package/utility/hdbTerms.ts +54 -1
- package/utility/install/checkJWTTokensExist.js +1 -1
- package/utility/install/{installer.js → installer.ts} +66 -42
- package/utility/installation.ts +2 -2
- package/utility/lmdb/{DBIDefinition.js → DBIDefinition.ts} +4 -1
- package/utility/lmdb/{DeleteRecordsResponseObject.js → DeleteRecordsResponseObject.ts} +2 -1
- package/utility/lmdb/{InsertRecordsResponseObject.js → InsertRecordsResponseObject.ts} +2 -1
- package/utility/lmdb/OpenDBIObject.ts +57 -0
- package/utility/lmdb/{OpenEnvironmentObject.js → OpenEnvironmentObject.ts} +19 -6
- package/utility/lmdb/{UpdateRecordsResponseObject.js → UpdateRecordsResponseObject.ts} +2 -1
- package/utility/lmdb/{UpsertRecordsResponseObject.js → UpsertRecordsResponseObject.ts} +2 -1
- package/utility/lmdb/{cleanLMDBMap.js → cleanLMDBMap.ts} +5 -5
- package/utility/lmdb/{commonUtility.js → commonUtility.ts} +13 -21
- package/utility/lmdb/{deleteUtility.js → deleteUtility.ts} +8 -12
- package/utility/lmdb/{environmentUtility.js → environmentUtility.ts} +43 -52
- package/utility/lmdb/{searchCursorFunctions.js → searchCursorFunctions.ts} +12 -26
- package/utility/lmdb/{searchUtility.js → searchUtility.ts} +75 -64
- package/utility/lmdb/{terms.js → terms.ts} +10 -23
- package/utility/lmdb/{writeUtility.js → writeUtility.ts} +37 -22
- package/utility/logging/{harper_logger.js → harper_logger.ts} +137 -90
- package/utility/logging/{logRotator.js → logRotator.ts} +15 -18
- package/utility/logging/logger.ts +1 -1
- package/utility/logging/{readLog.js → readLog.ts} +19 -19
- package/utility/logging/{transactionLog.js → transactionLog.ts} +10 -14
- package/utility/{mount_hdb.js → mount_hdb.ts} +15 -16
- package/utility/{npmUtilities.js → npmUtilities.ts} +14 -17
- package/utility/{operation_authorization.js → operation_authorization.ts} +173 -124
- package/utility/packageUtils.js +7 -16
- package/utility/password.ts +1 -1
- package/utility/processManagement/processManagement.js +2 -2
- package/utility/processManagement/servicesConfig.js +1 -1
- package/utility/{signalling.js → signalling.ts} +6 -11
- package/utility/watcherFallback.ts +74 -0
- package/validation/analyticsValidator.ts +44 -0
- package/validation/{bulkDeleteValidator.js → bulkDeleteValidator.ts} +5 -5
- package/validation/{check_permissions.js → check_permissions.ts} +3 -3
- package/validation/{common_validators.js → common_validators.ts} +12 -24
- package/validation/{configValidator.js → configValidator.ts} +114 -18
- package/validation/{deleteValidator.js → deleteValidator.ts} +5 -5
- package/validation/{fileLoadValidator.js → fileLoadValidator.ts} +12 -19
- package/validation/{insertValidator.js → insertValidator.ts} +5 -5
- package/validation/{installValidator.js → installValidator.ts} +8 -8
- package/validation/{readLogValidator.js → readLogValidator.ts} +10 -10
- package/validation/{role_validation.js → role_validation.ts} +26 -32
- package/validation/{schemaMetadataValidator.js → schemaMetadataValidator.ts} +5 -11
- package/validation/{searchValidator.js → searchValidator.ts} +12 -11
- package/validation/statusValidator.ts +1 -1
- package/validation/{transactionLogValidator.js → transactionLogValidator.ts} +4 -9
- package/validation/{user_validation.js → user_validation.ts} +4 -10
- package/validation/{validationWrapper.js → validationWrapper.ts} +3 -9
- package/bin/cliOperations.js +0 -159
- package/bin/lite.js +0 -5
- package/dataLayer/harperBridge/BridgeMethods.js +0 -85
- package/studio/web/assets/index-CybLScHg.js.map +0 -1
- package/utility/globalSchema.js +0 -35
- package/utility/lmdb/OpenDBIObject.js +0 -31
|
@@ -0,0 +1,734 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
var __importDefault = (this && this.__importDefault) || function (mod) {
|
|
3
|
+
return (mod && mod.__esModule) ? mod : { "default": mod };
|
|
4
|
+
};
|
|
5
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
6
|
+
exports.BedrockBackendError = exports.BedrockBackend = void 0;
|
|
7
|
+
exports._resetSdkCacheForTests = _resetSdkCacheForTests;
|
|
8
|
+
exports._injectSdkForTests = _injectSdkForTests;
|
|
9
|
+
exports.registerBedrockBackend = registerBedrockBackend;
|
|
10
|
+
/**
|
|
11
|
+
* AWS Bedrock backend (#633, Phase 6 of #510).
|
|
12
|
+
*
|
|
13
|
+
* Implements `ModelBackend` against AWS Bedrock via the official AWS SDK.
|
|
14
|
+
* Unlike Ollama / OpenAI / Anthropic, Bedrock requires SigV4-signed
|
|
15
|
+
* requests against region-specific endpoints; rolling that ourselves is
|
|
16
|
+
* not worth it. `@aws-sdk/client-bedrock-runtime` is declared as an
|
|
17
|
+
* **optional `peerDependency`** in Harper's `package.json`. Users who
|
|
18
|
+
* want the bedrock backend add the SDK to their own project's
|
|
19
|
+
* `package.json`; we dynamic-import on first use and throw a pointed
|
|
20
|
+
* error if it's missing.
|
|
21
|
+
*
|
|
22
|
+
* AWS credentials resolve via the SDK's standard chain (env / shared
|
|
23
|
+
* credentials file / EC2 / ECS / IAM roles for service accounts). No
|
|
24
|
+
* `apiKey` field on the Harper config — credential handling is the
|
|
25
|
+
* SDK's job, not ours.
|
|
26
|
+
*
|
|
27
|
+
* Bedrock has multiple model invocation shapes per family (Claude vs
|
|
28
|
+
* Llama vs Titan vs Cohere). The backend dispatches on the `model`
|
|
29
|
+
* field's prefix; per-family request/response translation lives in
|
|
30
|
+
* helpers below.
|
|
31
|
+
*/
|
|
32
|
+
const backendRegistry_ts_1 = require("../../resources/models/backendRegistry.js");
|
|
33
|
+
const backendHelpers_ts_1 = require("../../resources/models/backendHelpers.js");
|
|
34
|
+
const hdbError_ts_1 = require("../../utility/errors/hdbError.js");
|
|
35
|
+
const harper_logger_ts_1 = __importDefault(require("../../utility/logging/harper_logger.js"));
|
|
36
|
+
// Defaults matching Anthropic's expectation when Claude is invoked via
|
|
37
|
+
// Bedrock — Anthropic requires `max_tokens` on every request.
|
|
38
|
+
const DEFAULT_MAX_TOKENS = 4096;
|
|
39
|
+
// Max accumulated `bytes` from streamed Claude tool-use input_json_delta;
|
|
40
|
+
// matches the cap in `components/anthropic/index.ts`.
|
|
41
|
+
const MAX_TOOL_CALL_ARGS_CHARS = 1 << 20;
|
|
42
|
+
const log = harper_logger_ts_1.default.forComponent('bedrock').conditional;
|
|
43
|
+
let sdkPromise;
|
|
44
|
+
/**
|
|
45
|
+
* Load the AWS SDK on demand. Memoized — the SDK is module-scope state once
|
|
46
|
+
* loaded. Throws `BedrockBackendError` with a clear "add to your
|
|
47
|
+
* package.json" message if the SDK isn't installed.
|
|
48
|
+
*/
|
|
49
|
+
async function loadSdk() {
|
|
50
|
+
if (!sdkPromise) {
|
|
51
|
+
sdkPromise = (async () => {
|
|
52
|
+
try {
|
|
53
|
+
// `@aws-sdk/client-bedrock-runtime` is declared as an optional
|
|
54
|
+
// peerDependency in Harper's `package.json` — it is not present
|
|
55
|
+
// in Harper's `node_modules` by design, so TypeScript can't
|
|
56
|
+
// resolve it at compile time. The runtime import resolves
|
|
57
|
+
// against the user's project tree.
|
|
58
|
+
// @ts-expect-error optional peerDependency, not resolvable at build time
|
|
59
|
+
const mod = (await import('@aws-sdk/client-bedrock-runtime'));
|
|
60
|
+
return mod;
|
|
61
|
+
}
|
|
62
|
+
catch (err) {
|
|
63
|
+
// Wipe the cached rejection so a follow-up install + retry works
|
|
64
|
+
// without restart. The thrown error is still propagated for this call.
|
|
65
|
+
sdkPromise = undefined;
|
|
66
|
+
throw new BedrockBackendError('@aws-sdk/client-bedrock-runtime is not installed. Add it to your project ' +
|
|
67
|
+
'(`npm install @aws-sdk/client-bedrock-runtime`) — Harper declares it as an optional peerDependency, ' +
|
|
68
|
+
'not a direct dependency, so applications that do not use the bedrock backend never pay the install cost. ' +
|
|
69
|
+
`Underlying error: ${err?.message ?? err}`);
|
|
70
|
+
}
|
|
71
|
+
})();
|
|
72
|
+
}
|
|
73
|
+
return sdkPromise;
|
|
74
|
+
}
|
|
75
|
+
/** Test-only hook to reset the memoized SDK promise between cases. */
|
|
76
|
+
function _resetSdkCacheForTests() {
|
|
77
|
+
sdkPromise = undefined;
|
|
78
|
+
}
|
|
79
|
+
/** Test-only hook to inject a fake SDK. */
|
|
80
|
+
function _injectSdkForTests(sdk) {
|
|
81
|
+
sdkPromise = Promise.resolve(sdk);
|
|
82
|
+
}
|
|
83
|
+
/**
|
|
84
|
+
* `ModelBackend` for AWS Bedrock.
|
|
85
|
+
*
|
|
86
|
+
* - `embed` → `InvokeModel` against an embedding model (Titan, Cohere, etc.)
|
|
87
|
+
* - `generate` → `InvokeModel` against a generative model, per-family body shape
|
|
88
|
+
* - `generateStream` → `InvokeModelWithResponseStream`, per-family event parsing
|
|
89
|
+
*
|
|
90
|
+
* Tool support varies per model family — `capabilities()` advertises
|
|
91
|
+
* `tools: true` at the capability level; calls against models that don't
|
|
92
|
+
* support tools (or that haven't been wired into the per-family dispatcher
|
|
93
|
+
* yet) raise structured errors.
|
|
94
|
+
*/
|
|
95
|
+
class BedrockBackend {
|
|
96
|
+
name = 'bedrock';
|
|
97
|
+
#region;
|
|
98
|
+
#defaultModel;
|
|
99
|
+
#requestTimeoutMs;
|
|
100
|
+
#client;
|
|
101
|
+
constructor(config = {}) {
|
|
102
|
+
this.#region = config.region;
|
|
103
|
+
this.#defaultModel = config.model;
|
|
104
|
+
this.#requestTimeoutMs = config.requestTimeoutMs;
|
|
105
|
+
}
|
|
106
|
+
capabilities() {
|
|
107
|
+
return { embed: true, generate: true, stream: true, tools: true, adapters: false };
|
|
108
|
+
}
|
|
109
|
+
async embed(input, opts) {
|
|
110
|
+
const model = opts.model ?? this.#defaultModel;
|
|
111
|
+
(0, backendHelpers_ts_1.requireModel)(model, 'embed', BedrockBackendError);
|
|
112
|
+
const family = familyOf(model);
|
|
113
|
+
const texts = Array.isArray(input) ? input : [input];
|
|
114
|
+
const client = await this.#getClient();
|
|
115
|
+
const sdk = await loadSdk();
|
|
116
|
+
const vectors = [];
|
|
117
|
+
let totalPromptTokens = 0;
|
|
118
|
+
let sawAnyTokens = false;
|
|
119
|
+
// Bedrock embedding APIs (Titan, Cohere) accept one text per call.
|
|
120
|
+
// Loop to honor the multi-input contract; concurrent dispatch would
|
|
121
|
+
// trip the SDK's request budget on larger batches without bounded
|
|
122
|
+
// concurrency, which is overkill for v1.
|
|
123
|
+
for (const text of texts) {
|
|
124
|
+
const body = buildEmbedBody(family, text, opts.inputType);
|
|
125
|
+
const command = new sdk.InvokeModelCommand({
|
|
126
|
+
modelId: model,
|
|
127
|
+
body: JSON.stringify(body),
|
|
128
|
+
contentType: 'application/json',
|
|
129
|
+
accept: 'application/json',
|
|
130
|
+
});
|
|
131
|
+
const response = (await this.#sendWithAbort(client, command, opts.signal));
|
|
132
|
+
const parsed = parseInvokeModelResponse(response);
|
|
133
|
+
const { embedding, promptTokens } = extractEmbedResult(family, parsed);
|
|
134
|
+
vectors.push(Float32Array.from(embedding));
|
|
135
|
+
if (typeof promptTokens === 'number') {
|
|
136
|
+
totalPromptTokens += promptTokens;
|
|
137
|
+
sawAnyTokens = true;
|
|
138
|
+
}
|
|
139
|
+
}
|
|
140
|
+
const usage = {};
|
|
141
|
+
if (sawAnyTokens)
|
|
142
|
+
(0, backendHelpers_ts_1.assignFiniteTokenCount)(usage, 'embeddingTokens', totalPromptTokens);
|
|
143
|
+
return { status: 'completed', output: vectors, usage };
|
|
144
|
+
}
|
|
145
|
+
async generate(input, opts) {
|
|
146
|
+
const model = opts.model ?? this.#defaultModel;
|
|
147
|
+
(0, backendHelpers_ts_1.requireModel)(model, 'generate', BedrockBackendError);
|
|
148
|
+
const family = familyOf(model);
|
|
149
|
+
const body = buildGenerateBody(family, input, opts);
|
|
150
|
+
const client = await this.#getClient();
|
|
151
|
+
const sdk = await loadSdk();
|
|
152
|
+
const command = new sdk.InvokeModelCommand({
|
|
153
|
+
modelId: model,
|
|
154
|
+
body: JSON.stringify(body),
|
|
155
|
+
contentType: 'application/json',
|
|
156
|
+
accept: 'application/json',
|
|
157
|
+
});
|
|
158
|
+
const response = (await this.#sendWithAbort(client, command, opts.signal));
|
|
159
|
+
const parsed = parseInvokeModelResponse(response);
|
|
160
|
+
const result = extractGenerateResult(family, parsed);
|
|
161
|
+
return { status: 'completed', output: result.output, usage: result.usage };
|
|
162
|
+
}
|
|
163
|
+
async *generateStream(input, opts) {
|
|
164
|
+
const model = opts.model ?? this.#defaultModel;
|
|
165
|
+
(0, backendHelpers_ts_1.requireModel)(model, 'generateStream', BedrockBackendError);
|
|
166
|
+
const family = familyOf(model);
|
|
167
|
+
const body = buildGenerateBody(family, input, opts);
|
|
168
|
+
const client = await this.#getClient();
|
|
169
|
+
const sdk = await loadSdk();
|
|
170
|
+
const command = new sdk.InvokeModelWithResponseStreamCommand({
|
|
171
|
+
modelId: model,
|
|
172
|
+
body: JSON.stringify(body),
|
|
173
|
+
contentType: 'application/json',
|
|
174
|
+
accept: 'application/json',
|
|
175
|
+
});
|
|
176
|
+
const response = (await this.#sendWithAbort(client, command, opts.signal));
|
|
177
|
+
if (!response.body) {
|
|
178
|
+
throw new BedrockBackendError(`Bedrock InvokeModelWithResponseStream returned no body for model ${model}`);
|
|
179
|
+
}
|
|
180
|
+
yield* parseStream(family, response.body);
|
|
181
|
+
}
|
|
182
|
+
async #getClient() {
|
|
183
|
+
if (this.#client)
|
|
184
|
+
return this.#client;
|
|
185
|
+
const sdk = await loadSdk();
|
|
186
|
+
this.#client = new sdk.BedrockRuntimeClient({ region: this.#region });
|
|
187
|
+
return this.#client;
|
|
188
|
+
}
|
|
189
|
+
/**
|
|
190
|
+
* Send a command with caller-supplied AbortSignal + optional per-call
|
|
191
|
+
* timeout composed via `AbortSignal.any`. The SDK accepts `abortSignal`
|
|
192
|
+
* in the request options bag.
|
|
193
|
+
*/
|
|
194
|
+
async #sendWithAbort(client, command, callerSignal) {
|
|
195
|
+
const abortSignal = (0, backendHelpers_ts_1.composeSignal)(callerSignal, this.#requestTimeoutMs);
|
|
196
|
+
return client.send(command, abortSignal ? { abortSignal } : undefined);
|
|
197
|
+
}
|
|
198
|
+
}
|
|
199
|
+
exports.BedrockBackend = BedrockBackend;
|
|
200
|
+
/**
|
|
201
|
+
* Boot-bridge helper. Called from `resources/models/bootstrap.ts` for each
|
|
202
|
+
* `models.embedding.<name>` / `models.generative.<name>` entry whose
|
|
203
|
+
* `backend: bedrock`. Construction is cheap (no SDK load) — the SDK loads
|
|
204
|
+
* lazily on first call.
|
|
205
|
+
*/
|
|
206
|
+
function registerBedrockBackend(args) {
|
|
207
|
+
const backend = new BedrockBackend(args.config);
|
|
208
|
+
if (args.kind === 'embedding')
|
|
209
|
+
(0, backendRegistry_ts_1.setEmbedding)(args.logicalName, backend);
|
|
210
|
+
else
|
|
211
|
+
(0, backendRegistry_ts_1.setGenerative)(args.logicalName, backend);
|
|
212
|
+
}
|
|
213
|
+
class BedrockBackendError extends hdbError_ts_1.ServerError {
|
|
214
|
+
constructor(message) {
|
|
215
|
+
super(message);
|
|
216
|
+
this.name = 'BedrockBackendError';
|
|
217
|
+
}
|
|
218
|
+
}
|
|
219
|
+
exports.BedrockBackendError = BedrockBackendError;
|
|
220
|
+
function familyOf(modelId) {
|
|
221
|
+
const prefix = modelId.split('.', 1)[0]?.toLowerCase() ?? '';
|
|
222
|
+
if (prefix === 'anthropic')
|
|
223
|
+
return 'anthropic';
|
|
224
|
+
if (prefix === 'amazon')
|
|
225
|
+
return 'amazon';
|
|
226
|
+
if (prefix === 'meta')
|
|
227
|
+
return 'meta';
|
|
228
|
+
if (prefix === 'cohere')
|
|
229
|
+
return 'cohere';
|
|
230
|
+
if (prefix === 'mistral')
|
|
231
|
+
return 'mistral';
|
|
232
|
+
return 'unknown';
|
|
233
|
+
}
|
|
234
|
+
// ---------- embed body / result extraction ----------
|
|
235
|
+
function buildEmbedBody(family, text, inputType) {
|
|
236
|
+
if (family === 'amazon') {
|
|
237
|
+
// Titan embed v2: { inputText, dimensions?, normalize? }. Titan does
|
|
238
|
+
// not currently differentiate document vs query at the wire level.
|
|
239
|
+
return { inputText: text };
|
|
240
|
+
}
|
|
241
|
+
if (family === 'cohere') {
|
|
242
|
+
// Cohere embed-v3: `input_type` materially affects the produced vector
|
|
243
|
+
// — `search_document` and `search_query` produce different embeddings
|
|
244
|
+
// for the same text. Honor the caller's `inputType`; default to
|
|
245
|
+
// `search_document` when unset (matches Cohere's recommended default
|
|
246
|
+
// for indexing).
|
|
247
|
+
const cohereInputType = inputType === 'query' ? 'search_query' : 'search_document';
|
|
248
|
+
return { texts: [text], input_type: cohereInputType };
|
|
249
|
+
}
|
|
250
|
+
throw new BedrockBackendError(`Bedrock embed not supported for model family '${family}'`);
|
|
251
|
+
}
|
|
252
|
+
function extractEmbedResult(family, parsed) {
|
|
253
|
+
if (family === 'amazon') {
|
|
254
|
+
const embedding = parsed.embedding;
|
|
255
|
+
if (!Array.isArray(embedding) || !embedding.every((n) => typeof n === 'number' && Number.isFinite(n))) {
|
|
256
|
+
throw new BedrockBackendError("Bedrock Titan response missing 'embedding' as a finite-number array");
|
|
257
|
+
}
|
|
258
|
+
const inputTextTokenCount = parsed.inputTextTokenCount;
|
|
259
|
+
return {
|
|
260
|
+
embedding: embedding,
|
|
261
|
+
promptTokens: typeof inputTextTokenCount === 'number' ? inputTextTokenCount : undefined,
|
|
262
|
+
};
|
|
263
|
+
}
|
|
264
|
+
if (family === 'cohere') {
|
|
265
|
+
const embeddings = parsed.embeddings;
|
|
266
|
+
if (!Array.isArray(embeddings) || embeddings.length === 0) {
|
|
267
|
+
throw new BedrockBackendError("Bedrock Cohere response missing 'embeddings' array");
|
|
268
|
+
}
|
|
269
|
+
const first = embeddings[0];
|
|
270
|
+
if (!Array.isArray(first) || !first.every((n) => typeof n === 'number' && Number.isFinite(n))) {
|
|
271
|
+
throw new BedrockBackendError('Bedrock Cohere embedding vector is not an array of finite numbers');
|
|
272
|
+
}
|
|
273
|
+
return { embedding: first };
|
|
274
|
+
}
|
|
275
|
+
throw new BedrockBackendError(`Bedrock embed result extraction not implemented for family '${family}'`);
|
|
276
|
+
}
|
|
277
|
+
// ---------- generate body / result extraction ----------
|
|
278
|
+
function buildGenerateBody(family, input, opts) {
|
|
279
|
+
if (family === 'anthropic')
|
|
280
|
+
return buildAnthropicBody(input, opts);
|
|
281
|
+
if (family === 'meta')
|
|
282
|
+
return buildLlamaBody(input, opts);
|
|
283
|
+
if (family === 'amazon')
|
|
284
|
+
return buildTitanGenerateBody(input, opts);
|
|
285
|
+
if (family === 'mistral')
|
|
286
|
+
return buildMistralBody(input, opts);
|
|
287
|
+
if (family === 'cohere')
|
|
288
|
+
return buildCohereGenerateBody(input, opts);
|
|
289
|
+
throw new BedrockBackendError(`Bedrock generate not supported for model family '${family}'`);
|
|
290
|
+
}
|
|
291
|
+
function extractGenerateResult(family, parsed) {
|
|
292
|
+
if (family === 'anthropic')
|
|
293
|
+
return extractAnthropicResult(parsed);
|
|
294
|
+
if (family === 'meta')
|
|
295
|
+
return extractLlamaResult(parsed);
|
|
296
|
+
if (family === 'amazon')
|
|
297
|
+
return extractTitanResult(parsed);
|
|
298
|
+
if (family === 'mistral')
|
|
299
|
+
return extractMistralResult(parsed);
|
|
300
|
+
if (family === 'cohere')
|
|
301
|
+
return extractCohereResult(parsed);
|
|
302
|
+
throw new BedrockBackendError(`Bedrock generate result extraction not implemented for family '${family}'`);
|
|
303
|
+
}
|
|
304
|
+
// Claude via Bedrock uses Anthropic's Messages API shape verbatim. Reuse the
|
|
305
|
+
// translation patterns from `components/anthropic/index.ts` but keep the
|
|
306
|
+
// code self-contained here — duplicated shape, different transport.
|
|
307
|
+
function buildAnthropicBody(input, opts) {
|
|
308
|
+
const { messages, system } = normalizeMessages(input);
|
|
309
|
+
const tools = extractTools(input);
|
|
310
|
+
const body = {
|
|
311
|
+
anthropic_version: 'bedrock-2023-05-31',
|
|
312
|
+
messages: messages.map(toAnthropicMessage),
|
|
313
|
+
max_tokens: typeof opts.maxTokens === 'number' && opts.maxTokens > 0 ? opts.maxTokens : DEFAULT_MAX_TOKENS,
|
|
314
|
+
};
|
|
315
|
+
if (system)
|
|
316
|
+
body.system = system;
|
|
317
|
+
if (tools && tools.length > 0) {
|
|
318
|
+
body.tools = tools.map((t) => ({ name: t.name, description: t.description, input_schema: t.parameters }));
|
|
319
|
+
}
|
|
320
|
+
if (typeof opts.temperature === 'number')
|
|
321
|
+
body.temperature = opts.temperature;
|
|
322
|
+
return body;
|
|
323
|
+
}
|
|
324
|
+
function extractAnthropicResult(parsed) {
|
|
325
|
+
const content = Array.isArray(parsed.content) ? parsed.content : [];
|
|
326
|
+
const text = [];
|
|
327
|
+
const toolCalls = [];
|
|
328
|
+
for (const block of content) {
|
|
329
|
+
if (block.type === 'text' && typeof block.text === 'string')
|
|
330
|
+
text.push(block.text);
|
|
331
|
+
else if (block.type === 'tool_use' && block.id && block.name) {
|
|
332
|
+
const input = block.input && typeof block.input === 'object' ? block.input : {};
|
|
333
|
+
toolCalls.push({ id: block.id, name: block.name, arguments: input });
|
|
334
|
+
}
|
|
335
|
+
}
|
|
336
|
+
const usage = {};
|
|
337
|
+
const usageObj = parsed.usage;
|
|
338
|
+
(0, backendHelpers_ts_1.assignFiniteTokenCount)(usage, 'promptTokens', usageObj?.input_tokens);
|
|
339
|
+
(0, backendHelpers_ts_1.assignFiniteTokenCount)(usage, 'completionTokens', usageObj?.output_tokens);
|
|
340
|
+
const output = {
|
|
341
|
+
content: text.join(''),
|
|
342
|
+
finishReason: mapAnthropicStopReason(parsed.stop_reason),
|
|
343
|
+
};
|
|
344
|
+
if (toolCalls.length > 0)
|
|
345
|
+
output.toolCalls = toolCalls;
|
|
346
|
+
return { output, usage };
|
|
347
|
+
}
|
|
348
|
+
function buildLlamaBody(input, opts) {
|
|
349
|
+
// Llama on Bedrock uses a flat `prompt` string. Caller's structured
|
|
350
|
+
// messages are flattened with role tags; not as expressive as native chat,
|
|
351
|
+
// but matches what AWS documents.
|
|
352
|
+
rejectToolsForFamily(input, 'meta');
|
|
353
|
+
const prompt = flattenToLlamaPrompt(input);
|
|
354
|
+
const body = { prompt };
|
|
355
|
+
if (typeof opts.maxTokens === 'number')
|
|
356
|
+
body.max_gen_len = opts.maxTokens;
|
|
357
|
+
if (typeof opts.temperature === 'number')
|
|
358
|
+
body.temperature = opts.temperature;
|
|
359
|
+
return body;
|
|
360
|
+
}
|
|
361
|
+
function extractLlamaResult(parsed) {
|
|
362
|
+
const generation = typeof parsed.generation === 'string' ? parsed.generation : '';
|
|
363
|
+
const usage = {};
|
|
364
|
+
(0, backendHelpers_ts_1.assignFiniteTokenCount)(usage, 'promptTokens', parsed.prompt_token_count);
|
|
365
|
+
(0, backendHelpers_ts_1.assignFiniteTokenCount)(usage, 'completionTokens', parsed.generation_token_count);
|
|
366
|
+
const output = {
|
|
367
|
+
content: generation,
|
|
368
|
+
finishReason: mapGenericStopReason(parsed.stop_reason),
|
|
369
|
+
};
|
|
370
|
+
return { output, usage };
|
|
371
|
+
}
|
|
372
|
+
function buildTitanGenerateBody(input, opts) {
|
|
373
|
+
rejectToolsForFamily(input, 'amazon');
|
|
374
|
+
const inputText = flattenToFlatPrompt(input);
|
|
375
|
+
const body = { inputText };
|
|
376
|
+
const textGenerationConfig = {};
|
|
377
|
+
if (typeof opts.maxTokens === 'number')
|
|
378
|
+
textGenerationConfig.maxTokenCount = opts.maxTokens;
|
|
379
|
+
if (typeof opts.temperature === 'number')
|
|
380
|
+
textGenerationConfig.temperature = opts.temperature;
|
|
381
|
+
if (Object.keys(textGenerationConfig).length > 0)
|
|
382
|
+
body.textGenerationConfig = textGenerationConfig;
|
|
383
|
+
return body;
|
|
384
|
+
}
|
|
385
|
+
function extractTitanResult(parsed) {
|
|
386
|
+
const results = Array.isArray(parsed.results) ? parsed.results : [];
|
|
387
|
+
const first = results[0] ?? {};
|
|
388
|
+
const outputText = typeof first.outputText === 'string' ? first.outputText : '';
|
|
389
|
+
const usage = {};
|
|
390
|
+
(0, backendHelpers_ts_1.assignFiniteTokenCount)(usage, 'promptTokens', parsed.inputTextTokenCount);
|
|
391
|
+
(0, backendHelpers_ts_1.assignFiniteTokenCount)(usage, 'completionTokens', first.tokenCount);
|
|
392
|
+
const output = {
|
|
393
|
+
content: outputText,
|
|
394
|
+
finishReason: mapGenericStopReason(first.completionReason),
|
|
395
|
+
};
|
|
396
|
+
return { output, usage };
|
|
397
|
+
}
|
|
398
|
+
function buildMistralBody(input, opts) {
|
|
399
|
+
rejectToolsForFamily(input, 'mistral');
|
|
400
|
+
const prompt = flattenToFlatPrompt(input);
|
|
401
|
+
const body = { prompt };
|
|
402
|
+
if (typeof opts.maxTokens === 'number')
|
|
403
|
+
body.max_tokens = opts.maxTokens;
|
|
404
|
+
if (typeof opts.temperature === 'number')
|
|
405
|
+
body.temperature = opts.temperature;
|
|
406
|
+
return body;
|
|
407
|
+
}
|
|
408
|
+
function extractMistralResult(parsed) {
|
|
409
|
+
const outputs = Array.isArray(parsed.outputs) ? parsed.outputs : [];
|
|
410
|
+
const first = outputs[0] ?? {};
|
|
411
|
+
const text = typeof first.text === 'string' ? first.text : '';
|
|
412
|
+
const output = {
|
|
413
|
+
content: text,
|
|
414
|
+
finishReason: mapGenericStopReason(first.stop_reason),
|
|
415
|
+
};
|
|
416
|
+
// Mistral via Bedrock doesn't currently return per-call token counts in a
|
|
417
|
+
// stable shape — leave usage empty.
|
|
418
|
+
return { output, usage: {} };
|
|
419
|
+
}
|
|
420
|
+
function buildCohereGenerateBody(input, opts) {
|
|
421
|
+
rejectToolsForFamily(input, 'cohere');
|
|
422
|
+
const prompt = flattenToFlatPrompt(input);
|
|
423
|
+
const body = { prompt };
|
|
424
|
+
if (typeof opts.maxTokens === 'number')
|
|
425
|
+
body.max_tokens = opts.maxTokens;
|
|
426
|
+
if (typeof opts.temperature === 'number')
|
|
427
|
+
body.temperature = opts.temperature;
|
|
428
|
+
return body;
|
|
429
|
+
}
|
|
430
|
+
function extractCohereResult(parsed) {
|
|
431
|
+
const generations = Array.isArray(parsed.generations) ? parsed.generations : [];
|
|
432
|
+
const first = generations[0] ?? {};
|
|
433
|
+
const text = typeof first.text === 'string' ? first.text : '';
|
|
434
|
+
const output = {
|
|
435
|
+
content: text,
|
|
436
|
+
finishReason: mapGenericStopReason(first.finish_reason),
|
|
437
|
+
};
|
|
438
|
+
return { output, usage: {} };
|
|
439
|
+
}
|
|
440
|
+
// ---------- streaming dispatch ----------
|
|
441
|
+
async function* parseStream(family, body) {
|
|
442
|
+
if (family === 'anthropic') {
|
|
443
|
+
yield* parseAnthropicStream(body);
|
|
444
|
+
return;
|
|
445
|
+
}
|
|
446
|
+
if (family === 'meta' || family === 'amazon' || family === 'mistral' || family === 'cohere') {
|
|
447
|
+
yield* parseFlatStream(family, body);
|
|
448
|
+
return;
|
|
449
|
+
}
|
|
450
|
+
throw new BedrockBackendError(`Bedrock streaming not supported for model family '${family}'`);
|
|
451
|
+
}
|
|
452
|
+
async function* parseAnthropicStream(body) {
|
|
453
|
+
const decoder = new TextDecoder('utf-8');
|
|
454
|
+
const toolBuf = new Map();
|
|
455
|
+
let finalFinishReason;
|
|
456
|
+
for await (const event of body) {
|
|
457
|
+
if (!event.chunk?.bytes)
|
|
458
|
+
continue;
|
|
459
|
+
const text = decoder.decode(event.chunk.bytes);
|
|
460
|
+
let parsed;
|
|
461
|
+
try {
|
|
462
|
+
parsed = JSON.parse(text);
|
|
463
|
+
}
|
|
464
|
+
catch {
|
|
465
|
+
throw new BedrockBackendError('Invalid JSON in Bedrock Anthropic stream chunk');
|
|
466
|
+
}
|
|
467
|
+
const chunk = {};
|
|
468
|
+
const type = parsed.type;
|
|
469
|
+
const index = parsed.index;
|
|
470
|
+
const contentBlock = parsed.content_block;
|
|
471
|
+
const delta = parsed.delta;
|
|
472
|
+
// Mid-stream upstream errors from Anthropic-via-Bedrock arrive as a
|
|
473
|
+
// `type: 'error'` chunk; without explicit handling the stream ends
|
|
474
|
+
// silently and the caller can't distinguish a clean end from an
|
|
475
|
+
// aborted one. Same posture as the direct Anthropic backend.
|
|
476
|
+
if (type === 'error') {
|
|
477
|
+
const upstream = parsed.error?.message;
|
|
478
|
+
if (typeof upstream === 'string' && upstream.length > 0) {
|
|
479
|
+
const truncated = upstream.length > 500 ? upstream.slice(0, 500) + '…' : upstream;
|
|
480
|
+
throw new BedrockBackendError(`Bedrock Anthropic stream aborted by upstream error: ${truncated}`);
|
|
481
|
+
}
|
|
482
|
+
throw new BedrockBackendError('Bedrock Anthropic stream aborted by upstream error');
|
|
483
|
+
}
|
|
484
|
+
if (type === 'content_block_start' && index !== undefined && contentBlock?.type === 'tool_use') {
|
|
485
|
+
toolBuf.set(index, { id: contentBlock.id ?? '', name: contentBlock.name ?? '', argumentsBuf: '' });
|
|
486
|
+
}
|
|
487
|
+
if (type === 'content_block_delta' && index !== undefined && delta) {
|
|
488
|
+
if (delta.type === 'text_delta' && typeof delta.text === 'string' && delta.text.length > 0) {
|
|
489
|
+
chunk.deltaContent = delta.text;
|
|
490
|
+
}
|
|
491
|
+
else if (delta.type === 'input_json_delta' && typeof delta.partial_json === 'string') {
|
|
492
|
+
const acc = toolBuf.get(index);
|
|
493
|
+
if (acc) {
|
|
494
|
+
if (acc.argumentsBuf.length + delta.partial_json.length > MAX_TOOL_CALL_ARGS_CHARS) {
|
|
495
|
+
throw new BedrockBackendError(`Bedrock tool-call arguments exceed ${MAX_TOOL_CALL_ARGS_CHARS} chars (index ${index})`);
|
|
496
|
+
}
|
|
497
|
+
acc.argumentsBuf += delta.partial_json;
|
|
498
|
+
}
|
|
499
|
+
}
|
|
500
|
+
}
|
|
501
|
+
if (type === 'content_block_stop' && index !== undefined) {
|
|
502
|
+
const acc = toolBuf.get(index);
|
|
503
|
+
if (acc?.id && acc.name) {
|
|
504
|
+
try {
|
|
505
|
+
const args = acc.argumentsBuf.length > 0 ? JSON.parse(acc.argumentsBuf) : {};
|
|
506
|
+
chunk.deltaToolCalls = [{ id: acc.id, name: acc.name, arguments: args }];
|
|
507
|
+
}
|
|
508
|
+
catch {
|
|
509
|
+
log.warn?.(`Bedrock tool call dropped: malformed arguments (id=${acc.id}, name=${acc.name})`);
|
|
510
|
+
}
|
|
511
|
+
toolBuf.delete(index);
|
|
512
|
+
}
|
|
513
|
+
}
|
|
514
|
+
if (type === 'message_delta' && delta?.stop_reason) {
|
|
515
|
+
finalFinishReason = mapAnthropicStopReason(delta.stop_reason);
|
|
516
|
+
chunk.finishReason = finalFinishReason;
|
|
517
|
+
}
|
|
518
|
+
if (chunk.deltaContent || chunk.deltaToolCalls || chunk.finishReason)
|
|
519
|
+
yield chunk;
|
|
520
|
+
}
|
|
521
|
+
if (!finalFinishReason && toolBuf.size > 0) {
|
|
522
|
+
const tail = [];
|
|
523
|
+
for (const acc of toolBuf.values()) {
|
|
524
|
+
if (!acc.id || !acc.name)
|
|
525
|
+
continue;
|
|
526
|
+
try {
|
|
527
|
+
const args = acc.argumentsBuf.length > 0 ? JSON.parse(acc.argumentsBuf) : {};
|
|
528
|
+
tail.push({ id: acc.id, name: acc.name, arguments: args });
|
|
529
|
+
}
|
|
530
|
+
catch {
|
|
531
|
+
log.warn?.(`Bedrock tool call dropped on flush (id=${acc.id}, name=${acc.name})`);
|
|
532
|
+
}
|
|
533
|
+
}
|
|
534
|
+
toolBuf.clear();
|
|
535
|
+
if (tail.length > 0)
|
|
536
|
+
yield { deltaToolCalls: tail };
|
|
537
|
+
}
|
|
538
|
+
}
|
|
539
|
+
async function* parseFlatStream(family, body) {
|
|
540
|
+
// Llama / Titan / Mistral / Cohere via Bedrock all emit one JSON object
|
|
541
|
+
// per stream chunk with a family-specific "delta-content" field. We yield
|
|
542
|
+
// each as a GenerateChunk and rely on the final chunk's stop_reason
|
|
543
|
+
// (or family equivalent) to terminate.
|
|
544
|
+
const decoder = new TextDecoder('utf-8');
|
|
545
|
+
for await (const event of body) {
|
|
546
|
+
if (!event.chunk?.bytes)
|
|
547
|
+
continue;
|
|
548
|
+
const text = decoder.decode(event.chunk.bytes);
|
|
549
|
+
let parsed;
|
|
550
|
+
try {
|
|
551
|
+
parsed = JSON.parse(text);
|
|
552
|
+
}
|
|
553
|
+
catch {
|
|
554
|
+
throw new BedrockBackendError('Invalid JSON in Bedrock stream chunk');
|
|
555
|
+
}
|
|
556
|
+
const chunk = {};
|
|
557
|
+
const deltaContent = extractFlatDeltaContent(family, parsed);
|
|
558
|
+
if (deltaContent && deltaContent.length > 0)
|
|
559
|
+
chunk.deltaContent = deltaContent;
|
|
560
|
+
const stopReason = extractFlatStopReason(family, parsed);
|
|
561
|
+
if (stopReason)
|
|
562
|
+
chunk.finishReason = mapGenericStopReason(stopReason);
|
|
563
|
+
if (chunk.deltaContent || chunk.finishReason)
|
|
564
|
+
yield chunk;
|
|
565
|
+
}
|
|
566
|
+
}
|
|
567
|
+
function extractFlatDeltaContent(family, parsed) {
|
|
568
|
+
if (family === 'meta')
|
|
569
|
+
return typeof parsed.generation === 'string' ? parsed.generation : undefined;
|
|
570
|
+
if (family === 'amazon')
|
|
571
|
+
return typeof parsed.outputText === 'string' ? parsed.outputText : undefined;
|
|
572
|
+
if (family === 'mistral') {
|
|
573
|
+
const outputs = Array.isArray(parsed.outputs) ? parsed.outputs : [];
|
|
574
|
+
const first = outputs[0] ?? {};
|
|
575
|
+
return typeof first.text === 'string' ? first.text : undefined;
|
|
576
|
+
}
|
|
577
|
+
if (family === 'cohere') {
|
|
578
|
+
const generations = Array.isArray(parsed.generations) ? parsed.generations : [];
|
|
579
|
+
const first = generations[0] ?? {};
|
|
580
|
+
return typeof first.text === 'string' ? first.text : undefined;
|
|
581
|
+
}
|
|
582
|
+
return undefined;
|
|
583
|
+
}
|
|
584
|
+
function extractFlatStopReason(family, parsed) {
|
|
585
|
+
if (family === 'meta')
|
|
586
|
+
return parsed.stop_reason;
|
|
587
|
+
if (family === 'amazon')
|
|
588
|
+
return parsed.completionReason;
|
|
589
|
+
if (family === 'mistral') {
|
|
590
|
+
const outputs = Array.isArray(parsed.outputs) ? parsed.outputs : [];
|
|
591
|
+
const first = outputs[0] ?? {};
|
|
592
|
+
return first.stop_reason;
|
|
593
|
+
}
|
|
594
|
+
if (family === 'cohere') {
|
|
595
|
+
const generations = Array.isArray(parsed.generations) ? parsed.generations : [];
|
|
596
|
+
const first = generations[0] ?? {};
|
|
597
|
+
return first.finish_reason;
|
|
598
|
+
}
|
|
599
|
+
return undefined;
|
|
600
|
+
}
|
|
601
|
+
function normalizeMessages(input) {
|
|
602
|
+
if (typeof input === 'string')
|
|
603
|
+
return { messages: [{ role: 'user', content: input }] };
|
|
604
|
+
if (Array.isArray(input)) {
|
|
605
|
+
const system = [];
|
|
606
|
+
const rest = [];
|
|
607
|
+
for (const m of input) {
|
|
608
|
+
if (m.role === 'system')
|
|
609
|
+
system.push(m.content);
|
|
610
|
+
else
|
|
611
|
+
rest.push(m);
|
|
612
|
+
}
|
|
613
|
+
return system.length > 0 ? { messages: rest, system: system.join('\n\n') } : { messages: rest };
|
|
614
|
+
}
|
|
615
|
+
const explicit = input.system;
|
|
616
|
+
const inlineSystems = [];
|
|
617
|
+
const rest = [];
|
|
618
|
+
for (const m of input.messages) {
|
|
619
|
+
if (m.role === 'system')
|
|
620
|
+
inlineSystems.push(m.content);
|
|
621
|
+
else
|
|
622
|
+
rest.push(m);
|
|
623
|
+
}
|
|
624
|
+
const combined = [explicit, ...inlineSystems]
|
|
625
|
+
.filter((s) => typeof s === 'string' && s.length > 0)
|
|
626
|
+
.join('\n\n');
|
|
627
|
+
return combined.length > 0 ? { messages: rest, system: combined } : { messages: rest };
|
|
628
|
+
}
|
|
629
|
+
function extractTools(input) {
|
|
630
|
+
if (typeof input === 'string' || Array.isArray(input))
|
|
631
|
+
return undefined;
|
|
632
|
+
return input.tools;
|
|
633
|
+
}
|
|
634
|
+
/**
|
|
635
|
+
* Throw if the caller supplied `tools` on a Bedrock model family that this
|
|
636
|
+
* backend doesn't route them to. `capabilities()` advertises `tools: true`
|
|
637
|
+
* at the backend level, but only Anthropic-via-Bedrock actually consumes
|
|
638
|
+
* them in this PR — other families' body builders would silently drop
|
|
639
|
+
* the tools, leaving the caller unable to distinguish "model chose not to
|
|
640
|
+
* call" from "model never saw the tool". Loud error makes the
|
|
641
|
+
* unsupported-family case unambiguous; capability negotiation should
|
|
642
|
+
* eventually become model-aware (follow-up).
|
|
643
|
+
*/
|
|
644
|
+
function rejectToolsForFamily(input, family) {
|
|
645
|
+
const tools = extractTools(input);
|
|
646
|
+
if (tools && tools.length > 0) {
|
|
647
|
+
throw new BedrockBackendError(`Bedrock tool calls are not supported for model family '${family}' (only 'anthropic' models route tools in this version)`);
|
|
648
|
+
}
|
|
649
|
+
}
|
|
650
|
+
function toAnthropicMessage(m) {
|
|
651
|
+
if (m.role !== 'user' && m.role !== 'assistant' && m.role !== 'tool') {
|
|
652
|
+
return { role: 'user', content: m.content };
|
|
653
|
+
}
|
|
654
|
+
if (m.role === 'tool') {
|
|
655
|
+
return {
|
|
656
|
+
role: 'user',
|
|
657
|
+
content: [{ type: 'tool_result', tool_use_id: m.toolCallId ?? '', content: m.content }],
|
|
658
|
+
};
|
|
659
|
+
}
|
|
660
|
+
if (m.role === 'assistant' && m.toolCalls && m.toolCalls.length > 0) {
|
|
661
|
+
const blocks = [];
|
|
662
|
+
if (m.content)
|
|
663
|
+
blocks.push({ type: 'text', text: m.content });
|
|
664
|
+
for (const tc of m.toolCalls) {
|
|
665
|
+
blocks.push({ type: 'tool_use', id: tc.id, name: tc.name, input: tc.arguments ?? {} });
|
|
666
|
+
}
|
|
667
|
+
return { role: 'assistant', content: blocks };
|
|
668
|
+
}
|
|
669
|
+
return { role: m.role, content: m.content };
|
|
670
|
+
}
|
|
671
|
+
function flattenToLlamaPrompt(input) {
|
|
672
|
+
if (typeof input === 'string')
|
|
673
|
+
return input;
|
|
674
|
+
const messages = Array.isArray(input) ? input : input.messages;
|
|
675
|
+
const system = !Array.isArray(input) && typeof input.system === 'string' ? input.system : undefined;
|
|
676
|
+
const parts = [];
|
|
677
|
+
if (system)
|
|
678
|
+
parts.push(`<|begin_of_text|><|start_header_id|>system<|end_header_id|>\n\n${system}<|eot_id|>`);
|
|
679
|
+
for (const m of messages) {
|
|
680
|
+
parts.push(`<|start_header_id|>${m.role}<|end_header_id|>\n\n${m.content}<|eot_id|>`);
|
|
681
|
+
}
|
|
682
|
+
parts.push('<|start_header_id|>assistant<|end_header_id|>\n\n');
|
|
683
|
+
return parts.join('');
|
|
684
|
+
}
|
|
685
|
+
function flattenToFlatPrompt(input) {
|
|
686
|
+
if (typeof input === 'string')
|
|
687
|
+
return input;
|
|
688
|
+
const messages = Array.isArray(input) ? input : input.messages;
|
|
689
|
+
const system = !Array.isArray(input) && typeof input.system === 'string' ? input.system : undefined;
|
|
690
|
+
const parts = [];
|
|
691
|
+
if (system)
|
|
692
|
+
parts.push(`System: ${system}`);
|
|
693
|
+
for (const m of messages)
|
|
694
|
+
parts.push(`${m.role[0].toUpperCase()}${m.role.slice(1)}: ${m.content}`);
|
|
695
|
+
parts.push('Assistant:');
|
|
696
|
+
return parts.join('\n\n');
|
|
697
|
+
}
|
|
698
|
+
// ---------- finish-reason mapping ----------
|
|
699
|
+
function mapAnthropicStopReason(reason) {
|
|
700
|
+
switch (reason) {
|
|
701
|
+
case 'max_tokens':
|
|
702
|
+
return 'length';
|
|
703
|
+
case 'tool_use':
|
|
704
|
+
return 'tool_calls';
|
|
705
|
+
case 'end_turn':
|
|
706
|
+
case 'stop_sequence':
|
|
707
|
+
default:
|
|
708
|
+
return 'stop';
|
|
709
|
+
}
|
|
710
|
+
}
|
|
711
|
+
function mapGenericStopReason(reason) {
|
|
712
|
+
const r = (reason ?? '').toLowerCase();
|
|
713
|
+
if (r === 'length' || r === 'max_tokens' || r === 'max_token' || r === 'truncated')
|
|
714
|
+
return 'length';
|
|
715
|
+
if (r === 'tool_calls' || r === 'tool_use' || r === 'function_call')
|
|
716
|
+
return 'tool_calls';
|
|
717
|
+
if (r === 'content_filter' || r === 'content_filtered')
|
|
718
|
+
return 'content_filter';
|
|
719
|
+
return 'stop';
|
|
720
|
+
}
|
|
721
|
+
// ---------- response parsing ----------
|
|
722
|
+
function parseInvokeModelResponse(response) {
|
|
723
|
+
if (!response.body) {
|
|
724
|
+
throw new BedrockBackendError('Bedrock InvokeModel response missing body');
|
|
725
|
+
}
|
|
726
|
+
const text = typeof response.body === 'string' ? response.body : new TextDecoder('utf-8').decode(response.body);
|
|
727
|
+
try {
|
|
728
|
+
return JSON.parse(text);
|
|
729
|
+
}
|
|
730
|
+
catch {
|
|
731
|
+
throw new BedrockBackendError('Bedrock InvokeModel response body is not valid JSON');
|
|
732
|
+
}
|
|
733
|
+
}
|
|
734
|
+
//# sourceMappingURL=index.js.map
|