]> git.ipfire.org Git - thirdparty/krb5.git/commitdiff
Fix LDAP null deref on empty arg [CVE-2016-3119]
authorGreg Hudson <ghudson@mit.edu>
Mon, 14 Mar 2016 21:26:34 +0000 (17:26 -0400)
committerGreg Hudson <ghudson@mit.edu>
Fri, 18 Mar 2016 20:24:28 +0000 (16:24 -0400)
In the LDAP KDB module's process_db_args(), strtok_r() may return NULL
if there is an empty string in the db_args array.  Check for this case
and avoid dereferencing a null pointer.

CVE-2016-3119:

In MIT krb5 1.6 and later, an authenticated attacker with permission
to modify a principal entry can cause kadmind to dereference a null
pointer by supplying an empty DB argument to the modify_principal
command, if kadmind is configured to use the LDAP KDB module.

    CVSSv2 Vector: AV:N/AC:H/Au:S/C:N/I:N/A:C/E:H/RL:OF/RC:ND

ticket: 8383 (new)
target_version: 1.14-next
target_version: 1.13-next
tags: pullup

src/plugins/kdb/ldap/libkdb_ldap/ldap_principal2.c

index 6e591e197425639a8b15838bad59b8065db72859..79c4cf05cc2f6b2da394aa4bcdc9c29fa573fd0f 100644 (file)
@@ -296,6 +296,7 @@ process_db_args(krb5_context context, char **db_args, xargs_t *xargs,
     if (db_args) {
         for (i=0; db_args[i]; ++i) {
             arg = strtok_r(db_args[i], "=", &arg_val);
+            arg = (arg != NULL) ? arg : "";
             if (strcmp(arg, TKTPOLICY_ARG) == 0) {
                 dptr = &xargs->tktpolicydn;
             } else {