From 9003a76d21c10bb5e77fd73f5f01ec7b16342f7a Mon Sep 17 00:00:00 2001 From: rtrimana Date: Thu, 14 Jul 2016 17:31:51 -0700 Subject: [PATCH] Client read slots algorithm - Cleaning up, adding error function, making sure that slots are processed in order --- doc/iotcloud.tex | 161 +++++++++++++++++++++++------------------------ 1 file changed, 79 insertions(+), 82 deletions(-) diff --git a/doc/iotcloud.tex b/doc/iotcloud.tex index eb6fca1..67204d1 100644 --- a/doc/iotcloud.tex +++ b/doc/iotcloud.tex @@ -76,7 +76,7 @@ or user-level data) is dead if there is a newer slot from the same machine. entry 50 is dead and 70 is live. However, not until the number of slots reaches 70 that queue state entry 50 will be expunged from the queue.} -\item Collision resolution entry is dead if there this entry has been seen +\item Collision resolution entry is dead if this entry has been seen by all clients after a collision happens. \end{enumerate} @@ -202,16 +202,18 @@ $sv_s = \tuple{s, E(Dat_s)} = \textit{$MS_c$ = set MS to save all $\tuple{id, s_{last}}$ pairs while traversing DT after a request to server (initially empty)} \\ \textit{$max_c$ = maximum number of slots (initially $max_c > 0$)} \\ -\textit{m = number of slots on client (initially $m = 0 \mid m \leq n$)} \\ +\textit{m = number of slots on client (initially $m = 0 and m \leq n$)} \\ \textit{$hmac_p$ = the HMAC value of the previous slot ($hmac_p = \emptyset$ for the first slot)} \\ \textit{$id_{self}$ = machine Id of this client} \\ \textit{SK = Secret Key} \\ \\ \textbf{Helper Functions} \\ -$MaxSlot(SL_s)= \tuple{s, sv} \mid \tuple{s, sv} +$MaxSlot(SL_s)= \tuple{s, sv}$ \textit{such that} $\tuple{s, sv} \in SL_s \wedge \forall \tuple{s_s, sv_s} \in SL_s, s \geq s_s$ \\ -$MinSlot(SL_s)= \tuple{s, sv} \mid \tuple{s, sv} +$MinSlot(SL_s)= \tuple{s, sv}$ \textit{such that} $\tuple{s, sv} \in SL_s \wedge \forall \tuple{s_s, sv_s} \in SL_s, s \leq s_s$ \\ +$Slot(SL_s,s_s)= \tuple{s, sv}$ \textit{such that} $\tuple{s, sv} +\in SL_s \wedge \forall \tuple{s_s, sv_s} \in SL_s, s = s_s$ \\ $SeqN(\tuple{s, sv})=s$ \\ $SlotVal(\tuple{s, sv})=sv$ \\ $Decrypt(SK_s,sv_s)=Dat_s=\tuple{s,id,hmac_p,DE,hmac_c}$ \\ @@ -223,73 +225,63 @@ $GetMacId(Dat_s = \tuple{s,id,hmac_p,DE,hmac_c})=id$ \\ $GetPrevHmac(Dat_s = \tuple{s,id,hmac_p,DE,hmac_c})=hmac_p$ \\ $GetCurrHmac(Dat_s = \tuple{s,id,hmac_p,DE,hmac_c})=hmac_c$ \\ $GetDatEnt(Dat_s = \tuple{s,id,hmac_p,DE,hmac_c})=DE$ \\ -$GetQS(de_s \mid de_s \in D \land de_s = qs)=qs$ \\ -$GetSS(de_s \mid de_s \in D \land de_s = ss)=ss$ \\ -$GetKV(de_s \mid de_s \in D \land de_s = kv)=kv=\tuple{k,v}$ \\ -$GetLastSeqN(MS_s,id_s)= s_{last} \mid \tuple{id, s_{last}} +$GetQS(de_s$ \textit{such that} $de_s \in D \land de_s = qs)=qs$ \\ +$GetSS(de_s$ \textit{such that} $de_s \in D \land de_s = ss)=ss$ \\ +$GetKV(de_s$ \textit{such that} $de_s \in D \land de_s = kv)=kv=\tuple{k,v}$ \\ +$GetLastSeqN(MS_s,id_s)= s_{last}$ \textit{such that} $\tuple{id, s_{last}} \in MS_s \wedge \forall \tuple{id_s, s_{s_{last}}} \in MS_s, id = id_s$ \\ $GetKey(\tuple{k, v})=k$ \\ $GetVal(\tuple{k, v})=v$ \\ -$GetKeyVal(DT_s,k_s)= \tuple{k, v} \mid \tuple{k, v} +$GetKeyVal(DT_s,k_s)= \tuple{k, v}$ \textit{such that} $\tuple{k, v} \in DT_s \wedge \forall \tuple{k_s, v_s} \in DT_s, k = k_s$ \\ \begin{algorithmic}[1] -\Function{CreateSK}{$uid,pw$} -\State $SK = ComputeHash(uid + pw)$ -\State \Return{$SK$} -\EndFunction -\end{algorithmic} - -\begin{algorithmic}[1] -\Function{Hmac}{$Dat_s,SK_s$} -\State \Return{$ComputeHmac(Dat_s,SK_s)$} -\EndFunction +\Procedure{ReportError}{$msg$} +\State $Print(msg)$ +\State $Halt()$ +\EndProcedure \end{algorithmic} \begin{algorithmic}[1] \Function{ValidHmac}{$Dat_s,SK_s$} \State $hmac_{stored} \gets GetCurrHmac(Dat_s)$ -\State $hmac_{computed} \gets \Call{Hmac}{Dat_s,SK_s}$ +\State $hmac_{computed} \gets Hmac(Dat_s,SK_s)$ \If{$hmac_{stored} = hmac_{computed}$} - \State \Return{$true$} + \State $valid \gets true$ \Else - \State \Return{$false$} + \State $valid \gets false$ \EndIf +\State \Return{$valid$} \EndFunction \end{algorithmic} \begin{algorithmic}[1] \Function{ValidPrevHmac}{$Dat_s,hmac_{p_s}$} \If{$hmac_{p_s} = \emptyset$}\Comment{First slot - no previous HMAC} - \State \Return{$true$} -\EndIf -\State $hmac_{stored} \gets GetPrevHmac(Dat_s)$ -\If{$hmac_{stored} = hmac_{p_s}$} - \State \Return{$true$} + \State $valid \gets true$ \Else - \State \Return{$false$} + \State $hmac_{stored} \gets GetPrevHmac(Dat_s)$ + \If{$hmac_{stored} = hmac_{p_s}$} + \State $valid \gets true$ + \Else + \State $valid \gets false$ + \EndIf \EndIf +\State \Return{$valid$} \EndFunction \end{algorithmic} \begin{algorithmic}[1] \Function{GetQueSta}{$Dat_s$} \State $DE_s \gets GetDatEnt(Dat_s)$ -%\State $qs_{ret} \gets max_s$ -%\ForAll{$de_i \in DE_s$} -% \If{$de_i \mid de_i \in D \land de_i = qs$} -% \State $qs_i \gets GetQS(de_i)$ -% \If{$qs_i > qs_{ret}$} -% \State $qs_{ret} \gets qs_i$ -% \EndIf -% \EndIf -%\EndFor -\State $de_{qs} \gets de_s \mid de_s \in DE_s, de_s \in D \land de_s = qs$ -\State $qs_{ret} \gets GetQS(de_{qs})$ -%\If{$qs_{ret} > max_s$} -%\State $qs_{ret} \gets qs_i$ -%\EndIf +\State $de_{qs} \gets de_s$ \textit{such that} $de_s \in DE_s, + de_s \in D \land de_s = qs$ +\If{$de_{qs} \neq \emptyset$} + \State $qs_{ret} \gets GetQS(de_{qs})$ +\Else + \State $qs_{ret} \gets \emptyset$ +\EndIf \State \Return{$qs_{ret}$} \EndFunction \end{algorithmic} @@ -297,13 +289,13 @@ $GetKeyVal(DT_s,k_s)= \tuple{k, v} \mid \tuple{k, v} \begin{algorithmic}[1] \Function{GetSlotSeq}{$Dat_s$} \State $DE_s \gets GetDatEnt(Dat_s)$ -%\ForAll{$de_i \in DE_s$} - %\If{$de_i \mid de_i \in D \land de_i = ss$} - %\State $\tuple{id_{ret},s_{last_{ret}}} \gets GetSS(de_i)$ - %\EndIf -%\EndFor -\State $de_{ss} \gets de_s \mid de_s \in DE_s, de_s \in D \land de_s = ss$ -\State $\tuple{id_{ret},s_{last_{ret}}} \gets GetSS(de_{ss})$ +\State $de_{ss} \gets de_s$ \textit{such that} $de_s \in DE_s, + de_s \in D \land de_s = ss$ +\If{$\tuple{id_{ret},s_{last_{ret}}} \neq \emptyset$} + \State $\tuple{id_{ret},s_{last_{ret}}} \gets GetSS(de_{ss})$ +\Else + \State $\tuple{id_{ret},s_{last_{ret}}} \gets \emptyset$ +\EndIf \State \Return{$\tuple{id_{ret},s_{last_{ret}}}$} \EndFunction \end{algorithmic} @@ -324,36 +316,33 @@ $GetKeyVal(DT_s,k_s)= \tuple{k, v} \mid \tuple{k, v} \end{algorithmic} \begin{algorithmic}[1] -\Function{CheckLastSeqN}{$MS_s,MS_t$}\Comment{Check $MS_t$ based on $MS_s$} +\Procedure{CheckLastSeqN}{$MS_s,MS_t$}\Comment{Check $MS_t$ based on $MS_s$} \ForAll{$\tuple{id_t,s_{t_{last}}} \in MS_t$} \State $s_{s_{last}} \gets GetLastSeqN(MS_s,id_t)$ \If{$s_{s_{last}} \neq \emptyset$} \If{$id_t = id_{self}$} \If{$s_{s_{last}} \neq s_{t_{last}}$} - \State $error \gets$ 'Invalid last $s$ for this machine' - \State \Return{error} + \State \Call{ReportError}{'Invalid last $s$ for this machine'} \EndIf \Else \If{$s_{s_{last}} \geq s_{t_{last}}$} \State $MS_s \gets (MS_s - \{\tuple{id_t,s_{t_{last}}}\}) \cup \{\tuple{id_t,s_{s_{last}}}\}$ \Else - \State $error \gets$ 'Invalid last $s$ for machine $id_t$' - \State \Return{error} + \State \Call{ReportError}{'Invalid last $s$ for machine $id_t$'} \EndIf \EndIf \EndIf \EndFor -\State \Return{$\emptyset$} -\EndFunction +\EndProcedure \end{algorithmic} \begin{algorithmic}[1] \Function{UpdateDT}{$DT_s,Dat_s$} \State $DE_s \gets GetDatEnt(Dat_s)$ -\ForAll{$de_i \in DE_s$} - \If{$de_i \mid de_i \in D \land de_i = kv$} - \State $\tuple{k_s,v_s} \gets GetKV(de_i)$ +\ForAll{$de_s \in DE_s$} + \If{$de_s$ \textit{such that} $de_s \in D \land de_s = kv$} + \State $\tuple{k_s,v_s} \gets GetKV(de_s)$ \State $k_s \gets GetKey(\tuple{k_s,v_s})$ \State $\tuple{k_s,v_t} \gets GetKeyVal(DT_s,k_s)$ \If{$\tuple{k_s,v_t} = \emptyset$} @@ -372,47 +361,55 @@ $GetKeyVal(DT_s,k_s)= \tuple{k, v} \mid \tuple{k, v} \Function{GetKVPairs}{$s$} \State $SL_c \gets \Call{GetSlot}{s}$ \State $MS_c \gets \emptyset$ -\ForAll{$\tuple{s_i,sv_i} \in SL_c$} - \State $s_i \gets SeqN(\tuple{s_i,sv_i})$ - \State $sv_i \gets SlotVal(\tuple{s,sv_i})$ - \State $Dat_i \gets Decrypt(SK,sv_i)$ - \State $s_s \gets GetSeqN(Dat_s)$ - \If{$s_i \neq s_s$} - \State $error \gets$ 'Invalid sequence number' +\State $\tuple{s_{c_{max}},sv_{c_{max}}} \gets MaxSlot(SL_c)$ +\State $s_{c_{max}} \gets SeqN(\tuple{s_{c_{max}},sv_{c_{max}}})$ +\State $\tuple{s_{c_{min}},sv_{c_{min}}} \gets MinSlot(SL_c)$ +\State $s_{c_{min}} \gets SeqN(\tuple{s_{c_{max}},sv_{c_{max}}})$ +%\For{$\{\tuple{s_c,sv_c} \mid \tuple{s_c,sv_c} \in SL_c\}$} +\For{$s_c \gets s_{c_{min}}$ \textbf{to} $s_{c_{max}}$} + \State $\tuple{s_c,sv_c} \gets Slot(SL_c,s_c)$ + \State $s_c \gets SeqN(\tuple{s_c,sv_c})$ + \State $sv_c \gets SlotVal(\tuple{s_c,sv_c})$ + \State $Dat_c \gets Decrypt(SK,sv_c)$ + \State $s_{c_{in}} \gets GetSeqN(Dat_c)$ + \If{$s_c \neq s_{c_{in}}$} + \State \Call{ReportError}{'Invalid sequence number'} \EndIf - \If{$\Call{ValidPrevHmac}{Dat_i,hmac_p} = false$} - \State $error \gets$ 'Invalid previous HMAC value' + \If{$\neg \Call{ValidPrevHmac}{Dat_c,hmac_p}$} + \State \Call{ReportError}{'Invalid previous HMAC value'} \EndIf - \If{$\Call{ValidHmac}{Dat_i,SK} = false$} - \State $error \gets$ 'Invalid current HMAC value' + \If{$\neg \Call{ValidHmac}{Dat_c,SK}$} + \State \Call{ReportError}{'Invalid current HMAC value'} \EndIf - \State $hmac_p \gets \Call{Hmac}{Dat_i,SK}$\Comment{Update $hmac_p$ for next slot check} - %\State $max_c \gets \Call{GetQueSta}{Dat_i,max_c}$\Comment{Handle qs} - \State $qs_c \gets \Call{GetQueSta}{Dat_i}$\Comment{Handle qs} - \If{$qs_c > max_c$} + \State $hmac_p \gets Hmac(Dat_c,SK)$\Comment{Update $hmac_p$ for next slot check} + \State $qs_c \gets \Call{GetQueSta}{Dat_c}$\Comment{Handle qs} + \If{$qs_c \neq \emptyset \land qs_c > max_c$} \State $max_c \gets qs_c$ \EndIf %Check for last s in Dat - \State $id_i \gets GetMacId(Dat_i)$\Comment{Handle last s} - \State $MS_c \gets \Call{UpdateLastSeqN}{id_i,s_i,MS_c}$ + \State $id_c \gets GetMacId(Dat_c)$\Comment{Handle last s} + \State $MS_c \gets \Call{UpdateLastSeqN}{id_c,s_c,MS_c}$ %Check for last s in DE in Dat - \State $\tuple{id_j,s_{j_{last}}} \gets \Call{GetSlotSeq}{Dat_i}$\Comment{Handle ss} - \State $MS_c \gets \Call{UpdateLastSeqN}{id_j,s_{j_{last}},MS_c}$ - \State $DT \gets \Call{UpdateDT}{DT,Dat_i}$ + \State $\tuple{id_d,s_{d_{last}}} \gets \Call{GetSlotSeq}{Dat_c}$\Comment{Handle ss} + \If{$\tuple{id_d,s_{d_{last}}} \neq \emptyset$} + \State $MS_c \gets \Call{UpdateLastSeqN}{id_d,s_{d_{last}},MS_c}$ + \EndIf + \State $DT \gets \Call{UpdateDT}{DT,Dat_c}$ \EndFor \If{$m + |SL_c| \leq max_c$}\Comment{Check actual size against $max_c$} \State $m \gets m + |SL_c|$ \Else - \State $error \gets$ 'Actual queue size exceeds $max_c$' + \State \Call{ReportError}{'Actual queue size exceeds $max_c$'} \EndIf - \State $error \gets \Call{CheckLastSeqN}{MS_c,MS}$ + \State $\Call{CheckLastSeqN}{MS_c,MS}$ \State \Return{$DT$} \EndFunction \end{algorithmic} \begin{algorithmic}[1] \Function{GetValFromKey}{$k_g$} -\State $\tuple{k_s,v_s} \gets \tuple{k,v} \mid \tuple{k,v} \in DT \land k = k_g$ +\State $\tuple{k_s,v_s} \gets \tuple{k,v}$ \textit{such that} $\tuple{k,v} + \in DT \land k = k_g$ \State $v_s \gets GetVal(\tuple{k_s,v_s})$ \State \Return{$v_s$} \EndFunction -- 2.34.1