1
0
mirror of https://github.com/d47081/qBittorrent.git synced 2025-01-22 20:44:15 +00:00

Improve parsing in BitTorrent::PeerAddress::parse

This commit is contained in:
Chocobo1 2019-07-23 14:02:01 +08:00
parent cf47342cec
commit ccec50e18e
No known key found for this signature in database
GPG Key ID: 210D9C873253A68C
2 changed files with 19 additions and 20 deletions

View File

@ -29,30 +29,29 @@
#include "peeraddress.h" #include "peeraddress.h"
#include <QString> #include <QString>
#include <QStringList>
BitTorrent::PeerAddress BitTorrent::PeerAddress::parse(QString peerAddressStr) BitTorrent::PeerAddress BitTorrent::PeerAddress::parse(const QString &address)
{ {
PeerAddress addr; QVector<QStringRef> ipPort;
QStringList ipPort;
if ((peerAddressStr[0] == '[') && (peerAddressStr.indexOf("]:") != -1)) // IPv6 if (address.startsWith('[') && address.contains("]:")) { // IPv6
ipPort = peerAddressStr.remove(QChar('[')).split("]:"); ipPort = address.splitRef("]:");
else if (peerAddressStr.indexOf(':') != -1) // IPv4 ipPort[0] = ipPort[0].mid(1); // chop '['
ipPort = peerAddressStr.split(':'); }
else else if (address.contains(':')) { // IPv4
return addr; ipPort = address.splitRef(':');
}
else {
return {};
}
QHostAddress ip(ipPort[0]); const QHostAddress ip {ipPort[0].toString()};
if (ip.isNull()) if (ip.isNull())
return addr; return {};
bool ok; const ushort port {ipPort[1].toUShort()};
int port = ipPort[1].toInt(&ok); if (port == 0)
if (!ok || (port < 1) || (port > 65535)) return {};
return addr;
addr.ip = ip; return {ip, port};
addr.port = port;
return addr;
} }

View File

@ -39,6 +39,6 @@ namespace BitTorrent
QHostAddress ip; QHostAddress ip;
ushort port = 0; ushort port = 0;
static PeerAddress parse(QString peerAddressStr); static PeerAddress parse(const QString &address);
}; };
} }