blob: b1c6aed9b8204a5f41e856bf5819d922cf94d672 (
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
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
|
module Fig.Frontend where
import Fig.Prelude
import Control.Lens (use)
import Data.Text (toLower)
-- import qualified Network.Wai.Middleware.Static as Wai.Static
import qualified Network.Wai.Handler.Warp as Warp
import qualified Web.Twain as Tw
import qualified Lucid as L
import qualified Lucid.Base as L
import Fig.Utils.SExpr
import Fig.Frontend.Utils
import Fig.Frontend.Auth
import Fig.Frontend.State
import qualified Fig.Frontend.DB as DB
server :: Config -> IO ()
server cfg = do
log $ "Frontend server running on port " <> tshow cfg.port
Warp.run cfg.port =<< app cfg
window :: Text -> Text -> L.Html () -> L.Html ()
window id_ title body =
L.term "fig-window" [L.id_ id_, L.makeAttributes "title" title] do
body
app :: Config -> IO Tw.Application
app cfg = do
db <- DB.connect
st <- stateRef
pure $ foldr' @[] ($)
(Tw.notFound . Tw.send $ Tw.text "not found")
-- [ Wai.Static.staticPolicy $ Wai.Static.addBase cfg.assetPath
[ Tw.get "/"
. Tw.send . Tw.html
. L.renderBS
$ L.doctypehtml_ do
L.head_ do
L.title_ "clonk zone api home page"
L.link_ [L.rel_ "icon", L.href_ "data:;base64,iVBORw0KGgo="]
L.body_ do
"hello"
, Tw.get "/api/check" $ authed cfg \auth -> do
Tw.send $ Tw.json @[Text] [auth.id, auth.name]
, Tw.put "/api/buffer" do
buf <- withState st $ use buffer
Tw.send $ Tw.text buf
, Tw.get "/api/user/:name" do
name <- toLower <$> Tw.param "name"
DB.get db ("user:" <> encodeUtf8 name) >>= \case
Nothing -> Tw.send . Tw.status Tw.status404 $ Tw.text "user not found"
Just val -> Tw.send . Tw.text $ decodeUtf8 val
, Tw.get "/api/songs" do
DB.hvals db "songnames" >>= \case
Nothing -> Tw.send . Tw.status Tw.status404 $ Tw.text "no sounds found :("
Just songs -> Tw.send . Tw.text . pretty . SExprList @Void $ SExprString . decodeUtf8 <$> songs
, Tw.get "/api/song/:hash" do
hash <- Tw.param "hash"
DB.hget db "songnotes" hash >>= \case
Nothing -> Tw.send . Tw.status Tw.status404 $ Tw.text "song not found"
Just val -> Tw.send . Tw.text $ decodeUtf8 val
, Tw.get "/api/poke/:name" do
target <- encodeUtf8 . toLower <$> Tw.param "name"
inbox <- fromMaybe [] <$> DB.smembers db ("pokeinbox:" <> target)
Tw.send . Tw.text . pretty . SExprList @Void $ SExprString . decodeUtf8 <$> inbox
, Tw.post "/api/poke/:name" do
me <- encodeUtf8 . toLower <$> Tw.param "ayem"
target <- encodeUtf8 . toLower <$> Tw.param "name"
DB.sismember db ("pokeinbox:" <> me) target >>= \case
True -> do
log . tshow $ "handshake between " <> me <> " and " <> target <> " complete!"
DB.srem db ("pokeinbox:" <> target) [me]
DB.srem db ("pokeinbox:" <> me) [target]
Tw.send $ Tw.text "complete"
False -> do
log . tshow $ "partial handshake from " <> me <> " to " <> target
DB.sadd db ("pokeinbox:" <> target) [me]
Tw.send $ Tw.text "partial"
]
|