summary refs log tree commit diff
path: root/blog/Main.hs
blob: 141a8e693c588a14cd8b58a60c55f09e60fd765f (plain) (blame)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
-- | Main module for the blog's web server
module Main where

import           BlogDB              (initialBlogState)
import           Control.Applicative (pure, (<$>), (<*>))
import           Control.Exception   (bracket)
import           Data.Acid
import           Data.Acid.Remote
import           Data.Word           (Word16)
import           Locales             (version)
import           Network             (HostName, PortID (..))
import           Options
import           Server

data MainOptions = MainOptions {
  dbHost      :: String,
  dbPort      :: Word16,
  blogPort    :: Int,
  resourceDir :: String
}

instance Options MainOptions where
  defineOptions = pure MainOptions
    <*> simpleOption "dbHost" "localhost"
        "Remote acid-state database host. Default is localhost"
    <*> simpleOption "dbPort" 8070
        "Remote acid-state database port. Default is 8070"
    <*> simpleOption "blogPort" 8000
        "Port to serve the blog on. Default is 8000."
    <*> simpleOption "resourceDir" "/opt/tazblog/res"
        "Resources folder location."

main :: IO()
main = do
    putStrLn ("TazBlog " ++ version ++ " in Haskell starting")
    runCommand $ \opts _ ->
      let port = PortNumber $ fromIntegral $ dbPort opts
      in openRemoteState skipAuthenticationPerform (dbHost opts) port >>=
              (\acid -> runBlog acid (blogPort opts) (resourceDir opts))