blob: 527a334d704af9d16716541c971164deb4982a2b (
plain)
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
|
module Fig.Web.Module.Model
( publicWebsockets
) where
import Fig.Prelude
import qualified Control.Concurrent.Chan as Chan
import qualified Network.WebSockets as WS
import Fig.Web.Types
publicWebsockets :: PublicWebsockets
publicWebsockets a =
[ ( "/api/model/broadcast", \conn -> do
forever do
msg <- liftIO $ WS.receiveDataMessage conn
Chan.writeChan a.channels.model msg
)
, ( "/api/model/events", \conn -> do
c <- Chan.dupChan a.channels.model
forever do
ev <- liftIO $ Chan.readChan c
WS.sendDataMessage conn ev
)
]
|