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
package/src/config.ts
DELETED
|
@@ -1,125 +0,0 @@
|
|
|
1
|
-
import path from "path";
|
|
2
|
-
import os from "os";
|
|
3
|
-
import argv from "yargs-parser";
|
|
4
|
-
|
|
5
|
-
import { ReadConcernLevel, ReadPreferenceMode, W } from "mongodb";
|
|
6
|
-
|
|
7
|
-
export interface ConnectOptions {
|
|
8
|
-
readConcern: ReadConcernLevel;
|
|
9
|
-
readPreference: ReadPreferenceMode;
|
|
10
|
-
writeConcern: W;
|
|
11
|
-
timeoutMS: number;
|
|
12
|
-
}
|
|
13
|
-
|
|
14
|
-
// If we decide to support non-string config options, we'll need to extend the mechanism for parsing
|
|
15
|
-
// env variables.
|
|
16
|
-
export interface UserConfig {
|
|
17
|
-
apiBaseUrl: string;
|
|
18
|
-
apiClientId?: string;
|
|
19
|
-
apiClientSecret?: string;
|
|
20
|
-
telemetry?: "enabled" | "disabled";
|
|
21
|
-
logPath: string;
|
|
22
|
-
connectionString?: string;
|
|
23
|
-
connectOptions: ConnectOptions;
|
|
24
|
-
disabledTools: Array<string>;
|
|
25
|
-
readOnly?: boolean;
|
|
26
|
-
indexCheck?: boolean;
|
|
27
|
-
}
|
|
28
|
-
|
|
29
|
-
const defaults: UserConfig = {
|
|
30
|
-
apiBaseUrl: "https://cloud.mongodb.com/",
|
|
31
|
-
logPath: getLogPath(),
|
|
32
|
-
connectOptions: {
|
|
33
|
-
readConcern: "local",
|
|
34
|
-
readPreference: "secondaryPreferred",
|
|
35
|
-
writeConcern: "majority",
|
|
36
|
-
timeoutMS: 30_000,
|
|
37
|
-
},
|
|
38
|
-
disabledTools: [],
|
|
39
|
-
telemetry: "enabled",
|
|
40
|
-
readOnly: false,
|
|
41
|
-
indexCheck: false,
|
|
42
|
-
};
|
|
43
|
-
|
|
44
|
-
export const config = {
|
|
45
|
-
...defaults,
|
|
46
|
-
...getEnvConfig(),
|
|
47
|
-
...getCliConfig(),
|
|
48
|
-
};
|
|
49
|
-
|
|
50
|
-
function getLogPath(): string {
|
|
51
|
-
const localDataPath =
|
|
52
|
-
process.platform === "win32"
|
|
53
|
-
? path.join(process.env.LOCALAPPDATA || process.env.APPDATA || os.homedir(), "mongodb")
|
|
54
|
-
: path.join(os.homedir(), ".mongodb");
|
|
55
|
-
|
|
56
|
-
const logPath = path.join(localDataPath, "mongodb-mcp", ".app-logs");
|
|
57
|
-
|
|
58
|
-
return logPath;
|
|
59
|
-
}
|
|
60
|
-
|
|
61
|
-
// Gets the config supplied by the user as environment variables. The variable names
|
|
62
|
-
// are prefixed with `MDB_MCP_` and the keys match the UserConfig keys, but are converted
|
|
63
|
-
// to SNAKE_UPPER_CASE.
|
|
64
|
-
function getEnvConfig(): Partial<UserConfig> {
|
|
65
|
-
function setValue(obj: Record<string, unknown>, path: string[], value: string): void {
|
|
66
|
-
const currentField = path.shift();
|
|
67
|
-
if (!currentField) {
|
|
68
|
-
return;
|
|
69
|
-
}
|
|
70
|
-
if (path.length === 0) {
|
|
71
|
-
const numberValue = Number(value);
|
|
72
|
-
if (!isNaN(numberValue)) {
|
|
73
|
-
obj[currentField] = numberValue;
|
|
74
|
-
return;
|
|
75
|
-
}
|
|
76
|
-
|
|
77
|
-
const booleanValue = value.toLocaleLowerCase();
|
|
78
|
-
if (booleanValue === "true" || booleanValue === "false") {
|
|
79
|
-
obj[currentField] = booleanValue === "true";
|
|
80
|
-
return;
|
|
81
|
-
}
|
|
82
|
-
|
|
83
|
-
// Try to parse an array of values
|
|
84
|
-
if (value.indexOf(",") !== -1) {
|
|
85
|
-
obj[currentField] = value.split(",").map((v) => v.trim());
|
|
86
|
-
return;
|
|
87
|
-
}
|
|
88
|
-
|
|
89
|
-
obj[currentField] = value;
|
|
90
|
-
return;
|
|
91
|
-
}
|
|
92
|
-
|
|
93
|
-
if (!obj[currentField]) {
|
|
94
|
-
obj[currentField] = {};
|
|
95
|
-
}
|
|
96
|
-
|
|
97
|
-
setValue(obj[currentField] as Record<string, unknown>, path, value);
|
|
98
|
-
}
|
|
99
|
-
|
|
100
|
-
const result: Record<string, unknown> = {};
|
|
101
|
-
const mcpVariables = Object.entries(process.env).filter(
|
|
102
|
-
([key, value]) => value !== undefined && key.startsWith("MDB_MCP_")
|
|
103
|
-
) as [string, string][];
|
|
104
|
-
for (const [key, value] of mcpVariables) {
|
|
105
|
-
const fieldPath = key
|
|
106
|
-
.replace("MDB_MCP_", "")
|
|
107
|
-
.split(".")
|
|
108
|
-
.map((part) => SNAKE_CASE_toCamelCase(part));
|
|
109
|
-
|
|
110
|
-
setValue(result, fieldPath, value);
|
|
111
|
-
}
|
|
112
|
-
|
|
113
|
-
return result;
|
|
114
|
-
}
|
|
115
|
-
|
|
116
|
-
function SNAKE_CASE_toCamelCase(str: string): string {
|
|
117
|
-
return str.toLowerCase().replace(/([-_][a-z])/g, (group) => group.toUpperCase().replace("_", ""));
|
|
118
|
-
}
|
|
119
|
-
|
|
120
|
-
// Reads the cli args and parses them into a UserConfig object.
|
|
121
|
-
function getCliConfig() {
|
|
122
|
-
return argv(process.argv.slice(2), {
|
|
123
|
-
array: ["disabledTools"],
|
|
124
|
-
}) as unknown as Partial<UserConfig>;
|
|
125
|
-
}
|
package/src/errors.ts
DELETED
|
@@ -1,14 +0,0 @@
|
|
|
1
|
-
export enum ErrorCodes {
|
|
2
|
-
NotConnectedToMongoDB = 1_000_000,
|
|
3
|
-
MisconfiguredConnectionString = 1_000_001,
|
|
4
|
-
ForbiddenCollscan = 1_000_002,
|
|
5
|
-
}
|
|
6
|
-
|
|
7
|
-
export class MongoDBError extends Error {
|
|
8
|
-
constructor(
|
|
9
|
-
public code: ErrorCodes,
|
|
10
|
-
message: string
|
|
11
|
-
) {
|
|
12
|
-
super(message);
|
|
13
|
-
}
|
|
14
|
-
}
|
|
@@ -1,47 +0,0 @@
|
|
|
1
|
-
import { JSONRPCMessage, JSONRPCMessageSchema } from "@modelcontextprotocol/sdk/types.js";
|
|
2
|
-
import { EJSON } from "bson";
|
|
3
|
-
import { StdioServerTransport } from "@modelcontextprotocol/sdk/server/stdio.js";
|
|
4
|
-
|
|
5
|
-
// This is almost a copy of ReadBuffer from @modelcontextprotocol/sdk
|
|
6
|
-
// but it uses EJSON.parse instead of JSON.parse to handle BSON types
|
|
7
|
-
export class EJsonReadBuffer {
|
|
8
|
-
private _buffer?: Buffer;
|
|
9
|
-
|
|
10
|
-
append(chunk: Buffer): void {
|
|
11
|
-
this._buffer = this._buffer ? Buffer.concat([this._buffer, chunk]) : chunk;
|
|
12
|
-
}
|
|
13
|
-
|
|
14
|
-
readMessage(): JSONRPCMessage | null {
|
|
15
|
-
if (!this._buffer) {
|
|
16
|
-
return null;
|
|
17
|
-
}
|
|
18
|
-
|
|
19
|
-
const index = this._buffer.indexOf("\n");
|
|
20
|
-
if (index === -1) {
|
|
21
|
-
return null;
|
|
22
|
-
}
|
|
23
|
-
|
|
24
|
-
const line = this._buffer.toString("utf8", 0, index).replace(/\r$/, "");
|
|
25
|
-
this._buffer = this._buffer.subarray(index + 1);
|
|
26
|
-
|
|
27
|
-
// This is using EJSON.parse instead of JSON.parse to handle BSON types
|
|
28
|
-
return JSONRPCMessageSchema.parse(EJSON.parse(line));
|
|
29
|
-
}
|
|
30
|
-
|
|
31
|
-
clear(): void {
|
|
32
|
-
this._buffer = undefined;
|
|
33
|
-
}
|
|
34
|
-
}
|
|
35
|
-
|
|
36
|
-
// This is a hacky workaround for https://github.com/mongodb-js/mongodb-mcp-server/issues/211
|
|
37
|
-
// The underlying issue is that StdioServerTransport uses JSON.parse to deserialize
|
|
38
|
-
// messages, but that doesn't handle bson types, such as ObjectId when serialized as EJSON.
|
|
39
|
-
//
|
|
40
|
-
// This function creates a StdioServerTransport and replaces the internal readBuffer with EJsonReadBuffer
|
|
41
|
-
// that uses EJson.parse instead.
|
|
42
|
-
export function createEJsonTransport(): StdioServerTransport {
|
|
43
|
-
const server = new StdioServerTransport();
|
|
44
|
-
server["_readBuffer"] = new EJsonReadBuffer();
|
|
45
|
-
|
|
46
|
-
return server;
|
|
47
|
-
}
|
|
@@ -1,20 +0,0 @@
|
|
|
1
|
-
import { MongoClientOptions } from "mongodb";
|
|
2
|
-
import ConnectionString from "mongodb-connection-string-url";
|
|
3
|
-
|
|
4
|
-
export function setAppNameParamIfMissing({
|
|
5
|
-
connectionString,
|
|
6
|
-
defaultAppName,
|
|
7
|
-
}: {
|
|
8
|
-
connectionString: string;
|
|
9
|
-
defaultAppName?: string;
|
|
10
|
-
}): string {
|
|
11
|
-
const connectionStringUrl = new ConnectionString(connectionString);
|
|
12
|
-
|
|
13
|
-
const searchParams = connectionStringUrl.typedSearchParams<MongoClientOptions>();
|
|
14
|
-
|
|
15
|
-
if (!searchParams.has("appName") && defaultAppName !== undefined) {
|
|
16
|
-
searchParams.set("appName", defaultAppName);
|
|
17
|
-
}
|
|
18
|
-
|
|
19
|
-
return connectionStringUrl.toString();
|
|
20
|
-
}
|
package/src/index.ts
DELETED
|
@@ -1,58 +0,0 @@
|
|
|
1
|
-
#!/usr/bin/env node
|
|
2
|
-
|
|
3
|
-
import logger, { LogId } from "./logger.js";
|
|
4
|
-
import { McpServer } from "@modelcontextprotocol/sdk/server/mcp.js";
|
|
5
|
-
import { config } from "./config.js";
|
|
6
|
-
import { Session } from "./session.js";
|
|
7
|
-
import { Server } from "./server.js";
|
|
8
|
-
import { packageInfo } from "./helpers/packageInfo.js";
|
|
9
|
-
import { Telemetry } from "./telemetry/telemetry.js";
|
|
10
|
-
import { createEJsonTransport } from "./helpers/EJsonTransport.js";
|
|
11
|
-
|
|
12
|
-
try {
|
|
13
|
-
const session = new Session({
|
|
14
|
-
apiBaseUrl: config.apiBaseUrl,
|
|
15
|
-
apiClientId: config.apiClientId,
|
|
16
|
-
apiClientSecret: config.apiClientSecret,
|
|
17
|
-
});
|
|
18
|
-
const mcpServer = new McpServer({
|
|
19
|
-
name: packageInfo.mcpServerName,
|
|
20
|
-
version: packageInfo.version,
|
|
21
|
-
});
|
|
22
|
-
|
|
23
|
-
const telemetry = Telemetry.create(session, config);
|
|
24
|
-
|
|
25
|
-
const server = new Server({
|
|
26
|
-
mcpServer,
|
|
27
|
-
session,
|
|
28
|
-
telemetry,
|
|
29
|
-
userConfig: config,
|
|
30
|
-
});
|
|
31
|
-
|
|
32
|
-
const transport = createEJsonTransport();
|
|
33
|
-
|
|
34
|
-
const shutdown = () => {
|
|
35
|
-
logger.info(LogId.serverCloseRequested, "server", `Server close requested`);
|
|
36
|
-
|
|
37
|
-
server
|
|
38
|
-
.close()
|
|
39
|
-
.then(() => {
|
|
40
|
-
logger.info(LogId.serverClosed, "server", `Server closed successfully`);
|
|
41
|
-
process.exit(0);
|
|
42
|
-
})
|
|
43
|
-
.catch((err: unknown) => {
|
|
44
|
-
const error = err instanceof Error ? err : new Error(String(err));
|
|
45
|
-
logger.error(LogId.serverCloseFailure, "server", `Error closing server: ${error.message}`);
|
|
46
|
-
process.exit(1);
|
|
47
|
-
});
|
|
48
|
-
};
|
|
49
|
-
|
|
50
|
-
process.once("SIGINT", shutdown);
|
|
51
|
-
process.once("SIGTERM", shutdown);
|
|
52
|
-
process.once("SIGQUIT", shutdown);
|
|
53
|
-
|
|
54
|
-
await server.connect(transport);
|
|
55
|
-
} catch (error: unknown) {
|
|
56
|
-
logger.emergency(LogId.serverStartFailure, "server", `Fatal error running server: ${error as string}`);
|
|
57
|
-
process.exit(1);
|
|
58
|
-
}
|
package/src/logger.ts
DELETED
|
@@ -1,190 +0,0 @@
|
|
|
1
|
-
import fs from "fs/promises";
|
|
2
|
-
import { mongoLogId, MongoLogId, MongoLogManager, MongoLogWriter } from "mongodb-log-writer";
|
|
3
|
-
import redact from "mongodb-redact";
|
|
4
|
-
import { McpServer } from "@modelcontextprotocol/sdk/server/mcp.js";
|
|
5
|
-
import { LoggingMessageNotification } from "@modelcontextprotocol/sdk/types.js";
|
|
6
|
-
|
|
7
|
-
export type LogLevel = LoggingMessageNotification["params"]["level"];
|
|
8
|
-
|
|
9
|
-
export const LogId = {
|
|
10
|
-
serverStartFailure: mongoLogId(1_000_001),
|
|
11
|
-
serverInitialized: mongoLogId(1_000_002),
|
|
12
|
-
serverCloseRequested: mongoLogId(1_000_003),
|
|
13
|
-
serverClosed: mongoLogId(1_000_004),
|
|
14
|
-
serverCloseFailure: mongoLogId(1_000_005),
|
|
15
|
-
|
|
16
|
-
atlasCheckCredentials: mongoLogId(1_001_001),
|
|
17
|
-
atlasDeleteDatabaseUserFailure: mongoLogId(1_001_002),
|
|
18
|
-
atlasConnectFailure: mongoLogId(1_001_003),
|
|
19
|
-
atlasInspectFailure: mongoLogId(1_001_004),
|
|
20
|
-
|
|
21
|
-
telemetryDisabled: mongoLogId(1_002_001),
|
|
22
|
-
telemetryEmitFailure: mongoLogId(1_002_002),
|
|
23
|
-
telemetryEmitStart: mongoLogId(1_002_003),
|
|
24
|
-
telemetryEmitSuccess: mongoLogId(1_002_004),
|
|
25
|
-
telemetryMetadataError: mongoLogId(1_002_005),
|
|
26
|
-
telemetryDeviceIdFailure: mongoLogId(1_002_006),
|
|
27
|
-
telemetryDeviceIdTimeout: mongoLogId(1_002_007),
|
|
28
|
-
|
|
29
|
-
toolExecute: mongoLogId(1_003_001),
|
|
30
|
-
toolExecuteFailure: mongoLogId(1_003_002),
|
|
31
|
-
toolDisabled: mongoLogId(1_003_003),
|
|
32
|
-
|
|
33
|
-
mongodbConnectFailure: mongoLogId(1_004_001),
|
|
34
|
-
mongodbDisconnectFailure: mongoLogId(1_004_002),
|
|
35
|
-
|
|
36
|
-
toolUpdateFailure: mongoLogId(1_005_001),
|
|
37
|
-
} as const;
|
|
38
|
-
|
|
39
|
-
abstract class LoggerBase {
|
|
40
|
-
abstract log(level: LogLevel, id: MongoLogId, context: string, message: string): void;
|
|
41
|
-
|
|
42
|
-
info(id: MongoLogId, context: string, message: string): void {
|
|
43
|
-
this.log("info", id, context, message);
|
|
44
|
-
}
|
|
45
|
-
|
|
46
|
-
error(id: MongoLogId, context: string, message: string): void {
|
|
47
|
-
this.log("error", id, context, message);
|
|
48
|
-
}
|
|
49
|
-
debug(id: MongoLogId, context: string, message: string): void {
|
|
50
|
-
this.log("debug", id, context, message);
|
|
51
|
-
}
|
|
52
|
-
|
|
53
|
-
notice(id: MongoLogId, context: string, message: string): void {
|
|
54
|
-
this.log("notice", id, context, message);
|
|
55
|
-
}
|
|
56
|
-
|
|
57
|
-
warning(id: MongoLogId, context: string, message: string): void {
|
|
58
|
-
this.log("warning", id, context, message);
|
|
59
|
-
}
|
|
60
|
-
|
|
61
|
-
critical(id: MongoLogId, context: string, message: string): void {
|
|
62
|
-
this.log("critical", id, context, message);
|
|
63
|
-
}
|
|
64
|
-
|
|
65
|
-
alert(id: MongoLogId, context: string, message: string): void {
|
|
66
|
-
this.log("alert", id, context, message);
|
|
67
|
-
}
|
|
68
|
-
|
|
69
|
-
emergency(id: MongoLogId, context: string, message: string): void {
|
|
70
|
-
this.log("emergency", id, context, message);
|
|
71
|
-
}
|
|
72
|
-
}
|
|
73
|
-
|
|
74
|
-
class ConsoleLogger extends LoggerBase {
|
|
75
|
-
log(level: LogLevel, id: MongoLogId, context: string, message: string): void {
|
|
76
|
-
message = redact(message);
|
|
77
|
-
console.error(`[${level.toUpperCase()}] ${id.__value} - ${context}: ${message}`);
|
|
78
|
-
}
|
|
79
|
-
}
|
|
80
|
-
|
|
81
|
-
class DiskLogger extends LoggerBase {
|
|
82
|
-
private constructor(private logWriter: MongoLogWriter) {
|
|
83
|
-
super();
|
|
84
|
-
}
|
|
85
|
-
|
|
86
|
-
static async fromPath(logPath: string): Promise<DiskLogger> {
|
|
87
|
-
await fs.mkdir(logPath, { recursive: true });
|
|
88
|
-
|
|
89
|
-
const manager = new MongoLogManager({
|
|
90
|
-
directory: logPath,
|
|
91
|
-
retentionDays: 30,
|
|
92
|
-
onwarn: console.warn,
|
|
93
|
-
onerror: console.error,
|
|
94
|
-
gzip: false,
|
|
95
|
-
retentionGB: 1,
|
|
96
|
-
});
|
|
97
|
-
|
|
98
|
-
await manager.cleanupOldLogFiles();
|
|
99
|
-
|
|
100
|
-
const logWriter = await manager.createLogWriter();
|
|
101
|
-
|
|
102
|
-
return new DiskLogger(logWriter);
|
|
103
|
-
}
|
|
104
|
-
|
|
105
|
-
log(level: LogLevel, id: MongoLogId, context: string, message: string): void {
|
|
106
|
-
message = redact(message);
|
|
107
|
-
const mongoDBLevel = this.mapToMongoDBLogLevel(level);
|
|
108
|
-
|
|
109
|
-
this.logWriter[mongoDBLevel]("MONGODB-MCP", id, context, message);
|
|
110
|
-
}
|
|
111
|
-
|
|
112
|
-
private mapToMongoDBLogLevel(level: LogLevel): "info" | "warn" | "error" | "debug" | "fatal" {
|
|
113
|
-
switch (level) {
|
|
114
|
-
case "info":
|
|
115
|
-
return "info";
|
|
116
|
-
case "warning":
|
|
117
|
-
return "warn";
|
|
118
|
-
case "error":
|
|
119
|
-
return "error";
|
|
120
|
-
case "notice":
|
|
121
|
-
case "debug":
|
|
122
|
-
return "debug";
|
|
123
|
-
case "critical":
|
|
124
|
-
case "alert":
|
|
125
|
-
case "emergency":
|
|
126
|
-
return "fatal";
|
|
127
|
-
default:
|
|
128
|
-
return "info";
|
|
129
|
-
}
|
|
130
|
-
}
|
|
131
|
-
}
|
|
132
|
-
|
|
133
|
-
class McpLogger extends LoggerBase {
|
|
134
|
-
constructor(private server: McpServer) {
|
|
135
|
-
super();
|
|
136
|
-
}
|
|
137
|
-
|
|
138
|
-
log(level: LogLevel, _: MongoLogId, context: string, message: string): void {
|
|
139
|
-
// Only log if the server is connected
|
|
140
|
-
if (!this.server?.isConnected()) {
|
|
141
|
-
return;
|
|
142
|
-
}
|
|
143
|
-
|
|
144
|
-
void this.server.server.sendLoggingMessage({
|
|
145
|
-
level,
|
|
146
|
-
data: `[${context}]: ${message}`,
|
|
147
|
-
});
|
|
148
|
-
}
|
|
149
|
-
}
|
|
150
|
-
|
|
151
|
-
class CompositeLogger extends LoggerBase {
|
|
152
|
-
private loggers: LoggerBase[];
|
|
153
|
-
|
|
154
|
-
constructor(...loggers: LoggerBase[]) {
|
|
155
|
-
super();
|
|
156
|
-
|
|
157
|
-
if (loggers.length === 0) {
|
|
158
|
-
// default to ConsoleLogger
|
|
159
|
-
this.loggers = [new ConsoleLogger()];
|
|
160
|
-
return;
|
|
161
|
-
}
|
|
162
|
-
|
|
163
|
-
this.loggers = [...loggers];
|
|
164
|
-
}
|
|
165
|
-
|
|
166
|
-
setLoggers(...loggers: LoggerBase[]): void {
|
|
167
|
-
if (loggers.length === 0) {
|
|
168
|
-
throw new Error("At least one logger must be provided");
|
|
169
|
-
}
|
|
170
|
-
this.loggers = [...loggers];
|
|
171
|
-
}
|
|
172
|
-
|
|
173
|
-
log(level: LogLevel, id: MongoLogId, context: string, message: string): void {
|
|
174
|
-
for (const logger of this.loggers) {
|
|
175
|
-
logger.log(level, id, context, message);
|
|
176
|
-
}
|
|
177
|
-
}
|
|
178
|
-
}
|
|
179
|
-
|
|
180
|
-
const logger = new CompositeLogger();
|
|
181
|
-
export default logger;
|
|
182
|
-
|
|
183
|
-
export async function initializeLogger(server: McpServer, logPath: string): Promise<LoggerBase> {
|
|
184
|
-
const diskLogger = await DiskLogger.fromPath(logPath);
|
|
185
|
-
const mcpLogger = new McpLogger(server);
|
|
186
|
-
|
|
187
|
-
logger.setLoggers(mcpLogger, diskLogger);
|
|
188
|
-
|
|
189
|
-
return logger;
|
|
190
|
-
}
|
package/src/server.ts
DELETED
|
@@ -1,206 +0,0 @@
|
|
|
1
|
-
import { McpServer } from "@modelcontextprotocol/sdk/server/mcp.js";
|
|
2
|
-
import { Session } from "./session.js";
|
|
3
|
-
import { Transport } from "@modelcontextprotocol/sdk/shared/transport.js";
|
|
4
|
-
import { AtlasTools } from "./tools/atlas/tools.js";
|
|
5
|
-
import { MongoDbTools } from "./tools/mongodb/tools.js";
|
|
6
|
-
import logger, { initializeLogger, LogId } from "./logger.js";
|
|
7
|
-
import { ObjectId } from "mongodb";
|
|
8
|
-
import { Telemetry } from "./telemetry/telemetry.js";
|
|
9
|
-
import { UserConfig } from "./config.js";
|
|
10
|
-
import { type ServerEvent } from "./telemetry/types.js";
|
|
11
|
-
import { type ServerCommand } from "./telemetry/types.js";
|
|
12
|
-
import { CallToolRequestSchema, CallToolResult } from "@modelcontextprotocol/sdk/types.js";
|
|
13
|
-
import assert from "assert";
|
|
14
|
-
|
|
15
|
-
export interface ServerOptions {
|
|
16
|
-
session: Session;
|
|
17
|
-
userConfig: UserConfig;
|
|
18
|
-
mcpServer: McpServer;
|
|
19
|
-
telemetry: Telemetry;
|
|
20
|
-
}
|
|
21
|
-
|
|
22
|
-
export class Server {
|
|
23
|
-
public readonly session: Session;
|
|
24
|
-
private readonly mcpServer: McpServer;
|
|
25
|
-
private readonly telemetry: Telemetry;
|
|
26
|
-
public readonly userConfig: UserConfig;
|
|
27
|
-
private readonly startTime: number;
|
|
28
|
-
|
|
29
|
-
constructor({ session, mcpServer, userConfig, telemetry }: ServerOptions) {
|
|
30
|
-
this.startTime = Date.now();
|
|
31
|
-
this.session = session;
|
|
32
|
-
this.telemetry = telemetry;
|
|
33
|
-
this.mcpServer = mcpServer;
|
|
34
|
-
this.userConfig = userConfig;
|
|
35
|
-
}
|
|
36
|
-
|
|
37
|
-
async connect(transport: Transport): Promise<void> {
|
|
38
|
-
this.mcpServer.server.registerCapabilities({ logging: {} });
|
|
39
|
-
|
|
40
|
-
this.registerTools();
|
|
41
|
-
this.registerResources();
|
|
42
|
-
|
|
43
|
-
// This is a workaround for an issue we've seen with some models, where they'll see that everything in the `arguments`
|
|
44
|
-
// object is optional, and then not pass it at all. However, the MCP server expects the `arguments` object to be if
|
|
45
|
-
// the tool accepts any arguments, even if they're all optional.
|
|
46
|
-
//
|
|
47
|
-
// see: https://github.com/modelcontextprotocol/typescript-sdk/blob/131776764536b5fdca642df51230a3746fb4ade0/src/server/mcp.ts#L705
|
|
48
|
-
// Since paramsSchema here is not undefined, the server will create a non-optional z.object from it.
|
|
49
|
-
const existingHandler = (
|
|
50
|
-
this.mcpServer.server["_requestHandlers"] as Map<
|
|
51
|
-
string,
|
|
52
|
-
(request: unknown, extra: unknown) => Promise<CallToolResult>
|
|
53
|
-
>
|
|
54
|
-
).get(CallToolRequestSchema.shape.method.value);
|
|
55
|
-
|
|
56
|
-
assert(existingHandler, "No existing handler found for CallToolRequestSchema");
|
|
57
|
-
|
|
58
|
-
this.mcpServer.server.setRequestHandler(CallToolRequestSchema, (request, extra): Promise<CallToolResult> => {
|
|
59
|
-
if (!request.params.arguments) {
|
|
60
|
-
request.params.arguments = {};
|
|
61
|
-
}
|
|
62
|
-
|
|
63
|
-
return existingHandler(request, extra);
|
|
64
|
-
});
|
|
65
|
-
|
|
66
|
-
await initializeLogger(this.mcpServer, this.userConfig.logPath);
|
|
67
|
-
|
|
68
|
-
await this.mcpServer.connect(transport);
|
|
69
|
-
|
|
70
|
-
this.mcpServer.server.oninitialized = () => {
|
|
71
|
-
this.session.setAgentRunner(this.mcpServer.server.getClientVersion());
|
|
72
|
-
this.session.sessionId = new ObjectId().toString();
|
|
73
|
-
|
|
74
|
-
logger.info(
|
|
75
|
-
LogId.serverInitialized,
|
|
76
|
-
"server",
|
|
77
|
-
`Server started with transport ${transport.constructor.name} and agent runner ${this.session.agentRunner?.name}`
|
|
78
|
-
);
|
|
79
|
-
|
|
80
|
-
this.emitServerEvent("start", Date.now() - this.startTime);
|
|
81
|
-
};
|
|
82
|
-
|
|
83
|
-
this.mcpServer.server.onclose = () => {
|
|
84
|
-
const closeTime = Date.now();
|
|
85
|
-
this.emitServerEvent("stop", Date.now() - closeTime);
|
|
86
|
-
};
|
|
87
|
-
|
|
88
|
-
this.mcpServer.server.onerror = (error: Error) => {
|
|
89
|
-
const closeTime = Date.now();
|
|
90
|
-
this.emitServerEvent("stop", Date.now() - closeTime, error);
|
|
91
|
-
};
|
|
92
|
-
|
|
93
|
-
await this.validateConfig();
|
|
94
|
-
}
|
|
95
|
-
|
|
96
|
-
async close(): Promise<void> {
|
|
97
|
-
await this.telemetry.close();
|
|
98
|
-
await this.session.close();
|
|
99
|
-
await this.mcpServer.close();
|
|
100
|
-
}
|
|
101
|
-
|
|
102
|
-
/**
|
|
103
|
-
* Emits a server event
|
|
104
|
-
* @param command - The server command (e.g., "start", "stop", "register", "deregister")
|
|
105
|
-
* @param additionalProperties - Additional properties specific to the event
|
|
106
|
-
*/
|
|
107
|
-
private emitServerEvent(command: ServerCommand, commandDuration: number, error?: Error) {
|
|
108
|
-
const event: ServerEvent = {
|
|
109
|
-
timestamp: new Date().toISOString(),
|
|
110
|
-
source: "mdbmcp",
|
|
111
|
-
properties: {
|
|
112
|
-
result: "success",
|
|
113
|
-
duration_ms: commandDuration,
|
|
114
|
-
component: "server",
|
|
115
|
-
category: "other",
|
|
116
|
-
command: command,
|
|
117
|
-
},
|
|
118
|
-
};
|
|
119
|
-
|
|
120
|
-
if (command === "start") {
|
|
121
|
-
event.properties.startup_time_ms = commandDuration;
|
|
122
|
-
event.properties.read_only_mode = this.userConfig.readOnly || false;
|
|
123
|
-
event.properties.disabled_tools = this.userConfig.disabledTools || [];
|
|
124
|
-
}
|
|
125
|
-
if (command === "stop") {
|
|
126
|
-
event.properties.runtime_duration_ms = Date.now() - this.startTime;
|
|
127
|
-
if (error) {
|
|
128
|
-
event.properties.result = "failure";
|
|
129
|
-
event.properties.reason = error.message;
|
|
130
|
-
}
|
|
131
|
-
}
|
|
132
|
-
|
|
133
|
-
this.telemetry.emitEvents([event]).catch(() => {});
|
|
134
|
-
}
|
|
135
|
-
|
|
136
|
-
private registerTools() {
|
|
137
|
-
for (const tool of [...AtlasTools, ...MongoDbTools]) {
|
|
138
|
-
new tool(this.session, this.userConfig, this.telemetry).register(this.mcpServer);
|
|
139
|
-
}
|
|
140
|
-
}
|
|
141
|
-
|
|
142
|
-
private registerResources() {
|
|
143
|
-
this.mcpServer.resource(
|
|
144
|
-
"config",
|
|
145
|
-
"config://config",
|
|
146
|
-
{
|
|
147
|
-
description:
|
|
148
|
-
"Server configuration, supplied by the user either as environment variables or as startup arguments",
|
|
149
|
-
},
|
|
150
|
-
(uri) => {
|
|
151
|
-
const result = {
|
|
152
|
-
telemetry: this.userConfig.telemetry,
|
|
153
|
-
logPath: this.userConfig.logPath,
|
|
154
|
-
connectionString: this.userConfig.connectionString
|
|
155
|
-
? "set; access to MongoDB tools are currently available to use"
|
|
156
|
-
: "not set; before using any MongoDB tool, you need to configure a connection string, alternatively you can setup MongoDB Atlas access, more info at 'https://github.com/mongodb-js/mongodb-mcp-server'.",
|
|
157
|
-
connectOptions: this.userConfig.connectOptions,
|
|
158
|
-
atlas:
|
|
159
|
-
this.userConfig.apiClientId && this.userConfig.apiClientSecret
|
|
160
|
-
? "set; MongoDB Atlas tools are currently available to use"
|
|
161
|
-
: "not set; MongoDB Atlas tools are currently unavailable, to have access to MongoDB Atlas tools like creating clusters or connecting to clusters make sure to setup credentials, more info at 'https://github.com/mongodb-js/mongodb-mcp-server'.",
|
|
162
|
-
};
|
|
163
|
-
return {
|
|
164
|
-
contents: [
|
|
165
|
-
{
|
|
166
|
-
text: JSON.stringify(result),
|
|
167
|
-
mimeType: "application/json",
|
|
168
|
-
uri: uri.href,
|
|
169
|
-
},
|
|
170
|
-
],
|
|
171
|
-
};
|
|
172
|
-
}
|
|
173
|
-
);
|
|
174
|
-
}
|
|
175
|
-
|
|
176
|
-
private async validateConfig(): Promise<void> {
|
|
177
|
-
if (this.userConfig.connectionString) {
|
|
178
|
-
try {
|
|
179
|
-
await this.session.connectToMongoDB(this.userConfig.connectionString, this.userConfig.connectOptions);
|
|
180
|
-
} catch (error) {
|
|
181
|
-
console.error(
|
|
182
|
-
"Failed to connect to MongoDB instance using the connection string from the config: ",
|
|
183
|
-
error
|
|
184
|
-
);
|
|
185
|
-
throw new Error("Failed to connect to MongoDB instance using the connection string from the config");
|
|
186
|
-
}
|
|
187
|
-
}
|
|
188
|
-
|
|
189
|
-
if (this.userConfig.apiClientId && this.userConfig.apiClientSecret) {
|
|
190
|
-
try {
|
|
191
|
-
await this.session.apiClient.validateAccessToken();
|
|
192
|
-
} catch (error) {
|
|
193
|
-
if (this.userConfig.connectionString === undefined) {
|
|
194
|
-
console.error("Failed to validate MongoDB Atlas the credentials from the config: ", error);
|
|
195
|
-
|
|
196
|
-
throw new Error(
|
|
197
|
-
"Failed to connect to MongoDB Atlas instance using the credentials from the config"
|
|
198
|
-
);
|
|
199
|
-
}
|
|
200
|
-
console.error(
|
|
201
|
-
"Failed to validate MongoDB Atlas the credentials from the config, but validated the connection string."
|
|
202
|
-
);
|
|
203
|
-
}
|
|
204
|
-
}
|
|
205
|
-
}
|
|
206
|
-
}
|