twilight_http::request::guild::role

Struct UpdateRole

Source
pub struct UpdateRole<'a> { /* private fields */ }
Expand description

Update a role by guild id and its id.

Implementations§

Source§

impl<'a> UpdateRole<'a>

Source

pub const fn color(self, color: Option<u32>) -> Self

Set the role color.

This must be a valid hexadecimal RGB value. 0x000000 is ignored and doesn’t count towards the final computed color in the user list. Refer to COLOR_MAXIMUM for the maximum acceptable value.

Source

pub const fn hoist(self, hoist: bool) -> Self

If true, display the role in the members list.

Source

pub const fn icon(self, icon: Option<&'a str>) -> Self

Set the icon of the role.

Only works if the guild has the ROLE_ICONS feature.

See Discord Docs/Image Data.

§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.

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?;
Source

pub const fn mentionable(self, mentionable: bool) -> Self

If true, the role can be @mentioned (pinged) in chat.

Source

pub const fn name(self, name: Option<&'a str>) -> Self

Set the name of the role.

Source

pub const fn permissions(self, permissions: Permissions) -> Self

Set the allowed permissions of this role.

Source

pub const fn unicode_emoji(self, unicode_emoji: Option<&'a str>) -> Self

Set the unicode emoji of a role.

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.

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?;

Trait Implementations§

Source§

impl<'a> AuditLogReason<'a> for UpdateRole<'a>

Source§

fn reason(self, reason: &'a str) -> Self

Attach an audit log reason to the request. Read more
Source§

impl IntoFuture for UpdateRole<'_>

Source§

type Output = Result<Response<Role>, Error>

The output that the future will produce on completion.
Source§

type IntoFuture = ResponseFuture<Role>

Which kind of future are we turning this into?
Source§

fn into_future(self) -> Self::IntoFuture

Creates a future from a value. Read more
Source§

impl TryIntoRequest for UpdateRole<'_>

Source§

fn try_into_request(self) -> Result<Request, Error>

Try to convert a request builder into a raw Request. Read more

Auto Trait Implementations§

§

impl<'a> Freeze for UpdateRole<'a>

§

impl<'a> !RefUnwindSafe for UpdateRole<'a>

§

impl<'a> Send for UpdateRole<'a>

§

impl<'a> Sync for UpdateRole<'a>

§

impl<'a> Unpin for UpdateRole<'a>

§

impl<'a> !UnwindSafe for UpdateRole<'a>

Blanket Implementations§

Source§

impl<T> Any for T
where T: 'static + ?Sized,

Source§

fn type_id(&self) -> TypeId

Gets the TypeId of self. Read more
Source§

impl<T> Borrow<T> for T
where T: ?Sized,

Source§

fn borrow(&self) -> &T

Immutably borrows from an owned value. Read more
Source§

impl<T> BorrowMut<T> for T
where T: ?Sized,

Source§

fn borrow_mut(&mut self) -> &mut T

Mutably borrows from an owned value. Read more
Source§

impl<T> From<T> for T

Source§

fn from(t: T) -> T

Returns the argument unchanged.

§

impl<T> Instrument for T

§

fn instrument(self, span: Span) -> Instrumented<Self>

Instruments this type with the provided [Span], returning an Instrumented wrapper. Read more
§

fn in_current_span(self) -> Instrumented<Self>

Instruments this type with the current Span, returning an Instrumented wrapper. Read more
Source§

impl<T, U> Into<U> for T
where U: From<T>,

Source§

fn into(self) -> U

Calls U::from(self).

That is, this conversion is whatever the implementation of From<T> for U chooses to do.

Source§

impl<T, U> TryFrom<U> for T
where U: Into<T>,

Source§

type Error = Infallible

The type returned in the event of a conversion error.
Source§

fn try_from(value: U) -> Result<T, <T as TryFrom<U>>::Error>

Performs the conversion.
Source§

impl<T, U> TryInto<U> for T
where U: TryFrom<T>,

Source§

type Error = <U as TryFrom<T>>::Error

The type returned in the event of a conversion error.
Source§

fn try_into(self) -> Result<U, <U as TryFrom<T>>::Error>

Performs the conversion.
§

impl<V, T> VZip<V> for T
where V: MultiLane<T>,

§

fn vzip(self) -> V

§

impl<T> WithSubscriber for T

§

fn with_subscriber<S>(self, subscriber: S) -> WithDispatch<Self>
where S: Into<Dispatch>,

Attaches the provided Subscriber to this type, returning a [WithDispatch] wrapper. Read more
§

fn with_current_subscriber(self) -> WithDispatch<Self>

Attaches the current default Subscriber to this type, returning a [WithDispatch] wrapper. Read more
§

impl<T> ErasedDestructor for T
where T: 'static,

§

impl<T> MaybeSendSync for T