Use saturating addition for ephemeral timers

Integer overflows crash the application by default.

On a first sight this is only a potential crash that can't be
triggered, because timestamps are stored as i64 and ephemeral timer
duration is u32.
This commit is contained in:
link2xt
2021-09-10 22:49:48 +00:00
parent 15dcd62652
commit 6f3dd7f0c2
3 changed files with 5 additions and 3 deletions

View File

@@ -279,7 +279,7 @@ impl MsgId {
/// Starts ephemeral message timer for the message if it is not started yet.
pub(crate) async fn start_ephemeral_timer(self, context: &Context) -> anyhow::Result<()> {
if let Timer::Enabled { duration } = self.ephemeral_timer(context).await? {
let ephemeral_timestamp = time() + i64::from(duration);
let ephemeral_timestamp = time().saturating_add(duration.into());
context
.sql