V-281700
SV-281700r1179499_rule
CAT III
MongoDB must terminate a user session after organization-defined conditions or trigger events requiring session disconnect via a scheduled script.
From: MongoDB Enterprise Advanced 8.x Security Technical Implementation Guide (V1R1)
Description
<VulnDiscussion>This addresses the termination of user-initiated logical sessions in contrast to the termination of network connections that are associated with communications sessions (i.e., network disconnect). A logical session (for local, network, and remote access) is initiated whenever a user (or process acting on behalf of a user) accesses an organizational information system. Such user sessions can be terminated (and thus terminate user access) without terminating network sessions.
Session termination ends all processes associated with a user's logical session except those batch processes/jobs that are specifically created by the user (i.e., session owner) to continue after the session is terminated.
Conditions or trigger events requiring automatic session termination can include, for example, organization-defined periods of user inactivity, targeted responses to certain types of incidents, and time-of-day restrictions on information system use.
This capability is typically reserved for specific cases where the system owner, data owner, or organization requires additional assurance.</VulnDiscussion><FalsePositives></FalsePositives><FalseNegatives></FalseNegatives><Documentable>false</Documentable><Mitigations></Mitigations><SeverityOverrideGuidance></SeverityOverrideGuidance><PotentialImpacts></PotentialImpacts><ThirdPartyTools></ThirdPartyTools><MitigationControl></MitigationControl><Responsibility></Responsibility><IAControls></IAControls>
Check Procedure
Review system documentation to obtain the organization's definition of circumstances requiring automatic session termination.
If the documentation explicitly states that such termination is not required or is prohibited, this is not a finding.
Ensure a script is in place and scheduled that does the following (see fix content for example commands):
1. Lists all user sessions.
2. From the output, determines which user-initiated database sessions must be terminated.
3. Terminates the identified sessions by user.
If a script does not exist or is not scheduled to run at least daily, this is a finding.
Fix Text
Determine the situations when a user-initiated database session must be terminated.
Note: The user running the commands shown below must have privileges with listSessions, killAnySession and impersonate action on the cluster.
In the MongoDB shell, as an authenticated user, run the following command to list all user sessions:
> use config
> db.system.sessions.aggregate( [ { $listSessions: { allUsers: true } }
Reference: https://docs.mongodb.com/v8.0/reference/operator/aggregation/listSessions/
Example output:
{ "_id" : { "id" : UUID("b3b50641-54c6-4d6d-a96e-a2239fadce3c"), "uid" : BinData(0,"Y5mrDaxi8gv8RmdTsQ+1j7fmkr7JUsabhNmXAheU0fg=") }, "lastUse" : ISODate("2021-09-23T23:34:43.951Z"), "user" : { "name" : "jsmith@admin" } }
From the output, identify the names of users whose sessions should be terminated. Using the user for each session to be terminated, run the following command (still in MongoDB shell):
> db.runCommand( { killAllSessionsByPattern: [ { users: [ { user: <user>, db: <dbname> }, ... ] }] } )
Example to terminate user "jsmith@admin" sessions from example output:
> db.runCommand( { killAllSessionsByPattern: [ { users: [ { user: "jsmith", db: "admin" } ] }]} )
To terminate all user sessions running on the database, run the following command (still in MongoDB shell):
> db.runCommand( { killAllSessionsByPattern: [ ] } )
Reference: https://docs.mongodb.com/v8.0/reference/command/killAllSessionsByPattern/
CCI Reference
CCI-002361- Created
- 2026-04-07 20:08:22
- Last Updated
- 2026-04-07 20:08:22