2008-05-03 09:37:10 -05:00
|
|
|
#include <QHostAddress>
|
|
|
|
#include "streamconfigdialog.h"
|
|
|
|
#include "stream.h"
|
|
|
|
|
2008-05-25 06:30:30 -05:00
|
|
|
#include "modeltest.h"
|
|
|
|
|
2008-08-23 23:39:08 -05:00
|
|
|
// TODO(HI): Write HexLineEdit::setNum() and num() and use it in
|
|
|
|
// Load/Store stream methods
|
|
|
|
|
|
|
|
StreamConfigDialog::StreamConfigDialog(Port &port, uint streamIndex,
|
|
|
|
QWidget *parent) : QDialog (parent), mPort(port)
|
2008-05-03 09:37:10 -05:00
|
|
|
{
|
|
|
|
setupUi(this);
|
|
|
|
setupUiExtra();
|
|
|
|
|
2008-08-23 23:39:08 -05:00
|
|
|
//mpStreamList = streamList;
|
2008-05-03 09:37:10 -05:00
|
|
|
mCurrentStreamIndex = streamIndex;
|
|
|
|
LoadCurrentStream();
|
2008-08-23 23:39:08 -05:00
|
|
|
mpPacketModel = new PacketModel(&mPort.streamByIndex(mCurrentStreamIndex),
|
2008-05-25 06:30:30 -05:00
|
|
|
this);
|
|
|
|
tvPacketTree->setModel(mpPacketModel);
|
|
|
|
mpPacketModelTester = new ModelTest(mpPacketModel);
|
|
|
|
tvPacketTree->header()->hide();
|
2008-08-30 03:49:08 -05:00
|
|
|
vwPacketDump->setModel(mpPacketModel);
|
|
|
|
vwPacketDump->setSelectionModel(tvPacketTree->selectionModel());
|
2008-05-03 09:37:10 -05:00
|
|
|
|
2008-08-23 23:39:08 -05:00
|
|
|
// FIXME(MED): Enable this navigation
|
|
|
|
pbPrev->setDisabled(true);
|
|
|
|
pbNext->setDisabled(true);
|
2008-05-03 09:37:10 -05:00
|
|
|
}
|
|
|
|
|
|
|
|
void StreamConfigDialog::setupUiExtra()
|
|
|
|
{
|
|
|
|
QRegExp reHex2B("[0-9,a-f,A-F]{1,4}");
|
|
|
|
QRegExp reHex4B("[0-9,a-f,A-F]{1,8}");
|
|
|
|
QRegExp reMac("([0-9,a-f,A-F]{2,2}[:-]){5,5}[0-9,a-f,A-F]{2,2}");
|
|
|
|
|
|
|
|
// Setup default stuff that cannot be done in designer
|
|
|
|
twProto->setTabEnabled(2, FALSE);
|
|
|
|
twProto->setTabEnabled(3, FALSE);
|
|
|
|
|
|
|
|
/*
|
|
|
|
** Setup Validators
|
|
|
|
*/
|
|
|
|
// Meta Data
|
|
|
|
lePktLen->setValidator(new QIntValidator(MIN_PKT_LEN, MAX_PKT_LEN, this));
|
|
|
|
|
|
|
|
// L2 Ethernet
|
|
|
|
leDstMac->setValidator(new QRegExpValidator(reMac, this));
|
|
|
|
leSrcMac->setValidator(new QRegExpValidator(reMac, this));
|
|
|
|
leDstMacCount->setValidator(new QIntValidator(1, MAX_MAC_ITER_COUNT, this));
|
|
|
|
leSrcMacCount->setValidator(new QIntValidator(1, MAX_MAC_ITER_COUNT, this));
|
|
|
|
leCvlanTpid->setValidator(new QRegExpValidator(reHex2B, this));
|
|
|
|
leSvlanTpid->setValidator(new QRegExpValidator(reHex2B, this));
|
|
|
|
//leEtherType->setValidator(new QRegExpValidator(reHex2B, this));
|
|
|
|
|
|
|
|
/*
|
|
|
|
** Setup Connections
|
|
|
|
*/
|
|
|
|
connect(rbSendPackets, SIGNAL(toggled(bool)),
|
|
|
|
this, SLOT(update_NumPacketsAndNumBursts()));
|
|
|
|
connect(rbSendBursts, SIGNAL(toggled(bool)),
|
|
|
|
this, SLOT(update_NumPacketsAndNumBursts()));
|
|
|
|
connect(rbModeFixed, SIGNAL(toggled(bool)),
|
|
|
|
this, SLOT(update_NumPacketsAndNumBursts()));
|
|
|
|
connect(rbModeContinuous, SIGNAL(toggled(bool)),
|
|
|
|
this, SLOT(update_NumPacketsAndNumBursts()));
|
|
|
|
|
|
|
|
// Show "Packet Config" page by default
|
|
|
|
twTopLevel->setCurrentIndex(0);
|
|
|
|
}
|
|
|
|
|
|
|
|
StreamConfigDialog::~StreamConfigDialog()
|
|
|
|
{
|
2008-05-25 06:30:30 -05:00
|
|
|
delete mpPacketModelTester;
|
|
|
|
delete mpPacketModel;
|
2008-05-03 09:37:10 -05:00
|
|
|
}
|
|
|
|
|
|
|
|
void StreamConfigDialog::on_cmbDstMacMode_currentIndexChanged(QString mode)
|
|
|
|
{
|
|
|
|
if (mode == "Fixed")
|
2008-08-08 22:22:13 -05:00
|
|
|
{
|
2008-05-03 09:37:10 -05:00
|
|
|
leDstMacCount->setEnabled(FALSE);
|
2008-08-08 22:22:13 -05:00
|
|
|
leDstMacStep->setEnabled(FALSE);
|
|
|
|
}
|
2008-05-03 09:37:10 -05:00
|
|
|
else
|
2008-08-08 22:22:13 -05:00
|
|
|
{
|
2008-05-03 09:37:10 -05:00
|
|
|
leDstMacCount->setEnabled(TRUE);
|
2008-08-08 22:22:13 -05:00
|
|
|
leDstMacStep->setEnabled(TRUE);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
void StreamConfigDialog::on_cmbSrcMacMode_currentIndexChanged(QString mode)
|
|
|
|
{
|
|
|
|
if (mode == "Fixed")
|
|
|
|
{
|
|
|
|
leSrcMacCount->setEnabled(FALSE);
|
|
|
|
leSrcMacStep->setEnabled(FALSE);
|
|
|
|
}
|
|
|
|
else
|
|
|
|
{
|
|
|
|
leSrcMacCount->setEnabled(TRUE);
|
|
|
|
leSrcMacStep->setEnabled(TRUE);
|
|
|
|
}
|
2008-05-03 09:37:10 -05:00
|
|
|
}
|
|
|
|
|
|
|
|
void StreamConfigDialog::on_pbPrev_clicked()
|
|
|
|
{
|
|
|
|
#if 0
|
|
|
|
StoreCurrentStream(currStreamIdx);
|
|
|
|
currStreamIdx--;
|
|
|
|
LoadCurrentStream(currStreamIdx);
|
|
|
|
|
|
|
|
pbPrev->setDisabled((currStreamIdx == 0));
|
|
|
|
pbNext->setDisabled((currStreamIdx == 2));
|
|
|
|
#endif
|
|
|
|
}
|
|
|
|
|
|
|
|
void StreamConfigDialog::on_pbNext_clicked()
|
|
|
|
{
|
|
|
|
#if 0
|
|
|
|
StoreCurrentStream(currStreamIdx);
|
|
|
|
currStreamIdx++;
|
|
|
|
LoadCurrentStream(currStreamIdx);
|
|
|
|
|
|
|
|
pbPrev->setDisabled((currStreamIdx == 0));
|
|
|
|
pbNext->setDisabled((currStreamIdx == 2));
|
|
|
|
#endif
|
|
|
|
}
|
|
|
|
|
|
|
|
void StreamConfigDialog::on_rbFtLlcSnap_toggled(bool checked)
|
|
|
|
{
|
|
|
|
if (checked)
|
|
|
|
{
|
|
|
|
leDsap->setText("AA");
|
|
|
|
leSsap->setText("AA");
|
|
|
|
leControl->setText("03");
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
void StreamConfigDialog::on_rbL3Ipv4_toggled(bool checked)
|
|
|
|
{
|
|
|
|
if (checked)
|
|
|
|
{
|
|
|
|
swL3Proto->setCurrentIndex(0);
|
|
|
|
twProto->setTabEnabled(2, TRUE);
|
|
|
|
twProto->setTabText(2, "L3 (IPv4)");
|
|
|
|
leType->setText("08 00");
|
|
|
|
}
|
|
|
|
else
|
|
|
|
{
|
|
|
|
twProto->setTabEnabled(2, FALSE);
|
|
|
|
twProto->setTabText(2, "L3");
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
void StreamConfigDialog::on_rbL3Arp_toggled(bool checked)
|
|
|
|
{
|
|
|
|
if (checked)
|
|
|
|
{
|
|
|
|
swL3Proto->setCurrentIndex(1);
|
|
|
|
twProto->setTabEnabled(2, TRUE);
|
|
|
|
twProto->setTabText(2, "L3 (ARP)");
|
|
|
|
leType->setText("08 06");
|
|
|
|
}
|
|
|
|
else
|
|
|
|
{
|
|
|
|
twProto->setTabEnabled(2, FALSE);
|
|
|
|
twProto->setTabText(2, "L3");
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
void StreamConfigDialog::on_rbL4Icmp_toggled(bool checked)
|
|
|
|
{
|
|
|
|
QString str;
|
|
|
|
|
|
|
|
if (checked)
|
|
|
|
{
|
|
|
|
swL4Proto->setCurrentIndex(2);
|
|
|
|
twProto->setTabEnabled(3, TRUE);
|
|
|
|
twProto->setTabText(3, "L4 (ICMP)");
|
|
|
|
leIpProto->setText(uintToHexStr(IP_PROTO_ICMP, str, 1));
|
|
|
|
}
|
|
|
|
else
|
|
|
|
{
|
|
|
|
twProto->setTabEnabled(3, FALSE);
|
|
|
|
twProto->setTabText(3, "L4");
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
void StreamConfigDialog::on_rbL4Igmp_toggled(bool checked)
|
|
|
|
{
|
|
|
|
QString str;
|
|
|
|
|
|
|
|
if (checked)
|
|
|
|
{
|
|
|
|
swL4Proto->setCurrentIndex(3);
|
|
|
|
twProto->setTabEnabled(3, TRUE);
|
|
|
|
twProto->setTabText(3, "L4 (IGMP)");
|
|
|
|
leIpProto->setText(uintToHexStr(IP_PROTO_IGMP, str, 1));
|
|
|
|
}
|
|
|
|
else
|
|
|
|
{
|
|
|
|
twProto->setTabEnabled(3, FALSE);
|
|
|
|
twProto->setTabText(3, "L4");
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
void StreamConfigDialog::on_rbL4Tcp_toggled(bool checked)
|
|
|
|
{
|
|
|
|
QString str;
|
|
|
|
|
|
|
|
if (checked)
|
|
|
|
{
|
|
|
|
swL4Proto->setCurrentIndex(0);
|
|
|
|
twProto->setTabEnabled(3, TRUE);
|
|
|
|
twProto->setTabText(3, "L4 (TCP)");
|
|
|
|
leIpProto->setText(uintToHexStr(IP_PROTO_TCP, str, 1));
|
|
|
|
}
|
|
|
|
else
|
|
|
|
{
|
|
|
|
twProto->setTabEnabled(3, FALSE);
|
|
|
|
twProto->setTabText(3, "L4");
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
void StreamConfigDialog::on_rbL4Udp_toggled(bool checked)
|
|
|
|
{
|
|
|
|
QString str;
|
|
|
|
|
|
|
|
if (checked)
|
|
|
|
{
|
|
|
|
swL4Proto->setCurrentIndex(1);
|
|
|
|
twProto->setTabEnabled(3, TRUE);
|
|
|
|
twProto->setTabText(3, "L4 (UDP)");
|
|
|
|
leIpProto->setText(uintToHexStr(IP_PROTO_UDP, str, 1));
|
|
|
|
}
|
|
|
|
else
|
|
|
|
{
|
|
|
|
twProto->setTabEnabled(3, FALSE);
|
|
|
|
twProto->setTabText(3, "L4");
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
void StreamConfigDialog::on_rbL4Other_toggled(bool checked)
|
|
|
|
{
|
|
|
|
if (checked)
|
|
|
|
leIpProto->setEnabled(true);
|
|
|
|
else
|
|
|
|
leIpProto->setEnabled(false);
|
|
|
|
}
|
|
|
|
|
|
|
|
void StreamConfigDialog::update_NumPacketsAndNumBursts()
|
|
|
|
{
|
|
|
|
if (rbSendPackets->isChecked() && rbModeFixed->isChecked())
|
|
|
|
leNumPackets->setEnabled(true);
|
|
|
|
else
|
|
|
|
leNumPackets->setEnabled(false);
|
|
|
|
|
|
|
|
if (rbSendBursts->isChecked() && rbModeFixed->isChecked())
|
|
|
|
leNumBursts->setEnabled(true);
|
|
|
|
else
|
|
|
|
leNumBursts->setEnabled(false);
|
|
|
|
}
|
|
|
|
|
2008-08-08 22:22:13 -05:00
|
|
|
QString & uintToHexStr(quint64 num, QString &hexStr, quint8 octets)
|
2008-05-03 09:37:10 -05:00
|
|
|
{
|
|
|
|
int i;
|
|
|
|
QChar zero('0');
|
|
|
|
|
|
|
|
hexStr = "";
|
|
|
|
|
|
|
|
for (i = octets; i > 0; i--)
|
|
|
|
{
|
|
|
|
ushort byte;
|
|
|
|
QString str1 = "%1";
|
|
|
|
QString str;
|
|
|
|
|
|
|
|
byte = num & 0xff;
|
|
|
|
str = str1.arg(byte, 2, 16, zero).append(' ');
|
|
|
|
hexStr.prepend(str);
|
|
|
|
num = num >> 8;
|
|
|
|
}
|
|
|
|
|
|
|
|
return hexStr;
|
|
|
|
}
|
|
|
|
|
|
|
|
#if 0
|
|
|
|
void StreamConfigDialog::on_lePattern_editingFinished()
|
|
|
|
{
|
|
|
|
ulong num = 0;
|
|
|
|
bool isOk;
|
|
|
|
QString str;
|
|
|
|
|
|
|
|
num = lePattern->text().remove(QChar(' ')).toULong(&isOk, 16);
|
|
|
|
qDebug("editfinished (%s | %x)\n", lePattern->text().toAscii().data(), num);
|
|
|
|
lePattern->setText(uintToHexStr(num, str, 4));
|
|
|
|
qDebug("editfinished (%s | %x)\n", lePattern->text().toAscii().data(), num);
|
|
|
|
}
|
|
|
|
#endif
|
|
|
|
|
|
|
|
void StreamConfigDialog::LoadCurrentStream()
|
|
|
|
{
|
2008-08-23 23:39:08 -05:00
|
|
|
Stream *pStream = &mPort.streamByIndex(mCurrentStreamIndex);
|
2008-05-03 09:37:10 -05:00
|
|
|
QString str;
|
|
|
|
|
|
|
|
qDebug("loading pStream %p", pStream);
|
|
|
|
|
|
|
|
// Meta Data
|
|
|
|
{
|
2008-08-08 22:22:13 -05:00
|
|
|
cmbPatternMode->setCurrentIndex(pStream->patternMode());
|
|
|
|
lePattern->setText(uintToHexStr(pStream->pattern(), str, 4));
|
2008-05-03 09:37:10 -05:00
|
|
|
|
2008-08-08 22:22:13 -05:00
|
|
|
cmbPktLenMode->setCurrentIndex(pStream->lenMode());
|
|
|
|
lePktLen->setText(str.setNum(pStream->frameLen()));
|
|
|
|
lePktLenMin->setText(str.setNum(pStream->frameLenMin()));
|
|
|
|
lePktLenMax->setText(str.setNum(pStream->frameLenMax()));
|
2008-05-03 09:37:10 -05:00
|
|
|
}
|
|
|
|
|
|
|
|
// Protocols
|
|
|
|
{
|
2008-08-08 22:22:13 -05:00
|
|
|
qDebug("ft = %d\n", pStream->frameType());
|
|
|
|
switch(pStream->frameType())
|
2008-05-03 09:37:10 -05:00
|
|
|
{
|
|
|
|
case Stream::e_ft_none:
|
|
|
|
rbFtNone->setChecked(TRUE);
|
|
|
|
break;
|
|
|
|
case Stream::e_ft_eth_2:
|
|
|
|
rbFtEthernet2->setChecked(TRUE);
|
|
|
|
break;
|
|
|
|
case Stream::e_ft_802_3_raw:
|
|
|
|
rbFt802Dot3Raw->setChecked(TRUE);
|
|
|
|
break;
|
|
|
|
case Stream::e_ft_802_3_llc:
|
|
|
|
rbFt802Dot3Llc->setChecked(TRUE);
|
|
|
|
break;
|
|
|
|
case Stream::e_ft_snap:
|
|
|
|
rbFtLlcSnap->setChecked(TRUE);
|
|
|
|
break;
|
|
|
|
}
|
2008-08-08 22:22:13 -05:00
|
|
|
|
2008-08-23 23:39:08 -05:00
|
|
|
leDsap->setText(uintToHexStr(pStream->llc()->dsap(), str, 1));
|
|
|
|
leSsap->setText(uintToHexStr(pStream->llc()->ssap(), str, 1));
|
|
|
|
leControl->setText(uintToHexStr(pStream->llc()->ctl(), str, 1));
|
|
|
|
leOui->setText(uintToHexStr(pStream->snap()->oui(), str, 3));
|
|
|
|
|
|
|
|
leType->setText(uintToHexStr(pStream->eth2()->type(), str, 2));
|
2008-05-03 09:37:10 -05:00
|
|
|
|
2008-08-23 23:39:08 -05:00
|
|
|
switch(pStream->l3Proto())
|
|
|
|
{
|
|
|
|
case Stream::e_l3_none:
|
|
|
|
rbL3None->setChecked(true);
|
|
|
|
break;
|
|
|
|
case Stream::e_l3_ip:
|
|
|
|
rbL3Ipv4->setChecked(true);
|
|
|
|
break;
|
|
|
|
case Stream::e_l3_arp:
|
|
|
|
rbL3Arp->setChecked(true);
|
|
|
|
break;
|
|
|
|
default:
|
|
|
|
qDebug("%s: unknown L3 Protocol %d", __FUNCTION__,
|
|
|
|
pStream->l3Proto());
|
|
|
|
}
|
2008-05-03 09:37:10 -05:00
|
|
|
|
2008-08-23 23:39:08 -05:00
|
|
|
switch(pStream->l4Proto())
|
|
|
|
{
|
|
|
|
case Stream::e_l4_none:
|
|
|
|
rbL4None->setChecked(true);
|
|
|
|
break;
|
|
|
|
case Stream::e_l4_tcp:
|
|
|
|
rbL4Tcp->setChecked(true);
|
|
|
|
break;
|
|
|
|
case Stream::e_l4_udp:
|
|
|
|
rbL4Udp->setChecked(true);
|
|
|
|
break;
|
|
|
|
case Stream::e_l4_icmp:
|
|
|
|
rbL4Icmp->setChecked(true);
|
|
|
|
break;
|
|
|
|
case Stream::e_l4_igmp:
|
|
|
|
rbL4Igmp->setChecked(true);
|
|
|
|
break;
|
|
|
|
default:
|
|
|
|
qDebug("%s: unknown l4 Protocol %d", __FUNCTION__,
|
|
|
|
pStream->l4Proto());
|
|
|
|
}
|
|
|
|
// PB (not needed anymore?)
|
|
|
|
#if 0
|
2008-05-03 09:37:10 -05:00
|
|
|
// Check for specific supported protocols first ...
|
2008-08-23 23:39:08 -05:00
|
|
|
if (pStream->eth2()->type() == ETH_TYP_IP)
|
2008-05-03 09:37:10 -05:00
|
|
|
rbL3Ipv4->setChecked(TRUE);
|
2008-08-23 23:39:08 -05:00
|
|
|
else if (pStream->eth2()->type() == ETH_TYP_ARP)
|
2008-05-03 09:37:10 -05:00
|
|
|
rbL3Arp->setChecked(TRUE);
|
|
|
|
|
|
|
|
// ... then for None/Other
|
|
|
|
rbL3None->setChecked((pStream->proto.protoMask & PM_L3_PROTO_NONE) > 0);
|
|
|
|
rbL3Other->setChecked((pStream->proto.protoMask & PM_L3_PROTO_OTHER) > 0);
|
|
|
|
|
|
|
|
// Check for specific supported protocols first ...
|
|
|
|
if (pStream->proto.ipProto == IP_PROTO_ICMP)
|
|
|
|
rbL4Icmp->setChecked(TRUE);
|
|
|
|
else if (pStream->proto.ipProto == IP_PROTO_IGMP)
|
|
|
|
rbL4Igmp->setChecked(TRUE);
|
|
|
|
else if (pStream->proto.ipProto == IP_PROTO_TCP)
|
|
|
|
rbL4Tcp->setChecked(TRUE);
|
|
|
|
else if (pStream->proto.ipProto == IP_PROTO_UDP)
|
|
|
|
rbL4Udp->setChecked(TRUE);
|
|
|
|
|
|
|
|
// ... then for None/Other
|
|
|
|
rbL4None->setChecked((pStream->proto.protoMask & PM_L4_PROTO_NONE) > 0);
|
|
|
|
rbL4Other->setChecked((pStream->proto.protoMask & PM_L4_PROTO_OTHER) > 0);
|
2008-08-08 22:22:13 -05:00
|
|
|
#endif
|
2008-05-03 09:37:10 -05:00
|
|
|
}
|
|
|
|
|
|
|
|
// L2
|
|
|
|
{
|
|
|
|
// L2 | Ethernet
|
|
|
|
{
|
2008-08-08 22:22:13 -05:00
|
|
|
leDstMac->setText(uintToHexStr(pStream->mac()->dstMac(), str, 6));
|
|
|
|
cmbDstMacMode->setCurrentIndex(pStream->mac()->dstMacMode());
|
|
|
|
leDstMacCount->setText(str.setNum(pStream->mac()->dstMacCount()));
|
|
|
|
leDstMacStep->setText(str.setNum(pStream->mac()->dstMacStep()));
|
|
|
|
|
|
|
|
leSrcMac->setText(uintToHexStr(pStream->mac()->srcMac(), str, 6));
|
|
|
|
cmbSrcMacMode->setCurrentIndex(pStream->mac()->srcMacMode());
|
|
|
|
leSrcMacCount->setText(str.setNum(pStream->mac()->srcMacCount()));
|
|
|
|
leSrcMacStep->setText(str.setNum(pStream->mac()->srcMacStep()));
|
2008-08-23 23:39:08 -05:00
|
|
|
|
|
|
|
{
|
|
|
|
VlanProtocol *vlan = pStream->vlan();
|
|
|
|
VlanProtocol::VlanFlags f;
|
|
|
|
|
|
|
|
cmbCvlanPrio->setCurrentIndex(vlan->cvlanPrio());
|
|
|
|
cmbCvlanCfi->setCurrentIndex(vlan->cvlanCfi());
|
|
|
|
leCvlanId->setText(str.setNum(vlan->cvlanId()));
|
|
|
|
leCvlanTpid->setText(str.setNum(vlan->ctpid()));
|
|
|
|
cbCvlanTpidOverride->setChecked(vlan->vlanFlags().testFlag(
|
|
|
|
VlanProtocol::VlanCtpidOverride));
|
|
|
|
gbCvlan->setChecked(vlan->vlanFlags().testFlag(
|
|
|
|
VlanProtocol::VlanCvlanTagged));
|
|
|
|
|
|
|
|
cmbSvlanPrio->setCurrentIndex(vlan->svlanPrio());
|
|
|
|
cmbSvlanCfi->setCurrentIndex(vlan->svlanCfi());
|
|
|
|
leSvlanId->setText(str.setNum(vlan->svlanId()));
|
|
|
|
leSvlanTpid->setText(str.setNum(vlan->stpid()));
|
|
|
|
cbSvlanTpidOverride->setChecked(vlan->vlanFlags().testFlag(
|
|
|
|
VlanProtocol::VlanStpidOverride));
|
|
|
|
gbSvlan->setChecked(vlan->vlanFlags().testFlag(
|
|
|
|
VlanProtocol::VlanSvlanTagged));
|
|
|
|
}
|
2008-05-03 09:37:10 -05:00
|
|
|
}
|
|
|
|
}
|
2008-08-08 22:22:13 -05:00
|
|
|
|
2008-05-03 09:37:10 -05:00
|
|
|
// L3
|
|
|
|
{
|
|
|
|
// L3 | IP
|
|
|
|
{
|
2008-08-08 22:22:13 -05:00
|
|
|
leIpVersion->setText(str.setNum(pStream->ip()->ver()));
|
|
|
|
cbIpVersionOverride->setChecked(
|
|
|
|
pStream->ip()->ipFlags().testFlag(IpProtocol::IpOverrideVersion));
|
|
|
|
leIpHdrLen->setText(str.setNum(pStream->ip()->hdrLen()));
|
|
|
|
cbIpHdrLenOverride->setChecked(
|
|
|
|
pStream->ip()->ipFlags().testFlag(IpProtocol::IpOverrideHdrLen));
|
2008-05-03 09:37:10 -05:00
|
|
|
|
2008-08-08 22:22:13 -05:00
|
|
|
leIpTos->setText(uintToHexStr(pStream->ip()->tos(), str, 1));
|
2008-05-03 09:37:10 -05:00
|
|
|
|
2008-08-08 22:22:13 -05:00
|
|
|
leIpLength->setText(str.setNum(pStream->ip()->totLen()));
|
|
|
|
cbIpLengthOverride->setChecked(
|
|
|
|
pStream->ip()->ipFlags().testFlag(IpProtocol::IpOverrideTotLen));
|
2008-05-03 09:37:10 -05:00
|
|
|
|
2008-08-08 22:22:13 -05:00
|
|
|
leIpId->setText(uintToHexStr(pStream->ip()->id(), str, 2));
|
|
|
|
leIpFragOfs->setText(str.setNum(pStream->ip()->fragOfs()));
|
|
|
|
cbIpFlagsDf->setChecked((pStream->ip()->flags() & IP_FLAG_DF) > 0);
|
|
|
|
cbIpFlagsMf->setChecked((pStream->ip()->flags() & IP_FLAG_MF) > 0);
|
2008-05-03 09:37:10 -05:00
|
|
|
|
2008-08-08 22:22:13 -05:00
|
|
|
leIpTtl->setText(str.setNum(pStream->ip()->ttl()));
|
|
|
|
leIpProto->setText(uintToHexStr(pStream->ip()->proto(), str, 1));
|
2008-05-03 09:37:10 -05:00
|
|
|
|
2008-08-08 22:22:13 -05:00
|
|
|
leIpCksum->setText(uintToHexStr(pStream->ip()->cksum(), str, 2));
|
|
|
|
cbIpCksumOverride->setChecked(
|
|
|
|
pStream->ip()->ipFlags().testFlag(IpProtocol::IpOverrideCksum));
|
2008-05-03 09:37:10 -05:00
|
|
|
|
2008-08-08 22:22:13 -05:00
|
|
|
leIpSrcAddr->setText(QHostAddress(pStream->ip()->srcIp()).toString());
|
|
|
|
cmbIpSrcAddrMode->setCurrentIndex(pStream->ip()->srcIpMode());
|
|
|
|
leIpSrcAddrCount->setText(str.setNum(pStream->ip()->srcIpCount()));
|
|
|
|
leIpSrcAddrMask->setText(QHostAddress(pStream->ip()->srcIpMask()).toString());
|
2008-05-03 09:37:10 -05:00
|
|
|
|
2008-08-08 22:22:13 -05:00
|
|
|
leIpDstAddr->setText(QHostAddress(pStream->ip()->dstIp()).toString());
|
|
|
|
cmbIpDstAddrMode->setCurrentIndex(pStream->ip()->dstIpMode());
|
|
|
|
leIpDstAddrCount->setText(str.setNum(pStream->ip()->dstIpCount()));
|
|
|
|
leIpDstAddrMask->setText(QHostAddress(pStream->ip()->dstIpMask()).toString());
|
2008-05-03 09:37:10 -05:00
|
|
|
}
|
|
|
|
|
|
|
|
// L3 | ARP
|
|
|
|
{
|
2008-08-23 23:39:08 -05:00
|
|
|
// TODO(LOW)
|
2008-05-03 09:37:10 -05:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
// L4
|
|
|
|
{
|
|
|
|
// L4 | TCP
|
|
|
|
{
|
2008-08-23 23:39:08 -05:00
|
|
|
leTcpSrcPort->setText(str.setNum(pStream->tcp()->srcPort()));
|
|
|
|
leTcpDstPort->setText(str.setNum(pStream->tcp()->dstPort()));
|
2008-05-03 09:37:10 -05:00
|
|
|
|
2008-08-23 23:39:08 -05:00
|
|
|
leTcpSeqNum->setText(str.setNum(pStream->tcp()->seqNum()));
|
|
|
|
leTcpAckNum->setText(str.setNum(pStream->tcp()->ackNum()));
|
2008-05-03 09:37:10 -05:00
|
|
|
|
2008-08-23 23:39:08 -05:00
|
|
|
leTcpHdrLen->setText(str.setNum(pStream->tcp()->hdrLen()));
|
|
|
|
cbTcpHdrLenOverride->setChecked((pStream->tcp()->tcpFlags().
|
|
|
|
testFlag(TcpProtocol::TcpOverrideHdrLen)));
|
2008-05-03 09:37:10 -05:00
|
|
|
|
2008-08-23 23:39:08 -05:00
|
|
|
leTcpWindow->setText(str.setNum(pStream->tcp()->window()));
|
2008-05-03 09:37:10 -05:00
|
|
|
|
2008-08-23 23:39:08 -05:00
|
|
|
leTcpCksum->setText(str.setNum(pStream->tcp()->cksum()));
|
|
|
|
cbTcpCksumOverride->setChecked((pStream->tcp()->tcpFlags().
|
|
|
|
testFlag(TcpProtocol::TcpOverrideCksum)));
|
2008-05-03 09:37:10 -05:00
|
|
|
|
2008-08-23 23:39:08 -05:00
|
|
|
leTcpUrgentPointer->setText(str.setNum(pStream->tcp()->urgPtr()));
|
2008-05-03 09:37:10 -05:00
|
|
|
|
2008-08-23 23:39:08 -05:00
|
|
|
cbTcpFlagsUrg->setChecked((pStream->tcp()->flags() & TCP_FLAG_URG) > 0);
|
|
|
|
cbTcpFlagsAck->setChecked((pStream->tcp()->flags() & TCP_FLAG_ACK) > 0);
|
|
|
|
cbTcpFlagsPsh->setChecked((pStream->tcp()->flags() & TCP_FLAG_PSH) > 0);
|
|
|
|
cbTcpFlagsRst->setChecked((pStream->tcp()->flags() & TCP_FLAG_RST) > 0);
|
|
|
|
cbTcpFlagsSyn->setChecked((pStream->tcp()->flags() & TCP_FLAG_SYN) > 0);
|
|
|
|
cbTcpFlagsFin->setChecked((pStream->tcp()->flags() & TCP_FLAG_FIN) > 0);
|
2008-05-03 09:37:10 -05:00
|
|
|
}
|
|
|
|
|
|
|
|
// L4 | UDP
|
|
|
|
{
|
2008-08-23 23:39:08 -05:00
|
|
|
leUdpSrcPort->setText(str.setNum(pStream->udp()->srcPort()));
|
|
|
|
leUdpDstPort->setText(str.setNum(pStream->udp()->dstPort()));
|
2008-05-03 09:37:10 -05:00
|
|
|
|
2008-08-23 23:39:08 -05:00
|
|
|
leUdpLength->setText(str.setNum(pStream->udp()->totLen()));
|
|
|
|
cbUdpLengthOverride->setChecked((pStream->udp()->udpFlags().
|
|
|
|
testFlag(UdpProtocol::UdpOverrideTotLen)));
|
2008-05-03 09:37:10 -05:00
|
|
|
|
2008-08-23 23:39:08 -05:00
|
|
|
|
|
|
|
leUdpCksum->setText(str.setNum(pStream->udp()->cksum()));
|
|
|
|
cbUdpCksumOverride->setChecked((pStream->udp()->udpFlags().
|
|
|
|
testFlag(UdpProtocol::UdpOverrideCksum)));
|
2008-05-03 09:37:10 -05:00
|
|
|
}
|
|
|
|
|
|
|
|
// L4 | ICMP
|
|
|
|
{
|
2008-08-23 23:39:08 -05:00
|
|
|
// TODO(LOW)
|
2008-05-03 09:37:10 -05:00
|
|
|
}
|
|
|
|
|
|
|
|
// L4 | IGMP
|
|
|
|
{
|
2008-08-23 23:39:08 -05:00
|
|
|
// TODO(LOW)
|
2008-05-03 09:37:10 -05:00
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
void StreamConfigDialog::StoreCurrentStream()
|
|
|
|
{
|
2008-08-23 23:39:08 -05:00
|
|
|
Stream *pStream = &mPort.streamByIndex(mCurrentStreamIndex);
|
2008-05-03 09:37:10 -05:00
|
|
|
QString str;
|
|
|
|
bool isOk;
|
|
|
|
|
|
|
|
qDebug("storing pStream %p", pStream);
|
|
|
|
|
|
|
|
// Meta Data
|
2008-08-08 22:22:13 -05:00
|
|
|
pStream->setPatternMode((Stream::DataPatternMode) cmbPatternMode->currentIndex());
|
|
|
|
pStream->setPattern(lePattern->text().remove(QChar(' ')).toULong(&isOk, 16));
|
2008-05-03 09:37:10 -05:00
|
|
|
|
2008-08-08 22:22:13 -05:00
|
|
|
pStream->setLenMode((Stream::FrameLengthMode) cmbPktLenMode->currentIndex());
|
|
|
|
pStream->setFrameLen(lePktLen->text().toULong(&isOk));
|
|
|
|
pStream->setFrameLenMin(lePktLenMin->text().toULong(&isOk));
|
|
|
|
pStream->setFrameLenMax(lePktLenMax->text().toULong(&isOk));
|
2008-08-23 23:39:08 -05:00
|
|
|
|
2008-05-03 09:37:10 -05:00
|
|
|
// Protocols
|
|
|
|
{
|
|
|
|
if (rbFtNone->isChecked())
|
2008-08-08 22:22:13 -05:00
|
|
|
pStream->setFrameType(Stream::e_ft_none);
|
2008-05-03 09:37:10 -05:00
|
|
|
else if (rbFtEthernet2->isChecked())
|
2008-08-08 22:22:13 -05:00
|
|
|
pStream->setFrameType(Stream::e_ft_eth_2);
|
2008-05-03 09:37:10 -05:00
|
|
|
else if (rbFt802Dot3Raw->isChecked())
|
2008-08-08 22:22:13 -05:00
|
|
|
pStream->setFrameType(Stream::e_ft_802_3_raw);
|
2008-05-03 09:37:10 -05:00
|
|
|
else if (rbFt802Dot3Llc->isChecked())
|
2008-08-08 22:22:13 -05:00
|
|
|
pStream->setFrameType(Stream::e_ft_802_3_llc);
|
2008-05-03 09:37:10 -05:00
|
|
|
else if (rbFtLlcSnap->isChecked())
|
2008-08-08 22:22:13 -05:00
|
|
|
pStream->setFrameType(Stream::e_ft_snap);
|
|
|
|
qDebug("store ft(%d)\n", pStream->frameType());
|
2008-05-03 09:37:10 -05:00
|
|
|
|
2008-08-23 23:39:08 -05:00
|
|
|
pStream->llc()->setDsap(leDsap->text().remove(QChar(' ')).toULong(&isOk, 16));
|
|
|
|
pStream->llc()->setSsap(leSsap->text().remove(QChar(' ')).toULong(&isOk, 16));
|
|
|
|
pStream->llc()->setCtl(leControl->text().remove(QChar(' ')).toULong(&isOk, 16));
|
|
|
|
pStream->snap()->setOui(leOui->text().remove(QChar(' ')).toULong(&isOk, 16));
|
|
|
|
pStream->eth2()->setType(leType->text().remove(QChar(' ')).toULong(&isOk, 16));
|
2008-05-03 09:37:10 -05:00
|
|
|
|
|
|
|
if (rbL3None->isChecked())
|
2008-08-23 23:39:08 -05:00
|
|
|
pStream->setL3Proto(Stream::e_l3_none);
|
|
|
|
else if (rbL3Ipv4->isChecked())
|
|
|
|
pStream->setL3Proto(Stream::e_l3_ip);
|
|
|
|
else if (rbL3Arp->isChecked())
|
|
|
|
pStream->setL3Proto(Stream::e_l3_arp);
|
|
|
|
else
|
|
|
|
{
|
|
|
|
qCritical("No L3 Protocol??? Problem in Code!!!");
|
|
|
|
pStream->setL3Proto(Stream::e_l3_none);
|
|
|
|
}
|
2008-05-03 09:37:10 -05:00
|
|
|
|
|
|
|
if (rbL4None->isChecked())
|
2008-08-23 23:39:08 -05:00
|
|
|
pStream->setL4Proto(Stream::e_l4_none);
|
|
|
|
else if (rbL4Tcp->isChecked())
|
|
|
|
pStream->setL4Proto(Stream::e_l4_tcp);
|
|
|
|
else if (rbL4Udp->isChecked())
|
|
|
|
pStream->setL4Proto(Stream::e_l4_udp);
|
|
|
|
else if (rbL4Icmp->isChecked())
|
|
|
|
pStream->setL4Proto(Stream::e_l4_icmp);
|
|
|
|
else if (rbL4Igmp->isChecked())
|
|
|
|
pStream->setL4Proto(Stream::e_l4_igmp);
|
|
|
|
else
|
|
|
|
{
|
|
|
|
qCritical("No L4 Protocol??? Problem in Code!!!");
|
|
|
|
pStream->setL4Proto(Stream::e_l4_none);
|
|
|
|
}
|
2008-05-03 09:37:10 -05:00
|
|
|
}
|
|
|
|
|
|
|
|
// L2
|
|
|
|
{
|
|
|
|
// L2 | Ethernet
|
|
|
|
{
|
2008-08-08 22:22:13 -05:00
|
|
|
pStream->mac()->setDstMac(
|
|
|
|
leDstMac->text().remove(QChar(' ')).toULongLong(&isOk, 16));
|
2008-08-30 03:49:08 -05:00
|
|
|
#if 1
|
|
|
|
qDebug("%s: dstMac = %llx [%s] %d", __FUNCTION__,
|
|
|
|
pStream->mac()->dstMac(),
|
|
|
|
leDstMac->text().toAscii().constData(), isOk);
|
|
|
|
#endif
|
2008-08-08 22:22:13 -05:00
|
|
|
pStream->mac()->setDstMacMode(
|
|
|
|
(MacProtocol::MacAddrMode) cmbDstMacMode->currentIndex());
|
|
|
|
pStream->mac()->setDstMacCount(
|
|
|
|
leDstMacCount->text().toULong(&isOk));
|
|
|
|
pStream->mac()->setDstMacStep(
|
|
|
|
leDstMacStep->text().toULong(&isOk));
|
|
|
|
|
|
|
|
pStream->mac()->setSrcMac(
|
|
|
|
leSrcMac->text().remove(QChar(' ')).toULongLong(&isOk, 16));
|
2008-08-30 03:49:08 -05:00
|
|
|
qDebug("%s: srcMac = %llx [%s] %d", __FUNCTION__,
|
|
|
|
pStream->mac()->srcMac(),
|
|
|
|
leSrcMac->text().toAscii().constData(), isOk);
|
2008-08-08 22:22:13 -05:00
|
|
|
pStream->mac()->setSrcMacMode(
|
|
|
|
(MacProtocol::MacAddrMode) cmbSrcMacMode->currentIndex());
|
|
|
|
pStream->mac()->setSrcMacCount(
|
|
|
|
leSrcMacCount->text().toULong(&isOk));
|
|
|
|
pStream->mac()->setSrcMacStep(
|
|
|
|
|
|
|
|
leSrcMacStep->text().toULong(&isOk));
|
2008-05-03 09:37:10 -05:00
|
|
|
|
2008-08-23 23:39:08 -05:00
|
|
|
{
|
|
|
|
VlanProtocol *vlan = pStream->vlan();
|
|
|
|
VlanProtocol::VlanFlags f = 0;
|
|
|
|
|
|
|
|
vlan->setCvlanPrio(cmbCvlanPrio->currentIndex());
|
|
|
|
vlan->setCvlanCfi(cmbCvlanCfi->currentIndex());
|
|
|
|
vlan->setCvlanId(leCvlanId->text().toULong(&isOk));
|
|
|
|
vlan->setCtpid(leCvlanTpid->text().remove(QChar(' ')).toULong(&isOk));
|
|
|
|
if (cbCvlanTpidOverride->isChecked())
|
|
|
|
f |= VlanProtocol::VlanCtpidOverride;
|
|
|
|
if (gbCvlan->isChecked())
|
|
|
|
f |= VlanProtocol::VlanCvlanTagged;
|
|
|
|
|
|
|
|
vlan->setSvlanPrio(cmbSvlanPrio->currentIndex());
|
|
|
|
vlan->setSvlanCfi(cmbSvlanCfi->currentIndex());
|
|
|
|
vlan->setSvlanId(leSvlanId->text().toULong(&isOk));
|
|
|
|
vlan->setStpid(leSvlanTpid->text().remove(QChar(' ')).toULong(&isOk));
|
|
|
|
if (cbSvlanTpidOverride->isChecked())
|
|
|
|
f |= VlanProtocol::VlanStpidOverride;
|
|
|
|
if (gbSvlan->isChecked())
|
|
|
|
f |= VlanProtocol::VlanSvlanTagged;
|
|
|
|
|
|
|
|
vlan->setVlanFlags(f);
|
|
|
|
}
|
2008-05-03 09:37:10 -05:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
// L3
|
|
|
|
{
|
|
|
|
// L3 | IP
|
|
|
|
{
|
2008-08-08 22:22:13 -05:00
|
|
|
IpProtocol *ip = pStream->ip();
|
2008-08-23 23:39:08 -05:00
|
|
|
IpProtocol::IpFlags f = 0;
|
|
|
|
int ff = 0;
|
2008-05-03 09:37:10 -05:00
|
|
|
|
2008-08-08 22:22:13 -05:00
|
|
|
ip->setVer(leIpVersion->text().toULong(&isOk));
|
2008-05-03 09:37:10 -05:00
|
|
|
if (cbIpVersionOverride->isChecked())
|
2008-08-08 22:22:13 -05:00
|
|
|
f |= IpProtocol::IpOverrideVersion;
|
|
|
|
ip->setHdrLen(leIpHdrLen->text().toULong(&isOk));
|
2008-05-03 09:37:10 -05:00
|
|
|
if (cbIpHdrLenOverride->isChecked())
|
2008-08-08 22:22:13 -05:00
|
|
|
f |= IpProtocol::IpOverrideHdrLen;
|
2008-05-03 09:37:10 -05:00
|
|
|
|
2008-08-08 22:22:13 -05:00
|
|
|
ip->setTos(leIpTos->text().toULong(&isOk, 16));
|
2008-05-03 09:37:10 -05:00
|
|
|
|
2008-08-08 22:22:13 -05:00
|
|
|
ip->setTotLen(leIpLength->text().toULong(&isOk));
|
2008-05-03 09:37:10 -05:00
|
|
|
if (cbIpLengthOverride->isChecked())
|
2008-08-08 22:22:13 -05:00
|
|
|
f |= IpProtocol::IpOverrideHdrLen;
|
2008-05-03 09:37:10 -05:00
|
|
|
|
2008-08-08 22:22:13 -05:00
|
|
|
ip->setId(leIpId->text().remove(QChar(' ')).toULong(&isOk, 16));
|
|
|
|
ip->setFragOfs(leIpFragOfs->text().toULong(&isOk));
|
2008-05-03 09:37:10 -05:00
|
|
|
|
2008-08-08 22:22:13 -05:00
|
|
|
if (cbIpFlagsDf->isChecked()) ff |= IP_FLAG_DF;
|
|
|
|
if (cbIpFlagsMf->isChecked()) ff |= IP_FLAG_MF;
|
|
|
|
ip->setFlags(ff);
|
|
|
|
|
|
|
|
ip->setTtl(leIpTtl->text().toULong(&isOk));
|
|
|
|
ip->setProto(leIpProto->text().remove(QChar(' ')).toULong(&isOk, 16));
|
2008-05-03 09:37:10 -05:00
|
|
|
|
2008-08-08 22:22:13 -05:00
|
|
|
ip->setCksum(leIpCksum->text().remove(QChar(' ')).toULong(&isOk));
|
2008-05-03 09:37:10 -05:00
|
|
|
if (cbIpCksumOverride->isChecked())
|
2008-08-08 22:22:13 -05:00
|
|
|
f |= IpProtocol::IpOverrideCksum;
|
|
|
|
|
|
|
|
ip->setSrcIp(QHostAddress(leIpSrcAddr->text()).toIPv4Address());
|
|
|
|
ip->setSrcIpMode((IpProtocol::IpAddrMode) cmbIpSrcAddrMode->currentIndex());
|
|
|
|
ip->setSrcIpCount(leIpSrcAddrCount->text().toULong(&isOk));
|
|
|
|
ip->setSrcIpMask(QHostAddress(leIpSrcAddrMask->text()).toIPv4Address());
|
2008-05-03 09:37:10 -05:00
|
|
|
|
2008-08-08 22:22:13 -05:00
|
|
|
ip->setDstIp(QHostAddress(leIpDstAddr->text()).toIPv4Address());
|
|
|
|
ip->setDstIpMode((IpProtocol::IpAddrMode) cmbIpDstAddrMode->currentIndex());
|
|
|
|
ip->setDstIpCount(leIpDstAddrCount->text().toULong(&isOk));
|
|
|
|
ip->setDstIpMask(QHostAddress(leIpDstAddrMask->text()).toIPv4Address());
|
2008-05-03 09:37:10 -05:00
|
|
|
|
2008-08-08 22:22:13 -05:00
|
|
|
ip->setIpFlags(f);
|
2008-05-03 09:37:10 -05:00
|
|
|
}
|
|
|
|
|
|
|
|
// L3 | ARP
|
|
|
|
{
|
2008-08-23 23:39:08 -05:00
|
|
|
// TODO(LOW)
|
2008-05-03 09:37:10 -05:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
// L4
|
|
|
|
{
|
|
|
|
// L4 | TCP
|
|
|
|
{
|
2008-08-23 23:39:08 -05:00
|
|
|
TcpProtocol *tcp = pStream->tcp();
|
|
|
|
TcpProtocol::TcpFlags f = 0;
|
|
|
|
int ff = 0;
|
2008-05-03 09:37:10 -05:00
|
|
|
|
2008-08-23 23:39:08 -05:00
|
|
|
tcp->setSrcPort(leTcpSrcPort->text().toULong(&isOk));
|
|
|
|
tcp->setDstPort(leTcpDstPort->text().toULong(&isOk));
|
2008-05-03 09:37:10 -05:00
|
|
|
|
2008-08-23 23:39:08 -05:00
|
|
|
tcp->setSeqNum(leTcpSeqNum->text().toULong(&isOk));
|
|
|
|
tcp->setAckNum(leTcpAckNum->text().toULong(&isOk));
|
2008-05-03 09:37:10 -05:00
|
|
|
|
2008-08-23 23:39:08 -05:00
|
|
|
tcp->setHdrLen(leTcpHdrLen->text().toULong(&isOk));
|
2008-05-03 09:37:10 -05:00
|
|
|
if (cbTcpHdrLenOverride->isChecked())
|
2008-08-23 23:39:08 -05:00
|
|
|
f |= TcpProtocol::TcpOverrideHdrLen;
|
2008-05-03 09:37:10 -05:00
|
|
|
|
2008-08-23 23:39:08 -05:00
|
|
|
tcp->setWindow(leTcpWindow->text().toULong(&isOk));
|
2008-05-03 09:37:10 -05:00
|
|
|
|
2008-08-23 23:39:08 -05:00
|
|
|
tcp->setCksum(leTcpCksum->text().remove(QChar(' ')).toULong(&isOk));
|
2008-05-03 09:37:10 -05:00
|
|
|
if (cbTcpCksumOverride->isChecked())
|
2008-08-23 23:39:08 -05:00
|
|
|
f |= TcpProtocol::TcpOverrideCksum;
|
|
|
|
|
|
|
|
tcp->setUrgPtr(leTcpUrgentPointer->text().toULong(&isOk));
|
2008-05-03 09:37:10 -05:00
|
|
|
|
2008-08-23 23:39:08 -05:00
|
|
|
if (cbTcpFlagsUrg->isChecked()) ff |= TCP_FLAG_URG;
|
|
|
|
if (cbTcpFlagsAck->isChecked()) ff |= TCP_FLAG_ACK;
|
|
|
|
if (cbTcpFlagsPsh->isChecked()) ff |= TCP_FLAG_PSH;
|
|
|
|
if (cbTcpFlagsRst->isChecked()) ff |= TCP_FLAG_RST;
|
|
|
|
if (cbTcpFlagsSyn->isChecked()) ff |= TCP_FLAG_SYN;
|
|
|
|
if (cbTcpFlagsFin->isChecked()) ff |= TCP_FLAG_FIN;
|
|
|
|
tcp->setFlags(ff);
|
2008-05-03 09:37:10 -05:00
|
|
|
|
2008-08-23 23:39:08 -05:00
|
|
|
tcp->setTcpFlags(f);
|
2008-05-03 09:37:10 -05:00
|
|
|
}
|
|
|
|
|
|
|
|
// L4 | UDP
|
|
|
|
{
|
2008-08-23 23:39:08 -05:00
|
|
|
UdpProtocol *udp = pStream->udp();
|
|
|
|
UdpProtocol::UdpFlags f = 0;
|
2008-05-03 09:37:10 -05:00
|
|
|
|
2008-08-23 23:39:08 -05:00
|
|
|
udp->setSrcPort(leUdpSrcPort->text().toULong(&isOk));
|
|
|
|
udp->setDstPort(leUdpDstPort->text().toULong(&isOk));
|
2008-05-03 09:37:10 -05:00
|
|
|
|
2008-08-23 23:39:08 -05:00
|
|
|
udp->setTotLen(leUdpLength->text().toULong(&isOk));
|
2008-05-03 09:37:10 -05:00
|
|
|
|
2008-08-23 23:39:08 -05:00
|
|
|
if (cbUdpLengthOverride->isChecked())
|
|
|
|
f |= UdpProtocol::UdpOverrideTotLen;
|
|
|
|
|
|
|
|
udp->setCksum(leUdpCksum->text().remove(QChar(' ')).toULong(&isOk));
|
|
|
|
if (cbUdpCksumOverride->isChecked())
|
|
|
|
f |= UdpProtocol::UdpOverrideCksum;
|
|
|
|
|
|
|
|
udp->setUdpFlags(f);
|
2008-05-03 09:37:10 -05:00
|
|
|
}
|
|
|
|
|
|
|
|
// L4 | ICMP
|
|
|
|
{
|
2008-08-23 23:39:08 -05:00
|
|
|
// TODO)(LOW)
|
2008-05-03 09:37:10 -05:00
|
|
|
}
|
|
|
|
|
|
|
|
// L4 | IGMP
|
|
|
|
{
|
2008-08-23 23:39:08 -05:00
|
|
|
// TODO(LOW)
|
2008-05-03 09:37:10 -05:00
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
2008-08-23 23:39:08 -05:00
|
|
|
|
2008-05-03 09:37:10 -05:00
|
|
|
void StreamConfigDialog::on_pbOk_clicked()
|
|
|
|
{
|
|
|
|
// Store dialog contents into stream
|
|
|
|
StoreCurrentStream();
|
|
|
|
qDebug("stream stored");
|
|
|
|
}
|
|
|
|
|
|
|
|
//Junk Line for introducing a compiler error
|
|
|
|
|