diff -up sudo-1.8.6p7/plugins/sudoers/match.c.digestmessagesfix sudo-1.8.6p7/plugins/sudoers/match.c --- sudo-1.8.6p7/plugins/sudoers/match.c.digestmessagesfix 2015-09-01 15:33:27.493054381 +0200 +++ sudo-1.8.6p7/plugins/sudoers/match.c 2015-09-01 15:33:31.327054279 +0200 @@ -566,6 +566,21 @@ base64_decode(const char *in, unsigned c return io; } +static const char *digesttype2str(int digest_type) +{ + switch(digest_type) { + case SUDO_DIGEST_SHA224: + return "SHA224"; + case SUDO_DIGEST_SHA256: + return "SHA256"; + case SUDO_DIGEST_SHA384: + return "SHA384"; + case SUDO_DIGEST_SHA512: + return "SHA512"; + } + return ""; +} + static bool digest_matches(char *file, struct sudo_digest *sd) { @@ -597,7 +612,7 @@ digest_matches(char *file, struct sudo_d if (!isxdigit((unsigned char)sd->digest_str[i + i]) || !isxdigit((unsigned char)sd->digest_str[i + i + 1])) { warningx(_("digest for %s (%s) is not in %s form"), file, - sd->digest_str, sd->digest_str); + sd->digest_str, digesttype2str(sd->digest_type)); goto bad_format; } sudoers_digest[i] = hexchar(&sd->digest_str[i + i]); @@ -619,7 +634,7 @@ digest_matches(char *file, struct sudo_d debug_return_bool(match); bad_format: warningx(_("digest for %s (%s) is not in %s form"), file, - sd->digest_str, sd->digest_str); + sd->digest_str, digesttype2str(sd->digest_type)); if (sudoers_digest) efree(sudoers_digest); if (file_digest)