Blame SOURCES/freeradius-FR-GV-206-decode-option-60-string-not-63-octets-and-.patch

5fa452
From 46aa2d51f137ca34842dd744d17321ed7c11b386 Mon Sep 17 00:00:00 2001
5fa452
From: "Alan T. DeKok" <aland@freeradius.org>
5fa452
Date: Mon, 3 Jul 2017 11:36:13 -0400
5fa452
Subject: [PATCH] FR-GV-206 - decode option 60 (string) not 63 (octets), and
5fa452
 check length
5fa452
5fa452
---
5fa452
 src/modules/proto_dhcp/dhcp.c | 4 ++--
5fa452
 1 file changed, 2 insertions(+), 2 deletions(-)
5fa452
5fa452
diff --git a/src/modules/proto_dhcp/dhcp.c b/src/modules/proto_dhcp/dhcp.c
5fa452
index 98d87509d..a66a931cb 100644
5fa452
--- a/src/modules/proto_dhcp/dhcp.c
5fa452
+++ b/src/modules/proto_dhcp/dhcp.c
5fa452
@@ -1097,8 +1097,8 @@ int fr_dhcp_decode(RADIUS_PACKET *packet)
5fa452
 			/*
5fa452
 			 *	Vendor is "MSFT 98"
5fa452
 			 */
5fa452
-			vp = fr_pair_find_by_num(head, 63, DHCP_MAGIC_VENDOR, TAG_ANY);
5fa452
-			if (vp && (strcmp(vp->vp_strvalue, "MSFT 98") == 0)) {
5fa452
+			vp = fr_pair_find_by_num(head, 60, DHCP_MAGIC_VENDOR, TAG_ANY);
5fa452
+			if (vp && (vp->vp_length >= 7) && (memcmp(vp->vp_octets, "MSFT 98", 7) == 0)) {
5fa452
 				vp = fr_pair_find_by_num(head, 262, DHCP_MAGIC_VENDOR, TAG_ANY);
5fa452
 
5fa452
 				/*
5fa452
-- 
5fa452
2.13.2
5fa452