make tor hidden service work when directory watching is not available
Avoid crashing when built w/o inotify..
This commit is contained in:
parent
8ac4126bd2
commit
9dd510bf29
4 changed files with 22 additions and 18 deletions
|
@ -71,7 +71,7 @@ stopWatchingChangedRefs h@(ChangedRefsHandle wh chan) = do
|
||||||
atomically $ closeTBMChan chan
|
atomically $ closeTBMChan chan
|
||||||
drainChangedRefs h
|
drainChangedRefs h
|
||||||
|
|
||||||
watchChangedRefs :: Annex ChangedRefsHandle
|
watchChangedRefs :: Annex (Maybe ChangedRefsHandle)
|
||||||
watchChangedRefs = do
|
watchChangedRefs = do
|
||||||
-- This channel is used to accumulate notifications,
|
-- This channel is used to accumulate notifications,
|
||||||
-- because the DirWatcher might have multiple threads that find
|
-- because the DirWatcher might have multiple threads that find
|
||||||
|
@ -90,8 +90,11 @@ watchChangedRefs = do
|
||||||
, modifyHook = notifyhook
|
, modifyHook = notifyhook
|
||||||
}
|
}
|
||||||
|
|
||||||
|
if canWatch
|
||||||
|
then do
|
||||||
h <- liftIO $ watchDir refdir (const False) True hooks id
|
h <- liftIO $ watchDir refdir (const False) True hooks id
|
||||||
return $ ChangedRefsHandle h chan
|
return $ Just $ ChangedRefsHandle h chan
|
||||||
|
else return Nothing
|
||||||
|
|
||||||
notifyHook :: TBMChan Git.Sha -> FilePath -> Maybe FileStatus -> IO ()
|
notifyHook :: TBMChan Git.Sha -> FilePath -> Maybe FileStatus -> IO ()
|
||||||
notifyHook chan reffile _
|
notifyHook chan reffile _
|
||||||
|
|
|
@ -24,9 +24,9 @@ seek :: CmdParams -> CommandSeek
|
||||||
seek = withNothing start
|
seek = withNothing start
|
||||||
|
|
||||||
start :: CommandStart
|
start :: CommandStart
|
||||||
start = do
|
start = go =<< watchChangedRefs
|
||||||
h <- watchChangedRefs
|
where
|
||||||
|
go (Just h) = do
|
||||||
-- No messages need to be received from the caller,
|
-- No messages need to be received from the caller,
|
||||||
-- but when it closes the connection, notice and terminate.
|
-- but when it closes the connection, notice and terminate.
|
||||||
let receiver = forever $ void $ getProtocolLine stdin
|
let receiver = forever $ void $ getProtocolLine stdin
|
||||||
|
@ -36,6 +36,7 @@ start = do
|
||||||
void $ liftIO $ concurrently sender receiver
|
void $ liftIO $ concurrently sender receiver
|
||||||
liftIO $ stopWatchingChangedRefs h
|
liftIO $ stopWatchingChangedRefs h
|
||||||
stop
|
stop
|
||||||
|
go Nothing = stop
|
||||||
|
|
||||||
send :: Notification -> IO ()
|
send :: Notification -> IO ()
|
||||||
send n = do
|
send n = do
|
||||||
|
|
|
@ -26,7 +26,7 @@ import Utility.Metered
|
||||||
import Control.Monad.Free
|
import Control.Monad.Free
|
||||||
|
|
||||||
data RunMode
|
data RunMode
|
||||||
= Serving UUID ChangedRefsHandle
|
= Serving UUID (Maybe ChangedRefsHandle)
|
||||||
| Client
|
| Client
|
||||||
|
|
||||||
-- Full interpreter for Proto, that can receive and send objects.
|
-- Full interpreter for Proto, that can receive and send objects.
|
||||||
|
@ -114,12 +114,12 @@ runLocal runmode runner a = case a of
|
||||||
next
|
next
|
||||||
Right _ -> runner next
|
Right _ -> runner next
|
||||||
WaitRefChange next -> case runmode of
|
WaitRefChange next -> case runmode of
|
||||||
Serving _ h -> do
|
Serving _ (Just h) -> do
|
||||||
v <- tryNonAsync $ liftIO $ waitChangedRefs h
|
v <- tryNonAsync $ liftIO $ waitChangedRefs h
|
||||||
case v of
|
case v of
|
||||||
Left e -> return (Left (show e))
|
Left e -> return (Left (show e))
|
||||||
Right changedrefs -> runner (next changedrefs)
|
Right changedrefs -> runner (next changedrefs)
|
||||||
_ -> return $ Left "change notification not implemented for client"
|
_ -> return $ Left "change notification not available"
|
||||||
where
|
where
|
||||||
transfer mk k af ta = case runmode of
|
transfer mk k af ta = case runmode of
|
||||||
-- Update transfer logs when serving.
|
-- Update transfer logs when serving.
|
||||||
|
|
|
@ -110,7 +110,7 @@ serveClient th u r q = bracket setup cleanup start
|
||||||
liftAnnex th $ mergeState st'
|
liftAnnex th $ mergeState st'
|
||||||
|
|
||||||
authed conn theiruuid =
|
authed conn theiruuid =
|
||||||
bracket watchChangedRefs (liftIO . stopWatchingChangedRefs) $ \crh -> do
|
bracket watchChangedRefs (liftIO . maybe noop stopWatchingChangedRefs) $ \crh -> do
|
||||||
v' <- runFullProto (Serving theiruuid crh) conn $
|
v' <- runFullProto (Serving theiruuid crh) conn $
|
||||||
P2P.serveAuthed u
|
P2P.serveAuthed u
|
||||||
case v' of
|
case v' of
|
||||||
|
|
Loading…
Reference in a new issue