From 0c27128d0601ea363de28d071e9ab754dc3af264 Mon Sep 17 00:00:00 2001 From: Michael Krasnitski <42564254+mkrasnitski@users.noreply.github.com> Date: Fri, 23 Aug 2024 09:18:28 -0700 Subject: [PATCH] Fix and make `edit_role_position` plural (#2954) --- src/builder/edit_role.rs | 4 +++- src/http/client.rs | 4 ++-- src/model/guild/guild_id.rs | 34 +++++++++++++++++++++----------- src/model/guild/mod.rs | 26 ++++++++++++++++++------ src/model/guild/partial_guild.rs | 26 ++++++++++++++++++------ 5 files changed, 68 insertions(+), 26 deletions(-) diff --git a/src/builder/edit_role.rs b/src/builder/edit_role.rs index bbd8845026a..84e4be4ea0f 100644 --- a/src/builder/edit_role.rs +++ b/src/builder/edit_role.rs @@ -172,7 +172,9 @@ impl<'a> EditRole<'a> { }; if let Some(position) = self.position { - guild_id.edit_role_position(http, role.id, position, self.audit_log_reason).await?; + guild_id + .edit_role_positions(http, [(role.id, position)], self.audit_log_reason) + .await?; } Ok(role) } diff --git a/src/http/client.rs b/src/http/client.rs index 248b9b11fd1..29fb4bce9ff 100644 --- a/src/http/client.rs +++ b/src/http/client.rs @@ -2006,8 +2006,8 @@ impl Http { from_value(value).map_err(From::from) } - /// Changes the position of a role in a guild. - pub async fn edit_role_position( + /// Changes the positions of roles in a guild. + pub async fn edit_role_positions( &self, guild_id: GuildId, map: &impl serde::Serialize, diff --git a/src/model/guild/guild_id.rs b/src/model/guild/guild_id.rs index ead66460fc8..01023737150 100644 --- a/src/model/guild/guild_id.rs +++ b/src/model/guild/guild_id.rs @@ -794,15 +794,28 @@ impl GuildId { builder.execute(http, self, sticker_id).await } - /// Edit the position of a [`Role`] relative to all others in the [`Guild`]. + /// Edits the position of [`Role`]s relative to all others in the [`Guild`]. /// /// **Note**: Requires the [Manage Roles] permission. /// /// # Examples /// - /// ```rust,ignore - /// use serenity::model::{GuildId, RoleId}; - /// GuildId::new(7).edit_role_position(&context, RoleId::new(8), 2); + /// ```rust,no_run + /// # use std::collections::HashMap; + /// # use serenity::http::Http; + /// use serenity::model::id::{GuildId, RoleId}; + /// + /// # async fn run() -> Result<(), Box> { + /// # let http: Http = unimplemented!(); + /// let roles = HashMap::from([ + /// (RoleId::new(8), 2), + /// (RoleId::new(10), 3), + /// (RoleId::new(11), 4), + /// (RoleId::new(25), 7), + /// ]); + /// GuildId::new(7).edit_role_positions(&http, roles, None); + /// # Ok(()) + /// # } /// ``` /// /// # Errors @@ -810,11 +823,10 @@ impl GuildId { /// Returns an [`Error::Http`] if the current user lacks permission. /// /// [Manage Roles]: Permissions::MANAGE_ROLES - pub async fn edit_role_position( + pub async fn edit_role_positions( self, http: &Http, - role_id: RoleId, - position: i16, + roles: impl IntoIterator, reason: Option<&str>, ) -> Result> { #[derive(serde::Serialize)] @@ -827,12 +839,12 @@ impl GuildId { Maximum::AuditLogReason.check_overflow(reason.len())?; } - let map = EditRole { - id: role_id, + let iter = roles.into_iter().map(|(id, position)| EditRole { + id, position, - }; + }); - http.edit_role_position(self, &map, reason).await + http.edit_role_positions(self, &SerializeIter::new(iter), reason).await } /// Edits the guild's welcome screen. diff --git a/src/model/guild/mod.rs b/src/model/guild/mod.rs index 26c9d3e2dc8..e0166f0e71c 100644 --- a/src/model/guild/mod.rs +++ b/src/model/guild/mod.rs @@ -1090,9 +1090,24 @@ impl Guild { /// /// Change the order of a role: /// - /// ```rust,ignore + /// ```rust,no_run + /// # use std::collections::HashMap; + /// # use serenity::http::Http; + /// # use serenity::model::guild::Guild; /// use serenity::model::id::RoleId; - /// guild.edit_role_position(&context, RoleId::new(8), 2); + /// + /// # async fn run() -> Result<(), Box> { + /// # let http: Http = unimplemented!(); + /// # let guild: Guild = unimplemented!(); + /// let roles = HashMap::from([ + /// (RoleId::new(8), 2), + /// (RoleId::new(10), 3), + /// (RoleId::new(11), 4), + /// (RoleId::new(25), 7), + /// ]); + /// guild.edit_role_positions(&http, roles, None); + /// # Ok(()) + /// # } /// ``` /// /// # Errors @@ -1100,14 +1115,13 @@ impl Guild { /// Returns [`Error::Http`] if the current user lacks permission. /// /// [Manage Roles]: Permissions::MANAGE_ROLES - pub async fn edit_role_position( + pub async fn edit_role_positions( &self, http: &Http, - role_id: RoleId, - position: i16, + roles: impl IntoIterator, audit_log_reason: Option<&str>, ) -> Result> { - self.id.edit_role_position(http, role_id, position, audit_log_reason).await + self.id.edit_role_positions(http, roles, audit_log_reason).await } /// Modifies a scheduled event in the guild with the data set, if any. diff --git a/src/model/guild/partial_guild.rs b/src/model/guild/partial_guild.rs index 937a0943c58..462bf4f979a 100644 --- a/src/model/guild/partial_guild.rs +++ b/src/model/guild/partial_guild.rs @@ -815,9 +815,24 @@ impl PartialGuild { /// /// Change the order of a role: /// - /// ```rust,ignore + /// ```rust,no_run + /// # use std::collections::HashMap; + /// # use serenity::http::Http; + /// # use serenity::model::guild::PartialGuild; /// use serenity::model::id::RoleId; - /// partial_guild.edit_role_position(&context, RoleId::new(8), 2); + /// + /// # async fn run() -> Result<(), Box> { + /// # let http: Http = unimplemented!(); + /// # let partial_guild: PartialGuild = unimplemented!(); + /// let roles = HashMap::from([ + /// (RoleId::new(8), 2), + /// (RoleId::new(10), 3), + /// (RoleId::new(11), 4), + /// (RoleId::new(25), 7), + /// ]); + /// partial_guild.edit_role_positions(&http, roles, None); + /// # Ok(()) + /// # } /// ``` /// /// # Errors @@ -825,14 +840,13 @@ impl PartialGuild { /// Returns [`Error::Http`] if the current user lacks permission. /// /// [Manage Roles]: Permissions::MANAGE_ROLES - pub async fn edit_role_position( + pub async fn edit_role_positions( &self, http: &Http, - role_id: RoleId, - position: i16, + roles: impl IntoIterator, audit_log_reason: Option<&str>, ) -> Result> { - self.id.edit_role_position(http, role_id, position, audit_log_reason).await + self.id.edit_role_positions(http, roles, audit_log_reason).await } /// Edits a sticker.