
Security News
Attackers Are Hunting High-Impact Node.js Maintainers in a Coordinated Social Engineering Campaign
Multiple high-impact npm maintainers confirm they have been targeted in the same social engineering campaign that compromised Axios.
@mongosh/cli-repl
Advanced tools
CLI interface for MongoDB Shell, an extension to Node.js REPL with MongoDB API.
This package is a convenience distribution of mongosh. To download a fully supported version of mongosh, visit https://www.mongodb.com/try/download/shell.
$ mongosh [options] [db address] [file names (ending in .js or .mongodb)]
Options:
-h, --help Show this usage information
-f, --file [arg] Load the specified mongosh script
--host [arg] Server to connect to
--port [arg] Port to connect to
--build-info Show build information
--version Show version information
--quiet Silence output from the shell during the connection process
--shell Run the shell after executing files
--nodb Don't connect to mongod on startup - no 'db address' [arg] expected
--norc Will not run the '.mongoshrc.js' file on start up
--eval [arg] Evaluate javascript
--json[=canonical|relaxed] Print result of --eval as Extended JSON, including errors
--retryWrites[=true|false] Automatically retry write operations upon transient network errors (Default: true)
--deep-inspect[=true|false] Force full depth inspection of server results (default: true if in interactive mode)
Authentication Options:
-u, --username [arg] Username for authentication
-p, --password [arg] Password for authentication
--authenticationDatabase [arg] User source (defaults to dbname)
--authenticationMechanism [arg] Authentication mechanism
--awsIamSessionToken [arg] AWS IAM Temporary Session Token ID
--gssapiServiceName [arg] Service name to use when authenticating using GSSAPI/Kerberos
--sspiHostnameCanonicalization [arg] Specify the SSPI hostname canonicalization (none or forward, available on Windows)
--sspiRealmOverride [arg] Specify the SSPI server realm (available on Windows)
TLS Options:
--tls Use TLS for all connections
--tlsCertificateKeyFile [arg] PEM certificate/key file for TLS
--tlsCertificateKeyFilePassword [arg] Password for key in PEM file for TLS
--tlsCAFile [arg] Certificate Authority file for TLS
--tlsAllowInvalidHostnames Allow connections to servers with non-matching hostnames
--tlsAllowInvalidCertificates Allow connections to servers with invalid certificates
--tlsCertificateSelector [arg] TLS Certificate in system store (Windows and macOS only)
--tlsCRLFile [arg] Specifies the .pem file that contains the Certificate Revocation List
--tlsDisabledProtocols [arg] Comma separated list of TLS protocols to disable [TLS1_0,TLS1_1,TLS1_2]
--tlsFIPSMode Enable the system TLS library's FIPS mode
API version options:
--apiVersion [arg] Specifies the API version to connect with
--apiStrict Use strict API version mode
--apiDeprecationErrors Fail deprecated commands for the specified API version
FLE Options:
--awsAccessKeyId [arg] AWS Access Key for FLE Amazon KMS
--awsSecretAccessKey [arg] AWS Secret Key for FLE Amazon KMS
--awsSessionToken [arg] Optional AWS Session Token ID
--keyVaultNamespace [arg] database.collection to store encrypted FLE parameters
--kmsURL [arg] Test parameter to override the URL of the KMS endpoint
OIDC auth options:
--oidcFlows[=auth-code,device-auth] Supported OIDC auth flows
--oidcRedirectUri[=url] Local auth code flow redirect URL [http://localhost:27097/redirect]
--oidcTrustedEndpoint Treat the cluster/database mongosh as a trusted endpoint
--oidcIdTokenAsAccessToken Use ID tokens in place of access tokens for auth
--oidcDumpTokens[=mode] Debug OIDC by printing tokens to mongosh's output [redacted|include-secrets]
--oidcNoNonce Don't send a nonce argument in the OIDC auth request
DB Address Examples:
foo Foo database on local machine
192.168.0.5/foo Foo database on 192.168.0.5 machine
192.168.0.5:9999/foo Foo database on 192.168.0.5 machine on port 9999
mongodb://192.168.0.5:9999/foo Connection string URI can also be used
File Names:
A list of files to run. Files must end in .js and will exit after unless --shell is specified.
Examples:
Start mongosh using 'ships' database on specified connection string:
$ mongosh mongodb://192.168.0.5:9999/ships
For more information on usage: https://mongodb.com/docs/mongodb-shell.
CLI REPL listens to a few events via a message bus that are then logged to
user's local log file in ~/.mongodb/mongosh/ in ndjson format using
pino.
Where connectionInfo is an object with the following interface:
interface ConnectEvent {
driverUri: string;
}
Used to log and send telemetry about connection information. Sensitive information is stripped beforehand.
Example:
bus.emit('mongosh:connect', {
driverUri: 'mongodb://192.168.0.5:9999/ships',
});
Where telemetryUserIdentity is userId and anonymousId which are both a BSON ObjectID.
And enableTelemetry is a boolean flag.
This is used internally to update telemetry preferences.
Example:
bus.emit(
'mongosh:new-user',
{ userId: '12394dfjvnaw3uw3erdf', anonymousId: '12394dfjvnaw3uw3erdf' },
true
);
Where telemetryUserIdentity is userId and anonymousId which are both a BSON ObjectID.
And enableTelemetry is a boolean flag.
This is used internally to update telemetry preferences.
Example:
bus.emit(
'mongosh:update-user',
{ userId: '12394dfjvnaw3uw3erdf', anonymousId: null },
false
);
Where error is an Error Object. Used to log and send telemetry
about errors that are thrown.
Example:
bus.emit('mongosh:error', new Error('Unable to show collections'));
Used for internal debugging of async-rewriter. inputInfo is an object with the
following interface:
interface AsyncRewriterEvent {
original: string;
rewritten: string;
}
Example:
bus.emit('mongosh:rewritten-async-input', {
original: 'db.coll.find().forEach()',
rewritten: 'await db.coll.find().forEach();',
});
Used for recording information about use. args has the following interface:
interface UseEvent {
db: string;
}
Example:
bus.emit('mongosh:use', { db: 'cats' });
Used for recording information about show command. args has the following
interface:
interface ShowEvent {
method: string;
}
Example:
bus.emit('mongosh:show', { method: 'dbs' });
Used for recording when it command was called.
Example:
bus.emit('mongosh:it');
Used for recording information when API calls are made. args has the following
interface:
interface ApiEvent {
method?: string;
class?: string;
db?: string;
coll?: string;
arguments?: ApiEventArguments;
}
interface ApiEventArguments {
pipeline?: any[];
query?: object;
options?: object;
filter?: object;
}
arguments may contain information about the API call. As a rule, we don't emit
information containing documents coming from API calls such as
db.coll.insert() or db.coll.bulkWrite() to keep cleaner logs.
aggregate Event Example:
this.messageBus.emit('mongosh:api-call', {
method: 'aggregate',
class: 'Collection',
db,
coll,
arguments: { options, pipeline },
});
runCommand Event Example:
this.messageBus.emit('mongosh:api-call', {
method: 'runCommand',
class: 'Database',
db,
arguments: { cmd },
});
createIndex Event Example:
this.messageBus.emit('mongosh:api-call', {
method: 'createIndex',
class: 'Collection',
db,
coll,
arguments: { keys, options },
});
npm install --save @mongosh/cli-repl
FAQs
MongoDB Shell CLI REPL Package
The npm package @mongosh/cli-repl receives a total of 18,317 weekly downloads. As such, @mongosh/cli-repl popularity was classified as popular.
We found that @mongosh/cli-repl demonstrated a healthy version release cadence and project activity because the last version was released less than a year ago. It has 5 open source maintainers collaborating on the project.
Did you know?

Socket for GitHub automatically highlights issues in each pull request and monitors the health of all your open source dependencies. Discover the contents of your packages and block harmful activity before you install or update your dependencies.

Security News
Multiple high-impact npm maintainers confirm they have been targeted in the same social engineering campaign that compromised Axios.

Security News
Axios compromise traced to social engineering, showing how attacks on maintainers can bypass controls and expose the broader software supply chain.

Security News
Node.js has paused its bug bounty program after funding ended, removing payouts for vulnerability reports but keeping its security process unchanged.