hedgedoc/lib
Julian Rother 2eb4c8e05f Fix premature note cleanup on error
Connection forbidden errors cause cleanup of note state without first
checking if other clients are still connected to the note. This leads
to inconsistent pad content and changes not being saved properly.

This change reverts parts of 725e982 (Fix realtime on forbidden not clean
up properly ...). The call to `interruptConnection()` on permission errors
is redundant, since `failConnection()` and `disconnect()` already perform
all required cleanup in this case. The other call to `interruptConnection()`
only happens when a client (the first client for a note) disconnects while
the note is being loaded from the database. It is refactored for clarity.

Fixes #3894

Co-authored-by: David Mehren <git@herrmehren.de>
Signed-off-by: Julian Rother <julian@jrother.eu>
2023-05-28 16:10:51 +02:00
..
config Allow setting documentMaxLength via CMD_DOCUMENT_MAX_LENGTH 2023-03-09 10:20:42 +01:00
migrations
models
ot
web feat(healthcheck): add /_health endpoint 2023-03-19 22:09:16 +01:00
workers
csp.js
errors.js
history.js
letter-avatars.js
logger.js
prometheus.js
realtime.js Fix premature note cleanup on error 2023-05-28 16:10:51 +02:00
response.js
utils.js