Np1sec
Contents
- 1 Abstract
- 2 I. INTRODUCTION
- 3 II. History and literature review
- 4 III. Design rationale
- 5 IV. Security Properties
- 6 V. Chat Session Model
- 7 VI. Threat Models and Adversarial Goals
- 8 VII. Protocol High Level Design
- 9 VIII. (n)sec Protocol: Step by Step
- 9.1 VIII.1 Schematic view of the key exchange
- 9.2 VIII.2 Chatroom Setup
- 9.2.1 Join
- 9.2.2 Authentication Step for parties in the room
- 9.2.3 Initiate new session
- 9.2.4 Sending and receiving messages while joining is in progress
- 9.2.5 Leave
- 9.2.6 Farewell
- 9.2.7 Shrink
- 9.2.8 Secure Send and Receive
- 9.2.9 Reaching Consistency
- 9.2.10 Heartbeat
- 9.2.11 Failure to heartbeat and inactivity timers
 
 
- 10 IX Cryptographic Primitives
- 11 X. Conclusion
- 12 XI. References
- 13 Appendices
Abstract
In this document we present the first public draft of (n)sec - a secure multi-party communication protocol developed by eQualit.ie with support from the Open Technology Fund and Cryptocat. We include the design rationale, choice of security features, adversarial models, schematic and high level specification of sub-protocols. A subsequent document will present security proofs and implementation details.
I. INTRODUCTION
The (n)sec project was inspired by Off-The-Record messaging protocol and subsequent efforts to explore a multiparty use-case for OTR in [GUVGC09]. (n)sec is currently developed for Cryptocat - a browser based XMPP chat platform and assumes its use-cases. Most importantly, (n)sec allows for secure multi-party key exchange and end-to-end encrypted communications without extensive computational requirements from the client. You can follow and contribute to the implementation of libmpotr on our Github pages. Future protocol iterations will consider a variety of other real-world use cases and be platform independent.
In the following section we summarise relevant publications and describe their influence on this protocol. In Section III, we describe our approach and choice of security features. In Section IV, we review the security properties within this protocol. In Section V we give basic mathematical definition needed to model the chat session and security proofs for various security aspects of the protocol. Section VI provides formal definitions and references to the adversarial models for each property. In Section VII we describe various parts of the protocol and present choices for each sub protocol. In Section VIII, we present each of the (n)sec protocol steps at various stages in schematic and algorithmic format. We present our choice of primitives in Section IX. Finally, we conclude by describing work remaining to be done on this protocol.
II. History and literature review
Two-party Off The Record messaging (OTR) was introduced in [BGB04] as an alternative to PGP for secure casual Internet chat by providing necessary forward secrecy and deniable transcript features. The paper proposes the use of symmetric encryption and message authentication in OTR for confidentiality and integrity, and the Diffie-Hellman key exchange for authenticating the other party in the chat. Since publication in 2004, it has defined the standard for secure Internet chat attracting a lot of academic attention and security analysis. The OTR protocol is now at Version 3 and the libotr software libraries are continuously updated. Our research and literature review focused on the protocol presented in [BGB04] and the subsequent proposal for a multiparty use-case in [GUVGC09].
In [RGK05], researchers point out that OTR’s approach to authenticate renewed ephemeral session keys is provided by the property of confidentiality and is therefore dependent on the secrecy of the conversation. Hence, breaking the secrecy of the conversation (e.g. by leaking the session key) will lead to false authentication as well. They offer two authenticated deniable key exchange protocols, which also provide forward secrecy, as a replacement for OTR’s original key exchange. Furthermore, they argue that forgeability and malleability do not have any mathematical consequence in improving deniability if the parties have been authenticated by a deniable key exchange scheme. They argue that as these properties pose potential security threats, it is desirable to omit them from the protocol entirely.
An alternative appears in [BS07], using the Schnorr zero-knowledge proof and signature algorithm, to introduce a 4-round challenge-based authentication scheme that grants deniability to the two-round authenticated protocol described in [BVS05].
[ACMP10] offers a more efficient protocol than [BS07] in the sense that ephemeral Diffie-Hellman elements are reusable to regenerate keys when some of the participants change. As such, it offers a one-round protocol to generate a key for a subgroup of the original conversation.
An unauthenticated exchange of the OTR version identifier can pose a threat to authenticity as shown in [BM]: the adversary can force clients to downgrade to an older, insecure version of the protocol. They also note the Diffie-Hellman key exchange failure in delivering authentication in the presence of an active adversary. Furthermore, they show that the early publication of MAC keys for the purpose of forgeability can easily enable the active adversary to forge messages during the conversation (instead of the intended forgeability after the conversation has ended). Finally, they argue that in an environment where the adversary is controlling the whole network, she can effectively disarm the protocol of its forgeability property.
Various attempts have been made to construct an efficient multiparty (known as group) authenticated key exchange protocol. OTR authors proposed a generalisation of two-party OTR to a multiparty use-case in [GUVGC09]. However, they did not specify the cryptographic primitives, neither did they give a formal definition of the adversaries nor the proof of the algorithm’s security (reduction). Although a more robust key exchange is proposed, some primary performance analysis of the implementation of the key agreement protocol has been shown to be impractically slow, especially on mobile devices [Gun13a].
III. Design rationale
Our approach for (n)sec design was based on the following requirements, in order of importance:
- A protocol that is provably secure in a sufficiently strong adversarial model that addresses confidentiality, authenticity and forward secrecy
- Applicable to the Cryptocat XMPP use-case
- Providing some degree of deniability when it does not negatively impact usability or our security goals
- Addressing security flaws in [BGB04] and [GUVGC09]
We designate the protocol suggested in [GUVGC09] as our starting point and apply various modifications to reach a desirable protocol satisfying the above stated goals.
A significant portion of our research suggested a better performing, more secure alternative to the key exchange protocol suggested in [GUVGC09]. Based on conclusions in [BM] and [RGK05], we are making the following design changes:
- Using a more secure deniable key exchange algorithm, instead of naive Diffie-Hellman
In designing (n)sec’s deniable authentication and key agreement protocol, we have followed [ACMP10] by choosing a provably secure authenticated key exchange method and replacing the signature-based authentication with a deniable one. We have chosen the protocol introduced in [ACMP10] instead of [BS07], due to its superior efficiency. We abstract out the method where parties communicate their secret for additional flexibility.
- Using a more practical algorithm, rather than the peer-to-peer signature key exchange
We have chosen the two round SKEME-based Triple Diffie-Hellman deniable key authentication instead of the Schnorr signature scheme suggested in [BS07] because it saves us two critical rounds for authentication (even though it offers a slightly weaker form of deniability). We have also modified the protocol to represent the chat condition where participants sequentially join and leave the chat.
- Omitting forgeability and malleability from the protocol and refraining from broadcasting the expired ephemeral authentication keys.
Following conclusions in [RGK05] we have dropped forgeability (mandatory publication of ephemeral signature/MAC keys) and malleability from our requirements since protocol deniability is based on a deniable key exchange. This significantly improves protocol efficiency, a primary focus for (n)sec. The deniability of the authentication scheme prevents users not present in a chat session from forging a part of the transcript, however it allows them to forge a whole session with false participants and a complete transcript.
Another major departure from the suggested protocol in [GUVGC09] is in-session transcript authentication, which happens every time a participant receives or sends a message. Transcript authentication (referred to as transcript consistency check from here on) is an optimistic approach based on the assumption that the XMPP server provides a reliable and orderly message delivery. We can ensure transcript consistency whenever the underlying transport layer guarantees the reliable delivery of the messages in the same order for all participants.
We also equip (n)sec with heartbeat to ensure in-session forward secrecy, periodical consistency check and freshness.
We propose the possibility of using block-based, rather than stream-based, encryption for the symmetric encryption primitives.
Finally, other protocol design possibilities we considered and the rationale for not pursuing them further is discussed in Appendix B: Other design possibilities
IV. Security Properties
Following from the design rationales proposed in SectionIII, we give an informal description of the properties which (n)sec aims to secure in a multi-party chat session:
- Participant deniable authenticity based on their long term persistent identity: While a participant in a chat can be sure of another participant’s authenticity, they cannot prove their confidence to anybody else who has not actively participated in the chat session or who has not interacted with the authenticator prior to the session.
- Message origin authenticity against both outsider intrusion and the impersonation of existing participants by other malicious participants in the session. This means that the user can be assured of the authenticity of the sender of each original message even if other participants in the room try to impersonate the sender and send messages on their behalf.
- Confidentiality of the conversation so its content is not accessible or readable by an outsider.
- Forward secrecy of the conversation, so its content remains inaccessible in the event that the long term private key of a participant (which represents their long term identity) is compromised after session key establishment. In addition in-session forward secrecy means that compromise of the ephemeral keys of a participant, or the session key during chat session which is live for long time, would reveal only a fraction of the transcript.
- Room consistency, where all participants are confident that they have been participating in the same room; they are confident that everybody in the room believes that everybody else sees the same participant list as they do.
- Transcript consistency, where all participants are confident that they have been participating in the same conversation; they are confident that they have seen the same sequence of messages.
For each of these requirements, it is necessary to formalize the above mentioned properties against an adversarial model which addresses the elements discussed in III. The next section will introduce formal definitions covering these elements.
V. Chat Session Model
In modelling the chat session, in terms of the adversarial models and protocol specifications, the notation of [ACMP10] is followed. This notation is common to other publication on group key exchange such as [GBNM11], and is adherred to for consistency.
Definition III.1 Multi-party chat session: Let  be the set of possible participants. A multi-party chat session is an ordered pair
 be the set of possible participants. A multi-party chat session is an ordered pair  in which
 in which  and
 and  is the unique session id. Without loss of generality we assume
 is the unique session id. Without loss of generality we assume  and we interchangeably refer to party
 and we interchangeably refer to party  by index i. Furthermore, it is assumed that party
 by index i. Furthermore, it is assumed that party  is presented and identified verifiably by a long-term persistence key pair
 is presented and identified verifiably by a long-term persistence key pair  .
