25 releases
0.11.1 | Jul 23, 2024 |
---|---|
0.10.0 | Aug 20, 2023 |
0.9.4 | Jul 13, 2022 |
0.9.3 | Mar 7, 2022 |
0.1.0 | Feb 27, 2017 |
#212 in Network programming
205 downloads per month
Used in 14 crates
(4 directly)
76KB
1.5K
SLoC
jid
What's this?
A crate which provides a struct Jid for Jabber IDs. It's used in xmpp-rs but other XMPP libraries can of course use this.
What license is it under?
MPL-2.0 or later, see the LICENSE
file.
Notes
This library does not yet implement RFC7622.
lib.rs
:
Represents XMPP addresses, also known as JabberIDs (JIDs) for the XMPP
protocol. A [Jid
] can have between one and three parts in the form node@domain/resource
:
- the (optional) node part designates a specific account/service on a server, for example
username@server.com
- the domain part designates a server, for example
irc.jabberfr.org
- the (optional) resource part designates a more specific client, such as a participant in a
groupchat (
jabberfr@chat.jabberfr.org/user
) or a specific client device associated with an account (user@example.com/dino
)
The [Jid
] enum can be one of two variants, containing a more specific type:
BareJid
(Jid::Bare
variant): a JID without a resourceFullJid
(Jid::Full
variant): a JID with a resource
Jids as per the XMPP protocol only ever contain valid UTF-8. However, creating any form of Jid can fail in one of the following cases:
- wrong syntax: creating a Jid with an empty (yet declared) node or resource part, such as
@example.com
oruser@example.com/
- stringprep error: some characters were invalid according to the stringprep algorithm, such as mixing left-to-write and right-to-left characters
Dependencies
~1.6–2.1MB
~55K SLoC