Skip to content

Commit

Permalink
fix(http): update role icon and unicode_emoji using nullable strings (#…
Browse files Browse the repository at this point in the history
…2388)

According to [Discord
docs](https://discord.com/developers/docs/resources/guild#modify-guild-role),
`UpdateRoleFields::icon` is Image Data in [Data URI
scheme](https://en.wikipedia.org/wiki/Data_URI_scheme) format.
Basically, it must be a string. An example Data URI format is:

```
_ENCODED_JPEG_IMAGE_DATA
```

Additionally, people should be able to set `UpdateRoleFields::icon` and
`UpdateRoleFields::unicode_emoji` to null to remove the role icon (if
needed).

Briefly describe this pr, it makes `UpdateRoleFields::icon` and
`UpdateRoleFields::unicode_emoji` nullable strings.
  • Loading branch information
qpham031 authored Nov 25, 2024
1 parent 0a7fd21 commit c93fb5a
Showing 1 changed file with 67 additions and 6 deletions.
73 changes: 67 additions & 6 deletions twilight-http/src/request/guild/role/update_role.rs
Original file line number Diff line number Diff line change
Expand Up @@ -23,15 +23,15 @@ struct UpdateRoleFields<'a> {
#[serde(skip_serializing_if = "Option::is_none")]
hoist: Option<bool>,
#[serde(skip_serializing_if = "Option::is_none")]
icon: Option<&'a [u8]>,
icon: Option<Nullable<&'a str>>,
#[serde(skip_serializing_if = "Option::is_none")]
mentionable: Option<bool>,
#[serde(skip_serializing_if = "Option::is_none")]
name: Option<Nullable<&'a str>>,
#[serde(skip_serializing_if = "Option::is_none")]
permissions: Option<Permissions>,
#[serde(skip_serializing_if = "Option::is_none")]
unicode_emoji: Option<&'a str>,
unicode_emoji: Option<Nullable<&'a str>>,
}

/// Update a role by guild id and its id.
Expand Down Expand Up @@ -94,8 +94,38 @@ impl<'a> UpdateRole<'a> {
/// See [Discord Docs/Image Data].
///
/// [Discord Docs/Image Data]: https://discord.com/developers/docs/reference#image-data
pub const fn icon(mut self, icon: &'a [u8]) -> Self {
self.fields.icon = Some(icon);
///
/// # Editing
///
/// Pass [`None`] to clear the existing icon.
///
/// **Warning**: If the existing unicode emoji isn't cleared when setting the icon, it might
/// cause incorrect behavior.
///
/// # Examples
///
/// Sets a role icon. The unicode emoji should always be cleared to ensure the icon can be
/// set correctly.
///
/// ```no_run
/// # #[tokio::main] async fn main() -> Result<(), Box<dyn std::error::Error>> {
/// use twilight_http::Client;
/// use twilight_model::id::Id;
///
/// let client = Client::new("token".to_owned());
/// let guild_id = Id::new(1);
/// let role_id = Id::new(1);
/// let icon = "_ENCODED_PNG_IMAGE_DATA";
///
/// client
/// .update_role(guild_id, role_id)
/// .icon(Some(icon))
/// .unicode_emoji(None)
/// .await?;
/// # Ok(()) }
/// ```
pub const fn icon(mut self, icon: Option<&'a str>) -> Self {
self.fields.icon = Some(Nullable(icon));

self
}
Expand All @@ -122,8 +152,39 @@ impl<'a> UpdateRole<'a> {
}

/// Set the unicode emoji of a role.
pub const fn unicode_emoji(mut self, unicode_emoji: &'a str) -> Self {
self.fields.unicode_emoji = Some(unicode_emoji);
///
/// Only works if the guild has the `ROLE_ICONS` feature.
///
/// # Editing
///
/// Pass [`None`] to clear the existing unicode emoji.
///
/// **Warning**: If the existing icon isn't cleared when setting the unicode emoji, it might
/// cause incorrect behavior.
///
/// # Examples
///
/// Sets a role unicode emoji. The icon should always be cleared to ensure the unicode emoji
/// can be set correctly.
///
/// ```no_run
/// # #[tokio::main] async fn main() -> Result<(), Box<dyn std::error::Error>> {
/// use twilight_http::Client;
/// use twilight_model::id::Id;
///
/// let client = Client::new("token".to_owned());
/// let guild_id = Id::new(1);
/// let role_id = Id::new(1);
///
/// client
/// .update_role(guild_id, role_id)
/// .icon(None)
/// .unicode_emoji(Some("🦀"))
/// .await?;
/// # Ok(()) }
/// ```
pub const fn unicode_emoji(mut self, unicode_emoji: Option<&'a str>) -> Self {
self.fields.unicode_emoji = Some(Nullable(unicode_emoji));

self
}
Expand Down

0 comments on commit c93fb5a

Please sign in to comment.