@harperfast/harper 5.0.0-alpha.10 → 5.0.0-beta.3
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/bin/BinObjects.js +17 -0
- package/bin/cliOperations.js +157 -0
- package/bin/copyDb.ts +280 -0
- package/bin/harper.js +156 -0
- package/bin/install.js +15 -0
- package/bin/lite.js +5 -0
- package/bin/restart.js +201 -0
- package/bin/run.js +409 -0
- package/bin/status.js +65 -0
- package/bin/stop.js +22 -0
- package/bin/upgrade.js +134 -0
- package/components/Application.ts +646 -0
- package/components/ApplicationScope.ts +49 -0
- package/components/Component.ts +53 -0
- package/components/ComponentV1.ts +342 -0
- package/components/DEFAULT_CONFIG.ts +18 -0
- package/components/EntryHandler.ts +227 -0
- package/components/Logger.ts +14 -0
- package/components/OptionsWatcher.ts +354 -0
- package/components/PluginModule.ts +6 -0
- package/components/Scope.ts +329 -0
- package/components/componentLoader.ts +529 -0
- package/components/deriveCommonPatternBase.ts +31 -0
- package/components/deriveGlobOptions.ts +44 -0
- package/components/deriveURLPath.ts +57 -0
- package/components/operations.js +658 -0
- package/components/operationsValidation.js +246 -0
- package/components/packageComponent.ts +39 -0
- package/components/requestRestart.ts +26 -0
- package/components/resolveBaseURLPath.ts +38 -0
- package/components/status/ComponentStatus.ts +110 -0
- package/components/status/ComponentStatusRegistry.ts +251 -0
- package/components/status/api.ts +153 -0
- package/components/status/crossThread.ts +405 -0
- package/components/status/errors.ts +152 -0
- package/components/status/index.ts +44 -0
- package/components/status/internal.ts +65 -0
- package/components/status/registry.ts +12 -0
- package/components/status/types.ts +96 -0
- package/config/RootConfigWatcher.ts +59 -0
- package/config/configHelpers.ts +11 -0
- package/config/configUtils.js +967 -0
- package/config/harperConfigEnvVars.ts +641 -0
- package/dataLayer/CreateAttributeObject.js +25 -0
- package/dataLayer/CreateTableObject.js +11 -0
- package/dataLayer/DataLayerObjects.js +43 -0
- package/dataLayer/DeleteBeforeObject.js +22 -0
- package/dataLayer/DeleteObject.js +25 -0
- package/dataLayer/DropAttributeObject.js +11 -0
- package/dataLayer/GetBackupObject.js +22 -0
- package/dataLayer/InsertObject.js +24 -0
- package/dataLayer/ReadAuditLogObject.js +24 -0
- package/dataLayer/SQLSearch.js +1335 -0
- package/dataLayer/SearchByConditionsObject.js +61 -0
- package/dataLayer/SearchByHashObject.js +21 -0
- package/dataLayer/SearchObject.js +45 -0
- package/dataLayer/SqlSearchObject.js +14 -0
- package/dataLayer/UpdateObject.js +23 -0
- package/dataLayer/UpsertObject.js +23 -0
- package/dataLayer/bulkLoad.js +813 -0
- package/dataLayer/dataObjects/BulkLoadObjects.js +27 -0
- package/dataLayer/dataObjects/UpsertObject.js +23 -0
- package/dataLayer/delete.js +164 -0
- package/dataLayer/export.js +381 -0
- package/dataLayer/getBackup.js +40 -0
- package/dataLayer/harperBridge/BridgeMethods.js +81 -0
- package/dataLayer/harperBridge/ResourceBridge.ts +633 -0
- package/dataLayer/harperBridge/bridgeUtility/insertUpdateReturnObj.js +28 -0
- package/dataLayer/harperBridge/bridgeUtility/insertUpdateValidate.js +88 -0
- package/dataLayer/harperBridge/harperBridge.js +21 -0
- package/dataLayer/harperBridge/lmdbBridge/LMDBBridge.js +119 -0
- package/dataLayer/harperBridge/lmdbBridge/lmdbMethods/DeleteAuditLogsBeforeResults.js +19 -0
- package/dataLayer/harperBridge/lmdbBridge/lmdbMethods/lmdbCreateAttribute.js +112 -0
- package/dataLayer/harperBridge/lmdbBridge/lmdbMethods/lmdbCreateRecords.js +67 -0
- package/dataLayer/harperBridge/lmdbBridge/lmdbMethods/lmdbCreateSchema.js +31 -0
- package/dataLayer/harperBridge/lmdbBridge/lmdbMethods/lmdbCreateTable.js +94 -0
- package/dataLayer/harperBridge/lmdbBridge/lmdbMethods/lmdbDeleteAuditLogsBefore.js +98 -0
- package/dataLayer/harperBridge/lmdbBridge/lmdbMethods/lmdbDeleteRecords.js +89 -0
- package/dataLayer/harperBridge/lmdbBridge/lmdbMethods/lmdbDropAttribute.js +109 -0
- package/dataLayer/harperBridge/lmdbBridge/lmdbMethods/lmdbDropSchema.js +107 -0
- package/dataLayer/harperBridge/lmdbBridge/lmdbMethods/lmdbDropTable.js +137 -0
- package/dataLayer/harperBridge/lmdbBridge/lmdbMethods/lmdbFlush.js +35 -0
- package/dataLayer/harperBridge/lmdbBridge/lmdbMethods/lmdbGetBackup.js +111 -0
- package/dataLayer/harperBridge/lmdbBridge/lmdbMethods/lmdbGetDataByHash.js +28 -0
- package/dataLayer/harperBridge/lmdbBridge/lmdbMethods/lmdbGetDataByValue.js +29 -0
- package/dataLayer/harperBridge/lmdbBridge/lmdbMethods/lmdbReadAuditLog.js +207 -0
- package/dataLayer/harperBridge/lmdbBridge/lmdbMethods/lmdbSearchByConditions.js +156 -0
- package/dataLayer/harperBridge/lmdbBridge/lmdbMethods/lmdbSearchByHash.js +21 -0
- package/dataLayer/harperBridge/lmdbBridge/lmdbMethods/lmdbSearchByValue.js +30 -0
- package/dataLayer/harperBridge/lmdbBridge/lmdbMethods/lmdbTransaction.js +19 -0
- package/dataLayer/harperBridge/lmdbBridge/lmdbMethods/lmdbUpdateRecords.js +64 -0
- package/dataLayer/harperBridge/lmdbBridge/lmdbMethods/lmdbUpsertRecords.js +70 -0
- package/dataLayer/harperBridge/lmdbBridge/lmdbUtility/LMDBCreateAttributeObject.js +22 -0
- package/dataLayer/harperBridge/lmdbBridge/lmdbUtility/LMDBDeleteTransactionObject.js +23 -0
- package/dataLayer/harperBridge/lmdbBridge/lmdbUtility/LMDBInsertTransactionObject.js +22 -0
- package/dataLayer/harperBridge/lmdbBridge/lmdbUtility/LMDBTransactionObject.js +23 -0
- package/dataLayer/harperBridge/lmdbBridge/lmdbUtility/LMDBUpdateTransactionObject.js +24 -0
- package/dataLayer/harperBridge/lmdbBridge/lmdbUtility/LMDBUpsertTransactionObject.js +24 -0
- package/dataLayer/harperBridge/lmdbBridge/lmdbUtility/TableSizeObject.js +25 -0
- package/dataLayer/harperBridge/lmdbBridge/lmdbUtility/initializeHashSearch.js +21 -0
- package/dataLayer/harperBridge/lmdbBridge/lmdbUtility/initializePaths.js +157 -0
- package/dataLayer/harperBridge/lmdbBridge/lmdbUtility/lmdbCheckForNewAttributes.js +94 -0
- package/dataLayer/harperBridge/lmdbBridge/lmdbUtility/lmdbCreateTransactionsAuditEnvironment.js +39 -0
- package/dataLayer/harperBridge/lmdbBridge/lmdbUtility/lmdbGetTableSize.js +34 -0
- package/dataLayer/harperBridge/lmdbBridge/lmdbUtility/lmdbProcessRows.js +100 -0
- package/dataLayer/harperBridge/lmdbBridge/lmdbUtility/lmdbSearch.js +371 -0
- package/dataLayer/harperBridge/lmdbBridge/lmdbUtility/lmdbWriteTransaction.js +109 -0
- package/dataLayer/hdbInfoController.js +254 -0
- package/dataLayer/insert.js +266 -0
- package/dataLayer/readAuditLog.js +59 -0
- package/dataLayer/schema.js +366 -0
- package/dataLayer/schemaDescribe.js +289 -0
- package/dataLayer/search.js +60 -0
- package/dataLayer/transaction.js +17 -0
- package/dataLayer/update.js +124 -0
- package/dist/components/Logger.d.ts +12 -0
- package/dist/{resources/ResourceInterfaceV2.js → components/Logger.js} +1 -1
- package/dist/components/Logger.js.map +1 -0
- package/dist/components/Scope.d.ts +14 -4
- package/dist/components/Scope.js +18 -10
- package/dist/components/Scope.js.map +1 -1
- package/dist/components/componentLoader.js +17 -10
- package/dist/components/componentLoader.js.map +1 -1
- package/dist/components/operations.js +2 -2
- package/dist/components/operations.js.map +1 -1
- package/dist/config/configUtils.d.ts +1 -1
- package/dist/config/configUtils.js +1 -1
- package/dist/config/configUtils.js.map +1 -1
- package/dist/dataLayer/CreateTableObject.d.ts +2 -2
- package/dist/dataLayer/CreateTableObject.js +2 -2
- package/dist/dataLayer/CreateTableObject.js.map +1 -1
- package/dist/dataLayer/delete.d.ts +1 -1
- package/dist/dataLayer/schema.js +6 -5
- package/dist/dataLayer/schema.js.map +1 -1
- package/dist/dataLayer/schemaDescribe.js +1 -1
- package/dist/dataLayer/schemaDescribe.js.map +1 -1
- package/dist/index.d.ts +1 -1
- package/dist/index.js +2 -0
- package/dist/index.js.map +1 -1
- package/dist/resources/DatabaseTransaction.d.ts +1 -1
- package/dist/resources/IterableEventQueue.d.ts +1 -1
- package/dist/resources/LMDBTransaction.d.ts +5 -1
- package/dist/resources/Resource.d.ts +1 -1
- package/dist/resources/ResourceInterface.d.ts +1 -1
- package/dist/resources/RocksIndexStore.d.ts +3 -3
- package/dist/resources/RocksTransactionLogStore.d.ts +6 -3
- package/dist/resources/Table.d.ts +15 -6
- package/dist/resources/Table.js +12 -4
- package/dist/resources/Table.js.map +1 -1
- package/dist/resources/analytics/read.js +32 -22
- package/dist/resources/analytics/read.js.map +1 -1
- package/dist/resources/analytics/write.js +3 -6
- package/dist/resources/analytics/write.js.map +1 -1
- package/dist/resources/auditStore.d.ts +3 -3
- package/dist/resources/blob.d.ts +25 -2
- package/dist/resources/databases.d.ts +12 -2
- package/dist/resources/databases.js +22 -19
- package/dist/resources/databases.js.map +1 -1
- package/dist/resources/search.js +11 -5
- package/dist/resources/search.js.map +1 -1
- package/dist/resources/transaction.d.ts +2 -1
- package/dist/security/auth.js +1 -1
- package/dist/security/auth.js.map +1 -1
- package/dist/security/cryptoHash.d.ts +2 -2
- package/dist/security/jsLoader.js +265 -73
- package/dist/security/jsLoader.js.map +1 -1
- package/dist/security/keys.js +11 -12
- package/dist/security/keys.js.map +1 -1
- package/dist/security/user.js +3 -3
- package/dist/security/user.js.map +1 -1
- package/dist/server/REST.js +16 -2
- package/dist/server/REST.js.map +1 -1
- package/dist/server/Server.d.ts +2 -1
- package/dist/server/Server.js.map +1 -1
- package/dist/server/fastifyRoutes/plugins/hdbCore.d.ts +6 -1
- package/dist/server/fastifyRoutes.js +2 -0
- package/dist/server/fastifyRoutes.js.map +1 -1
- package/dist/server/http.js +12 -6
- package/dist/server/http.js.map +1 -1
- package/dist/server/jobs/JobObject.d.ts +3 -3
- package/dist/server/loadRootComponents.js +1 -0
- package/dist/server/loadRootComponents.js.map +1 -1
- package/dist/server/operationsServer.js +3 -1
- package/dist/server/operationsServer.js.map +1 -1
- package/dist/server/serverHelpers/JSONStream.d.ts +3 -3
- package/dist/server/serverHelpers/Request.d.ts +5 -5
- package/dist/server/serverHelpers/requestTimePlugin.d.ts +1 -1
- package/dist/server/threads/manageThreads.d.ts +2 -2
- package/dist/server/threads/manageThreads.js +52 -35
- package/dist/server/threads/manageThreads.js.map +1 -1
- package/dist/server/threads/socketRouter.d.ts +1 -1
- package/dist/sqlTranslator/deleteTranslator.d.ts +1 -1
- package/dist/utility/AWS/AWSConnector.d.ts +3 -2
- package/dist/utility/common_utils.d.ts +3 -3
- package/dist/utility/environment/systemInformation.d.ts +1 -0
- package/dist/utility/functions/date/dateFunctions.d.ts +11 -11
- package/dist/utility/globalSchema.d.ts +1 -1
- package/dist/utility/hdbTerms.d.ts +3 -0
- package/dist/utility/hdbTerms.js +3 -0
- package/dist/utility/hdbTerms.js.map +1 -1
- package/dist/utility/installation.d.ts +2 -4
- package/dist/utility/installation.js.map +1 -1
- package/dist/utility/lmdb/commonUtility.d.ts +2 -1
- package/dist/utility/lmdb/commonUtility.js +20 -13
- package/dist/utility/lmdb/commonUtility.js.map +1 -1
- package/dist/utility/lmdb/deleteUtility.d.ts +1 -0
- package/dist/utility/lmdb/environmentUtility.d.ts +1 -0
- package/dist/utility/lmdb/searchUtility.d.ts +2 -1
- package/dist/utility/lmdb/writeUtility.d.ts +1 -0
- package/dist/utility/logging/harper_logger.d.ts +6 -6
- package/dist/utility/processManagement/processManagement.d.ts +1 -1
- package/dist/utility/processManagement/servicesConfig.d.ts +12 -6
- package/dist/validation/common_validators.d.ts +4 -3
- package/dist/validation/configValidator.d.ts +3 -2
- package/index.d.ts +56 -0
- package/index.js +41 -0
- package/json/systemSchema.json +373 -0
- package/launchServiceScripts/launchHarperDB.js +3 -0
- package/launchServiceScripts/utility/checkNodeVersion.js +15 -0
- package/package.json +35 -16
- package/resources/DatabaseTransaction.ts +378 -0
- package/resources/ErrorResource.ts +57 -0
- package/resources/IterableEventQueue.ts +94 -0
- package/resources/LMDBTransaction.ts +349 -0
- package/resources/RecordEncoder.ts +702 -0
- package/resources/RequestTarget.ts +134 -0
- package/resources/Resource.ts +789 -0
- package/resources/ResourceInterface.ts +221 -0
- package/resources/Resources.ts +162 -0
- package/resources/RocksIndexStore.ts +70 -0
- package/resources/RocksTransactionLogStore.ts +352 -0
- package/resources/Table.ts +4531 -0
- package/resources/analytics/hostnames.ts +72 -0
- package/resources/analytics/metadata.ts +10 -0
- package/resources/analytics/read.ts +252 -0
- package/resources/analytics/write.ts +803 -0
- package/resources/auditStore.ts +556 -0
- package/resources/blob.ts +1268 -0
- package/resources/crdt.ts +125 -0
- package/resources/dataLoader.ts +527 -0
- package/resources/databases.ts +1290 -0
- package/resources/graphql.ts +221 -0
- package/resources/indexes/HierarchicalNavigableSmallWorld.ts +638 -0
- package/resources/indexes/customIndexes.ts +7 -0
- package/resources/indexes/vector.ts +38 -0
- package/resources/jsResource.ts +86 -0
- package/resources/loadEnv.ts +22 -0
- package/resources/login.ts +18 -0
- package/resources/openApi.ts +409 -0
- package/resources/registrationDeprecated.ts +8 -0
- package/resources/replayLogs.ts +136 -0
- package/resources/roles.ts +98 -0
- package/resources/search.ts +1301 -0
- package/resources/tracked.ts +584 -0
- package/resources/transaction.ts +89 -0
- package/resources/transactionBroadcast.ts +258 -0
- package/security/auth.ts +376 -0
- package/security/certificateVerification/certificateVerificationSource.ts +84 -0
- package/security/certificateVerification/configValidation.ts +107 -0
- package/security/certificateVerification/crlVerification.ts +623 -0
- package/security/certificateVerification/index.ts +121 -0
- package/security/certificateVerification/ocspVerification.ts +148 -0
- package/security/certificateVerification/pkijs-ed25519-patch.ts +188 -0
- package/security/certificateVerification/types.ts +128 -0
- package/security/certificateVerification/verificationConfig.ts +138 -0
- package/security/certificateVerification/verificationUtils.ts +447 -0
- package/security/cryptoHash.js +42 -0
- package/security/data_objects/PermissionAttributeResponseObject.js +15 -0
- package/security/data_objects/PermissionResponseObject.js +115 -0
- package/security/data_objects/PermissionTableResponseObject.js +20 -0
- package/security/fastifyAuth.js +169 -0
- package/security/impersonation.ts +160 -0
- package/security/jsLoader.ts +733 -0
- package/security/keys.js +948 -0
- package/security/permissionsTranslator.js +300 -0
- package/security/role.js +218 -0
- package/security/tokenAuthentication.ts +228 -0
- package/security/user.ts +449 -0
- package/server/DurableSubscriptionsSession.ts +503 -0
- package/server/REST.ts +407 -0
- package/server/Server.ts +89 -0
- package/server/fastifyRoutes/helpers/getCORSOptions.js +36 -0
- package/server/fastifyRoutes/helpers/getHeaderTimeoutConfig.js +15 -0
- package/server/fastifyRoutes/helpers/getServerOptions.js +33 -0
- package/server/fastifyRoutes/plugins/hdbCore.js +39 -0
- package/server/fastifyRoutes.ts +205 -0
- package/server/graphqlQuerying.ts +700 -0
- package/server/http.ts +640 -0
- package/server/itc/serverHandlers.js +161 -0
- package/server/itc/utility/ITCEventObject.js +10 -0
- package/server/jobs/JobObject.js +24 -0
- package/server/jobs/jobProcess.js +69 -0
- package/server/jobs/jobRunner.js +162 -0
- package/server/jobs/jobs.js +304 -0
- package/server/loadRootComponents.js +44 -0
- package/server/mqtt.ts +485 -0
- package/server/nodeName.ts +75 -0
- package/server/operationsServer.ts +313 -0
- package/server/serverHelpers/Headers.ts +108 -0
- package/server/serverHelpers/JSONStream.ts +269 -0
- package/server/serverHelpers/OperationFunctionObject.ts +13 -0
- package/server/serverHelpers/Request.ts +158 -0
- package/server/serverHelpers/contentTypes.ts +637 -0
- package/server/serverHelpers/requestTimePlugin.js +57 -0
- package/server/serverHelpers/serverHandlers.js +148 -0
- package/server/serverHelpers/serverUtilities.ts +473 -0
- package/server/serverRegistry.ts +8 -0
- package/server/static.ts +187 -0
- package/server/status/definitions.ts +37 -0
- package/server/status/index.ts +125 -0
- package/server/storageReclamation.ts +93 -0
- package/server/threads/itc.js +89 -0
- package/server/threads/manageThreads.js +596 -0
- package/server/threads/socketRouter.ts +360 -0
- package/server/threads/threadServer.js +279 -0
- package/server/throttle.ts +73 -0
- package/sqlTranslator/SelectValidator.js +330 -0
- package/sqlTranslator/alasqlFunctionImporter.js +62 -0
- package/sqlTranslator/deleteTranslator.js +67 -0
- package/sqlTranslator/index.js +242 -0
- package/sqlTranslator/sql_statement_bucket.js +472 -0
- package/static/defaultConfig.yaml +3 -0
- package/studio/web/HDBDogOnly.svg +78 -0
- package/studio/web/assets/PPRadioGrotesk-Bold-DDaUYG8E.woff +0 -0
- package/studio/web/assets/fa-brands-400-CEJbCg16.woff +0 -0
- package/studio/web/assets/fa-brands-400-CSYNqBb_.ttf +0 -0
- package/studio/web/assets/fa-brands-400-DnkPfk3o.eot +0 -0
- package/studio/web/assets/fa-brands-400-UxlILjvJ.woff2 +0 -0
- package/studio/web/assets/fa-brands-400-cH1MgKbP.svg +3717 -0
- package/studio/web/assets/fa-regular-400-BhTwtT8w.eot +0 -0
- package/studio/web/assets/fa-regular-400-D1vz6WBx.ttf +0 -0
- package/studio/web/assets/fa-regular-400-DFnMcJPd.woff +0 -0
- package/studio/web/assets/fa-regular-400-DGzu1beS.woff2 +0 -0
- package/studio/web/assets/fa-regular-400-gwj8Pxq-.svg +801 -0
- package/studio/web/assets/fa-solid-900-B4ZZ7kfP.svg +5034 -0
- package/studio/web/assets/fa-solid-900-B6Axprfb.eot +0 -0
- package/studio/web/assets/fa-solid-900-BUswJgRo.woff2 +0 -0
- package/studio/web/assets/fa-solid-900-DOXgCApm.woff +0 -0
- package/studio/web/assets/fa-solid-900-mxuxnBEa.ttf +0 -0
- package/studio/web/assets/index-C1G-Jo6n.js +37 -0
- package/studio/web/assets/index-C1G-Jo6n.js.map +1 -0
- package/studio/web/assets/index-D-CahN0-.js +2 -0
- package/studio/web/assets/index-D-CahN0-.js.map +1 -0
- package/studio/web/assets/index-DxlZI0PX.js +235 -0
- package/studio/web/assets/index-DxlZI0PX.js.map +1 -0
- package/studio/web/assets/index-Y2g_iFpU.css +1 -0
- package/studio/web/assets/index-jiPwkrsB.css +1 -0
- package/studio/web/assets/index.lazy-BUXDDqq9.js +266 -0
- package/studio/web/assets/index.lazy-BUXDDqq9.js.map +1 -0
- package/studio/web/assets/profiler-CU93QiSW.js +2 -0
- package/studio/web/assets/profiler-CU93QiSW.js.map +1 -0
- package/studio/web/assets/react-redux-B8k9Ep7e.js +6 -0
- package/studio/web/assets/react-redux-B8k9Ep7e.js.map +1 -0
- package/studio/web/assets/startRecording-DFeBXGk6.js +3 -0
- package/studio/web/assets/startRecording-DFeBXGk6.js.map +1 -0
- package/studio/web/fabric-signup-background.webp +0 -0
- package/studio/web/fabric-signup-text.png +0 -0
- package/studio/web/favicon_purple.png +0 -0
- package/studio/web/github-icon.svg +15 -0
- package/studio/web/harper-fabric_black.png +0 -0
- package/studio/web/harper-fabric_white.png +0 -0
- package/studio/web/harper-studio_white.png +0 -0
- package/studio/web/index.html +16 -0
- package/studio/web/running.css +148 -0
- package/studio/web/running.html +147 -0
- package/studio/web/running.js +111 -0
- package/upgrade/UpgradeObjects.js +13 -0
- package/upgrade/directives/directivesController.js +90 -0
- package/upgrade/directivesManager.js +139 -0
- package/upgrade/upgradePrompt.js +124 -0
- package/upgrade/upgradeUtilities.js +28 -0
- package/utility/AWS/AWSConnector.js +29 -0
- package/utility/OperationFunctionCaller.js +63 -0
- package/utility/assignCmdEnvVariables.js +62 -0
- package/utility/common_utils.js +867 -0
- package/utility/environment/environmentManager.js +208 -0
- package/utility/environment/systemInformation.js +355 -0
- package/utility/errors/commonErrors.js +267 -0
- package/utility/errors/hdbError.js +146 -0
- package/utility/functions/date/dateFunctions.js +65 -0
- package/utility/functions/geo.js +355 -0
- package/utility/functions/sql/alaSQLExtension.js +104 -0
- package/utility/globalSchema.js +35 -0
- package/utility/hdbTerms.ts +819 -0
- package/utility/install/checkJWTTokensExist.js +62 -0
- package/utility/install/harperdb.conf +15 -0
- package/utility/install/harperdb.service +14 -0
- package/utility/install/installer.js +635 -0
- package/utility/installation.ts +30 -0
- package/utility/lmdb/DBIDefinition.js +20 -0
- package/utility/lmdb/DeleteRecordsResponseObject.js +25 -0
- package/utility/lmdb/InsertRecordsResponseObject.js +22 -0
- package/utility/lmdb/OpenDBIObject.js +31 -0
- package/utility/lmdb/OpenEnvironmentObject.js +41 -0
- package/utility/lmdb/UpdateRecordsResponseObject.js +25 -0
- package/utility/lmdb/UpsertRecordsResponseObject.js +22 -0
- package/utility/lmdb/cleanLMDBMap.js +65 -0
- package/utility/lmdb/commonUtility.js +130 -0
- package/utility/lmdb/deleteUtility.js +128 -0
- package/utility/lmdb/environmentUtility.js +477 -0
- package/utility/lmdb/searchCursorFunctions.js +187 -0
- package/utility/lmdb/searchUtility.js +918 -0
- package/utility/lmdb/terms.js +57 -0
- package/utility/lmdb/writeUtility.js +407 -0
- package/utility/logging/harper_logger.js +876 -0
- package/utility/logging/logRotator.js +157 -0
- package/utility/logging/logger.ts +24 -0
- package/utility/logging/readLog.js +355 -0
- package/utility/logging/transactionLog.js +57 -0
- package/utility/mount_hdb.js +59 -0
- package/utility/npmUtilities.js +102 -0
- package/utility/operationPermissions.ts +112 -0
- package/utility/operation_authorization.js +836 -0
- package/utility/packageUtils.js +55 -0
- package/utility/password.ts +99 -0
- package/utility/processManagement/processManagement.js +187 -0
- package/utility/processManagement/servicesConfig.js +56 -0
- package/utility/scripts/restartHdb.js +24 -0
- package/utility/scripts/user_data.sh +13 -0
- package/utility/signalling.js +36 -0
- package/utility/terms/certificates.js +81 -0
- package/utility/when.ts +20 -0
- package/validation/bulkDeleteValidator.js +24 -0
- package/validation/check_permissions.js +19 -0
- package/validation/common_validators.js +95 -0
- package/validation/configValidator.js +331 -0
- package/validation/deleteValidator.js +15 -0
- package/validation/fileLoadValidator.js +153 -0
- package/validation/insertValidator.js +40 -0
- package/validation/installValidator.js +37 -0
- package/validation/readLogValidator.js +64 -0
- package/validation/role_validation.js +320 -0
- package/validation/schemaMetadataValidator.js +42 -0
- package/validation/searchValidator.js +166 -0
- package/validation/statusValidator.ts +66 -0
- package/validation/transactionLogValidator.js +33 -0
- package/validation/user_validation.js +55 -0
- package/validation/validationWrapper.js +105 -0
- package/dist/resources/ResourceInterfaceV2.d.ts +0 -21
- package/dist/resources/ResourceInterfaceV2.js.map +0 -1
- package/dist/resources/ResourceV2.d.ts +0 -30
- package/dist/resources/ResourceV2.js +0 -27
- package/dist/resources/ResourceV2.js.map +0 -1
- package/dist/resources/analytics/profile.d.ts +0 -2
- package/dist/resources/analytics/profile.js +0 -144
- package/dist/resources/analytics/profile.js.map +0 -1
|
@@ -0,0 +1,17 @@
|
|
|
1
|
+
'use strict';
|
|
2
|
+
|
|
3
|
+
/**
|
|
4
|
+
* This is meant as a central place to defined POJOs used by functions in the /bin/ directory.
|
|
5
|
+
*/
|
|
6
|
+
|
|
7
|
+
class HdbInfoInsertObject {
|
|
8
|
+
constructor(id, dataVersionNum, hdbVersionNum) {
|
|
9
|
+
this.info_id = id;
|
|
10
|
+
this.data_version_num = dataVersionNum;
|
|
11
|
+
this.hdb_version_num = hdbVersionNum;
|
|
12
|
+
}
|
|
13
|
+
}
|
|
14
|
+
|
|
15
|
+
module.exports = {
|
|
16
|
+
HdbInfoInsertObject,
|
|
17
|
+
};
|
|
@@ -0,0 +1,157 @@
|
|
|
1
|
+
'use strict';
|
|
2
|
+
|
|
3
|
+
const envMgr = require('../utility/environment/environmentManager.js');
|
|
4
|
+
envMgr.initSync();
|
|
5
|
+
const terms = require('../utility/hdbTerms.ts');
|
|
6
|
+
const { httpRequest } = require('../utility/common_utils.js');
|
|
7
|
+
const path = require('path');
|
|
8
|
+
const fs = require('fs-extra');
|
|
9
|
+
const YAML = require('yaml');
|
|
10
|
+
const { packageDirectory } = require('../components/packageComponent.ts');
|
|
11
|
+
const { encode } = require('cbor-x');
|
|
12
|
+
const { getHdbPid } = require('../utility/processManagement/processManagement.js');
|
|
13
|
+
const { initConfig } = require('../config/configUtils.js');
|
|
14
|
+
|
|
15
|
+
const OP_ALIASES = { deploy: 'deploy_component', package: 'package_component' };
|
|
16
|
+
|
|
17
|
+
module.exports = { cliOperations, buildRequest };
|
|
18
|
+
const PREPARE_OPERATION = {
|
|
19
|
+
deploy_component: async (req) => {
|
|
20
|
+
if (req.package) {
|
|
21
|
+
return;
|
|
22
|
+
}
|
|
23
|
+
|
|
24
|
+
const projectPath = process.cwd();
|
|
25
|
+
req.payload = await packageDirectory(projectPath, { skip_node_modules: true, ...req });
|
|
26
|
+
req.cborEncode = true;
|
|
27
|
+
if (!req.project) req.project = path.basename(projectPath);
|
|
28
|
+
},
|
|
29
|
+
};
|
|
30
|
+
|
|
31
|
+
/**
|
|
32
|
+
* Builds an Op-API request object from CLI args
|
|
33
|
+
*/
|
|
34
|
+
function buildRequest() {
|
|
35
|
+
const req = {};
|
|
36
|
+
for (const arg of process.argv.slice(2)) {
|
|
37
|
+
if (OP_ALIASES.hasOwnProperty(arg)) {
|
|
38
|
+
req.operation = OP_ALIASES[arg];
|
|
39
|
+
} else if (arg.includes('=')) {
|
|
40
|
+
let [first, ...rest] = arg.split('=');
|
|
41
|
+
rest = rest.join('=');
|
|
42
|
+
|
|
43
|
+
try {
|
|
44
|
+
rest = JSON.parse(rest);
|
|
45
|
+
} catch {
|
|
46
|
+
/* noop */
|
|
47
|
+
}
|
|
48
|
+
|
|
49
|
+
req[first] = rest;
|
|
50
|
+
} else {
|
|
51
|
+
// operation should only be in the first arg
|
|
52
|
+
req.operation ??= arg;
|
|
53
|
+
}
|
|
54
|
+
}
|
|
55
|
+
|
|
56
|
+
return req;
|
|
57
|
+
}
|
|
58
|
+
|
|
59
|
+
/**
|
|
60
|
+
* Using a unix domain socket will send a request to hdb operations API server
|
|
61
|
+
* @param req
|
|
62
|
+
* @returns {Promise<void>}
|
|
63
|
+
*/
|
|
64
|
+
async function cliOperations(req) {
|
|
65
|
+
if (!req.target) {
|
|
66
|
+
req.target = process.env.CLI_TARGET;
|
|
67
|
+
}
|
|
68
|
+
let target;
|
|
69
|
+
if (req.target) {
|
|
70
|
+
try {
|
|
71
|
+
target = new URL(req.target);
|
|
72
|
+
} catch (error) {
|
|
73
|
+
try {
|
|
74
|
+
target = new URL(`https://${req.target}:9925`);
|
|
75
|
+
} catch {
|
|
76
|
+
throw error; // throw the original error
|
|
77
|
+
}
|
|
78
|
+
}
|
|
79
|
+
target = {
|
|
80
|
+
protocol: target.protocol,
|
|
81
|
+
hostname: target.hostname,
|
|
82
|
+
port: target.port,
|
|
83
|
+
username: req.username || target.username || process.env.CLI_TARGET_USERNAME,
|
|
84
|
+
password: req.password || target.password || process.env.CLI_TARGET_PASSWORD,
|
|
85
|
+
rejectUnauthorized: req.rejectUnauthorized,
|
|
86
|
+
};
|
|
87
|
+
} else {
|
|
88
|
+
// if we aren't doing a targeted operation (like deploy), we initialize the config and verify that local harper
|
|
89
|
+
// is running and that we can communicate with it.
|
|
90
|
+
initConfig();
|
|
91
|
+
if (!getHdbPid()) {
|
|
92
|
+
console.error('Harper must be running to perform this operation');
|
|
93
|
+
process.exit(1);
|
|
94
|
+
}
|
|
95
|
+
|
|
96
|
+
if (!fs.existsSync(envMgr.get(terms.CONFIG_PARAMS.OPERATIONSAPI_NETWORK_DOMAINSOCKET))) {
|
|
97
|
+
console.error('No domain socket found, unable to perform this operation');
|
|
98
|
+
process.exit(1);
|
|
99
|
+
}
|
|
100
|
+
}
|
|
101
|
+
await PREPARE_OPERATION[req.operation]?.(req);
|
|
102
|
+
try {
|
|
103
|
+
let options = target ?? {
|
|
104
|
+
protocol: 'http:',
|
|
105
|
+
socketPath: envMgr.get(terms.CONFIG_PARAMS.OPERATIONSAPI_NETWORK_DOMAINSOCKET),
|
|
106
|
+
};
|
|
107
|
+
options.method = 'POST';
|
|
108
|
+
options.headers = { 'Content-Type': 'application/json' };
|
|
109
|
+
if (target?.username) {
|
|
110
|
+
options.headers.Authorization = `Basic ${Buffer.from(`${target.username}:${target.password}`).toString('base64')}`;
|
|
111
|
+
}
|
|
112
|
+
if (req.cborEncode) {
|
|
113
|
+
options.headers['Content-Type'] = 'application/cbor';
|
|
114
|
+
req = encode(req);
|
|
115
|
+
}
|
|
116
|
+
let response = await httpRequest(options, req);
|
|
117
|
+
|
|
118
|
+
let responseData;
|
|
119
|
+
try {
|
|
120
|
+
responseData = JSON.parse(response.body);
|
|
121
|
+
} catch {
|
|
122
|
+
responseData = {
|
|
123
|
+
status: response.statusCode + ' ' + (response.statusMessage || 'Unknown'),
|
|
124
|
+
body: response.body,
|
|
125
|
+
};
|
|
126
|
+
}
|
|
127
|
+
|
|
128
|
+
let responseLog;
|
|
129
|
+
if (req.json) {
|
|
130
|
+
responseLog = JSON.stringify(responseData, null, 2);
|
|
131
|
+
} else {
|
|
132
|
+
responseLog = YAML.stringify(responseData).trim();
|
|
133
|
+
}
|
|
134
|
+
|
|
135
|
+
const { statusCode } = response;
|
|
136
|
+
if (statusCode < 200 || (statusCode >= 300 && statusCode !== 304)) {
|
|
137
|
+
const errorPrefix = responseLog.startsWith('error:') ? '' : 'error: ';
|
|
138
|
+
console.error(`${errorPrefix}${responseLog}`);
|
|
139
|
+
process.exit(1);
|
|
140
|
+
}
|
|
141
|
+
|
|
142
|
+
console.log(responseLog);
|
|
143
|
+
|
|
144
|
+
return responseData;
|
|
145
|
+
} catch (err) {
|
|
146
|
+
if (err.code === 'ENOENT' || err.code === 'ECONNREFUSED') {
|
|
147
|
+
console.error(`error: Failed to connect to Harper (${err.code}): ${err.message}`);
|
|
148
|
+
} else if (err.code === 'EACCES') {
|
|
149
|
+
console.error(`error: Permission denied accessing the domain socket: ${err.message}`);
|
|
150
|
+
} else if (err.code === 'ENOTFOUND') {
|
|
151
|
+
console.error(`error: Host not found: "${err.hostname}" ${err.message}`);
|
|
152
|
+
} else {
|
|
153
|
+
console.error(`error: ${err.message ?? err}`);
|
|
154
|
+
}
|
|
155
|
+
process.exit(1);
|
|
156
|
+
}
|
|
157
|
+
}
|
package/bin/copyDb.ts
ADDED
|
@@ -0,0 +1,280 @@
|
|
|
1
|
+
import { getDatabases, getDefaultCompression, resetDatabases } from '../resources/databases.ts';
|
|
2
|
+
import { open } from 'lmdb';
|
|
3
|
+
import { join } from 'path';
|
|
4
|
+
import { move, remove } from 'fs-extra';
|
|
5
|
+
import { get } from '../utility/environment/environmentManager.js';
|
|
6
|
+
import OpenEnvironmentObject from '../utility/lmdb/OpenEnvironmentObject.js';
|
|
7
|
+
import { OpenDBIObject } from '../utility/lmdb/OpenDBIObject.js';
|
|
8
|
+
import { INTERNAL_DBIS_NAME, AUDIT_STORE_NAME } from '../utility/lmdb/terms.js';
|
|
9
|
+
import { CONFIG_PARAMS, DATABASES_DIR_NAME } from '../utility/hdbTerms.ts';
|
|
10
|
+
import { AUDIT_STORE_OPTIONS } from '../resources/auditStore.ts';
|
|
11
|
+
import { describeSchema } from '../dataLayer/schemaDescribe.js';
|
|
12
|
+
import { updateConfigValue } from '../config/configUtils.js';
|
|
13
|
+
import * as hdbLogger from '../utility/logging/harper_logger.js';
|
|
14
|
+
|
|
15
|
+
export async function compactOnStart() {
|
|
16
|
+
hdbLogger.notify('Running compact on start');
|
|
17
|
+
console.log('Running compact on start');
|
|
18
|
+
|
|
19
|
+
// Create compact copy and backup
|
|
20
|
+
const rootPath = get(CONFIG_PARAMS.ROOTPATH);
|
|
21
|
+
const compactedDb = new Map();
|
|
22
|
+
const databases = getDatabases();
|
|
23
|
+
|
|
24
|
+
updateConfigValue(CONFIG_PARAMS.STORAGE_COMPACTONSTART, false); // don't run this again, and update it before starting so that it fails we don't just keep retrying over and over
|
|
25
|
+
|
|
26
|
+
try {
|
|
27
|
+
for (const databaseName in databases) {
|
|
28
|
+
if (databaseName === 'system') continue;
|
|
29
|
+
if (databaseName.endsWith('-copy')) continue; // don't copy the copy
|
|
30
|
+
let dbPath;
|
|
31
|
+
for (const tableName in databases[databaseName]) {
|
|
32
|
+
dbPath = databases[databaseName][tableName].primaryStore.path;
|
|
33
|
+
break;
|
|
34
|
+
}
|
|
35
|
+
if (!dbPath) {
|
|
36
|
+
console.log("Couldn't find any tables in database", databaseName);
|
|
37
|
+
continue;
|
|
38
|
+
}
|
|
39
|
+
|
|
40
|
+
const backupDest = join(rootPath, 'backup', databaseName + '.mdb');
|
|
41
|
+
const copyDest = join(rootPath, DATABASES_DIR_NAME, databaseName + '-copy.mdb');
|
|
42
|
+
let recordCount = 0;
|
|
43
|
+
try {
|
|
44
|
+
recordCount = await getTotalDBRecordCount(databaseName);
|
|
45
|
+
console.log('Database', databaseName, 'before compact has a total record count of', recordCount);
|
|
46
|
+
} catch (error) {
|
|
47
|
+
hdbLogger.error('Error getting record count for database', databaseName, error);
|
|
48
|
+
console.error('Error getting record count for database', databaseName, error);
|
|
49
|
+
}
|
|
50
|
+
compactedDb.set(databaseName, {
|
|
51
|
+
dbPath,
|
|
52
|
+
copyDest,
|
|
53
|
+
backupDest,
|
|
54
|
+
recordCount,
|
|
55
|
+
});
|
|
56
|
+
|
|
57
|
+
await copyDb(databaseName, copyDest);
|
|
58
|
+
|
|
59
|
+
console.log('Backing up', databaseName, 'to', backupDest);
|
|
60
|
+
try {
|
|
61
|
+
await move(dbPath, backupDest, { overwrite: true });
|
|
62
|
+
} catch (error) {
|
|
63
|
+
console.log('Error moving database', dbPath, 'to', backupDest, error);
|
|
64
|
+
}
|
|
65
|
+
// Move compacted DB to back to original DB path
|
|
66
|
+
console.log('Moving copy compacted', databaseName, 'to', dbPath);
|
|
67
|
+
await move(copyDest, dbPath, { overwrite: true });
|
|
68
|
+
await remove(join(rootPath, DATABASES_DIR_NAME, `${databaseName}-copy.mdb-lock`));
|
|
69
|
+
}
|
|
70
|
+
try {
|
|
71
|
+
resetDatabases();
|
|
72
|
+
} catch (err) {
|
|
73
|
+
hdbLogger.error('Error resetting databases after backup', err);
|
|
74
|
+
console.error('Error resetting databases after backup', err);
|
|
75
|
+
}
|
|
76
|
+
|
|
77
|
+
try {
|
|
78
|
+
resetDatabases();
|
|
79
|
+
} catch (err) {
|
|
80
|
+
hdbLogger.error('Error resetting databases after backup', err);
|
|
81
|
+
console.error('Error resetting databases after backup', err);
|
|
82
|
+
process.exit(0); // just let the process restart
|
|
83
|
+
}
|
|
84
|
+
} catch (err) {
|
|
85
|
+
hdbLogger.error('Error compacting database, rolling back operation', err);
|
|
86
|
+
console.error('Error compacting database, rolling back operation', err);
|
|
87
|
+
|
|
88
|
+
updateConfigValue(CONFIG_PARAMS.STORAGE_COMPACTONSTART, false);
|
|
89
|
+
|
|
90
|
+
for (const [_db, { dbPath, backupDest }] of compactedDb) {
|
|
91
|
+
console.error('Moving backup database', backupDest, 'back to', dbPath);
|
|
92
|
+
try {
|
|
93
|
+
await move(backupDest, dbPath, { overwrite: true });
|
|
94
|
+
} catch (err) {
|
|
95
|
+
console.error(err);
|
|
96
|
+
}
|
|
97
|
+
}
|
|
98
|
+
resetDatabases();
|
|
99
|
+
|
|
100
|
+
throw err;
|
|
101
|
+
}
|
|
102
|
+
|
|
103
|
+
// Clean up backups
|
|
104
|
+
for (const [db, { backupDest, recordCount }] of compactedDb) {
|
|
105
|
+
const compactRecordCount = await getTotalDBRecordCount(db);
|
|
106
|
+
console.log('Database', db, 'after compact has a total record count of', compactRecordCount);
|
|
107
|
+
|
|
108
|
+
if (recordCount !== compactRecordCount) {
|
|
109
|
+
const errMsg = `There is a discrepancy between pre and post compact record count for database ${db}.\nTotal record count before compaction: ${recordCount}, total after: ${compactRecordCount}.\nDatabase backup has not been removed and can be found here: ${backupDest}`;
|
|
110
|
+
hdbLogger.warn(errMsg);
|
|
111
|
+
console.warn(errMsg);
|
|
112
|
+
}
|
|
113
|
+
|
|
114
|
+
if (get(CONFIG_PARAMS.STORAGE_COMPACTONSTARTKEEPBACKUP) === true) continue;
|
|
115
|
+
console.log('Removing backup', backupDest);
|
|
116
|
+
await remove(backupDest);
|
|
117
|
+
}
|
|
118
|
+
}
|
|
119
|
+
|
|
120
|
+
async function getTotalDBRecordCount(database: string) {
|
|
121
|
+
const dbDescribe = await describeSchema({ database });
|
|
122
|
+
let total = 0;
|
|
123
|
+
for (const table in dbDescribe) {
|
|
124
|
+
total += dbDescribe[table].record_count;
|
|
125
|
+
}
|
|
126
|
+
|
|
127
|
+
return total;
|
|
128
|
+
}
|
|
129
|
+
|
|
130
|
+
// we replace the write functions with a noop during this process, just in case they get called
|
|
131
|
+
function noop() {
|
|
132
|
+
// if there are any attempts to write to the db, ignore them
|
|
133
|
+
}
|
|
134
|
+
|
|
135
|
+
export async function copyDb(sourceDatabase: string, targetDatabasePath: string) {
|
|
136
|
+
console.log(`Copying database ${sourceDatabase} to ${targetDatabasePath}`);
|
|
137
|
+
const sourceDb = getDatabases()[sourceDatabase];
|
|
138
|
+
if (!sourceDb) throw new Error(`Source database not found: ${sourceDatabase}`);
|
|
139
|
+
let rootStore;
|
|
140
|
+
for (const tableName in sourceDb) {
|
|
141
|
+
const table = sourceDb[tableName];
|
|
142
|
+
// ensure that writes aren't occurring
|
|
143
|
+
table.primaryStore.put = noop;
|
|
144
|
+
table.primaryStore.remove = noop;
|
|
145
|
+
for (const attributeName in table.indices) {
|
|
146
|
+
const index = table.indices[attributeName];
|
|
147
|
+
index.put = noop;
|
|
148
|
+
index.remove = noop;
|
|
149
|
+
}
|
|
150
|
+
if (table.auditStore) {
|
|
151
|
+
table.auditStore.put = noop;
|
|
152
|
+
table.auditStore.remove = noop;
|
|
153
|
+
}
|
|
154
|
+
rootStore = table.primaryStore.rootStore;
|
|
155
|
+
}
|
|
156
|
+
if (!rootStore) throw new Error(`Source database does not have any tables: ${sourceDatabase}`);
|
|
157
|
+
// this contains the list of all the dbis
|
|
158
|
+
const sourceDbisDb = rootStore.dbisDb;
|
|
159
|
+
const sourceAuditStore = rootStore.auditStore;
|
|
160
|
+
const targetEnv = open(new OpenEnvironmentObject(targetDatabasePath));
|
|
161
|
+
const targetDbisDb = targetEnv.openDB(INTERNAL_DBIS_NAME);
|
|
162
|
+
let written;
|
|
163
|
+
let outstandingWrites = 0;
|
|
164
|
+
// we use a single transaction to get a snapshot, also we can't use snapshot: false on dupsort dbs
|
|
165
|
+
const transaction = sourceDbisDb.useReadTransaction();
|
|
166
|
+
try {
|
|
167
|
+
for (const { key, value: attribute } of sourceDbisDb.getRange({ transaction })) {
|
|
168
|
+
const isPrimary = attribute.isPrimaryKey;
|
|
169
|
+
let existingCompression, newCompression;
|
|
170
|
+
if (isPrimary) {
|
|
171
|
+
existingCompression = attribute.compression;
|
|
172
|
+
newCompression = getDefaultCompression();
|
|
173
|
+
if (newCompression) attribute.compression = newCompression;
|
|
174
|
+
else delete attribute.compression;
|
|
175
|
+
if (existingCompression?.dictionary?.toString() === newCompression?.dictionary?.toString()) {
|
|
176
|
+
// no need to change the compression, it's the same, so we can, and should, skip decompressing and recompressing
|
|
177
|
+
existingCompression = null;
|
|
178
|
+
newCompression = null;
|
|
179
|
+
}
|
|
180
|
+
}
|
|
181
|
+
targetDbisDb.put(key, attribute);
|
|
182
|
+
if (!(isPrimary || attribute.indexed)) continue;
|
|
183
|
+
const dbiInit = new OpenDBIObject(!isPrimary, isPrimary);
|
|
184
|
+
// we want to directly copy bytes so we don't have the overhead of
|
|
185
|
+
// encoding and decoding
|
|
186
|
+
dbiInit.encoding = 'binary';
|
|
187
|
+
dbiInit.compression = existingCompression;
|
|
188
|
+
//dbiInit.keyEncoding = 'binary';
|
|
189
|
+
const sourceDbi = rootStore.openDB(key, dbiInit);
|
|
190
|
+
sourceDbi.decoder = null;
|
|
191
|
+
sourceDbi.decoderCopies = false;
|
|
192
|
+
sourceDbi.encoding = 'binary';
|
|
193
|
+
dbiInit.compression = newCompression;
|
|
194
|
+
const targetDbi = targetEnv.openDB(key, dbiInit);
|
|
195
|
+
targetDbi.encoder = null;
|
|
196
|
+
console.log('copying', key, 'from', sourceDatabase, 'to', targetDatabasePath);
|
|
197
|
+
await copyDbi(sourceDbi, targetDbi, isPrimary, transaction);
|
|
198
|
+
}
|
|
199
|
+
if (sourceAuditStore) {
|
|
200
|
+
const targetAuditStore = rootStore.openDB(AUDIT_STORE_NAME, AUDIT_STORE_OPTIONS);
|
|
201
|
+
console.log('copying audit log for', sourceDatabase, 'to', targetDatabasePath);
|
|
202
|
+
copyDbi(sourceAuditStore, targetAuditStore, false, transaction);
|
|
203
|
+
}
|
|
204
|
+
|
|
205
|
+
async function copyDbi(sourceDbi, targetDbi, isPrimary, transaction) {
|
|
206
|
+
let recordsCopied = 0;
|
|
207
|
+
let bytesCopied = 0;
|
|
208
|
+
let skippedRecord = 0;
|
|
209
|
+
let retries = 10000000;
|
|
210
|
+
let start = null;
|
|
211
|
+
while (retries-- > 0) {
|
|
212
|
+
try {
|
|
213
|
+
for (const key of sourceDbi.getKeys({ start, transaction })) {
|
|
214
|
+
try {
|
|
215
|
+
start = key;
|
|
216
|
+
const { value, version } = sourceDbi.getEntry(key, { transaction });
|
|
217
|
+
// deleted entries should be 13 bytes long (8 for timestamp, 4 bytes for flags, 1 byte of the encoding of null)
|
|
218
|
+
if (value?.length < 14 && isPrimary) {
|
|
219
|
+
skippedRecord++;
|
|
220
|
+
continue;
|
|
221
|
+
}
|
|
222
|
+
written = targetDbi.put(key, value, isPrimary ? version : undefined);
|
|
223
|
+
recordsCopied++;
|
|
224
|
+
if (transaction.openTimer) transaction.openTimer = 0; // reset the timer, don't want it to time out
|
|
225
|
+
bytesCopied += (key?.length || 10) + value.length;
|
|
226
|
+
if (outstandingWrites++ > 5000) {
|
|
227
|
+
await written;
|
|
228
|
+
console.log(
|
|
229
|
+
'copied',
|
|
230
|
+
recordsCopied,
|
|
231
|
+
'entries, skipped',
|
|
232
|
+
skippedRecord,
|
|
233
|
+
'delete records,',
|
|
234
|
+
bytesCopied,
|
|
235
|
+
'bytes'
|
|
236
|
+
);
|
|
237
|
+
outstandingWrites = 0;
|
|
238
|
+
}
|
|
239
|
+
} catch (error) {
|
|
240
|
+
console.error(
|
|
241
|
+
'Error copying record',
|
|
242
|
+
typeof key === 'symbol' ? 'symbol' : key,
|
|
243
|
+
'from',
|
|
244
|
+
sourceDatabase,
|
|
245
|
+
'to',
|
|
246
|
+
targetDatabasePath,
|
|
247
|
+
error
|
|
248
|
+
);
|
|
249
|
+
}
|
|
250
|
+
}
|
|
251
|
+
console.log(
|
|
252
|
+
'finish copying, copied',
|
|
253
|
+
recordsCopied,
|
|
254
|
+
'entries, skipped',
|
|
255
|
+
skippedRecord,
|
|
256
|
+
'delete records,',
|
|
257
|
+
bytesCopied,
|
|
258
|
+
'bytes'
|
|
259
|
+
);
|
|
260
|
+
return;
|
|
261
|
+
} catch {
|
|
262
|
+
// try to resume with a bigger key
|
|
263
|
+
if (typeof start === 'string') {
|
|
264
|
+
if (start === 'z') {
|
|
265
|
+
return console.error('Reached end of dbi', start, 'for', sourceDatabase, 'to', targetDatabasePath);
|
|
266
|
+
}
|
|
267
|
+
start = start.slice(0, -2) + 'z';
|
|
268
|
+
} else if (typeof start === 'number') start++;
|
|
269
|
+
else return console.error('Unknown key type', start, 'for', sourceDatabase, 'to', targetDatabasePath);
|
|
270
|
+
}
|
|
271
|
+
}
|
|
272
|
+
}
|
|
273
|
+
|
|
274
|
+
await written;
|
|
275
|
+
console.log('copied database ' + sourceDatabase + ' to ' + targetDatabasePath);
|
|
276
|
+
} finally {
|
|
277
|
+
transaction.done();
|
|
278
|
+
targetEnv.close();
|
|
279
|
+
}
|
|
280
|
+
}
|
package/bin/harper.js
ADDED
|
@@ -0,0 +1,156 @@
|
|
|
1
|
+
#!/usr/bin/env node
|
|
2
|
+
'use strict';
|
|
3
|
+
|
|
4
|
+
const fs = require('node:fs');
|
|
5
|
+
const path = require('node:path');
|
|
6
|
+
const logger = require('../utility/logging/harper_logger.js');
|
|
7
|
+
const cliOperations = require('./cliOperations.js');
|
|
8
|
+
const { packageJson } = require('../utility/packageUtils.js');
|
|
9
|
+
const checkNode = require('../launchServiceScripts/utility/checkNodeVersion.js');
|
|
10
|
+
const hdbTerms = require('../utility/hdbTerms.ts');
|
|
11
|
+
const { SERVICE_ACTIONS_ENUM } = hdbTerms;
|
|
12
|
+
process.setSourceMapsEnabled(true); // this is necessary for source maps to work, at least on the main thread.
|
|
13
|
+
|
|
14
|
+
const HELP = `
|
|
15
|
+
Usage: harperdb [command]
|
|
16
|
+
|
|
17
|
+
With no command, harper will simply run Harper (in the foreground)
|
|
18
|
+
|
|
19
|
+
By default, the CLI also supports certain Operation APIs. Specify the operation name and any required parameters, and omit the 'operation' command.
|
|
20
|
+
|
|
21
|
+
Commands:
|
|
22
|
+
copy-db <source> <target> - Copies a database from source path to target path
|
|
23
|
+
dev <path> - Run the application in dev mode with debugging, foreground logging, no auth
|
|
24
|
+
install - Install harperdb
|
|
25
|
+
<api-operation> <param>=<value> - Run an API operation and return result to the CLI, not all operations are supported
|
|
26
|
+
register - Register harperdb
|
|
27
|
+
renew-certs - Generate a new set of self-signed certificates
|
|
28
|
+
restart - Restart the harperdb background process
|
|
29
|
+
run <path> - Run the application in the specified path
|
|
30
|
+
start - Starts a separate background process for harperdb and CLI will exit
|
|
31
|
+
status - Print the status of Harper
|
|
32
|
+
stop - Stop the harperdb background process
|
|
33
|
+
help - Display this output
|
|
34
|
+
upgrade - Upgrade harperdb
|
|
35
|
+
version - Print the version
|
|
36
|
+
deploy - Deploy the application locally or remotely with target=<remote url>
|
|
37
|
+
`;
|
|
38
|
+
|
|
39
|
+
async function harper() {
|
|
40
|
+
let nodeResults = checkNode();
|
|
41
|
+
|
|
42
|
+
if (nodeResults) {
|
|
43
|
+
if (nodeResults.error) {
|
|
44
|
+
console.error(nodeResults.error);
|
|
45
|
+
logger.error(nodeResults.error);
|
|
46
|
+
return;
|
|
47
|
+
} else if (nodeResults.warn) {
|
|
48
|
+
console.warn(nodeResults.warn);
|
|
49
|
+
logger.warn(nodeResults.warn);
|
|
50
|
+
}
|
|
51
|
+
}
|
|
52
|
+
|
|
53
|
+
let service;
|
|
54
|
+
|
|
55
|
+
if (process.argv && process.argv[2] && !process.argv[2].startsWith('-')) {
|
|
56
|
+
service = process.argv[2].toLowerCase();
|
|
57
|
+
}
|
|
58
|
+
|
|
59
|
+
switch (service) {
|
|
60
|
+
case SERVICE_ACTIONS_ENUM.HELP:
|
|
61
|
+
return HELP;
|
|
62
|
+
case SERVICE_ACTIONS_ENUM.START:
|
|
63
|
+
return require('./run.js').launch();
|
|
64
|
+
case SERVICE_ACTIONS_ENUM.INSTALL:
|
|
65
|
+
return require('./install.js')();
|
|
66
|
+
case SERVICE_ACTIONS_ENUM.STOP:
|
|
67
|
+
return require('./stop.js')().then(() => {
|
|
68
|
+
process.exit(0);
|
|
69
|
+
});
|
|
70
|
+
case SERVICE_ACTIONS_ENUM.RESTART:
|
|
71
|
+
return require('./restart.js').restart({});
|
|
72
|
+
case SERVICE_ACTIONS_ENUM.VERSION:
|
|
73
|
+
return packageJson.version;
|
|
74
|
+
case SERVICE_ACTIONS_ENUM.UPGRADE:
|
|
75
|
+
logger.setLogLevel(hdbTerms.LOG_LEVELS.INFO);
|
|
76
|
+
// The require is here to better control the flow of imports when this module is called.
|
|
77
|
+
return require('./upgrade.js')
|
|
78
|
+
.upgrade(null)
|
|
79
|
+
.then(() => 'Your instance of Harper is up to date!');
|
|
80
|
+
case SERVICE_ACTIONS_ENUM.STATUS:
|
|
81
|
+
return require('./status.js')();
|
|
82
|
+
case SERVICE_ACTIONS_ENUM.RENEWCERTS:
|
|
83
|
+
return require('../security/keys.js')
|
|
84
|
+
.renewSelfSigned()
|
|
85
|
+
.then(() => 'Successfully renewed self-signed certificates');
|
|
86
|
+
case SERVICE_ACTIONS_ENUM.COPYDB: {
|
|
87
|
+
let sourceDb = process.argv[3];
|
|
88
|
+
let targetDbPath = process.argv[4];
|
|
89
|
+
return require('./copyDb.ts').copyDb(sourceDb, targetDbPath);
|
|
90
|
+
}
|
|
91
|
+
case SERVICE_ACTIONS_ENUM.DEV:
|
|
92
|
+
process.env.DEV_MODE = true;
|
|
93
|
+
// fall through
|
|
94
|
+
case SERVICE_ACTIONS_ENUM.RUN: {
|
|
95
|
+
// Run a specific application folder
|
|
96
|
+
let appFolder = process.argv[3];
|
|
97
|
+
if (appFolder && appFolder[0] !== '-') {
|
|
98
|
+
if (!fs.existsSync(appFolder)) {
|
|
99
|
+
throw new Error(`The folder ${appFolder} does not exist`);
|
|
100
|
+
}
|
|
101
|
+
if (!fs.statSync(appFolder).isDirectory()) {
|
|
102
|
+
throw new Error(`The path ${appFolder} is not a folder`);
|
|
103
|
+
}
|
|
104
|
+
appFolder = fs.realpathSync(appFolder);
|
|
105
|
+
if (
|
|
106
|
+
fs.existsSync(path.join(appFolder, hdbTerms.HARPER_CONFIG_FILE)) ||
|
|
107
|
+
(fs.existsSync(path.join(appFolder, hdbTerms.HDB_CONFIG_FILE)) &&
|
|
108
|
+
fs.existsSync(path.join(appFolder, 'database')))
|
|
109
|
+
) {
|
|
110
|
+
// This can be used to run HDB without a boot file
|
|
111
|
+
process.env.ROOTPATH = appFolder;
|
|
112
|
+
} else {
|
|
113
|
+
process.env.RUN_HDB_APP = appFolder;
|
|
114
|
+
}
|
|
115
|
+
} else if (fs.existsSync(hdbTerms.HDB_COMPONENT_CONFIG_FILE) || fs.existsSync('schema.graphql')) {
|
|
116
|
+
console.warn(
|
|
117
|
+
`It appears you are running Harper in an application directory, but did not specify the path. I'll go ahead and run the application for you since that's probably what you meant. But to avoid this warning in the future, run applications in the current directory like this: "harper ${service} ."`
|
|
118
|
+
);
|
|
119
|
+
process.env.RUN_HDB_APP = process.cwd();
|
|
120
|
+
} else if (fs.existsSync(hdbTerms.HARPER_CONFIG_FILE) || fs.existsSync(hdbTerms.HDB_CONFIG_FILE)) {
|
|
121
|
+
console.warn(
|
|
122
|
+
`It appears you are running Harper in a root data directory, but did not specify the path. I'll go ahead and run Harper with its root path set to "." for you since that's probably what you meant. But to avoid this warning in the future, run it like this: "harper ${service} ."`
|
|
123
|
+
);
|
|
124
|
+
process.env.ROOTPATH = process.cwd();
|
|
125
|
+
}
|
|
126
|
+
}
|
|
127
|
+
// fall through
|
|
128
|
+
case undefined: // run harperdb in the foreground in standard mode
|
|
129
|
+
return require('./run.js').main();
|
|
130
|
+
default:
|
|
131
|
+
const cliApiOp = cliOperations.buildRequest();
|
|
132
|
+
logger.trace('calling cli operations with:', cliApiOp);
|
|
133
|
+
await cliOperations.cliOperations(cliApiOp);
|
|
134
|
+
return;
|
|
135
|
+
}
|
|
136
|
+
}
|
|
137
|
+
exports.harper = harper;
|
|
138
|
+
if (require.main === module) {
|
|
139
|
+
harper()
|
|
140
|
+
.then((message) => {
|
|
141
|
+
if (message) {
|
|
142
|
+
console.log(message);
|
|
143
|
+
logger.notify(message);
|
|
144
|
+
}
|
|
145
|
+
// Intentionally not calling `process.exit(0);` so if a CLI
|
|
146
|
+
// command resulted in a long running process (aka `run`),
|
|
147
|
+
// it continues to run.
|
|
148
|
+
})
|
|
149
|
+
.catch((error) => {
|
|
150
|
+
if (error) {
|
|
151
|
+
console.error(error);
|
|
152
|
+
logger.error(error);
|
|
153
|
+
}
|
|
154
|
+
process.exit(1);
|
|
155
|
+
});
|
|
156
|
+
}
|
package/bin/install.js
ADDED
|
@@ -0,0 +1,15 @@
|
|
|
1
|
+
const installer = require('../utility/install/installer.js');
|
|
2
|
+
const hdbLogger = require('../utility/logging/harper_logger.js');
|
|
3
|
+
|
|
4
|
+
module.exports = install;
|
|
5
|
+
|
|
6
|
+
async function install() {
|
|
7
|
+
try {
|
|
8
|
+
await installer.install();
|
|
9
|
+
} catch (err) {
|
|
10
|
+
console.error('There was an error during the install.');
|
|
11
|
+
console.error(err);
|
|
12
|
+
hdbLogger.error(err);
|
|
13
|
+
process.exit(1);
|
|
14
|
+
}
|
|
15
|
+
}
|