summaryrefslogtreecommitdiff
path: root/Remote
diff options
context:
space:
mode:
authorGravatar Joey Hess <joeyh@joeyh.name>2016-09-30 13:36:50 -0400
committerGravatar Joey Hess <joeyh@joeyh.name>2016-09-30 13:36:50 -0400
commitff84a7d05050da889da5e48b85067186616da80f (patch)
treec6b3263d55e289ab211f28d94987142cbe54b047 /Remote
parent9bdcbd84e505a91b54c3a8193f877f7b2d721c63 (diff)
move externalConfig into ExternalState
Groundwork to having multiple processes running at once for an external special remote; each needs its own externalConfig.
Diffstat (limited to 'Remote')
-rw-r--r--Remote/External.hs42
-rw-r--r--Remote/External/Types.hs7
2 files changed, 29 insertions, 20 deletions
diff --git a/Remote/External.hs b/Remote/External.hs
index b10977b6d..e7365991b 100644
--- a/Remote/External.hs
+++ b/Remote/External.hs
@@ -126,7 +126,9 @@ externalSetup mu _ c gc = do
INITREMOTE_SUCCESS -> Just noop
INITREMOTE_FAILURE errmsg -> Just $ error errmsg
_ -> Nothing
- liftIO $ atomically $ readTMVar $ externalConfig external
+ withExternalLock external $ \lck ->
+ fromExternal lck external externalConfig $
+ liftIO . atomically . readTMVar
gitConfigSpecialRemote u c'' "externaltype" externaltype
return (c'', u)
@@ -232,22 +234,26 @@ handleRequest' lck external req mp responsehandler
handleRemoteRequest (DIRHASH_LOWER k) =
send $ VALUE $ hashDirLower def k
handleRemoteRequest (SETCONFIG setting value) =
- liftIO $ atomically $ do
- let v = externalConfig external
- m <- takeTMVar v
- putTMVar v $ M.insert setting value m
+ fromExternal lck external externalConfig $ \v ->
+ liftIO $ atomically $ do
+ m <- takeTMVar v
+ putTMVar v $ M.insert setting value m
handleRemoteRequest (GETCONFIG setting) = do
- value <- fromMaybe "" . M.lookup setting
- <$> liftIO (atomically $ readTMVar $ externalConfig external)
+ value <- fromExternal lck external externalConfig $ \v ->
+ fromMaybe "" . M.lookup setting
+ <$> liftIO (atomically $ readTMVar v)
send $ VALUE value
handleRemoteRequest (SETCREDS setting login password) = do
- c <- liftIO $ atomically $ readTMVar $ externalConfig external
- let gc = externalGitConfig external
- c' <- setRemoteCredPair encryptionAlreadySetup c gc (credstorage setting) $
- Just (login, password)
- void $ liftIO $ atomically $ swapTMVar (externalConfig external) c'
+ fromExternal lck external externalConfig $ \v -> do
+ c <- liftIO $ atomically $ readTMVar v
+ let gc = externalGitConfig external
+ c' <- setRemoteCredPair encryptionAlreadySetup c gc
+ (credstorage setting)
+ (Just (login, password))
+ void $ liftIO $ atomically $ swapTMVar v c'
handleRemoteRequest (GETCREDS setting) = do
- c <- liftIO $ atomically $ readTMVar $ externalConfig external
+ c <- fromExternal lck external externalConfig $
+ liftIO . atomically . readTMVar
let gc = externalGitConfig external
creds <- fromMaybe ("", "") <$>
getRemoteCredPair c gc (credstorage setting)
@@ -351,7 +357,7 @@ fromExternal lck external extractor a =
where
go (Just st) = run st
go Nothing = do
- st <- startExternal $ externalType external
+ st <- startExternal external
void $ liftIO $ atomically $ do
void $ tryReadTMVar v
putTMVar v st
@@ -370,8 +376,8 @@ fromExternal lck external extractor a =
{- Starts an external remote process running, but does not handle checking
- VERSION, etc. -}
-startExternal :: ExternalType -> Annex ExternalState
-startExternal externaltype = do
+startExternal :: External -> Annex ExternalState
+startExternal external = do
errrelayer <- mkStderrRelayer
g <- Annex.gitRepo
liftIO $ do
@@ -389,6 +395,7 @@ startExternal externaltype = do
fileEncoding herr
stderrelay <- async $ errrelayer herr
checkearlytermination =<< getProcessExitCode pid
+ cv <- atomically $ newTMVar $ externalDefaultConfig external
return $ ExternalState
{ externalSend = hin
, externalReceive = hout
@@ -396,9 +403,10 @@ startExternal externaltype = do
cancel stderrelay
void $ waitForProcess pid
, externalPrepared = Unprepared
+ , externalConfig = cv
}
where
- basecmd = externalRemoteProgram externaltype
+ basecmd = externalRemoteProgram $ externalType external
propgit g p = do
environ <- propGitEnv g
diff --git a/Remote/External/Types.hs b/Remote/External/Types.hs
index be608d4e5..8098826b2 100644
--- a/Remote/External/Types.hs
+++ b/Remote/External/Types.hs
@@ -52,8 +52,7 @@ data External = External
, externalState :: TMVar ExternalState
-- Empty when a remote is in use.
, externalLock :: TMVar ExternalLock
- -- Never left empty.
- , externalConfig :: TMVar RemoteConfig
+ , externalDefaultConfig :: RemoteConfig
, externalGitConfig :: RemoteGitConfig
}
@@ -63,7 +62,7 @@ newExternal externaltype u c gc = liftIO $ External
<*> pure u
<*> atomically newEmptyTMVar
<*> atomically (newTMVar ExternalLock)
- <*> atomically (newTMVar c)
+ <*> pure c
<*> pure gc
type ExternalType = String
@@ -73,6 +72,8 @@ data ExternalState = ExternalState
, externalReceive :: Handle
, externalShutdown :: IO ()
, externalPrepared :: PrepareStatus
+ -- Never left empty.
+ , externalConfig :: TMVar RemoteConfig
}
data PrepareStatus = Unprepared | Prepared | FailedPrepare ErrorMsg