.
Definition III.2 sub session After session S is established, A subset of participants   might want to start a session in which parties in
 might want to start a session in which parties in  are excluded (for example when those parties leave the chatroom). In such a setting we say
 are excluded (for example when those parties leave the chatroom). In such a setting we say  is a subsession of S. When there is no need to specify the subsession of choice, we use
 is a subsession of S. When there is no need to specify the subsession of choice, we use  to refer to
 to refer to  .
.
Definition III.3 An authenticated group key exchange (AGKE) is Algorithm  which each honest party will execute in order to communicate (by means of sending, receiving or computing) a cryptographic secret - namely a key - among the other parties of a session. By
 which each honest party will execute in order to communicate (by means of sending, receiving or computing) a cryptographic secret - namely a key - among the other parties of a session. By  (or
 (or  when the underlying session is understood) we are referring to an instance of
 when the underlying session is understood) we are referring to an instance of  which the party
 which the party  executes to achieve the collective goal. Further more we define:
 executes to achieve the collective goal. Further more we define:
-  Session id as seen by  : Session id : Session id will be derived during the execution of the protocol. The session id is computed by will be derived during the execution of the protocol. The session id is computed by (the instance of the protocol run by (the instance of the protocol run by for session S) and is indicated by for session S) and is indicated by , or , or when there is no concern of confusion when there is no concern of confusion
-  Participant list:  is the list of participants which is the list of participants which believes are participating in the chat session S. believes are participating in the chat session S.
-  Session key of  as seen by as seen by : : (or (or ) is the session key of session S as computed by ) is the session key of session S as computed by . It represents the cryptographic secret computed by AGKE, it can be a set of secrets. The essential defining factor is that it should become common knowledge for the session participants at the end of AGKE execution. Similarly we define . It represents the cryptographic secret computed by AGKE, it can be a set of secrets. The essential defining factor is that it should become common knowledge for the session participants at the end of AGKE execution. Similarly we define to represent the subsession key to represent the subsession key
-  Accepted state: A party enters the accepted state if it has computed  and has detected no errors in the protocol. and has detected no errors in the protocol.
-  Partnered instances: Two instances  and and are considered partnered if and only if both instances have accepted are considered partnered if and only if both instances have accepted and and . .
-  A correct AKGE algorithm is an AKGE which, when all  instances of AKE algorithm are initiated with access to a network which correctly forwards all messages without modification, all participants ultimately are partnered and all compute equal instances of AKE algorithm are initiated with access to a network which correctly forwards all messages without modification, all participants ultimately are partnered and all compute equal ’s. ’s.
When underlying session are not considered we may omit the super script  from all above notations.
 from all above notations.
VI. Threat Models and Adversarial Goals
Adversarial models are explained as a game, in which the adversary's possibilitiy of winning the game should be considered in terms of their ability to break the cryptographic primitives.
Accordingly to the requirements discussed in Section IV, it is necessary to examine the algorithm in terms of following threat cases:
- Deniable Authenticated key exchange (including a forward secrecy adversary)
- Message origin authenticity
- Confidentiality
- Transcript consistency
The following sections will define adversarial scenarios which represent the above threats.
Deniable Authenticated Key Exchange Adversary
Following the approach in [BoSt06] the model is divided into two adversaries: Authenticated Group Key Exchange and the Deniability Adversary.
As deniability is not our primary focus, we wil consider a weaker deniability adversarial model, which limits possible input similarly to the limitations considered by [GKR06]. This provision would disallow an input from the 'judge' and therefore saves an extra round of communication within the protocol.
Because he t(n)sec protocol runs a peer-to-peer key exchange and establishes parallel deniable authentication, we use the adversarial model from [ACMP10] for authenticated group key exchange. This ensures the security of both group and peer-to-peer keys independently. The protocol also takes advantage of "single round computation of a subgroup key". Meaning that when a participant leaves the session remaining participants can re-establish a (sub)session with only one round of communication. In this circumstance, the model must also consider an adversary's attack against the subgroup key.
We do not attempt to model resistance against internal key compromise impersonation (KCI) as defined [GBNM11].
Authenticated Key Exchange Adversary
Adversarial power
The following set of functions model the AKE adversarial threats. The adversary for the authenticated key exchange can mount an attack through a sequence of call to the functions, outlined below. The limitation on the order and condition of calling these functions is defined per adversary. We will re-use these definitions to demonstrate similar routes for other adversaries considered by the threat models in later sections.
-  Execute( ): asks all parties in the ): asks all parties in the to run (a new) AGKE protocol and to run (a new) AGKE protocol and will receive the execution transcript, i.e. will receive the execution transcript, i.e. can eavesdrop. can eavesdrop.
-  Send( )/( )/( ) sends a message m to the instance ) sends a message m to the instance . We assume that m contains information to identify the sender . We assume that m contains information to identify the sender . . will receive the execution transcript. Specifically, by sending will receive the execution transcript. Specifically, by sending messages it forces messages it forces to initiate to initiate . .
-  SKE( ): asks ): asks to compute the subgroup key for the to compute the subgroup key for the subsession. In response, subsession. In response, will either send a message or compute the subgroup key will either send a message or compute the subgroup key depending on the state of depending on the state of . This can be invoked only once per input. . This can be invoked only once per input.
-  RevealGK( )}: )}: gives gives to to if it has accepted (as defined in Definition III.3). if it has accepted (as defined in Definition III.3).
-  RevealSK( ): ): gives the gives the to to if it has been computed for subsession T. if it has been computed for subsession T.
-  Corrupt( ): ): gives its long term secret key to gives its long term secret key to (but not the session key). (but not the session key).
Adversary's challenges
The following set of functions model the adversary's challenges. These reveal either a random value or a key. The adversary's advantage in distinguishing the cases should be translatable into an attack against the GDH primitive for the protocol to be considered secure.
-  TestGK( ): To the ultimate goal of challenging the confidentially of ): To the ultimate goal of challenging the confidentially of , , can run TestGK( can run TestGK( ) against U. As a the result a random bit b is chosen, if ) against U. As a the result a random bit b is chosen, if then then is given is given the session key, otherwise a random value from the same probability distribution is given to the session key, otherwise a random value from the same probability distribution is given to . Obviously, this can only be invoked once and only on accepted participants. . Obviously, this can only be invoked once and only on accepted participants.
-  TestSK( ): To the ultimate goal of challenging the confidentially of ): To the ultimate goal of challenging the confidentially of , , can run TestSK( can run TestSK( ) against U. The result depends on a a random chosen bit b, if ) against U. The result depends on a a random chosen bit b, if then then is given is given the subsession key, otherwise a random value from the same probability distribution is given to the subsession key, otherwise a random value from the same probability distribution is given to . .
Definition of Adversaries and their advantages
The following terminology is useful in simplifying the elimination of trivial adversarial threats.
Definition VI.1 Accepted  is fresh if none of the following is true:
  is fresh if none of the following is true:
