Load bind address from environment

This commit is contained in:
rnhmjoj 2015-04-08 15:54:06 +02:00
parent f5157016db
commit d7c0b8d4a5
3 changed files with 22 additions and 8 deletions

View File

@ -20,8 +20,9 @@ import qualified Data.ByteString.Char8 as BS
app :: (Application -> IO ()) -> IO () app :: (Application -> IO ()) -> IO ()
app runner = do app runner = do
settings <- newAppSettings settings <- newAppSettings
table <- records (baseUrl,_) <- serverSettings
table <- records
runner $ controllerApp settings $ do runner $ controllerApp settings $ do
get "/" (render "index.html" ()) get "/" (render "index.html" ())
@ -41,8 +42,7 @@ app runner = do
case lookup "url" form of case lookup "url" form of
Just url' -> do Just url' -> do
let url = BS.unpack url' let url = BS.unpack url'
address <- return "http://localhost:3000/"
word <- liftIO (insert table url) word <- liftIO (insert table url)
liftIO $ putStrLn (printf "Registered %s -> %s " url word) liftIO $ putStrLn (printf "Registered %s -> %s " url word)
render "done.html" $ object ["link" .= (address ++ word)] render "done.html" $ object ["link" .= (baseUrl ++ word)]
Nothing -> respond badRequest Nothing -> respond badRequest

View File

@ -2,14 +2,13 @@
module Main where module Main where
import Application import Application
import Shortener.Common
import Control.Applicative import Control.Applicative
import System.Environment
import Network.Wai.Handler.Warp import Network.Wai.Handler.Warp
import Network.Wai.Middleware.RequestLogger import Network.Wai.Middleware.RequestLogger
main :: IO () main :: IO ()
main = do main = do
port <- maybe 3000 read <$> lookupEnv "PORT" (_, settings) <- serverSettings
app (run port . logStdout) app (runSettings settings . logStdout)

View File

@ -2,11 +2,26 @@
module Shortener.Common where module Shortener.Common where
import Control.Applicative import Control.Applicative
import Text.Printf
import Data.String
import System.Environment
import Network.Wai.Handler.Warp
import Web.Simple import Web.Simple
import Web.Simple.Templates import Web.Simple.Templates
data AppSettings = AppSettings { } data AppSettings = AppSettings { }
serverSettings :: IO (String, Settings)
serverSettings = do
port <- maybe 3000 read <$> lookupEnv "PORT"
host <- maybe "127.0.0.1" id <$> lookupEnv "ADDRESS"
let opts = setPort port $ setHost (fromString host) defaultSettings
url = if port == 80
then printf "http://%s/" host
else printf "http://%s:%d/" host port
return (url, opts)
newAppSettings :: IO AppSettings newAppSettings :: IO AppSettings
newAppSettings = return AppSettings newAppSettings = return AppSettings