Alex Vandiver
e6eace307e
CVE-2022-24751: Clear sessions outside of the transaction.
...
Clearing the sessions inside the transaction makes Zulip vulnerable to
a narrow window where the deleted session has not yet been committed,
but has been removed from the memcached cache. During this window, a
request with the session-id which has just been deleted can
successfully re-fill the memcached cache, as the in-database delete is
not yet committed, and thus not yet visible. After the delete
transaction commits, the cache will be left with a cached session,
which allows further site access until it expires (after
SESSION_COOKIE_AGE seconds), is ejected from the cache due to memory
pressure, or the server is upgraded.
Move the session deletion outside of the transaction.
Because the testsuite runs inside of a transaction, it is impossible
to test this is CI; the testsuite uses the non-caching
`django.contrib.sessions.backends.db` backend, regardless. The test
added in this commit thus does not fail before this commit; it is
merely a base expression that the session should be deleted somehow,
and does not exercise the assert added in the previous commit.
2022-03-15 20:29:05 +00:00
..
2021-10-27 05:23:34 +00:00
2021-04-15 18:01:34 -07:00
2021-05-10 09:57:26 -07:00
2022-03-15 20:29:05 +00:00
2021-04-15 18:01:34 -07:00
2021-02-12 13:11:19 -08:00
2021-04-15 18:01:34 -07:00
2021-02-12 13:11:19 -08:00
2021-02-12 13:11:19 -08:00
2021-02-12 13:11:19 -08:00
2021-04-28 08:32:21 -07:00
2021-02-12 13:11:19 -08:00
2021-04-29 16:06:17 -07:00
2022-03-15 20:29:05 +00:00
2021-05-10 09:57:26 -07:00
2021-02-12 13:11:19 -08:00
2021-02-12 13:11:19 -08:00
2021-02-12 13:11:19 -08:00
2021-04-30 15:57:09 -07:00
2021-02-12 13:11:19 -08:00
2021-02-12 13:11:19 -08:00
2021-02-12 13:11:19 -08:00
2021-02-12 13:11:19 -08:00
2021-02-12 13:11:19 -08:00
2021-02-12 13:11:19 -08:00
2021-04-15 18:01:34 -07:00
2021-02-12 13:11:19 -08:00
2021-05-13 11:17:01 -07:00
2021-07-22 21:31:36 +00:00
2021-04-15 18:01:34 -07:00
2021-04-15 18:01:34 -07:00
2021-04-15 18:01:34 -07:00
2021-04-29 15:13:50 -07:00
2021-05-18 19:17:13 -07:00
2021-04-15 18:01:34 -07:00
2021-05-10 09:57:26 -07:00
2021-05-10 09:57:26 -07:00
2021-02-12 13:11:19 -08:00
2021-02-12 13:11:19 -08:00
2021-05-06 17:52:00 -07:00
2021-05-12 10:21:48 -07:00
2021-04-26 09:31:08 -07:00
2021-02-12 13:11:19 -08:00
2021-02-12 13:11:19 -08:00
2021-02-12 13:11:19 -08:00
2021-05-10 09:57:26 -07:00
2021-02-12 13:11:19 -08:00
2021-05-10 17:50:32 -07:00
2021-02-12 13:11:19 -08:00
2021-05-10 12:30:58 -07:00
2021-02-12 13:11:19 -08:00
2021-02-12 13:11:19 -08:00
2021-05-12 16:23:22 -07:00
2021-02-12 13:11:19 -08:00
2021-02-12 13:11:19 -08:00
2021-02-12 13:11:19 -08:00
2021-04-29 16:06:17 -07:00
2021-04-15 18:01:34 -07:00
2021-05-07 08:39:36 -07:00
2021-09-23 14:49:36 -07:00
2021-04-22 14:53:00 -07:00
2021-02-12 13:11:19 -08:00
2021-11-03 11:41:57 -07:00
2020-06-11 16:45:32 -07:00
2021-02-12 13:11:19 -08:00
2021-02-12 13:11:19 -08:00
2021-02-12 13:11:19 -08:00
2021-02-12 13:11:19 -08:00
2021-02-12 13:11:19 -08:00
2021-02-12 13:11:19 -08:00
2021-04-15 18:01:34 -07:00
2021-04-15 18:01:34 -07:00
2021-04-15 18:01:34 -07:00
2021-02-12 13:11:19 -08:00
2021-02-12 13:11:19 -08:00
2022-03-15 20:29:05 +00:00
2021-10-18 17:06:11 -07:00
2021-04-30 09:25:11 -07:00
2021-02-12 13:11:19 -08:00
2021-11-10 12:30:24 -08:00
2021-02-12 13:11:19 -08:00
2021-02-12 13:11:19 -08:00
2021-02-12 13:11:19 -08:00
2021-05-12 16:23:22 -07:00
2021-05-12 08:10:57 -07:00
2021-04-29 16:06:17 -07:00
2021-06-08 15:28:32 -07:00
2021-05-02 11:12:49 -07:00
2021-04-29 16:06:17 -07:00
2021-09-07 13:56:41 -07:00
2021-03-25 12:58:36 -07:00
2021-05-06 20:07:32 -07:00
2021-05-07 22:42:39 -07:00
2021-02-12 13:11:19 -08:00
2021-05-06 20:07:32 -07:00
2021-02-15 17:05:28 -08:00
2021-02-12 13:11:19 -08:00
2021-02-12 13:11:19 -08:00
2021-03-30 12:11:35 -07:00
2021-05-12 16:23:22 -07:00
2021-02-12 13:11:19 -08:00
2021-02-12 13:11:19 -08:00
2021-04-05 18:16:08 -07:00
2021-03-16 14:46:18 -07:00
2021-06-22 09:36:29 -07:00
2021-02-12 13:11:19 -08:00
2021-02-12 13:11:19 -08:00
2021-04-15 18:01:34 -07:00
2021-04-22 14:53:00 -07:00
2021-02-12 13:11:19 -08:00
2021-05-02 11:12:49 -07:00
2021-02-12 13:11:19 -08:00
2021-07-01 15:15:11 -07:00
2021-06-14 17:57:24 -07:00
2021-04-15 18:01:34 -07:00
2021-02-12 13:11:19 -08:00