aboutsummaryrefslogtreecommitdiff
path: root/lib/models/channel.ml
blob: 3fab4524eb09fe001289301fb7a84a6f787f15e0 (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
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
module Make(Http : S.Http) = struct
    open Async
    open Core
    include Channel_t

    exception Invalid_message
    exception No_message_found
    
    let say ~content ch =
        Http.create_message (get_id ch) (`Assoc [("content", `String content)])
        >>| Result.map ~f:Message_t.of_yojson_exn

    let send_message ?embed ?content ?file ?(tts=false) ch =
        let embed = match embed with
        | Some e -> e
        | None -> `Null in
        let content = match content with
        | Some c -> `String c
        | None -> `Null in
        let file = match file with
        | Some f -> `String f
        | None -> `Null in
        let () = match embed, content with
        | `Null, `Null -> raise Invalid_message
        | _ -> () in
        Http.create_message (get_id ch) (`Assoc [
            ("embed", embed);
            ("content", content);
            ("file", file);
            ("tts", `Bool tts);
        ]) >>| Result.map ~f:Message_t.of_yojson_exn

    let delete ch =
        Http.delete_channel (get_id ch) >>| Result.map ~f:ignore

    let get_message ~id ch =
        Http.get_message (get_id ch) id >>| Result.map ~f:Message_t.of_yojson_exn

    let get_messages ?(mode=`Around) ?id ?(limit=50) ch =
        let kind = match mode with
        | `Around -> "around", limit
        | `Before -> "before", limit
        | `After -> "after", limit
        in
        let id = match id with
        | Some id -> id
        | None -> raise No_message_found in
        Http.get_messages (get_id ch) id kind >>| Result.map ~f:(fun l ->
            Yojson.Safe.Util.to_list l
            |> List.map ~f:Message_t.of_yojson_exn)

    let broadcast_typing ch =
        Http.broadcast_typing (get_id ch) >>| Result.map ~f:ignore

    let get_pins ch =
        Http.get_pinned_messages (get_id ch) >>| Result.map ~f:(fun l ->
            Yojson.Safe.Util.to_list l
            |> List.map ~f:Message_t.of_yojson_exn)
end