forked from GNUsocial/gnu-social
[Xmpp] Use UnexpectedValueException in splitJid, a bit narrower
This commit is contained in:
parent
5bc1b8695e
commit
b312712d1b
@ -93,8 +93,9 @@ class XmppPlugin extends ImPlugin
|
|||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
return ($parts['resource'] === null); // missing; empty ain't kosher
|
// missing; empty isn't kosher
|
||||||
} catch (Exception $e) {
|
return is_null($parts['resource']);
|
||||||
|
} catch (UnexpectedValueException $e) {
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@ -106,7 +107,7 @@ class XmppPlugin extends ImPlugin
|
|||||||
* @param string $jid string to check
|
* @param string $jid string to check
|
||||||
*
|
*
|
||||||
* @return array with "node", "domain", and "resource" indices
|
* @return array with "node", "domain", and "resource" indices
|
||||||
* @throws Exception if input is not valid
|
* @throws UnexpectedValueException if input is not valid
|
||||||
* @license Licensed under ISC-L, which is compatible with everything else that keeps the copyright notice intact.
|
* @license Licensed under ISC-L, which is compatible with everything else that keeps the copyright notice intact.
|
||||||
*
|
*
|
||||||
* @copyright 2009 Patrick Georgi <patrick@georgi-clan.de>
|
* @copyright 2009 Patrick Georgi <patrick@georgi-clan.de>
|
||||||
@ -157,7 +158,7 @@ class XmppPlugin extends ImPlugin
|
|||||||
$node = explode("@", $parts[0]);
|
$node = explode("@", $parts[0]);
|
||||||
if ((count($node) > 2) || (count($node) == 0)) {
|
if ((count($node) > 2) || (count($node) == 0)) {
|
||||||
// TRANS: Exception thrown when using too many @ signs in a Jabber ID.
|
// TRANS: Exception thrown when using too many @ signs in a Jabber ID.
|
||||||
throw new Exception(_m('Invalid JID: too many @s.'));
|
throw new UnexpectedValueException(_m('Invalid JID: too many @s.'));
|
||||||
} elseif (count($node) == 1) {
|
} elseif (count($node) == 1) {
|
||||||
$domain = $node[0];
|
$domain = $node[0];
|
||||||
$node = null;
|
$node = null;
|
||||||
@ -166,7 +167,7 @@ class XmppPlugin extends ImPlugin
|
|||||||
$node = $node[0];
|
$node = $node[0];
|
||||||
if ($node == '') {
|
if ($node == '') {
|
||||||
// TRANS: Exception thrown when using @ sign not followed by a Jabber ID.
|
// TRANS: Exception thrown when using @ sign not followed by a Jabber ID.
|
||||||
throw new Exception(_m('Invalid JID: @ but no node'));
|
throw new UnexpectedValueException(_m('Invalid JID: @ but no node'));
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -174,35 +175,35 @@ class XmppPlugin extends ImPlugin
|
|||||||
// Length limits per http://xmpp.org/rfcs/rfc3920.html#addressing
|
// Length limits per http://xmpp.org/rfcs/rfc3920.html#addressing
|
||||||
if (strlen($node) > 1023) {
|
if (strlen($node) > 1023) {
|
||||||
// TRANS: Exception thrown when using too long a Jabber ID (>1023).
|
// TRANS: Exception thrown when using too long a Jabber ID (>1023).
|
||||||
throw new Exception(_m('Invalid JID: node too long.'));
|
throw new UnexpectedValueException(_m('Invalid JID: node too long.'));
|
||||||
}
|
}
|
||||||
// C5 - Surrogate codes is ensured by encoding check
|
// C5 - Surrogate codes is ensured by encoding check
|
||||||
if (preg_match("/[" . $nodeprepchars . "]/u", $node) || mb_detect_encoding($node, 'UTF-8', true) != 'UTF-8') {
|
if (preg_match("/[" . $nodeprepchars . "]/u", $node) || mb_detect_encoding($node, 'UTF-8', true) != 'UTF-8') {
|
||||||
// TRANS: Exception thrown when using an invalid Jabber ID.
|
// TRANS: Exception thrown when using an invalid Jabber ID.
|
||||||
// TRANS: %s is the invalid Jabber ID.
|
// TRANS: %s is the invalid Jabber ID.
|
||||||
throw new Exception(sprintf(_m('Invalid JID node "%s".'), $node));
|
throw new UnexpectedValueException(sprintf(_m('Invalid JID node "%s".'), $node));
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
if (strlen($domain) > 1023) {
|
if (strlen($domain) > 1023) {
|
||||||
// TRANS: Exception thrown when using too long a Jabber domain (>1023).
|
// TRANS: Exception thrown when using too long a Jabber domain (>1023).
|
||||||
throw new Exception(_m('Invalid JID: domain too long.'));
|
throw new UnexpectedValueException(_m('Invalid JID: domain too long.'));
|
||||||
}
|
}
|
||||||
if (!common_valid_domain($domain)) {
|
if (!common_valid_domain($domain)) {
|
||||||
// TRANS: Exception thrown when using an invalid Jabber domain name.
|
// TRANS: Exception thrown when using an invalid Jabber domain name.
|
||||||
// TRANS: %s is the invalid domain name.
|
// TRANS: %s is the invalid domain name.
|
||||||
throw new Exception(sprintf(_m('Invalid JID domain name "%s".'), $domain));
|
throw new UnexpectedValueException(sprintf(_m('Invalid JID domain name "%s".'), $domain));
|
||||||
}
|
}
|
||||||
|
|
||||||
if ($resource !== null) {
|
if ($resource !== null) {
|
||||||
if (strlen($resource) > 1023) {
|
if (strlen($resource) > 1023) {
|
||||||
// TRANS: Exception thrown when using too long a resource (>1023).
|
// TRANS: Exception thrown when using too long a resource (>1023).
|
||||||
throw new Exception("Invalid JID: resource too long.");
|
throw new UnexpectedValueException('Invalid JID: resource too long.');
|
||||||
}
|
}
|
||||||
if (preg_match("/[" . $chars . "]/u", $resource)) {
|
if (preg_match("/[" . $chars . "]/u", $resource)) {
|
||||||
// TRANS: Exception thrown when using an invalid Jabber resource.
|
// TRANS: Exception thrown when using an invalid Jabber resource.
|
||||||
// TRANS: %s is the invalid resource.
|
// TRANS: %s is the invalid resource.
|
||||||
throw new Exception(sprintf(_m('Invalid JID resource "%s".'), $resource));
|
throw new UnexpectedValueException(sprintf(_m('Invalid JID resource "%s".'), $resource));
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -370,12 +371,12 @@ class XmppPlugin extends ImPlugin
|
|||||||
{
|
{
|
||||||
try {
|
try {
|
||||||
$parts = $this->splitJid($jid);
|
$parts = $this->splitJid($jid);
|
||||||
if ($parts['node'] !== null) {
|
if (!is_null($parts['node'])) {
|
||||||
return $parts['node'] . '@' . $parts['domain'];
|
return $parts['node'] . '@' . $parts['domain'];
|
||||||
} else {
|
} else {
|
||||||
return $parts['domain'];
|
return $parts['domain'];
|
||||||
}
|
}
|
||||||
} catch (Exception $e) {
|
} catch (UnexpectedValueException $e) {
|
||||||
return null;
|
return null;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@ -447,7 +448,7 @@ class XmppPlugin extends ImPlugin
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
return $parts['resource'] !== ''; // missing or present; empty ain't kosher
|
return $parts['resource'] !== ''; // missing or present; empty ain't kosher
|
||||||
} catch (Exception $e) {
|
} catch (UnexpectedValueException $e) {
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
Loading…
Reference in New Issue
Block a user