Implemented ICMPv4/ICMPv6 PDML Protocol
This commit is contained in:
parent
cbcd9872d4
commit
b230ff8082
@ -30,6 +30,7 @@ along with this program. If not, see <http://www.gnu.org/licenses/>
|
||||
#include "hexdump.pb.h"
|
||||
#include "llc.pb.h"
|
||||
#include "mac.pb.h"
|
||||
#include "icmp.pb.h"
|
||||
#include "ip4.pb.h"
|
||||
#include "ip6.pb.h"
|
||||
#include "snap.pb.h"
|
||||
@ -207,6 +208,8 @@ PdmlReader::PdmlReader(OstProto::StreamConfigList *streams)
|
||||
factory_.insert("arp", PdmlArpProtocol::createInstance);
|
||||
factory_.insert("eth", PdmlEthProtocol::createInstance);
|
||||
factory_.insert("http", PdmlTextProtocol::createInstance);
|
||||
factory_.insert("icmp", PdmlIcmpProtocol::createInstance);
|
||||
factory_.insert("icmpv6", PdmlIcmpProtocol::createInstance);
|
||||
factory_.insert("ieee8021ad", PdmlSvlanProtocol::createInstance);
|
||||
factory_.insert("imap", PdmlTextProtocol::createInstance);
|
||||
factory_.insert("ip", PdmlIp4Protocol::createInstance);
|
||||
@ -1305,6 +1308,80 @@ void PdmlIp6Protocol::postProtocolHandler(OstProto::Protocol *pbProto,
|
||||
ip6->set_is_override_next_header(true); // FIXME
|
||||
}
|
||||
|
||||
|
||||
// ---------------------------------------------------------- //
|
||||
// PdmlIcmpProtocol //
|
||||
// ---------------------------------------------------------- //
|
||||
|
||||
PdmlIcmpProtocol::PdmlIcmpProtocol()
|
||||
{
|
||||
pdmlProtoName_ = "icmp";
|
||||
ostProtoId_ = OstProto::Protocol::kIcmpFieldNumber;
|
||||
|
||||
fieldMap_.insert("icmp.type", OstProto::Icmp::kTypeFieldNumber);
|
||||
fieldMap_.insert("icmp.code", OstProto::Icmp::kCodeFieldNumber);
|
||||
fieldMap_.insert("icmp.checksum", OstProto::Icmp::kChecksumFieldNumber);
|
||||
fieldMap_.insert("icmp.ident", OstProto::Icmp::kIdentifierFieldNumber);
|
||||
fieldMap_.insert("icmp.seq", OstProto::Icmp::kSequenceFieldNumber);
|
||||
|
||||
fieldMap_.insert("icmpv6.type", OstProto::Icmp::kTypeFieldNumber);
|
||||
fieldMap_.insert("icmpv6.code", OstProto::Icmp::kCodeFieldNumber);
|
||||
fieldMap_.insert("icmpv6.checksum", OstProto::Icmp::kChecksumFieldNumber);
|
||||
// ICMPv6 ident and seq need to be handled as 'unknown' since Wireshark
|
||||
// doesn't define display filters for the same
|
||||
}
|
||||
|
||||
PdmlDefaultProtocol* PdmlIcmpProtocol::createInstance()
|
||||
{
|
||||
return new PdmlIcmpProtocol();
|
||||
}
|
||||
|
||||
void PdmlIcmpProtocol::preProtocolHandler(QString name,
|
||||
const QXmlStreamAttributes &attributes, int expectedPos,
|
||||
OstProto::Protocol *pbProto, OstProto::Stream *stream)
|
||||
{
|
||||
OstProto::Icmp *icmp = pbProto->MutableExtension(OstProto::icmp);
|
||||
|
||||
if (name == "icmp")
|
||||
icmp->set_icmp_version(OstProto::Icmp::kIcmp4);
|
||||
else if (name == "icmpv6")
|
||||
icmp->set_icmp_version(OstProto::Icmp::kIcmp6);
|
||||
|
||||
icmp->set_is_override_checksum(true);
|
||||
|
||||
icmp->set_type(kIcmpInvalidType);
|
||||
}
|
||||
|
||||
void PdmlIcmpProtocol::unknownFieldHandler(QString name, int pos, int size,
|
||||
const QXmlStreamAttributes &attributes, OstProto::Protocol *pbProto,
|
||||
OstProto::Stream *stream)
|
||||
{
|
||||
bool isOk;
|
||||
OstProto::Icmp *icmp = pbProto->MutableExtension(OstProto::icmp);
|
||||
|
||||
if ((icmp->icmp_version() == OstProto::Icmp::kIcmp6)
|
||||
&& (icmp->type() >= kIcmp6EchoRequest)
|
||||
&& (icmp->type() <= kIcmp6EchoReply))
|
||||
{
|
||||
QString addrHexStr = attributes.value("value").toString();
|
||||
|
||||
if (attributes.value("show").toString().startsWith("ID"))
|
||||
icmp->set_identifier(addrHexStr.toUInt(&isOk, kBaseHex));
|
||||
else if (attributes.value("show").toString().startsWith("Sequence"))
|
||||
icmp->set_sequence(addrHexStr.toUInt(&isOk, kBaseHex));
|
||||
}
|
||||
}
|
||||
|
||||
void PdmlIcmpProtocol::postProtocolHandler(OstProto::Protocol *pbProto,
|
||||
OstProto::Stream *stream)
|
||||
{
|
||||
OstProto::Icmp *icmp = pbProto->MutableExtension(OstProto::icmp);
|
||||
|
||||
if (icmp->type() == kIcmpInvalidType)
|
||||
stream->mutable_protocol()->RemoveLast();
|
||||
}
|
||||
|
||||
|
||||
// ---------------------------------------------------------- //
|
||||
// PdmlTcpProtocol //
|
||||
// ---------------------------------------------------------- //
|
||||
|
@ -248,6 +248,28 @@ public:
|
||||
OstProto::Stream *stream);
|
||||
};
|
||||
|
||||
class PdmlIcmpProtocol : public PdmlDefaultProtocol
|
||||
{
|
||||
public:
|
||||
PdmlIcmpProtocol();
|
||||
|
||||
static PdmlDefaultProtocol* createInstance();
|
||||
|
||||
virtual void preProtocolHandler(QString name,
|
||||
const QXmlStreamAttributes &attributes, int expectedPos,
|
||||
OstProto::Protocol *pbProto, OstProto::Stream *stream);
|
||||
virtual void unknownFieldHandler(QString name, int pos, int size,
|
||||
const QXmlStreamAttributes &attributes,
|
||||
OstProto::Protocol *pbProto, OstProto::Stream *stream);
|
||||
virtual void postProtocolHandler(OstProto::Protocol *pbProto,
|
||||
OstProto::Stream *stream);
|
||||
private:
|
||||
static const uint kIcmpInvalidType = 0xFFFFFFFF;
|
||||
|
||||
static const uint kIcmp6EchoRequest = 128;
|
||||
static const uint kIcmp6EchoReply = 129;
|
||||
};
|
||||
|
||||
class PdmlTcpProtocol : public PdmlDefaultProtocol
|
||||
{
|
||||
public:
|
||||
|
@ -484,8 +484,8 @@ void UdpProtocol::storeConfigWidget()
|
||||
setFieldData(udp_isOverrideTotLen,
|
||||
configForm->cbUdpLengthOverride->isChecked());
|
||||
|
||||
setFieldData(udp_cksum, configForm->leUdpCksum->text().toUInt(
|
||||
&isOk, BASE_HEX));
|
||||
setFieldData(udp_cksum, configForm->leUdpCksum->text().remove(QChar(' '))
|
||||
.toUInt(&isOk, BASE_HEX));
|
||||
setFieldData(udp_isOverrideCksum,
|
||||
configForm->cbUdpCksumOverride->isChecked());
|
||||
}
|
||||
|
Loading…
Reference in New Issue
Block a user