summaryrefslogtreecommitdiff
path: root/Remote/Web.hs
diff options
context:
space:
mode:
authorGravatar Joey Hess <joey@kitenet.net>2011-08-16 20:49:04 -0400
committerGravatar Joey Hess <joey@kitenet.net>2011-08-16 20:49:44 -0400
commit4545a0e78cf675c6bbbcdd86b5c06bf99bb0c7e9 (patch)
tree37ee27fd0a852aafb741be4b85b4d48a96f295e2 /Remote/Web.hs
parent07f2e7ee726f3d7f60cd478e928afc69db60c0c8 (diff)
split out generic url stuff into a helper library from Remote.Web
Diffstat (limited to 'Remote/Web.hs')
-rw-r--r--Remote/Web.hs42
1 files changed, 9 insertions, 33 deletions
diff --git a/Remote/Web.hs b/Remote/Web.hs
index cd028a06d..cc96d5306 100644
--- a/Remote/Web.hs
+++ b/Remote/Web.hs
@@ -7,28 +7,24 @@
module Remote.Web (
remote,
- setUrl,
- download
+ setUrl
) where
import Control.Monad.State (liftIO)
import Control.Exception
import System.FilePath
-import Network.Browser
-import Network.HTTP
-import Network.URI
import Types
import Types.Remote
import qualified Git
import qualified Annex
import Messages
-import Utility
import UUID
import Config
import PresenceLog
import LocationLog
import Locations
+import qualified Remote.Helper.Url as Url
type URLString = String
@@ -90,9 +86,12 @@ setUrl key url status = do
logChange g key webUUID (if null us then InfoMissing else InfoPresent)
downloadKey :: Key -> FilePath -> Annex Bool
-downloadKey key file = do
- us <- getUrls key
- download us file
+downloadKey key file = iter =<< getUrls key
+ where
+ iter [] = return False
+ iter (url:urls) = do
+ ok <- Url.download url file
+ if ok then return ok else iter urls
uploadKey :: Key -> Annex Bool
uploadKey _ = do
@@ -114,28 +113,5 @@ checkKey' :: [URLString] -> Annex Bool
checkKey' [] = return False
checkKey' (u:us) = do
showAction $ "checking " ++ u
- e <- liftIO $ urlexists u
+ e <- liftIO $ Url.exists u
if e then return e else checkKey' us
-
-urlexists :: URLString -> IO Bool
-urlexists url =
- case parseURI url of
- Nothing -> return False
- Just u -> do
- (_, r) <- Network.Browser.browse $ do
- setErrHandler ignore
- setOutHandler ignore
- setAllowRedirects True
- request (mkRequest HEAD u :: Request_String)
- case rspCode r of
- (2,_,_) -> return True
- _ -> return False
- where
- ignore = const $ return ()
-
-download :: [URLString] -> FilePath -> Annex Bool
-download [] _ = return False
-download (url:us) file = do
- showOutput -- make way for curl progress bar
- ok <- liftIO $ boolSystem "curl" [Params "-L -C - -# -o", File file, File url]
- if ok then return ok else download us file