diff options
author | Joey Hess <joeyh@joeyh.name> | 2016-11-17 21:27:16 -0400 |
---|---|---|
committer | Joey Hess <joeyh@joeyh.name> | 2016-11-17 21:32:09 -0400 |
commit | 0a4a2af3ee769e93287e1f52f7aa5856c30f9dd4 (patch) | |
tree | b132c00215e7a2799e767f8d98082b35780ccd35 | |
parent | a5e818dd54e8413fdb1da0d92343a9718b8754a7 (diff) |
pass Len to writeKeyFile so it can detect short reads
-rw-r--r-- | Remote/Helper/P2P.hs | 16 |
1 files changed, 12 insertions, 4 deletions
diff --git a/Remote/Helper/P2P.hs b/Remote/Helper/P2P.hs index bf25a4ed9..b94eda850 100644 --- a/Remote/Helper/P2P.hs +++ b/Remote/Helper/P2P.hs @@ -59,10 +59,19 @@ data ProtoF next | GetMessage (Message -> next) | SendBytes Len L.ByteString next | ReceiveBytes Len (L.ByteString -> next) + -- ^ Lazily reads bytes from peer. Stops once Len are read, + -- or if connection is lost, and in either case returns the bytes + -- that were read. This allows resuming interrupted transfers. | KeyFileSize Key (Len -> next) -- ^ Checks size of key file (dne = 0) | ReadKeyFile Key Offset (L.ByteString -> next) - | WriteKeyFile Key Offset L.ByteString (Bool -> next) + | WriteKeyFile Key Offset Len L.ByteString (Bool -> next) + -- ^ Writes to key file starting at an offset. Returns True + -- once the whole content of the key is stored in the key file. + -- + -- Note: The ByteString may not contain the entire remaining content + -- of the key. Only once the key file size == Len has the whole + -- content been transferred. | CheckAuthToken UUID AuthToken (Bool -> next) | SetPresent Key UUID next deriving (Functor) @@ -81,7 +90,7 @@ runPure (Free (SendBytes _ _ next)) ms = ("> bytes", Nothing):runPure next ms runPure (Free (ReceiveBytes _ next)) ms = ("< bytes", Nothing):runPure (next L.empty) ms runPure (Free (KeyFileSize _ next)) ms = runPure (next (Len 100)) ms runPure (Free (ReadKeyFile _ _ next)) ms = runPure (next L.empty) ms -runPure (Free (WriteKeyFile _ _ _ next)) ms = runPure (next True) ms +runPure (Free (WriteKeyFile _ _ _ _ next)) ms = runPure (next True) ms runPure (Free (CheckAuthToken _ _ next)) ms = runPure (next True) ms runPure (Free (SetPresent _ _ next)) ms = runPure next ms @@ -181,8 +190,7 @@ receiveContent key mkmsg = do r <- getMessage case r of DATA len -> do - content <- receiveBytes len - ok <- writeKeyFile key offset content + ok <- writeKeyFile key offset len =<< receiveBytes len sendMessage $ if ok then SUCCESS else FAILURE return ok _ -> do |