git-annex/Assistant/Threads/ConfigMonitor.hs

95 lines
3 KiB
Haskell
Raw Normal View History

{- git-annex assistant config monitor thread
-
- Copyright 2012 Joey Hess <id@joeyh.name>
-
- Licensed under the GNU AGPL version 3 or higher.
-}
module Assistant.Threads.ConfigMonitor where
import Assistant.Common
import Assistant.BranchChange
import Assistant.DaemonStatus
2012-10-21 19:50:49 +00:00
import Assistant.Commits
import Utility.ThreadScheduler
import Logs
import Logs.UUID
import Logs.Trust
import Logs.PreferredContent
import Logs.Group
import Logs.NumCopies
import Remote.List.Util
import qualified Git.LsTree as LsTree
2016-01-01 19:56:24 +00:00
import Git.Types
import Git.FilePath
import qualified Annex.Branch
import Annex.FileMatcher
import qualified Data.Set as S
{- This thread detects when configuration changes have been made to the
- git-annex branch and reloads cached configuration.
-
- If the branch is frequently changing, it's checked for configuration
- changes no more often than once every 60 seconds. On the other hand,
- if the branch has not changed in a while, configuration changes will
- be detected immediately.
-}
2012-10-29 15:40:22 +00:00
configMonitorThread :: NamedThread
configMonitorThread = namedThread "ConfigMonitor" $ loop =<< getConfigs
2012-10-29 15:40:22 +00:00
where
loop old = do
2012-10-29 23:20:54 +00:00
waitBranchChange
2012-10-29 15:40:22 +00:00
new <- getConfigs
when (old /= new) $ do
let changedconfigs = new `S.difference` old
debug $ "reloading config" :
map (fromRawFilePath . fst)
(S.toList changedconfigs)
2012-10-29 15:40:22 +00:00
reloadConfigs new
{- Record a commit to get this config
- change pushed out to remotes. -}
2012-10-29 23:35:18 +00:00
recordCommit
liftIO $ threadDelaySeconds (Seconds 60)
2012-10-29 15:40:22 +00:00
loop new
{- Config files, and their checksums. -}
type Configs = S.Set (RawFilePath, Sha)
{- All git-annex's config files, and actions to run when they change. -}
configFilesActions :: [(RawFilePath, Assistant ())]
configFilesActions =
[ (uuidLog, void $ liftAnnex uuidDescMapLoad)
, (remoteLog, void $ liftAnnex remotesChanged)
, (trustLog, void $ liftAnnex trustMapLoad)
, (groupLog, void $ liftAnnex groupMapLoad)
, (numcopiesLog, void $ liftAnnex globalNumCopiesLoad)
, (scheduleLog, void updateScheduleLog)
-- Preferred and required content settings depend on most of the
-- other configs, so will be reloaded whenever any configs change.
, (preferredContentLog, noop)
, (requiredContentLog, noop)
, (groupPreferredContentLog, noop)
]
2012-10-29 15:40:22 +00:00
reloadConfigs :: Configs -> Assistant ()
reloadConfigs changedconfigs = do
sequence_ as
void $ liftAnnex $ preferredRequiredMapsLoad preferredContentTokens
{- Changes to the remote log, or the trust log, can affect the
2012-11-13 21:50:54 +00:00
- syncRemotes list. Changes to the uuid log may affect its
- display so are also included. -}
2013-10-03 02:59:07 +00:00
when (any (`elem` fs) [remoteLog, trustLog, uuidLog])
updateSyncRemotes
2012-10-29 15:40:22 +00:00
where
(fs, as) = unzip $ filter (flip S.member changedfiles . fst)
configFilesActions
changedfiles = S.map fst changedconfigs
2012-10-29 15:40:22 +00:00
getConfigs :: Assistant Configs
getConfigs = S.fromList . map extract
<$> liftAnnex (inRepo $ LsTree.lsTreeFiles Annex.Branch.fullname files)
where
files = map (fromRawFilePath . fst) configFilesActions
extract treeitem = (getTopFilePath $ LsTree.file treeitem, LsTree.sha treeitem)