Paper 2022/1710
Formal Analysis of Session-Handling in Secure Messaging: Lifting Security from Sessions to Conversations
Abstract
The building blocks for secure messaging apps, such as Signal’s X3DH and Double Ratchet (DR) protocols, have received a lot of attention from the research community. They have notably been proved to meet strong security properties even in the case of compromise such as Forward Secrecy (FS) and Post-Compromise Security (PCS). However, there is a lack of formal study of these properties at the application level. Whereas the research works have studied such properties in the context of a single ratcheting chain, a conversation between two persons in a messaging application can in fact be the result of merging multiple ratcheting chains. In this work, we initiate the formal analysis of secure messaging taking the session-handling layer into account, and apply our approach to Sesame, Signal’s session management. We first experimentally show practical scenarios in which PCS can be violated in Signal by a clone attacker, despite its use of the Double Ratchet. We identify how this is enabled by Signal’s session-handling layer. We then design a formal model of the session-handling layer of Signal that is tractable for automated verification with the Tamarin prover, and use this model to rediscover the PCS violation and propose two provably secure mechanisms to offer stronger guarantees.
Metadata
- Available format(s)
- Category
- Cryptographic protocols
- Publication info
- Preprint.
- Keywords
- Formal analysisTamarinPCSPost-Compromise SecuritySignalSesame
- Contact author(s)
-
cremers @ cispa de
charlie jacomme @ inria fr
aurora naska @ cispa de - History
- 2024-08-05: last of 3 revisions
- 2022-12-09: received
- See all versions
- Short URL
- https://ia.cr/2022/1710
- License
-
CC BY
BibTeX
@misc{cryptoeprint:2022/1710, author = {Cas Cremers and Charlie Jacomme and Aurora Naska}, title = {Formal Analysis of Session-Handling in Secure Messaging: Lifting Security from Sessions to Conversations}, howpublished = {Cryptology {ePrint} Archive, Paper 2022/1710}, year = {2022}, url = {https://eprint.iacr.org/2022/1710} }