implemented servePutOffset and clientPutOffset
But, it's buggy: the server hangs without processing the VALIDITY, and I can't seem to work out why. As far as I can see, storefile is getting as far as running the validitycheck, which is supposed to read that, but never does. This is especially strange because what seems like the same protocol doesn't hang when servePut runs it. This made me think that it needed to use inAnnexWorker to be more like servePut, but that didn't help. Another small problem with this is that it does create an empty .git/annex/tmp/ file for the key. Since this will usually be used in combination with servePut, that doesn't seem worth worrying about much.
This commit is contained in:
parent
c36b9cd1fc
commit
3069e28dd8
6 changed files with 110 additions and 31 deletions
|
@ -107,10 +107,14 @@ newtype PutResult = PutResult Bool
|
|||
data PutResultPlus = PutResultPlus Bool [B64UUID Plus]
|
||||
deriving (Show)
|
||||
|
||||
newtype PutOffsetResult = PutOffsetResult Offset
|
||||
data PutOffsetResult
|
||||
= PutOffsetResult Offset
|
||||
| PutOffsetResultAlreadyHave
|
||||
deriving (Show)
|
||||
|
||||
data PutOffsetResultPlus = PutOffsetResultPlus Offset [B64UUID Plus]
|
||||
data PutOffsetResultPlus
|
||||
= PutOffsetResultPlus Offset
|
||||
| PutOffsetResultAlreadyHavePlus [B64UUID Plus]
|
||||
deriving (Show, Generic, NFData)
|
||||
|
||||
newtype Offset = Offset P2P.Offset
|
||||
|
@ -296,23 +300,37 @@ instance FromJSON GetTimestampResult where
|
|||
instance ToJSON PutOffsetResult where
|
||||
toJSON (PutOffsetResult (Offset (P2P.Offset o))) = object
|
||||
["offset" .= o]
|
||||
toJSON PutOffsetResultAlreadyHave = object
|
||||
["alreadyhave" .= True]
|
||||
|
||||
instance FromJSON PutOffsetResult where
|
||||
parseJSON = withObject "PutOffsetResult" $ \v ->
|
||||
PutOffsetResult
|
||||
<$> (Offset . P2P.Offset <$> v .: "offset")
|
||||
(PutOffsetResult
|
||||
<$> (Offset . P2P.Offset <$> v .: "offset"))
|
||||
<|> (mkalreadyhave
|
||||
<$> (v .: "alreadyhave"))
|
||||
where
|
||||
mkalreadyhave :: Bool -> PutOffsetResult
|
||||
mkalreadyhave _ = PutOffsetResultAlreadyHave
|
||||
|
||||
instance ToJSON PutOffsetResultPlus where
|
||||
toJSON (PutOffsetResultPlus (Offset (P2P.Offset o)) us) = object
|
||||
[ "offset" .= o
|
||||
toJSON (PutOffsetResultPlus (Offset (P2P.Offset o))) = object
|
||||
[ "offset" .= o ]
|
||||
toJSON (PutOffsetResultAlreadyHavePlus us) = object
|
||||
[ "alreadyhave" .= True
|
||||
, "plusuuids" .= plusList us
|
||||
]
|
||||
|
||||
instance FromJSON PutOffsetResultPlus where
|
||||
parseJSON = withObject "PutOffsetResultPlus" $ \v ->
|
||||
PutOffsetResultPlus
|
||||
<$> (Offset . P2P.Offset <$> v .: "offset")
|
||||
<*> v .: "plusuuids"
|
||||
(PutOffsetResultPlus
|
||||
<$> (Offset . P2P.Offset <$> v .: "offset"))
|
||||
<|> (mkalreadyhave
|
||||
<$> (v .: "alreadyhave")
|
||||
<*> (v .: "plusuuids"))
|
||||
where
|
||||
mkalreadyhave :: Bool -> [B64UUID Plus] -> PutOffsetResultPlus
|
||||
mkalreadyhave _ us = PutOffsetResultAlreadyHavePlus us
|
||||
|
||||
instance FromJSON (B64UUID t) where
|
||||
parseJSON (String t) = case decodeB64Text t of
|
||||
|
@ -358,5 +376,8 @@ instance PlusClass PutResultPlus PutResult where
|
|||
plus (PutResult b) = PutResultPlus b mempty
|
||||
|
||||
instance PlusClass PutOffsetResultPlus PutOffsetResult where
|
||||
dePlus (PutOffsetResultPlus o _) = PutOffsetResult o
|
||||
plus (PutOffsetResult o) = PutOffsetResultPlus o mempty
|
||||
dePlus (PutOffsetResultPlus o) = PutOffsetResult o
|
||||
dePlus (PutOffsetResultAlreadyHavePlus _) = PutOffsetResultAlreadyHave
|
||||
plus (PutOffsetResult o) = PutOffsetResultPlus o
|
||||
plus PutOffsetResultAlreadyHave = PutOffsetResultAlreadyHavePlus []
|
||||
|
||||
|
|
Loading…
Add table
Add a link
Reference in a new issue