@harperfast/harper-pro 5.0.25 → 5.1.0-beta.1
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/analytics/profile.ts +4 -0
- package/core/AGENTS.md +92 -6
- package/core/DESIGN.md +24 -0
- package/core/README.md +11 -10
- package/core/agent/agent.ts +203 -0
- package/core/agent/loop.ts +205 -0
- package/core/agent/operations.ts +148 -0
- package/core/agent/session.ts +187 -0
- package/core/agent/tools/fsTools.ts +276 -0
- package/core/agent/tools/httpFetchTool.ts +112 -0
- package/core/agent/tools/scheduleTool.ts +68 -0
- package/core/agent/toolset.ts +43 -0
- package/core/agent/types.ts +85 -0
- package/core/benchmarks/hnsw-search.js +157 -0
- package/core/benchmarks/ycsb/README.md +144 -0
- package/core/benchmarks/ycsb/analyze-profile.mts +120 -0
- package/core/benchmarks/ycsb/app/config.yaml +3 -0
- package/core/benchmarks/ycsb/app/schema.graphql +17 -0
- package/core/benchmarks/ycsb/harness.mts +328 -0
- package/core/benchmarks/ycsb/restClient.mts +120 -0
- package/core/benchmarks/ycsb/run-single-node.mts +97 -0
- package/core/benchmarks/ycsb/to-benchmark-json.mts +58 -0
- package/core/benchmarks/ycsb/workload.mts +499 -0
- package/core/benchmarks/ycsb/workload.test.mts +174 -0
- package/core/bin/{BinObjects.js → BinObjects.ts} +4 -5
- package/core/bin/cliCredentials.ts +133 -0
- package/core/bin/cliOperations.ts +339 -0
- package/core/bin/copyDb.ts +10 -10
- package/core/bin/deployRenderer.ts +196 -0
- package/core/bin/{harper.js → harper.ts} +48 -24
- package/core/bin/{install.js → install.ts} +3 -3
- package/core/bin/lite.ts +2 -0
- package/core/bin/login.ts +168 -0
- package/core/bin/logout.ts +11 -0
- package/core/bin/mcp/client.ts +407 -0
- package/core/bin/mcp/doctor.ts +189 -0
- package/core/bin/mcp/index.ts +80 -0
- package/core/bin/mcp/options.ts +122 -0
- package/core/bin/mcp/printConfig.ts +89 -0
- package/core/bin/multipartBuilder.ts +74 -0
- package/core/bin/{restart.js → restart.ts} +31 -32
- package/core/bin/{run.js → run.ts} +57 -46
- package/core/bin/sseConsumer.ts +126 -0
- package/core/bin/{status.js → status.ts} +10 -10
- package/core/bin/stop.ts +21 -0
- package/core/bin/upgrade.js +6 -6
- package/core/components/Application.ts +144 -18
- package/core/components/ApplicationScope.ts +2 -2
- package/core/components/ComponentV1.ts +2 -2
- package/core/components/EntryHandler.ts +159 -9
- package/core/components/OptionsWatcher.ts +75 -11
- package/core/components/Scope.ts +125 -15
- package/core/components/anthropic/index.ts +547 -0
- package/core/components/bedrock/index.ts +823 -0
- package/core/components/componentLoader.ts +63 -32
- package/core/components/deployLifecycle.ts +161 -0
- package/core/components/deploymentOperations.ts +173 -0
- package/core/components/deploymentRecorder.ts +402 -0
- package/core/components/deriveURLPath.ts +4 -4
- package/core/components/mcp/adapters/fastify.ts +87 -0
- package/core/components/mcp/adapters/harperHttp.ts +103 -0
- package/core/components/mcp/audit.ts +75 -0
- package/core/components/mcp/index.ts +134 -0
- package/core/components/mcp/jsonrpc.ts +134 -0
- package/core/components/mcp/lifecycle.ts +105 -0
- package/core/components/mcp/listChanged.ts +270 -0
- package/core/components/mcp/rateLimit.ts +217 -0
- package/core/components/mcp/resources.ts +593 -0
- package/core/components/mcp/session.ts +151 -0
- package/core/components/mcp/sessionRegistry.ts +140 -0
- package/core/components/mcp/toolRegistry.ts +292 -0
- package/core/components/mcp/tools/application.ts +603 -0
- package/core/components/mcp/tools/operations.ts +283 -0
- package/core/components/mcp/tools/schemas/derive.ts +256 -0
- package/core/components/mcp/tools/schemas/operations.ts +245 -0
- package/core/components/mcp/transport.ts +517 -0
- package/core/components/ollama/index.ts +316 -0
- package/core/components/openai/index.ts +563 -0
- package/core/components/operations.js +211 -60
- package/core/components/operationsValidation.js +3 -3
- package/core/components/packageComponent.ts +97 -29
- package/core/components/requestRestart.ts +17 -2
- package/core/components/status/crossThread.ts +14 -5
- package/core/components/status/errors.ts +1 -1
- package/core/config/RootConfigWatcher.ts +56 -2
- package/core/config/configUtils.js +29 -8
- package/core/config/harperConfigEnvVars.ts +1 -1
- package/core/dataLayer/{CreateAttributeObject.js → CreateAttributeObject.ts} +4 -3
- package/core/dataLayer/{CreateTableObject.js → CreateTableObject.ts} +2 -1
- package/core/dataLayer/{DataLayerObjects.js → DataLayerObjects.ts} +17 -9
- package/core/dataLayer/{DeleteBeforeObject.js → DeleteBeforeObject.ts} +2 -1
- package/core/dataLayer/{DeleteObject.js → DeleteObject.ts} +3 -2
- package/core/dataLayer/{DropAttributeObject.js → DropAttributeObject.ts} +2 -1
- package/core/dataLayer/{GetBackupObject.js → GetBackupObject.ts} +3 -2
- package/core/dataLayer/{InsertObject.js → InsertObject.ts} +3 -2
- package/core/dataLayer/{ReadAuditLogObject.js → ReadAuditLogObject.ts} +3 -2
- package/core/dataLayer/{SQLSearch.js → SQLSearch.ts} +97 -43
- package/core/dataLayer/{SearchByConditionsObject.js → SearchByConditionsObject.ts} +5 -6
- package/core/dataLayer/{SearchByHashObject.js → SearchByHashObject.ts} +2 -1
- package/core/dataLayer/{SearchObject.js → SearchObject.ts} +2 -1
- package/core/dataLayer/{SqlSearchObject.js → SqlSearchObject.ts} +2 -1
- package/core/dataLayer/{UpdateObject.js → UpdateObject.ts} +3 -2
- package/core/dataLayer/{UpsertObject.js → UpsertObject.ts} +3 -2
- package/core/dataLayer/{bulkLoad.js → bulkLoad.ts} +40 -49
- package/core/dataLayer/{delete.js → delete.ts} +21 -26
- package/core/dataLayer/{export.js → export.ts} +22 -26
- package/core/dataLayer/{getBackup.js → getBackup.ts} +7 -9
- package/core/dataLayer/harperBridge/BridgeMethods.ts +102 -0
- package/core/dataLayer/harperBridge/ResourceBridge.ts +27 -26
- package/core/dataLayer/harperBridge/TableSizeObject.ts +1 -0
- package/core/dataLayer/harperBridge/bridgeUtility/insertUpdateValidate.js +4 -4
- package/core/dataLayer/harperBridge/{harperBridge.js → harperBridge.ts} +3 -3
- package/core/dataLayer/harperBridge/lmdbBridge/lmdbMethods/lmdbCreateAttribute.js +8 -6
- package/core/dataLayer/harperBridge/lmdbBridge/lmdbMethods/lmdbCreateRecords.js +4 -4
- package/core/dataLayer/harperBridge/lmdbBridge/lmdbMethods/lmdbCreateSchema.js +1 -1
- package/core/dataLayer/harperBridge/lmdbBridge/lmdbMethods/lmdbCreateTable.js +6 -4
- package/core/dataLayer/harperBridge/lmdbBridge/lmdbMethods/lmdbDeleteAuditLogsBefore.js +5 -4
- package/core/dataLayer/harperBridge/lmdbBridge/lmdbMethods/lmdbDeleteRecords.js +4 -4
- package/core/dataLayer/harperBridge/lmdbBridge/lmdbMethods/lmdbDropAttribute.js +6 -5
- package/core/dataLayer/harperBridge/lmdbBridge/lmdbMethods/lmdbDropSchema.js +5 -4
- package/core/dataLayer/harperBridge/lmdbBridge/lmdbMethods/lmdbDropTable.js +5 -5
- package/core/dataLayer/harperBridge/lmdbBridge/lmdbMethods/lmdbFlush.js +1 -1
- package/core/dataLayer/harperBridge/lmdbBridge/lmdbMethods/lmdbGetBackup.js +3 -3
- package/core/dataLayer/harperBridge/lmdbBridge/lmdbMethods/lmdbGetDataByHash.js +1 -1
- package/core/dataLayer/harperBridge/lmdbBridge/lmdbMethods/lmdbGetDataByValue.js +3 -2
- package/core/dataLayer/harperBridge/lmdbBridge/lmdbMethods/lmdbReadAuditLog.js +5 -5
- package/core/dataLayer/harperBridge/lmdbBridge/lmdbMethods/lmdbSearchByConditions.js +10 -8
- package/core/dataLayer/harperBridge/lmdbBridge/lmdbMethods/lmdbSearchByHash.js +1 -1
- package/core/dataLayer/harperBridge/lmdbBridge/lmdbMethods/lmdbSearchByValue.js +4 -3
- package/core/dataLayer/harperBridge/lmdbBridge/lmdbMethods/lmdbUpdateRecords.js +3 -3
- package/core/dataLayer/harperBridge/lmdbBridge/lmdbMethods/lmdbUpsertRecords.js +6 -5
- package/core/dataLayer/harperBridge/lmdbBridge/lmdbUtility/LMDBCreateAttributeObject.js +2 -1
- package/core/dataLayer/harperBridge/lmdbBridge/lmdbUtility/initializeHashSearch.js +3 -2
- package/core/dataLayer/harperBridge/lmdbBridge/lmdbUtility/initializePaths.js +2 -2
- package/core/dataLayer/harperBridge/lmdbBridge/lmdbUtility/lmdbCheckForNewAttributes.js +5 -4
- package/core/dataLayer/harperBridge/lmdbBridge/lmdbUtility/lmdbCreateTransactionsAuditEnvironment.js +6 -3
- package/core/dataLayer/harperBridge/lmdbBridge/lmdbUtility/lmdbGetTableSize.ts +1 -1
- package/core/dataLayer/harperBridge/lmdbBridge/lmdbUtility/lmdbProcessRows.js +4 -4
- package/core/dataLayer/harperBridge/lmdbBridge/lmdbUtility/lmdbSearch.js +5 -5
- package/core/dataLayer/harperBridge/lmdbBridge/lmdbUtility/lmdbWriteTransaction.js +4 -4
- package/core/dataLayer/{hdbInfoController.js → hdbInfoController.ts} +20 -26
- package/core/dataLayer/{insert.js → insert.ts} +24 -24
- package/core/dataLayer/{readAuditLog.js → readAuditLog.ts} +8 -10
- package/core/dataLayer/{schema.js → schema.ts} +32 -44
- package/core/dataLayer/{schemaDescribe.js → schemaDescribe.ts} +23 -26
- package/core/dataLayer/{search.js → search.ts} +9 -15
- package/core/dataLayer/{transaction.js → transaction.ts} +2 -5
- package/core/dataLayer/{update.js → update.ts} +19 -22
- package/core/index.ts +5 -0
- package/core/json/systemSchema.json +65 -0
- package/core/launchServiceScripts/utility/checkNodeVersion.js +2 -0
- package/core/package-lock.json +9051 -4318
- package/core/resources/DESIGN.md +98 -0
- package/core/resources/DatabaseTransaction.ts +58 -30
- package/core/resources/ErrorResource.ts +2 -1
- package/core/resources/LMDBTransaction.ts +38 -29
- package/core/resources/RecordEncoder.ts +12 -4
- package/core/resources/RequestTarget.ts +2 -0
- package/core/resources/Resource.ts +89 -56
- package/core/resources/ResourceInterface.ts +44 -21
- package/core/resources/Resources.ts +8 -8
- package/core/resources/RocksIndexStore.ts +3 -0
- package/core/resources/RocksTransactionLogStore.ts +47 -28
- package/core/resources/Table.ts +386 -214
- package/core/resources/analytics/metadata.ts +1 -0
- package/core/resources/analytics/read.ts +24 -6
- package/core/resources/analytics/write.ts +240 -17
- package/core/resources/auditStore.ts +28 -19
- package/core/resources/blob.ts +53 -53
- package/core/resources/dataLoader.ts +4 -4
- package/core/resources/databases.ts +190 -71
- package/core/resources/graphql.ts +227 -164
- package/core/resources/indexes/HierarchicalNavigableSmallWorld.ts +294 -65
- package/core/resources/indexes/vector.ts +17 -0
- package/core/resources/loadEnv.ts +21 -17
- package/core/resources/login.ts +5 -3
- package/core/resources/models/Models.ts +304 -0
- package/core/resources/models/TestBackend.ts +83 -0
- package/core/resources/models/agentLoop.ts +895 -0
- package/core/resources/models/analyticsTable.ts +199 -0
- package/core/resources/models/backendHelpers.ts +116 -0
- package/core/resources/models/backendRegistry.ts +66 -0
- package/core/resources/models/bootstrap.ts +135 -0
- package/core/resources/models/embedHook.ts +138 -0
- package/core/resources/models/types.ts +296 -0
- package/core/resources/replayLogs.ts +15 -7
- package/core/resources/roles.ts +62 -67
- package/core/resources/search.ts +355 -135
- package/core/resources/tracked.ts +8 -8
- package/core/resources/transaction.ts +8 -8
- package/core/resources/transactionBroadcast.ts +3 -3
- package/core/security/auth.ts +35 -26
- package/core/security/certificateVerification/crlVerification.ts +11 -4
- package/core/security/{cryptoHash.js → cryptoHash.ts} +3 -8
- package/core/security/data_objects/{PermissionAttributeResponseObject.js → PermissionAttributeResponseObject.ts} +4 -4
- package/core/security/data_objects/{PermissionResponseObject.js → PermissionResponseObject.ts} +12 -11
- package/core/security/data_objects/{PermissionTableResponseObject.js → PermissionTableResponseObject.ts} +6 -4
- package/core/security/{fastifyAuth.js → fastifyAuth.ts} +93 -20
- package/core/security/impersonation.ts +3 -3
- package/core/security/jsLoader.ts +22 -8
- package/core/security/{keys.js → keys.ts} +113 -121
- package/core/security/permissionsTranslator.js +2 -2
- package/core/security/{role.js → role.ts} +26 -33
- package/core/security/tokenAuthentication.ts +34 -7
- package/core/security/user.ts +26 -22
- package/core/server/DESIGN.md +139 -0
- package/core/server/DurableSubscriptionsSession.ts +67 -50
- package/core/server/REST.ts +120 -107
- package/core/server/Server.ts +31 -12
- package/core/server/fastifyRoutes/helpers/getCORSOptions.js +1 -1
- package/core/server/fastifyRoutes/helpers/getHeaderTimeoutConfig.js +1 -1
- package/core/server/fastifyRoutes/helpers/getServerOptions.js +1 -1
- package/core/server/fastifyRoutes.ts +37 -33
- package/core/server/graphqlQuerying.ts +6 -5
- package/core/server/http.ts +517 -26
- package/core/server/itc/serverHandlers.js +75 -14
- package/core/server/jobs/{JobObject.js → JobObject.ts} +13 -6
- package/core/server/jobs/{jobProcess.js → jobProcess.ts} +20 -16
- package/core/server/jobs/{jobRunner.js → jobRunner.ts} +20 -21
- package/core/server/jobs/{jobs.js → jobs.ts} +41 -44
- package/core/server/loadRootComponents.js +1 -1
- package/core/server/middlewareChain.ts +270 -0
- package/core/server/mqtt.ts +35 -26
- package/core/server/nodeName.ts +2 -1
- package/core/server/operationsServer.ts +85 -10
- package/core/server/serverHelpers/Headers.ts +10 -8
- package/core/server/serverHelpers/JSONStream.ts +15 -5
- package/core/server/serverHelpers/Request.ts +370 -13
- package/core/server/serverHelpers/contentTypes.ts +42 -11
- package/core/server/serverHelpers/multipartParser.ts +152 -0
- package/core/server/serverHelpers/progressEmitter.ts +110 -0
- package/core/server/serverHelpers/serverHandlers.js +43 -7
- package/core/server/serverHelpers/serverUtilities.ts +40 -30
- package/core/server/static.ts +9 -6
- package/core/server/status/index.ts +2 -2
- package/core/server/storageReclamation.ts +39 -2
- package/core/server/threads/itc.js +7 -4
- package/core/server/threads/manageThreads.js +100 -26
- package/core/server/threads/socketRouter.ts +12 -275
- package/core/server/threads/threadServer.js +345 -105
- package/core/server/threads/workerProcessGuard.ts +93 -0
- package/core/server/throttle.ts +18 -0
- package/core/sqlTranslator/{SelectValidator.js → SelectValidator.ts} +41 -49
- package/core/sqlTranslator/{alasqlFunctionImporter.js → alasqlFunctionImporter.ts} +5 -5
- package/core/sqlTranslator/{deleteTranslator.js → deleteTranslator.ts} +13 -18
- package/core/sqlTranslator/{index.js → index.ts} +30 -33
- package/core/sqlTranslator/{sql_statement_bucket.js → sql_statement_bucket.ts} +49 -20
- package/core/static/README.md +10 -9
- package/core/system/000004.log +0 -0
- package/core/system/CURRENT +1 -0
- package/core/system/IDENTITY +1 -0
- package/core/system/LOCK +0 -0
- package/core/system/LOG +1351 -0
- package/core/system/MANIFEST-000005 +0 -0
- package/core/system/OPTIONS-000013 +607 -0
- package/core/system/OPTIONS-000015 +734 -0
- package/core/upgrade/{UpgradeObjects.js → UpgradeObjects.ts} +3 -6
- package/core/upgrade/directives/5-2-0.ts +49 -0
- package/core/upgrade/directives/{directivesController.js → directivesController.ts} +16 -16
- package/core/upgrade/{directivesManager.js → directivesManager.ts} +7 -11
- package/core/upgrade/{upgradePrompt.js → upgradePrompt.ts} +8 -14
- package/core/upgrade/{upgradeUtilities.js → upgradeUtilities.ts} +3 -7
- package/core/utility/{OperationFunctionCaller.js → OperationFunctionCaller.ts} +7 -7
- package/core/utility/{assignCmdEnvVariables.js → assignCmdEnvVariables.ts} +6 -8
- package/core/utility/{common_utils.js → common_utils.ts} +113 -139
- package/core/utility/environment/{environmentManager.js → environmentManager.ts} +34 -33
- package/core/utility/environment/systemInformation.ts +18 -4
- package/core/utility/errors/{commonErrors.js → commonErrors.ts} +9 -9
- package/core/utility/errors/{hdbError.js → hdbError.ts} +39 -45
- package/core/utility/expandEnvVar.ts +110 -0
- package/core/utility/functions/geo.js +2 -2
- package/core/utility/functions/sql/alaSQLExtension.js +1 -1
- package/core/utility/globalSchema.ts +30 -0
- package/core/utility/hdbTerms.ts +56 -0
- package/core/utility/install/checkJWTTokensExist.js +1 -1
- package/core/utility/install/{installer.js → installer.ts} +58 -59
- package/core/utility/installation.ts +2 -2
- package/core/utility/lmdb/{DBIDefinition.js → DBIDefinition.ts} +4 -1
- package/core/utility/lmdb/{DeleteRecordsResponseObject.js → DeleteRecordsResponseObject.ts} +2 -1
- package/core/utility/lmdb/{InsertRecordsResponseObject.js → InsertRecordsResponseObject.ts} +2 -1
- package/core/utility/lmdb/OpenDBIObject.ts +43 -0
- package/core/utility/lmdb/{OpenEnvironmentObject.js → OpenEnvironmentObject.ts} +19 -6
- package/core/utility/lmdb/{UpdateRecordsResponseObject.js → UpdateRecordsResponseObject.ts} +2 -1
- package/core/utility/lmdb/{UpsertRecordsResponseObject.js → UpsertRecordsResponseObject.ts} +2 -1
- package/core/utility/lmdb/{cleanLMDBMap.js → cleanLMDBMap.ts} +5 -5
- package/core/utility/lmdb/{commonUtility.js → commonUtility.ts} +13 -21
- package/core/utility/lmdb/{deleteUtility.js → deleteUtility.ts} +8 -12
- package/core/utility/lmdb/{environmentUtility.js → environmentUtility.ts} +43 -52
- package/core/utility/lmdb/{searchCursorFunctions.js → searchCursorFunctions.ts} +12 -26
- package/core/utility/lmdb/{searchUtility.js → searchUtility.ts} +75 -64
- package/core/utility/lmdb/{terms.js → terms.ts} +10 -23
- package/core/utility/lmdb/{writeUtility.js → writeUtility.ts} +37 -22
- package/core/utility/logging/{harper_logger.js → harper_logger.ts} +136 -89
- package/core/utility/logging/{logRotator.js → logRotator.ts} +13 -13
- package/core/utility/logging/logger.ts +1 -1
- package/core/utility/logging/{readLog.js → readLog.ts} +19 -19
- package/core/utility/logging/{transactionLog.js → transactionLog.ts} +10 -14
- package/core/utility/{mount_hdb.js → mount_hdb.ts} +15 -16
- package/core/utility/{npmUtilities.js → npmUtilities.ts} +14 -17
- package/core/utility/{operation_authorization.js → operation_authorization.ts} +173 -124
- package/core/utility/packageUtils.js +7 -16
- package/core/utility/password.ts +1 -1
- package/core/utility/processManagement/processManagement.js +2 -2
- package/core/utility/processManagement/servicesConfig.js +1 -1
- package/core/utility/{signalling.js → signalling.ts} +6 -11
- package/core/utility/watcherFallback.ts +74 -0
- package/core/validation/analyticsValidator.ts +43 -0
- package/core/validation/{bulkDeleteValidator.js → bulkDeleteValidator.ts} +5 -5
- package/core/validation/{check_permissions.js → check_permissions.ts} +3 -3
- package/core/validation/{common_validators.js → common_validators.ts} +12 -24
- package/core/validation/{configValidator.js → configValidator.ts} +114 -18
- package/core/validation/{deleteValidator.js → deleteValidator.ts} +5 -5
- package/core/validation/{fileLoadValidator.js → fileLoadValidator.ts} +12 -19
- package/core/validation/{insertValidator.js → insertValidator.ts} +5 -5
- package/core/validation/{installValidator.js → installValidator.ts} +8 -8
- package/core/validation/{readLogValidator.js → readLogValidator.ts} +10 -10
- package/core/validation/{role_validation.js → role_validation.ts} +26 -32
- package/core/validation/{schemaMetadataValidator.js → schemaMetadataValidator.ts} +5 -11
- package/core/validation/{searchValidator.js → searchValidator.ts} +12 -11
- package/core/validation/statusValidator.ts +1 -1
- package/core/validation/{transactionLogValidator.js → transactionLogValidator.ts} +4 -9
- package/core/validation/{user_validation.js → user_validation.ts} +4 -10
- package/core/validation/{validationWrapper.js → validationWrapper.ts} +3 -9
- package/dist/analytics/profile.js +4 -0
- package/dist/analytics/profile.js.map +1 -1
- package/dist/cloneNode/cloneNode.js +224 -12
- package/dist/cloneNode/cloneNode.js.map +1 -1
- package/dist/core/agent/agent.js +175 -0
- package/dist/core/agent/agent.js.map +1 -0
- package/dist/core/agent/loop.js +176 -0
- package/dist/core/agent/loop.js.map +1 -0
- package/dist/core/agent/operations.js +137 -0
- package/dist/core/agent/operations.js.map +1 -0
- package/dist/core/agent/session.js +182 -0
- package/dist/core/agent/session.js.map +1 -0
- package/dist/core/agent/tools/fsTools.js +286 -0
- package/dist/core/agent/tools/fsTools.js.map +1 -0
- package/dist/core/agent/tools/httpFetchTool.js +116 -0
- package/dist/core/agent/tools/httpFetchTool.js.map +1 -0
- package/dist/core/agent/tools/scheduleTool.js +54 -0
- package/dist/core/agent/tools/scheduleTool.js.map +1 -0
- package/dist/core/agent/toolset.js +33 -0
- package/dist/core/agent/toolset.js.map +1 -0
- package/dist/core/agent/types.js +10 -0
- package/dist/core/agent/types.js.map +1 -0
- package/dist/core/bin/BinObjects.js +6 -3
- package/dist/core/bin/BinObjects.js.map +1 -1
- package/dist/core/bin/cliCredentials.js +130 -0
- package/dist/core/bin/cliCredentials.js.map +1 -0
- package/dist/core/bin/cliOperations.js +254 -40
- package/dist/core/bin/cliOperations.js.map +1 -1
- package/dist/core/bin/copyDb.js +16 -16
- package/dist/core/bin/copyDb.js.map +1 -1
- package/dist/core/bin/deployRenderer.js +185 -0
- package/dist/core/bin/deployRenderer.js.map +1 -0
- package/dist/core/bin/harper.js +92 -31
- package/dist/core/bin/harper.js.map +1 -1
- package/dist/core/bin/install.js +41 -4
- package/dist/core/bin/install.js.map +1 -1
- package/dist/core/bin/lite.js +3 -4
- package/dist/core/bin/lite.js.map +1 -1
- package/dist/core/bin/login.js +158 -0
- package/dist/core/bin/login.js.map +1 -0
- package/dist/core/bin/logout.js +16 -0
- package/dist/core/bin/logout.js.map +1 -0
- package/dist/core/bin/mcp/client.js +395 -0
- package/dist/core/bin/mcp/client.js.map +1 -0
- package/dist/core/bin/mcp/doctor.js +193 -0
- package/dist/core/bin/mcp/doctor.js.map +1 -0
- package/dist/core/bin/mcp/index.js +81 -0
- package/dist/core/bin/mcp/index.js.map +1 -0
- package/dist/core/bin/mcp/options.js +113 -0
- package/dist/core/bin/mcp/options.js.map +1 -0
- package/dist/core/bin/mcp/printConfig.js +85 -0
- package/dist/core/bin/mcp/printConfig.js.map +1 -0
- package/dist/core/bin/multipartBuilder.js +55 -0
- package/dist/core/bin/multipartBuilder.js.map +1 -0
- package/dist/core/bin/restart.js +85 -48
- package/dist/core/bin/restart.js.map +1 -1
- package/dist/core/bin/run.js +123 -77
- package/dist/core/bin/run.js.map +1 -1
- package/dist/core/bin/sseConsumer.js +127 -0
- package/dist/core/bin/sseConsumer.js.map +1 -0
- package/dist/core/bin/status.js +48 -11
- package/dist/core/bin/status.js.map +1 -1
- package/dist/core/bin/stop.js +44 -7
- package/dist/core/bin/stop.js.map +1 -1
- package/dist/core/bin/upgrade.js +6 -6
- package/dist/core/components/Application.js +134 -28
- package/dist/core/components/Application.js.map +1 -1
- package/dist/core/components/ApplicationScope.js +2 -2
- package/dist/core/components/ComponentV1.js +5 -5
- package/dist/core/components/ComponentV1.js.map +1 -1
- package/dist/core/components/EntryHandler.js +153 -13
- package/dist/core/components/EntryHandler.js.map +1 -1
- package/dist/core/components/OptionsWatcher.js +72 -10
- package/dist/core/components/OptionsWatcher.js.map +1 -1
- package/dist/core/components/Scope.js +105 -9
- package/dist/core/components/Scope.js.map +1 -1
- package/dist/core/components/anthropic/index.js +428 -0
- package/dist/core/components/anthropic/index.js.map +1 -0
- package/dist/core/components/bedrock/index.js +734 -0
- package/dist/core/components/bedrock/index.js.map +1 -0
- package/dist/core/components/componentLoader.js +63 -38
- package/dist/core/components/componentLoader.js.map +1 -1
- package/dist/core/components/deployLifecycle.js +156 -0
- package/dist/core/components/deployLifecycle.js.map +1 -0
- package/dist/core/components/deploymentOperations.js +185 -0
- package/dist/core/components/deploymentOperations.js.map +1 -0
- package/dist/core/components/deploymentRecorder.js +401 -0
- package/dist/core/components/deploymentRecorder.js.map +1 -0
- package/dist/core/components/deriveURLPath.js +2 -2
- package/dist/core/components/deriveURLPath.js.map +1 -1
- package/dist/core/components/mcp/adapters/fastify.js +66 -0
- package/dist/core/components/mcp/adapters/fastify.js.map +1 -0
- package/dist/core/components/mcp/adapters/harperHttp.js +78 -0
- package/dist/core/components/mcp/adapters/harperHttp.js.map +1 -0
- package/dist/core/components/mcp/audit.js +73 -0
- package/dist/core/components/mcp/audit.js.map +1 -0
- package/dist/core/components/mcp/index.js +109 -0
- package/dist/core/components/mcp/index.js.map +1 -0
- package/dist/core/components/mcp/jsonrpc.js +93 -0
- package/dist/core/components/mcp/jsonrpc.js.map +1 -0
- package/dist/core/components/mcp/lifecycle.js +79 -0
- package/dist/core/components/mcp/lifecycle.js.map +1 -0
- package/dist/core/components/mcp/listChanged.js +257 -0
- package/dist/core/components/mcp/listChanged.js.map +1 -0
- package/dist/core/components/mcp/rateLimit.js +226 -0
- package/dist/core/components/mcp/rateLimit.js.map +1 -0
- package/dist/core/components/mcp/resources.js +515 -0
- package/dist/core/components/mcp/resources.js.map +1 -0
- package/dist/core/components/mcp/session.js +170 -0
- package/dist/core/components/mcp/session.js.map +1 -0
- package/dist/core/components/mcp/sessionRegistry.js +124 -0
- package/dist/core/components/mcp/sessionRegistry.js.map +1 -0
- package/dist/core/components/mcp/toolRegistry.js +176 -0
- package/dist/core/components/mcp/toolRegistry.js.map +1 -0
- package/dist/core/components/mcp/tools/application.js +549 -0
- package/dist/core/components/mcp/tools/application.js.map +1 -0
- package/dist/core/components/mcp/tools/operations.js +303 -0
- package/dist/core/components/mcp/tools/operations.js.map +1 -0
- package/dist/core/components/mcp/tools/schemas/derive.js +216 -0
- package/dist/core/components/mcp/tools/schemas/derive.js.map +1 -0
- package/dist/core/components/mcp/tools/schemas/operations.js +243 -0
- package/dist/core/components/mcp/tools/schemas/operations.js.map +1 -0
- package/dist/core/components/mcp/transport.js +467 -0
- package/dist/core/components/mcp/transport.js.map +1 -0
- package/dist/core/components/ollama/index.js +239 -0
- package/dist/core/components/ollama/index.js.map +1 -0
- package/dist/core/components/openai/index.js +475 -0
- package/dist/core/components/openai/index.js.map +1 -0
- package/dist/core/components/operations.js +198 -52
- package/dist/core/components/operations.js.map +1 -1
- package/dist/core/components/operationsValidation.js +3 -3
- package/dist/core/components/packageComponent.js +87 -26
- package/dist/core/components/packageComponent.js.map +1 -1
- package/dist/core/components/requestRestart.js +12 -1
- package/dist/core/components/requestRestart.js.map +1 -1
- package/dist/core/components/status/crossThread.js +12 -5
- package/dist/core/components/status/crossThread.js.map +1 -1
- package/dist/core/components/status/errors.js +7 -7
- package/dist/core/config/RootConfigWatcher.js +52 -1
- package/dist/core/config/RootConfigWatcher.js.map +1 -1
- package/dist/core/config/configUtils.js +31 -8
- package/dist/core/config/configUtils.js.map +1 -1
- package/dist/core/config/harperConfigEnvVars.js +1 -1
- package/dist/core/config/harperConfigEnvVars.js.map +1 -1
- package/dist/core/dataLayer/CreateAttributeObject.js +4 -3
- package/dist/core/dataLayer/CreateAttributeObject.js.map +1 -1
- package/dist/core/dataLayer/CreateTableObject.js +2 -1
- package/dist/core/dataLayer/CreateTableObject.js.map +1 -1
- package/dist/core/dataLayer/DataLayerObjects.js +19 -5
- package/dist/core/dataLayer/DataLayerObjects.js.map +1 -1
- package/dist/core/dataLayer/DeleteBeforeObject.js +2 -1
- package/dist/core/dataLayer/DeleteBeforeObject.js.map +1 -1
- package/dist/core/dataLayer/DeleteObject.js +4 -3
- package/dist/core/dataLayer/DeleteObject.js.map +1 -1
- package/dist/core/dataLayer/DropAttributeObject.js +2 -1
- package/dist/core/dataLayer/DropAttributeObject.js.map +1 -1
- package/dist/core/dataLayer/GetBackupObject.js +4 -3
- package/dist/core/dataLayer/GetBackupObject.js.map +1 -1
- package/dist/core/dataLayer/InsertObject.js +4 -3
- package/dist/core/dataLayer/InsertObject.js.map +1 -1
- package/dist/core/dataLayer/ReadAuditLogObject.js +4 -3
- package/dist/core/dataLayer/ReadAuditLogObject.js.map +1 -1
- package/dist/core/dataLayer/SQLSearch.js +140 -78
- package/dist/core/dataLayer/SQLSearch.js.map +1 -1
- package/dist/core/dataLayer/SearchByConditionsObject.js +5 -7
- package/dist/core/dataLayer/SearchByConditionsObject.js.map +1 -1
- package/dist/core/dataLayer/SearchByHashObject.js +2 -1
- package/dist/core/dataLayer/SearchByHashObject.js.map +1 -1
- package/dist/core/dataLayer/SearchObject.js +2 -1
- package/dist/core/dataLayer/SearchObject.js.map +1 -1
- package/dist/core/dataLayer/SqlSearchObject.js +2 -1
- package/dist/core/dataLayer/SqlSearchObject.js.map +1 -1
- package/dist/core/dataLayer/UpdateObject.js +4 -3
- package/dist/core/dataLayer/UpdateObject.js.map +1 -1
- package/dist/core/dataLayer/UpsertObject.js +4 -3
- package/dist/core/dataLayer/UpsertObject.js.map +1 -1
- package/dist/core/dataLayer/bulkLoad.js +122 -88
- package/dist/core/dataLayer/bulkLoad.js.map +1 -1
- package/dist/core/dataLayer/delete.js +74 -39
- package/dist/core/dataLayer/delete.js.map +1 -1
- package/dist/core/dataLayer/export.js +90 -55
- package/dist/core/dataLayer/export.js.map +1 -1
- package/dist/core/dataLayer/getBackup.js +43 -11
- package/dist/core/dataLayer/getBackup.js.map +1 -1
- package/dist/core/dataLayer/harperBridge/BridgeMethods.js +41 -20
- package/dist/core/dataLayer/harperBridge/BridgeMethods.js.map +1 -1
- package/dist/core/dataLayer/harperBridge/ResourceBridge.js +26 -25
- package/dist/core/dataLayer/harperBridge/ResourceBridge.js.map +1 -1
- package/dist/core/dataLayer/harperBridge/TableSizeObject.js.map +1 -1
- package/dist/core/dataLayer/harperBridge/bridgeUtility/insertUpdateValidate.js +4 -4
- package/dist/core/dataLayer/harperBridge/harperBridge.js +38 -4
- package/dist/core/dataLayer/harperBridge/harperBridge.js.map +1 -1
- package/dist/core/dataLayer/harperBridge/lmdbBridge/lmdbMethods/lmdbCreateAttribute.js +7 -6
- package/dist/core/dataLayer/harperBridge/lmdbBridge/lmdbMethods/lmdbCreateAttribute.js.map +1 -1
- package/dist/core/dataLayer/harperBridge/lmdbBridge/lmdbMethods/lmdbCreateRecords.js +4 -4
- package/dist/core/dataLayer/harperBridge/lmdbBridge/lmdbMethods/lmdbCreateRecords.js.map +1 -1
- package/dist/core/dataLayer/harperBridge/lmdbBridge/lmdbMethods/lmdbCreateSchema.js +1 -1
- package/dist/core/dataLayer/harperBridge/lmdbBridge/lmdbMethods/lmdbCreateSchema.js.map +1 -1
- package/dist/core/dataLayer/harperBridge/lmdbBridge/lmdbMethods/lmdbCreateTable.js +5 -4
- package/dist/core/dataLayer/harperBridge/lmdbBridge/lmdbMethods/lmdbCreateTable.js.map +1 -1
- package/dist/core/dataLayer/harperBridge/lmdbBridge/lmdbMethods/lmdbDeleteAuditLogsBefore.js +4 -4
- package/dist/core/dataLayer/harperBridge/lmdbBridge/lmdbMethods/lmdbDeleteAuditLogsBefore.js.map +1 -1
- package/dist/core/dataLayer/harperBridge/lmdbBridge/lmdbMethods/lmdbDeleteRecords.js +4 -4
- package/dist/core/dataLayer/harperBridge/lmdbBridge/lmdbMethods/lmdbDropAttribute.js +5 -5
- package/dist/core/dataLayer/harperBridge/lmdbBridge/lmdbMethods/lmdbDropAttribute.js.map +1 -1
- package/dist/core/dataLayer/harperBridge/lmdbBridge/lmdbMethods/lmdbDropSchema.js +4 -4
- package/dist/core/dataLayer/harperBridge/lmdbBridge/lmdbMethods/lmdbDropSchema.js.map +1 -1
- package/dist/core/dataLayer/harperBridge/lmdbBridge/lmdbMethods/lmdbDropTable.js +5 -5
- package/dist/core/dataLayer/harperBridge/lmdbBridge/lmdbMethods/lmdbDropTable.js.map +1 -1
- package/dist/core/dataLayer/harperBridge/lmdbBridge/lmdbMethods/lmdbFlush.js +1 -1
- package/dist/core/dataLayer/harperBridge/lmdbBridge/lmdbMethods/lmdbGetBackup.js +3 -3
- package/dist/core/dataLayer/harperBridge/lmdbBridge/lmdbMethods/lmdbGetDataByHash.js +1 -1
- package/dist/core/dataLayer/harperBridge/lmdbBridge/lmdbMethods/lmdbGetDataByValue.js +2 -2
- package/dist/core/dataLayer/harperBridge/lmdbBridge/lmdbMethods/lmdbGetDataByValue.js.map +1 -1
- package/dist/core/dataLayer/harperBridge/lmdbBridge/lmdbMethods/lmdbReadAuditLog.js +5 -5
- package/dist/core/dataLayer/harperBridge/lmdbBridge/lmdbMethods/lmdbSearchByConditions.js +8 -8
- package/dist/core/dataLayer/harperBridge/lmdbBridge/lmdbMethods/lmdbSearchByConditions.js.map +1 -1
- package/dist/core/dataLayer/harperBridge/lmdbBridge/lmdbMethods/lmdbSearchByHash.js +1 -1
- package/dist/core/dataLayer/harperBridge/lmdbBridge/lmdbMethods/lmdbSearchByValue.js +3 -3
- package/dist/core/dataLayer/harperBridge/lmdbBridge/lmdbMethods/lmdbSearchByValue.js.map +1 -1
- package/dist/core/dataLayer/harperBridge/lmdbBridge/lmdbMethods/lmdbUpdateRecords.js +3 -3
- package/dist/core/dataLayer/harperBridge/lmdbBridge/lmdbMethods/lmdbUpsertRecords.js +5 -5
- package/dist/core/dataLayer/harperBridge/lmdbBridge/lmdbMethods/lmdbUpsertRecords.js.map +1 -1
- package/dist/core/dataLayer/harperBridge/lmdbBridge/lmdbUtility/LMDBCreateAttributeObject.js +1 -1
- package/dist/core/dataLayer/harperBridge/lmdbBridge/lmdbUtility/LMDBCreateAttributeObject.js.map +1 -1
- package/dist/core/dataLayer/harperBridge/lmdbBridge/lmdbUtility/initializeHashSearch.js +2 -2
- package/dist/core/dataLayer/harperBridge/lmdbBridge/lmdbUtility/initializeHashSearch.js.map +1 -1
- package/dist/core/dataLayer/harperBridge/lmdbBridge/lmdbUtility/initializePaths.js +2 -2
- package/dist/core/dataLayer/harperBridge/lmdbBridge/lmdbUtility/lmdbCheckForNewAttributes.js +4 -4
- package/dist/core/dataLayer/harperBridge/lmdbBridge/lmdbUtility/lmdbCheckForNewAttributes.js.map +1 -1
- package/dist/core/dataLayer/harperBridge/lmdbBridge/lmdbUtility/lmdbCreateTransactionsAuditEnvironment.js +5 -3
- package/dist/core/dataLayer/harperBridge/lmdbBridge/lmdbUtility/lmdbCreateTransactionsAuditEnvironment.js.map +1 -1
- package/dist/core/dataLayer/harperBridge/lmdbBridge/lmdbUtility/lmdbGetTableSize.js +2 -2
- package/dist/core/dataLayer/harperBridge/lmdbBridge/lmdbUtility/lmdbProcessRows.js +4 -4
- package/dist/core/dataLayer/harperBridge/lmdbBridge/lmdbUtility/lmdbProcessRows.js.map +1 -1
- package/dist/core/dataLayer/harperBridge/lmdbBridge/lmdbUtility/lmdbSearch.js +5 -5
- package/dist/core/dataLayer/harperBridge/lmdbBridge/lmdbUtility/lmdbWriteTransaction.js +4 -4
- package/dist/core/dataLayer/hdbInfoController.js +66 -31
- package/dist/core/dataLayer/hdbInfoController.js.map +1 -1
- package/dist/core/dataLayer/insert.js +63 -28
- package/dist/core/dataLayer/insert.js.map +1 -1
- package/dist/core/dataLayer/readAuditLog.js +45 -13
- package/dist/core/dataLayer/readAuditLog.js.map +1 -1
- package/dist/core/dataLayer/schema.js +124 -89
- package/dist/core/dataLayer/schema.js.map +1 -1
- package/dist/core/dataLayer/schemaDescribe.js +78 -41
- package/dist/core/dataLayer/schemaDescribe.js.map +1 -1
- package/dist/core/dataLayer/search.js +12 -13
- package/dist/core/dataLayer/search.js.map +1 -1
- package/dist/core/dataLayer/transaction.js +3 -4
- package/dist/core/dataLayer/transaction.js.map +1 -1
- package/dist/core/dataLayer/update.js +53 -18
- package/dist/core/dataLayer/update.js.map +1 -1
- package/dist/core/globals.js +1 -0
- package/dist/core/globals.js.map +1 -1
- package/dist/core/index.js +4 -1
- package/dist/core/index.js.map +1 -1
- package/dist/core/json/systemSchema.json +65 -0
- package/dist/core/launchServiceScripts/utility/checkNodeVersion.js +3 -0
- package/dist/core/launchServiceScripts/utility/checkNodeVersion.js.map +1 -1
- package/dist/core/resources/DatabaseTransaction.js +39 -15
- package/dist/core/resources/DatabaseTransaction.js.map +1 -1
- package/dist/core/resources/ErrorResource.js +3 -1
- package/dist/core/resources/ErrorResource.js.map +1 -1
- package/dist/core/resources/LMDBTransaction.js +18 -7
- package/dist/core/resources/LMDBTransaction.js.map +1 -1
- package/dist/core/resources/RecordEncoder.js +5 -2
- package/dist/core/resources/RecordEncoder.js.map +1 -1
- package/dist/core/resources/RequestTarget.js.map +1 -1
- package/dist/core/resources/Resource.js +37 -10
- package/dist/core/resources/Resource.js.map +1 -1
- package/dist/core/resources/ResourceInterface.js +20 -0
- package/dist/core/resources/ResourceInterface.js.map +1 -1
- package/dist/core/resources/Resources.js +7 -6
- package/dist/core/resources/Resources.js.map +1 -1
- package/dist/core/resources/RocksIndexStore.js +3 -0
- package/dist/core/resources/RocksIndexStore.js.map +1 -1
- package/dist/core/resources/RocksTransactionLogStore.js +46 -27
- package/dist/core/resources/RocksTransactionLogStore.js.map +1 -1
- package/dist/core/resources/Table.js +267 -107
- package/dist/core/resources/Table.js.map +1 -1
- package/dist/core/resources/analytics/metadata.js +1 -0
- package/dist/core/resources/analytics/metadata.js.map +1 -1
- package/dist/core/resources/analytics/read.js +16 -5
- package/dist/core/resources/analytics/read.js.map +1 -1
- package/dist/core/resources/analytics/write.js +232 -20
- package/dist/core/resources/analytics/write.js.map +1 -1
- package/dist/core/resources/auditStore.js +13 -8
- package/dist/core/resources/auditStore.js.map +1 -1
- package/dist/core/resources/blob.js +8 -8
- package/dist/core/resources/blob.js.map +1 -1
- package/dist/core/resources/dataLoader.js +13 -13
- package/dist/core/resources/databases.js +160 -52
- package/dist/core/resources/databases.js.map +1 -1
- package/dist/core/resources/graphql.js +224 -174
- package/dist/core/resources/graphql.js.map +1 -1
- package/dist/core/resources/indexes/HierarchicalNavigableSmallWorld.js +308 -59
- package/dist/core/resources/indexes/HierarchicalNavigableSmallWorld.js.map +1 -1
- package/dist/core/resources/indexes/vector.js +14 -0
- package/dist/core/resources/indexes/vector.js.map +1 -1
- package/dist/core/resources/loadEnv.js +21 -18
- package/dist/core/resources/loadEnv.js.map +1 -1
- package/dist/core/resources/login.js +5 -4
- package/dist/core/resources/login.js.map +1 -1
- package/dist/core/resources/models/Models.js +265 -0
- package/dist/core/resources/models/Models.js.map +1 -0
- package/dist/core/resources/models/TestBackend.js +71 -0
- package/dist/core/resources/models/TestBackend.js.map +1 -0
- package/dist/core/resources/models/agentLoop.js +746 -0
- package/dist/core/resources/models/agentLoop.js.map +1 -0
- package/dist/core/resources/models/analyticsTable.js +166 -0
- package/dist/core/resources/models/analyticsTable.js.map +1 -0
- package/dist/core/resources/models/backendHelpers.js +109 -0
- package/dist/core/resources/models/backendHelpers.js.map +1 -0
- package/dist/core/resources/models/backendRegistry.js +54 -0
- package/dist/core/resources/models/backendRegistry.js.map +1 -0
- package/dist/core/resources/models/bootstrap.js +112 -0
- package/dist/core/resources/models/bootstrap.js.map +1 -0
- package/dist/core/resources/models/embedHook.js +127 -0
- package/dist/core/resources/models/embedHook.js.map +1 -0
- package/dist/core/resources/models/types.js +11 -0
- package/dist/core/resources/models/types.js.map +1 -0
- package/dist/core/resources/replayLogs.js +7 -1
- package/dist/core/resources/replayLogs.js.map +1 -1
- package/dist/core/resources/roles.js +67 -71
- package/dist/core/resources/roles.js.map +1 -1
- package/dist/core/resources/search.js +349 -140
- package/dist/core/resources/search.js.map +1 -1
- package/dist/core/resources/tracked.js +14 -14
- package/dist/core/resources/tracked.js.map +1 -1
- package/dist/core/resources/transaction.js +1 -1
- package/dist/core/resources/transaction.js.map +1 -1
- package/dist/core/resources/transactionBroadcast.js.map +1 -1
- package/dist/core/security/auth.js +34 -25
- package/dist/core/security/auth.js.map +1 -1
- package/dist/core/security/certificateVerification/crlVerification.js +7 -1
- package/dist/core/security/certificateVerification/crlVerification.js.map +1 -1
- package/dist/core/security/cryptoHash.js +37 -5
- package/dist/core/security/cryptoHash.js.map +1 -1
- package/dist/core/security/data_objects/PermissionAttributeResponseObject.js +4 -1
- package/dist/core/security/data_objects/PermissionAttributeResponseObject.js.map +1 -1
- package/dist/core/security/data_objects/PermissionResponseObject.js +15 -8
- package/dist/core/security/data_objects/PermissionResponseObject.js.map +1 -1
- package/dist/core/security/data_objects/PermissionTableResponseObject.js +6 -1
- package/dist/core/security/data_objects/PermissionTableResponseObject.js.map +1 -1
- package/dist/core/security/fastifyAuth.js +131 -22
- package/dist/core/security/fastifyAuth.js.map +1 -1
- package/dist/core/security/impersonation.js +15 -15
- package/dist/core/security/jsLoader.js +18 -5
- package/dist/core/security/jsLoader.js.map +1 -1
- package/dist/core/security/keys.js +160 -114
- package/dist/core/security/keys.js.map +1 -1
- package/dist/core/security/permissionsTranslator.js +2 -2
- package/dist/core/security/role.js +70 -35
- package/dist/core/security/role.js.map +1 -1
- package/dist/core/security/tokenAuthentication.js +57 -27
- package/dist/core/security/tokenAuthentication.js.map +1 -1
- package/dist/core/security/user.js +74 -38
- package/dist/core/security/user.js.map +1 -1
- package/dist/core/server/DurableSubscriptionsSession.js +71 -55
- package/dist/core/server/DurableSubscriptionsSession.js.map +1 -1
- package/dist/core/server/REST.js +17 -16
- package/dist/core/server/REST.js.map +1 -1
- package/dist/core/server/Server.js +1 -1
- package/dist/core/server/Server.js.map +1 -1
- package/dist/core/server/fastifyRoutes/helpers/getCORSOptions.js +1 -1
- package/dist/core/server/fastifyRoutes/helpers/getHeaderTimeoutConfig.js +1 -1
- package/dist/core/server/fastifyRoutes/helpers/getServerOptions.js +1 -1
- package/dist/core/server/fastifyRoutes.js +34 -30
- package/dist/core/server/fastifyRoutes.js.map +1 -1
- package/dist/core/server/graphqlQuerying.js +8 -7
- package/dist/core/server/graphqlQuerying.js.map +1 -1
- package/dist/core/server/http.js +523 -47
- package/dist/core/server/http.js.map +1 -1
- package/dist/core/server/itc/serverHandlers.js +66 -15
- package/dist/core/server/itc/serverHandlers.js.map +1 -1
- package/dist/core/server/jobs/JobObject.js +53 -7
- package/dist/core/server/jobs/JobObject.js.map +1 -1
- package/dist/core/server/jobs/jobProcess.js +64 -24
- package/dist/core/server/jobs/jobProcess.js.map +1 -1
- package/dist/core/server/jobs/jobRunner.js +68 -30
- package/dist/core/server/jobs/jobRunner.js.map +1 -1
- package/dist/core/server/jobs/jobs.js +93 -61
- package/dist/core/server/jobs/jobs.js.map +1 -1
- package/dist/core/server/loadRootComponents.js +1 -1
- package/dist/core/server/middlewareChain.js +252 -0
- package/dist/core/server/middlewareChain.js.map +1 -0
- package/dist/core/server/mqtt.js +22 -17
- package/dist/core/server/mqtt.js.map +1 -1
- package/dist/core/server/nodeName.js +44 -13
- package/dist/core/server/nodeName.js.map +1 -1
- package/dist/core/server/operationsServer.js +106 -33
- package/dist/core/server/operationsServer.js.map +1 -1
- package/dist/core/server/serverHelpers/Headers.js +2 -0
- package/dist/core/server/serverHelpers/Headers.js.map +1 -1
- package/dist/core/server/serverHelpers/JSONStream.js +12 -3
- package/dist/core/server/serverHelpers/JSONStream.js.map +1 -1
- package/dist/core/server/serverHelpers/Request.js +370 -9
- package/dist/core/server/serverHelpers/Request.js.map +1 -1
- package/dist/core/server/serverHelpers/contentTypes.js +36 -7
- package/dist/core/server/serverHelpers/contentTypes.js.map +1 -1
- package/dist/core/server/serverHelpers/multipartParser.js +142 -0
- package/dist/core/server/serverHelpers/multipartParser.js.map +1 -0
- package/dist/core/server/serverHelpers/progressEmitter.js +103 -0
- package/dist/core/server/serverHelpers/progressEmitter.js.map +1 -0
- package/dist/core/server/serverHelpers/serverHandlers.js +38 -7
- package/dist/core/server/serverHelpers/serverHandlers.js.map +1 -1
- package/dist/core/server/serverHelpers/serverUtilities.js +97 -93
- package/dist/core/server/serverHelpers/serverUtilities.js.map +1 -1
- package/dist/core/server/static.js +8 -5
- package/dist/core/server/static.js.map +1 -1
- package/dist/core/server/status/index.js +3 -3
- package/dist/core/server/storageReclamation.js +68 -9
- package/dist/core/server/storageReclamation.js.map +1 -1
- package/dist/core/server/threads/itc.js +7 -4
- package/dist/core/server/threads/itc.js.map +1 -1
- package/dist/core/server/threads/manageThreads.js +110 -26
- package/dist/core/server/threads/manageThreads.js.map +1 -1
- package/dist/core/server/threads/socketRouter.js +8 -271
- package/dist/core/server/threads/socketRouter.js.map +1 -1
- package/dist/core/server/threads/threadServer.js +360 -118
- package/dist/core/server/threads/threadServer.js.map +1 -1
- package/dist/core/server/threads/workerProcessGuard.js +114 -0
- package/dist/core/server/threads/workerProcessGuard.js.map +1 -0
- package/dist/core/server/throttle.js +17 -0
- package/dist/core/server/throttle.js.map +1 -1
- package/dist/core/sqlTranslator/SelectValidator.js +86 -47
- package/dist/core/sqlTranslator/SelectValidator.js.map +1 -1
- package/dist/core/sqlTranslator/alasqlFunctionImporter.js +40 -3
- package/dist/core/sqlTranslator/alasqlFunctionImporter.js.map +1 -1
- package/dist/core/sqlTranslator/deleteTranslator.js +48 -14
- package/dist/core/sqlTranslator/deleteTranslator.js.map +1 -1
- package/dist/core/sqlTranslator/index.js +69 -30
- package/dist/core/sqlTranslator/index.js.map +1 -1
- package/dist/core/sqlTranslator/sql_statement_bucket.js +55 -13
- package/dist/core/sqlTranslator/sql_statement_bucket.js.map +1 -1
- package/dist/core/upgrade/UpgradeObjects.js +37 -4
- package/dist/core/upgrade/UpgradeObjects.js.map +1 -1
- package/dist/core/upgrade/directives/5-2-0.js +77 -0
- package/dist/core/upgrade/directives/5-2-0.js.map +1 -0
- package/dist/core/upgrade/directives/directivesController.js +52 -11
- package/dist/core/upgrade/directives/directivesController.js.map +1 -1
- package/dist/core/upgrade/directivesManager.js +53 -18
- package/dist/core/upgrade/directivesManager.js.map +1 -1
- package/dist/core/upgrade/upgradePrompt.js +65 -30
- package/dist/core/upgrade/upgradePrompt.js.map +1 -1
- package/dist/core/upgrade/upgradeUtilities.js +37 -5
- package/dist/core/upgrade/upgradeUtilities.js.map +1 -1
- package/dist/core/utility/OperationFunctionCaller.js +45 -10
- package/dist/core/utility/OperationFunctionCaller.js.map +1 -1
- package/dist/core/utility/assignCmdEnvVariables.js +8 -4
- package/dist/core/utility/assignCmdEnvVariables.js.map +1 -1
- package/dist/core/utility/common_utils.js +140 -79
- package/dist/core/utility/common_utils.js.map +1 -1
- package/dist/core/utility/environment/environmentManager.js +75 -29
- package/dist/core/utility/environment/environmentManager.js.map +1 -1
- package/dist/core/utility/environment/systemInformation.js +27 -16
- package/dist/core/utility/environment/systemInformation.js.map +1 -1
- package/dist/core/utility/errors/commonErrors.js +49 -18
- package/dist/core/utility/errors/commonErrors.js.map +1 -1
- package/dist/core/utility/errors/hdbError.js +65 -26
- package/dist/core/utility/errors/hdbError.js.map +1 -1
- package/dist/core/utility/expandEnvVar.js +113 -0
- package/dist/core/utility/expandEnvVar.js.map +1 -0
- package/dist/core/utility/functions/geo.js +2 -2
- package/dist/core/utility/functions/sql/alaSQLExtension.js +1 -1
- package/dist/core/utility/globalSchema.js +14 -11
- package/dist/core/utility/globalSchema.js.map +1 -1
- package/dist/core/utility/hdbTerms.js +56 -0
- package/dist/core/utility/hdbTerms.js.map +1 -1
- package/dist/core/utility/install/checkJWTTokensExist.js +1 -1
- package/dist/core/utility/install/installer.js +106 -70
- package/dist/core/utility/install/installer.js.map +1 -1
- package/dist/core/utility/installation.js +3 -3
- package/dist/core/utility/lmdb/DBIDefinition.js +5 -1
- package/dist/core/utility/lmdb/DBIDefinition.js.map +1 -1
- package/dist/core/utility/lmdb/DeleteRecordsResponseObject.js +2 -1
- package/dist/core/utility/lmdb/DeleteRecordsResponseObject.js.map +1 -1
- package/dist/core/utility/lmdb/InsertRecordsResponseObject.js +2 -1
- package/dist/core/utility/lmdb/InsertRecordsResponseObject.js.map +1 -1
- package/dist/core/utility/lmdb/OpenDBIObject.js +54 -6
- package/dist/core/utility/lmdb/OpenDBIObject.js.map +1 -1
- package/dist/core/utility/lmdb/OpenEnvironmentObject.js +52 -4
- package/dist/core/utility/lmdb/OpenEnvironmentObject.js.map +1 -1
- package/dist/core/utility/lmdb/UpdateRecordsResponseObject.js +2 -1
- package/dist/core/utility/lmdb/UpdateRecordsResponseObject.js.map +1 -1
- package/dist/core/utility/lmdb/UpsertRecordsResponseObject.js +2 -1
- package/dist/core/utility/lmdb/UpsertRecordsResponseObject.js.map +1 -1
- package/dist/core/utility/lmdb/cleanLMDBMap.js +44 -7
- package/dist/core/utility/lmdb/cleanLMDBMap.js.map +1 -1
- package/dist/core/utility/lmdb/commonUtility.js +46 -17
- package/dist/core/utility/lmdb/commonUtility.js.map +1 -1
- package/dist/core/utility/lmdb/deleteUtility.js +51 -16
- package/dist/core/utility/lmdb/deleteUtility.js.map +1 -1
- package/dist/core/utility/lmdb/environmentUtility.js +91 -51
- package/dist/core/utility/lmdb/environmentUtility.js.map +1 -1
- package/dist/core/utility/lmdb/searchCursorFunctions.js +46 -14
- package/dist/core/utility/lmdb/searchCursorFunctions.js.map +1 -1
- package/dist/core/utility/lmdb/searchUtility.js +91 -55
- package/dist/core/utility/lmdb/searchUtility.js.map +1 -1
- package/dist/core/utility/lmdb/terms.js +12 -22
- package/dist/core/utility/lmdb/terms.js.map +1 -1
- package/dist/core/utility/lmdb/writeUtility.js +61 -28
- package/dist/core/utility/lmdb/writeUtility.js.map +1 -1
- package/dist/core/utility/logging/harper_logger.js +176 -81
- package/dist/core/utility/logging/harper_logger.js.map +1 -1
- package/dist/core/utility/logging/logRotator.js +65 -28
- package/dist/core/utility/logging/logRotator.js.map +1 -1
- package/dist/core/utility/logging/logger.js +4 -4
- package/dist/core/utility/logging/readLog.js +54 -17
- package/dist/core/utility/logging/readLog.js.map +1 -1
- package/dist/core/utility/logging/transactionLog.js +51 -16
- package/dist/core/utility/logging/transactionLog.js.map +1 -1
- package/dist/core/utility/mount_hdb.js +54 -17
- package/dist/core/utility/mount_hdb.js.map +1 -1
- package/dist/core/utility/npmUtilities.js +54 -19
- package/dist/core/utility/npmUtilities.js.map +1 -1
- package/dist/core/utility/operation_authorization.js +135 -86
- package/dist/core/utility/operation_authorization.js.map +1 -1
- package/dist/core/utility/packageUtils.js +7 -17
- package/dist/core/utility/packageUtils.js.map +1 -1
- package/dist/core/utility/password.js +2 -2
- package/dist/core/utility/processManagement/processManagement.js +2 -2
- package/dist/core/utility/processManagement/servicesConfig.js +1 -1
- package/dist/core/utility/signalling.js +51 -16
- package/dist/core/utility/signalling.js.map +1 -1
- package/dist/core/utility/watcherFallback.js +73 -0
- package/dist/core/utility/watcherFallback.js.map +1 -0
- package/dist/core/validation/analyticsValidator.js +79 -0
- package/dist/core/validation/analyticsValidator.js.map +1 -0
- package/dist/core/validation/bulkDeleteValidator.js +49 -11
- package/dist/core/validation/bulkDeleteValidator.js.map +1 -1
- package/dist/core/validation/check_permissions.js +38 -3
- package/dist/core/validation/check_permissions.js.map +1 -1
- package/dist/core/validation/common_validators.js +62 -31
- package/dist/core/validation/common_validators.js.map +1 -1
- package/dist/core/validation/configValidator.js +189 -54
- package/dist/core/validation/configValidator.js.map +1 -1
- package/dist/core/validation/deleteValidator.js +49 -11
- package/dist/core/validation/deleteValidator.js.map +1 -1
- package/dist/core/validation/fileLoadValidator.js +67 -32
- package/dist/core/validation/fileLoadValidator.js.map +1 -1
- package/dist/core/validation/insertValidator.js +48 -10
- package/dist/core/validation/insertValidator.js.map +1 -1
- package/dist/core/validation/installValidator.js +47 -10
- package/dist/core/validation/installValidator.js.map +1 -1
- package/dist/core/validation/readLogValidator.js +60 -22
- package/dist/core/validation/readLogValidator.js.map +1 -1
- package/dist/core/validation/role_validation.js +55 -19
- package/dist/core/validation/role_validation.js.map +1 -1
- package/dist/core/validation/schemaMetadataValidator.js +11 -12
- package/dist/core/validation/schemaMetadataValidator.js.map +1 -1
- package/dist/core/validation/searchValidator.js +82 -43
- package/dist/core/validation/searchValidator.js.map +1 -1
- package/dist/core/validation/transactionLogValidator.js +52 -17
- package/dist/core/validation/transactionLogValidator.js.map +1 -1
- package/dist/core/validation/user_validation.js +38 -6
- package/dist/core/validation/user_validation.js.map +1 -1
- package/dist/core/validation/validationWrapper.js +4 -5
- package/dist/core/validation/validationWrapper.js.map +1 -1
- package/dist/licensing/usageLicensing.js +30 -21
- package/dist/licensing/usageLicensing.js.map +1 -1
- package/dist/replication/knownNodes.js +173 -39
- package/dist/replication/knownNodes.js.map +1 -1
- package/dist/replication/replicationConnection.js +441 -85
- package/dist/replication/replicationConnection.js.map +1 -1
- package/dist/replication/replicator.js +44 -26
- package/dist/replication/replicator.js.map +1 -1
- package/dist/replication/setNode.js +22 -2
- package/dist/replication/setNode.js.map +1 -1
- package/dist/replication/subscriptionManager.js +121 -9
- package/dist/replication/subscriptionManager.js.map +1 -1
- package/dist/security/certificate.js +41 -6
- package/dist/security/certificate.js.map +1 -1
- package/dist/security/sshKeyOperations.js +35 -2
- package/dist/security/sshKeyOperations.js.map +1 -1
- package/licensing/usageLicensing.ts +32 -37
- package/npm-shrinkwrap.json +8994 -4305
- package/package.json +16 -11
- package/replication/DESIGN.md +139 -0
- package/replication/knownNodes.ts +166 -43
- package/replication/replicationConnection.ts +475 -92
- package/replication/replicator.ts +42 -25
- package/replication/setNode.ts +28 -9
- package/replication/subscriptionManager.ts +138 -14
- package/security/certificate.ts +8 -4
- package/security/sshKeyOperations.ts +1 -1
- package/static/defaultConfig.yaml +1 -0
- package/studio/web/assets/{index-CmtPP0YO.js → index-COfIkCT-.js} +5 -5
- package/studio/web/assets/index-COfIkCT-.js.map +1 -0
- package/studio/web/assets/{index.lazy-C8jvGtlu.js → index.lazy-CIvl7Fj9.js} +2 -2
- package/studio/web/assets/{index.lazy-C8jvGtlu.js.map → index.lazy-CIvl7Fj9.js.map} +1 -1
- package/studio/web/assets/{profile-O0DYlJUv.js → profile-B2ZVB--r.js} +2 -2
- package/studio/web/assets/{profile-O0DYlJUv.js.map → profile-B2ZVB--r.js.map} +1 -1
- package/studio/web/assets/{status-BIlJkJby.js → status-Db6WBmhf.js} +2 -2
- package/studio/web/assets/{status-BIlJkJby.js.map → status-Db6WBmhf.js.map} +1 -1
- package/studio/web/index.html +1 -1
- package/core/bin/cliOperations.js +0 -159
- package/core/bin/lite.js +0 -5
- package/core/bin/stop.js +0 -21
- package/core/dataLayer/harperBridge/BridgeMethods.js +0 -85
- package/core/utility/globalSchema.js +0 -35
- package/core/utility/lmdb/OpenDBIObject.js +0 -31
- package/studio/web/assets/index-CmtPP0YO.js.map +0 -1
|
@@ -0,0 +1,66 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.createFastifyHandler = createFastifyHandler;
|
|
4
|
+
/**
|
|
5
|
+
* Fastify adapter for the MCP transport core (operations port, #614).
|
|
6
|
+
*
|
|
7
|
+
* Maps Fastify's `(request, reply)` ↔ the transport's normalized
|
|
8
|
+
* Request/Response shape. The route is registered with the
|
|
9
|
+
* `authAndEnsureUserOnRequest` preValidation hook, so the authenticated
|
|
10
|
+
* user lands on `request.hdb_user` before this handler runs.
|
|
11
|
+
*
|
|
12
|
+
* Fastify auto-parses JSON request bodies; we re-stringify so the core's
|
|
13
|
+
* `parseMessage` sees the raw envelope it expects. The round-trip is
|
|
14
|
+
* cheap for the small JSON-RPC frames in the MCP wire format and keeps
|
|
15
|
+
* the core framework-agnostic.
|
|
16
|
+
*/
|
|
17
|
+
const transport_ts_1 = require("../transport.js");
|
|
18
|
+
function createFastifyHandler(profile) {
|
|
19
|
+
return async function mcpFastifyHandler(request, reply) {
|
|
20
|
+
const norm = {
|
|
21
|
+
method: request.method,
|
|
22
|
+
headers: normalizeHeaders(request.headers),
|
|
23
|
+
// Fastify has already parsed the JSON body into an object via its
|
|
24
|
+
// preParsing pipeline. Pass it through directly — the transport
|
|
25
|
+
// core's parseMessage accepts both strings and parsed values, so we
|
|
26
|
+
// avoid an unnecessary stringify/re-parse round trip on the hot path.
|
|
27
|
+
body: request.body,
|
|
28
|
+
user: request.hdb_user?.username ?? '',
|
|
29
|
+
userObject: (request.hdb_user ?? undefined),
|
|
30
|
+
profile,
|
|
31
|
+
};
|
|
32
|
+
const res = await (0, transport_ts_1.handleMcpRequest)(norm);
|
|
33
|
+
reply.code(res.status);
|
|
34
|
+
for (const [name, value] of Object.entries(res.headers)) {
|
|
35
|
+
reply.header(name, value);
|
|
36
|
+
}
|
|
37
|
+
if (res.jsonBody !== undefined) {
|
|
38
|
+
if (!res.headers['Content-Type'] && !res.headers['content-type']) {
|
|
39
|
+
reply.header('Content-Type', 'application/json');
|
|
40
|
+
}
|
|
41
|
+
reply.send(res.jsonBody);
|
|
42
|
+
return;
|
|
43
|
+
}
|
|
44
|
+
if (res.sseIterable !== undefined) {
|
|
45
|
+
// Reserved for #619 (server-push GET stream). Fastify will iterate
|
|
46
|
+
// the async iterable and write SSE frames via the contentTypes
|
|
47
|
+
// serializer at `server/serverHelpers/contentTypes.ts:128-162`.
|
|
48
|
+
if (!res.headers['Content-Type'] && !res.headers['content-type']) {
|
|
49
|
+
reply.header('Content-Type', 'text/event-stream');
|
|
50
|
+
}
|
|
51
|
+
reply.header('Cache-Control', 'no-store');
|
|
52
|
+
reply.send(res.sseIterable);
|
|
53
|
+
return;
|
|
54
|
+
}
|
|
55
|
+
// 202/204/4xx with empty body.
|
|
56
|
+
reply.send();
|
|
57
|
+
};
|
|
58
|
+
}
|
|
59
|
+
function normalizeHeaders(headers) {
|
|
60
|
+
const out = {};
|
|
61
|
+
for (const [name, value] of Object.entries(headers)) {
|
|
62
|
+
out[name.toLowerCase()] = Array.isArray(value) ? value[0] : value;
|
|
63
|
+
}
|
|
64
|
+
return out;
|
|
65
|
+
}
|
|
66
|
+
//# sourceMappingURL=fastify.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"fastify.js","sourceRoot":"","sources":["../../../../../core/components/mcp/adapters/fastify.ts"],"names":[],"mappings":";;AAiCA,oDA6CC;AA9ED;;;;;;;;;;;;GAYG;AACH,kDAAsF;AAoBtF,SAAgB,oBAAoB,CAAC,OAAmB;IACvD,OAAO,KAAK,UAAU,iBAAiB,CAAC,OAA2B,EAAE,KAAuB;QAC3F,MAAM,IAAI,GAAgB;YACzB,MAAM,EAAE,OAAO,CAAC,MAAM;YACtB,OAAO,EAAE,gBAAgB,CAAC,OAAO,CAAC,OAAO,CAAC;YAC1C,kEAAkE;YAClE,gEAAgE;YAChE,oEAAoE;YACpE,sEAAsE;YACtE,IAAI,EAAE,OAAO,CAAC,IAAI;YAClB,IAAI,EAAE,OAAO,CAAC,QAAQ,EAAE,QAAQ,IAAI,EAAE;YACtC,UAAU,EAAE,CAAC,OAAO,CAAC,QAAQ,IAAI,SAAS,CAA8B;YACxE,OAAO;SACP,CAAC;QAEF,MAAM,GAAG,GAAG,MAAM,IAAA,+BAAgB,EAAC,IAAI,CAAC,CAAC;QAEzC,KAAK,CAAC,IAAI,CAAC,GAAG,CAAC,MAAM,CAAC,CAAC;QACvB,KAAK,MAAM,CAAC,IAAI,EAAE,KAAK,CAAC,IAAI,MAAM,CAAC,OAAO,CAAC,GAAG,CAAC,OAAO,CAAC,EAAE,CAAC;YACzD,KAAK,CAAC,MAAM,CAAC,IAAI,EAAE,KAAK,CAAC,CAAC;QAC3B,CAAC;QAED,IAAI,GAAG,CAAC,QAAQ,KAAK,SAAS,EAAE,CAAC;YAChC,IAAI,CAAC,GAAG,CAAC,OAAO,CAAC,cAAc,CAAC,IAAI,CAAC,GAAG,CAAC,OAAO,CAAC,cAAc,CAAC,EAAE,CAAC;gBAClE,KAAK,CAAC,MAAM,CAAC,cAAc,EAAE,kBAAkB,CAAC,CAAC;YAClD,CAAC;YACD,KAAK,CAAC,IAAI,CAAC,GAAG,CAAC,QAAQ,CAAC,CAAC;YACzB,OAAO;QACR,CAAC;QAED,IAAI,GAAG,CAAC,WAAW,KAAK,SAAS,EAAE,CAAC;YACnC,mEAAmE;YACnE,+DAA+D;YAC/D,gEAAgE;YAChE,IAAI,CAAC,GAAG,CAAC,OAAO,CAAC,cAAc,CAAC,IAAI,CAAC,GAAG,CAAC,OAAO,CAAC,cAAc,CAAC,EAAE,CAAC;gBAClE,KAAK,CAAC,MAAM,CAAC,cAAc,EAAE,mBAAmB,CAAC,CAAC;YACnD,CAAC;YACD,KAAK,CAAC,MAAM,CAAC,eAAe,EAAE,UAAU,CAAC,CAAC;YAC1C,KAAK,CAAC,IAAI,CAAC,GAAG,CAAC,WAAW,CAAC,CAAC;YAC5B,OAAO;QACR,CAAC;QAED,+BAA+B;QAC/B,KAAK,CAAC,IAAI,EAAE,CAAC;IACd,CAAC,CAAC;AACH,CAAC;AAED,SAAS,gBAAgB,CAAC,OAAsD;IAC/E,MAAM,GAAG,GAAuC,EAAE,CAAC;IACnD,KAAK,MAAM,CAAC,IAAI,EAAE,KAAK,CAAC,IAAI,MAAM,CAAC,OAAO,CAAC,OAAO,CAAC,EAAE,CAAC;QACrD,GAAG,CAAC,IAAI,CAAC,WAAW,EAAE,CAAC,GAAG,KAAK,CAAC,OAAO,CAAC,KAAK,CAAC,CAAC,CAAC,CAAC,KAAK,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,KAAK,CAAC;IACnE,CAAC;IACD,OAAO,GAAG,CAAC;AACZ,CAAC"}
|
|
@@ -0,0 +1,78 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.createHarperHttpHandler = createHarperHttpHandler;
|
|
4
|
+
/**
|
|
5
|
+
* Harper-HTTP adapter for the MCP transport core (application port, #614).
|
|
6
|
+
*
|
|
7
|
+
* Maps Harper's HTTP handler signature `(request, nextHandler) => { status,
|
|
8
|
+
* headers, body }` to/from the transport's normalized Request/Response.
|
|
9
|
+
* Auth runs upstream via `{ after: 'authentication' }` on the registration,
|
|
10
|
+
* so `request.user` is already populated when this handler fires.
|
|
11
|
+
*
|
|
12
|
+
* SSE responses (reserved for #619) are returned as `{ body: iterable,
|
|
13
|
+
* headers: { 'content-type': 'text/event-stream' } }`. Harper's serializer
|
|
14
|
+
* at `server/serverHelpers/contentTypes.ts:128-162` picks the SSE writer
|
|
15
|
+
* automatically and pipes the iterable to the wire.
|
|
16
|
+
*/
|
|
17
|
+
const transport_ts_1 = require("../transport.js");
|
|
18
|
+
function createHarperHttpHandler(profile) {
|
|
19
|
+
return async function mcpHarperHttpHandler(request, nextHandler) {
|
|
20
|
+
// WebSocket upgrades aren't ours — let the next handler take it.
|
|
21
|
+
if (request.isWebSocket)
|
|
22
|
+
return nextHandler(request);
|
|
23
|
+
const norm = {
|
|
24
|
+
method: request.method,
|
|
25
|
+
headers: normalizeHeaders(request.headers),
|
|
26
|
+
body: await readBody(request.body),
|
|
27
|
+
user: request.user?.username ?? '',
|
|
28
|
+
userObject: request.user,
|
|
29
|
+
profile,
|
|
30
|
+
};
|
|
31
|
+
const res = await (0, transport_ts_1.handleMcpRequest)(norm);
|
|
32
|
+
return toHarperResponse(res);
|
|
33
|
+
};
|
|
34
|
+
}
|
|
35
|
+
function normalizeHeaders(headers) {
|
|
36
|
+
const out = {};
|
|
37
|
+
for (const [name, value] of headers) {
|
|
38
|
+
out[name.toLowerCase()] = Array.isArray(value) ? value[0] : value;
|
|
39
|
+
}
|
|
40
|
+
return out;
|
|
41
|
+
}
|
|
42
|
+
async function readBody(body) {
|
|
43
|
+
if (!body)
|
|
44
|
+
return '';
|
|
45
|
+
const chunks = [];
|
|
46
|
+
for await (const chunk of body) {
|
|
47
|
+
chunks.push(typeof chunk === 'string' ? Buffer.from(chunk, 'utf8') : chunk);
|
|
48
|
+
}
|
|
49
|
+
return Buffer.concat(chunks).toString('utf8');
|
|
50
|
+
}
|
|
51
|
+
function toHarperResponse(res) {
|
|
52
|
+
const headers = { ...res.headers };
|
|
53
|
+
if (res.jsonBody !== undefined) {
|
|
54
|
+
if (!headers['Content-Type'] && !headers['content-type']) {
|
|
55
|
+
headers['Content-Type'] = 'application/json';
|
|
56
|
+
}
|
|
57
|
+
return {
|
|
58
|
+
status: res.status,
|
|
59
|
+
headers,
|
|
60
|
+
body: JSON.stringify(res.jsonBody),
|
|
61
|
+
};
|
|
62
|
+
}
|
|
63
|
+
if (res.sseIterable !== undefined) {
|
|
64
|
+
if (!headers['Content-Type'] && !headers['content-type']) {
|
|
65
|
+
headers['Content-Type'] = 'text/event-stream';
|
|
66
|
+
}
|
|
67
|
+
if (!headers['Cache-Control'] && !headers['cache-control']) {
|
|
68
|
+
headers['Cache-Control'] = 'no-store';
|
|
69
|
+
}
|
|
70
|
+
return {
|
|
71
|
+
status: res.status,
|
|
72
|
+
headers,
|
|
73
|
+
body: res.sseIterable,
|
|
74
|
+
};
|
|
75
|
+
}
|
|
76
|
+
return { status: res.status, headers };
|
|
77
|
+
}
|
|
78
|
+
//# sourceMappingURL=harperHttp.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"harperHttp.js","sourceRoot":"","sources":["../../../../../core/components/mcp/adapters/harperHttp.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,73 @@
|
|
|
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.redactArgs = redactArgs;
|
|
7
|
+
exports.maskSessionId = maskSessionId;
|
|
8
|
+
exports.emitAuditEntry = emitAuditEntry;
|
|
9
|
+
/**
|
|
10
|
+
* Per-`tools/call` audit logging. Emits a structured info-level log entry
|
|
11
|
+
* for every tool invocation so operators can replay who-did-what after the
|
|
12
|
+
* fact. The shape mirrors what Harper's existing operations audit captures
|
|
13
|
+
* (operation, user, status, duration) plus MCP-specific identity
|
|
14
|
+
* (session id, profile, tool name).
|
|
15
|
+
*
|
|
16
|
+
* Argument summarization runs through a redaction step that drops anything
|
|
17
|
+
* that looks like a credential (key/secret/password). Operators who need
|
|
18
|
+
* stricter PII handling configure `mcp.audit.argumentRedactor` to a custom
|
|
19
|
+
* function via a future component-author hook (v1.1).
|
|
20
|
+
*/
|
|
21
|
+
const harper_logger_ts_1 = __importDefault(require("../../utility/logging/harper_logger.js"));
|
|
22
|
+
const REDACTION_PATTERN = /(secret|password|token|api[-_]?key|credentials?|auth)/i;
|
|
23
|
+
const REDACTION_PLACEHOLDER = '[redacted]';
|
|
24
|
+
const MAX_REDACTION_DEPTH = 10;
|
|
25
|
+
/**
|
|
26
|
+
* Recursively walk an object and replace values for keys matching the
|
|
27
|
+
* redaction pattern. Bounded depth so a pathological cyclic input doesn't
|
|
28
|
+
* stall the audit emit; on overflow the entire sub-object is redacted so
|
|
29
|
+
* a credential buried below the depth limit cannot leak. Returns a shallow
|
|
30
|
+
* clone — the caller's payload is never mutated.
|
|
31
|
+
*/
|
|
32
|
+
function redactArgs(value, depth = 0) {
|
|
33
|
+
if (value === null || typeof value !== 'object')
|
|
34
|
+
return value;
|
|
35
|
+
if (depth > MAX_REDACTION_DEPTH)
|
|
36
|
+
return REDACTION_PLACEHOLDER;
|
|
37
|
+
if (Array.isArray(value)) {
|
|
38
|
+
return value.map((v) => redactArgs(v, depth + 1));
|
|
39
|
+
}
|
|
40
|
+
const out = {};
|
|
41
|
+
for (const [k, v] of Object.entries(value)) {
|
|
42
|
+
if (REDACTION_PATTERN.test(k)) {
|
|
43
|
+
out[k] = REDACTION_PLACEHOLDER;
|
|
44
|
+
}
|
|
45
|
+
else {
|
|
46
|
+
out[k] = redactArgs(v, depth + 1);
|
|
47
|
+
}
|
|
48
|
+
}
|
|
49
|
+
return out;
|
|
50
|
+
}
|
|
51
|
+
/** Mask a session id for logging — first 8 chars, suffix elided. */
|
|
52
|
+
function maskSessionId(id) {
|
|
53
|
+
if (typeof id !== 'string' || id.length <= 8)
|
|
54
|
+
return id;
|
|
55
|
+
return `${id.slice(0, 8)}…`;
|
|
56
|
+
}
|
|
57
|
+
/**
|
|
58
|
+
* Emit a single audit entry. Writes to the structured log channel as INFO
|
|
59
|
+
* so it's captured by Harper's standard log rotation; downstream tooling
|
|
60
|
+
* can filter on `category: 'mcp.audit'`.
|
|
61
|
+
*/
|
|
62
|
+
function emitAuditEntry(entry) {
|
|
63
|
+
try {
|
|
64
|
+
const masked = { ...entry, sessionId: maskSessionId(entry.sessionId), args: redactArgs(entry.args) };
|
|
65
|
+
harper_logger_ts_1.default.info({ category: 'mcp.audit', ...masked });
|
|
66
|
+
}
|
|
67
|
+
catch (err) {
|
|
68
|
+
// Audit emission must never break a tool call. If logging itself fails
|
|
69
|
+
// (logger disposed, disk full, whatever), trace-log the loss and move on.
|
|
70
|
+
harper_logger_ts_1.default.trace(`MCP audit emit failed: ${err.message}`);
|
|
71
|
+
}
|
|
72
|
+
}
|
|
73
|
+
//# sourceMappingURL=audit.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"audit.js","sourceRoot":"","sources":["../../../../core/components/mcp/audit.ts"],"names":[],"mappings":";;;;;AAqCA,gCAeC;AAGD,sCAGC;AAOD,wCASC;AA1ED;;;;;;;;;;;GAWG;AACH,8FAAkE;AAclE,MAAM,iBAAiB,GAAG,wDAAwD,CAAC;AACnF,MAAM,qBAAqB,GAAG,YAAY,CAAC;AAC3C,MAAM,mBAAmB,GAAG,EAAE,CAAC;AAE/B;;;;;;GAMG;AACH,SAAgB,UAAU,CAAC,KAAc,EAAE,KAAK,GAAG,CAAC;IACnD,IAAI,KAAK,KAAK,IAAI,IAAI,OAAO,KAAK,KAAK,QAAQ;QAAE,OAAO,KAAK,CAAC;IAC9D,IAAI,KAAK,GAAG,mBAAmB;QAAE,OAAO,qBAAqB,CAAC;IAC9D,IAAI,KAAK,CAAC,OAAO,CAAC,KAAK,CAAC,EAAE,CAAC;QAC1B,OAAO,KAAK,CAAC,GAAG,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,UAAU,CAAC,CAAC,EAAE,KAAK,GAAG,CAAC,CAAC,CAAC,CAAC;IACnD,CAAC;IACD,MAAM,GAAG,GAA4B,EAAE,CAAC;IACxC,KAAK,MAAM,CAAC,CAAC,EAAE,CAAC,CAAC,IAAI,MAAM,CAAC,OAAO,CAAC,KAAK,CAAC,EAAE,CAAC;QAC5C,IAAI,iBAAiB,CAAC,IAAI,CAAC,CAAC,CAAC,EAAE,CAAC;YAC/B,GAAG,CAAC,CAAC,CAAC,GAAG,qBAAqB,CAAC;QAChC,CAAC;aAAM,CAAC;YACP,GAAG,CAAC,CAAC,CAAC,GAAG,UAAU,CAAC,CAAC,EAAE,KAAK,GAAG,CAAC,CAAC,CAAC;QACnC,CAAC;IACF,CAAC;IACD,OAAO,GAAG,CAAC;AACZ,CAAC;AAED,oEAAoE;AACpE,SAAgB,aAAa,CAAC,EAAU;IACvC,IAAI,OAAO,EAAE,KAAK,QAAQ,IAAI,EAAE,CAAC,MAAM,IAAI,CAAC;QAAE,OAAO,EAAE,CAAC;IACxD,OAAO,GAAG,EAAE,CAAC,KAAK,CAAC,CAAC,EAAE,CAAC,CAAC,GAAG,CAAC;AAC7B,CAAC;AAED;;;;GAIG;AACH,SAAgB,cAAc,CAAC,KAAiB;IAC/C,IAAI,CAAC;QACJ,MAAM,MAAM,GAAG,EAAE,GAAG,KAAK,EAAE,SAAS,EAAE,aAAa,CAAC,KAAK,CAAC,SAAS,CAAC,EAAE,IAAI,EAAE,UAAU,CAAC,KAAK,CAAC,IAAI,CAAC,EAAE,CAAC;QACrG,0BAAY,CAAC,IAAI,CAAC,EAAE,QAAQ,EAAE,WAAW,EAAE,GAAG,MAAM,EAAE,CAAC,CAAC;IACzD,CAAC;IAAC,OAAO,GAAG,EAAE,CAAC;QACd,uEAAuE;QACvE,0EAA0E;QAC1E,0BAAY,CAAC,KAAK,CAAC,0BAA2B,GAAa,CAAC,OAAO,EAAE,CAAC,CAAC;IACxE,CAAC;AACF,CAAC"}
|
|
@@ -0,0 +1,109 @@
|
|
|
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._setGetConfigObjForTest = _setGetConfigObjForTest;
|
|
7
|
+
exports._restoreGetConfigObj = _restoreGetConfigObj;
|
|
8
|
+
exports.registerMcpProfile = registerMcpProfile;
|
|
9
|
+
exports.handleApplication = handleApplication;
|
|
10
|
+
exports._resetApplicationStartedForTest = _resetApplicationStartedForTest;
|
|
11
|
+
/**
|
|
12
|
+
* Native MCP (Model Context Protocol) server component for Harper.
|
|
13
|
+
*
|
|
14
|
+
* #614 replaces the foundation stub from #613 with a real Streamable HTTP
|
|
15
|
+
* transport. Two entry points:
|
|
16
|
+
*
|
|
17
|
+
* - `registerMcpProfile({profile:'operations', host, config, routeOptions})`
|
|
18
|
+
* called from `server/operationsServer.ts` (Fastify-side gate).
|
|
19
|
+
*
|
|
20
|
+
* - `handleApplication(scope)` invoked by the component loader when the
|
|
21
|
+
* root config contains a top-level `mcp:` block. Registers the
|
|
22
|
+
* application-profile handler on the HTTP port iff `mcp.application` is
|
|
23
|
+
* present.
|
|
24
|
+
*
|
|
25
|
+
* Profile presence drives enablement, matching Harper's `replication`
|
|
26
|
+
* convention (no `enabled` flag). See #465 for the umbrella design.
|
|
27
|
+
*/
|
|
28
|
+
const harper_logger_ts_1 = __importDefault(require("../../utility/logging/harper_logger.js"));
|
|
29
|
+
const configUtils_js_1 = require("../../config/configUtils.js");
|
|
30
|
+
const fastify_ts_1 = require("./adapters/fastify.js");
|
|
31
|
+
const harperHttp_ts_1 = require("./adapters/harperHttp.js");
|
|
32
|
+
const session_ts_1 = require("./session.js");
|
|
33
|
+
const listChanged_ts_1 = require("./listChanged.js");
|
|
34
|
+
const application_ts_1 = require("./tools/application.js");
|
|
35
|
+
const operations_ts_1 = require("./tools/operations.js");
|
|
36
|
+
// Indirection so tests can swap the config source.
|
|
37
|
+
let getConfigObj = configUtils_js_1.getConfigObj;
|
|
38
|
+
function _setGetConfigObjForTest(fn) {
|
|
39
|
+
getConfigObj = fn;
|
|
40
|
+
}
|
|
41
|
+
function _restoreGetConfigObj() {
|
|
42
|
+
getConfigObj = configUtils_js_1.getConfigObj;
|
|
43
|
+
}
|
|
44
|
+
const DEFAULT_MOUNT_PATH = '/mcp';
|
|
45
|
+
/**
|
|
46
|
+
* Fastify-side registration. Used by `server/operationsServer.ts` for the
|
|
47
|
+
* operations profile. Idempotent through the host's own route table.
|
|
48
|
+
*/
|
|
49
|
+
function registerMcpProfile({ profile, host, config, routeOptions }) {
|
|
50
|
+
const profileConfig = config?.mcp?.[profile];
|
|
51
|
+
if (!profileConfig) {
|
|
52
|
+
harper_logger_ts_1.default.trace(`MCP ${profile} profile not configured, skipping registration`);
|
|
53
|
+
return;
|
|
54
|
+
}
|
|
55
|
+
(0, session_ts_1.ensureSessionTable)();
|
|
56
|
+
(0, listChanged_ts_1.initListChanged)();
|
|
57
|
+
if (profile === 'operations') {
|
|
58
|
+
(0, operations_ts_1.registerOperationsTools)();
|
|
59
|
+
}
|
|
60
|
+
const mountPath = profileConfig.mountPath ?? DEFAULT_MOUNT_PATH;
|
|
61
|
+
const handler = (0, fastify_ts_1.createFastifyHandler)(profile);
|
|
62
|
+
// Register POST, GET, and DELETE on the same mount path. The transport
|
|
63
|
+
// core decides whether to handle (POST initialize / JSON-RPC dispatch),
|
|
64
|
+
// return 405 with an accurate `Allow` header (GET always in v1, DELETE
|
|
65
|
+
// when `mcp.session.allowClientDelete` is false), or process (DELETE
|
|
66
|
+
// when enabled). Without explicit GET/DELETE routes Fastify would
|
|
67
|
+
// short-circuit to its built-in 404 before the transport runs.
|
|
68
|
+
for (const method of ['post', 'get', 'delete']) {
|
|
69
|
+
if (routeOptions) {
|
|
70
|
+
host[method](mountPath, routeOptions, handler);
|
|
71
|
+
}
|
|
72
|
+
else {
|
|
73
|
+
host[method](mountPath, handler);
|
|
74
|
+
}
|
|
75
|
+
}
|
|
76
|
+
harper_logger_ts_1.default.info(`MCP ${profile} profile registered at ${mountPath}`);
|
|
77
|
+
}
|
|
78
|
+
let applicationStarted = false;
|
|
79
|
+
/**
|
|
80
|
+
* Trusted-Resource-Plugin entry point for the application profile. The
|
|
81
|
+
* component loader invokes this with the runtime `Scope` when the root
|
|
82
|
+
* config contains a top-level `mcp:` block. We register the handler iff the
|
|
83
|
+
* `application` sub-block is also present.
|
|
84
|
+
*
|
|
85
|
+
* Idempotent — repeated invocations no-op via `applicationStarted`. This
|
|
86
|
+
* matches REST's pattern at `server/REST.ts:283-303`.
|
|
87
|
+
*/
|
|
88
|
+
function handleApplication(scope) {
|
|
89
|
+
if (applicationStarted)
|
|
90
|
+
return;
|
|
91
|
+
const config = getConfigObj();
|
|
92
|
+
if (!config?.mcp?.application) {
|
|
93
|
+
harper_logger_ts_1.default.trace('MCP application profile not configured, skipping registration');
|
|
94
|
+
return;
|
|
95
|
+
}
|
|
96
|
+
applicationStarted = true;
|
|
97
|
+
(0, session_ts_1.ensureSessionTable)();
|
|
98
|
+
(0, listChanged_ts_1.initListChanged)();
|
|
99
|
+
(0, application_ts_1.registerApplicationTools)();
|
|
100
|
+
const mountPath = config.mcp.application.mountPath ?? DEFAULT_MOUNT_PATH;
|
|
101
|
+
const handler = (0, harperHttp_ts_1.createHarperHttpHandler)('application');
|
|
102
|
+
scope.server.http(handler, { urlPath: mountPath, after: 'authentication' });
|
|
103
|
+
harper_logger_ts_1.default.info(`MCP application profile registered at ${mountPath}`);
|
|
104
|
+
}
|
|
105
|
+
/** Test seam: reset the module-level guard so tests can re-invoke handleApplication. */
|
|
106
|
+
function _resetApplicationStartedForTest() {
|
|
107
|
+
applicationStarted = false;
|
|
108
|
+
}
|
|
109
|
+
//# sourceMappingURL=index.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index.js","sourceRoot":"","sources":["../../../../core/components/mcp/index.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,93 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
/**
|
|
3
|
+
* JSON-RPC 2.0 envelope parsing + error helpers for the MCP Streamable HTTP
|
|
4
|
+
* transport (#614). The MCP wire format is one JSON-RPC message per HTTP body
|
|
5
|
+
* (no batches in the 2025-06-18 revision — spec §transports).
|
|
6
|
+
*
|
|
7
|
+
* Spec: https://www.jsonrpc.org/specification
|
|
8
|
+
*/
|
|
9
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
10
|
+
exports.ERROR_CODES = exports.JSONRPC_VERSION = void 0;
|
|
11
|
+
exports.parseMessage = parseMessage;
|
|
12
|
+
exports.isClientFireAndForget = isClientFireAndForget;
|
|
13
|
+
exports.buildSuccess = buildSuccess;
|
|
14
|
+
exports.buildError = buildError;
|
|
15
|
+
exports.JSONRPC_VERSION = '2.0';
|
|
16
|
+
/** Standard JSON-RPC 2.0 error codes (spec §5.1). */
|
|
17
|
+
exports.ERROR_CODES = {
|
|
18
|
+
PARSE_ERROR: -32700,
|
|
19
|
+
INVALID_REQUEST: -32600,
|
|
20
|
+
METHOD_NOT_FOUND: -32601,
|
|
21
|
+
INVALID_PARAMS: -32602,
|
|
22
|
+
INTERNAL_ERROR: -32603,
|
|
23
|
+
};
|
|
24
|
+
/**
|
|
25
|
+
* Validate a JSON-RPC envelope. Accepts either a raw UTF-8 JSON string
|
|
26
|
+
* (e.g., from a streamed request body) or an already-parsed value (e.g.,
|
|
27
|
+
* Fastify hands us a parsed object via its preParsing pipeline). Returns
|
|
28
|
+
* either a typed message or a structured parse error that the caller maps
|
|
29
|
+
* to a JSON-RPC error response. Never throws.
|
|
30
|
+
*/
|
|
31
|
+
function parseMessage(body) {
|
|
32
|
+
let parsed;
|
|
33
|
+
if (typeof body === 'string') {
|
|
34
|
+
try {
|
|
35
|
+
parsed = JSON.parse(body);
|
|
36
|
+
}
|
|
37
|
+
catch (err) {
|
|
38
|
+
const fail = { ok: false, code: exports.ERROR_CODES.PARSE_ERROR, reason: err.message };
|
|
39
|
+
return fail;
|
|
40
|
+
}
|
|
41
|
+
}
|
|
42
|
+
else {
|
|
43
|
+
parsed = body;
|
|
44
|
+
}
|
|
45
|
+
if (parsed === null || typeof parsed !== 'object' || Array.isArray(parsed)) {
|
|
46
|
+
// Batch requests (arrays) are not used in the MCP Streamable HTTP wire
|
|
47
|
+
// format; rejecting them keeps the transport unambiguous.
|
|
48
|
+
const fail = { ok: false, code: exports.ERROR_CODES.INVALID_REQUEST, reason: 'expected a JSON object' };
|
|
49
|
+
return fail;
|
|
50
|
+
}
|
|
51
|
+
const obj = parsed;
|
|
52
|
+
if (obj.jsonrpc !== exports.JSONRPC_VERSION) {
|
|
53
|
+
const fail = {
|
|
54
|
+
ok: false,
|
|
55
|
+
code: exports.ERROR_CODES.INVALID_REQUEST,
|
|
56
|
+
reason: `jsonrpc must be "${exports.JSONRPC_VERSION}"`,
|
|
57
|
+
};
|
|
58
|
+
return fail;
|
|
59
|
+
}
|
|
60
|
+
const hasMethod = typeof obj.method === 'string';
|
|
61
|
+
const hasResultOrError = 'result' in obj || 'error' in obj;
|
|
62
|
+
if (!hasMethod && !hasResultOrError) {
|
|
63
|
+
const fail = {
|
|
64
|
+
ok: false,
|
|
65
|
+
code: exports.ERROR_CODES.INVALID_REQUEST,
|
|
66
|
+
reason: 'missing method, result, or error field',
|
|
67
|
+
};
|
|
68
|
+
return fail;
|
|
69
|
+
}
|
|
70
|
+
const success = { ok: true, message: parsed };
|
|
71
|
+
return success;
|
|
72
|
+
}
|
|
73
|
+
/**
|
|
74
|
+
* True if the message is a "fire-and-forget" frame from the client's
|
|
75
|
+
* perspective — a notification (no `id`) or a response to a server-initiated
|
|
76
|
+
* request (has `result` or `error`). Per MCP §transports point 4, both yield
|
|
77
|
+
* HTTP 202 with no body.
|
|
78
|
+
*/
|
|
79
|
+
function isClientFireAndForget(message) {
|
|
80
|
+
const hasId = 'id' in message;
|
|
81
|
+
const hasResultOrError = 'result' in message || 'error' in message;
|
|
82
|
+
return !hasId || hasResultOrError;
|
|
83
|
+
}
|
|
84
|
+
function buildSuccess(id, result) {
|
|
85
|
+
return { jsonrpc: exports.JSONRPC_VERSION, id, result };
|
|
86
|
+
}
|
|
87
|
+
function buildError(id, code, message, data) {
|
|
88
|
+
const error = { code, message };
|
|
89
|
+
if (data !== undefined)
|
|
90
|
+
error.data = data;
|
|
91
|
+
return { jsonrpc: exports.JSONRPC_VERSION, id, error };
|
|
92
|
+
}
|
|
93
|
+
//# sourceMappingURL=jsonrpc.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"jsonrpc.js","sourceRoot":"","sources":["../../../../core/components/mcp/jsonrpc.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,79 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.SERVER_CAPABILITIES = exports.SERVER_INFO = exports.SUPPORTED_PROTOCOL_VERSIONS = exports.PROTOCOL_VERSION_BACKCOMPAT = exports.PROTOCOL_VERSION_PREFERRED = void 0;
|
|
4
|
+
exports.handleInitialize = handleInitialize;
|
|
5
|
+
exports.handleInitialized = handleInitialized;
|
|
6
|
+
/**
|
|
7
|
+
* MCP lifecycle handlers — `initialize` and `notifications/initialized`.
|
|
8
|
+
*
|
|
9
|
+
* Spec: https://modelcontextprotocol.io/specification/2025-06-18/basic/lifecycle
|
|
10
|
+
* v1 supports protocol version `2025-06-18` (preferred) and `2025-03-26`
|
|
11
|
+
* (backcompat). Anything else returns 400 to the client; per the spec, the
|
|
12
|
+
* server SHOULD respond with its preferred supported version so the client
|
|
13
|
+
* can decide whether to connect on the older version or disconnect.
|
|
14
|
+
*/
|
|
15
|
+
const session_ts_1 = require("./session.js");
|
|
16
|
+
const packageUtils_js_1 = require("../../utility/packageUtils.js");
|
|
17
|
+
exports.PROTOCOL_VERSION_PREFERRED = '2025-06-18';
|
|
18
|
+
exports.PROTOCOL_VERSION_BACKCOMPAT = '2025-03-26';
|
|
19
|
+
exports.SUPPORTED_PROTOCOL_VERSIONS = [exports.PROTOCOL_VERSION_PREFERRED, exports.PROTOCOL_VERSION_BACKCOMPAT];
|
|
20
|
+
exports.SERVER_INFO = {
|
|
21
|
+
name: 'harper-mcp',
|
|
22
|
+
version: packageUtils_js_1.packageJson.version,
|
|
23
|
+
};
|
|
24
|
+
/** Server capabilities advertised on `initialize` for v1. */
|
|
25
|
+
exports.SERVER_CAPABILITIES = {
|
|
26
|
+
tools: { listChanged: true },
|
|
27
|
+
resources: { listChanged: true },
|
|
28
|
+
logging: {},
|
|
29
|
+
};
|
|
30
|
+
/**
|
|
31
|
+
* Negotiate protocol version, create a session, and return the JSON-RPC
|
|
32
|
+
* result body. The caller (transport core) maps `ok: false` to HTTP 400.
|
|
33
|
+
*
|
|
34
|
+
* Per the MCP spec: if the client requests a version the server does not
|
|
35
|
+
* support, the server MUST respond with a version it does support (so the
|
|
36
|
+
* client can decide whether to downgrade or disconnect) — NOT fail. We
|
|
37
|
+
* pick `PROTOCOL_VERSION_PREFERRED` for any unknown version. The only
|
|
38
|
+
* `ok: false` cases are a missing or non-string `protocolVersion` field,
|
|
39
|
+
* which is a protocol-level violation rather than version negotiation.
|
|
40
|
+
*
|
|
41
|
+
* `instructions` is optional per spec; we omit it in v1 (it can be wired
|
|
42
|
+
* later when tools land in #617 and we know which profile is active).
|
|
43
|
+
*/
|
|
44
|
+
async function handleInitialize(params, user) {
|
|
45
|
+
const requested = params?.protocolVersion;
|
|
46
|
+
if (typeof requested !== 'string') {
|
|
47
|
+
return {
|
|
48
|
+
ok: false,
|
|
49
|
+
reason: `protocolVersion is required and must be a string`,
|
|
50
|
+
supportedVersions: exports.SUPPORTED_PROTOCOL_VERSIONS,
|
|
51
|
+
};
|
|
52
|
+
}
|
|
53
|
+
const negotiated = exports.SUPPORTED_PROTOCOL_VERSIONS.includes(requested)
|
|
54
|
+
? requested
|
|
55
|
+
: exports.PROTOCOL_VERSION_PREFERRED;
|
|
56
|
+
const session = await (0, session_ts_1.createSession)({ user, protocolVersion: negotiated });
|
|
57
|
+
return {
|
|
58
|
+
ok: true,
|
|
59
|
+
session,
|
|
60
|
+
result: {
|
|
61
|
+
protocolVersion: negotiated,
|
|
62
|
+
serverInfo: exports.SERVER_INFO,
|
|
63
|
+
capabilities: exports.SERVER_CAPABILITIES,
|
|
64
|
+
},
|
|
65
|
+
};
|
|
66
|
+
}
|
|
67
|
+
/**
|
|
68
|
+
* Flip the session to `initialized: true`. Called when the client posts the
|
|
69
|
+
* `notifications/initialized` JSON-RPC notification (per MCP §lifecycle).
|
|
70
|
+
* The transport returns HTTP 202 with no body regardless of outcome here.
|
|
71
|
+
*/
|
|
72
|
+
async function handleInitialized(session) {
|
|
73
|
+
if (session.initialized)
|
|
74
|
+
return session;
|
|
75
|
+
const updated = { ...session, initialized: true };
|
|
76
|
+
await (0, session_ts_1.saveSession)(updated);
|
|
77
|
+
return updated;
|
|
78
|
+
}
|
|
79
|
+
//# sourceMappingURL=lifecycle.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"lifecycle.js","sourceRoot":"","sources":["../../../../core/components/mcp/lifecycle.ts"],"names":[],"mappings":";;;AAmEA,4CAyBC;AAOD,8CAKC;AAxGD;;;;;;;;GAQG;AACH,6CAAiF;AACjF,mEAA4D;AAE/C,QAAA,0BAA0B,GAAG,YAAY,CAAC;AAC1C,QAAA,2BAA2B,GAAG,YAAY,CAAC;AAC3C,QAAA,2BAA2B,GAAG,CAAC,kCAA0B,EAAE,mCAA2B,CAAU,CAAC;AAEjG,QAAA,WAAW,GAAG;IAC1B,IAAI,EAAE,YAAY;IAClB,OAAO,EAAG,6BAAmC,CAAC,OAAO;CAC5C,CAAC;AAEX,6DAA6D;AAChD,QAAA,mBAAmB,GAAG;IAClC,KAAK,EAAE,EAAE,WAAW,EAAE,IAAI,EAAE;IAC5B,SAAS,EAAE,EAAE,WAAW,EAAE,IAAI,EAAE;IAChC,OAAO,EAAE,EAAE;CACF,CAAC;AA2BX;;;;;;;;;;;;;GAaG;AACI,KAAK,UAAU,gBAAgB,CACrC,MAAoC,EACpC,IAAY;IAEZ,MAAM,SAAS,GAAG,MAAM,EAAE,eAAe,CAAC;IAC1C,IAAI,OAAO,SAAS,KAAK,QAAQ,EAAE,CAAC;QACnC,OAAO;YACN,EAAE,EAAE,KAAK;YACT,MAAM,EAAE,kDAAkD;YAC1D,iBAAiB,EAAE,mCAA2B;SAC9C,CAAC;IACH,CAAC;IACD,MAAM,UAAU,GAAG,mCAA2B,CAAC,QAAQ,CAAC,SAAyD,CAAC;QACjH,CAAC,CAAC,SAAS;QACX,CAAC,CAAC,kCAA0B,CAAC;IAC9B,MAAM,OAAO,GAAG,MAAM,IAAA,0BAAa,EAAC,EAAE,IAAI,EAAE,eAAe,EAAE,UAAU,EAAE,CAAC,CAAC;IAC3E,OAAO;QACN,EAAE,EAAE,IAAI;QACR,OAAO;QACP,MAAM,EAAE;YACP,eAAe,EAAE,UAAU;YAC3B,UAAU,EAAE,mBAAW;YACvB,YAAY,EAAE,2BAAmB;SACjC;KACD,CAAC;AACH,CAAC;AAED;;;;GAIG;AACI,KAAK,UAAU,iBAAiB,CAAC,OAAyB;IAChE,IAAI,OAAO,CAAC,WAAW;QAAE,OAAO,OAAO,CAAC;IACxC,MAAM,OAAO,GAAqB,EAAE,GAAG,OAAO,EAAE,WAAW,EAAE,IAAI,EAAE,CAAC;IACpE,MAAM,IAAA,wBAAW,EAAC,OAAO,CAAC,CAAC;IAC3B,OAAO,OAAO,CAAC;AAChB,CAAC"}
|