mongodb-mcp-server 0.2.0 → 0.3.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/README.md +53 -23
- package/dist/cjs/common/atlas/accessListUtils.d.ts +15 -0
- package/dist/cjs/common/atlas/accessListUtils.d.ts.map +1 -0
- package/dist/cjs/common/atlas/accessListUtils.js +53 -0
- package/dist/cjs/common/atlas/accessListUtils.js.map +1 -0
- package/dist/cjs/common/atlas/apiClient.d.ts +235 -0
- package/dist/cjs/common/atlas/apiClient.d.ts.map +1 -0
- package/dist/cjs/common/atlas/apiClient.js +439 -0
- package/dist/cjs/common/atlas/apiClient.js.map +1 -0
- package/dist/cjs/common/atlas/apiClientError.d.ts +11 -0
- package/dist/cjs/common/atlas/apiClientError.d.ts.map +1 -0
- package/dist/cjs/common/atlas/apiClientError.js +54 -0
- package/dist/cjs/common/atlas/apiClientError.js.map +1 -0
- package/dist/cjs/common/atlas/cluster.d.ts +14 -0
- package/dist/cjs/common/atlas/cluster.d.ts.map +1 -0
- package/dist/cjs/common/atlas/cluster.js +75 -0
- package/dist/cjs/common/atlas/cluster.js.map +1 -0
- package/dist/cjs/common/atlas/roles.d.ts +8 -0
- package/dist/cjs/common/atlas/roles.d.ts.map +1 -0
- package/dist/cjs/common/atlas/roles.js +28 -0
- package/dist/cjs/common/atlas/roles.js.map +1 -0
- package/dist/cjs/common/config.d.ts +37 -0
- package/dist/cjs/common/config.d.ts.map +1 -0
- package/dist/cjs/common/config.js +282 -0
- package/dist/cjs/common/config.js.map +1 -0
- package/dist/cjs/common/connectionManager.d.ts +74 -0
- package/dist/cjs/common/connectionManager.d.ts.map +1 -0
- package/dist/cjs/common/connectionManager.js +225 -0
- package/dist/cjs/common/connectionManager.js.map +1 -0
- package/dist/cjs/common/errors.d.ts +10 -0
- package/dist/cjs/common/errors.d.ts.map +1 -0
- package/dist/cjs/common/errors.js +17 -0
- package/dist/cjs/common/errors.js.map +1 -0
- package/dist/cjs/common/exportsManager.d.ts +86 -0
- package/dist/cjs/common/exportsManager.d.ts.map +1 -0
- package/dist/cjs/common/exportsManager.js +288 -0
- package/dist/cjs/common/exportsManager.js.map +1 -0
- package/dist/cjs/common/logger.d.ts +118 -0
- package/dist/cjs/common/logger.d.ts.map +1 -0
- package/dist/cjs/common/logger.js +267 -0
- package/dist/cjs/common/logger.js.map +1 -0
- package/dist/cjs/common/managedTimeout.d.ts +6 -0
- package/dist/cjs/common/managedTimeout.d.ts.map +1 -0
- package/dist/cjs/common/managedTimeout.js +23 -0
- package/dist/cjs/common/managedTimeout.js.map +1 -0
- package/dist/cjs/common/packageInfo.d.ts +5 -0
- package/dist/cjs/common/packageInfo.d.ts.map +1 -0
- package/dist/cjs/common/packageInfo.js +9 -0
- package/dist/cjs/common/packageInfo.js.map +1 -0
- package/dist/cjs/common/session.d.ts +42 -0
- package/dist/cjs/common/session.d.ts.map +1 -0
- package/dist/cjs/common/session.js +106 -0
- package/dist/cjs/common/session.js.map +1 -0
- package/dist/cjs/common/sessionStore.d.ts +16 -0
- package/dist/cjs/common/sessionStore.d.ts.map +1 -0
- package/dist/cjs/common/sessionStore.js +99 -0
- package/dist/cjs/common/sessionStore.js.map +1 -0
- package/dist/cjs/helpers/connectionOptions.d.ts +25 -0
- package/dist/cjs/helpers/connectionOptions.d.ts.map +1 -0
- package/dist/cjs/helpers/connectionOptions.js +46 -0
- package/dist/cjs/helpers/connectionOptions.js.map +1 -0
- package/dist/cjs/helpers/container.d.ts +2 -0
- package/dist/cjs/helpers/container.d.ts.map +1 -0
- package/dist/cjs/helpers/container.js +34 -0
- package/dist/cjs/helpers/container.js.map +1 -0
- package/dist/cjs/helpers/deviceId.d.ts +24 -0
- package/dist/cjs/helpers/deviceId.d.ts.map +1 -0
- package/dist/cjs/helpers/deviceId.js +106 -0
- package/dist/cjs/helpers/deviceId.js.map +1 -0
- package/dist/cjs/helpers/generatePassword.d.ts +2 -0
- package/dist/cjs/helpers/generatePassword.d.ts.map +1 -0
- package/dist/cjs/helpers/generatePassword.js +12 -0
- package/dist/cjs/helpers/generatePassword.js.map +1 -0
- package/dist/cjs/helpers/indexCheck.d.ts +17 -0
- package/dist/cjs/helpers/indexCheck.d.ts.map +1 -0
- package/dist/cjs/helpers/indexCheck.js +68 -0
- package/dist/cjs/helpers/indexCheck.js.map +1 -0
- package/dist/cjs/index.d.ts +3 -0
- package/dist/cjs/index.d.ts.map +1 -0
- package/dist/cjs/index.js +133 -0
- package/dist/cjs/index.js.map +1 -0
- package/dist/cjs/lib.d.ts +8 -0
- package/dist/cjs/lib.d.ts.map +1 -0
- package/dist/cjs/lib.js +16 -0
- package/dist/cjs/lib.js.map +1 -0
- package/dist/cjs/package.json +1 -0
- package/dist/cjs/resources/common/config.d.ts +10 -0
- package/dist/cjs/resources/common/config.d.ts.map +1 -0
- package/dist/cjs/resources/common/config.js +46 -0
- package/dist/cjs/resources/common/config.js.map +1 -0
- package/dist/cjs/resources/common/debug.d.ts +17 -0
- package/dist/cjs/resources/common/debug.d.ts.map +1 -0
- package/dist/cjs/resources/common/debug.js +67 -0
- package/dist/cjs/resources/common/debug.js.map +1 -0
- package/dist/cjs/resources/common/exportedData.d.ts +15 -0
- package/dist/cjs/resources/common/exportedData.d.ts.map +1 -0
- package/dist/cjs/resources/common/exportedData.js +103 -0
- package/dist/cjs/resources/common/exportedData.js.map +1 -0
- package/dist/cjs/resources/resource.d.ts +44 -0
- package/dist/cjs/resources/resource.d.ts.map +1 -0
- package/dist/cjs/resources/resource.js +56 -0
- package/dist/cjs/resources/resource.js.map +1 -0
- package/dist/cjs/resources/resources.d.ts +5 -0
- package/dist/cjs/resources/resources.d.ts.map +1 -0
- package/dist/cjs/resources/resources.js +8 -0
- package/dist/cjs/resources/resources.js.map +1 -0
- package/dist/cjs/server.d.ts +40 -0
- package/dist/cjs/server.d.ts.map +1 -0
- package/dist/cjs/server.js +192 -0
- package/dist/cjs/server.js.map +1 -0
- package/dist/cjs/telemetry/constants.d.ts +6 -0
- package/dist/cjs/telemetry/constants.d.ts.map +1 -0
- package/dist/cjs/telemetry/constants.js +16 -0
- package/dist/cjs/telemetry/constants.js.map +1 -0
- package/dist/cjs/telemetry/eventCache.d.ts +34 -0
- package/dist/cjs/telemetry/eventCache.d.ts.map +1 -0
- package/dist/cjs/telemetry/eventCache.js +57 -0
- package/dist/cjs/telemetry/eventCache.js.map +1 -0
- package/dist/cjs/telemetry/telemetry.d.ts +50 -0
- package/dist/cjs/telemetry/telemetry.d.ts.map +1 -0
- package/dist/cjs/telemetry/telemetry.js +145 -0
- package/dist/cjs/telemetry/telemetry.js.map +1 -0
- package/dist/cjs/telemetry/types.d.ts +70 -0
- package/dist/cjs/telemetry/types.d.ts.map +1 -0
- package/dist/cjs/telemetry/types.js +3 -0
- package/dist/cjs/telemetry/types.js.map +1 -0
- package/dist/cjs/tools/atlas/atlasTool.d.ts +18 -0
- package/dist/cjs/tools/atlas/atlasTool.d.ts.map +1 -0
- package/dist/cjs/tools/atlas/atlasTool.js +92 -0
- package/dist/cjs/tools/atlas/atlasTool.js.map +1 -0
- package/dist/cjs/tools/atlas/connect/connectCluster.d.ts +18 -0
- package/dist/cjs/tools/atlas/connect/connectCluster.d.ts.map +1 -0
- package/dist/cjs/tools/atlas/connect/connectCluster.js +215 -0
- package/dist/cjs/tools/atlas/connect/connectCluster.js.map +1 -0
- package/dist/cjs/tools/atlas/create/createAccessList.d.ts +18 -0
- package/dist/cjs/tools/atlas/create/createAccessList.d.ts.map +1 -0
- package/dist/cjs/tools/atlas/create/createAccessList.js +66 -0
- package/dist/cjs/tools/atlas/create/createAccessList.js.map +1 -0
- package/dist/cjs/tools/atlas/create/createDBUser.d.ts +30 -0
- package/dist/cjs/tools/atlas/create/createDBUser.d.ts.map +1 -0
- package/dist/cjs/tools/atlas/create/createDBUser.js +80 -0
- package/dist/cjs/tools/atlas/create/createDBUser.js.map +1 -0
- package/dist/cjs/tools/atlas/create/createFreeCluster.d.ts +16 -0
- package/dist/cjs/tools/atlas/create/createFreeCluster.d.ts.map +1 -0
- package/dist/cjs/tools/atlas/create/createFreeCluster.js +59 -0
- package/dist/cjs/tools/atlas/create/createFreeCluster.js.map +1 -0
- package/dist/cjs/tools/atlas/create/createProject.d.ts +15 -0
- package/dist/cjs/tools/atlas/create/createProject.d.ts.map +1 -0
- package/dist/cjs/tools/atlas/create/createProject.js +60 -0
- package/dist/cjs/tools/atlas/create/createProject.js.map +1 -0
- package/dist/cjs/tools/atlas/read/inspectAccessList.d.ts +14 -0
- package/dist/cjs/tools/atlas/read/inspectAccessList.d.ts.map +1 -0
- package/dist/cjs/tools/atlas/read/inspectAccessList.js +43 -0
- package/dist/cjs/tools/atlas/read/inspectAccessList.js.map +1 -0
- package/dist/cjs/tools/atlas/read/inspectCluster.d.ts +16 -0
- package/dist/cjs/tools/atlas/read/inspectCluster.d.ts.map +1 -0
- package/dist/cjs/tools/atlas/read/inspectCluster.js +32 -0
- package/dist/cjs/tools/atlas/read/inspectCluster.js.map +1 -0
- package/dist/cjs/tools/atlas/read/listAlerts.d.ts +14 -0
- package/dist/cjs/tools/atlas/read/listAlerts.d.ts.map +1 -0
- package/dist/cjs/tools/atlas/read/listAlerts.js +46 -0
- package/dist/cjs/tools/atlas/read/listAlerts.js.map +1 -0
- package/dist/cjs/tools/atlas/read/listClusters.d.ts +16 -0
- package/dist/cjs/tools/atlas/read/listClusters.d.ts.map +1 -0
- package/dist/cjs/tools/atlas/read/listClusters.js +96 -0
- package/dist/cjs/tools/atlas/read/listClusters.js.map +1 -0
- package/dist/cjs/tools/atlas/read/listDBUsers.d.ts +14 -0
- package/dist/cjs/tools/atlas/read/listDBUsers.d.ts.map +1 -0
- package/dist/cjs/tools/atlas/read/listDBUsers.js +58 -0
- package/dist/cjs/tools/atlas/read/listDBUsers.js.map +1 -0
- package/dist/cjs/tools/atlas/read/listOrgs.d.ts +11 -0
- package/dist/cjs/tools/atlas/read/listOrgs.d.ts.map +1 -0
- package/dist/cjs/tools/atlas/read/listOrgs.js +36 -0
- package/dist/cjs/tools/atlas/read/listOrgs.js.map +1 -0
- package/dist/cjs/tools/atlas/read/listProjects.d.ts +15 -0
- package/dist/cjs/tools/atlas/read/listProjects.d.ts.map +1 -0
- package/dist/cjs/tools/atlas/read/listProjects.js +59 -0
- package/dist/cjs/tools/atlas/read/listProjects.js.map +1 -0
- package/dist/cjs/tools/atlas/tools.d.ts +14 -0
- package/dist/cjs/tools/atlas/tools.d.ts.map +1 -0
- package/dist/cjs/tools/atlas/tools.js +30 -0
- package/dist/cjs/tools/atlas/tools.js.map +1 -0
- package/dist/cjs/tools/mongodb/connect/connect.d.ts +26 -0
- package/dist/cjs/tools/mongodb/connect/connect.d.ts.map +1 -0
- package/dist/cjs/tools/mongodb/connect/connect.js +86 -0
- package/dist/cjs/tools/mongodb/connect/connect.js.map +1 -0
- package/dist/cjs/tools/mongodb/create/createCollection.d.ts +14 -0
- package/dist/cjs/tools/mongodb/create/createCollection.d.ts.map +1 -0
- package/dist/cjs/tools/mongodb/create/createCollection.js +27 -0
- package/dist/cjs/tools/mongodb/create/createCollection.js.map +1 -0
- package/dist/cjs/tools/mongodb/create/createIndex.d.ts +18 -0
- package/dist/cjs/tools/mongodb/create/createIndex.d.ts.map +1 -0
- package/dist/cjs/tools/mongodb/create/createIndex.js +37 -0
- package/dist/cjs/tools/mongodb/create/createIndex.js.map +1 -0
- package/dist/cjs/tools/mongodb/create/insertMany.d.ts +16 -0
- package/dist/cjs/tools/mongodb/create/insertMany.d.ts.map +1 -0
- package/dist/cjs/tools/mongodb/create/insertMany.js +37 -0
- package/dist/cjs/tools/mongodb/create/insertMany.js.map +1 -0
- package/dist/cjs/tools/mongodb/delete/deleteMany.d.ts +16 -0
- package/dist/cjs/tools/mongodb/delete/deleteMany.d.ts.map +1 -0
- package/dist/cjs/tools/mongodb/delete/deleteMany.js +53 -0
- package/dist/cjs/tools/mongodb/delete/deleteMany.js.map +1 -0
- package/dist/cjs/tools/mongodb/delete/dropCollection.d.ts +14 -0
- package/dist/cjs/tools/mongodb/delete/dropCollection.d.ts.map +1 -0
- package/dist/cjs/tools/mongodb/delete/dropCollection.js +29 -0
- package/dist/cjs/tools/mongodb/delete/dropCollection.js.map +1 -0
- package/dist/cjs/tools/mongodb/delete/dropDatabase.d.ts +13 -0
- package/dist/cjs/tools/mongodb/delete/dropDatabase.d.ts.map +1 -0
- package/dist/cjs/tools/mongodb/delete/dropDatabase.js +29 -0
- package/dist/cjs/tools/mongodb/delete/dropDatabase.js.map +1 -0
- package/dist/cjs/tools/mongodb/metadata/collectionSchema.d.ts +14 -0
- package/dist/cjs/tools/mongodb/metadata/collectionSchema.d.ts.map +1 -0
- package/dist/cjs/tools/mongodb/metadata/collectionSchema.js +36 -0
- package/dist/cjs/tools/mongodb/metadata/collectionSchema.js.map +1 -0
- package/dist/cjs/tools/mongodb/metadata/collectionStorageSize.d.ts +16 -0
- package/dist/cjs/tools/mongodb/metadata/collectionStorageSize.d.ts.map +1 -0
- package/dist/cjs/tools/mongodb/metadata/collectionStorageSize.js +61 -0
- package/dist/cjs/tools/mongodb/metadata/collectionStorageSize.js.map +1 -0
- package/dist/cjs/tools/mongodb/metadata/dbStats.d.ts +13 -0
- package/dist/cjs/tools/mongodb/metadata/dbStats.d.ts.map +1 -0
- package/dist/cjs/tools/mongodb/metadata/dbStats.js +29 -0
- package/dist/cjs/tools/mongodb/metadata/dbStats.js.map +1 -0
- package/dist/cjs/tools/mongodb/metadata/explain.d.ts +89 -0
- package/dist/cjs/tools/mongodb/metadata/explain.d.ts.map +1 -0
- package/dist/cjs/tools/mongodb/metadata/explain.js +80 -0
- package/dist/cjs/tools/mongodb/metadata/explain.js.map +1 -0
- package/dist/cjs/tools/mongodb/metadata/listCollections.d.ts +13 -0
- package/dist/cjs/tools/mongodb/metadata/listCollections.d.ts.map +1 -0
- package/dist/cjs/tools/mongodb/metadata/listCollections.js +35 -0
- package/dist/cjs/tools/mongodb/metadata/listCollections.js.map +1 -0
- package/dist/cjs/tools/mongodb/metadata/listDatabases.d.ts +11 -0
- package/dist/cjs/tools/mongodb/metadata/listDatabases.d.ts.map +1 -0
- package/dist/cjs/tools/mongodb/metadata/listDatabases.js +25 -0
- package/dist/cjs/tools/mongodb/metadata/listDatabases.js.map +1 -0
- package/dist/cjs/tools/mongodb/metadata/logs.d.ts +15 -0
- package/dist/cjs/tools/mongodb/metadata/logs.d.ts.map +1 -0
- package/dist/cjs/tools/mongodb/metadata/logs.js +49 -0
- package/dist/cjs/tools/mongodb/metadata/logs.js.map +1 -0
- package/dist/cjs/tools/mongodb/mongodbTool.d.ts +20 -0
- package/dist/cjs/tools/mongodb/mongodbTool.d.ts.map +1 -0
- package/dist/cjs/tools/mongodb/mongodbTool.js +130 -0
- package/dist/cjs/tools/mongodb/mongodbTool.js.map +1 -0
- package/dist/cjs/tools/mongodb/read/aggregate.d.ts +19 -0
- package/dist/cjs/tools/mongodb/read/aggregate.d.ts.map +1 -0
- package/dist/cjs/tools/mongodb/read/aggregate.js +40 -0
- package/dist/cjs/tools/mongodb/read/aggregate.js.map +1 -0
- package/dist/cjs/tools/mongodb/read/collectionIndexes.d.ts +15 -0
- package/dist/cjs/tools/mongodb/read/collectionIndexes.d.ts.map +1 -0
- package/dist/cjs/tools/mongodb/read/collectionIndexes.js +40 -0
- package/dist/cjs/tools/mongodb/read/collectionIndexes.js.map +1 -0
- package/dist/cjs/tools/mongodb/read/count.d.ts +19 -0
- package/dist/cjs/tools/mongodb/read/count.d.ts.map +1 -0
- package/dist/cjs/tools/mongodb/read/count.js +51 -0
- package/dist/cjs/tools/mongodb/read/count.js.map +1 -0
- package/dist/cjs/tools/mongodb/read/export.d.ts +72 -0
- package/dist/cjs/tools/mongodb/read/export.d.ts.map +1 -0
- package/dist/cjs/tools/mongodb/read/export.js +119 -0
- package/dist/cjs/tools/mongodb/read/export.js.map +1 -0
- package/dist/cjs/tools/mongodb/read/find.d.ts +26 -0
- package/dist/cjs/tools/mongodb/read/find.d.ts.map +1 -0
- package/dist/cjs/tools/mongodb/read/find.js +53 -0
- package/dist/cjs/tools/mongodb/read/find.js.map +1 -0
- package/dist/cjs/tools/mongodb/tools.d.ts +23 -0
- package/dist/cjs/tools/mongodb/tools.d.ts.map +1 -0
- package/dist/cjs/tools/mongodb/tools.js +48 -0
- package/dist/cjs/tools/mongodb/tools.js.map +1 -0
- package/dist/cjs/tools/mongodb/update/renameCollection.d.ts +18 -0
- package/dist/cjs/tools/mongodb/update/renameCollection.d.ts.map +1 -0
- package/dist/cjs/tools/mongodb/update/renameCollection.js +59 -0
- package/dist/cjs/tools/mongodb/update/renameCollection.js.map +1 -0
- package/dist/cjs/tools/mongodb/update/updateMany.d.ts +18 -0
- package/dist/cjs/tools/mongodb/update/updateMany.d.ts.map +1 -0
- package/dist/cjs/tools/mongodb/update/updateMany.js +78 -0
- package/dist/cjs/tools/mongodb/update/updateMany.js.map +1 -0
- package/dist/cjs/tools/tool.d.ts +49 -0
- package/dist/cjs/tools/tool.d.ts.map +1 -0
- package/dist/cjs/tools/tool.js +201 -0
- package/dist/cjs/tools/tool.js.map +1 -0
- package/dist/cjs/transports/base.d.ts +16 -0
- package/dist/cjs/transports/base.d.ts.map +1 -0
- package/dist/cjs/transports/base.js +71 -0
- package/dist/cjs/transports/base.js.map +1 -0
- package/dist/cjs/transports/stdio.d.ts +19 -0
- package/dist/cjs/transports/stdio.d.ts.map +1 -0
- package/dist/cjs/transports/stdio.js +69 -0
- package/dist/cjs/transports/stdio.js.map +1 -0
- package/dist/cjs/transports/streamableHttp.d.ts +13 -0
- package/dist/cjs/transports/streamableHttp.d.ts.map +1 -0
- package/dist/cjs/transports/streamableHttp.js +220 -0
- package/dist/cjs/transports/streamableHttp.js.map +1 -0
- package/dist/esm/common/atlas/accessListUtils.d.ts +15 -0
- package/dist/esm/common/atlas/accessListUtils.d.ts.map +1 -0
- package/dist/esm/common/atlas/accessListUtils.js +48 -0
- package/dist/esm/common/atlas/accessListUtils.js.map +1 -0
- package/dist/esm/common/atlas/apiClient.d.ts +235 -0
- package/dist/esm/common/atlas/apiClient.d.ts.map +1 -0
- package/dist/esm/common/atlas/apiClient.js +399 -0
- package/dist/esm/common/atlas/apiClient.js.map +1 -0
- package/dist/esm/common/atlas/apiClientError.d.ts +11 -0
- package/dist/esm/common/atlas/apiClientError.d.ts.map +1 -0
- package/dist/esm/common/atlas/apiClientError.js.map +1 -0
- package/dist/esm/common/atlas/cluster.d.ts +14 -0
- package/dist/esm/common/atlas/cluster.d.ts.map +1 -0
- package/dist/esm/common/atlas/cluster.js +70 -0
- package/dist/esm/common/atlas/cluster.js.map +1 -0
- package/dist/esm/common/atlas/roles.d.ts +8 -0
- package/dist/esm/common/atlas/roles.d.ts.map +1 -0
- package/dist/esm/common/atlas/roles.js +25 -0
- package/dist/esm/common/atlas/roles.js.map +1 -0
- package/dist/esm/common/config.d.ts +37 -0
- package/dist/esm/common/config.d.ts.map +1 -0
- package/dist/esm/common/config.js +274 -0
- package/dist/esm/common/config.js.map +1 -0
- package/dist/esm/common/connectionManager.d.ts +74 -0
- package/dist/esm/common/connectionManager.d.ts.map +1 -0
- package/dist/esm/common/connectionManager.js +218 -0
- package/dist/esm/common/connectionManager.js.map +1 -0
- package/dist/esm/common/errors.d.ts +10 -0
- package/dist/esm/common/errors.d.ts.map +1 -0
- package/dist/esm/common/errors.js.map +1 -0
- package/dist/esm/common/exportsManager.d.ts +86 -0
- package/dist/esm/common/exportsManager.d.ts.map +1 -0
- package/dist/esm/common/exportsManager.js +278 -0
- package/dist/esm/common/exportsManager.js.map +1 -0
- package/dist/esm/common/logger.d.ts +118 -0
- package/dist/esm/common/logger.d.ts.map +1 -0
- package/dist/esm/common/logger.js +255 -0
- package/dist/esm/common/logger.js.map +1 -0
- package/dist/esm/common/managedTimeout.d.ts +6 -0
- package/dist/esm/common/managedTimeout.d.ts.map +1 -0
- package/dist/esm/common/managedTimeout.js.map +1 -0
- package/dist/esm/common/packageInfo.d.ts +5 -0
- package/dist/esm/common/packageInfo.d.ts.map +1 -0
- package/dist/esm/common/packageInfo.js +6 -0
- package/dist/esm/common/packageInfo.js.map +1 -0
- package/dist/esm/common/session.d.ts +42 -0
- package/dist/esm/common/session.d.ts.map +1 -0
- package/dist/esm/common/session.js +99 -0
- package/dist/esm/common/session.js.map +1 -0
- package/dist/esm/common/sessionStore.d.ts +16 -0
- package/dist/esm/common/sessionStore.d.ts.map +1 -0
- package/dist/esm/common/sessionStore.js +95 -0
- package/dist/esm/common/sessionStore.js.map +1 -0
- package/dist/esm/helpers/connectionOptions.d.ts +25 -0
- package/dist/esm/helpers/connectionOptions.d.ts.map +1 -0
- package/dist/esm/helpers/connectionOptions.js +39 -0
- package/dist/esm/helpers/connectionOptions.js.map +1 -0
- package/dist/esm/helpers/container.d.ts +2 -0
- package/dist/esm/helpers/container.d.ts.map +1 -0
- package/dist/esm/helpers/container.js.map +1 -0
- package/dist/esm/helpers/deviceId.d.ts +24 -0
- package/dist/esm/helpers/deviceId.d.ts.map +1 -0
- package/dist/esm/helpers/deviceId.js +69 -0
- package/dist/esm/helpers/deviceId.js.map +1 -0
- package/dist/esm/helpers/generatePassword.d.ts +2 -0
- package/dist/esm/helpers/generatePassword.d.ts.map +1 -0
- package/dist/esm/helpers/generatePassword.js.map +1 -0
- package/dist/esm/helpers/indexCheck.d.ts +17 -0
- package/dist/esm/helpers/indexCheck.d.ts.map +1 -0
- package/dist/esm/helpers/indexCheck.js.map +1 -0
- package/dist/esm/index.d.ts +3 -0
- package/dist/esm/index.d.ts.map +1 -0
- package/dist/esm/index.js +128 -0
- package/dist/esm/index.js.map +1 -0
- package/dist/esm/lib.d.ts +8 -0
- package/dist/esm/lib.d.ts.map +1 -0
- package/dist/esm/lib.js +7 -0
- package/dist/esm/lib.js.map +1 -0
- package/dist/esm/package.json +1 -0
- package/dist/esm/resources/common/config.d.ts +10 -0
- package/dist/esm/resources/common/config.d.ts.map +1 -0
- package/dist/esm/resources/common/config.js +42 -0
- package/dist/esm/resources/common/config.js.map +1 -0
- package/dist/esm/resources/common/debug.d.ts +17 -0
- package/dist/esm/resources/common/debug.d.ts.map +1 -0
- package/dist/esm/resources/common/debug.js +63 -0
- package/dist/esm/resources/common/debug.js.map +1 -0
- package/dist/esm/resources/common/exportedData.d.ts +15 -0
- package/dist/esm/resources/common/exportedData.d.ts.map +1 -0
- package/dist/esm/resources/common/exportedData.js +99 -0
- package/dist/esm/resources/common/exportedData.js.map +1 -0
- package/dist/esm/resources/resource.d.ts +44 -0
- package/dist/esm/resources/resource.d.ts.map +1 -0
- package/dist/esm/resources/resource.js +52 -0
- package/dist/esm/resources/resource.js.map +1 -0
- package/dist/esm/resources/resources.d.ts +5 -0
- package/dist/esm/resources/resources.d.ts.map +1 -0
- package/dist/esm/resources/resources.js +5 -0
- package/dist/esm/resources/resources.js.map +1 -0
- package/dist/esm/server.d.ts +40 -0
- package/dist/esm/server.d.ts.map +1 -0
- package/dist/esm/server.js +185 -0
- package/dist/esm/server.js.map +1 -0
- package/dist/esm/telemetry/constants.d.ts +6 -0
- package/dist/esm/telemetry/constants.d.ts.map +1 -0
- package/dist/esm/telemetry/constants.js.map +1 -0
- package/dist/esm/telemetry/eventCache.d.ts +34 -0
- package/dist/esm/telemetry/eventCache.d.ts.map +1 -0
- package/dist/esm/telemetry/eventCache.js.map +1 -0
- package/dist/esm/telemetry/telemetry.d.ts +50 -0
- package/dist/esm/telemetry/telemetry.d.ts.map +1 -0
- package/dist/esm/telemetry/telemetry.js +141 -0
- package/dist/esm/telemetry/telemetry.js.map +1 -0
- package/dist/esm/telemetry/types.d.ts +70 -0
- package/dist/esm/telemetry/types.d.ts.map +1 -0
- package/dist/esm/telemetry/types.js.map +1 -0
- package/dist/esm/tools/atlas/atlasTool.d.ts +18 -0
- package/dist/esm/tools/atlas/atlasTool.d.ts.map +1 -0
- package/dist/esm/tools/atlas/atlasTool.js +88 -0
- package/dist/esm/tools/atlas/atlasTool.js.map +1 -0
- package/dist/esm/tools/atlas/connect/connectCluster.d.ts +18 -0
- package/dist/esm/tools/atlas/connect/connectCluster.d.ts.map +1 -0
- package/dist/esm/tools/atlas/connect/connectCluster.js +211 -0
- package/dist/esm/tools/atlas/connect/connectCluster.js.map +1 -0
- package/dist/esm/tools/atlas/create/createAccessList.d.ts +18 -0
- package/dist/esm/tools/atlas/create/createAccessList.d.ts.map +1 -0
- package/dist/esm/tools/atlas/create/createAccessList.js.map +1 -0
- package/dist/esm/tools/atlas/create/createDBUser.d.ts +30 -0
- package/dist/esm/tools/atlas/create/createDBUser.d.ts.map +1 -0
- package/dist/esm/tools/atlas/create/createDBUser.js +76 -0
- package/dist/esm/tools/atlas/create/createDBUser.js.map +1 -0
- package/dist/esm/tools/atlas/create/createFreeCluster.d.ts +16 -0
- package/dist/esm/tools/atlas/create/createFreeCluster.d.ts.map +1 -0
- package/dist/esm/tools/atlas/create/createFreeCluster.js.map +1 -0
- package/dist/esm/tools/atlas/create/createProject.d.ts +15 -0
- package/dist/esm/tools/atlas/create/createProject.d.ts.map +1 -0
- package/dist/esm/tools/atlas/create/createProject.js.map +1 -0
- package/dist/esm/tools/atlas/read/inspectAccessList.d.ts +14 -0
- package/dist/esm/tools/atlas/read/inspectAccessList.d.ts.map +1 -0
- package/dist/esm/tools/atlas/read/inspectAccessList.js +39 -0
- package/dist/esm/tools/atlas/read/inspectAccessList.js.map +1 -0
- package/dist/esm/tools/atlas/read/inspectCluster.d.ts +16 -0
- package/dist/esm/tools/atlas/read/inspectCluster.d.ts.map +1 -0
- package/dist/esm/tools/atlas/read/inspectCluster.js +28 -0
- package/dist/esm/tools/atlas/read/inspectCluster.js.map +1 -0
- package/dist/esm/tools/atlas/read/listAlerts.d.ts +14 -0
- package/dist/esm/tools/atlas/read/listAlerts.d.ts.map +1 -0
- package/dist/esm/tools/atlas/read/listAlerts.js +42 -0
- package/dist/esm/tools/atlas/read/listAlerts.js.map +1 -0
- package/dist/esm/tools/atlas/read/listClusters.d.ts +16 -0
- package/dist/esm/tools/atlas/read/listClusters.d.ts.map +1 -0
- package/dist/esm/tools/atlas/read/listClusters.js +92 -0
- package/dist/esm/tools/atlas/read/listClusters.js.map +1 -0
- package/dist/esm/tools/atlas/read/listDBUsers.d.ts +14 -0
- package/dist/esm/tools/atlas/read/listDBUsers.d.ts.map +1 -0
- package/dist/esm/tools/atlas/read/listDBUsers.js +54 -0
- package/dist/esm/tools/atlas/read/listDBUsers.js.map +1 -0
- package/dist/esm/tools/atlas/read/listOrgs.d.ts +11 -0
- package/dist/esm/tools/atlas/read/listOrgs.d.ts.map +1 -0
- package/dist/esm/tools/atlas/read/listOrgs.js +32 -0
- package/dist/esm/tools/atlas/read/listOrgs.js.map +1 -0
- package/dist/esm/tools/atlas/read/listProjects.d.ts +15 -0
- package/dist/esm/tools/atlas/read/listProjects.d.ts.map +1 -0
- package/dist/esm/tools/atlas/read/listProjects.js +55 -0
- package/dist/esm/tools/atlas/read/listProjects.js.map +1 -0
- package/dist/esm/tools/atlas/tools.d.ts +14 -0
- package/dist/esm/tools/atlas/tools.d.ts.map +1 -0
- package/dist/esm/tools/atlas/tools.js.map +1 -0
- package/dist/esm/tools/mongodb/connect/connect.d.ts +26 -0
- package/dist/esm/tools/mongodb/connect/connect.d.ts.map +1 -0
- package/dist/esm/tools/mongodb/connect/connect.js +79 -0
- package/dist/esm/tools/mongodb/connect/connect.js.map +1 -0
- package/dist/esm/tools/mongodb/create/createCollection.d.ts +14 -0
- package/dist/esm/tools/mongodb/create/createCollection.d.ts.map +1 -0
- package/dist/esm/tools/mongodb/create/createCollection.js.map +1 -0
- package/dist/esm/tools/mongodb/create/createIndex.d.ts +18 -0
- package/dist/esm/tools/mongodb/create/createIndex.d.ts.map +1 -0
- package/dist/esm/tools/mongodb/create/createIndex.js.map +1 -0
- package/dist/esm/tools/mongodb/create/insertMany.d.ts +16 -0
- package/dist/esm/tools/mongodb/create/insertMany.d.ts.map +1 -0
- package/dist/esm/tools/mongodb/create/insertMany.js.map +1 -0
- package/dist/esm/tools/mongodb/delete/deleteMany.d.ts +16 -0
- package/dist/esm/tools/mongodb/delete/deleteMany.d.ts.map +1 -0
- package/dist/esm/tools/mongodb/delete/deleteMany.js.map +1 -0
- package/dist/esm/tools/mongodb/delete/dropCollection.d.ts +14 -0
- package/dist/esm/tools/mongodb/delete/dropCollection.d.ts.map +1 -0
- package/dist/esm/tools/mongodb/delete/dropCollection.js.map +1 -0
- package/dist/esm/tools/mongodb/delete/dropDatabase.d.ts +13 -0
- package/dist/esm/tools/mongodb/delete/dropDatabase.d.ts.map +1 -0
- package/dist/esm/tools/mongodb/delete/dropDatabase.js.map +1 -0
- package/dist/esm/tools/mongodb/metadata/collectionSchema.d.ts +14 -0
- package/dist/esm/tools/mongodb/metadata/collectionSchema.d.ts.map +1 -0
- package/dist/esm/tools/mongodb/metadata/collectionSchema.js +32 -0
- package/dist/esm/tools/mongodb/metadata/collectionSchema.js.map +1 -0
- package/dist/esm/tools/mongodb/metadata/collectionStorageSize.d.ts +16 -0
- package/dist/esm/tools/mongodb/metadata/collectionStorageSize.d.ts.map +1 -0
- package/dist/esm/tools/mongodb/metadata/collectionStorageSize.js.map +1 -0
- package/dist/esm/tools/mongodb/metadata/dbStats.d.ts +13 -0
- package/dist/esm/tools/mongodb/metadata/dbStats.d.ts.map +1 -0
- package/dist/esm/tools/mongodb/metadata/dbStats.js +25 -0
- package/dist/esm/tools/mongodb/metadata/dbStats.js.map +1 -0
- package/dist/esm/tools/mongodb/metadata/explain.d.ts +89 -0
- package/dist/esm/tools/mongodb/metadata/explain.d.ts.map +1 -0
- package/dist/esm/tools/mongodb/metadata/explain.js +76 -0
- package/dist/esm/tools/mongodb/metadata/explain.js.map +1 -0
- package/dist/esm/tools/mongodb/metadata/listCollections.d.ts +13 -0
- package/dist/esm/tools/mongodb/metadata/listCollections.d.ts.map +1 -0
- package/dist/esm/tools/mongodb/metadata/listCollections.js +31 -0
- package/dist/esm/tools/mongodb/metadata/listCollections.js.map +1 -0
- package/dist/esm/tools/mongodb/metadata/listDatabases.d.ts +11 -0
- package/dist/esm/tools/mongodb/metadata/listDatabases.d.ts.map +1 -0
- package/dist/esm/tools/mongodb/metadata/listDatabases.js +21 -0
- package/dist/esm/tools/mongodb/metadata/listDatabases.js.map +1 -0
- package/dist/esm/tools/mongodb/metadata/logs.d.ts +15 -0
- package/dist/esm/tools/mongodb/metadata/logs.d.ts.map +1 -0
- package/dist/esm/tools/mongodb/metadata/logs.js.map +1 -0
- package/dist/esm/tools/mongodb/mongodbTool.d.ts +20 -0
- package/dist/esm/tools/mongodb/mongodbTool.d.ts.map +1 -0
- package/dist/esm/tools/mongodb/mongodbTool.js +126 -0
- package/dist/esm/tools/mongodb/mongodbTool.js.map +1 -0
- package/dist/esm/tools/mongodb/read/aggregate.d.ts +19 -0
- package/dist/esm/tools/mongodb/read/aggregate.d.ts.map +1 -0
- package/dist/esm/tools/mongodb/read/aggregate.js +36 -0
- package/dist/esm/tools/mongodb/read/aggregate.js.map +1 -0
- package/dist/esm/tools/mongodb/read/collectionIndexes.d.ts +15 -0
- package/dist/esm/tools/mongodb/read/collectionIndexes.d.ts.map +1 -0
- package/dist/esm/tools/mongodb/read/collectionIndexes.js +36 -0
- package/dist/esm/tools/mongodb/read/collectionIndexes.js.map +1 -0
- package/dist/esm/tools/mongodb/read/count.d.ts +19 -0
- package/dist/esm/tools/mongodb/read/count.d.ts.map +1 -0
- package/dist/esm/tools/mongodb/read/count.js.map +1 -0
- package/dist/esm/tools/mongodb/read/export.d.ts +72 -0
- package/dist/esm/tools/mongodb/read/export.d.ts.map +1 -0
- package/dist/esm/tools/mongodb/read/export.js +112 -0
- package/dist/esm/tools/mongodb/read/export.js.map +1 -0
- package/dist/esm/tools/mongodb/read/find.d.ts +26 -0
- package/dist/esm/tools/mongodb/read/find.d.ts.map +1 -0
- package/dist/esm/tools/mongodb/read/find.js +49 -0
- package/dist/esm/tools/mongodb/read/find.js.map +1 -0
- package/dist/esm/tools/mongodb/tools.d.ts +23 -0
- package/dist/esm/tools/mongodb/tools.d.ts.map +1 -0
- package/dist/esm/tools/mongodb/tools.js +45 -0
- package/dist/esm/tools/mongodb/tools.js.map +1 -0
- package/dist/esm/tools/mongodb/update/renameCollection.d.ts +18 -0
- package/dist/esm/tools/mongodb/update/renameCollection.d.ts.map +1 -0
- package/dist/esm/tools/mongodb/update/renameCollection.js.map +1 -0
- package/dist/esm/tools/mongodb/update/updateMany.d.ts +18 -0
- package/dist/esm/tools/mongodb/update/updateMany.d.ts.map +1 -0
- package/dist/esm/tools/mongodb/update/updateMany.js.map +1 -0
- package/dist/esm/tools/tool.d.ts +49 -0
- package/dist/esm/tools/tool.d.ts.map +1 -0
- package/dist/esm/tools/tool.js +196 -0
- package/dist/esm/tools/tool.js.map +1 -0
- package/dist/esm/transports/base.d.ts +16 -0
- package/dist/esm/transports/base.d.ts.map +1 -0
- package/dist/esm/transports/base.js +67 -0
- package/dist/esm/transports/base.js.map +1 -0
- package/dist/esm/transports/stdio.d.ts +19 -0
- package/dist/esm/transports/stdio.d.ts.map +1 -0
- package/dist/esm/transports/stdio.js +63 -0
- package/dist/esm/transports/stdio.js.map +1 -0
- package/dist/esm/transports/streamableHttp.d.ts +13 -0
- package/dist/esm/transports/streamableHttp.d.ts.map +1 -0
- package/dist/esm/transports/streamableHttp.js +213 -0
- package/dist/esm/transports/streamableHttp.js.map +1 -0
- package/dist/index.js +1 -44
- package/package.json +47 -14
- package/.dockerignore +0 -11
- package/.github/CODEOWNERS +0 -1
- package/.github/ISSUE_TEMPLATE/bug_report.yml +0 -48
- package/.github/dependabot.yml +0 -10
- package/.github/pull_request_template.md +0 -5
- package/.github/workflows/accuracy-tests.yml +0 -55
- package/.github/workflows/check-pr-title.yml +0 -29
- package/.github/workflows/check.yml +0 -58
- package/.github/workflows/code_health.yaml +0 -94
- package/.github/workflows/code_health_fork.yaml +0 -36
- package/.github/workflows/codeql.yml +0 -34
- package/.github/workflows/dependabot_pr.yaml +0 -26
- package/.github/workflows/docker.yaml +0 -57
- package/.github/workflows/jira-issue.yml +0 -72
- package/.github/workflows/prepare_release.yaml +0 -53
- package/.github/workflows/publish.yaml +0 -73
- package/.github/workflows/stale.yml +0 -32
- package/.prettierignore +0 -5
- package/.prettierrc.json +0 -37
- package/.smithery/Dockerfile +0 -30
- package/.smithery/smithery.yaml +0 -73
- package/.vscode/extensions.json +0 -9
- package/.vscode/launch.json +0 -27
- package/.vscode/settings.json +0 -1
- package/CONTRIBUTING.md +0 -185
- package/Dockerfile +0 -11
- package/dist/common/atlas/accessListUtils.js +0 -36
- package/dist/common/atlas/accessListUtils.js.map +0 -1
- package/dist/common/atlas/apiClient.js +0 -306
- package/dist/common/atlas/apiClient.js.map +0 -1
- package/dist/common/atlas/apiClientError.js.map +0 -1
- package/dist/common/atlas/cluster.js +0 -66
- package/dist/common/atlas/cluster.js.map +0 -1
- package/dist/common/config.js +0 -89
- package/dist/common/config.js.map +0 -1
- package/dist/common/errors.js.map +0 -1
- package/dist/common/logger.js +0 -152
- package/dist/common/logger.js.map +0 -1
- package/dist/common/managedTimeout.js.map +0 -1
- package/dist/common/packageInfo.js +0 -6
- package/dist/common/packageInfo.js.map +0 -1
- package/dist/common/session.js +0 -83
- package/dist/common/session.js.map +0 -1
- package/dist/common/sessionStore.js +0 -73
- package/dist/common/sessionStore.js.map +0 -1
- package/dist/helpers/connectionOptions.js +0 -10
- package/dist/helpers/connectionOptions.js.map +0 -1
- package/dist/helpers/container.js.map +0 -1
- package/dist/helpers/generatePassword.js.map +0 -1
- package/dist/helpers/indexCheck.js.map +0 -1
- package/dist/index.js.map +0 -1
- package/dist/server.js +0 -179
- package/dist/server.js.map +0 -1
- package/dist/telemetry/constants.js.map +0 -1
- package/dist/telemetry/eventCache.js.map +0 -1
- package/dist/telemetry/telemetry.js +0 -143
- package/dist/telemetry/telemetry.js.map +0 -1
- package/dist/telemetry/types.js.map +0 -1
- package/dist/tools/atlas/atlasTool.js +0 -84
- package/dist/tools/atlas/atlasTool.js.map +0 -1
- package/dist/tools/atlas/connect/connectCluster.js +0 -198
- package/dist/tools/atlas/connect/connectCluster.js.map +0 -1
- package/dist/tools/atlas/create/createAccessList.js.map +0 -1
- package/dist/tools/atlas/create/createDBUser.js +0 -76
- package/dist/tools/atlas/create/createDBUser.js.map +0 -1
- package/dist/tools/atlas/create/createFreeCluster.js.map +0 -1
- package/dist/tools/atlas/create/createProject.js.map +0 -1
- package/dist/tools/atlas/read/inspectAccessList.js +0 -40
- package/dist/tools/atlas/read/inspectAccessList.js.map +0 -1
- package/dist/tools/atlas/read/inspectCluster.js +0 -32
- package/dist/tools/atlas/read/inspectCluster.js.map +0 -1
- package/dist/tools/atlas/read/listAlerts.js +0 -41
- package/dist/tools/atlas/read/listAlerts.js.map +0 -1
- package/dist/tools/atlas/read/listClusters.js +0 -98
- package/dist/tools/atlas/read/listClusters.js.map +0 -1
- package/dist/tools/atlas/read/listDBUsers.js +0 -51
- package/dist/tools/atlas/read/listDBUsers.js.map +0 -1
- package/dist/tools/atlas/read/listOrgs.js +0 -29
- package/dist/tools/atlas/read/listOrgs.js.map +0 -1
- package/dist/tools/atlas/read/listProjects.js +0 -50
- package/dist/tools/atlas/read/listProjects.js.map +0 -1
- package/dist/tools/atlas/tools.js.map +0 -1
- package/dist/tools/mongodb/connect/connect.js +0 -76
- package/dist/tools/mongodb/connect/connect.js.map +0 -1
- package/dist/tools/mongodb/create/createCollection.js.map +0 -1
- package/dist/tools/mongodb/create/createIndex.js.map +0 -1
- package/dist/tools/mongodb/create/insertMany.js.map +0 -1
- package/dist/tools/mongodb/delete/deleteMany.js.map +0 -1
- package/dist/tools/mongodb/delete/dropCollection.js.map +0 -1
- package/dist/tools/mongodb/delete/dropDatabase.js.map +0 -1
- package/dist/tools/mongodb/metadata/collectionSchema.js +0 -40
- package/dist/tools/mongodb/metadata/collectionSchema.js.map +0 -1
- package/dist/tools/mongodb/metadata/collectionStorageSize.js.map +0 -1
- package/dist/tools/mongodb/metadata/dbStats.js +0 -33
- package/dist/tools/mongodb/metadata/dbStats.js.map +0 -1
- package/dist/tools/mongodb/metadata/explain.js +0 -84
- package/dist/tools/mongodb/metadata/explain.js.map +0 -1
- package/dist/tools/mongodb/metadata/listCollections.js +0 -35
- package/dist/tools/mongodb/metadata/listCollections.js.map +0 -1
- package/dist/tools/mongodb/metadata/listDatabases.js +0 -23
- package/dist/tools/mongodb/metadata/listDatabases.js.map +0 -1
- package/dist/tools/mongodb/metadata/logs.js.map +0 -1
- package/dist/tools/mongodb/mongodbTool.js +0 -111
- package/dist/tools/mongodb/mongodbTool.js.map +0 -1
- package/dist/tools/mongodb/read/aggregate.js +0 -47
- package/dist/tools/mongodb/read/aggregate.js.map +0 -1
- package/dist/tools/mongodb/read/collectionIndexes.js +0 -42
- package/dist/tools/mongodb/read/collectionIndexes.js.map +0 -1
- package/dist/tools/mongodb/read/count.js.map +0 -1
- package/dist/tools/mongodb/read/find.js +0 -60
- package/dist/tools/mongodb/read/find.js.map +0 -1
- package/dist/tools/mongodb/tools.js +0 -43
- package/dist/tools/mongodb/tools.js.map +0 -1
- package/dist/tools/mongodb/update/renameCollection.js.map +0 -1
- package/dist/tools/mongodb/update/updateMany.js.map +0 -1
- package/dist/tools/tool.js +0 -153
- package/dist/tools/tool.js.map +0 -1
- package/dist/transports/base.js +0 -26
- package/dist/transports/base.js.map +0 -1
- package/dist/transports/stdio.js +0 -60
- package/dist/transports/stdio.js.map +0 -1
- package/dist/transports/streamableHttp.js +0 -140
- package/dist/transports/streamableHttp.js.map +0 -1
- package/eslint.config.js +0 -64
- package/resources/test-summary-template.html +0 -415
- package/scripts/accuracy/generateTestSummary.ts +0 -335
- package/scripts/accuracy/runAccuracyTests.sh +0 -45
- package/scripts/accuracy/updateAccuracyRunStatus.ts +0 -21
- package/scripts/apply.ts +0 -135
- package/scripts/filter.ts +0 -76
- package/scripts/generate.sh +0 -11
- package/src/common/atlas/accessListUtils.ts +0 -54
- package/src/common/atlas/apiClient.ts +0 -406
- package/src/common/atlas/apiClientError.ts +0 -72
- package/src/common/atlas/cluster.ts +0 -94
- package/src/common/atlas/openapi.d.ts +0 -7486
- package/src/common/config.ts +0 -137
- package/src/common/errors.ts +0 -14
- package/src/common/logger.ts +0 -188
- package/src/common/managedTimeout.ts +0 -27
- package/src/common/packageInfo.ts +0 -6
- package/src/common/session.ts +0 -118
- package/src/common/sessionStore.ts +0 -111
- package/src/helpers/connectionOptions.ts +0 -20
- package/src/helpers/container.ts +0 -35
- package/src/helpers/generatePassword.ts +0 -10
- package/src/helpers/indexCheck.ts +0 -83
- package/src/index.ts +0 -48
- package/src/server.ts +0 -250
- package/src/telemetry/constants.ts +0 -14
- package/src/telemetry/eventCache.ts +0 -62
- package/src/telemetry/telemetry.ts +0 -202
- package/src/telemetry/types.ts +0 -76
- package/src/tools/atlas/atlasTool.ts +0 -103
- package/src/tools/atlas/connect/connectCluster.ts +0 -259
- package/src/tools/atlas/create/createAccessList.ts +0 -78
- package/src/tools/atlas/create/createDBUser.ts +0 -90
- package/src/tools/atlas/create/createFreeCluster.ts +0 -58
- package/src/tools/atlas/create/createProject.ts +0 -68
- package/src/tools/atlas/read/inspectAccessList.ts +0 -42
- package/src/tools/atlas/read/inspectCluster.ts +0 -34
- package/src/tools/atlas/read/listAlerts.ts +0 -45
- package/src/tools/atlas/read/listClusters.ts +0 -113
- package/src/tools/atlas/read/listDBUsers.ts +0 -60
- package/src/tools/atlas/read/listOrgs.ts +0 -32
- package/src/tools/atlas/read/listProjects.ts +0 -56
- package/src/tools/atlas/tools.ts +0 -27
- package/src/tools/mongodb/connect/connect.ts +0 -99
- package/src/tools/mongodb/create/createCollection.ts +0 -26
- package/src/tools/mongodb/create/createIndex.ts +0 -41
- package/src/tools/mongodb/create/insertMany.ts +0 -40
- package/src/tools/mongodb/delete/deleteMany.ts +0 -58
- package/src/tools/mongodb/delete/dropCollection.ts +0 -27
- package/src/tools/mongodb/delete/dropDatabase.ts +0 -26
- package/src/tools/mongodb/metadata/collectionSchema.ts +0 -43
- package/src/tools/mongodb/metadata/collectionStorageSize.ts +0 -68
- package/src/tools/mongodb/metadata/dbStats.ts +0 -35
- package/src/tools/mongodb/metadata/explain.ts +0 -103
- package/src/tools/mongodb/metadata/listCollections.ts +0 -38
- package/src/tools/mongodb/metadata/listDatabases.ts +0 -25
- package/src/tools/mongodb/metadata/logs.ts +0 -55
- package/src/tools/mongodb/mongodbTool.ts +0 -136
- package/src/tools/mongodb/read/aggregate.ts +0 -56
- package/src/tools/mongodb/read/collectionIndexes.ts +0 -48
- package/src/tools/mongodb/read/count.ts +0 -55
- package/src/tools/mongodb/read/find.ts +0 -75
- package/src/tools/mongodb/tools.ts +0 -43
- package/src/tools/mongodb/update/renameCollection.ts +0 -66
- package/src/tools/mongodb/update/updateMany.ts +0 -85
- package/src/tools/tool.ts +0 -219
- package/src/transports/base.ts +0 -34
- package/src/transports/stdio.ts +0 -76
- package/src/transports/streamableHttp.ts +0 -178
- package/src/types/mongodb-connection-string-url.d.ts +0 -69
- package/src/types/mongodb-redact.d.ts +0 -4
- package/tests/accuracy/aggregate.test.ts +0 -27
- package/tests/accuracy/collectionIndexes.test.ts +0 -40
- package/tests/accuracy/collectionSchema.test.ts +0 -28
- package/tests/accuracy/collectionStorageSize.test.ts +0 -41
- package/tests/accuracy/count.test.ts +0 -44
- package/tests/accuracy/createCollection.test.ts +0 -46
- package/tests/accuracy/createIndex.test.ts +0 -37
- package/tests/accuracy/dbStats.test.ts +0 -15
- package/tests/accuracy/deleteMany.test.ts +0 -44
- package/tests/accuracy/dropCollection.test.ts +0 -74
- package/tests/accuracy/dropDatabase.test.ts +0 -41
- package/tests/accuracy/explain.test.ts +0 -73
- package/tests/accuracy/find.test.ts +0 -114
- package/tests/accuracy/insertMany.test.ts +0 -48
- package/tests/accuracy/listCollections.test.ts +0 -60
- package/tests/accuracy/listDatabases.test.ts +0 -31
- package/tests/accuracy/logs.test.ts +0 -28
- package/tests/accuracy/renameCollection.test.ts +0 -31
- package/tests/accuracy/sdk/accuracyResultStorage/diskStorage.ts +0 -189
- package/tests/accuracy/sdk/accuracyResultStorage/getAccuracyResultStorage.ts +0 -11
- package/tests/accuracy/sdk/accuracyResultStorage/mongodbStorage.ts +0 -151
- package/tests/accuracy/sdk/accuracyResultStorage/resultStorage.ts +0 -117
- package/tests/accuracy/sdk/accuracyScorer.ts +0 -93
- package/tests/accuracy/sdk/accuracyTestingClient.ts +0 -94
- package/tests/accuracy/sdk/agent.ts +0 -56
- package/tests/accuracy/sdk/constants.ts +0 -26
- package/tests/accuracy/sdk/describeAccuracyTests.ts +0 -126
- package/tests/accuracy/sdk/gitInfo.ts +0 -7
- package/tests/accuracy/sdk/matcher.ts +0 -193
- package/tests/accuracy/sdk/models.ts +0 -95
- package/tests/accuracy/test-data-dumps/comics.books.json +0 -417
- package/tests/accuracy/test-data-dumps/comics.characters.json +0 -402
- package/tests/accuracy/test-data-dumps/mflix.movies.json +0 -496
- package/tests/accuracy/test-data-dumps/mflix.shows.json +0 -572
- package/tests/accuracy/updateMany.test.ts +0 -42
- package/tests/integration/helpers.ts +0 -265
- package/tests/integration/inMemoryTransport.ts +0 -59
- package/tests/integration/indexCheck.test.ts +0 -464
- package/tests/integration/server.test.ts +0 -88
- package/tests/integration/telemetry.test.ts +0 -29
- package/tests/integration/tools/atlas/accessLists.test.ts +0 -118
- package/tests/integration/tools/atlas/alerts.test.ts +0 -43
- package/tests/integration/tools/atlas/atlasHelpers.ts +0 -111
- package/tests/integration/tools/atlas/clusters.test.ts +0 -237
- package/tests/integration/tools/atlas/dbUsers.test.ts +0 -118
- package/tests/integration/tools/atlas/orgs.test.ts +0 -25
- package/tests/integration/tools/atlas/projects.test.ts +0 -79
- package/tests/integration/tools/mongodb/connect/connect.test.ts +0 -159
- package/tests/integration/tools/mongodb/create/createCollection.test.ts +0 -96
- package/tests/integration/tools/mongodb/create/createIndex.test.ts +0 -204
- package/tests/integration/tools/mongodb/create/insertMany.test.ts +0 -99
- package/tests/integration/tools/mongodb/delete/deleteMany.test.ts +0 -155
- package/tests/integration/tools/mongodb/delete/dropCollection.test.ts +0 -69
- package/tests/integration/tools/mongodb/delete/dropDatabase.test.ts +0 -81
- package/tests/integration/tools/mongodb/metadata/collectionSchema.test.ts +0 -155
- package/tests/integration/tools/mongodb/metadata/collectionStorageSize.test.ts +0 -87
- package/tests/integration/tools/mongodb/metadata/dbStats.test.ts +0 -105
- package/tests/integration/tools/mongodb/metadata/explain.test.ts +0 -172
- package/tests/integration/tools/mongodb/metadata/listCollections.test.ts +0 -77
- package/tests/integration/tools/mongodb/metadata/listDatabases.test.ts +0 -78
- package/tests/integration/tools/mongodb/metadata/logs.test.ts +0 -84
- package/tests/integration/tools/mongodb/mongodbHelpers.ts +0 -235
- package/tests/integration/tools/mongodb/read/aggregate.test.ts +0 -115
- package/tests/integration/tools/mongodb/read/collectionIndexes.test.ts +0 -100
- package/tests/integration/tools/mongodb/read/count.test.ts +0 -96
- package/tests/integration/tools/mongodb/read/find.test.ts +0 -211
- package/tests/integration/tools/mongodb/update/renameCollection.test.ts +0 -195
- package/tests/integration/tools/mongodb/update/updateMany.test.ts +0 -239
- package/tests/integration/transports/stdio.test.ts +0 -40
- package/tests/integration/transports/streamableHttp.test.ts +0 -56
- package/tests/matchers/toIncludeSameMembers.test.ts +0 -59
- package/tests/matchers/toIncludeSameMembers.ts +0 -12
- package/tests/setup.ts +0 -7
- package/tests/unit/accessListUtils.test.ts +0 -39
- package/tests/unit/accuracyScorer.test.ts +0 -390
- package/tests/unit/common/apiClient.test.ts +0 -193
- package/tests/unit/common/managedTimeout.test.ts +0 -67
- package/tests/unit/common/session.test.ts +0 -60
- package/tests/unit/helpers/indexCheck.test.ts +0 -150
- package/tests/unit/telemetry.test.ts +0 -332
- package/tests/unit/transports/stdio.test.ts +0 -71
- package/tests/vitest.d.ts +0 -11
- package/tsconfig.build.json +0 -20
- package/tsconfig.json +0 -8
- package/tsconfig.test.json +0 -8
- package/vitest.config.ts +0 -41
- /package/dist/{common → esm/common}/atlas/apiClientError.js +0 -0
- /package/dist/{common → esm/common}/errors.js +0 -0
- /package/dist/{common → esm/common}/managedTimeout.js +0 -0
- /package/dist/{helpers → esm/helpers}/container.js +0 -0
- /package/dist/{helpers → esm/helpers}/generatePassword.js +0 -0
- /package/dist/{helpers → esm/helpers}/indexCheck.js +0 -0
- /package/dist/{telemetry → esm/telemetry}/constants.js +0 -0
- /package/dist/{telemetry → esm/telemetry}/eventCache.js +0 -0
- /package/dist/{telemetry → esm/telemetry}/types.js +0 -0
- /package/dist/{tools → esm/tools}/atlas/create/createAccessList.js +0 -0
- /package/dist/{tools → esm/tools}/atlas/create/createFreeCluster.js +0 -0
- /package/dist/{tools → esm/tools}/atlas/create/createProject.js +0 -0
- /package/dist/{tools → esm/tools}/atlas/tools.js +0 -0
- /package/dist/{tools → esm/tools}/mongodb/create/createCollection.js +0 -0
- /package/dist/{tools → esm/tools}/mongodb/create/createIndex.js +0 -0
- /package/dist/{tools → esm/tools}/mongodb/create/insertMany.js +0 -0
- /package/dist/{tools → esm/tools}/mongodb/delete/deleteMany.js +0 -0
- /package/dist/{tools → esm/tools}/mongodb/delete/dropCollection.js +0 -0
- /package/dist/{tools → esm/tools}/mongodb/delete/dropDatabase.js +0 -0
- /package/dist/{tools → esm/tools}/mongodb/metadata/collectionStorageSize.js +0 -0
- /package/dist/{tools → esm/tools}/mongodb/metadata/logs.js +0 -0
- /package/dist/{tools → esm/tools}/mongodb/read/count.js +0 -0
- /package/dist/{tools → esm/tools}/mongodb/update/renameCollection.js +0 -0
- /package/dist/{tools → esm/tools}/mongodb/update/updateMany.js +0 -0
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"session.js","sourceRoot":"","sources":["../../../src/common/session.ts"],"names":[],"mappings":";;;;;;AAAA,+BAAgC;AAEhC,uDAAiD;AAGjD,2CAAoC;AACpC,oDAAkC;AASlC,2CAAuD;AAmBvD,MAAa,OAAQ,SAAQ,gBAA2B;IAapD,YAAY,EACR,UAAU,EACV,WAAW,EACX,eAAe,EACf,MAAM,EACN,iBAAiB,EACjB,cAAc,GACD;QACb,KAAK,EAAE,CAAC;QApBH,cAAS,GAAW,IAAI,eAAQ,EAAE,CAAC,QAAQ,EAAE,CAAC;QAsBnD,IAAI,CAAC,MAAM,GAAG,MAAM,CAAC;QACrB,MAAM,WAAW,GACb,WAAW,IAAI,eAAe;YAC1B,CAAC,CAAC;gBACI,QAAQ,EAAE,WAAW;gBACrB,YAAY,EAAE,eAAe;aAChC;YACH,CAAC,CAAC,SAAS,CAAC;QAEpB,IAAI,CAAC,SAAS,GAAG,IAAI,wBAAS,CAAC,EAAE,OAAO,EAAE,UAAU,EAAE,WAAW,EAAE,EAAE,MAAM,CAAC,CAAC;QAC7E,IAAI,CAAC,cAAc,GAAG,cAAc,CAAC;QACrC,IAAI,CAAC,iBAAiB,GAAG,iBAAiB,CAAC;QAC3C,IAAI,CAAC,iBAAiB,CAAC,EAAE,CAAC,oBAAoB,EAAE,GAAG,EAAE,CAAC,IAAI,CAAC,IAAI,CAAC,SAAS,CAAC,CAAC,CAAC;QAC5E,IAAI,CAAC,iBAAiB,CAAC,EAAE,CAAC,qBAAqB,EAAE,CAAC,KAAK,EAAE,EAAE,CAAC,IAAI,CAAC,IAAI,CAAC,kBAAkB,EAAE,KAAK,CAAC,CAAC,CAAC;QAClG,IAAI,CAAC,iBAAiB,CAAC,EAAE,CAAC,kBAAkB,EAAE,GAAG,EAAE,CAAC,IAAI,CAAC,IAAI,CAAC,YAAY,CAAC,CAAC,CAAC;QAC7E,IAAI,CAAC,iBAAiB,CAAC,EAAE,CAAC,kBAAkB,EAAE,CAAC,KAAK,EAAE,EAAE,CAAC,IAAI,CAAC,IAAI,CAAC,kBAAkB,EAAE,KAAK,CAAC,CAAC,CAAC;IACnG,CAAC;IAED,YAAY,CAAC,SAAqC;QAC9C,IAAI,CAAC,SAAS,EAAE,CAAC;YACb,IAAI,CAAC,iBAAiB,CAAC,aAAa,CAAC,SAAS,CAAC,CAAC;YAChD,IAAI,CAAC,MAAM,CAAC,KAAK,CAAC;gBACd,EAAE,EAAE,iBAAK,CAAC,kBAAkB;gBAC5B,OAAO,EAAE,SAAS;gBAClB,OAAO,EAAE,2BAA2B;aACvC,CAAC,CAAC;QACP,CAAC;QAED,IAAI,CAAC,SAAS,GAAG;YACb,IAAI,EAAE,SAAS,EAAE,IAAI,IAAI,SAAS;YAClC,OAAO,EAAE,SAAS,EAAE,OAAO,IAAI,SAAS;YACxC,KAAK,EAAE,SAAS,EAAE,KAAK,IAAI,SAAS;SACvC,CAAC;QAEF,uEAAuE;QACvE,IAAI,CAAC,iBAAiB,CAAC,aAAa,CAAC,IAAI,CAAC,SAAS,CAAC,IAAI,IAAI,SAAS,CAAC,CAAC;IAC3E,CAAC;IAED,KAAK,CAAC,UAAU;QACZ,MAAM,YAAY,GAAG,IAAI,CAAC,qBAAqB,CAAC;QAEhD,IAAI,CAAC;YACD,MAAM,IAAI,CAAC,iBAAiB,CAAC,UAAU,EAAE,CAAC;QAC9C,CAAC;QAAC,OAAO,GAAY,EAAE,CAAC;YACpB,MAAM,KAAK,GAAG,GAAG,YAAY,KAAK,CAAC,CAAC,CAAC,GAAG,CAAC,CAAC,CAAC,IAAI,KAAK,CAAC,MAAM,CAAC,GAAG,CAAC,CAAC,CAAC;YAClE,IAAI,CAAC,MAAM,CAAC,KAAK,CAAC;gBACd,EAAE,EAAE,iBAAK,CAAC,wBAAwB;gBAClC,OAAO,EAAE,SAAS;gBAClB,OAAO,EAAE,mCAAmC,KAAK,CAAC,OAAO,EAAE;aAC9D,CAAC,CAAC;QACP,CAAC;QAED,IAAI,YAAY,EAAE,QAAQ,IAAI,YAAY,EAAE,SAAS,EAAE,CAAC;YACpD,KAAK,IAAI,CAAC,SAAS;iBACd,kBAAkB,CAAC;gBAChB,MAAM,EAAE;oBACJ,IAAI,EAAE;wBACF,OAAO,EAAE,YAAY,CAAC,SAAS;wBAC/B,QAAQ,EAAE,YAAY,CAAC,QAAQ;wBAC/B,YAAY,EAAE,OAAO;qBACxB;iBACJ;aACJ,CAAC;iBACD,KAAK,CAAC,CAAC,GAAY,EAAE,EAAE;gBACpB,MAAM,KAAK,GAAG,GAAG,YAAY,KAAK,CAAC,CAAC,CAAC,GAAG,CAAC,CAAC,CAAC,IAAI,KAAK,CAAC,MAAM,CAAC,GAAG,CAAC,CAAC,CAAC;gBAClE,IAAI,CAAC,MAAM,CAAC,KAAK,CAAC;oBACd,EAAE,EAAE,iBAAK,CAAC,8BAA8B;oBACxC,OAAO,EAAE,SAAS;oBAClB,OAAO,EAAE,0CAA0C,KAAK,CAAC,OAAO,EAAE;iBACrE,CAAC,CAAC;YACP,CAAC,CAAC,CAAC;QACX,CAAC;IACL,CAAC;IAED,KAAK,CAAC,KAAK;QACP,MAAM,IAAI,CAAC,UAAU,EAAE,CAAC;QACxB,MAAM,IAAI,CAAC,SAAS,CAAC,KAAK,EAAE,CAAC;QAC7B,MAAM,IAAI,CAAC,cAAc,CAAC,KAAK,EAAE,CAAC;QAClC,IAAI,CAAC,IAAI,CAAC,OAAO,CAAC,CAAC;IACvB,CAAC;IAED,KAAK,CAAC,gBAAgB,CAAC,QAA4B;QAC/C,MAAM,IAAI,CAAC,iBAAiB,CAAC,OAAO,CAAC,EAAE,GAAG,QAAQ,EAAE,CAAC,CAAC;IAC1D,CAAC;IAED,IAAI,oBAAoB;QACpB,OAAO,IAAI,CAAC,iBAAiB,CAAC,sBAAsB,CAAC,GAAG,KAAK,WAAW,CAAC;IAC7E,CAAC;IAED,IAAI,eAAe;QACf,IAAI,IAAI,CAAC,oBAAoB,EAAE,CAAC;YAC5B,MAAM,KAAK,GAAG,IAAI,CAAC,iBAAiB,CAAC,sBAAkD,CAAC;YACxF,OAAO,KAAK,CAAC,eAAe,CAAC;QACjC,CAAC;QAED,MAAM,IAAI,wBAAY,CAAC,sBAAU,CAAC,qBAAqB,EAAE,0BAA0B,CAAC,CAAC;IACzF,CAAC;IAED,IAAI,qBAAqB;QACrB,OAAO,IAAI,CAAC,iBAAiB,CAAC,sBAAsB,CAAC,qBAAqB,CAAC;IAC/E,CAAC;CACJ;AA5HD,0BA4HC"}
|
|
@@ -0,0 +1,16 @@
|
|
|
1
|
+
import type { StreamableHTTPServerTransport } from "@modelcontextprotocol/sdk/server/streamableHttp.js";
|
|
2
|
+
import type { LoggerBase } from "./logger.js";
|
|
3
|
+
export declare class SessionStore {
|
|
4
|
+
private readonly idleTimeoutMS;
|
|
5
|
+
private readonly notificationTimeoutMS;
|
|
6
|
+
private readonly logger;
|
|
7
|
+
private sessions;
|
|
8
|
+
constructor(idleTimeoutMS: number, notificationTimeoutMS: number, logger: LoggerBase);
|
|
9
|
+
getSession(sessionId: string): StreamableHTTPServerTransport | undefined;
|
|
10
|
+
private resetTimeout;
|
|
11
|
+
private sendNotification;
|
|
12
|
+
setSession(sessionId: string, transport: StreamableHTTPServerTransport, logger: LoggerBase): void;
|
|
13
|
+
closeSession(sessionId: string, closeTransport?: boolean): Promise<void>;
|
|
14
|
+
closeAllSessions(): Promise<void>;
|
|
15
|
+
}
|
|
16
|
+
//# sourceMappingURL=sessionStore.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"sessionStore.d.ts","sourceRoot":"","sources":["../../../src/common/sessionStore.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,6BAA6B,EAAE,MAAM,oDAAoD,CAAC;AACxG,OAAO,KAAK,EAAE,UAAU,EAAE,MAAM,aAAa,CAAC;AAK9C,qBAAa,YAAY;IAWjB,OAAO,CAAC,QAAQ,CAAC,aAAa;IAC9B,OAAO,CAAC,QAAQ,CAAC,qBAAqB;IACtC,OAAO,CAAC,QAAQ,CAAC,MAAM;IAZ3B,OAAO,CAAC,QAAQ,CAOT;gBAGc,aAAa,EAAE,MAAM,EACrB,qBAAqB,EAAE,MAAM,EAC7B,MAAM,EAAE,UAAU;IAavC,UAAU,CAAC,SAAS,EAAE,MAAM,GAAG,6BAA6B,GAAG,SAAS;IAKxE,OAAO,CAAC,YAAY;IAWpB,OAAO,CAAC,gBAAgB;IAiBxB,UAAU,CAAC,SAAS,EAAE,MAAM,EAAE,SAAS,EAAE,6BAA6B,EAAE,MAAM,EAAE,UAAU,GAAG,IAAI;IA4B3F,YAAY,CAAC,SAAS,EAAE,MAAM,EAAE,cAAc,GAAE,OAAc,GAAG,OAAO,CAAC,IAAI,CAAC;IAqB9E,gBAAgB,IAAI,OAAO,CAAC,IAAI,CAAC;CAG1C"}
|
|
@@ -0,0 +1,99 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.SessionStore = void 0;
|
|
4
|
+
const logger_js_1 = require("./logger.js");
|
|
5
|
+
const managedTimeout_js_1 = require("./managedTimeout.js");
|
|
6
|
+
class SessionStore {
|
|
7
|
+
constructor(idleTimeoutMS, notificationTimeoutMS, logger) {
|
|
8
|
+
this.idleTimeoutMS = idleTimeoutMS;
|
|
9
|
+
this.notificationTimeoutMS = notificationTimeoutMS;
|
|
10
|
+
this.logger = logger;
|
|
11
|
+
this.sessions = {};
|
|
12
|
+
if (idleTimeoutMS <= 0) {
|
|
13
|
+
throw new Error("idleTimeoutMS must be greater than 0");
|
|
14
|
+
}
|
|
15
|
+
if (notificationTimeoutMS <= 0) {
|
|
16
|
+
throw new Error("notificationTimeoutMS must be greater than 0");
|
|
17
|
+
}
|
|
18
|
+
if (idleTimeoutMS <= notificationTimeoutMS) {
|
|
19
|
+
throw new Error("idleTimeoutMS must be greater than notificationTimeoutMS");
|
|
20
|
+
}
|
|
21
|
+
}
|
|
22
|
+
getSession(sessionId) {
|
|
23
|
+
this.resetTimeout(sessionId);
|
|
24
|
+
return this.sessions[sessionId]?.transport;
|
|
25
|
+
}
|
|
26
|
+
resetTimeout(sessionId) {
|
|
27
|
+
const session = this.sessions[sessionId];
|
|
28
|
+
if (!session) {
|
|
29
|
+
return;
|
|
30
|
+
}
|
|
31
|
+
session.abortTimeout.restart();
|
|
32
|
+
session.notificationTimeout.restart();
|
|
33
|
+
}
|
|
34
|
+
sendNotification(sessionId) {
|
|
35
|
+
const session = this.sessions[sessionId];
|
|
36
|
+
if (!session) {
|
|
37
|
+
this.logger.warning({
|
|
38
|
+
id: logger_js_1.LogId.streamableHttpTransportSessionCloseNotificationFailure,
|
|
39
|
+
context: "sessionStore",
|
|
40
|
+
message: `session ${sessionId} not found, no notification delivered`,
|
|
41
|
+
});
|
|
42
|
+
return;
|
|
43
|
+
}
|
|
44
|
+
session.logger.info({
|
|
45
|
+
id: logger_js_1.LogId.streamableHttpTransportSessionCloseNotification,
|
|
46
|
+
context: "sessionStore",
|
|
47
|
+
message: "Session is about to be closed due to inactivity",
|
|
48
|
+
});
|
|
49
|
+
}
|
|
50
|
+
setSession(sessionId, transport, logger) {
|
|
51
|
+
const session = this.sessions[sessionId];
|
|
52
|
+
if (session) {
|
|
53
|
+
throw new Error(`Session ${sessionId} already exists`);
|
|
54
|
+
}
|
|
55
|
+
const abortTimeout = (0, managedTimeout_js_1.setManagedTimeout)(async () => {
|
|
56
|
+
if (this.sessions[sessionId]) {
|
|
57
|
+
this.sessions[sessionId].logger.info({
|
|
58
|
+
id: logger_js_1.LogId.streamableHttpTransportSessionCloseNotification,
|
|
59
|
+
context: "sessionStore",
|
|
60
|
+
message: "Session closed due to inactivity",
|
|
61
|
+
});
|
|
62
|
+
await this.closeSession(sessionId);
|
|
63
|
+
}
|
|
64
|
+
}, this.idleTimeoutMS);
|
|
65
|
+
const notificationTimeout = (0, managedTimeout_js_1.setManagedTimeout)(() => this.sendNotification(sessionId), this.notificationTimeoutMS);
|
|
66
|
+
this.sessions[sessionId] = {
|
|
67
|
+
transport,
|
|
68
|
+
abortTimeout,
|
|
69
|
+
notificationTimeout,
|
|
70
|
+
logger,
|
|
71
|
+
};
|
|
72
|
+
}
|
|
73
|
+
async closeSession(sessionId, closeTransport = true) {
|
|
74
|
+
const session = this.sessions[sessionId];
|
|
75
|
+
if (!session) {
|
|
76
|
+
throw new Error(`Session ${sessionId} not found`);
|
|
77
|
+
}
|
|
78
|
+
session.abortTimeout.cancel();
|
|
79
|
+
session.notificationTimeout.cancel();
|
|
80
|
+
if (closeTransport) {
|
|
81
|
+
try {
|
|
82
|
+
await session.transport.close();
|
|
83
|
+
}
|
|
84
|
+
catch (error) {
|
|
85
|
+
this.logger.error({
|
|
86
|
+
id: logger_js_1.LogId.streamableHttpTransportSessionCloseFailure,
|
|
87
|
+
context: "streamableHttpTransport",
|
|
88
|
+
message: `Error closing transport ${sessionId}: ${error instanceof Error ? error.message : String(error)}`,
|
|
89
|
+
});
|
|
90
|
+
}
|
|
91
|
+
}
|
|
92
|
+
delete this.sessions[sessionId];
|
|
93
|
+
}
|
|
94
|
+
async closeAllSessions() {
|
|
95
|
+
await Promise.all(Object.keys(this.sessions).map((sessionId) => this.closeSession(sessionId)));
|
|
96
|
+
}
|
|
97
|
+
}
|
|
98
|
+
exports.SessionStore = SessionStore;
|
|
99
|
+
//# sourceMappingURL=sessionStore.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"sessionStore.js","sourceRoot":"","sources":["../../../src/common/sessionStore.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,25 @@
|
|
|
1
|
+
export interface AppNameComponents {
|
|
2
|
+
appName: string;
|
|
3
|
+
deviceId?: Promise<string>;
|
|
4
|
+
clientName?: string;
|
|
5
|
+
}
|
|
6
|
+
/**
|
|
7
|
+
* Sets the appName parameter with the extended format: appName--deviceId--clientName
|
|
8
|
+
* Only sets the appName if it's not already present in the connection string
|
|
9
|
+
* @param connectionString - The connection string to modify
|
|
10
|
+
* @param components - The components to build the appName from
|
|
11
|
+
* @returns The modified connection string
|
|
12
|
+
*/
|
|
13
|
+
export declare function setAppNameParamIfMissing({ connectionString, components, }: {
|
|
14
|
+
connectionString: string;
|
|
15
|
+
components: AppNameComponents;
|
|
16
|
+
}): Promise<string>;
|
|
17
|
+
/**
|
|
18
|
+
* Validates the connection string
|
|
19
|
+
* @param connectionString - The connection string to validate
|
|
20
|
+
* @param looseValidation - Whether to allow loose validation
|
|
21
|
+
* @returns void
|
|
22
|
+
* @throws Error if the connection string is invalid
|
|
23
|
+
*/
|
|
24
|
+
export declare function validateConnectionString(connectionString: string, looseValidation: boolean): void;
|
|
25
|
+
//# sourceMappingURL=connectionOptions.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"connectionOptions.d.ts","sourceRoot":"","sources":["../../../src/helpers/connectionOptions.ts"],"names":[],"mappings":"AAGA,MAAM,WAAW,iBAAiB;IAC9B,OAAO,EAAE,MAAM,CAAC;IAChB,QAAQ,CAAC,EAAE,OAAO,CAAC,MAAM,CAAC,CAAC;IAC3B,UAAU,CAAC,EAAE,MAAM,CAAC;CACvB;AAED;;;;;;GAMG;AACH,wBAAsB,wBAAwB,CAAC,EAC3C,gBAAgB,EAChB,UAAU,GACb,EAAE;IACC,gBAAgB,EAAE,MAAM,CAAC;IACzB,UAAU,EAAE,iBAAiB,CAAC;CACjC,GAAG,OAAO,CAAC,MAAM,CAAC,CAmBlB;AAED;;;;;;GAMG;AACH,wBAAgB,wBAAwB,CAAC,gBAAgB,EAAE,MAAM,EAAE,eAAe,EAAE,OAAO,GAAG,IAAI,CAQjG"}
|
|
@@ -0,0 +1,46 @@
|
|
|
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.setAppNameParamIfMissing = setAppNameParamIfMissing;
|
|
7
|
+
exports.validateConnectionString = validateConnectionString;
|
|
8
|
+
const mongodb_connection_string_url_1 = __importDefault(require("mongodb-connection-string-url"));
|
|
9
|
+
/**
|
|
10
|
+
* Sets the appName parameter with the extended format: appName--deviceId--clientName
|
|
11
|
+
* Only sets the appName if it's not already present in the connection string
|
|
12
|
+
* @param connectionString - The connection string to modify
|
|
13
|
+
* @param components - The components to build the appName from
|
|
14
|
+
* @returns The modified connection string
|
|
15
|
+
*/
|
|
16
|
+
async function setAppNameParamIfMissing({ connectionString, components, }) {
|
|
17
|
+
const connectionStringUrl = new mongodb_connection_string_url_1.default(connectionString);
|
|
18
|
+
const searchParams = connectionStringUrl.typedSearchParams();
|
|
19
|
+
// Only set appName if it's not already present
|
|
20
|
+
if (searchParams.has("appName")) {
|
|
21
|
+
return connectionStringUrl.toString();
|
|
22
|
+
}
|
|
23
|
+
const appName = components.appName || "unknown";
|
|
24
|
+
const deviceId = components.deviceId ? await components.deviceId : "unknown";
|
|
25
|
+
const clientName = components.clientName || "unknown";
|
|
26
|
+
// Build the extended appName format: appName--deviceId--clientName
|
|
27
|
+
const extendedAppName = `${appName}--${deviceId}--${clientName}`;
|
|
28
|
+
searchParams.set("appName", extendedAppName);
|
|
29
|
+
return connectionStringUrl.toString();
|
|
30
|
+
}
|
|
31
|
+
/**
|
|
32
|
+
* Validates the connection string
|
|
33
|
+
* @param connectionString - The connection string to validate
|
|
34
|
+
* @param looseValidation - Whether to allow loose validation
|
|
35
|
+
* @returns void
|
|
36
|
+
* @throws Error if the connection string is invalid
|
|
37
|
+
*/
|
|
38
|
+
function validateConnectionString(connectionString, looseValidation) {
|
|
39
|
+
try {
|
|
40
|
+
new mongodb_connection_string_url_1.default(connectionString, { looseValidation });
|
|
41
|
+
}
|
|
42
|
+
catch (error) {
|
|
43
|
+
throw new Error(`Invalid connection string with error: ${error instanceof Error ? error.message : String(error)}`);
|
|
44
|
+
}
|
|
45
|
+
}
|
|
46
|
+
//# sourceMappingURL=connectionOptions.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"connectionOptions.js","sourceRoot":"","sources":["../../../src/helpers/connectionOptions.ts"],"names":[],"mappings":";;;;;AAgBA,4DAyBC;AASD,4DAQC;AAzDD,kGAA6D;AAQ7D;;;;;;GAMG;AACI,KAAK,UAAU,wBAAwB,CAAC,EAC3C,gBAAgB,EAChB,UAAU,GAIb;IACG,MAAM,mBAAmB,GAAG,IAAI,uCAAgB,CAAC,gBAAgB,CAAC,CAAC;IACnE,MAAM,YAAY,GAAG,mBAAmB,CAAC,iBAAiB,EAAsB,CAAC;IAEjF,+CAA+C;IAC/C,IAAI,YAAY,CAAC,GAAG,CAAC,SAAS,CAAC,EAAE,CAAC;QAC9B,OAAO,mBAAmB,CAAC,QAAQ,EAAE,CAAC;IAC1C,CAAC;IAED,MAAM,OAAO,GAAG,UAAU,CAAC,OAAO,IAAI,SAAS,CAAC;IAChD,MAAM,QAAQ,GAAG,UAAU,CAAC,QAAQ,CAAC,CAAC,CAAC,MAAM,UAAU,CAAC,QAAQ,CAAC,CAAC,CAAC,SAAS,CAAC;IAC7E,MAAM,UAAU,GAAG,UAAU,CAAC,UAAU,IAAI,SAAS,CAAC;IAEtD,mEAAmE;IACnE,MAAM,eAAe,GAAG,GAAG,OAAO,KAAK,QAAQ,KAAK,UAAU,EAAE,CAAC;IAEjE,YAAY,CAAC,GAAG,CAAC,SAAS,EAAE,eAAe,CAAC,CAAC;IAE7C,OAAO,mBAAmB,CAAC,QAAQ,EAAE,CAAC;AAC1C,CAAC;AAED;;;;;;GAMG;AACH,SAAgB,wBAAwB,CAAC,gBAAwB,EAAE,eAAwB;IACvF,IAAI,CAAC;QACD,IAAI,uCAAgB,CAAC,gBAAgB,EAAE,EAAE,eAAe,EAAE,CAAC,CAAC;IAChE,CAAC;IAAC,OAAO,KAAK,EAAE,CAAC;QACb,MAAM,IAAI,KAAK,CACX,yCAAyC,KAAK,YAAY,KAAK,CAAC,CAAC,CAAC,KAAK,CAAC,OAAO,CAAC,CAAC,CAAC,MAAM,CAAC,KAAK,CAAC,EAAE,CACpG,CAAC;IACN,CAAC;AACL,CAAC"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"container.d.ts","sourceRoot":"","sources":["../../../src/helpers/container.ts"],"names":[],"mappings":"AAIA,wBAAsB,kBAAkB,IAAI,OAAO,CAAC,OAAO,CAAC,CA8B3D"}
|
|
@@ -0,0 +1,34 @@
|
|
|
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.detectContainerEnv = detectContainerEnv;
|
|
7
|
+
const promises_1 = __importDefault(require("fs/promises"));
|
|
8
|
+
let containerEnv;
|
|
9
|
+
async function detectContainerEnv() {
|
|
10
|
+
if (containerEnv !== undefined) {
|
|
11
|
+
return containerEnv;
|
|
12
|
+
}
|
|
13
|
+
const detect = async function () {
|
|
14
|
+
if (process.platform !== "linux") {
|
|
15
|
+
return false; // we only support linux containers for now
|
|
16
|
+
}
|
|
17
|
+
if (process.env.container) {
|
|
18
|
+
return true;
|
|
19
|
+
}
|
|
20
|
+
const exists = await Promise.all(["/.dockerenv", "/run/.containerenv", "/var/run/.containerenv"].map(async (file) => {
|
|
21
|
+
try {
|
|
22
|
+
await promises_1.default.access(file);
|
|
23
|
+
return true;
|
|
24
|
+
}
|
|
25
|
+
catch {
|
|
26
|
+
return false;
|
|
27
|
+
}
|
|
28
|
+
}));
|
|
29
|
+
return exists.includes(true);
|
|
30
|
+
};
|
|
31
|
+
containerEnv = await detect();
|
|
32
|
+
return containerEnv;
|
|
33
|
+
}
|
|
34
|
+
//# sourceMappingURL=container.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"container.js","sourceRoot":"","sources":["../../../src/helpers/container.ts"],"names":[],"mappings":";;;;;AAIA,gDA8BC;AAlCD,2DAA6B;AAE7B,IAAI,YAAiC,CAAC;AAE/B,KAAK,UAAU,kBAAkB;IACpC,IAAI,YAAY,KAAK,SAAS,EAAE,CAAC;QAC7B,OAAO,YAAY,CAAC;IACxB,CAAC;IAED,MAAM,MAAM,GAAG,KAAK;QAChB,IAAI,OAAO,CAAC,QAAQ,KAAK,OAAO,EAAE,CAAC;YAC/B,OAAO,KAAK,CAAC,CAAC,2CAA2C;QAC7D,CAAC;QAED,IAAI,OAAO,CAAC,GAAG,CAAC,SAAS,EAAE,CAAC;YACxB,OAAO,IAAI,CAAC;QAChB,CAAC;QAED,MAAM,MAAM,GAAG,MAAM,OAAO,CAAC,GAAG,CAC5B,CAAC,aAAa,EAAE,oBAAoB,EAAE,wBAAwB,CAAC,CAAC,GAAG,CAAC,KAAK,EAAE,IAAI,EAAE,EAAE;YAC/E,IAAI,CAAC;gBACD,MAAM,kBAAE,CAAC,MAAM,CAAC,IAAI,CAAC,CAAC;gBACtB,OAAO,IAAI,CAAC;YAChB,CAAC;YAAC,MAAM,CAAC;gBACL,OAAO,KAAK,CAAC;YACjB,CAAC;QACL,CAAC,CAAC,CACL,CAAC;QAEF,OAAO,MAAM,CAAC,QAAQ,CAAC,IAAI,CAAC,CAAC;IACjC,CAAC,CAAC;IAEF,YAAY,GAAG,MAAM,MAAM,EAAE,CAAC;IAC9B,OAAO,YAAY,CAAC;AACxB,CAAC"}
|
|
@@ -0,0 +1,24 @@
|
|
|
1
|
+
import type { LoggerBase } from "../common/logger.js";
|
|
2
|
+
export declare const DEVICE_ID_TIMEOUT = 3000;
|
|
3
|
+
export declare class DeviceId {
|
|
4
|
+
private static readonly UnknownDeviceId;
|
|
5
|
+
private deviceIdPromise;
|
|
6
|
+
private abortController;
|
|
7
|
+
private logger;
|
|
8
|
+
private readonly getMachineId;
|
|
9
|
+
private timeout;
|
|
10
|
+
private constructor();
|
|
11
|
+
private initialize;
|
|
12
|
+
static create(logger: LoggerBase, timeout?: number): DeviceId;
|
|
13
|
+
/**
|
|
14
|
+
* Closes the device ID calculation promise and abort controller.
|
|
15
|
+
*/
|
|
16
|
+
close(): void;
|
|
17
|
+
/**
|
|
18
|
+
* Gets the device ID, waiting for the calculation to complete if necessary.
|
|
19
|
+
* @returns Promise that resolves to the device ID string
|
|
20
|
+
*/
|
|
21
|
+
get(): Promise<string>;
|
|
22
|
+
private handleDeviceIdError;
|
|
23
|
+
}
|
|
24
|
+
//# sourceMappingURL=deviceId.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"deviceId.d.ts","sourceRoot":"","sources":["../../../src/helpers/deviceId.ts"],"names":[],"mappings":"AACA,OAAO,KAAK,EAAE,UAAU,EAAE,MAAM,qBAAqB,CAAC;AAGtD,eAAO,MAAM,iBAAiB,OAAO,CAAC;AAEtC,qBAAa,QAAQ;IACjB,OAAO,CAAC,MAAM,CAAC,QAAQ,CAAC,eAAe,CAA8B;IAErE,OAAO,CAAC,eAAe,CAAkB;IACzC,OAAO,CAAC,eAAe,CAAkB;IACzC,OAAO,CAAC,MAAM,CAAa;IAC3B,OAAO,CAAC,QAAQ,CAAC,YAAY,CAAwB;IACrD,OAAO,CAAC,OAAO,CAAS;IAExB,OAAO;IAaP,OAAO,CAAC,UAAU;WAWJ,MAAM,CAAC,MAAM,EAAE,UAAU,EAAE,OAAO,CAAC,EAAE,MAAM,GAAG,QAAQ;IAOpE;;OAEG;IACI,KAAK,IAAI,IAAI;IAIpB;;;OAGG;IACI,GAAG,IAAI,OAAO,CAAC,MAAM,CAAC;IAI7B,OAAO,CAAC,mBAAmB;CAwB9B"}
|
|
@@ -0,0 +1,106 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
var __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) {
|
|
3
|
+
if (k2 === undefined) k2 = k;
|
|
4
|
+
var desc = Object.getOwnPropertyDescriptor(m, k);
|
|
5
|
+
if (!desc || ("get" in desc ? !m.__esModule : desc.writable || desc.configurable)) {
|
|
6
|
+
desc = { enumerable: true, get: function() { return m[k]; } };
|
|
7
|
+
}
|
|
8
|
+
Object.defineProperty(o, k2, desc);
|
|
9
|
+
}) : (function(o, m, k, k2) {
|
|
10
|
+
if (k2 === undefined) k2 = k;
|
|
11
|
+
o[k2] = m[k];
|
|
12
|
+
}));
|
|
13
|
+
var __setModuleDefault = (this && this.__setModuleDefault) || (Object.create ? (function(o, v) {
|
|
14
|
+
Object.defineProperty(o, "default", { enumerable: true, value: v });
|
|
15
|
+
}) : function(o, v) {
|
|
16
|
+
o["default"] = v;
|
|
17
|
+
});
|
|
18
|
+
var __importStar = (this && this.__importStar) || (function () {
|
|
19
|
+
var ownKeys = function(o) {
|
|
20
|
+
ownKeys = Object.getOwnPropertyNames || function (o) {
|
|
21
|
+
var ar = [];
|
|
22
|
+
for (var k in o) if (Object.prototype.hasOwnProperty.call(o, k)) ar[ar.length] = k;
|
|
23
|
+
return ar;
|
|
24
|
+
};
|
|
25
|
+
return ownKeys(o);
|
|
26
|
+
};
|
|
27
|
+
return function (mod) {
|
|
28
|
+
if (mod && mod.__esModule) return mod;
|
|
29
|
+
var result = {};
|
|
30
|
+
if (mod != null) for (var k = ownKeys(mod), i = 0; i < k.length; i++) if (k[i] !== "default") __createBinding(result, mod, k[i]);
|
|
31
|
+
__setModuleDefault(result, mod);
|
|
32
|
+
return result;
|
|
33
|
+
};
|
|
34
|
+
})();
|
|
35
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
36
|
+
exports.DeviceId = exports.DEVICE_ID_TIMEOUT = void 0;
|
|
37
|
+
const device_id_1 = require("@mongodb-js/device-id");
|
|
38
|
+
const logger_js_1 = require("../common/logger.js");
|
|
39
|
+
exports.DEVICE_ID_TIMEOUT = 3000;
|
|
40
|
+
class DeviceId {
|
|
41
|
+
constructor(logger, timeout = exports.DEVICE_ID_TIMEOUT) {
|
|
42
|
+
this.logger = logger;
|
|
43
|
+
this.timeout = timeout;
|
|
44
|
+
this.getMachineId = async () => {
|
|
45
|
+
const nodeMachineId = await Promise.resolve().then(() => __importStar(require("node-machine-id")));
|
|
46
|
+
const machineId = nodeMachineId.default?.machineId || nodeMachineId.machineId;
|
|
47
|
+
return machineId(true);
|
|
48
|
+
};
|
|
49
|
+
this.abortController = new AbortController();
|
|
50
|
+
this.deviceIdPromise = DeviceId.UnknownDeviceId;
|
|
51
|
+
}
|
|
52
|
+
initialize() {
|
|
53
|
+
this.deviceIdPromise = (0, device_id_1.getDeviceId)({
|
|
54
|
+
getMachineId: this.getMachineId,
|
|
55
|
+
onError: (reason, error) => {
|
|
56
|
+
this.handleDeviceIdError(reason, String(error));
|
|
57
|
+
},
|
|
58
|
+
timeout: this.timeout,
|
|
59
|
+
abortSignal: this.abortController.signal,
|
|
60
|
+
});
|
|
61
|
+
}
|
|
62
|
+
static create(logger, timeout) {
|
|
63
|
+
const instance = new DeviceId(logger, timeout ?? exports.DEVICE_ID_TIMEOUT);
|
|
64
|
+
instance.initialize();
|
|
65
|
+
return instance;
|
|
66
|
+
}
|
|
67
|
+
/**
|
|
68
|
+
* Closes the device ID calculation promise and abort controller.
|
|
69
|
+
*/
|
|
70
|
+
close() {
|
|
71
|
+
this.abortController.abort();
|
|
72
|
+
}
|
|
73
|
+
/**
|
|
74
|
+
* Gets the device ID, waiting for the calculation to complete if necessary.
|
|
75
|
+
* @returns Promise that resolves to the device ID string
|
|
76
|
+
*/
|
|
77
|
+
get() {
|
|
78
|
+
return this.deviceIdPromise;
|
|
79
|
+
}
|
|
80
|
+
handleDeviceIdError(reason, error) {
|
|
81
|
+
this.deviceIdPromise = DeviceId.UnknownDeviceId;
|
|
82
|
+
switch (reason) {
|
|
83
|
+
case "resolutionError":
|
|
84
|
+
this.logger.debug({
|
|
85
|
+
id: logger_js_1.LogId.deviceIdResolutionError,
|
|
86
|
+
context: "deviceId",
|
|
87
|
+
message: `Resolution error: ${String(error)}`,
|
|
88
|
+
});
|
|
89
|
+
break;
|
|
90
|
+
case "timeout":
|
|
91
|
+
this.logger.debug({
|
|
92
|
+
id: logger_js_1.LogId.deviceIdTimeout,
|
|
93
|
+
context: "deviceId",
|
|
94
|
+
message: "Device ID retrieval timed out",
|
|
95
|
+
noRedaction: true,
|
|
96
|
+
});
|
|
97
|
+
break;
|
|
98
|
+
case "abort":
|
|
99
|
+
// No need to log in the case of 'abort' errors
|
|
100
|
+
break;
|
|
101
|
+
}
|
|
102
|
+
}
|
|
103
|
+
}
|
|
104
|
+
exports.DeviceId = DeviceId;
|
|
105
|
+
DeviceId.UnknownDeviceId = Promise.resolve("unknown");
|
|
106
|
+
//# sourceMappingURL=deviceId.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"deviceId.js","sourceRoot":"","sources":["../../../src/helpers/deviceId.ts"],"names":[],"mappings":";;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;AAAA,qDAAoD;AAEpD,mDAA4C;AAE/B,QAAA,iBAAiB,GAAG,IAAI,CAAC;AAEtC,MAAa,QAAQ;IASjB,YAAoB,MAAkB,EAAE,UAAkB,yBAAiB;QACvE,IAAI,CAAC,MAAM,GAAG,MAAM,CAAC;QACrB,IAAI,CAAC,OAAO,GAAG,OAAO,CAAC;QACvB,IAAI,CAAC,YAAY,GAAG,KAAK,IAAqB,EAAE;YAC5C,MAAM,aAAa,GAAG,wDAAa,iBAAiB,GAAC,CAAC;YACtD,MAAM,SAAS,GAAG,aAAa,CAAC,OAAO,EAAE,SAAS,IAAI,aAAa,CAAC,SAAS,CAAC;YAC9E,OAAO,SAAS,CAAC,IAAI,CAAC,CAAC;QAC3B,CAAC,CAAC;QACF,IAAI,CAAC,eAAe,GAAG,IAAI,eAAe,EAAE,CAAC;QAE7C,IAAI,CAAC,eAAe,GAAG,QAAQ,CAAC,eAAe,CAAC;IACpD,CAAC;IAEO,UAAU;QACd,IAAI,CAAC,eAAe,GAAG,IAAA,uBAAW,EAAC;YAC/B,YAAY,EAAE,IAAI,CAAC,YAAY;YAC/B,OAAO,EAAE,CAAC,MAAM,EAAE,KAAK,EAAE,EAAE;gBACvB,IAAI,CAAC,mBAAmB,CAAC,MAAM,EAAE,MAAM,CAAC,KAAK,CAAC,CAAC,CAAC;YACpD,CAAC;YACD,OAAO,EAAE,IAAI,CAAC,OAAO;YACrB,WAAW,EAAE,IAAI,CAAC,eAAe,CAAC,MAAM;SAC3C,CAAC,CAAC;IACP,CAAC;IAEM,MAAM,CAAC,MAAM,CAAC,MAAkB,EAAE,OAAgB;QACrD,MAAM,QAAQ,GAAG,IAAI,QAAQ,CAAC,MAAM,EAAE,OAAO,IAAI,yBAAiB,CAAC,CAAC;QACpE,QAAQ,CAAC,UAAU,EAAE,CAAC;QAEtB,OAAO,QAAQ,CAAC;IACpB,CAAC;IAED;;OAEG;IACI,KAAK;QACR,IAAI,CAAC,eAAe,CAAC,KAAK,EAAE,CAAC;IACjC,CAAC;IAED;;;OAGG;IACI,GAAG;QACN,OAAO,IAAI,CAAC,eAAe,CAAC;IAChC,CAAC;IAEO,mBAAmB,CAAC,MAAc,EAAE,KAAa;QACrD,IAAI,CAAC,eAAe,GAAG,QAAQ,CAAC,eAAe,CAAC;QAEhD,QAAQ,MAAM,EAAE,CAAC;YACb,KAAK,iBAAiB;gBAClB,IAAI,CAAC,MAAM,CAAC,KAAK,CAAC;oBACd,EAAE,EAAE,iBAAK,CAAC,uBAAuB;oBACjC,OAAO,EAAE,UAAU;oBACnB,OAAO,EAAE,qBAAqB,MAAM,CAAC,KAAK,CAAC,EAAE;iBAChD,CAAC,CAAC;gBACH,MAAM;YACV,KAAK,SAAS;gBACV,IAAI,CAAC,MAAM,CAAC,KAAK,CAAC;oBACd,EAAE,EAAE,iBAAK,CAAC,eAAe;oBACzB,OAAO,EAAE,UAAU;oBACnB,OAAO,EAAE,+BAA+B;oBACxC,WAAW,EAAE,IAAI;iBACpB,CAAC,CAAC;gBACH,MAAM;YACV,KAAK,OAAO;gBACR,+CAA+C;gBAC/C,MAAM;QACd,CAAC;IACL,CAAC;;AA9EL,4BA+EC;AA9E2B,wBAAe,GAAG,OAAO,CAAC,OAAO,CAAC,SAAS,CAAC,CAAC"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"generatePassword.d.ts","sourceRoot":"","sources":["../../../src/helpers/generatePassword.ts"],"names":[],"mappings":"AAKA,wBAAsB,sBAAsB,IAAI,OAAO,CAAC,MAAM,CAAC,CAI9D"}
|
|
@@ -0,0 +1,12 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.generateSecurePassword = generateSecurePassword;
|
|
4
|
+
const crypto_1 = require("crypto");
|
|
5
|
+
const util_1 = require("util");
|
|
6
|
+
const randomBytesAsync = (0, util_1.promisify)(crypto_1.randomBytes);
|
|
7
|
+
async function generateSecurePassword() {
|
|
8
|
+
const buf = await randomBytesAsync(16);
|
|
9
|
+
const pass = buf.toString("base64url");
|
|
10
|
+
return pass;
|
|
11
|
+
}
|
|
12
|
+
//# sourceMappingURL=generatePassword.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"generatePassword.js","sourceRoot":"","sources":["../../../src/helpers/generatePassword.ts"],"names":[],"mappings":";;AAKA,wDAIC;AATD,mCAAqC;AACrC,+BAAiC;AAEjC,MAAM,gBAAgB,GAAG,IAAA,gBAAS,EAAC,oBAAW,CAAC,CAAC;AAEzC,KAAK,UAAU,sBAAsB;IACxC,MAAM,GAAG,GAAG,MAAM,gBAAgB,CAAC,EAAE,CAAC,CAAC;IACvC,MAAM,IAAI,GAAG,GAAG,CAAC,QAAQ,CAAC,WAAW,CAAC,CAAC;IACvC,OAAO,IAAI,CAAC;AAChB,CAAC"}
|
|
@@ -0,0 +1,17 @@
|
|
|
1
|
+
import type { Document } from "mongodb";
|
|
2
|
+
import type { NodeDriverServiceProvider } from "@mongosh/service-provider-node-driver";
|
|
3
|
+
/**
|
|
4
|
+
* Check if the query plan uses an index
|
|
5
|
+
* @param explainResult The result of the explain query
|
|
6
|
+
* @returns true if an index is used, false if it's a full collection scan
|
|
7
|
+
*/
|
|
8
|
+
export declare function usesIndex(explainResult: Document): boolean;
|
|
9
|
+
/**
|
|
10
|
+
* Generate an error message for index check failure
|
|
11
|
+
*/
|
|
12
|
+
export declare function getIndexCheckErrorMessage(database: string, collection: string, operation: string): string;
|
|
13
|
+
/**
|
|
14
|
+
* Generic function to perform index usage check
|
|
15
|
+
*/
|
|
16
|
+
export declare function checkIndexUsage(provider: NodeDriverServiceProvider, database: string, collection: string, operation: string, explainCallback: () => Promise<Document>): Promise<void>;
|
|
17
|
+
//# sourceMappingURL=indexCheck.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"indexCheck.d.ts","sourceRoot":"","sources":["../../../src/helpers/indexCheck.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,QAAQ,EAAE,MAAM,SAAS,CAAC;AACxC,OAAO,KAAK,EAAE,yBAAyB,EAAE,MAAM,uCAAuC,CAAC;AAGvF;;;;GAIG;AACH,wBAAgB,SAAS,CAAC,aAAa,EAAE,QAAQ,GAAG,OAAO,CAoC1D;AAED;;GAEG;AACH,wBAAgB,yBAAyB,CAAC,QAAQ,EAAE,MAAM,EAAE,UAAU,EAAE,MAAM,EAAE,SAAS,EAAE,MAAM,GAAG,MAAM,CAEzG;AAED;;GAEG;AACH,wBAAsB,eAAe,CACjC,QAAQ,EAAE,yBAAyB,EACnC,QAAQ,EAAE,MAAM,EAChB,UAAU,EAAE,MAAM,EAClB,SAAS,EAAE,MAAM,EACjB,eAAe,EAAE,MAAM,OAAO,CAAC,QAAQ,CAAC,GACzC,OAAO,CAAC,IAAI,CAAC,CAmBf"}
|
|
@@ -0,0 +1,68 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.usesIndex = usesIndex;
|
|
4
|
+
exports.getIndexCheckErrorMessage = getIndexCheckErrorMessage;
|
|
5
|
+
exports.checkIndexUsage = checkIndexUsage;
|
|
6
|
+
const errors_js_1 = require("../common/errors.js");
|
|
7
|
+
/**
|
|
8
|
+
* Check if the query plan uses an index
|
|
9
|
+
* @param explainResult The result of the explain query
|
|
10
|
+
* @returns true if an index is used, false if it's a full collection scan
|
|
11
|
+
*/
|
|
12
|
+
function usesIndex(explainResult) {
|
|
13
|
+
const queryPlanner = explainResult?.queryPlanner;
|
|
14
|
+
const winningPlan = queryPlanner?.winningPlan;
|
|
15
|
+
const stage = winningPlan?.stage;
|
|
16
|
+
const inputStage = winningPlan?.inputStage;
|
|
17
|
+
// Check for index scan stages (including MongoDB 8.0+ stages)
|
|
18
|
+
const indexScanStages = [
|
|
19
|
+
"IXSCAN",
|
|
20
|
+
"COUNT_SCAN",
|
|
21
|
+
"EXPRESS_IXSCAN",
|
|
22
|
+
"EXPRESS_CLUSTERED_IXSCAN",
|
|
23
|
+
"EXPRESS_UPDATE",
|
|
24
|
+
"EXPRESS_DELETE",
|
|
25
|
+
"IDHACK",
|
|
26
|
+
];
|
|
27
|
+
if (stage && indexScanStages.includes(stage)) {
|
|
28
|
+
return true;
|
|
29
|
+
}
|
|
30
|
+
if (inputStage && inputStage.stage && indexScanStages.includes(inputStage.stage)) {
|
|
31
|
+
return true;
|
|
32
|
+
}
|
|
33
|
+
// Recursively check deeper stages
|
|
34
|
+
if (inputStage && inputStage.inputStage) {
|
|
35
|
+
return usesIndex({ queryPlanner: { winningPlan: inputStage } });
|
|
36
|
+
}
|
|
37
|
+
if (stage === "COLLSCAN") {
|
|
38
|
+
return false;
|
|
39
|
+
}
|
|
40
|
+
// Default to false (conservative approach)
|
|
41
|
+
return false;
|
|
42
|
+
}
|
|
43
|
+
/**
|
|
44
|
+
* Generate an error message for index check failure
|
|
45
|
+
*/
|
|
46
|
+
function getIndexCheckErrorMessage(database, collection, operation) {
|
|
47
|
+
return `Index check failed: The ${operation} operation on "${database}.${collection}" performs a collection scan (COLLSCAN) instead of using an index. Consider adding an index for better performance. Use 'explain' tool for query plan analysis or 'collection-indexes' to view existing indexes. To disable this check, set MDB_MCP_INDEX_CHECK to false.`;
|
|
48
|
+
}
|
|
49
|
+
/**
|
|
50
|
+
* Generic function to perform index usage check
|
|
51
|
+
*/
|
|
52
|
+
async function checkIndexUsage(provider, database, collection, operation, explainCallback) {
|
|
53
|
+
try {
|
|
54
|
+
const explainResult = await explainCallback();
|
|
55
|
+
if (!usesIndex(explainResult)) {
|
|
56
|
+
throw new errors_js_1.MongoDBError(errors_js_1.ErrorCodes.ForbiddenCollscan, getIndexCheckErrorMessage(database, collection, operation));
|
|
57
|
+
}
|
|
58
|
+
}
|
|
59
|
+
catch (error) {
|
|
60
|
+
if (error instanceof errors_js_1.MongoDBError && error.code === errors_js_1.ErrorCodes.ForbiddenCollscan) {
|
|
61
|
+
throw error;
|
|
62
|
+
}
|
|
63
|
+
// If explain itself fails, log but do not prevent query execution
|
|
64
|
+
// This avoids blocking normal queries in special cases (e.g., permission issues)
|
|
65
|
+
console.warn(`Index check failed to execute explain for ${operation} on ${database}.${collection}:`, error);
|
|
66
|
+
}
|
|
67
|
+
}
|
|
68
|
+
//# sourceMappingURL=indexCheck.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"indexCheck.js","sourceRoot":"","sources":["../../../src/helpers/indexCheck.ts"],"names":[],"mappings":";;AASA,8BAoCC;AAKD,8DAEC;AAKD,0CAyBC;AAhFD,mDAA+D;AAE/D;;;;GAIG;AACH,SAAgB,SAAS,CAAC,aAAuB;IAC7C,MAAM,YAAY,GAAG,aAAa,EAAE,YAAoC,CAAC;IACzE,MAAM,WAAW,GAAG,YAAY,EAAE,WAAmC,CAAC;IACtE,MAAM,KAAK,GAAG,WAAW,EAAE,KAA2B,CAAC;IACvD,MAAM,UAAU,GAAG,WAAW,EAAE,UAAkC,CAAC;IAEnE,8DAA8D;IAC9D,MAAM,eAAe,GAAG;QACpB,QAAQ;QACR,YAAY;QACZ,gBAAgB;QAChB,0BAA0B;QAC1B,gBAAgB;QAChB,gBAAgB;QAChB,QAAQ;KACX,CAAC;IAEF,IAAI,KAAK,IAAI,eAAe,CAAC,QAAQ,CAAC,KAAK,CAAC,EAAE,CAAC;QAC3C,OAAO,IAAI,CAAC;IAChB,CAAC;IAED,IAAI,UAAU,IAAI,UAAU,CAAC,KAAK,IAAI,eAAe,CAAC,QAAQ,CAAC,UAAU,CAAC,KAAe,CAAC,EAAE,CAAC;QACzF,OAAO,IAAI,CAAC;IAChB,CAAC;IAED,kCAAkC;IAClC,IAAI,UAAU,IAAI,UAAU,CAAC,UAAU,EAAE,CAAC;QACtC,OAAO,SAAS,CAAC,EAAE,YAAY,EAAE,EAAE,WAAW,EAAE,UAAU,EAAE,EAAE,CAAC,CAAC;IACpE,CAAC;IAED,IAAI,KAAK,KAAK,UAAU,EAAE,CAAC;QACvB,OAAO,KAAK,CAAC;IACjB,CAAC;IAED,2CAA2C;IAC3C,OAAO,KAAK,CAAC;AACjB,CAAC;AAED;;GAEG;AACH,SAAgB,yBAAyB,CAAC,QAAgB,EAAE,UAAkB,EAAE,SAAiB;IAC7F,OAAO,2BAA2B,SAAS,kBAAkB,QAAQ,IAAI,UAAU,2QAA2Q,CAAC;AACnW,CAAC;AAED;;GAEG;AACI,KAAK,UAAU,eAAe,CACjC,QAAmC,EACnC,QAAgB,EAChB,UAAkB,EAClB,SAAiB,EACjB,eAAwC;IAExC,IAAI,CAAC;QACD,MAAM,aAAa,GAAG,MAAM,eAAe,EAAE,CAAC;QAE9C,IAAI,CAAC,SAAS,CAAC,aAAa,CAAC,EAAE,CAAC;YAC5B,MAAM,IAAI,wBAAY,CAClB,sBAAU,CAAC,iBAAiB,EAC5B,yBAAyB,CAAC,QAAQ,EAAE,UAAU,EAAE,SAAS,CAAC,CAC7D,CAAC;QACN,CAAC;IACL,CAAC;IAAC,OAAO,KAAK,EAAE,CAAC;QACb,IAAI,KAAK,YAAY,wBAAY,IAAI,KAAK,CAAC,IAAI,KAAK,sBAAU,CAAC,iBAAiB,EAAE,CAAC;YAC/E,MAAM,KAAK,CAAC;QAChB,CAAC;QAED,kEAAkE;QAClE,iFAAiF;QACjF,OAAO,CAAC,IAAI,CAAC,6CAA6C,SAAS,OAAO,QAAQ,IAAI,UAAU,GAAG,EAAE,KAAK,CAAC,CAAC;IAChH,CAAC;AACL,CAAC"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../src/index.ts"],"names":[],"mappings":""}
|