Browse Source

Added bounds checking to LeaseSet2.

pull/1941/head
Chad Fraleigh 1 year ago
parent
commit
9ae8c1869a
No known key found for this signature in database
GPG Key ID: 2415C39758458A8F
  1. 8
      libi2pd/LeaseSet.cpp

8
libi2pd/LeaseSet.cpp

@ -394,6 +394,10 @@ namespace data
size_t LeaseSet2::ReadStandardLS2TypeSpecificPart (const uint8_t * buf, size_t len) size_t LeaseSet2::ReadStandardLS2TypeSpecificPart (const uint8_t * buf, size_t len)
{ {
size_t offset = 0; size_t offset = 0;
if(offset + 2 > len) // AKA (len < 2)
return 0;
// properties // properties
uint16_t propertiesLen = bufbe16toh (buf + offset); offset += 2; uint16_t propertiesLen = bufbe16toh (buf + offset); offset += 2;
offset += propertiesLen; // skip for now. TODO: implement properties offset += propertiesLen; // skip for now. TODO: implement properties
@ -448,6 +452,10 @@ namespace data
size_t LeaseSet2::ReadMetaLS2TypeSpecificPart (const uint8_t * buf, size_t len) size_t LeaseSet2::ReadMetaLS2TypeSpecificPart (const uint8_t * buf, size_t len)
{ {
size_t offset = 0; size_t offset = 0;
if(offset + 2 > len) // AKA (len < 2)
return 0;
// properties // properties
uint16_t propertiesLen = bufbe16toh (buf + offset); offset += 2; uint16_t propertiesLen = bufbe16toh (buf + offset); offset += 2;
offset += propertiesLen; // skip for now. TODO: implement properties offset += propertiesLen; // skip for now. TODO: implement properties

Loading…
Cancel
Save