blob: 08a182ec4319582a7c299cc07780aed8b5708a4b (
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
32
33
34
35
36
37
38
39
40
41
|
open Async
open Core
open Disml
let hook_events client =
Client.on "MESSAGE_CREATE" client (fun msg ->
let msg_time = Time.(to_span_since_epoch @@ now ()) in
let content = Yojson.Basic.Util.(member "content" msg |> to_string) in
let channel = Yojson.Basic.Util.(member "channel_id" msg |> to_string) in
if String.is_prefix ~prefix:"!?ping" content then
Http.create_message channel @@ `Assoc [
("content", `String "Pong!");
("tts", `Bool false);
]
>>> fun resp ->
let message_id = Yojson.Basic.Util.(member "id" resp |> to_string) in
let rtt = Time.(to_span_since_epoch @@ sub (now ()) msg_time) in
Http.edit_message channel message_id @@ `Assoc [
("content", `String ("Pong! `" ^ (Float.to_string @@ Time.Span.to_ms rtt) ^ " ms`"));
]
>>> fun _ -> print_endline "Message Edited!"
);
Client.on "GUILD_CREATE" client (fun guild -> print_endline Yojson.Basic.Util.(member "name" guild |> to_string))
let main () =
let token = match Sys.getenv "DISCORD_TOKEN" with
| Some s -> s
| None -> failwith "No token"
in
let client = Client.make token in
hook_events client;
Client.start client
>>> fun client ->
Clock.every
(Time.Span.create ~sec:60 ())
(fun () ->
Client.set_status_with client (fun shard -> `String ("Current seq: " ^ (Int.to_string shard.seq)))
|> ignore)
let _ =
Scheduler.go_main ~main ()
|