Page MenuHomePhabricator

Make partial sessions expire after 30 minutes, and do not extend them
ClosedPublic

Authored by epriestley on Dec 18 2018, 7:58 PM.
Tags
None
Referenced Files
F14055496: D19905.diff
Sat, Nov 16, 12:33 PM
F14043442: D19905.diff
Tue, Nov 12, 10:13 AM
F14025740: D19905.diff
Thu, Nov 7, 7:56 PM
F14001131: D19905.diff
Fri, Oct 25, 4:25 AM
Unknown Object (File)
Oct 13 2024, 5:35 PM
Unknown Object (File)
Oct 9 2024, 11:01 AM
Unknown Object (File)
Sep 27 2024, 2:12 PM
Unknown Object (File)
Sep 6 2024, 4:46 AM
Subscribers
None

Details

Summary

Depends on D19904. Ref T13226. Ref T13222. Currently, partial sessions (where you've provided a primary auth factor like a password, but not yet provided MFA) work like normal sessions: they're good for 30 days and extend indefinitely under regular use.

This behavior is convenient for full sessions, but normal users don't ever spend 30 minutes answering MFA, so there's no real reason to do it for partial sessions. If we add login alerts in the future, limiting partial sessions to a short lifetime will make them more useful, since an attacker can't get one partial session and keep extending it forever while waiting for an opportunity to get past your MFA.

Test Plan
  • Did a partial login (to the MFA prompt), checked database, saw a ~29 minute partial session.
  • Did a full login, saw session extend to ~30 days.

Diff Detail

Repository
rP Phabricator
Lint
Lint Not Applicable
Unit
Tests Not Applicable