refactor
This commit is contained in:
parent
e6ae5e8d56
commit
d2091730e9
3 changed files with 36 additions and 31 deletions
|
@ -1,6 +1,6 @@
|
|||
{- Logs listing keys that are equivalent to a key.
|
||||
-
|
||||
- Copyright 2024 Joey Hess <id@joeyh.name>
|
||||
- Copyright 2024-2025 Joey Hess <id@joeyh.name>
|
||||
-
|
||||
- Licensed under the GNU AGPL version 3 or higher.
|
||||
-}
|
||||
|
@ -10,6 +10,8 @@
|
|||
module Logs.EquivilantKeys (
|
||||
getEquivilantKeys,
|
||||
setEquivilantKey,
|
||||
updateEquivilantKeys,
|
||||
generateEquivilantKey,
|
||||
) where
|
||||
|
||||
import Annex.Common
|
||||
|
@ -17,6 +19,11 @@ import qualified Annex
|
|||
import Logs
|
||||
import Logs.Presence
|
||||
import qualified Annex.Branch
|
||||
import qualified Backend.Hash
|
||||
import Types.KeySource
|
||||
import Types.Backend
|
||||
import Types.Remote (Verification(..))
|
||||
import Utility.Metered
|
||||
|
||||
getEquivilantKeys :: Key -> Annex [Key]
|
||||
getEquivilantKeys key = do
|
||||
|
@ -29,3 +36,30 @@ setEquivilantKey key equivkey = do
|
|||
config <- Annex.getGitConfig
|
||||
addLog (Annex.Branch.RegardingUUID []) (equivilantKeysLogFile config key)
|
||||
InfoPresent (LogInfo (serializeKey' equivkey))
|
||||
|
||||
-- The Backend must use a cryptographically secure hash.
|
||||
--
|
||||
-- This returns Verified when when an equivilant key has been added to the
|
||||
-- log (or was already in the log). This is to avoid hashing the object
|
||||
-- again later.
|
||||
updateEquivilantKeys :: Backend -> OsPath -> Key -> [Key] -> Annex (Maybe Verification)
|
||||
updateEquivilantKeys b obj key eks = generateEquivilantKey b obj >>= \case
|
||||
Nothing -> return Nothing
|
||||
Just ek -> do
|
||||
unless (ek `elem` eks) $
|
||||
setEquivilantKey key ek
|
||||
return (Just Verified)
|
||||
|
||||
generateEquivilantKey :: Backend -> OsPath -> Annex (Maybe Key)
|
||||
generateEquivilantKey b obj =
|
||||
case genKey b of
|
||||
Just genkey -> do
|
||||
showSideAction (UnquotedString Backend.Hash.descChecksum)
|
||||
Just <$> genkey source nullMeterUpdate
|
||||
Nothing -> return Nothing
|
||||
where
|
||||
source = KeySource
|
||||
{ keyFilename = mempty -- avoid adding any extension
|
||||
, contentLocation = obj
|
||||
, inodeCache = Nothing
|
||||
}
|
||||
|
|
Loading…
Add table
Add a link
Reference in a new issue