|
 |
77e006 |
From 0eec70b9dbd0a50a24fe173a68fd9ab72857e08d Mon Sep 17 00:00:00 2001
|
|
 |
77e006 |
From: Rob Crittenden <rcritten@redhat.com>
|
|
 |
77e006 |
Date: Wed, 17 Feb 2021 13:40:52 -0500
|
|
 |
77e006 |
Subject: [PATCH] Add NULL checks before string compares when analyzing a cert
|
|
 |
77e006 |
|
|
 |
77e006 |
A user reported a segfault which was due to a broken request.
|
|
 |
77e006 |
How it got broken I have no idea but it was effectively empty.
|
|
 |
77e006 |
|
|
 |
77e006 |
It had everything as defaults: 0, -1, UNSPECIFIED or not
|
|
 |
77e006 |
present at all.
|
|
 |
77e006 |
|
|
 |
77e006 |
So when trying to analyze the request it did a NULL compare.
|
|
 |
77e006 |
|
|
 |
77e006 |
https://pagure.io/certmonger/issue/191
|
|
 |
77e006 |
---
|
|
 |
77e006 |
src/tdbush.c | 4 ++--
|
|
 |
77e006 |
1 file changed, 2 insertions(+), 2 deletions(-)
|
|
 |
77e006 |
|
|
 |
77e006 |
diff --git a/src/tdbush.c b/src/tdbush.c
|
|
 |
77e006 |
index a10a1aff..fb81c477 100644
|
|
 |
77e006 |
--- a/src/tdbush.c
|
|
 |
77e006 |
+++ b/src/tdbush.c
|
|
 |
77e006 |
@@ -678,14 +678,14 @@ base_add_request(DBusConnection *conn, DBusMessage *msg,
|
|
 |
77e006 |
if (cert_storage != e->cm_cert_storage_type) {
|
|
 |
77e006 |
continue;
|
|
 |
77e006 |
}
|
|
 |
77e006 |
- if (strcmp(cert_location, e->cm_cert_storage_location) != 0) {
|
|
 |
77e006 |
+ if ((e->cm_cert_storage_location == NULL) || strcmp(cert_location, e->cm_cert_storage_location) != 0) {
|
|
 |
77e006 |
continue;
|
|
 |
77e006 |
}
|
|
 |
77e006 |
switch (cert_storage) {
|
|
 |
77e006 |
case cm_cert_storage_file:
|
|
 |
77e006 |
break;
|
|
 |
77e006 |
case cm_cert_storage_nssdb:
|
|
 |
77e006 |
- if (strcmp(cert_nickname, e->cm_cert_nickname) != 0) {
|
|
 |
77e006 |
+ if ((e->cm_cert_nickname == NULL) || strcmp(cert_nickname, e->cm_cert_nickname) != 0) {
|
|
 |
77e006 |
continue;
|
|
 |
77e006 |
}
|
|
 |
77e006 |
break;
|
|
 |
77e006 |
--
|
|
 |
77e006 |
2.31.1
|
|
 |
77e006 |
|