xmpp::event

Enum Event

Source
pub enum Event {
Show 17 variants Online, Disconnected(Error), ContactAdded(Item), ContactRemoved(Item), ContactChanged(Item), AvatarRetrieved(Jid, String), ChatMessage(Id, BareJid, Body, StanzaTimeInfo), JoinRoom(BareJid, Conference), LeaveRoom(BareJid), LeaveAllRooms, RoomJoined(BareJid), RoomLeft(BareJid), RoomMessage(Id, BareJid, RoomNick, Body, StanzaTimeInfo), RoomSubject(BareJid, Option<RoomNick>, String, StanzaTimeInfo), RoomPrivateMessage(Id, BareJid, RoomNick, Body, StanzaTimeInfo), ServiceMessage(Id, BareJid, Body, StanzaTimeInfo), HttpUploadedFile(String),
}
Expand description

An Event the client should react to.

This can be an XMPP event received from the server, or existing state communicated by the server to the client, like when receiving the contact list.

Variants§

§

Online

The client has connected to the server.

§

Disconnected(Error)

The client has been disconnected from the server. Unless reconnect is enabled, no more event will be received.

§

ContactAdded(Item)

A contact is received from the server, because it was added recently to the contact list (roster), or because the client went online and is receiving the existing roster.

§

ContactRemoved(Item)

A contact has been removed from the roster on the server.

§

ContactChanged(Item)

A contact changed in the roster.

This can happen because (non-exhaustive):

  • the contact’s nickname changed
  • the contact’s subscription status changed (eg. they accepted a friend request)
  • the contact has been added to or removed from a contact group
§

AvatarRetrieved(Jid, String)

Available on crate feature avatars only.

An avatar for a certain JID was retrieved from the server.

The associated String is a local filesystem path where the crate has saved the avatar data. For now, it’s not possible to configure where the avatars are stored, see issue !112 for more information.

§

ChatMessage(Id, BareJid, Body, StanzaTimeInfo)

A chat message was received. It may have been delayed on the network.

  • The Id is a unique identifier for this message.
  • The BareJid is the sender’s JID.
  • The Body is the message body.
  • The StanzaTimeInfo about when message was received, and when the message was claimed sent.
§

JoinRoom(BareJid, Conference)

A room with the given Jid was retrieved from the bookmarks, and has been marked for auto-join. The client should join it.

§

LeaveRoom(BareJid)

TODO

§

LeaveAllRooms

TODO: WHY?

§

RoomJoined(BareJid)

An event signaling that a room was joined; after this the client should receive messages from the room and may send messages to it.

§

RoomLeft(BareJid)

An event signaling that a room was left; after this the client should not receive messages from the room and should not send messages to it.

§

RoomMessage(Id, BareJid, RoomNick, Body, StanzaTimeInfo)

A message was received from a room, containing the room JID, the sender’s nickname, the message body, and the message timing information.

§

RoomSubject(BareJid, Option<RoomNick>, String, StanzaTimeInfo)

The subject of a room was received.

  • The BareJid is the room’s address.
  • The RoomNick is the nickname of the room member who set the subject.
  • The String is the new subject.
§

RoomPrivateMessage(Id, BareJid, RoomNick, Body, StanzaTimeInfo)

A private message received from a room member, containing the message ID, the room’s BareJid, the sender’s nickname in the room, the message body, and the message timing information.

§

ServiceMessage(Id, BareJid, Body, StanzaTimeInfo)

A service message was received.

§

HttpUploadedFile(String)

A file has been uploaded over HTTP; contains the URL of the file.

Trait Implementations§

Source§

impl Debug for Event

Source§

fn fmt(&self, f: &mut Formatter<'_>) -> Result

Formats the value using the given formatter. Read more

Auto Trait Implementations§

§

impl Freeze for Event

§

impl !RefUnwindSafe for Event

§

impl Send for Event

§

impl Sync for Event

§

impl Unpin for Event

§

impl !UnwindSafe for Event

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.

Source§

impl<T> Instrument for T

Source§

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

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

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> Same for T

Source§

type Output = T

Should always be Self
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.
Source§

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

Source§

fn vzip(self) -> V

Source§

impl<T> WithSubscriber for T

Source§

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

fn with_current_subscriber(self) -> WithDispatch<Self>

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

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

Source§

impl<T> MaybeSendSync for T