aboutsummaryrefslogtreecommitdiff
path: root/lib/models/member.ml
blob: 40e82c24ec1dc7df1e71b647f0b2fd919703399d (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
module Make(Http : S.Http) = struct
	open Async
	open Core
	include Member_t
	
	let add_role ~(role:Role_t.t) member =
		Http.add_member_role member.guild_id member.user.id role.id
		>>| Result.map ~f:ignore

	let remove_role ~(role:Role_t.t) member =
		Http.remove_member_role member.guild_id member.user.id role.id
		>>| Result.map ~f:ignore

	let ban ?(reason="") ?(days=0) member =
		Http.guild_ban_add member.guild_id member.user.id (`Assoc [
            ("delete-message-days", `Int days);
            ("reason", `String reason);
        ]) >>| Result.map ~f:ignore

    let kick ?reason member =
        let payload = match reason with
        | Some r -> `Assoc [("reason", `String r)]
        | None -> `Null
        in Http.remove_member member.guild_id member.user.id payload >>| Result.map ~f:ignore

	let mute member =
		Http.edit_member member.guild_id member.user.id (`Assoc [
			("mute", `Bool true);
		]) >>| Result.map ~f:ignore

	let deafen member =
		Http.edit_member member.guild_id member.user.id (`Assoc [
			("deaf", `Bool true);
		]) >>| Result.map ~f:ignore

	let unmute member =
		Http.edit_member member.guild_id member.user.id (`Assoc [
			("mute", `Bool false);
		]) >>| Result.map ~f:ignore
	
	let undeafen member =
		Http.edit_member member.guild_id member.user.id (`Assoc [
			("deaf", `Bool false);
		]) >>| Result.map ~f:ignore
end