X-Git-Url: http://g0dil.de/git?a=blobdiff_plain;f=senf%2FPackets%2F80221Bundle%2FMIHPacket.cc;h=50b4439360d681970b46d26ceb18362bb9b3f67c;hb=57daeae6f2e924ce3f16f9677c3474f531cba9e5;hp=f4efbeb2c13bc035027cb81c12e807de9c0fbc36;hpb=ff305084cba283649a2c97e73d2608c3e4598683;p=senf.git diff --git a/senf/Packets/80221Bundle/MIHPacket.cc b/senf/Packets/80221Bundle/MIHPacket.cc index f4efbeb..50b4439 100644 --- a/senf/Packets/80221Bundle/MIHPacket.cc +++ b/senf/Packets/80221Bundle/MIHPacket.cc @@ -78,17 +78,20 @@ prefix_ senf::PacketInterpreterBase::factory_t senf::MIHPacketType::nextPacketTy return e ? e->factory() : MIHGenericPayloadPacket::factory(); } -prefix_ std::pair senf::MIHPacketType::validate(packet p) +prefix_ void senf::MIHPacketType::validate(packet p) { - if (p.data().size() < initSize()) - return std::make_pair(false, "truncated MIH message"); - if (p->version() != 1) - return std::make_pair(false, "invalid MIH version: " + senf::str(p->version()) ); - if (p->payloadLength() != p.size()-8) - return std::make_pair(false, "wrong MIH length: " + senf::str(p->payloadLength()) ); - if (p.next(senf::nothrow)) - return MIHMessageRegistry::instance().validate( p->messageId(), p.next()); - return std::make_pair(true, ""); + 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"); + } } //-/////////////////////////////////////////////////////////////////////////////////////////////////