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
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
use crate::request::prelude::*;
use std::{
error::Error,
fmt::{Display, Formatter, Result as FmtResult},
};
use twilight_model::id::{GuildId, UserId};
#[derive(Clone, Debug)]
pub enum CreateBanError {
DeleteMessageDaysInvalid,
}
impl Display for CreateBanError {
fn fmt(&self, f: &mut Formatter<'_>) -> FmtResult {
match self {
Self::DeleteMessageDaysInvalid => {
f.write_str("the number of days' worth of messages to delete is invalid")
}
}
}
}
impl Error for CreateBanError {}
#[derive(Default)]
struct CreateBanFields {
delete_message_days: Option<u64>,
reason: Option<String>,
}
pub struct CreateBan<'a> {
fields: CreateBanFields,
fut: Option<Pending<'a, ()>>,
guild_id: GuildId,
http: &'a Client,
user_id: UserId,
}
impl<'a> CreateBan<'a> {
pub(crate) fn new(http: &'a Client, guild_id: GuildId, user_id: UserId) -> Self {
Self {
fields: CreateBanFields::default(),
fut: None,
guild_id,
http,
user_id,
}
}
pub fn delete_message_days(mut self, days: u64) -> Result<Self, CreateBanError> {
if !validate::ban_delete_message_days(days) {
return Err(CreateBanError::DeleteMessageDaysInvalid);
}
self.fields.delete_message_days.replace(days);
Ok(self)
}
pub fn reason(mut self, reason: impl Into<String>) -> Self {
self.fields.reason.replace(reason.into());
self
}
fn start(&mut self) -> Result<()> {
self.fut.replace(Box::pin(self.http.verify(Request::from(
Route::CreateBan {
delete_message_days: self.fields.delete_message_days,
guild_id: self.guild_id.0,
reason: self.fields.reason.clone(),
user_id: self.user_id.0,
},
))));
Ok(())
}
}
poll_req!(CreateBan<'_>, ());