diff options
author | Joey Hess <joey@kitenet.net> | 2011-08-16 20:49:04 -0400 |
---|---|---|
committer | Joey Hess <joey@kitenet.net> | 2011-08-16 20:49:44 -0400 |
commit | 4545a0e78cf675c6bbbcdd86b5c06bf99bb0c7e9 (patch) | |
tree | 37ee27fd0a852aafb741be4b85b4d48a96f295e2 /Remote/Web.hs | |
parent | 07f2e7ee726f3d7f60cd478e928afc69db60c0c8 (diff) |
split out generic url stuff into a helper library from Remote.Web
Diffstat (limited to 'Remote/Web.hs')
-rw-r--r-- | Remote/Web.hs | 42 |
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 |