From d9c43c7a931db6fe658644b52fd815a6019320d2 Mon Sep 17 00:00:00 2001 From: Joey Hess Date: Thu, 5 Sep 2013 16:34:13 -0400 Subject: add getParticipantList Note that it needs to look at global git config, since git-remote-gcrypt will see any setting there as a fallback. --- Git/GCrypt.hs | 28 ++++++++++++++++++++++++---- 1 file changed, 24 insertions(+), 4 deletions(-) diff --git a/Git/GCrypt.hs b/Git/GCrypt.hs index 5f2694806..e22bd74a2 100644 --- a/Git/GCrypt.hs +++ b/Git/GCrypt.hs @@ -12,7 +12,8 @@ module Git.GCrypt where import Common import Git.Types import Git.Construct -import Git.Config +import qualified Git.Config as Config +import Utility.Gpg urlPrefix :: String urlPrefix = "gcrypt::" @@ -47,7 +48,26 @@ encryptedRepo baserepo = go - which is stored in the repository (in encrypted form) - and cached in a per-remote gcrypt-id configuration setting. -} remoteRepoId :: Repo -> Repo -> Maybe String -remoteRepoId baserepo remote = do +remoteRepoId = getRemoteConfig "gcrypt-id" + +getRemoteConfig :: String -> Repo -> Repo -> Maybe String +getRemoteConfig field baserepo remote = do name <- remoteName remote - let key = "remote." ++ name ++ ".gcrypt-id" - getMaybe key baserepo + Config.getMaybe (remoteConfigKey field name) baserepo + +{- Gpg keys that the remote is encrypted for. + - If empty, gcrypt uses --default-recipient-self -} +particiantList :: Maybe Repo -> Repo -> Repo -> KeyIds +particiantList globalconfigrepo baserepo remote = KeyIds $ parse $ firstJust + [ getRemoteConfig "participants" baserepo remote + , Config.getMaybe defaultkey baserepo + , Config.getMaybe defaultkey =<< globalconfigrepo + ] + where + defaultkey = "gcrypt.participants" + parse (Just "simple") = [] + parse (Just l) = words l + parse Nothing = [] + +remoteConfigKey :: String -> String -> String +remoteConfigKey key field = "remote." ++ field ++ "." ++ key -- cgit v1.2.3