blob: af5bd961b374c070a77ccfaf0f99b2d50d9d385a (
plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
|
module Web.Router where
import Web.Response
import Web.Request
import Web.Http
-- Route callback url method
data Route = Route (Request -> IO Response) String Method
resolve :: [Route] -> Request -> IO Response
resolve [] _ = return notFoundResponse
resolve (Route callback routeUrl _ : routerTable) req @ (Request _ url _) =
if url == routeUrl then
callback req
else resolve routerTable req
|