2023-06-19 21:54:08 +00:00
|
|
|
|
// Copyright (c) 2017, 2018 lumi <lumi@pew.im>
|
|
|
|
|
// Copyright (c) 2017, 2018, 2019 Emmanuel Gil Peyrot <linkmauve@linkmauve.fr>
|
|
|
|
|
// Copyright (c) 2017, 2018, 2019 Maxime “pep” Buquet <pep@bouah.net>
|
|
|
|
|
// Copyright (c) 2017, 2018 Astro <astro@spaceboyz.net>
|
|
|
|
|
// Copyright (c) 2017 Bastien Orivel <eijebong@bananium.fr>
|
|
|
|
|
//
|
|
|
|
|
// This Source Code Form is subject to the terms of the Mozilla Public
|
|
|
|
|
// License, v. 2.0. If a copy of the MPL was not distributed with this
|
|
|
|
|
// file, You can obtain one at http://mozilla.org/MPL/2.0/.
|
|
|
|
|
|
|
|
|
|
use std::error::Error as StdError;
|
|
|
|
|
use std::fmt;
|
|
|
|
|
|
|
|
|
|
/// An error that signifies that a `Jid` cannot be parsed from a string.
|
2023-06-20 10:49:20 +00:00
|
|
|
|
#[derive(Debug, PartialEq, Eq)]
|
2023-06-20 10:51:37 +00:00
|
|
|
|
pub enum Error {
|
2023-06-20 15:58:16 +00:00
|
|
|
|
/// Happens when the node is empty, that is the string starts with a @.
|
|
|
|
|
NodeEmpty,
|
|
|
|
|
|
2023-06-19 21:54:08 +00:00
|
|
|
|
/// Happens when there is no domain, that is either the string is empty,
|
|
|
|
|
/// starts with a /, or contains the @/ sequence.
|
2023-06-20 15:58:16 +00:00
|
|
|
|
DomainEmpty,
|
2023-06-19 21:54:08 +00:00
|
|
|
|
|
|
|
|
|
/// Happens when the resource is empty, that is the string ends with a /.
|
2023-06-20 15:58:16 +00:00
|
|
|
|
ResourceEmpty,
|
2023-06-19 21:54:08 +00:00
|
|
|
|
|
2023-06-20 10:49:20 +00:00
|
|
|
|
/// Happens when the localpart is longer than 1023 bytes.
|
|
|
|
|
NodeTooLong,
|
2023-06-19 21:54:08 +00:00
|
|
|
|
|
2023-06-20 10:49:20 +00:00
|
|
|
|
/// Happens when the domain is longer than 1023 bytes.
|
|
|
|
|
DomainTooLong,
|
2023-06-19 21:54:08 +00:00
|
|
|
|
|
2023-06-20 10:49:20 +00:00
|
|
|
|
/// Happens when the resource is longer than 1023 bytes.
|
|
|
|
|
ResourceTooLong,
|
2023-06-19 21:54:08 +00:00
|
|
|
|
|
2023-06-20 10:49:20 +00:00
|
|
|
|
/// Happens when the localpart is invalid according to nodeprep.
|
|
|
|
|
NodePrep,
|
|
|
|
|
|
|
|
|
|
/// Happens when the domain is invalid according to nameprep.
|
|
|
|
|
NamePrep,
|
|
|
|
|
|
|
|
|
|
/// Happens when the resource is invalid according to resourceprep.
|
|
|
|
|
ResourcePrep,
|
|
|
|
|
|
2023-06-20 15:58:16 +00:00
|
|
|
|
/// Happens when there is no resource, that is string contains no /.
|
|
|
|
|
ResourceMissingInFullJid,
|
|
|
|
|
|
2023-06-20 10:49:20 +00:00
|
|
|
|
/// Happens when parsing a bare JID and there is a resource.
|
|
|
|
|
ResourceInBareJid,
|
|
|
|
|
}
|
2023-06-19 21:54:08 +00:00
|
|
|
|
|
2023-06-20 10:51:37 +00:00
|
|
|
|
impl StdError for Error {}
|
2023-06-19 21:54:08 +00:00
|
|
|
|
|
2023-06-20 10:51:37 +00:00
|
|
|
|
impl fmt::Display for Error {
|
2023-06-19 21:54:08 +00:00
|
|
|
|
fn fmt(&self, fmt: &mut fmt::Formatter) -> fmt::Result {
|
2023-06-20 10:49:20 +00:00
|
|
|
|
fmt.write_str(match self {
|
2023-06-20 15:58:16 +00:00
|
|
|
|
Error::NodeEmpty => "nodepart empty despite the presence of a @",
|
|
|
|
|
Error::DomainEmpty => "no domain found in this JID",
|
|
|
|
|
Error::ResourceEmpty => "resource empty despite the presence of a /",
|
2023-06-20 10:51:37 +00:00
|
|
|
|
Error::NodeTooLong => "localpart longer than 1023 bytes",
|
|
|
|
|
Error::DomainTooLong => "domain longer than 1023 bytes",
|
|
|
|
|
Error::ResourceTooLong => "resource longer than 1023 bytes",
|
|
|
|
|
Error::NodePrep => "localpart doesn’t pass nodeprep validation",
|
|
|
|
|
Error::NamePrep => "domain doesn’t pass nameprep validation",
|
|
|
|
|
Error::ResourcePrep => "resource doesn’t pass resourceprep validation",
|
2023-06-20 15:58:16 +00:00
|
|
|
|
Error::ResourceMissingInFullJid => "no resource found in this full JID",
|
2023-06-20 10:51:37 +00:00
|
|
|
|
Error::ResourceInBareJid => "resource found while parsing a bare JID",
|
2023-06-20 10:49:20 +00:00
|
|
|
|
})
|
2023-06-19 21:54:08 +00:00
|
|
|
|
}
|
|
|
|
|
}
|