summaryrefslogtreecommitdiff
path: root/Command/WebApp.hs
diff options
context:
space:
mode:
authorGravatar Joey Hess <joey@kitenet.net>2012-07-25 23:13:01 -0400
committerGravatar Joey Hess <joey@kitenet.net>2012-07-25 23:13:01 -0400
commit1ffef3ad75e51b7f66c4ffdd0935a0495042e5ae (patch)
tree202fa2e776f76c1decaab7a6839688886bbcc490 /Command/WebApp.hs
parente6ce54de82c19999fb5adcd5fd1ea4001fd2059e (diff)
git annex webapp now opens a browser to the webapp
Also, starts the assistant if it wasn't already running.
Diffstat (limited to 'Command/WebApp.hs')
-rw-r--r--Command/WebApp.hs58
1 files changed, 58 insertions, 0 deletions
diff --git a/Command/WebApp.hs b/Command/WebApp.hs
new file mode 100644
index 000000000..616a6512a
--- /dev/null
+++ b/Command/WebApp.hs
@@ -0,0 +1,58 @@
+{- git-annex webapp launcher
+ -
+ - Copyright 2012 Joey Hess <joey@kitenet.net>
+ -
+ - Licensed under the GNU GPL version 3 or higher.
+ -}
+
+module Command.WebApp where
+
+import Common.Annex
+import Command
+import Assistant
+import Utility.WebApp
+import Utility.Daemon
+import qualified Annex
+
+import Control.Concurrent
+import System.Posix.Process
+
+def :: [Command]
+def = [command "webapp" paramNothing seek "launch webapp"]
+
+seek :: [CommandSeek]
+seek = [withNothing start]
+
+start :: CommandStart
+start = notBareRepo $ do
+ r <- checkpid
+ when (r == Nothing) $
+ startassistant
+ f <- liftIO . absPath =<< fromRepo gitAnnexHtmlShim
+ let url = "file://" ++ f
+ ifM (liftIO $ runBrowser url)
+ ( stop
+ , error $ "failed to start web browser on url " ++ url
+ )
+ where
+ checkpid = do
+ pidfile <- fromRepo gitAnnexPidFile
+ liftIO $ checkDaemon pidfile
+ startassistant = do
+ {- Fork a separate process to run the assistant,
+ - with a copy of the Annex state. -}
+ state <- Annex.getState id
+ liftIO $ void $ forkProcess $
+ Annex.eval state $ startDaemon True False
+ waitdaemon (100 :: Int)
+ waitdaemon 0 = error "failed to start git-annex assistant"
+ waitdaemon n = do
+ r <- checkpid
+ case r of
+ Just _ -> return ()
+ Nothing -> do
+ liftIO $
+ threadDelay 100000 -- 0.1 seconds
+
+
+waitdaemon (n - 1)