aboutsummaryrefslogtreecommitdiff
path: root/portal/test/js/websockets_hello.ml
blob: 76b70e4d1f412e9fc737c61686a60982e37d3337 (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
open Lwt.Syntax
open Js_of_ocaml

(* https://stackoverflow.com/questions/34929382/what-are-the-differences-between-lwt-async-and-lwt-main-run-on-ocaml-node-js *)
let rec run t =
  let next_tick (_callback : unit -> unit) =
    Js.Unsafe.(fun_call
                 (js_expr "process.nextTick")
                 [| inject (Js.wrap_callback _callback) |])
  in Lwt.wakeup_paused ();
     match Lwt.poll t with
     | Some x -> x
     | None ->
        if Lwt.paused_count () > 0
        then next_tick (fun () -> run t)
        else ()

let () =
  run @@
    let* ws = Portal_ws.ws_endpoint "squarebowl.club" in
    let stream, push =
      Portal_ws.ws_stream ws in
    push (Some "malformed");
    let+ stanzas = stream
                   |> Lwt_stream.map
                        (fun stanza ->
                          match stanza with
                          | {|<close xmlns='urn:ietf:params:xml:ns:xmpp-framing'/>|} -> push None; stanza
                          | stanza -> stanza)
                   |> Lwt_stream.to_list
    in List.map (fun x -> " >>> " ^ x) stanzas |> String.concat "\n" |> print_endline