diff options
| author | acdenisSK <[email protected]> | 2017-09-06 15:52:48 +0200 |
|---|---|---|
| committer | acdenisSK <[email protected]> | 2017-09-06 15:52:48 +0200 |
| commit | 421c709bbd706d4f04453baacf0ec6a88759f8cd (patch) | |
| tree | f92d0ec795c31e940648a652649006e336fec7a4 /src/model/guild/member.rs | |
| parent | Add a way for users to get Shards (diff) | |
| download | serenity-421c709bbd706d4f04453baacf0ec6a88759f8cd.tar.xz serenity-421c709bbd706d4f04453baacf0ec6a88759f8cd.zip | |
Update `Guild::ban` to use `BanOptions`
Also update `Member::permissions` to the default channel change
Diffstat (limited to 'src/model/guild/member.rs')
| -rw-r--r-- | src/model/guild/member.rs | 10 |
1 files changed, 9 insertions, 1 deletions
diff --git a/src/model/guild/member.rs b/src/model/guild/member.rs index f1a5114..d9ac230 100644 --- a/src/model/guild/member.rs +++ b/src/model/guild/member.rs @@ -274,8 +274,11 @@ impl Member { /// /// Returns a [`ModelError::GuildNotFound`] if the guild the member's in could not be /// found in the cache. + /// + /// And/or returns [`ModelError::ItemMissing`] if the "default channel" of the guild is not found. /// /// [`ModelError::GuildNotFound`]: enum.ModelError.html#variant.GuildNotFound + /// [`ModelError::ItemMissing`]: enum.ModelError.html#variant.ItemMissing #[cfg(feature = "cache")] pub fn permissions(&self) -> Result<Permissions> { let guild = match self.guild_id.find() { @@ -285,8 +288,13 @@ impl Member { let guild = guild.read().unwrap(); + let default_channel = match guild.default_channel() { + Some(dc) => dc, + None => return Err(From::from(ModelError::ItemMissing)), + }; + Ok(guild.permissions_for( - ChannelId(guild.id.0), + default_channel.id, self.user.read().unwrap().id, )) } |