refactor
This commit is contained in:
parent
4be94c67c7
commit
dc7dc1e179
5 changed files with 24 additions and 31 deletions
|
@ -190,11 +190,7 @@ downloadRemoteFile addunlockedmatcher r o uri file sz = checkCanAdd file $ do
|
||||||
-- should use to download it.
|
-- should use to download it.
|
||||||
setTempUrl urlkey loguri
|
setTempUrl urlkey loguri
|
||||||
let downloader = \dest p ->
|
let downloader = \dest p ->
|
||||||
tryNonAsync (Remote.retrieveKeyFile r urlkey af dest p) >>= \case
|
fst <$> Remote.verifiedAction (Remote.retrieveKeyFile r urlkey af dest p)
|
||||||
Right _ -> return True
|
|
||||||
Left e -> do
|
|
||||||
warning (show e)
|
|
||||||
return False
|
|
||||||
ret <- downloadWith addunlockedmatcher downloader urlkey (Remote.uuid r) loguri file
|
ret <- downloadWith addunlockedmatcher downloader urlkey (Remote.uuid r) loguri file
|
||||||
removeTempUrl urlkey
|
removeTempUrl urlkey
|
||||||
return ret
|
return ret
|
||||||
|
|
|
@ -131,11 +131,7 @@ performRemote key afile numcopies remote = do
|
||||||
, "proof:"
|
, "proof:"
|
||||||
, show proof
|
, show proof
|
||||||
]
|
]
|
||||||
ok <- tryNonAsync (Remote.removeKey remote key) >>= \case
|
ok <- Remote.action (Remote.removeKey remote key)
|
||||||
Right () -> return True
|
|
||||||
Left e -> do
|
|
||||||
warning (show e)
|
|
||||||
return False
|
|
||||||
next $ cleanupRemote key remote ok
|
next $ cleanupRemote key remote ok
|
||||||
, stop
|
, stop
|
||||||
)
|
)
|
||||||
|
|
|
@ -112,9 +112,5 @@ getKey' key afile = dispatch
|
||||||
download (Remote.uuid r) key afile stdRetry
|
download (Remote.uuid r) key afile stdRetry
|
||||||
(\p -> do
|
(\p -> do
|
||||||
showAction $ "from " ++ Remote.name r
|
showAction $ "from " ++ Remote.name r
|
||||||
tryNonAsync (Remote.retrieveKeyFile r key afile dest p) >>= \case
|
Remote.verifiedAction (Remote.retrieveKeyFile r key afile dest p)
|
||||||
Right v -> return (True, v)
|
|
||||||
Left e -> do
|
|
||||||
warning (show e)
|
|
||||||
return (False, UnVerified)
|
|
||||||
) witness
|
) witness
|
||||||
|
|
|
@ -126,12 +126,8 @@ toPerform dest removewhen key afile fastcheck isthere =
|
||||||
Right False -> do
|
Right False -> do
|
||||||
showAction $ "to " ++ Remote.name dest
|
showAction $ "to " ++ Remote.name dest
|
||||||
ok <- notifyTransfer Upload afile $
|
ok <- notifyTransfer Upload afile $
|
||||||
upload (Remote.uuid dest) key afile stdRetry $ \p ->
|
upload (Remote.uuid dest) key afile stdRetry $
|
||||||
tryNonAsync (Remote.storeKey dest key afile p) >>= \case
|
Remote.action . Remote.storeKey dest key afile
|
||||||
Left e -> do
|
|
||||||
warning (show e)
|
|
||||||
return False
|
|
||||||
Right () -> return True
|
|
||||||
if ok
|
if ok
|
||||||
then finish False $
|
then finish False $
|
||||||
Remote.logStatus dest key InfoPresent
|
Remote.logStatus dest key InfoPresent
|
||||||
|
@ -207,11 +203,7 @@ fromPerform src removewhen key afile = do
|
||||||
go = notifyTransfer Download afile $
|
go = notifyTransfer Download afile $
|
||||||
download (Remote.uuid src) key afile stdRetry $ \p ->
|
download (Remote.uuid src) key afile stdRetry $ \p ->
|
||||||
getViaTmp (Remote.retrievalSecurityPolicy src) (RemoteVerify src) key $ \t ->
|
getViaTmp (Remote.retrievalSecurityPolicy src) (RemoteVerify src) key $ \t ->
|
||||||
tryNonAsync (Remote.retrieveKeyFile src key afile t p) >>= \case
|
Remote.verifiedAction $ Remote.retrieveKeyFile src key afile t p
|
||||||
Right v -> return (True, v)
|
|
||||||
Left e -> do
|
|
||||||
warning (show e)
|
|
||||||
return (False, UnVerified)
|
|
||||||
dispatch _ _ False = stop -- failed
|
dispatch _ _ False = stop -- failed
|
||||||
dispatch RemoveNever _ True = next $ return True -- copy complete
|
dispatch RemoveNever _ True = next $ return True -- copy complete
|
||||||
dispatch RemoveSafe deststartedwithcopy True = lockContentShared key $ \_lck -> do
|
dispatch RemoveSafe deststartedwithcopy True = lockContentShared key $ \_lck -> do
|
||||||
|
@ -232,11 +224,7 @@ fromPerform src removewhen key afile = do
|
||||||
, show src
|
, show src
|
||||||
, "(" ++ reason ++ ")"
|
, "(" ++ reason ++ ")"
|
||||||
]
|
]
|
||||||
ok <- tryNonAsync (Remote.removeKey src key) >>= \case
|
ok <- Remote.action (Remote.removeKey src key)
|
||||||
Right () -> return True
|
|
||||||
Left e -> do
|
|
||||||
warning (show e)
|
|
||||||
return False
|
|
||||||
next $ Command.Drop.cleanupRemote key src ok
|
next $ Command.Drop.cleanupRemote key src ok
|
||||||
faileddropremote = do
|
faileddropremote = do
|
||||||
showLongNote "(Use --force to override this check, or adjust numcopies.)"
|
showLongNote "(Use --force to override this check, or adjust numcopies.)"
|
||||||
|
|
17
Remote.hs
17
Remote.hs
|
@ -11,6 +11,8 @@ module Remote (
|
||||||
Remote,
|
Remote,
|
||||||
uuid,
|
uuid,
|
||||||
name,
|
name,
|
||||||
|
action,
|
||||||
|
verifiedAction,
|
||||||
storeKey,
|
storeKey,
|
||||||
retrieveKeyFile,
|
retrieveKeyFile,
|
||||||
retrieveKeyFileCheap,
|
retrieveKeyFileCheap,
|
||||||
|
@ -77,6 +79,21 @@ import Config.DynamicConfig
|
||||||
import Git.Types (RemoteName, ConfigKey(..), fromConfigValue)
|
import Git.Types (RemoteName, ConfigKey(..), fromConfigValue)
|
||||||
import Utility.Aeson
|
import Utility.Aeson
|
||||||
|
|
||||||
|
{- Runs an action that may throw exceptions, catching and displaying them. -}
|
||||||
|
action :: Annex () -> Annex Bool
|
||||||
|
action a = tryNonAsync a >>= \case
|
||||||
|
Right () -> return True
|
||||||
|
Left e -> do
|
||||||
|
warning (show e)
|
||||||
|
return False
|
||||||
|
|
||||||
|
verifiedAction :: Annex Verification -> Annex (Bool, Verification)
|
||||||
|
verifiedAction a = tryNonAsync a >>= \case
|
||||||
|
Right v -> return (True, v)
|
||||||
|
Left e -> do
|
||||||
|
warning (show e)
|
||||||
|
return (False, UnVerified)
|
||||||
|
|
||||||
{- Map from UUIDs of Remotes to a calculated value. -}
|
{- Map from UUIDs of Remotes to a calculated value. -}
|
||||||
remoteMap :: (Remote -> v) -> Annex (M.Map UUID v)
|
remoteMap :: (Remote -> v) -> Annex (M.Map UUID v)
|
||||||
remoteMap mkv = remoteMap' mkv (pure . mkk)
|
remoteMap mkv = remoteMap' mkv (pure . mkk)
|
||||||
|
|
Loading…
Reference in a new issue