Blame SOURCES/0004-service-do-not-copy-option-values-to-avoid-memory-le.patch

3eb28c
From 7daf5993995baad0f5c7f7ae3822dae37eb9f46f Mon Sep 17 00:00:00 2001
3eb28c
From: Sumit Bose <sbose@redhat.com>
3eb28c
Date: Fri, 30 Oct 2020 16:44:23 +0100
3eb28c
Subject: [PATCH 4/6] service: do not copy option values to avoid memory leaks
3eb28c
3eb28c
---
3eb28c
 service/realm-adcli-enroll.c | 15 ++++++++-------
3eb28c
 service/realm-options.c      |  8 +++-----
3eb28c
 2 files changed, 11 insertions(+), 12 deletions(-)
3eb28c
3eb28c
diff --git a/service/realm-adcli-enroll.c b/service/realm-adcli-enroll.c
3eb28c
index 2731283..e0d752b 100644
3eb28c
--- a/service/realm-adcli-enroll.c
3eb28c
+++ b/service/realm-adcli-enroll.c
3eb28c
@@ -80,7 +80,8 @@ realm_adcli_enroll_join_async (RealmDisco *disco,
3eb28c
 	GBytes *input = NULL;
3eb28c
 	const gchar *upn;
3eb28c
 	GPtrArray *args;
3eb28c
-	const gchar *os;
3eb28c
+	const gchar *os_n = NULL;
3eb28c
+	const gchar *os_v = NULL;
3eb28c
 	gchar *ccache_arg = NULL;
3eb28c
 	gchar *upn_arg = NULL;
3eb28c
 	gchar *server_arg = NULL;
3eb28c
@@ -144,16 +145,16 @@ realm_adcli_enroll_join_async (RealmDisco *disco,
3eb28c
 			g_ptr_array_add (args, (gpointer)computer_ou);
3eb28c
 	}
3eb28c
 
3eb28c
-	os = realm_options_ad_specific (options, "os-name");
3eb28c
-	if (os != NULL && !g_str_equal (os, "")) {
3eb28c
+	os_n = realm_options_ad_specific (options, "os-name");
3eb28c
+	if (os_n != NULL && !g_str_equal (os_n, "")) {
3eb28c
 		g_ptr_array_add (args, "--os-name");
3eb28c
-		g_ptr_array_add (args, (gpointer)os);
3eb28c
+		g_ptr_array_add (args, (gpointer)os_n);
3eb28c
 	}
3eb28c
 
3eb28c
-	os = realm_options_ad_specific (options, "os-version");
3eb28c
-	if (os != NULL && !g_str_equal (os, "")) {
3eb28c
+	os_v = realm_options_ad_specific (options, "os-version");
3eb28c
+	if (os_v != NULL && !g_str_equal (os_v, "")) {
3eb28c
 		g_ptr_array_add (args, "--os-version");
3eb28c
-		g_ptr_array_add (args, (gpointer)os);
3eb28c
+		g_ptr_array_add (args, (gpointer)os_v);
3eb28c
 	}
3eb28c
 
3eb28c
 	switch (cred->type) {
3eb28c
diff --git a/service/realm-options.c b/service/realm-options.c
3eb28c
index d42eb7c..4ebd6c0 100644
3eb28c
--- a/service/realm-options.c
3eb28c
+++ b/service/realm-options.c
3eb28c
@@ -179,7 +179,7 @@ realm_options_computer_name (GVariant *options,
3eb28c
 		g_free (section);
3eb28c
 	}
3eb28c
 
3eb28c
-	return g_strdup (computer_name);
3eb28c
+	return computer_name;
3eb28c
 }
3eb28c
 
3eb28c
 const gchar *
3eb28c
@@ -197,22 +197,20 @@ realm_options_ad_specific (GVariant *options,
3eb28c
 		value = realm_settings_value ("active-directory", option_name);
3eb28c
 	}
3eb28c
 
3eb28c
-	return g_strdup (value);
3eb28c
+	return value;
3eb28c
 }
3eb28c
 
3eb28c
 gboolean realm_option_use_ldaps (GVariant *options)
3eb28c
 {
3eb28c
-	gchar *use_ldaps_str;
3eb28c
+	const gchar *use_ldaps_str;
3eb28c
 
3eb28c
 	use_ldaps_str = realm_options_ad_specific (options,
3eb28c
 	                                          REALM_DBUS_OPTION_USE_LDAPS);
3eb28c
 	if (use_ldaps_str != NULL
3eb28c
 	            && ( g_ascii_strcasecmp (use_ldaps_str, "True") == 0
3eb28c
 	                || g_ascii_strcasecmp (use_ldaps_str, "Yes") == 0)) {
3eb28c
-		g_free (use_ldaps_str);
3eb28c
 		return TRUE;
3eb28c
 	}
3eb28c
-	g_free (use_ldaps_str);
3eb28c
 
3eb28c
 	return FALSE;
3eb28c
 }
3eb28c
-- 
3eb28c
2.26.2
3eb28c