Sam Lanning 69f180a5ec Fix some potential integer overflows for expiration time
In a number of locations in the code, there were conversions of message
expiration times from seconds to milliseconds, and then assigned to `long`
contexts. However these conversions were being done as integer multiplication
rather than long multiplication, meaning that there was a potential for
overflows.

Specifically, the maximum value that could be represented before overflowing
was (2^31 / 1000 / 60 / 60 / 24) days = 24.8 days (< 1 month). Luckily the
current allowed timeouts are all less than that value, but this fix would
remove the artificial restriction, effectively allowing values of 1000x greater
(68 years), at least for android.

Related #5775
Closes #7338
2018-03-07 09:55:24 -08:00
..
2017-11-14 10:50:17 -08:00
2018-03-05 16:11:49 -08:00
2016-02-18 17:52:01 -08:00
2018-03-07 09:51:05 -08:00
2017-10-01 22:36:52 -07:00
2018-02-01 19:22:48 -08:00
2018-03-05 16:13:56 -08:00
2017-12-08 14:36:56 -08:00
2016-09-25 14:23:52 -07:00
2018-03-07 09:51:05 -08:00
2018-02-01 18:29:09 -08:00
2018-03-07 09:51:05 -08:00
2018-02-01 19:22:48 -08:00
2015-11-19 11:30:39 -08:00
2018-02-01 19:22:48 -08:00
2017-10-11 17:47:12 -07:00
2015-11-19 10:30:26 -08:00
2016-11-11 18:44:22 -08:00
2018-02-01 19:22:48 -08:00