Difference between revisions of "Np1sec/Specification"
|  (Remove Leave description) | |||
| Line 182: | Line 182: | ||
|   Input: <math>lastMessage</math> |   Input: <math>lastMessage</math> | ||
|     '''for each''' <math>message</math> in Messages Received from <math>lastDigestedMessage</math>+1 till <math>lastMessage</math>, '''do''' |     '''for each''' <math>message</math> in Messages Received from <math>lastDigestedMessage</math>+1 till <math>lastMessage</math>, '''do''' | ||
| − |        <math>sesionDigest :=  | + |        <math>sesionDigest := Hash(sessionDigest, message)</math>   | 
|        <span style="font-family: serif; font-size: larger; font-variant:small-caps;">'''LRU Cache Store Digest</span>'''(<math>sessionDigest</math>, <math>message</math>) |        <span style="font-family: serif; font-size: larger; font-variant:small-caps;">'''LRU Cache Store Digest</span>'''(<math>sessionDigest</math>, <math>message</math>) | ||
|     '''return''' <math>sessionDigest</math>,<math>lastMessageId</math> |     '''return''' <math>sessionDigest</math>,<math>lastMessageId</math> | ||
Revision as of 17:39, 21 October 2014
Contents
Procedures
Chat setup
Chatroom setup
Procedure Chatroom Init Input:,
global
global
global
global
Generate Initial Paramters(
) global

![participantList:=[Nick_{{myId}}]](https://learn.equalit.ie/mathupload/b/e/e/bee06e338ec583775c6684822dd226a8.png)
![ephemeralPublicPointList:=[y_{{myId}},y_{{other}}]](https://learn.equalit.ie/mathupload/f/1/d/f1dc4f765afd19e840a1823381479e9f.png)
Joining
Join
Procedure Join Input:,
,
global
global

Generate Initial Paramters(
) global
Broadcast(":3mpCAT:3Join:3",
,
,
) global
Receive() global
Compute Session Id(
,
,
) Sign and Send Key Confirmation and Shares() Wait On Receive(":3mpCAT:3KeyConfirmationShare:3") global
Receive() Verify Key Confirmations and Signatures(
,
) Update Session Key()
Procedure Receive Session Digest Input:global

Protocol for other participants already in the chat to accept the newcomer
Procedure Accept Input:Broadcast(":3mpCAT:3Join:3",
,
,
) Wait On Receive(":3mpCAT:3Join:3") global
,
Receive() Update Lists(
,
) global
Compute Session Id(
,
,
) Sign and Send Key Confirmation and Shares() Wait On Receive(":3mpCAT:3KeyConfirmationShare:3") global
Receive() Verify Key Confirmations and Signatures(
,
) Update Session Key() Send(
)
Leave
Farewell
Procedure Shrink on Leave Input:remove
from
global
Compute Session Id() if
, then Sign and Send Key Shares() Wait On Receive(":3mpCAT:3KeyShare:3")
:= Receive() Update Session Key(
)
Procedure Sign and Send Key Shares Input: globalglobal


ED25519Sign(
,
||
) Broadcast(":3mpCAT:3KeyShare:3",
,
,
) # we can send this encrypted but leaving person can read it, hence theoretically it is the same as sending it unencrypted.
Send
Procedure Send
Input:,

= NewKeyShareMessage(
)
:= AES CTR Encrypt(
,
)
:= ED25519Sign(
,
||
)
:= Compute Session Digest(
) Broadcast(":3mpCAT:3",
,
,
,
,":3")
Receive
Procedure Receive
Input:  ,
,  ,
,  ,
,  
ED25519VerifySignature(
,
,
) Assert(
) or return Reject
AES CTR Decrypt(
,
){}
UpdateNewKeyStatus(
) Verify Digests(
) return{
} # isMetaMessage is true if the message is purely meta message and there is nothing to display
Common functions
Common functions used by other procedures in different stages
Procedure Generate Initial Paramters Input:
RandomBits(256)
Ed25519 Scalar(
)) #{This is both Diffie-Hellman secret and ephemeral signature private key}
return

Procedure Verify Key Confirmation and Signatures Input:,
for each
, do if
, then Halt() else if ED25519VerifySignature(
,
,
) = Fail , then Halt()
Procedure Compute Session Id Input:,
return
#
![zip([a,b],[c,d]):=[(a,c),(b,d)]](https://learn.equalit.ie/mathupload/d/a/3/da318a8a8f2f71fda08564297e83c4b3.png)
Procedure Verify Signatures Input:,
, # standard signature verification
Procedure Sign and Send Key Confirmation and Share Input:for each
, do
# Triple DH
global
global


ED25519Sign(
,
||
) Broadcast(":3mpCAT:3KeyConfirmationAndShare:3",
,
,
,
)
Procedure Update Session Key Input:
for each
, do
# recovered
should be equal to its original value global
![sessionKey:=Hash(z_{{j,j+1}}|j\in [1...n])](https://learn.equalit.ie/mathupload/9/1/1/91146cf10f6a4009ef7e391b118ed09c.png)
Procedure Sign Params Update Session Key Input:,
,
Update Session Key()

Sign Session and Send(
) Broadcast(":3mpCAT:3SignedSessionParameters:3",
)
Procedure ComputeSessionDigest Input:for each
in Messages Received from
+1 till
, do
LRU Cache Store Digest(
,
) return
,

Procedure NewKeyShareMessage Input:# Based on metaMessage Determines what type of keyshare needs to be send (Ephemeral point or Group key share) and returen it.
Procedure UpdateNewKeyStatus Input:# Update the table of which participant has sent its new ephemeral point or its new group key share
Procedure Hash Input:return SHA-512(
)
