From a124b27b2b026919733ea2f5056edee55bc9fe24 Mon Sep 17 00:00:00 2001 From: Wiebe Cazemier Date: Tue, 14 May 2024 22:20:26 +1000 Subject: [PATCH] Check RequestXInformation is always 0 or 1 --- mqttpacket.cpp | 18 ++++++++++++++++-- 1 file changed, 16 insertions(+), 2 deletions(-) diff --git a/mqttpacket.cpp b/mqttpacket.cpp index dbb855a..4825d66 100644 --- a/mqttpacket.cpp +++ b/mqttpacket.cpp @@ -579,17 +579,31 @@ ConnectData MqttPacket::parseConnectData() result.max_outgoing_topic_aliases = std::min(readTwoBytesToUInt16(), settings.maxOutgoingTopicAliasValue); break; case Mqtt5Properties::RequestResponseInformation: + { if (pcounts[4]++ > 0) throw ProtocolError("Can't specify " + propertyToString(prop) + " more than once", ReasonCodes::ProtocolError); - result.request_response_information = !!readByte(); + const uint8_t x = readUint8(); + + if (x > 1) + throw ProtocolError(propertyToString(prop) + " must be 0 or 1", ReasonCodes::ProtocolError); + + result.request_response_information = static_cast(x); break; + } case Mqtt5Properties::RequestProblemInformation: + { if (pcounts[5]++ > 0) throw ProtocolError("Can't specify " + propertyToString(prop) + " more than once", ReasonCodes::ProtocolError); - result.request_problem_information = !!readByte(); + const uint8_t x = readUint8(); + + if (x > 1) + throw ProtocolError(propertyToString(prop) + " must be 0 or 1", ReasonCodes::ProtocolError); + + result.request_problem_information = static_cast(x); break; + } case Mqtt5Properties::UserProperty: readUserProperty(); break;