]> git.ipfire.org Git - thirdparty/krb5.git/commitdiff
Fix memory leak in OTP kdcpreauth module
authorGreg Hudson <ghudson@mit.edu>
Fri, 3 Jun 2022 18:30:42 +0000 (14:30 -0400)
committerGreg Hudson <ghudson@mit.edu>
Sat, 5 Nov 2022 19:56:37 +0000 (15:56 -0400)
In otp_edata(), free the generated nonce.

(cherry picked from commit 5ad465bc8e0d957a4945218bea487b77622bf433)

ticket: 9063
version_fixed: 1.19.4

src/plugins/preauth/otp/main.c

index a1b6816824053eb9861092a2e2763e2ba5ade754..2f3d7dfe28e36aa0ec4f3e9c903e01bbdaecd9e0 100644 (file)
@@ -211,7 +211,7 @@ otp_edata(krb5_context context, krb5_kdc_req *request,
     krb5_pa_otp_challenge chl;
     krb5_pa_data *pa = NULL;
     krb5_error_code retval;
-    krb5_data *encoding;
+    krb5_data *encoding, nonce = empty_data();
     char *config;
 
     /* Determine if otp is enabled for the user. */
@@ -239,9 +239,10 @@ otp_edata(krb5_context context, krb5_kdc_req *request,
     ti.iteration_count = -1;
 
     /* Generate the nonce. */
-    retval = nonce_generate(context, armor_key->length, &chl.nonce);
+    retval = nonce_generate(context, armor_key->length, &nonce);
     if (retval != 0)
         goto out;
+    chl.nonce = nonce;
 
     /* Build the output pa-data. */
     retval = encode_krb5_pa_otp_challenge(&chl, &encoding);
@@ -258,6 +259,7 @@ otp_edata(krb5_context context, krb5_kdc_req *request,
     free(encoding);
 
 out:
+    krb5_free_data_contents(context, &nonce);
     (*respond)(arg, retval, pa);
 }