mirror of
https://github.com/teloxide/teloxide.git
synced 2025-01-03 09:49:07 +01:00
Merge pull request #800 from Veetaha/feat/chat-member-overhaul
Overhaul `teloxide_core::types::chat_member` module
This commit is contained in:
commit
c5cb33c242
2 changed files with 104 additions and 22 deletions
|
@ -14,6 +14,11 @@ and this project adheres to [Semantic Versioning](https://semver.org/spec/v2.0.0
|
|||
- The following functions were made `#[must_use]`:
|
||||
- `MaskPoint::{new, point}`
|
||||
- `StickerKind::{premium_animation, mask_position, custom_emoji_id}`
|
||||
- `Option<bool>` fields of `Administrator` are now `bool` ([#800][pr800]):
|
||||
- `can_post_messages`
|
||||
- `can_edit_messages`
|
||||
- `can_pin_messages`
|
||||
- `can_manage_topics`
|
||||
|
||||
### Added
|
||||
|
||||
|
@ -21,6 +26,24 @@ and this project adheres to [Semantic Versioning](https://semver.org/spec/v2.0.0
|
|||
- `ChatMember::can_send_polls` method ([#764][pr764])
|
||||
|
||||
[pr764]: https://github.com/teloxide/teloxide/pull/764
|
||||
[pr800]: https://github.com/teloxide/teloxide/pull/800
|
||||
|
||||
### Deprecated
|
||||
|
||||
- `ChatMemberKind` methods ([#800][pr800]):
|
||||
- `can_change_info`
|
||||
- `can_invite_users`
|
||||
- `can_pin_messages`
|
||||
- `can_send_messages`
|
||||
- `can_send_media_messages`
|
||||
- `can_send_other_messages`
|
||||
- `can_send_polls`
|
||||
- `can_add_web_page_previews`
|
||||
- `ChatMemberStatus::is_present` method ([#800][pr800])
|
||||
|
||||
### Fixed
|
||||
|
||||
- `ChatMemberKind::can_manage_chat` method now correctly returns `false` for non owner/administrator users ([#800][pr800])
|
||||
|
||||
## 0.8.0 - 2022-10-03
|
||||
|
||||
|
|
|
@ -66,11 +66,13 @@ pub struct Administrator {
|
|||
pub can_change_info: bool,
|
||||
|
||||
/// `true` if the administrator can post in the channel, channels only.
|
||||
pub can_post_messages: Option<bool>,
|
||||
#[serde(default)]
|
||||
pub can_post_messages: bool,
|
||||
|
||||
/// `true` if the administrator can edit messages of other users and can pin
|
||||
/// messages, channels only.
|
||||
pub can_edit_messages: Option<bool>,
|
||||
#[serde(default)]
|
||||
pub can_edit_messages: bool,
|
||||
|
||||
/// `true` if the administrator can delete messages of other users.
|
||||
pub can_delete_messages: bool,
|
||||
|
@ -85,11 +87,13 @@ pub struct Administrator {
|
|||
pub can_restrict_members: bool,
|
||||
|
||||
/// `true` if the administrator can pin messages, supergroups only.
|
||||
pub can_pin_messages: Option<bool>,
|
||||
#[serde(default)]
|
||||
pub can_pin_messages: bool,
|
||||
|
||||
/// `true`, if the user is allowed to create, rename, close, and reopen
|
||||
/// forum topics; supergroups only
|
||||
pub can_manage_topics: Option<bool>,
|
||||
#[serde(default)]
|
||||
pub can_manage_topics: bool,
|
||||
|
||||
/// `true` if the administrator can add new administrators with a subset of
|
||||
/// his own privileges or demote administrators that he has promoted,
|
||||
|
@ -206,7 +210,12 @@ impl ChatMemberKind {
|
|||
|
||||
/// Returns `true` if the user is a common [member] of the given chat.
|
||||
///
|
||||
/// ⚠️ Don't confuse this with [`is_present`]. This method merely checks
|
||||
/// for [`ChatMemberKind::Member`] variant which is not enough to determine
|
||||
/// if the user is joinned to the chat. Use [`is_present`] for that instead.
|
||||
///
|
||||
/// [member]: ChatMemberKind::Member
|
||||
/// [`is_present`]: ChatMemberKind::is_present
|
||||
#[must_use]
|
||||
pub fn is_member(&self) -> bool {
|
||||
matches!(self, Self::Member { .. })
|
||||
|
@ -222,7 +231,12 @@ impl ChatMemberKind {
|
|||
|
||||
/// Returns `true` if the user [left] the given chat.
|
||||
///
|
||||
/// ⚠️ Don't confuse this with [`is_present`]. This method merely checks
|
||||
/// for [`ChatMemberKind::Left`] variant which is not enough to determine
|
||||
/// if the user is joinned to the chat. Use [`is_present`] for that instead.
|
||||
///
|
||||
/// [left]: ChatMemberKind::Left
|
||||
/// [`is_present`]: ChatMemberKind::is_present
|
||||
#[must_use]
|
||||
pub fn is_left(&self) -> bool {
|
||||
matches!(self, Self::Left { .. })
|
||||
|
@ -354,7 +368,7 @@ impl ChatMemberKind {
|
|||
match self {
|
||||
Self::Owner(_) => true,
|
||||
Self::Administrator(Administrator { can_manage_chat, .. }) => *can_manage_chat,
|
||||
Self::Member | Self::Restricted(_) | Self::Left | Self::Banned(_) => true,
|
||||
Self::Member | Self::Restricted(_) | Self::Left | Self::Banned(_) => false,
|
||||
}
|
||||
}
|
||||
|
||||
|
@ -367,6 +381,10 @@ impl ChatMemberKind {
|
|||
/// [`Administrator::can_change_info`] privilege.
|
||||
/// - is restricted, but does have [`Restricted::can_change_info`] privilege
|
||||
/// Returns `false` otherwise.
|
||||
#[deprecated(
|
||||
since = "0.9.0",
|
||||
note = "Match manually and use `can_change_info` field directly. Details: https://github.com/teloxide/teloxide/issues/781"
|
||||
)]
|
||||
#[must_use]
|
||||
pub fn can_change_info(&self) -> bool {
|
||||
match self {
|
||||
|
@ -390,9 +408,7 @@ impl ChatMemberKind {
|
|||
pub fn can_post_messages(&self) -> bool {
|
||||
match self {
|
||||
Self::Owner(_) => true,
|
||||
Self::Administrator(Administrator { can_post_messages, .. }) => {
|
||||
can_post_messages.unwrap_or_default()
|
||||
}
|
||||
Self::Administrator(Administrator { can_post_messages, .. }) => *can_post_messages,
|
||||
Self::Member | Self::Restricted(_) | Self::Left | Self::Banned(_) => false,
|
||||
}
|
||||
}
|
||||
|
@ -411,9 +427,7 @@ impl ChatMemberKind {
|
|||
pub fn can_edit_messages(&self) -> bool {
|
||||
match self {
|
||||
Self::Owner(_) => true,
|
||||
Self::Administrator(Administrator { can_edit_messages, .. }) => {
|
||||
can_edit_messages.unwrap_or_default()
|
||||
}
|
||||
Self::Administrator(Administrator { can_edit_messages, .. }) => *can_edit_messages,
|
||||
Self::Member | Self::Restricted(_) | Self::Left | Self::Banned(_) => false,
|
||||
}
|
||||
}
|
||||
|
@ -471,6 +485,10 @@ impl ChatMemberKind {
|
|||
/// - is restricted, but does have [`Restricted::can_invite_users`]
|
||||
/// privilege
|
||||
/// Returns `false` otherwise.
|
||||
#[deprecated(
|
||||
since = "0.9.0",
|
||||
note = "Match manually and use `can_invite_users` field directly. Details: https://github.com/teloxide/teloxide/issues/781"
|
||||
)]
|
||||
#[must_use]
|
||||
pub fn can_invite_users(&self) -> bool {
|
||||
match &self {
|
||||
|
@ -510,14 +528,16 @@ impl ChatMemberKind {
|
|||
/// - is restricted, but does have [`Restricted::can_pin_messages`]
|
||||
/// privilege
|
||||
/// Returns `false` otherwise.
|
||||
#[deprecated(
|
||||
since = "0.9.0",
|
||||
note = "Match manually and use `can_pin_messages` field directly. Details: https://github.com/teloxide/teloxide/issues/781"
|
||||
)]
|
||||
#[must_use]
|
||||
pub fn can_pin_messages(&self) -> bool {
|
||||
match self {
|
||||
Self::Owner(_) => true,
|
||||
Self::Administrator(Administrator { can_pin_messages, .. }) => {
|
||||
can_pin_messages.unwrap_or_default()
|
||||
}
|
||||
Self::Restricted(Restricted { can_pin_messages, .. }) => *can_pin_messages,
|
||||
Self::Administrator(Administrator { can_pin_messages, .. })
|
||||
| Self::Restricted(Restricted { can_pin_messages, .. }) => *can_pin_messages,
|
||||
Self::Member | Self::Left | Self::Banned(_) => false,
|
||||
}
|
||||
}
|
||||
|
@ -531,14 +551,18 @@ impl ChatMemberKind {
|
|||
/// - is restricted, but does have [`Restricted::can_manage_topics`]
|
||||
/// privilege
|
||||
/// Returns `false` otherwise.
|
||||
#[deprecated(
|
||||
since = "0.9.0",
|
||||
note = "Match manually and use `can_manage_topics` field directly. Details: https://github.com/teloxide/teloxide/issues/781"
|
||||
)]
|
||||
#[must_use]
|
||||
pub fn can_manage_topics(&self) -> bool {
|
||||
match self {
|
||||
ChatMemberKind::Owner(_) => true,
|
||||
ChatMemberKind::Administrator(Administrator { can_manage_topics, .. }) => {
|
||||
can_manage_topics.unwrap_or_default()
|
||||
ChatMemberKind::Administrator(Administrator { can_manage_topics, .. })
|
||||
| ChatMemberKind::Restricted(Restricted { can_manage_topics, .. }) => {
|
||||
*can_manage_topics
|
||||
}
|
||||
ChatMemberKind::Restricted(Restricted { can_manage_topics, .. }) => *can_manage_topics,
|
||||
ChatMemberKind::Member | ChatMemberKind::Left | ChatMemberKind::Banned(_) => false,
|
||||
}
|
||||
}
|
||||
|
@ -576,6 +600,10 @@ impl ChatMemberKind {
|
|||
/// Returns `true` otherwise.
|
||||
///
|
||||
/// [`can_send_messages`]: Restricted::can_send_messages
|
||||
#[deprecated(
|
||||
since = "0.9.0",
|
||||
note = "Match manually and use `can_send_messages` field directly. Details: https://github.com/teloxide/teloxide/issues/781"
|
||||
)]
|
||||
#[must_use]
|
||||
pub fn can_send_messages(&self) -> bool {
|
||||
match &self {
|
||||
|
@ -594,6 +622,10 @@ impl ChatMemberKind {
|
|||
/// Returns `true` otherwise.
|
||||
///
|
||||
/// [`can_send_media_messages`]: Restricted::can_send_media_messages
|
||||
#[deprecated(
|
||||
since = "0.9.0",
|
||||
note = "Match manually and use `can_send_media_messages` field directly. Details: https://github.com/teloxide/teloxide/issues/781"
|
||||
)]
|
||||
#[must_use]
|
||||
pub fn can_send_media_messages(&self) -> bool {
|
||||
match &self {
|
||||
|
@ -614,6 +646,10 @@ impl ChatMemberKind {
|
|||
/// Returns `true` otherwise.
|
||||
///
|
||||
/// [`can_send_media_messages`]: Restricted::can_send_media_messages
|
||||
#[deprecated(
|
||||
since = "0.9.0",
|
||||
note = "Match manually and use `can_send_other_messages` field directly. Details: https://github.com/teloxide/teloxide/issues/781"
|
||||
)]
|
||||
#[must_use]
|
||||
pub fn can_send_other_messages(&self) -> bool {
|
||||
match &self {
|
||||
|
@ -634,6 +670,10 @@ impl ChatMemberKind {
|
|||
/// Returns `true` otherwise.
|
||||
///
|
||||
/// [`can_send_media_messages`]: Restricted::can_send_media_messages
|
||||
#[deprecated(
|
||||
since = "0.9.0",
|
||||
note = "Match manually and use `can_add_web_page_previews` field directly. Details: https://github.com/teloxide/teloxide/issues/781"
|
||||
)]
|
||||
#[must_use]
|
||||
pub fn can_add_web_page_previews(&self) -> bool {
|
||||
match &self {
|
||||
|
@ -653,6 +693,10 @@ impl ChatMemberKind {
|
|||
/// Returns `true` otherwise.
|
||||
///
|
||||
/// [`can_send_polls`]: Restricted::can_send_polls
|
||||
#[deprecated(
|
||||
since = "0.9.0",
|
||||
note = "Match manually and use `can_send_polls` field directly. Details: https://github.com/teloxide/teloxide/issues/781"
|
||||
)]
|
||||
#[must_use]
|
||||
pub fn can_send_polls(&self) -> bool {
|
||||
match &self {
|
||||
|
@ -701,7 +745,13 @@ impl ChatMemberStatus {
|
|||
|
||||
/// Returns `true` if the user is a common [member] of the given chat.
|
||||
///
|
||||
/// ⚠️ Don't confuse this with [`is_present`]. This method merely checks
|
||||
/// for [`ChatMemberStatus::Member`] variant which is not enough to
|
||||
/// determine if the user is joinned to the chat. Use [`is_present`] for
|
||||
/// that instead.
|
||||
///
|
||||
/// [member]: ChatMemberKind::Member
|
||||
/// [`is_present`]: ChatMemberKind::is_present
|
||||
#[must_use]
|
||||
pub fn is_member(&self) -> bool {
|
||||
matches!(self, Self::Member { .. })
|
||||
|
@ -717,7 +767,12 @@ impl ChatMemberStatus {
|
|||
|
||||
/// Returns `true` if the user [left] the given chat.
|
||||
///
|
||||
/// ⚠️ Don't confuse this with [`is_present`]. This method merely checks
|
||||
/// for [`ChatMemberStatus::Left`] variant which is not enough to determine
|
||||
/// if the user is joinned to the chat. Use [`is_present`] for that instead.
|
||||
///
|
||||
/// [left]: ChatMemberKind::Left
|
||||
/// [`is_present`]: ChatMemberKind::is_present
|
||||
#[must_use]
|
||||
pub fn is_left(&self) -> bool {
|
||||
matches!(self, Self::Left { .. })
|
||||
|
@ -750,6 +805,10 @@ impl ChatMemberStatus {
|
|||
/// [left]: ChatMemberKind::Left
|
||||
/// [banned]: ChatMemberKind::Banned
|
||||
#[must_use]
|
||||
#[deprecated(
|
||||
since = "0.9.0",
|
||||
note = "Use `ChatMemberKind::is_present` method instead. Details: https://github.com/teloxide/teloxide/issues/781"
|
||||
)]
|
||||
pub fn is_present(&self) -> bool {
|
||||
!(self.is_left() || self.is_banned())
|
||||
}
|
||||
|
@ -801,15 +860,15 @@ mod tests {
|
|||
can_be_edited: false,
|
||||
can_manage_chat: true,
|
||||
can_change_info: true,
|
||||
can_post_messages: None,
|
||||
can_edit_messages: None,
|
||||
can_post_messages: false,
|
||||
can_edit_messages: false,
|
||||
can_delete_messages: true,
|
||||
can_manage_video_chats: true,
|
||||
can_invite_users: true,
|
||||
can_restrict_members: true,
|
||||
can_pin_messages: Some(true),
|
||||
can_pin_messages: true,
|
||||
can_promote_members: true,
|
||||
can_manage_topics: None,
|
||||
can_manage_topics: false,
|
||||
}),
|
||||
};
|
||||
let actual = serde_json::from_str::<ChatMember>(json).unwrap();
|
||||
|
|
Loading…
Reference in a new issue