X-Git-Url: http://g0dil.de/git?a=blobdiff_plain;f=senf%2FPackets%2F80221Bundle%2FMIHPacket.cc;h=50b4439360d681970b46d26ceb18362bb9b3f67c;hb=57daeae6f2e924ce3f16f9677c3474f531cba9e5;hp=e3f438970f64aab5363de66c64c1e36af3242a0c;hpb=9cb871b939efe93e35dd96808d25089399acfc46;p=senf.git diff --git a/senf/Packets/80221Bundle/MIHPacket.cc b/senf/Packets/80221Bundle/MIHPacket.cc index e3f4389..50b4439 100644 --- a/senf/Packets/80221Bundle/MIHPacket.cc +++ b/senf/Packets/80221Bundle/MIHPacket.cc @@ -28,15 +28,16 @@ // Custom includes #include +#include #include #define prefix_ -///////////////////////////////cc.p//////////////////////////////////////// +//-///////////////////////////////////////////////////////////////////////////////////////////////// SENF_PACKET_REGISTRY_REGISTER( senf::EtherTypes, 0x8917, senf::MIHPacket); -/////////////////////////////////////////////////////////////////////////// +//-///////////////////////////////////////////////////////////////////////////////////////////////// // MIHPacketType prefix_ void senf::MIHPacketType::dump(packet p, std::ostream &os) @@ -72,11 +73,28 @@ prefix_ senf::PacketInterpreterBase::factory_t senf::MIHPacketType::nextPacketTy { if (p.data().size() < initSize()) return no_factory(); - PkReg_Entry const * e (PacketRegistry::lookup( p->messageId(), nothrow )); + PacketRegistry::Entry const * e ( + PacketRegistry::lookup( p->messageId(), nothrow )); return e ? e->factory() : MIHGenericPayloadPacket::factory(); } -/////////////////////////////////////////////////////////////////////////// +prefix_ void senf::MIHPacketType::validate(packet p) +{ + try { + if (p.data().size() < initSize()) + throw InvalidMIHPacketException("truncated MIH message"); + if (p->version() != 1) + throw InvalidMIHPacketException("invalid MIH version: ") << senf::str(p->version()); + if (p->payloadLength() != p.size()-8) + throw InvalidMIHPacketException("wrong MIH length: ") << senf::str(p->payloadLength()); + if (p.next(senf::nothrow)) + MIHMessageRegistry::instance().validate( p->messageId(), p.next()); + } catch (senf::TruncatedPacketException e) { + throw InvalidMIHPacketException("truncated MIH message"); + } +} + +//-///////////////////////////////////////////////////////////////////////////////////////////////// // MIHGenericPayloadPacketType prefix_ void senf::MIHGenericPayloadPacketType::dump(packet p, std::ostream &os) @@ -93,12 +111,14 @@ prefix_ void senf::MIHGenericPayloadPacketType::finalize(packet p) { typedef parser::tlvList_t::container tlvContainer_t; tlvContainer_t tlvs (p->tlvList() ); - for (tlvContainer_t::iterator i (tlvs.begin()); i != tlvs.end(); ++i) - i->finalize(); + for (tlvContainer_t::iterator i (tlvs.begin()); i != tlvs.end(); ++i) { + MIHGenericTLVParser p (*i); + p.finalize(); + } } -///////////////////////////////cc.e//////////////////////////////////////// +//-///////////////////////////////////////////////////////////////////////////////////////////////// #undef prefix_