-  RevealGK( ) for ) for . .
-  Corrupt( ) invoked for any ) invoked for any before any Send( before any Send( ). ).
Definition VI.2 A pair of  is fresh, if
 is fresh, if  is accepted and if none of the following is true:
  is accepted and if none of the following is true:
-  RevealSK( ) for ) for . .
-  Corrupt( ) invoked for any ) invoked for any before any Send( before any Send( ). ).
Definition VI.3 An AKE Adversary for the join key agreement  is a probabilistic polynomial time algorithm (ppt) which can invoke all the functions given above with a
condition that the TestSK is invoked at least once against a fresh instance
 is a probabilistic polynomial time algorithm (ppt) which can invoke all the functions given above with a
condition that the TestSK is invoked at least once against a fresh instance  which stays fresh until the end of the game. The game ends when
 which stays fresh until the end of the game. The game ends when  outputs its guess for b. We say a key exchange protocol is secure if the following function is negligible:
 outputs its guess for b. We say a key exchange protocol is secure if the following function is negligible:
 
Similarly we define  the Adversary leaving the session:
 the Adversary leaving the session:
Definition VI.4 An AKE Adversary for the leave key agreement  is a ppt which can invoke all the functions given above with the condition that one of the invocations of TestSK is invoked against a fresh instance
 is a ppt which can invoke all the functions given above with the condition that one of the invocations of TestSK is invoked against a fresh instance  which stays fresh till the the end of the game. The game ends when
 which stays fresh till the the end of the game. The game ends when  outputs its guess for b for that invocation. We say a key exchange protocol is secure if the following function is negilgible:
 outputs its guess for b for that invocation. We say a key exchange protocol is secure if the following function is negilgible:
 
Forward Secrecy Adversary
We do not define an independent forward secrecy adversary. Forward secrecy can be derived by resistance against the confidentiality adversary as well incorporating a forward secure key exchange as described in [GBN10]. The adversaries of Definition VI.3 and VI.4, are able to Corrupt users after the communication of DH secrets. Therefore they can trivially break an AKE which without forward secrecy. In this sense, the resistance against forward secrecy adversary is included in AKE adversarial model.
Deniability Adversary
We use the deniability adversary of [BoSt06], however following the path of [GRK06], we limit the security input of the deniability adversary in order to prevent the adversary from receiving input from the judge.
'Definition VI.5 A Deniability Adversary   with bound
 with bound  and security input
 and security input  is a ppt algorithm which can invoke Send and Reveal as desired and Corrupt as many as
 is a ppt algorithm which can invoke Send and Reveal as desired and Corrupt as many as  times. At the end,
 times. At the end,  will output a transcript
 will output a transcript  .
.
Definition VI.6 For each  , we define a simulator
, we define a simulator  , is a ppt algorithm which receives the same input as
, is a ppt algorithm which receives the same input as  . It can invoke Corrupt
. It can invoke Corrupt  times in addition to Send and Reveal but only against corrupted instances. It terminates by outputting a transcript
 times in addition to Send and Reveal but only against corrupted instances. It terminates by outputting a transcript  .
. 
Definition VI.7 A deniability judge  with security input
 with security input  is a ppt algorithm which can invoke arbitrary number of deniability adversaries
 is a ppt algorithm which can invoke arbitrary number of deniability adversaries  with security input
 with security input  . On each execution of
. On each execution of  a corresponding
 a corresponding  runs with the same input. At the end a confidential random bit b is generated, and either
 runs with the same input. At the end a confidential random bit b is generated, and either  or
 or  is presented to
  is presented to   based on whether
 based on whether  or 0 respectively.
 or 0 respectively. 
Definition VI.8 We call a Group AKE deniable with respect to input set  , if the following advantage is negligible:
, if the following advantage is negligible:
 
Similar to [GRK06], we claim that the AKE presented in this paper is deniable when  is equal to the set of valid messages eavesdropped by
 is equal to the set of valid messages eavesdropped by  during other sessions. This, in particular, excludes a transcript computed by
 during other sessions. This, in particular, excludes a transcript computed by  such as a group element whose discrete logarithm is only known to
 such as a group element whose discrete logarithm is only known to  (This means
 (This means  is given
 is given  but is unaware of a).
 but is unaware of a).
Secure Multiparty Channel Adversary
The desirable way to define an adversary for a multiparty chat session is a secure channel model similar to the two-party secure channels described in [CaKr01] and [KPW13]. However, defining such a model is outside of our current scope. It is desirable to later improve the security of the protocol bu considering such a model at a later stage. At present, we use a per message model for confidentiality and origin authenticity.
Message Origin Authentication Adversary
As each participant executes a sign and encrypt function before sending their authenticated ephemeral signing key, the message origin adversary model is based on a typical adversary for a signature scheme such as the one presented in [PVY00].
Adversarial power
In addition to adversarial functions defined in section 1.1.1. we must define the following function to allow for the adversary using the chosen-message attack.
-  MakeSend( ) causes the ) causes the to sign and send a valid message m to instance to sign and send a valid message m to instance . . will receive the transcript including the signature. will receive the transcript including the signature.
Definition of Adversary
Definition VI.9: Message Origin Authentication Adversary  is a polynomial time algorithm which has access to the Corrupt, Send, Reveal and MakeSend functions. The output of the algorithm should be a message m sent to instance
 is a polynomial time algorithm which has access to the Corrupt, Send, Reveal and MakeSend functions. The output of the algorithm should be a message m sent to instance  . The scheme is secure against Message Origin Adversary if the probability in which
. The scheme is secure against Message Origin Adversary if the probability in which  believes that m has originated from an uncorrupted participant
 believes that m has originated from an uncorrupted participant  is negligible.
 is negligible.
Message Confidentiality Adversary
The goal of adversary  is to read, at least, part of the communications transcript during the session.
 is to read, at least, part of the communications transcript during the session.
Adversary's challenges
The following set of functions model the confidentiality adversary's challenges. These reveal either a random value or an encrypted message. The adversary's advantage in distinguishing the cases should be translatable into an attack against the block cipher, AES in this case.
-  TestM( ): To the ultimate goal of challenging the indistinguishibility of ): To the ultimate goal of challenging the indistinguishibility of , , can execute TestM( can execute TestM( ) against ) against . As a result a random bit b is chosen, if . As a result a random bit b is chosen, if then then is given is given . .
Definition of Adversaries and their advantages
Definition 1 A Confidentiality Adversary  is a ppt which can invoke all the functions given in sections IV.1.1.1 and IV.1.1.3 with the condition that one of the invocations of TestM is invoked against an instance
 is a ppt which can invoke all the functions given in sections IV.1.1.1 and IV.1.1.3 with the condition that one of the invocations of TestM is invoked against an instance  where all instances in session s are fresh and stay fresh till the end of the game. The game ends when
 where all instances in session s are fresh and stay fresh till the end of the game. The game ends when  outputs its guess for b for that invocation. We say that the protocol is secure if the following function is negligible:
 outputs its guess for b for that invocation. We say that the protocol is secure if the following function is negligible:
 
Consistency Adversary
Definition 1 Transcript Consistency Adversary  is given the ability to invoke all functions in sections IV.1.1.1 and IV.1.1.3. We say the protocol is secure against Consensus Adversary if at least two uncorrupted accepted instances
 is given the ability to invoke all functions in sections IV.1.1.1 and IV.1.1.3. We say the protocol is secure against Consensus Adversary if at least two uncorrupted accepted instances  possess the transcripts chain
 possess the transcripts chain  and they believe they have the
 and they believe they have the  see Section VII.4.1.
 see Section VII.4.1.
