mongodb-mcp-server 0.1.3 → 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 +149 -32
- 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/{src/common/atlas/apiClientError.ts → dist/cjs/common/atlas/apiClientError.js} +20 -38
- 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/{src/helpers/indexCheck.ts → dist/cjs/helpers/indexCheck.js} +19 -34
- 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/{src/telemetry/eventCache.ts → dist/cjs/telemetry/eventCache.js} +14 -19
- 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/{src/telemetry/types.ts → dist/cjs/telemetry/types.d.ts} +3 -7
- package/dist/cjs/telemetry/types.d.ts.map +1 -0
- package/dist/cjs/telemetry/types.js +3 -0
- package/dist/{telemetry → cjs/telemetry}/types.js.map +1 -1
- package/dist/cjs/tools/atlas/atlasTool.d.ts +18 -0
- package/dist/cjs/tools/atlas/atlasTool.d.ts.map +1 -0
- package/{src/tools/atlas/atlasTool.ts → dist/cjs/tools/atlas/atlasTool.js} +27 -38
- 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/{src/tools/atlas/create/createFreeCluster.ts → dist/cjs/tools/atlas/create/createFreeCluster.js} +23 -20
- 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/{tools/atlas/tools.js → cjs/tools/atlas/tools.d.ts} +3 -16
- 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/{src/tools/mongodb/metadata/collectionStorageSize.ts → dist/cjs/tools/mongodb/metadata/collectionStorageSize.js} +21 -28
- 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/{src/tools/mongodb/tools.ts → dist/cjs/tools/mongodb/tools.d.ts} +4 -24
- 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/{src/tools/mongodb/update/renameCollection.ts → dist/cjs/tools/mongodb/update/renameCollection.js} +21 -28
- 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/{src/tools/mongodb/update/updateMany.ts → dist/cjs/tools/mongodb/update/updateMany.js} +35 -40
- 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/{src/tools/tool.ts → dist/cjs/tools/tool.js} +90 -103
- 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/{common → esm/common}/atlas/apiClient.js +133 -21
- 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/{common → esm/common}/atlas/cluster.js +8 -4
- 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 +20 -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 +28 -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/{helpers → esm/helpers}/indexCheck.js +1 -1
- 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/{server.js → esm/server.js} +83 -40
- 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/{telemetry → esm/telemetry}/constants.js +1 -1
- 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/{telemetry → esm/telemetry}/telemetry.js +42 -37
- 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/{tools → esm/tools}/atlas/atlasTool.js +8 -4
- 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/{tools → esm/tools}/atlas/create/createAccessList.js +9 -10
- 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/{tools → esm/tools}/atlas/create/createDBUser.js +4 -2
- 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/{tools → esm/tools}/atlas/create/createFreeCluster.js +2 -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/{tools → esm/tools}/atlas/read/inspectAccessList.js +12 -13
- 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/{tools → esm/tools}/atlas/read/inspectCluster.js +3 -7
- 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/{tools → esm/tools}/atlas/read/listAlerts.js +2 -1
- 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/{tools → esm/tools}/atlas/read/listClusters.js +6 -12
- 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/{tools → esm/tools}/atlas/read/listDBUsers.js +5 -2
- 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/{tools → esm/tools}/atlas/read/listOrgs.js +6 -3
- 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/{tools → esm/tools}/atlas/read/listProjects.js +8 -3
- 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/{src/tools/atlas/tools.ts → dist/esm/tools/atlas/tools.js} +2 -2
- 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/{tools/mongodb/metadata → esm/tools/mongodb/connect}/connect.js +11 -5
- 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/{tools → esm/tools}/mongodb/create/createIndex.js +1 -1
- 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/{tools → esm/tools}/mongodb/create/insertMany.js +1 -1
- 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/{tools → esm/tools}/mongodb/delete/deleteMany.js +2 -1
- 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/{tools → esm/tools}/mongodb/metadata/collectionSchema.js +2 -10
- 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/{tools → esm/tools}/mongodb/metadata/dbStats.js +2 -10
- 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/{tools → esm/tools}/mongodb/metadata/explain.js +3 -11
- 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/{tools → esm/tools}/mongodb/metadata/listCollections.js +3 -7
- 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/{tools → esm/tools}/mongodb/metadata/listDatabases.js +4 -6
- 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/{tools → esm/tools}/mongodb/read/aggregate.js +4 -15
- 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/{tools → esm/tools}/mongodb/read/collectionIndexes.js +6 -12
- 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/{tools → esm/tools}/mongodb/read/count.js +2 -1
- 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/{tools → esm/tools}/mongodb/read/find.js +10 -18
- 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/{tools → esm/tools}/mongodb/tools.js +3 -1
- 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/{tools → esm/tools}/mongodb/update/updateMany.js +4 -2
- 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/{tools → esm/tools}/tool.js +55 -9
- 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/{helpers/EJsonTransport.js → esm/transports/stdio.js} +27 -2
- 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 -51
- package/package.json +84 -41
- 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/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 -50
- package/.github/workflows/codeql.yml +0 -34
- package/.github/workflows/docker.yaml +0 -57
- 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 -17
- package/.vscode/settings.json +0 -11
- package/CONTRIBUTING.md +0 -185
- package/Dockerfile +0 -10
- package/dist/common/atlas/apiClient.js.map +0 -1
- package/dist/common/atlas/apiClientError.js.map +0 -1
- package/dist/common/atlas/cluster.js.map +0 -1
- package/dist/common/atlas/generatePassword.js.map +0 -1
- package/dist/config.js +0 -83
- package/dist/config.js.map +0 -1
- package/dist/errors.js.map +0 -1
- package/dist/helpers/EJsonTransport.js.map +0 -1
- package/dist/helpers/connectionOptions.js +0 -10
- package/dist/helpers/connectionOptions.js.map +0 -1
- package/dist/helpers/indexCheck.js.map +0 -1
- package/dist/helpers/packageInfo.js +0 -6
- package/dist/helpers/packageInfo.js.map +0 -1
- package/dist/index.js.map +0 -1
- package/dist/logger.js +0 -150
- package/dist/logger.js.map +0 -1
- package/dist/server.js.map +0 -1
- package/dist/session.js +0 -84
- package/dist/session.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.map +0 -1
- package/dist/tools/atlas/atlasTool.js.map +0 -1
- package/dist/tools/atlas/create/createAccessList.js.map +0 -1
- 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/metadata/connectCluster.js +0 -100
- package/dist/tools/atlas/metadata/connectCluster.js.map +0 -1
- package/dist/tools/atlas/read/inspectAccessList.js.map +0 -1
- package/dist/tools/atlas/read/inspectCluster.js.map +0 -1
- package/dist/tools/atlas/read/listAlerts.js.map +0 -1
- package/dist/tools/atlas/read/listClusters.js.map +0 -1
- package/dist/tools/atlas/read/listDBUsers.js.map +0 -1
- package/dist/tools/atlas/read/listOrgs.js.map +0 -1
- package/dist/tools/atlas/read/listProjects.js.map +0 -1
- package/dist/tools/atlas/tools.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.map +0 -1
- package/dist/tools/mongodb/metadata/collectionStorageSize.js.map +0 -1
- package/dist/tools/mongodb/metadata/connect.js.map +0 -1
- package/dist/tools/mongodb/metadata/dbStats.js.map +0 -1
- package/dist/tools/mongodb/metadata/explain.js.map +0 -1
- package/dist/tools/mongodb/metadata/listCollections.js.map +0 -1
- 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 -84
- package/dist/tools/mongodb/mongodbTool.js.map +0 -1
- package/dist/tools/mongodb/read/aggregate.js.map +0 -1
- 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.map +0 -1
- 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.map +0 -1
- package/eslint.config.js +0 -55
- package/global.d.ts +0 -1
- package/jest.config.cjs +0 -22
- package/scripts/apply.ts +0 -135
- package/scripts/filter.ts +0 -76
- package/scripts/generate.sh +0 -11
- package/src/common/atlas/apiClient.ts +0 -387
- package/src/common/atlas/cluster.ts +0 -94
- package/src/common/atlas/generatePassword.ts +0 -10
- package/src/common/atlas/openapi.d.ts +0 -7486
- package/src/config.ts +0 -125
- package/src/errors.ts +0 -14
- package/src/helpers/EJsonTransport.ts +0 -47
- package/src/helpers/connectionOptions.ts +0 -20
- package/src/helpers/packageInfo.ts +0 -6
- package/src/index.ts +0 -58
- package/src/logger.ts +0 -190
- package/src/server.ts +0 -206
- package/src/session.ts +0 -120
- package/src/telemetry/constants.ts +0 -14
- package/src/telemetry/telemetry.ts +0 -194
- package/src/tools/atlas/create/createAccessList.ts +0 -76
- package/src/tools/atlas/create/createDBUser.ts +0 -88
- package/src/tools/atlas/create/createProject.ts +0 -68
- package/src/tools/atlas/metadata/connectCluster.ts +0 -121
- 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/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 -57
- 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/connect.ts +0 -96
- 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 -100
- 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 -54
- package/src/tools/mongodb/read/find.ts +0 -70
- package/src/types/mongodb-connection-string-url.d.ts +0 -69
- package/src/types/mongodb-redact.d.ts +0 -4
- package/tests/integration/helpers.ts +0 -265
- package/tests/integration/inMemoryTransport.ts +0 -59
- package/tests/integration/indexCheck.test.ts +0 -463
- package/tests/integration/server.test.ts +0 -87
- package/tests/integration/telemetry.test.ts +0 -28
- package/tests/integration/tools/atlas/accessLists.test.ts +0 -98
- package/tests/integration/tools/atlas/alerts.test.ts +0 -42
- package/tests/integration/tools/atlas/atlasHelpers.ts +0 -108
- package/tests/integration/tools/atlas/clusters.test.ts +0 -185
- package/tests/integration/tools/atlas/dbUsers.test.ts +0 -105
- package/tests/integration/tools/atlas/orgs.test.ts +0 -24
- package/tests/integration/tools/atlas/projects.test.ts +0 -78
- package/tests/integration/tools/mongodb/create/createCollection.test.ts +0 -95
- package/tests/integration/tools/mongodb/create/createIndex.test.ts +0 -203
- package/tests/integration/tools/mongodb/create/insertMany.test.ts +0 -98
- package/tests/integration/tools/mongodb/delete/deleteMany.test.ts +0 -154
- package/tests/integration/tools/mongodb/delete/dropCollection.test.ts +0 -69
- package/tests/integration/tools/mongodb/delete/dropDatabase.test.ts +0 -80
- package/tests/integration/tools/mongodb/metadata/collectionSchema.test.ts +0 -154
- package/tests/integration/tools/mongodb/metadata/collectionStorageSize.test.ts +0 -86
- package/tests/integration/tools/mongodb/metadata/connect.test.ts +0 -128
- package/tests/integration/tools/mongodb/metadata/dbStats.test.ts +0 -104
- package/tests/integration/tools/mongodb/metadata/explain.test.ts +0 -171
- package/tests/integration/tools/mongodb/metadata/listCollections.test.ts +0 -76
- package/tests/integration/tools/mongodb/metadata/listDatabases.test.ts +0 -77
- package/tests/integration/tools/mongodb/metadata/logs.test.ts +0 -83
- package/tests/integration/tools/mongodb/mongodbHelpers.ts +0 -171
- package/tests/integration/tools/mongodb/read/aggregate.test.ts +0 -114
- package/tests/integration/tools/mongodb/read/collectionIndexes.test.ts +0 -99
- package/tests/integration/tools/mongodb/read/count.test.ts +0 -95
- package/tests/integration/tools/mongodb/read/find.test.ts +0 -210
- package/tests/integration/tools/mongodb/update/renameCollection.test.ts +0 -194
- package/tests/integration/tools/mongodb/update/updateMany.test.ts +0 -238
- package/tests/unit/EJsonTransport.test.ts +0 -71
- package/tests/unit/apiClient.test.ts +0 -193
- package/tests/unit/indexCheck.test.ts +0 -149
- package/tests/unit/session.test.ts +0 -65
- package/tests/unit/telemetry.test.ts +0 -322
- package/tsconfig.build.json +0 -20
- package/tsconfig.jest.json +0 -9
- package/tsconfig.json +0 -9
- /package/dist/{common → esm/common}/atlas/apiClientError.js +0 -0
- /package/dist/{errors.js → esm/common/errors.js} +0 -0
- /package/dist/{common/atlas → esm/helpers}/generatePassword.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/createProject.js +0 -0
- /package/dist/{tools → esm/tools}/mongodb/create/createCollection.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/update/renameCollection.js +0 -0
|
@@ -0,0 +1,225 @@
|
|
|
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.ConnectionManager = void 0;
|
|
7
|
+
const service_provider_node_driver_1 = require("@mongosh/service-provider-node-driver");
|
|
8
|
+
const events_1 = __importDefault(require("events"));
|
|
9
|
+
const connectionOptions_js_1 = require("../helpers/connectionOptions.js");
|
|
10
|
+
const packageInfo_js_1 = require("./packageInfo.js");
|
|
11
|
+
const mongodb_connection_string_url_1 = __importDefault(require("mongodb-connection-string-url"));
|
|
12
|
+
const errors_js_1 = require("./errors.js");
|
|
13
|
+
const logger_js_1 = require("./logger.js");
|
|
14
|
+
const arg_parser_1 = require("@mongosh/arg-parser");
|
|
15
|
+
class ConnectionManager extends events_1.default {
|
|
16
|
+
constructor(userConfig, driverOptions, logger, deviceId, bus) {
|
|
17
|
+
super();
|
|
18
|
+
this.userConfig = userConfig;
|
|
19
|
+
this.driverOptions = driverOptions;
|
|
20
|
+
this.logger = logger;
|
|
21
|
+
this.bus = bus ?? new events_1.default();
|
|
22
|
+
this.state = { tag: "disconnected" };
|
|
23
|
+
this.bus.on("mongodb-oidc-plugin:auth-failed", this.onOidcAuthFailed.bind(this));
|
|
24
|
+
this.bus.on("mongodb-oidc-plugin:auth-succeeded", this.onOidcAuthSucceeded.bind(this));
|
|
25
|
+
this.deviceId = deviceId;
|
|
26
|
+
this.clientName = "unknown";
|
|
27
|
+
}
|
|
28
|
+
setClientName(clientName) {
|
|
29
|
+
this.clientName = clientName;
|
|
30
|
+
}
|
|
31
|
+
async connect(settings) {
|
|
32
|
+
var _a, _b, _c, _d;
|
|
33
|
+
this.emit("connection-request", this.state);
|
|
34
|
+
if (this.state.tag === "connected" || this.state.tag === "connecting") {
|
|
35
|
+
await this.disconnect();
|
|
36
|
+
}
|
|
37
|
+
let serviceProvider;
|
|
38
|
+
let connectionInfo;
|
|
39
|
+
let connectionStringAuthType = "scram";
|
|
40
|
+
try {
|
|
41
|
+
settings = { ...settings };
|
|
42
|
+
const appNameComponents = {
|
|
43
|
+
appName: `${packageInfo_js_1.packageInfo.mcpServerName} ${packageInfo_js_1.packageInfo.version}`,
|
|
44
|
+
deviceId: this.deviceId.get(),
|
|
45
|
+
clientName: this.clientName,
|
|
46
|
+
};
|
|
47
|
+
settings.connectionString = await (0, connectionOptions_js_1.setAppNameParamIfMissing)({
|
|
48
|
+
connectionString: settings.connectionString,
|
|
49
|
+
components: appNameComponents,
|
|
50
|
+
});
|
|
51
|
+
connectionInfo = (0, arg_parser_1.generateConnectionInfoFromCliArgs)({
|
|
52
|
+
...this.userConfig,
|
|
53
|
+
...this.driverOptions,
|
|
54
|
+
connectionSpecifier: settings.connectionString,
|
|
55
|
+
});
|
|
56
|
+
if (connectionInfo.driverOptions.oidc) {
|
|
57
|
+
(_a = connectionInfo.driverOptions.oidc).allowedFlows ?? (_a.allowedFlows = ["auth-code"]);
|
|
58
|
+
(_b = connectionInfo.driverOptions.oidc).notifyDeviceFlow ?? (_b.notifyDeviceFlow = this.onOidcNotifyDeviceFlow.bind(this));
|
|
59
|
+
}
|
|
60
|
+
(_c = connectionInfo.driverOptions).proxy ?? (_c.proxy = { useEnvironmentVariableProxies: true });
|
|
61
|
+
(_d = connectionInfo.driverOptions).applyProxyToOIDC ?? (_d.applyProxyToOIDC = true);
|
|
62
|
+
connectionStringAuthType = ConnectionManager.inferConnectionTypeFromSettings(this.userConfig, connectionInfo);
|
|
63
|
+
serviceProvider = await service_provider_node_driver_1.NodeDriverServiceProvider.connect(connectionInfo.connectionString, {
|
|
64
|
+
productDocsLink: "https://github.com/mongodb-js/mongodb-mcp-server/",
|
|
65
|
+
productName: "MongoDB MCP",
|
|
66
|
+
...connectionInfo.driverOptions,
|
|
67
|
+
}, undefined, this.bus);
|
|
68
|
+
}
|
|
69
|
+
catch (error) {
|
|
70
|
+
const errorReason = error instanceof Error ? error.message : `${error}`;
|
|
71
|
+
this.changeState("connection-error", {
|
|
72
|
+
tag: "errored",
|
|
73
|
+
errorReason,
|
|
74
|
+
connectionStringAuthType,
|
|
75
|
+
connectedAtlasCluster: settings.atlas,
|
|
76
|
+
});
|
|
77
|
+
throw new errors_js_1.MongoDBError(errors_js_1.ErrorCodes.MisconfiguredConnectionString, errorReason);
|
|
78
|
+
}
|
|
79
|
+
try {
|
|
80
|
+
const connectionType = ConnectionManager.inferConnectionTypeFromSettings(this.userConfig, connectionInfo);
|
|
81
|
+
if (connectionType.startsWith("oidc")) {
|
|
82
|
+
void this.pingAndForget(serviceProvider);
|
|
83
|
+
return this.changeState("connection-request", {
|
|
84
|
+
tag: "connecting",
|
|
85
|
+
connectedAtlasCluster: settings.atlas,
|
|
86
|
+
serviceProvider,
|
|
87
|
+
connectionStringAuthType: connectionType,
|
|
88
|
+
oidcConnectionType: connectionType,
|
|
89
|
+
});
|
|
90
|
+
}
|
|
91
|
+
await serviceProvider?.runCommand?.("admin", { hello: 1 });
|
|
92
|
+
return this.changeState("connection-success", {
|
|
93
|
+
tag: "connected",
|
|
94
|
+
connectedAtlasCluster: settings.atlas,
|
|
95
|
+
serviceProvider,
|
|
96
|
+
connectionStringAuthType: connectionType,
|
|
97
|
+
});
|
|
98
|
+
}
|
|
99
|
+
catch (error) {
|
|
100
|
+
const errorReason = error instanceof Error ? error.message : `${error}`;
|
|
101
|
+
this.changeState("connection-error", {
|
|
102
|
+
tag: "errored",
|
|
103
|
+
errorReason,
|
|
104
|
+
connectionStringAuthType,
|
|
105
|
+
connectedAtlasCluster: settings.atlas,
|
|
106
|
+
});
|
|
107
|
+
throw new errors_js_1.MongoDBError(errors_js_1.ErrorCodes.NotConnectedToMongoDB, errorReason);
|
|
108
|
+
}
|
|
109
|
+
}
|
|
110
|
+
async disconnect() {
|
|
111
|
+
if (this.state.tag === "disconnected" || this.state.tag === "errored") {
|
|
112
|
+
return this.state;
|
|
113
|
+
}
|
|
114
|
+
if (this.state.tag === "connected" || this.state.tag === "connecting") {
|
|
115
|
+
try {
|
|
116
|
+
await this.state.serviceProvider?.close(true);
|
|
117
|
+
}
|
|
118
|
+
finally {
|
|
119
|
+
this.changeState("connection-close", {
|
|
120
|
+
tag: "disconnected",
|
|
121
|
+
});
|
|
122
|
+
}
|
|
123
|
+
}
|
|
124
|
+
return { tag: "disconnected" };
|
|
125
|
+
}
|
|
126
|
+
get currentConnectionState() {
|
|
127
|
+
return this.state;
|
|
128
|
+
}
|
|
129
|
+
changeState(event, newState) {
|
|
130
|
+
this.state = newState;
|
|
131
|
+
// TypeScript doesn't seem to be happy with the spread operator and generics
|
|
132
|
+
// eslint-disable-next-line
|
|
133
|
+
this.emit(event, ...[newState]);
|
|
134
|
+
return newState;
|
|
135
|
+
}
|
|
136
|
+
onOidcAuthFailed(error) {
|
|
137
|
+
if (this.state.tag === "connecting" && this.state.connectionStringAuthType?.startsWith("oidc")) {
|
|
138
|
+
void this.disconnectOnOidcError(error);
|
|
139
|
+
}
|
|
140
|
+
}
|
|
141
|
+
onOidcAuthSucceeded() {
|
|
142
|
+
if (this.state.tag === "connecting" && this.state.connectionStringAuthType?.startsWith("oidc")) {
|
|
143
|
+
this.changeState("connection-success", { ...this.state, tag: "connected" });
|
|
144
|
+
}
|
|
145
|
+
this.logger.info({
|
|
146
|
+
id: logger_js_1.LogId.oidcFlow,
|
|
147
|
+
context: "mongodb-oidc-plugin:auth-succeeded",
|
|
148
|
+
message: "Authenticated successfully.",
|
|
149
|
+
});
|
|
150
|
+
}
|
|
151
|
+
onOidcNotifyDeviceFlow(flowInfo) {
|
|
152
|
+
if (this.state.tag === "connecting" && this.state.connectionStringAuthType?.startsWith("oidc")) {
|
|
153
|
+
this.changeState("connection-request", {
|
|
154
|
+
...this.state,
|
|
155
|
+
tag: "connecting",
|
|
156
|
+
connectionStringAuthType: "oidc-device-flow",
|
|
157
|
+
oidcLoginUrl: flowInfo.verificationUrl,
|
|
158
|
+
oidcUserCode: flowInfo.userCode,
|
|
159
|
+
});
|
|
160
|
+
}
|
|
161
|
+
this.logger.info({
|
|
162
|
+
id: logger_js_1.LogId.oidcFlow,
|
|
163
|
+
context: "mongodb-oidc-plugin:notify-device-flow",
|
|
164
|
+
message: "OIDC Flow changed automatically to device flow.",
|
|
165
|
+
});
|
|
166
|
+
}
|
|
167
|
+
static inferConnectionTypeFromSettings(config, settings) {
|
|
168
|
+
const connString = new mongodb_connection_string_url_1.default(settings.connectionString);
|
|
169
|
+
const searchParams = connString.typedSearchParams();
|
|
170
|
+
switch (searchParams.get("authMechanism")) {
|
|
171
|
+
case "MONGODB-OIDC": {
|
|
172
|
+
if (config.transport === "stdio" && config.browser) {
|
|
173
|
+
return "oidc-auth-flow";
|
|
174
|
+
}
|
|
175
|
+
if (config.transport === "http" && config.httpHost === "127.0.0.1" && config.browser) {
|
|
176
|
+
return "oidc-auth-flow";
|
|
177
|
+
}
|
|
178
|
+
return "oidc-device-flow";
|
|
179
|
+
}
|
|
180
|
+
case "MONGODB-X509":
|
|
181
|
+
return "x.509";
|
|
182
|
+
case "GSSAPI":
|
|
183
|
+
return "kerberos";
|
|
184
|
+
case "PLAIN":
|
|
185
|
+
if (searchParams.get("authSource") === "$external") {
|
|
186
|
+
return "ldap";
|
|
187
|
+
}
|
|
188
|
+
return "scram";
|
|
189
|
+
// default should catch also null, but eslint complains
|
|
190
|
+
// about it.
|
|
191
|
+
case null:
|
|
192
|
+
default:
|
|
193
|
+
return "scram";
|
|
194
|
+
}
|
|
195
|
+
}
|
|
196
|
+
async pingAndForget(serviceProvider) {
|
|
197
|
+
try {
|
|
198
|
+
await serviceProvider?.runCommand?.("admin", { hello: 1 });
|
|
199
|
+
}
|
|
200
|
+
catch (error) {
|
|
201
|
+
this.logger.warning({
|
|
202
|
+
id: logger_js_1.LogId.oidcFlow,
|
|
203
|
+
context: "pingAndForget",
|
|
204
|
+
message: String(error),
|
|
205
|
+
});
|
|
206
|
+
}
|
|
207
|
+
}
|
|
208
|
+
async disconnectOnOidcError(error) {
|
|
209
|
+
try {
|
|
210
|
+
await this.disconnect();
|
|
211
|
+
}
|
|
212
|
+
catch (error) {
|
|
213
|
+
this.logger.warning({
|
|
214
|
+
id: logger_js_1.LogId.oidcFlow,
|
|
215
|
+
context: "disconnectOnOidcError",
|
|
216
|
+
message: String(error),
|
|
217
|
+
});
|
|
218
|
+
}
|
|
219
|
+
finally {
|
|
220
|
+
this.changeState("connection-error", { tag: "errored", errorReason: String(error) });
|
|
221
|
+
}
|
|
222
|
+
}
|
|
223
|
+
}
|
|
224
|
+
exports.ConnectionManager = ConnectionManager;
|
|
225
|
+
//# sourceMappingURL=connectionManager.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"connectionManager.js","sourceRoot":"","sources":["../../../src/common/connectionManager.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,10 @@
|
|
|
1
|
+
export declare enum ErrorCodes {
|
|
2
|
+
NotConnectedToMongoDB = 1000000,
|
|
3
|
+
MisconfiguredConnectionString = 1000001,
|
|
4
|
+
ForbiddenCollscan = 1000002
|
|
5
|
+
}
|
|
6
|
+
export declare class MongoDBError extends Error {
|
|
7
|
+
code: ErrorCodes;
|
|
8
|
+
constructor(code: ErrorCodes, message: string);
|
|
9
|
+
}
|
|
10
|
+
//# sourceMappingURL=errors.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"errors.d.ts","sourceRoot":"","sources":["../../../src/common/errors.ts"],"names":[],"mappings":"AAAA,oBAAY,UAAU;IAClB,qBAAqB,UAAY;IACjC,6BAA6B,UAAY;IACzC,iBAAiB,UAAY;CAChC;AAED,qBAAa,YAAa,SAAQ,KAAK;IAExB,IAAI,EAAE,UAAU;gBAAhB,IAAI,EAAE,UAAU,EACvB,OAAO,EAAE,MAAM;CAItB"}
|
|
@@ -0,0 +1,17 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.MongoDBError = exports.ErrorCodes = void 0;
|
|
4
|
+
var ErrorCodes;
|
|
5
|
+
(function (ErrorCodes) {
|
|
6
|
+
ErrorCodes[ErrorCodes["NotConnectedToMongoDB"] = 1000000] = "NotConnectedToMongoDB";
|
|
7
|
+
ErrorCodes[ErrorCodes["MisconfiguredConnectionString"] = 1000001] = "MisconfiguredConnectionString";
|
|
8
|
+
ErrorCodes[ErrorCodes["ForbiddenCollscan"] = 1000002] = "ForbiddenCollscan";
|
|
9
|
+
})(ErrorCodes || (exports.ErrorCodes = ErrorCodes = {}));
|
|
10
|
+
class MongoDBError extends Error {
|
|
11
|
+
constructor(code, message) {
|
|
12
|
+
super(message);
|
|
13
|
+
this.code = code;
|
|
14
|
+
}
|
|
15
|
+
}
|
|
16
|
+
exports.MongoDBError = MongoDBError;
|
|
17
|
+
//# sourceMappingURL=errors.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"errors.js","sourceRoot":"","sources":["../../../src/common/errors.ts"],"names":[],"mappings":";;;AAAA,IAAY,UAIX;AAJD,WAAY,UAAU;IAClB,mFAAiC,CAAA;IACjC,mGAAyC,CAAA;IACzC,2EAA6B,CAAA;AACjC,CAAC,EAJW,UAAU,0BAAV,UAAU,QAIrB;AAED,MAAa,YAAa,SAAQ,KAAK;IACnC,YACW,IAAgB,EACvB,OAAe;QAEf,KAAK,CAAC,OAAO,CAAC,CAAC;QAHR,SAAI,GAAJ,IAAI,CAAY;IAI3B,CAAC;CACJ;AAPD,oCAOC"}
|
|
@@ -0,0 +1,86 @@
|
|
|
1
|
+
import z from "zod";
|
|
2
|
+
import EventEmitter from "events";
|
|
3
|
+
import type { AggregationCursor, FindCursor } from "mongodb";
|
|
4
|
+
import type { UserConfig } from "./config.js";
|
|
5
|
+
import type { LoggerBase } from "./logger.js";
|
|
6
|
+
export declare const jsonExportFormat: z.ZodEnum<["relaxed", "canonical"]>;
|
|
7
|
+
export type JSONExportFormat = z.infer<typeof jsonExportFormat>;
|
|
8
|
+
interface CommonExportData {
|
|
9
|
+
exportName: string;
|
|
10
|
+
exportTitle: string;
|
|
11
|
+
exportURI: string;
|
|
12
|
+
exportPath: string;
|
|
13
|
+
}
|
|
14
|
+
interface ReadyExport extends CommonExportData {
|
|
15
|
+
exportStatus: "ready";
|
|
16
|
+
exportCreatedAt: number;
|
|
17
|
+
}
|
|
18
|
+
interface InProgressExport extends CommonExportData {
|
|
19
|
+
exportStatus: "in-progress";
|
|
20
|
+
}
|
|
21
|
+
type StoredExport = ReadyExport | InProgressExport;
|
|
22
|
+
/**
|
|
23
|
+
* Ideally just exportName and exportURI should be made publicly available but
|
|
24
|
+
* we also make exportPath available because the export tool, also returns the
|
|
25
|
+
* exportPath in its response when the MCP server is running connected to stdio
|
|
26
|
+
* transport. The reasoning behind this is that a few clients, Cursor in
|
|
27
|
+
* particular, as of the date of this writing (7 August 2025) cannot refer to
|
|
28
|
+
* resource URIs which means they have no means to access the exported resource.
|
|
29
|
+
* As of this writing, majority of the usage of our MCP server is behind STDIO
|
|
30
|
+
* transport so we can assume that for most of the usages, if not all, the MCP
|
|
31
|
+
* server will be running on the same machine as of the MCP client and thus we
|
|
32
|
+
* can provide the local path to export so that these clients which do not still
|
|
33
|
+
* support parsing resource URIs, can still work with the exported data. We
|
|
34
|
+
* expect for clients to catch up and implement referencing resource URIs at
|
|
35
|
+
* which point it would be safe to remove the `exportPath` from the publicly
|
|
36
|
+
* exposed properties of an export.
|
|
37
|
+
*
|
|
38
|
+
* The editors that we would like to watch out for are Cursor and Windsurf as
|
|
39
|
+
* they don't yet support working with Resource URIs.
|
|
40
|
+
*
|
|
41
|
+
* Ref Cursor: https://forum.cursor.com/t/cursor-mcp-resource-feature-support/50987
|
|
42
|
+
* JIRA: https://jira.mongodb.org/browse/MCP-104 */
|
|
43
|
+
type AvailableExport = Pick<StoredExport, "exportName" | "exportTitle" | "exportURI" | "exportPath">;
|
|
44
|
+
export type ExportsManagerConfig = Pick<UserConfig, "exportsPath" | "exportTimeoutMs" | "exportCleanupIntervalMs">;
|
|
45
|
+
type ExportsManagerEvents = {
|
|
46
|
+
closed: [];
|
|
47
|
+
"export-expired": [string];
|
|
48
|
+
"export-available": [string];
|
|
49
|
+
};
|
|
50
|
+
export declare class ExportsManager extends EventEmitter<ExportsManagerEvents> {
|
|
51
|
+
private readonly exportsDirectoryPath;
|
|
52
|
+
private readonly config;
|
|
53
|
+
private readonly logger;
|
|
54
|
+
private storedExports;
|
|
55
|
+
private exportsCleanupInProgress;
|
|
56
|
+
private exportsCleanupInterval?;
|
|
57
|
+
private readonly shutdownController;
|
|
58
|
+
private constructor();
|
|
59
|
+
get availableExports(): AvailableExport[];
|
|
60
|
+
protected init(): void;
|
|
61
|
+
close(): Promise<void>;
|
|
62
|
+
readExport(exportName: string): Promise<string>;
|
|
63
|
+
createJSONExport({ input, exportName, exportTitle, jsonExportFormat, }: {
|
|
64
|
+
input: FindCursor | AggregationCursor;
|
|
65
|
+
exportName: string;
|
|
66
|
+
exportTitle: string;
|
|
67
|
+
jsonExportFormat: JSONExportFormat;
|
|
68
|
+
}): Promise<AvailableExport>;
|
|
69
|
+
private startExport;
|
|
70
|
+
private getEJSONOptionsForFormat;
|
|
71
|
+
private docToEJSONStream;
|
|
72
|
+
private cleanupExpiredExports;
|
|
73
|
+
private silentlyRemoveExport;
|
|
74
|
+
private assertIsNotShuttingDown;
|
|
75
|
+
static init(config: ExportsManagerConfig, logger: LoggerBase, sessionId?: string): ExportsManager;
|
|
76
|
+
}
|
|
77
|
+
/**
|
|
78
|
+
* Ensures the path ends with the provided extension */
|
|
79
|
+
export declare function ensureExtension(pathOrName: string, extension: string): string;
|
|
80
|
+
/**
|
|
81
|
+
* Small utility to decoding and validating provided export name for path
|
|
82
|
+
* traversal or no extension */
|
|
83
|
+
export declare function validateExportName(nameWithExtension: string): string;
|
|
84
|
+
export declare function isExportExpired(createdAt: number, exportTimeoutMs: number): boolean;
|
|
85
|
+
export {};
|
|
86
|
+
//# sourceMappingURL=exportsManager.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"exportsManager.d.ts","sourceRoot":"","sources":["../../../src/common/exportsManager.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,288 @@
|
|
|
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.ExportsManager = exports.jsonExportFormat = void 0;
|
|
7
|
+
exports.ensureExtension = ensureExtension;
|
|
8
|
+
exports.validateExportName = validateExportName;
|
|
9
|
+
exports.isExportExpired = isExportExpired;
|
|
10
|
+
const zod_1 = __importDefault(require("zod"));
|
|
11
|
+
const path_1 = __importDefault(require("path"));
|
|
12
|
+
const promises_1 = __importDefault(require("fs/promises"));
|
|
13
|
+
const events_1 = __importDefault(require("events"));
|
|
14
|
+
const fs_1 = require("fs");
|
|
15
|
+
const bson_1 = require("bson");
|
|
16
|
+
const stream_1 = require("stream");
|
|
17
|
+
const promises_2 = require("stream/promises");
|
|
18
|
+
const logger_js_1 = require("./logger.js");
|
|
19
|
+
exports.jsonExportFormat = zod_1.default.enum(["relaxed", "canonical"]);
|
|
20
|
+
class ExportsManager extends events_1.default {
|
|
21
|
+
constructor(exportsDirectoryPath, config, logger) {
|
|
22
|
+
super();
|
|
23
|
+
this.exportsDirectoryPath = exportsDirectoryPath;
|
|
24
|
+
this.config = config;
|
|
25
|
+
this.logger = logger;
|
|
26
|
+
this.storedExports = {};
|
|
27
|
+
this.exportsCleanupInProgress = false;
|
|
28
|
+
this.shutdownController = new AbortController();
|
|
29
|
+
}
|
|
30
|
+
get availableExports() {
|
|
31
|
+
this.assertIsNotShuttingDown();
|
|
32
|
+
return Object.values(this.storedExports)
|
|
33
|
+
.filter((storedExport) => {
|
|
34
|
+
return (storedExport.exportStatus === "ready" &&
|
|
35
|
+
!isExportExpired(storedExport.exportCreatedAt, this.config.exportTimeoutMs));
|
|
36
|
+
})
|
|
37
|
+
.map(({ exportName, exportTitle, exportURI, exportPath }) => ({
|
|
38
|
+
exportName,
|
|
39
|
+
exportTitle,
|
|
40
|
+
exportURI,
|
|
41
|
+
exportPath,
|
|
42
|
+
}));
|
|
43
|
+
}
|
|
44
|
+
init() {
|
|
45
|
+
if (!this.exportsCleanupInterval) {
|
|
46
|
+
this.exportsCleanupInterval = setInterval(() => void this.cleanupExpiredExports(), this.config.exportCleanupIntervalMs);
|
|
47
|
+
}
|
|
48
|
+
}
|
|
49
|
+
async close() {
|
|
50
|
+
if (this.shutdownController.signal.aborted) {
|
|
51
|
+
return;
|
|
52
|
+
}
|
|
53
|
+
try {
|
|
54
|
+
clearInterval(this.exportsCleanupInterval);
|
|
55
|
+
this.shutdownController.abort();
|
|
56
|
+
await promises_1.default.rm(this.exportsDirectoryPath, { force: true, recursive: true });
|
|
57
|
+
this.emit("closed");
|
|
58
|
+
}
|
|
59
|
+
catch (error) {
|
|
60
|
+
this.logger.error({
|
|
61
|
+
id: logger_js_1.LogId.exportCloseError,
|
|
62
|
+
context: "Error while closing ExportsManager",
|
|
63
|
+
message: error instanceof Error ? error.message : String(error),
|
|
64
|
+
});
|
|
65
|
+
}
|
|
66
|
+
}
|
|
67
|
+
async readExport(exportName) {
|
|
68
|
+
try {
|
|
69
|
+
this.assertIsNotShuttingDown();
|
|
70
|
+
exportName = decodeURIComponent(exportName);
|
|
71
|
+
const exportHandle = this.storedExports[exportName];
|
|
72
|
+
if (!exportHandle) {
|
|
73
|
+
throw new Error("Requested export has either expired or does not exist.");
|
|
74
|
+
}
|
|
75
|
+
if (exportHandle.exportStatus === "in-progress") {
|
|
76
|
+
throw new Error("Requested export is still being generated. Try again later.");
|
|
77
|
+
}
|
|
78
|
+
const { exportPath } = exportHandle;
|
|
79
|
+
return promises_1.default.readFile(exportPath, { encoding: "utf8", signal: this.shutdownController.signal });
|
|
80
|
+
}
|
|
81
|
+
catch (error) {
|
|
82
|
+
this.logger.error({
|
|
83
|
+
id: logger_js_1.LogId.exportReadError,
|
|
84
|
+
context: `Error when reading export - ${exportName}`,
|
|
85
|
+
message: error instanceof Error ? error.message : String(error),
|
|
86
|
+
});
|
|
87
|
+
throw error;
|
|
88
|
+
}
|
|
89
|
+
}
|
|
90
|
+
async createJSONExport({ input, exportName, exportTitle, jsonExportFormat, }) {
|
|
91
|
+
try {
|
|
92
|
+
this.assertIsNotShuttingDown();
|
|
93
|
+
const exportNameWithExtension = validateExportName(ensureExtension(exportName, "json"));
|
|
94
|
+
if (this.storedExports[exportNameWithExtension]) {
|
|
95
|
+
return Promise.reject(new Error("Export with same name is either already available or being generated."));
|
|
96
|
+
}
|
|
97
|
+
const exportURI = `exported-data://${encodeURIComponent(exportNameWithExtension)}`;
|
|
98
|
+
const exportFilePath = path_1.default.join(this.exportsDirectoryPath, exportNameWithExtension);
|
|
99
|
+
const inProgressExport = (this.storedExports[exportNameWithExtension] = {
|
|
100
|
+
exportName: exportNameWithExtension,
|
|
101
|
+
exportTitle,
|
|
102
|
+
exportPath: exportFilePath,
|
|
103
|
+
exportURI: exportURI,
|
|
104
|
+
exportStatus: "in-progress",
|
|
105
|
+
});
|
|
106
|
+
void this.startExport({ input, jsonExportFormat, inProgressExport });
|
|
107
|
+
return Promise.resolve(inProgressExport);
|
|
108
|
+
}
|
|
109
|
+
catch (error) {
|
|
110
|
+
this.logger.error({
|
|
111
|
+
id: logger_js_1.LogId.exportCreationError,
|
|
112
|
+
context: "Error when registering JSON export request",
|
|
113
|
+
message: error instanceof Error ? error.message : String(error),
|
|
114
|
+
});
|
|
115
|
+
throw error;
|
|
116
|
+
}
|
|
117
|
+
}
|
|
118
|
+
async startExport({ input, jsonExportFormat, inProgressExport, }) {
|
|
119
|
+
try {
|
|
120
|
+
let pipeSuccessful = false;
|
|
121
|
+
try {
|
|
122
|
+
await promises_1.default.mkdir(this.exportsDirectoryPath, { recursive: true });
|
|
123
|
+
const outputStream = (0, fs_1.createWriteStream)(inProgressExport.exportPath);
|
|
124
|
+
await (0, promises_2.pipeline)([
|
|
125
|
+
input.stream(),
|
|
126
|
+
this.docToEJSONStream(this.getEJSONOptionsForFormat(jsonExportFormat)),
|
|
127
|
+
outputStream,
|
|
128
|
+
], { signal: this.shutdownController.signal });
|
|
129
|
+
pipeSuccessful = true;
|
|
130
|
+
}
|
|
131
|
+
catch (error) {
|
|
132
|
+
// If the pipeline errors out then we might end up with
|
|
133
|
+
// partial and incorrect export so we remove it entirely.
|
|
134
|
+
delete this.storedExports[inProgressExport.exportName];
|
|
135
|
+
// do not block the user, just delete the file in the background
|
|
136
|
+
void this.silentlyRemoveExport(inProgressExport.exportPath, logger_js_1.LogId.exportCreationCleanupError, `Error when removing incomplete export ${inProgressExport.exportName}`);
|
|
137
|
+
throw error;
|
|
138
|
+
}
|
|
139
|
+
finally {
|
|
140
|
+
if (pipeSuccessful) {
|
|
141
|
+
this.storedExports[inProgressExport.exportName] = {
|
|
142
|
+
...inProgressExport,
|
|
143
|
+
exportCreatedAt: Date.now(),
|
|
144
|
+
exportStatus: "ready",
|
|
145
|
+
};
|
|
146
|
+
this.emit("export-available", inProgressExport.exportURI);
|
|
147
|
+
}
|
|
148
|
+
void input.close();
|
|
149
|
+
}
|
|
150
|
+
}
|
|
151
|
+
catch (error) {
|
|
152
|
+
this.logger.error({
|
|
153
|
+
id: logger_js_1.LogId.exportCreationError,
|
|
154
|
+
context: `Error when generating JSON export for ${inProgressExport.exportName}`,
|
|
155
|
+
message: error instanceof Error ? error.message : String(error),
|
|
156
|
+
});
|
|
157
|
+
}
|
|
158
|
+
}
|
|
159
|
+
getEJSONOptionsForFormat(format) {
|
|
160
|
+
switch (format) {
|
|
161
|
+
case "relaxed":
|
|
162
|
+
return { relaxed: true };
|
|
163
|
+
case "canonical":
|
|
164
|
+
return { relaxed: false };
|
|
165
|
+
default:
|
|
166
|
+
return undefined;
|
|
167
|
+
}
|
|
168
|
+
}
|
|
169
|
+
docToEJSONStream(ejsonOptions) {
|
|
170
|
+
let docsTransformed = 0;
|
|
171
|
+
return new stream_1.Transform({
|
|
172
|
+
objectMode: true,
|
|
173
|
+
transform(chunk, encoding, callback) {
|
|
174
|
+
try {
|
|
175
|
+
const doc = bson_1.EJSON.stringify(chunk, undefined, undefined, ejsonOptions);
|
|
176
|
+
if (docsTransformed === 0) {
|
|
177
|
+
this.push("[" + doc);
|
|
178
|
+
}
|
|
179
|
+
else {
|
|
180
|
+
this.push(",\n" + doc);
|
|
181
|
+
}
|
|
182
|
+
docsTransformed++;
|
|
183
|
+
callback();
|
|
184
|
+
}
|
|
185
|
+
catch (err) {
|
|
186
|
+
callback(err);
|
|
187
|
+
}
|
|
188
|
+
},
|
|
189
|
+
flush(callback) {
|
|
190
|
+
if (docsTransformed === 0) {
|
|
191
|
+
this.push("[]");
|
|
192
|
+
}
|
|
193
|
+
else {
|
|
194
|
+
this.push("]");
|
|
195
|
+
}
|
|
196
|
+
callback();
|
|
197
|
+
},
|
|
198
|
+
});
|
|
199
|
+
}
|
|
200
|
+
async cleanupExpiredExports() {
|
|
201
|
+
if (this.exportsCleanupInProgress) {
|
|
202
|
+
return;
|
|
203
|
+
}
|
|
204
|
+
this.exportsCleanupInProgress = true;
|
|
205
|
+
try {
|
|
206
|
+
// first, unregister all exports that are expired, so they are not considered anymore for reading
|
|
207
|
+
const exportsForCleanup = [];
|
|
208
|
+
for (const expiredExport of Object.values(this.storedExports)) {
|
|
209
|
+
if (expiredExport.exportStatus === "ready" &&
|
|
210
|
+
isExportExpired(expiredExport.exportCreatedAt, this.config.exportTimeoutMs)) {
|
|
211
|
+
exportsForCleanup.push(expiredExport);
|
|
212
|
+
delete this.storedExports[expiredExport.exportName];
|
|
213
|
+
}
|
|
214
|
+
}
|
|
215
|
+
// and then remove them (slow operation potentially) from disk.
|
|
216
|
+
const allDeletionPromises = [];
|
|
217
|
+
for (const { exportPath, exportName } of exportsForCleanup) {
|
|
218
|
+
allDeletionPromises.push(this.silentlyRemoveExport(exportPath, logger_js_1.LogId.exportCleanupError, `Considerable error when removing export ${exportName}`));
|
|
219
|
+
}
|
|
220
|
+
await Promise.allSettled(allDeletionPromises);
|
|
221
|
+
}
|
|
222
|
+
catch (error) {
|
|
223
|
+
this.logger.error({
|
|
224
|
+
id: logger_js_1.LogId.exportCleanupError,
|
|
225
|
+
context: "Error when cleaning up exports",
|
|
226
|
+
message: error instanceof Error ? error.message : String(error),
|
|
227
|
+
});
|
|
228
|
+
}
|
|
229
|
+
finally {
|
|
230
|
+
this.exportsCleanupInProgress = false;
|
|
231
|
+
}
|
|
232
|
+
}
|
|
233
|
+
async silentlyRemoveExport(exportPath, logId, logContext) {
|
|
234
|
+
try {
|
|
235
|
+
await promises_1.default.unlink(exportPath);
|
|
236
|
+
}
|
|
237
|
+
catch (error) {
|
|
238
|
+
// If the file does not exist or the containing directory itself
|
|
239
|
+
// does not exist then we can safely ignore that error anything else
|
|
240
|
+
// we need to flag.
|
|
241
|
+
if (error.code !== "ENOENT") {
|
|
242
|
+
this.logger.error({
|
|
243
|
+
id: logId,
|
|
244
|
+
context: logContext,
|
|
245
|
+
message: error instanceof Error ? error.message : String(error),
|
|
246
|
+
});
|
|
247
|
+
}
|
|
248
|
+
}
|
|
249
|
+
}
|
|
250
|
+
assertIsNotShuttingDown() {
|
|
251
|
+
if (this.shutdownController.signal.aborted) {
|
|
252
|
+
throw new Error("ExportsManager is shutting down.");
|
|
253
|
+
}
|
|
254
|
+
}
|
|
255
|
+
static init(config, logger, sessionId = new bson_1.ObjectId().toString()) {
|
|
256
|
+
const exportsDirectoryPath = path_1.default.join(config.exportsPath, sessionId);
|
|
257
|
+
const exportsManager = new ExportsManager(exportsDirectoryPath, config, logger);
|
|
258
|
+
exportsManager.init();
|
|
259
|
+
return exportsManager;
|
|
260
|
+
}
|
|
261
|
+
}
|
|
262
|
+
exports.ExportsManager = ExportsManager;
|
|
263
|
+
/**
|
|
264
|
+
* Ensures the path ends with the provided extension */
|
|
265
|
+
function ensureExtension(pathOrName, extension) {
|
|
266
|
+
const extWithDot = extension.startsWith(".") ? extension : `.${extension}`;
|
|
267
|
+
if (pathOrName.endsWith(extWithDot)) {
|
|
268
|
+
return pathOrName;
|
|
269
|
+
}
|
|
270
|
+
return `${pathOrName}${extWithDot}`;
|
|
271
|
+
}
|
|
272
|
+
/**
|
|
273
|
+
* Small utility to decoding and validating provided export name for path
|
|
274
|
+
* traversal or no extension */
|
|
275
|
+
function validateExportName(nameWithExtension) {
|
|
276
|
+
const decodedName = decodeURIComponent(nameWithExtension);
|
|
277
|
+
if (!path_1.default.extname(decodedName)) {
|
|
278
|
+
throw new Error("Provided export name has no extension");
|
|
279
|
+
}
|
|
280
|
+
if (decodedName.includes("..") || decodedName.includes("/") || decodedName.includes("\\")) {
|
|
281
|
+
throw new Error("Invalid export name: path traversal hinted");
|
|
282
|
+
}
|
|
283
|
+
return decodedName;
|
|
284
|
+
}
|
|
285
|
+
function isExportExpired(createdAt, exportTimeoutMs) {
|
|
286
|
+
return Date.now() - createdAt > exportTimeoutMs;
|
|
287
|
+
}
|
|
288
|
+
//# sourceMappingURL=exportsManager.js.map
|