diff options
| author | Róman Joost <rjoost@redhat.com> | 2017-08-24 14:32:32 +1000 | 
|---|---|---|
| committer | Róman Joost <rjoost@redhat.com> | 2017-08-24 17:08:13 +1000 | 
| commit | a7bc612666062b5c48efae74054a453334727e91 (patch) | |
| tree | de92595ae2380afc80928ec72aa2d7cb5b9b7c9b /src/Plugins/Monitors | |
| parent | f0c265b3b4359e866673954dbcc5a586c7ae51dd (diff) | |
| download | xmobar-a7bc612666062b5c48efae74054a453334727e91.tar.gz xmobar-a7bc612666062b5c48efae74054a453334727e91.tar.bz2 | |
Fix UVMeter due to changed URL and BOM
The URL which exports the real time UV data has changed to an HTTPS
address. Since the HTTP package does not support HTTPS URLs, use
http-conduit to retrieve the XML document.
Unfortunately, the XML documents XML declaration precedes a byte order
mark which the previous XML parser was unable to handle. We're simply
ignoring the BOM in order to get to the UV values.
Diffstat (limited to 'src/Plugins/Monitors')
| -rw-r--r-- | src/Plugins/Monitors/UVMeter.hs | 25 | 
1 files changed, 16 insertions, 9 deletions
| diff --git a/src/Plugins/Monitors/UVMeter.hs b/src/Plugins/Monitors/UVMeter.hs index b0f5ac3..4d90846 100644 --- a/src/Plugins/Monitors/UVMeter.hs +++ b/src/Plugins/Monitors/UVMeter.hs @@ -18,11 +18,14 @@ module Plugins.Monitors.UVMeter where  import Plugins.Monitors.Common  import qualified Control.Exception as CE -import Control.Applicative hiding ((<|>),many) -import Network.HTTP +import Network.HTTP.Conduit +       (parseRequest, newManager, tlsManagerSettings, httpLbs, +        responseBody) +import Data.ByteString.Lazy.Char8 as B  import Text.Read (readMaybe)  import Text.Parsec  import Text.Parsec.String +import Control.Monad (void)  uvConfig :: IO MConfig @@ -35,14 +38,18 @@ newtype UvInfo = UV { index :: String }      deriving (Show)  uvURL :: String -uvURL = "http://www.arpansa.gov.au/uvindex/realtime/xml/uvvalues.xml" +uvURL = "https://uvdata.arpansa.gov.au/xml/uvvalues.xml"  getData :: IO String -getData = do -    let request = getRequest uvURL -    CE.catch (simpleHTTP request >>= getResponseBody) errHandler -    where errHandler :: CE.IOException -> IO String -          errHandler _ = return "<Could not retrieve data>" +getData = +  CE.catch (do request <- parseRequest uvURL +               manager <- newManager tlsManagerSettings +               res <- httpLbs request manager +               return $ B.unpack $ responseBody res) +           errHandler +  where errHandler +          :: CE.SomeException -> IO String +        errHandler _ = return "<Could not retrieve data>"  textToXMLDocument :: String -> Either ParseError [XML]  textToXMLDocument = parse document "" @@ -123,7 +130,7 @@ tag  = do  xmlDecl :: Parser XML  xmlDecl = do -    string "<?xml" +    void $ manyTill anyToken (string "<?xml") -- ignore the byte order mark      decl <- many (noneOf "?>")      string "?>"      return (Decl decl) | 