VII. Protocol High Level Design
To achieve the security properties listed in Section IV, we break the protocol into the following sub-protocols:
- Deniable authenticated signature key and session key exchange, where participants deniably authenticate each other and agree on session key(s), while also exchanging ephemeral signing keys
- Communication, where parties send authenticated confidential messages
- Transcript consistency verification, where parties verify that all have received and seen an identical transcript since the start of the chat session
Our choice of sub-protocols for (n)sec followed suggestions made in [BGB04] and [GUVGC09], except where there has been a practical or security-related reason to deviate from those recommendations.
In the following section we briefly describe our choice of the sub-protocols for each of the required tasks for a multi-party chat session.
VII.1 Design of Deniable Authenticated Signature Key Exchange
We have chosen our deniable signature key exchange protocol following the conclusions in [Gun13b] - by identifying a secure key exchange protocol that satisfies our needs. We then apply the triple Diffie-Hellman authenticated exchange to grant it properties of deniability. Subsequently, one can apply the same approach presented in [Gun13b] to communicate ephemeral signature keys during the key establishment process. However, for efficiency, we use the same ephemeral Diffie-Hellman private and public values used to deniably authenticate users and generate secret shares to produce ephemeral signatures.
For the choice of the base authenticated key exchange protocol, we suggest a variant based on [ACMP10]. The rationale for the choice is laid out as follows:
- The base design of the protocol in [ACMP10] is the same as the base for [BVS05] (recommended by [Gun13a]). However, the protocol presented in [ACMP10] is simpler.
- [ACMP10] offers a peer-to-peer key exchange with no extra rounds, if needed.
-  [BVS05] and [ACMP10] are superior to the widely studied [BCPQ01] and its dynamic variation [BCP01] both in security and performance ( rounds). rounds).
- [BVS05] has been suggested by [Gun13b] for the reason described in [Gun13a]. We believe that the new deniable authentication approach, as it is similar to the SKEME protocol, satisfies the properties of deniability which [BVS05] considered crucial aside from the cooperating judge.
- Security analysis of [GBNM11] and [BCGNP08] has found that [BVS05] is provably secure against all attacks (including the insider attacks) that the papers consider.
- It is a two-round protocol and hence offers competitive efficiency considering the security property that it provides.
- [ACMP10] only needs one round of key re-agreement in the case of a participant leaving the chat, while [BVS05] enforces re-computation of Diffie-Hellman ephemeral keys and hence needs a minimum of two rounds plus overhead of re-authenticating the new ephemeral keys. This can significantly improve the efficiency of casual chat sessions where participants frequently enter and exit the chat.
- Although the Schnorr based algorithm suggested in [BVS05] satisfies a more comprehensible deniable model, Triple Diffie-Hellman authenticated key exchange only needs two rounds of communication and can be done alongside the key agreement steps, while the Schnorr based algorithm of [BVS05] needs four rounds.
- Although key exchange algorithms based on the standard model are considered theoretically more secure than those based on the random oracle model, there has been no proposal for a 2-round protocol in the standard model that promises forward secrecy. Therefore, due to the importance of usability and efficiency in our approach, we opted to for a ROM based protocol such as described by [BVS05] and [ACMP10].
VII.1a Sharing a secret among the group
All AGKE descriptions take the necessary steps to share a common secret confidentially among the group members along side other operations such as authentication and insuring partnership. To insure forward secrecy these methods mostly rely upon a P2P Deffie-Hellman key exchange. Most AGKE descriptions rely on sharing an equation and solving a specific linear system described in IX.4.
We abstract this step as GroupEnc/GroupDec primitive, to allow for alternative designs which do not interact with the rest of the protocol and might offer other benefits. For example the "Naive peer-to-peer" primitive IX.4 trades simplicity and generalizability (to a broadcast scheme c.f. Section VII.2) for bandwidth consumption.
VII.3 Message Authentication
As message authentication needs to be resistant to malicious insiders, following the outline of [GUVGC09], (n)sec signs each message using a public key signature scheme. The messages are signed with the ephemeral key of the sender. The authenticity of the origin can be verified by the public ephemeral key of the party distributed during the key exchange period.
VII.4 Transcript Ordering and Consistency
Since each message sent by any one participant is signed by the ephemeral private key generated for that specific session, it is not possible for the internal or external adversary to forge a message on behalf of an uncorrupted participant.
However, if the adversary is controlling the network structure, denial or delay of service is always possible. The consistency of the transcript (i.e. all participants see the same transcript in the same order) relies on the means of transport guaranteeing reliable delivery, with a single order, to every participant. In other words, we are verifying the recipients of a message.
The protocol offered in this document examines the transcript for such consistency. In the case that the underlying transport fails to provide this level of consistency, clearly the consistency test will fail. In this sense, failure of consistency does not distinguish between malicious activities or the absence of a reliable transport.
(n)sec performs transcript authentication whenever a message is received. This is to guarantee consistency and protect the protocol against the transcript consistency attack. The procedure is similar to the procedure described in [GUVGC09], with two major differences:
- We require additionally that message order be preserved for the following reasons:
- XMPP, as the main protocol considered for this design, delivers messages to all clients in the same order.
- The (n)sec protocol detects if the adversary has manipulated the order of the messages rather than only dropping undesirable messages
- It is simpler to authenticate an ordered transcript compared to an unordered transcript.
- We also require that each participant updates all other participants about their view of the session transcript every time they send a message, along with requiring heartbeat, this ensures that participants are aware whether or not they are all seeing the same transcript during the session.
There are some cases where XMPP can fail our reliability assumption. In such cases, our consistency checks will fail. More advanced end-to-end recovery techniques are able to rescue such a scenario. We do not specify such techniques currently, though later versions of the protocol may rectify this.
Definitions and assumptions
Transport assumption: We assume the central server reliably delivers messages to everyone, including the original sender, in the same order.
Definition Each message M (sent after session S has been established) has an implicit server-sequence-number seqnum(M), a receive-parent: parent(M) (or recv-parent) the seqnum of last message the sender has received before sending M and a sender-sequence-number own-seqnum(M). We interchangeable use m when refering to both a message and its seqnum.
Once a message M with seqnum m is received by instance  from the server (including participants own messages sent), a
 from the server (including participants own messages sent), a ![TranscriptChain_{i}^{S}[m]](https://learn.equalit.ie/mathupload/5/b/f/5bff4b4daad3be1ac65db8f552fb59f9.png) may be calculated recursively as follows:
 may be calculated recursively as follows:
![TrascriptChain_{i}^{S}[m]:=(M,Hash(TranscriptChain_{i}^{S}[m-1]))](https://learn.equalit.ie/mathupload/e/7/3/e73795fef819447b256ff48d4167343c.png) 
(we define TrascriptChain[0] = (sk^S_i, sid_i))
A new message M contains p the seqnum of recv-parent of m, ![Hash(TranscriptChain_{i}^{S}[p])](https://learn.equalit.ie/mathupload/9/0/c/90c024f5b4e666e9017e88bb006fb09b.png) and own-seqnum(M).
  and own-seqnum(M).
-  We say instance  has accepted message m if it has been received by has accepted message m if it has been received by , then decrypted-verified. , then decrypted-verified.
-  We say instances  and and have reached mutual consistency for message m if both accepted message m and have calculated the same hash of have reached mutual consistency for message m if both accepted message m and have calculated the same hash of and verified and verified![H_{j}(TranscriptChain_{i}^{S}[m]))==H_{i}(TranscriptChain_{i}^{S}[m])](https://learn.equalit.ie/mathupload/9/3/f/93fb549f055ad356f30df89c17e92844.png) . .
-  We say session S has reached consistency on message  m, if all instances  , , and and have reached mutual consistency. have reached mutual consistency.
Server order
All clients see the same message order from the server. All messages are sent to all users. Aside from the presence messages (messages which indicate a user is joining or leaving a chatroom or if they have been inactive for a long time) sent by the server, messages are sent by users.
All messages in a room have a unique sequence number (0, 1, ...). We assume that the server is unaware of sequence numbers (e.g. XMPP MUC); clients must allocate them implicitly when receiving messages.
VIII. (n)sec Protocol: Step by Step
In this section we present the (n)sec protocol in algorithmic format. All user Ids should be considered the modulo number of participants in the room.
Deniable authentication is derived from the Triple Diffie-Hellman algorithm presented in [Sys14]. Joining the room is a variation of the two-round mBD+P protocol presented in [ACMP10] where the authentication step has been made deniable. Leaving the room is the one-round mBD+S from [ACMP10].
VIII.1 Schematic view of the key exchange
Although computing a unified session key for all participant is possible, the protocol will compute n different keys each being used to decrypt the text received from the corresponding participant. In other words, Participant  uses key
 uses key  to encrypt data. Formally we consider a tuple of
 to encrypt data. Formally we consider a tuple of  as a session key. This measure has been taken to facilitate the transition to a broadcast use-case where the protocol does not promise same
 as a session key. This measure has been taken to facilitate the transition to a broadcast use-case where the protocol does not promise same  for all participants and therefore, it is conceptually impossible to compute a unique key. For more information please see Section VII2.2b.
 for all participants and therefore, it is conceptually impossible to compute a unique key. For more information please see Section VII2.2b.
For the high level design of the protocol we do not specify the primitives for GroupEnc and GroupDec used in steps 2.4 and -.3. However, we disucss their property and we present some canadidates.
For simplicity, group operation is written multiplicatively, although it is actually an elliptic curve points operation traditionally represented by addition. Where ever our design deviates from [ACMP10], it is marked by yellow. Pink means we have abstracted out the step mentioned in [ACMP10] as an independent primitive:
Algorithm 1
| Rnd | Description | Pseudo-code | Type | 
|---|---|---|---|
| 1 | Generate ephemeral DH private key | ![x_{i}\leftarrow [0,order(g)]](https://learn.equalit.ie/mathupload/1/2/d/12d8053eb32075495eaa2b3ba8587435.png)  | Computation | 
| 1.1 | Generate DH key for BD, Triple DH and Signature |   | Computation | 
| 1.2 | Broadcast User identity and the DH key |   | Broadcast | 
| 2 | Compute Session Id |   | Receive | 
| 2.1 | Generate Triple Diffie-Hellman P2P keys |   | Computation | 
| 2.2 | Generate key confirmations |   | Broadcast | 
| 2.3 | Generate secret shares |   | Computation | 
| 2.4 | Encrypt shares |   | Computation | 
| 2.3 | Sign identity, shares |   | Computation | 
| 2.4 | Broadcast encrypted shares and confirmation |   ) | Broadcast | 
| - | Check validity of key confirmation | ![kc_{k}[j]{\stackrel  {?}{=}}kc_{j}[k]\;\forall j\neq k](https://learn.equalit.ie/mathupload/d/f/6/df601fcdceb3e5645782bd002046b876.png)  | Receive | 
| Check signatures |   | Computation | |
| Check Session Ids |   | Computation | |
| Generate session key |   | Computation | 
VIII.2 Chatroom Setup
In almost any practical case, participants join the chat sequentially. It is assumed that multiple participants cannot join simultaneously. For the sake of efficiency one can adjust the implementation to have a threshold time to wait and thus start a chat with more participants. However, this makes the implementation significantly more complicated without any evident efficiency benefit.
Therefore, our assumption is that a secure chat is always set up when a participant starts the chat room. Additional participants would be added sequentially using Algorithm VIII.3, as they enter the chat. Algorithm 1 describes the chat room setup protocol.
Algorithm 2
| Description | Pseudo-code | Type | 
|---|---|---|
| Generate ephemeral DH private key of the room initiator | ![x_{i}\leftarrow [0,order(g)]](https://learn.equalit.ie/mathupload/1/2/d/12d8053eb32075495eaa2b3ba8587435.png)  | Computation | 
| Generate DH key for BD, Triple DH and Signature |   | Computation | 
| Set participant list | ![plist\leftarrow [U_{i}]](https://learn.equalit.ie/mathupload/0/e/6/0e6f38c92925621271a93a3227820837.png)  | Computation | 
Join
Joining a chat involves two different procedures: the Join procedure, described in Algorithm 2, which runs on the new participant’s instance, and an Accept New Participant Procedure, described in Algorithm 3, which runs on the clients of participants that are already in the chat.
When a new participant  joins the chat, current participants can still use their established authenticated ephemeral public key (to derive the
 joins the chat, current participants can still use their established authenticated ephemeral public key (to derive the  and as their signature verification key). Confidentiality of
 and as their signature verification key). Confidentiality of  is guarded against the new participant by Diffie-Hellman key shares hashed alongside the session id (which is dependent on the list of participants). The new participant cannot combine the old and new shares to recover
 is guarded against the new participant by Diffie-Hellman key shares hashed alongside the session id (which is dependent on the list of participants). The new participant cannot combine the old and new shares to recover  . The fact that old participants do not need to compute new ephemeral keys (and re-verify their ephemeral identities) decreases the computational complexity of the protocol.
. The fact that old participants do not need to compute new ephemeral keys (and re-verify their ephemeral identities) decreases the computational complexity of the protocol.
The new participant needs to authenticate everybody already in the room and hand them their ephemeral key. All the parties already in the room only need to authenticate the new participant and need to send to them their ephemeral DH key. These procedures are described in Algorithm 3 and 4. After initial authentication step, all parties follow the same procedure to initiate a new session following Algorithm 5.
Authentication Step for new Joining party
Algorithm 3
| Description | Pseudo-code | Type | 
|---|---|---|
| Generate ephemeral DH private key | ![x_{i}\leftarrow [0,order(g)]](https://learn.equalit.ie/mathupload/1/2/d/12d8053eb32075495eaa2b3ba8587435.png)  | Computation | 
| Generate DH key for BD, Triple DH and Signature |   | Computation | 
| Broadcast User identity and the DH key |   | Broadcast | 
| Receive other users' id/key |   | Receive | 
| Generate Triple Diffie-Hellman P2P keys |  }} | Computation | 
| Generate key confirmations |  }} | Computation | 
After this step joining user will proceed to "initiate new session" by Algorithm 5.
Authentication Step for parties in the room
For other participants to a accept a new participant only, the authentication step is different. After current participants authenticate the new user, they proceed to update session.
Algorithm 4
| Description | Pseudo-code | Type | 
|---|---|---|
| broadcast all user's identities |   | Broadcast | 
| Receive other users' id/key and update participant list |   | Receive | 
| Generate Triple Diffie-Hellman P2P key for the new participant |   | Computation | 
| Generate key confirmations |   | Computation | 
After this step users will proceed to "initiate new session" using Algorithm 5.
Initiate new session
Algorithm 5
| Description | Pseudo-code | Type | 
|---|---|---|
| Compute Session Id |   | Computation | 
| Generate secret shares |   | Computation | 
| Encrypt shares |   | Computation | 
| Sign identity, shares |   | Computation | 
| Broadcast key shares and confirmation (if any) |   | Broadcast | 
| Receive other user(s)' key shares and confirmation of unauthenticated users |   | Receive | 
| Check validity of key confirmation of unauthenticated users | ![kc_{i}[j]{\stackrel  {?}{=}}H(k_{{j,i}},U_{j}){\textrm  {for}}U_{j}{\textrm  {unauthenticated}}](https://learn.equalit.ie/mathupload/c/4/b/c4b730540bc8ff3a771d472c6df75147.png)  | Computation | 
| Check signatures |   | Computation | 
| Check Session Ids |   | Computation | 
| Generate session key |   | Computation | 
| Initiate the TranscriptChain | ![TrascriptChain_{i}^{S}[0]\leftarrow (sk_{i}^{S},sid_{i})](https://learn.equalit.ie/mathupload/7/c/3/7c3f980ff3571d6d0c536f09f1b16597.png)  | Computation | 
Sending and receiving messages while joining is in progress
In situations where a prolonged joining process (due to connection problems or malicious activities) has an adverse effect on the user experience, it might be desirable to enable that joining users can communicate with the parties in the room, while maintaining minimum assurances of authenticity, confidentiality, forward secrecy, as well as consistency only among participants.
Consistency aspects of (n)sec, both for the room view (plist) and for the transcript, are reached through group agreement. However, there are times when group agreement may be hard or impossible to reach either due to latency in a single participant's connection or due to a single participant broadcasting incorrect confirmation data (such as wrong plist, sid, key share, etc).
We offer an extension to the (n)sec protocol to tackle this problem during the joining process. When a new participant joins the room, they send their DH key shares to the other participants. The other participants send their ephemeral key in return. They then send their key confirmation and key share. If this extension is to be considered, as soon as each user receives a key confirmation from another user, who is not currently part of the session, (n)sec displays a message highlighting the fact that although the user is not part of the session the conversation is being shared with them (through P2P encryption using the key derived from DH Key). The protocol, however, does not honour their input in the consistency check until a new session including the new user is set up. Each client can decide whether to disable this option.
The user remains in the list of those not part of the current session, but receives the session messages until a new session is set up. Similarly, when a user receives a message from a user who is not part of the session, (n)sec will decrypt the message and display it with a disclaimer that the user is not yet part of the session and that some participants may not receive the same message.
In this model, a room is a forwardly secure authenticated communication channel while a session is a subset of the room, which additionally offers a consistent view of the room and consistent messages among participants.
Leave
Leaving a chatroom involves a message from a leaving party indicating its intention to leave which, as with all other messages, contains the hash of TranscriptChain and one procedure for those who are staying in the chatroom (Procedure Farewell) which is described in Table ''(n)sec''#Leave.
Farewell
Run by exiting user.
Algorithm 6
| Description | Pseudo-code | Type | 
|---|---|---|
| Send farewell message | Failed to parse (lexing error): Send("Leaving!") | Broadcast | 
| Wait to receive hashes of TranscriptChain |   | Receive | 
Shrink
When the remaining participants receive the farewell message they need to reply with the Hash of TranscriptChain of the last message seen by the leaving user. They also need to re-run the one round key update algorithm. However, they only need a notice from the server that the user is leaving to initiate a subsession excluding the leaving user.
Additionally, failure to receive a heartbeat from a user will result in executing Algorithm ''(n)sec''#Leave excluding users who did not update their key.
Algorithm 7
| Description | Pseudo-code | Type | 
|---|---|---|
| Send Hash of TranscriptChain of last message seen by leaving user | ![Send(H(TranscriptChain_{i}^{S}[Parent(m_{{farewell}})]))](https://learn.equalit.ie/mathupload/5/6/3/5633444a4fb212a73f63ec251f2fc188.png)  | Broadcast | 
| Remove leaving user's id/key and update participant list |   | Computation | 
Users will proceed to "initiate new session" steps.
Secure Send and Receive
After the session key is established, participants will use Algorithms 5 and 6 to communicate securely.
On Send, the protocol checks the status of the new ephemeral Diffie-Hellman and key share using messages it receives from participants. It (re)sends any missing pieces. It also informs other participants which part of the key share has been received by the participant. This information is need inorder to enforce in-session forward secrecy. The metadata flag indicates if the message being sent only contains meta data (e.g. heartbeat) or actual user communication.
On Receive, the protocol updates who has seen which pieces of the key shares. The protocol also generates a new group key if the new key shares have been received from all participants. Those who have not updated their key shares eventually time out via their heartbeat interval.
Send
Encrypted messages include a "hash of TranscriptChain" of their parent as "additional authenticated data".
![(H(parent(m)),H(TransciptChain[parent(m)-1])))](https://learn.equalit.ie/mathupload/9/c/0/9c05e23e26c4bfc81313c8dba29cdafe.png) 
Note that we defined  rather than
 rather than  . This is because a hash may only be calculated once the subject is actually received back from the server (i.e. gets a sequence number). This differs from some other concepts of "message ID" that may be calculated locally.
. This is because a hash may only be calculated once the subject is actually received back from the server (i.e. gets a sequence number). This differs from some other concepts of "message ID" that may be calculated locally.
Algorithm 8
| Description | Pseudo-code | Type | 
|---|---|---|
| Generate new DH Key or new secret share if needed and append |   | Computation | 
| Append the hash of the TranscriptChain, up to the parent of the message being sent | ![m\leftarrow (m,(H(parent(m)),H(TransciptChain_{i}^{S}[parent(m)-1]),parent\_id(m)))](https://learn.equalit.ie/mathupload/f/4/2/f4280a450db3c1323b7d08affbb607ba.png)  | Computation | 
| Sign the message |   | Computation | 
| Encrypt |   | Computation | 
| Broadcast the message |   | Broadcast | 
Receive
Algorithm 9
| Description | Pseudo-code | Type | 
|---|---|---|
| Check signature |   | Computation | 
| Update TranscriptChain |   | Computation | 
| decrypt message |   | Computation | 
| Verify session id and transcript consistency, issue a warning in case of failure | ![sid_{i}{\stackrel  {?}{=}}sid_{{rec}}\;{\textrm  {and}}\;h{\stackrel  {?}{=}}(H(parent(m)),TranscriptChain_{i}^{S}[parent(m)-1])](https://learn.equalit.ie/mathupload/7/c/6/7c68439af86ad88e2e11a1e2ac03003a.png)  | Computation | 
| Update sender key or share key |   | Computation | 
| If all users' share are received, generate session key |   | Computation | 
| return m | m | 
Reaching Consistency
The protocol provisions two procedures to reach consistency in different cases: (a) reaching consistency for arbitrary messages during the course of a conversation, and (b) reaching consistency when an instance  leaves. Case (b) may be viewed as a special instance of case (a) plus the additional premise that
 leaves. Case (b) may be viewed as a special instance of case (a) plus the additional premise that   must reach consistency as soon as possible (because they want to leave), and that they don't care about reaching consistency for any subsequent messages that they might receive after their final "farewell" message.
 must reach consistency as soon as possible (because they want to leave), and that they don't care about reaching consistency for any subsequent messages that they might receive after their final "farewell" message.
Reaching consistency for arbitrary messages during the course of a conversation:
Algorithm 10
| Description | Pseudo-code | Type | 
|---|---|---|
| Receive m with parent p from   |   | Computation | 
| Compare hash of TranscriptChain_j[p] with own value of it, issue a warning if it fails. | ![H(TranscriptChain_{j}^{S}[p])==H(TranscriptChain_{i}^{S}[p])](https://learn.equalit.ie/mathupload/d/8/3/d835bcf02ab398a412841c995e4ec9d0.png) for all   | Computation | 
| Compute TranscriptChain^S_i[m] | ![plist\leftarrow [U_{i}]](https://learn.equalit.ie/mathupload/0/e/6/0e6f38c92925621271a93a3227820837.png)  | Computation | 
Case (b): when an instance  wants to part, they send a "farewell" message m which contains
 wants to part, they send a "farewell" message m which contains ![Hash(TranscriptChain_{i}^{S}[p])](https://learn.equalit.ie/mathupload/9/0/c/90c024f5b4e666e9017e88bb006fb09b.png) .
.
-  Everyone should include ![Hash(TranscriptChain_{j}[p])](https://learn.equalit.ie/mathupload/5/0/b/50b8d16aa5eae3724ac41a936d4a3722.png) in their re-key message in their re-key message
-  When  reaches mutual consistency for p may leave or otherwise (if received hashes and their owns are non-matching)  shows a warning. reaches mutual consistency for p may leave or otherwise (if received hashes and their owns are non-matching)  shows a warning.-   won't have a chance to reach consistency for the messages receives after p won't have a chance to reach consistency for the messages receives after p
 
-  
Heartbeat
Heartbeat is an empty message which contains only meta data. The meta data consists of information used to compute a new key and the most updated hash of transcript chain.
The protocol sends a heart beat only if the user has not sent any messages for a specific period of time.
The heartbeat is necessary to ensure three properties:
- Periodic transcript consistency check. - In session forward secrecy. - Freshness
To achieve these goals three time out periods are defined when heart beat sending is required. Additionally, we define an interval to model the latency in the underlying transport. These should be defined to cover common cases (e.g. 95th-percentile):
-  ACK_GRACE_INTERVAL: When  a receives a non-empty message it needs to inform the group about the transcript update no later than ACK_GRACE_INTERVAL time. Therefore if a receives a non-empty message it needs to inform the group about the transcript update no later than ACK_GRACE_INTERVAL time. Therefore if f f does not send a message ACK_GRACE_INTERVAL seconds after receiving a non empty message, does not send a message ACK_GRACE_INTERVAL seconds after receiving a non empty message, will send a heartbeat. will send a heartbeat.
- REKEY_GRACE_INTERVAL, to ensure in session forward secrecy, the protocol
requires that each  updates their DH ephemeral key as well as 
group key. After a session is established or it was rekeyed, each
 updates their DH ephemeral key as well as 
group key. After a session is established or it was rekeyed, each
 needs to send its new DH ephemeral key no later than
REKEY_GRACE_INTERVAL. Therefore if
 needs to send its new DH ephemeral key no later than
REKEY_GRACE_INTERVAL. Therefore if  has not sent any message by that
period of time, it issues an empty message. Similarly after receiving
all ephemeral keys from all participants,
 has not sent any message by that
period of time, it issues an empty message. Similarly after receiving
all ephemeral keys from all participants,  needs to send its
secret for computation of new key no later than REKEY_GRACE_INTERVAL.
 needs to send its
secret for computation of new key no later than REKEY_GRACE_INTERVAL.
- BROADCAST_LATENCY: Modelling the amount of time which a message takes to reach the server and broadcast to the other clients. It should be based on the transport considered.
Failure to heartbeat and inactivity timers
Whenever, a message m is received a timer of (2*BROADCAST_LATENCY)+ACK_GRACE_INTERVAL) period is set. If the ![H(Transcript_{j}[m'])](https://learn.equalit.ie/mathupload/8/3/8/8382ca9da9b9f0f6088074e5918e2b9e.png) for a
 for a  is received from all participants, the timer is cancelled. Otherwise at the time out, the protocol issues a local UI warning and cancel the warning if/when such a hash is received and is consistence among participants.
 is received from all participants, the timer is cancelled. Otherwise at the time out, the protocol issues a local UI warning and cancel the warning if/when such a hash is received and is consistence among participants.
When a new session key is computed as well as when  receives new ephemeral DH values from all users, a timer of (2*BROADCAST_LATENCY)+REKEY_GRACE_INTERVAL) period is set. It is cancelled when all user contributions are received (ephemeral keys or session key secrets). Otherwise, the
 receives new ephemeral DH values from all users, a timer of (2*BROADCAST_LATENCY)+REKEY_GRACE_INTERVAL) period is set. It is cancelled when all user contributions are received (ephemeral keys or session key secrets). Otherwise, the  excludes users who failed to contribute from the
 excludes users who failed to contribute from the  and request a call for leave procedure to exclude those users from the session. This measure is taken to ensure that users do not block in-session forward secrecy due to loss of connection or being under attack.
 and request a call for leave procedure to exclude those users from the session. This measure is taken to ensure that users do not block in-session forward secrecy due to loss of connection or being under attack.
IX Cryptographic Primitives
IX.1 Hash Function
SHA256 is being used as the hash function and the random oracle. SHA256 provides a sufficiently secure hash primitive for the level of security provided by (n)sec and is widely implemented.
IX.2 Message Origin Authentication
ED25519 has been chosen as the signature primitive due to its efficiency and more secure implementability over other elliptic-curve digital signature algorithms.
IX.3 Message Encryption
We are using AES-256 in counter mode with a shared group key for message encryption, as suggested by the original OTR protocol.
IX.4 GroupEnc and GroupDec Functions
The GroupEnc and GroupDec functions are primitives which are supposed to satisfies the following goal:
Definition: Let  and for each
 and for each  , let
, let  be a secret shared between and only between
 be a secret shared between and only between  and
 and  . The goal of group
. The goal of group  is that:
 is that:
-  Each member of group  to generate and share a secret to generate and share a secret among the member of group G using public channel among the member of group G using public channel . .
-   remains unknown for any remains unknown for any eavesdropping the channel eavesdropping the channel . .
To this end each membercompute
and broadcast
on
. Later on when
receives all
. It recovers all secrets
by computing
.
Here we mention two examples of such functions:
- Naive peer-to-peer GroupEnc/Dec:
The simplest path to design such primitives is to encrypt  using the p2p encryption secret between each pair of participants:
 using the p2p encryption secret between each pair of participants:
 
![GroupDec((k_{{i,1}},...,k_{{i,n}}),(z_{1},...,z_{n})):=(D_{{k_{{i,1}}}}(z_{1}[i]),...,D_{{k_{{i,n}}}}(z_{n}[i]))](https://learn.equalit.ie/mathupload/a/a/1/aa1d3510964e45c479337a15ade5d1c1.png) 
- Linear System based GroupEnc/Dec:
Another possibility is that each user generates k linear equations of l variables such if the system of  equations has m independent equations then m < l. The remaining equations should be generated using the mutual secrets
 equations has m independent equations then m < l. The remaining equations should be generated using the mutual secrets  .
.
An example of such a system is used by [BuDe95]. In which  as follows:
 as follows:
Each user U_i generate equations (k_{i,i-1}+k_{i,i+1}=a_i) so the system for n equation  variable will be:
 variable will be:
Failed to parse (unknown function '\matrix'): \matrix{ x_1 + x_2 = a_1 \\ x_2+x_3= a_2 \\ \vdots \\ x_n + x_{n-1} = a_n \\}
Then each participant adds the equation of  to the system and solves the derived system of
 to the system and solves the derived system of  -equation
-equation  -unknown to recover the secrets.
-unknown to recover the secrets.
in such a system:
 
 
(n)sec uses the modification of the primitive suggested in [ACMP10] to guard the confidentiality of the p2p and the subgroup keys:
 
While the naive peer to peer primitive is easier to understand and analyse, the second system gives the flexibility for the implementor to decide the trade off between the amount of data (number of equations) vs. the redundancy in the system (if some equations are not delivered the user can still compute a subset of secrets).
X. Conclusion
In this document, we presented the final draft of (n)sec. We hope by receiving public comment on this draft we are able to improve the design. We have referenced the adversarial models which the protocol is supposed to resist. Meanwhile we are working on an implementation of (n)sec. We will publish a sequel document which high light the implementation details as well as proof of resistance to the adversarial model presented here.
XI. References
[ACMP10] ^ 1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 Michel Abdalla, Céline Chevalier, Mark Manulis, and David Pointcheval. “Flexible Group Key Exchange with on-Demand Computation of Subgroup Keys.” In Third African International Conference on Cryptology (AfricaCrypt ’10), edited by Dan Bernstein and Tanja Lange, 6055:351–368. LNCS. Stellenbosch, South Africa, 2010: Springer. doi:10.1007/978-3-642-12678-9_21.
[BS07] ^ 1 2 3 4 Bohli, Jens-Matthias, and Rainer Steinwandt. 2007. “Deniable Group Key Agreement.” In VIETCRYPT, edited by Phong Q. Nguyen, 4341:298–311. Lecture Notes in Computer Science. Springer. http://dblp.uni-trier.de/db/conf/vietcrypt/vietcrypt2006.html#BohliS06.
[BVS05] ^ 1 2 3 4 5 6 7 8 9 10 Bohli, Jens-Matthias, Maria Isabel Gonzalez Vasco, and Rainer Steinwandt. 2005. “Secure Group Key Establishment Revisited.” IACR Cryptology ePrint Archive 2005: 395. http://dblp.uni-trier.de/db/journals/iacr/iacr2005.html#BohliVS05a.
[BM] ^ 1 2 Bonneau, Joseph, and Andrew Morrison. “Finite-State Security Analysis of OTR Version 2.” http://www.jbonneau.com/doc/BM06-OTR_v2_analysis.pdf
[BGB04] ^ 1 2 3 4 Borisov, Nikita, Ian Goldberg, and Eric Brewer. 2004. “Off-the-Record Communication, or, Why Not to Use PGP.” In Proceedings of the 2004 ACM Workshop on Privacy in the Electronic Society, 77–84. WPES ’04. New York, NY, USA: ACM. doi:10.1145/1029179.1029200. http://doi.acm.org/10.1145/1029179.1029200.
[BCGNP08] ^ Colin Boyd, Yvonne Cliff, Juan Gonzalez Nieto, and KennethG. Paterson. 2008. “Efficient One-Round Key Exchange in the Standard Model.” In Information Security and Privacy, edited by Yi Mu, Willy Susilo, and Jennifer Seberry, 5107:69–83. Lecture Notes in Computer Science. Springer Berlin Heidelberg. http://dx.doi.org/10.1007/978-3-540-70500-0_6.
[BCP01] ^ Emmanuel Bresson, Olivier Chevassut, and David Pointcheval. 2001. “Provably Authenticated Group Diffie-Hellman Key Exchange - the Dynamic Case.” In Advances in Cryptology - Proceedings of ASIACRYPT ’01, edited by Colin Boyd, 2248:290–309. LNCS. Gold Coast, Australia: Springer. doi:10.1007/3-540-45682-1_18.
[BCPQ01] ^ Emmanuel Bresson, Olivier Chevassut, David Pointcheval, and Jean-Jacques Quisquater. 2001. “Provably Authenticated Group Diffie-Hellman Key Exchange.” In Proceedings of the 8th ACM Conference on Computer and Communications Security (CCS ’01), edited by Mike Reiter, 255–264. Philadelphia, Pennsylvania: ACM Press. doi:10.1145/501983.502018.
[Da14] ^ George Danezis, Should Group Key Agreement be Symmetric and Contributory, http://conspicuouschatter.wordpress.com/2014/06/28/should-group-key-agreement-be-symmetric-and-contributory/
[GUVGC09] ^ 1 2 3 4 5 6 7 8 9 10 Ian Goldberg, Berkant Ustao\uglu, Matthew D. Van Gundy, and Hao Chen. 2009. “Multi-Party Off-the-Record Messaging.” In Proceedings of the 16th ACM Conference on Computer and Communications Security, 358–368. CCS ’09. New York, NY, USA: ACM. doi:10.1145/1653662.1653705. http://doi.acm.org/10.1145/1653662.1653705.
[GBN10] ^ M. Choudary Gorantla, Colin Boyd, and Juan Manuel González Nieto. 2010. One Round Group Key Exchange with Forward Security in the Standard Model. http://eprint.iacr.org/2010/083.pdf
[GBNM11] ^ 1 2 3 M. Choudary Gorantla, Colin Boyd, Juan Manuel González Nieto, and Mark Manulis. 2011. “Modeling Key Compromise Impersonation Attacks on Group Key Exchange Protocols.” ACM Trans. Inf. Syst. Secur. 14 (4): 28.http://dl.acm.org/citation.cfm?id=2043628.2043629
[Gun13a] ^ 1 2 3 Matthew Van Gundy. April 2013. “[OTR-dev] Improved Deniable Signature Key Exchange for mpOTR.” http://matt.singlethink.net/projects/mpotr/improved-dske.pdf
[Gun13b] ^ 1 2 3 Matthew Van Gundy March 2013. “[OTR-dev] Improved Deniable Signature Key Exchange for mpOTR.” http://lists.cypherpunks.ca/pipermail/otr-dev/2013-March/001676.html.
[KLL04] Hyun-Jeong Kim, Su-Mi Lee, and Dong Hoon Lee. 2004. “Constant-Round Authenticated Group Key Exchange for Dynamic Groups.” In ASIACRYPT, 245–259. https://www.iacr.org/archive/asiacrypt2004/33290243/33290243.pdf
[Man06] Mark Manulis. 2006. “Security-Focused Survey on Group Key Exchange Protocols.” IACR Cryptology ePrint Archive 2006: 395. http://eprint.iacr.org/2006/395.
[Per] Trevor Perrin. “Axolotl Ratchet.” https://github.com/trevp/axolotl/wiki
[RGK05] ^ 1 2 3 Mario Di Raimondo, Rosario Gennaro, and Hugo Krawczyk. 2005. “Secure Off-the-Record Messaging.” In WPES, 81–89. Alexandria, VA, USA. http://dl.acm.org/citation.cfm?doid=1102199.1102216
[Sys14] ^ Whisper Systems. 2014. “TextSecure ProtocolV2.” Accessed March 2. https://github.com/WhisperSystems/TextSecure/wiki/ProtocolV2.
Appendices
Appendix A: Asynchronous communication and Forward Secrecy
The protocol is primarily targeted to synchronous cases, however, with some modification it can be used for asynchronous cases.
Provided that the participants are not concerned with authenticating the list of participants (it is OK if Eve impersonates Bob as long as she is unable to read Bob’s messages). Participants can communicate using their pairwise exchanged ephemeral Diffie-Hellman keys until all participants finish the second round of authentication.
As soon as a deniable handshake has been established among a set of participants any subset of them can communicate and authenticate their messages using the “session key” and their ephemeral signature key.
The protocol does not enforce explicitly a time limit on renewing the session key shares and can be used for an asynchronous high latency transport after the key establishment state.
The downside of using a session key for a long time is that a compromised session key will reveal all past communication during that session. This does not pose an imminent threat when the life span of a chat is short. However, in the context of asynchronous high latency transport, it is a more serious concern.
The protocol requires the participants to pre-emptively update their ephemeral signature/shares and propagate them as part of the messages they are already sending. Subsequently, they also update their key share with their neighbours as soon as the neighbours also propagate their new ephemeral signature keys.
As the assumption of having a continuous heartbeat might not be realistic in various asynchronous cases, implementations can assume specific deadlines for dropping users who did not communicate their new keys or shares.
Appendix B: Other design possibilities
During the process of designing (n)sec we have considered, and debated, other design possibilities which we will describe in this section along side our argument in favour of the choice we have made.
Group Key Scheme vs Broadcast Scheme
We say a group key scheme (as defined in Section V) is correct if all accepted instances of  end up with the same participant lists
 end up with the same participant lists  and compute the same session id.
 and compute the same session id. 
By contrast, a broadcast scheme refers to a scheme in which each participant is broadcasting a message to a set of participants of their choice from a set of potential participants. Each participant will have its own different  which is able to broadcast as well.
 which is able to broadcast as well. 
Therefore, in the context of a chat room, broadcasting scheme participants do not have the same view of the room and consequently we cannot compute a unified session id  based on the list of the participants (as opposed to the group key scheme). In a group key scheme, it is the name of the chat room plus a set of ephemeral keys and the set of ephemeral public keys which uniquely identifies the session. There are advantages and disadvantages to each of these schemes, which we enumerate here:
 based on the list of the participants (as opposed to the group key scheme). In a group key scheme, it is the name of the chat room plus a set of ephemeral keys and the set of ephemeral public keys which uniquely identifies the session. There are advantages and disadvantages to each of these schemes, which we enumerate here:
- Chat room simulation: A group scheme simulates a normal chat room in the absence of an authentication adversary, where the participants all have the same view of who is in the chat room when they start talking. This is not the case in a broadcasting scheme as participants keep different participant lists. This is in conflict with the security assumptions of the authentication properties from the original proposal for (n)sec.
- Consistency: In a group key exchange, the consistency of the participant list (and session id) is provided by the group key exchange protocol. In such a protocol, extra measures need to be taken only to assure the transcript's consistency, i.e. verification of the consistency of delivery and order of messages exchanged between participants. In a broadcast scheme, a new notion needs to be defined and enforced so that a minimum consistency of a conversation can be simulated. For example, as broadcasting to a subset of potential participants is allowed, the notion needs to deal with a situation in which A receives the DH public key of B but wants to send a message to the "room" before it receives the DH key of C.
- Delayed join and leave: In a group scheme, until all participants confirm their identical view of a new participant list (due to a member joining or leaving the room), they need to assume the status quo. This might delay a new participant from joining a chat or, if no further measure is taken, enable a participant to deny join/leave for the whole group. While various mitigation methods are possible against such attacks (all summarized under the umbrella term "Denial of Service" ) they are not included in threat model considered in (n)sec protocol.
Based on the above differences, we selected a group key scheme for the proposed protocol. This is primarily because room consistency is one of the main security properties desired. However, when it is critical, the sub-protocol described by VI.II.2b allows for communication with users while they are waiting for the join procedure to complete.
Participatory vs individually independent computation of group keys
Most AKGE offer some degree of contributiveness in computing the group secret. This roughly means that (at least in the absence of an insider) the group secret is derived using contribution from all members of the group. There has been criticism of the importance of this property such as in [Da14]. In this section we consider briefly the arguments for each side and describe the rational for our choice.
