summaryrefslogtreecommitdiff
path: root/Annex
diff options
context:
space:
mode:
authorGravatar Joey Hess <joeyh@joeyh.name>2015-10-09 11:09:46 -0400
committerGravatar Joey Hess <joeyh@joeyh.name>2015-10-09 11:09:46 -0400
commit00ba3ec15d8e3a51545aed4c6e43771f2630a0f8 (patch)
treea6fa813ce14bb4ebbb40c7a58712c471ee880fcf /Annex
parentbd0c751b267c080ba28a6efeb88b1c0af293429f (diff)
improve drop proof code
Diffstat (limited to 'Annex')
-rw-r--r--Annex/NumCopies.hs61
1 files changed, 21 insertions, 40 deletions
diff --git a/Annex/NumCopies.hs b/Annex/NumCopies.hs
index a06ef0c5e..6c069c763 100644
--- a/Annex/NumCopies.hs
+++ b/Annex/NumCopies.hs
@@ -15,7 +15,7 @@ module Annex.NumCopies (
defaultNumCopies,
numCopiesCheck,
numCopiesCheck',
- verifyEnoughCopies,
+ verifyEnoughCopiesToDrop,
knownCopies,
) where
@@ -93,31 +93,35 @@ numCopiesCheck' file vs have = do
return $ length have `vs` needed
{- Verifies that enough copies of a key exist amoung the listed remotes,
- - printing an informative message if not.
+ - running an action with a proof if so, and printing an informative
+ - message if not.
-}
-verifyEnoughCopies
+verifyEnoughCopiesToDrop
:: String -- message to print when there are no known locations
-> Key
-> NumCopies
-> [UUID] -- repos to skip considering (generally untrusted remotes)
-> [VerifiedCopy] -- copies already verified to exist
- -> [Remote] -- remotes to check to see if they have it
- -> Annex Bool
-verifyEnoughCopies nolocmsg key need skip preverified tocheck =
+ -> [Remote] -- remotes to check to see if they have copies
+ -> (SafeDropProof -> Annex a) -- action to perform to drop
+ -> Annex a -- action to perform when unable to drop
+ -> Annex a
+verifyEnoughCopiesToDrop nolocmsg key need skip preverified tocheck dropaction nodropaction =
helper [] [] preverified (nub tocheck)
where
- helper bad missing have []
- | NumCopies (length have) >= need = return True
- | otherwise = do
- notEnoughCopies key need have (skip++missing) bad nolocmsg
- return False
+ helper bad missing have [] = do
+ p <- liftIO $ mkSafeDropProof need have
+ case p of
+ Right proof -> dropaction proof
+ Left stillhave -> do
+ notEnoughCopies key need stillhave (skip++missing) bad nolocmsg
+ nodropaction
helper bad missing have (r:rs)
- | verifiedEnoughCopies need have = do
- stillhave <- liftIO $ filterM checkVerifiedCopy have
- if verifiedEnoughCopies need stillhave
- then return True
- else helper bad missing stillhave (r:rs)
- | any safeVerification have = helper bad missing have rs
+ | isSafeDrop need have = do
+ p <- liftIO $ mkSafeDropProof need have
+ case p of
+ Right proof -> dropaction proof
+ Left stillhave -> helper bad missing stillhave (r:rs)
| otherwise = do
haskey <- Remote.hasKey r key
case haskey of
@@ -125,29 +129,6 @@ verifyEnoughCopies nolocmsg key need skip preverified tocheck =
Left _ -> helper (r:bad) missing have rs
Right False -> helper bad (Remote.uuid r:missing) have rs
-{- Check whether enough verification has been done of copies to allow
- - dropping content safely.
- -
- - Unless numcopies is 0, at least one VerifiedCopyLock or TrustedCopy
- - is required. A VerifiedCopyLock prevents races between concurrent
- - drops from dropping the last copy, no matter what.
- -
- - The other N-1 copies can be less strong verifications, like
- - RecentlyVerifiedCopy. While those are subject to concurrent drop races,
- - and so could be dropped all at once, causing numcopies to be violated,
- - this is the best that can be done without requiring all special remotes
- - to support locking.
- -}
-verifiedEnoughCopies :: NumCopies -> [VerifiedCopy] -> Bool
-verifiedEnoughCopies (NumCopies n) l
- | n == 0 = True
- | otherwise = length (deDupVerifiedCopies l) >= n && any safeVerification l
-
-safeVerification :: VerifiedCopy -> Bool
-safeVerification (VerifiedCopyLock _) = True
-safeVerification (TrustedCopy _) = True
-safeVerification (RecentlyVerifiedCopy _) = False
-
notEnoughCopies :: Key -> NumCopies -> [VerifiedCopy] -> [UUID] -> [Remote] -> String -> Annex ()
notEnoughCopies key need have skip bad nolocmsg = do
showNote "unsafe"