From 06218428c7d28e8ab091c948dc075f6f740ef5bf Mon Sep 17 00:00:00 2001 From: Joey Hess Date: Wed, 12 Mar 2014 12:19:48 -0400 Subject: [PATCH] quick fix to build with old warp-tls Debian stable's warp-tls is too old to support the new https feature well, so only use http with that old version. Note that the webapp still depends on warp-tls, because the TLSSettings type is used. --- BuildFlags.hs | 3 +++ Utility/WebApp.hs | 10 +++++++--- git-annex.cabal | 6 ++++++ 3 files changed, 16 insertions(+), 3 deletions(-) diff --git a/BuildFlags.hs b/BuildFlags.hs index e5d389d280..d5c98aa4ec 100644 --- a/BuildFlags.hs +++ b/BuildFlags.hs @@ -22,6 +22,9 @@ buildFlags = filter (not . null) #else #warning Building without the webapp. You probably need to install Yesod.. #endif +#ifdef WITH_WEBAPP_HTTPS + , "Webapp-https" +#endif #ifdef WITH_PAIRING , "Pairing" #else diff --git a/Utility/WebApp.hs b/Utility/WebApp.hs index c9cb32106e..31d3711f18 100644 --- a/Utility/WebApp.hs +++ b/Utility/WebApp.hs @@ -74,11 +74,15 @@ browserProc url = proc "xdg-open" [url] runWebApp :: Maybe TLSSettings -> Maybe HostName -> Wai.Application -> (SockAddr -> IO ()) -> IO () runWebApp tlssettings h app observer = withSocketsDo $ do sock <- getSocket h - void $ forkIO $ - (maybe runSettingsSocket (\ts -> runTLSSocket ts) tlssettings) - webAppSettings sock app + void $ forkIO $ run webAppSettings sock app sockaddr <- fixSockAddr <$> getSocketName sock observer sockaddr + where +#ifdef WITH_WEBAPP_HTTPS + run = (maybe runSettingsSocket (\ts -> runTLSSocket ts) tlssettings) +#else + run = runSettingsSocket +#endif fixSockAddr :: SockAddr -> SockAddr #ifdef __ANDROID__ diff --git a/git-annex.cabal b/git-annex.cabal index 2f3b7a2eb4..a98e3e34a6 100644 --- a/git-annex.cabal +++ b/git-annex.cabal @@ -43,6 +43,9 @@ Flag Assistant Flag Webapp Description: Enable git-annex webapp +Flag Webapp-https + Description: Enable git-annex webapp https + Flag Pairing Description: Enable pairing @@ -180,6 +183,9 @@ Executable git-annex blaze-builder, crypto-api, hamlet, clientsession, template-haskell, data-default, aeson, network-conduit CPP-Options: -DWITH_WEBAPP + if flag(Webapp) && flag (Webapp-https) + Build-Depends: warp-tls (>= 1.4) + CPP-Options: -DWITH_WEBAPP_HTTPS if flag(Pairing) Build-Depends: network-multicast, network-info