2018-08-30 22:01:49 +00:00
|
|
|
module Examples.Chunked.Main where
|
|
|
|
|
|
|
|
import Prelude
|
2022-05-04 21:02:29 +00:00
|
|
|
|
2022-05-22 11:30:14 +00:00
|
|
|
import Data.Generic.Rep (class Generic)
|
|
|
|
import Data.Maybe (Maybe(..))
|
2021-11-19 06:16:35 +00:00
|
|
|
import Effect.Aff (Aff)
|
|
|
|
import Effect.Class (liftEffect)
|
|
|
|
import Effect.Console (log)
|
2022-05-22 11:47:58 +00:00
|
|
|
import HTTPurple (Request, ResponseM, ServerM, ok, serve)
|
2022-05-04 21:02:29 +00:00
|
|
|
import Node.ChildProcess (defaultSpawnOptions, spawn, stdout)
|
2021-11-19 06:16:35 +00:00
|
|
|
import Node.Stream (Readable)
|
2022-05-22 11:30:14 +00:00
|
|
|
import Routing.Duplex as RD
|
|
|
|
import Routing.Duplex.Generic as RG
|
|
|
|
|
|
|
|
data Route = SayHello
|
|
|
|
|
|
|
|
derive instance Generic Route _
|
|
|
|
|
|
|
|
route :: RD.RouteDuplex' Route
|
|
|
|
route = RD.root $ RG.sum
|
|
|
|
{ "SayHello": RG.noArgs
|
|
|
|
}
|
2018-08-30 22:01:49 +00:00
|
|
|
|
|
|
|
-- | Run a script and return it's stdout stream
|
2021-11-19 06:16:35 +00:00
|
|
|
runScript :: String -> Aff (Readable ())
|
2021-03-22 19:02:36 +00:00
|
|
|
runScript script =
|
2021-11-19 06:16:35 +00:00
|
|
|
liftEffect $ stdout <$> spawn "sh" [ "-c", script ] defaultSpawnOptions
|
2018-08-30 22:01:49 +00:00
|
|
|
|
|
|
|
-- | Say 'hello world!' in chunks when run
|
2022-05-22 11:30:14 +00:00
|
|
|
router :: Request Route -> ResponseM
|
|
|
|
router = const $ runScript "echo 'hello '; sleep 1; echo 'world!'" >>= ok
|
2018-08-30 22:01:49 +00:00
|
|
|
|
|
|
|
-- | Boot up the server
|
2021-11-19 06:16:35 +00:00
|
|
|
main :: ServerM
|
2021-03-22 19:02:36 +00:00
|
|
|
main =
|
2022-05-22 16:36:08 +00:00
|
|
|
serve { port: 8080, onStarted } { route, router }
|
|
|
|
where
|
|
|
|
onStarted = do
|
2021-11-19 06:16:35 +00:00
|
|
|
log " ┌──────────────────────────────────────┐"
|
|
|
|
log " │ Server now up on port 8080 │"
|
|
|
|
log " │ │"
|
|
|
|
log " │ To test, run: │"
|
|
|
|
log " │ > curl -Nv localhost:8080 │"
|
|
|
|
log " │ # => ... │"
|
|
|
|
log " │ # => < Transfer-Encoding: chunked │"
|
|
|
|
log " │ # => ... │"
|
|
|
|
log " │ # => hello │"
|
|
|
|
log " │ (1 second pause) │"
|
|
|
|
log " │ # => world! │"
|
|
|
|
log " └──────────────────────────────────────┘"
|