From: Zdenek Dohnal Date: Thu, 11 Sep 2025 12:44:59 +0000 (+0200) Subject: cupsd: Block authentication using alternate method X-Git-Tag: v2.4.13~2 X-Git-Url: http://git.ipfire.org/cgi-bin/gitweb.cgi?a=commitdiff_plain;h=595d691075b1d396d2edfaa0a8fd0873a0a1f221;p=thirdparty%2Fcups.git cupsd: Block authentication using alternate method Fixes: CVE-2025-58060 --- diff --git a/scheduler/auth.c b/scheduler/auth.c index 5fa53644de..3c9aa72aaf 100644 --- a/scheduler/auth.c +++ b/scheduler/auth.c @@ -513,6 +513,16 @@ cupsdAuthorize(cupsd_client_t *con) /* I - Client connection */ int userlen; /* Username:password length */ + /* + * Only allow Basic if enabled... + */ + + if (type != CUPSD_AUTH_BASIC) + { + cupsdLogClient(con, CUPSD_LOG_ERROR, "Basic authentication is not enabled."); + return; + } + authorization += 5; while (isspace(*authorization & 255)) authorization ++; @@ -558,7 +568,6 @@ cupsdAuthorize(cupsd_client_t *con) /* I - Client connection */ * Validate the username and password... */ - if (type == CUPSD_AUTH_BASIC) { #if HAVE_LIBPAM /* @@ -727,6 +736,16 @@ cupsdAuthorize(cupsd_client_t *con) /* I - Client connection */ /* Output token for username */ gss_name_t client_name; /* Client name */ + /* + * Only allow Kerberos if enabled... + */ + + if (type != CUPSD_AUTH_NEGOTIATE) + { + cupsdLogClient(con, CUPSD_LOG_ERROR, "Kerberos authentication is not enabled."); + return; + } + # ifdef __APPLE__ /* * If the weak-linked GSSAPI/Kerberos library is not present, don't try