2014-02-11 14:22:27 +00:00
|
|
|
diff --git a/sendmail/usersmtp.c b/sendmail/usersmtp.c
|
2020-07-07 20:06:27 +00:00
|
|
|
index b4ff5cc..dddbb0a 100644
|
2014-02-11 14:22:27 +00:00
|
|
|
--- a/sendmail/usersmtp.c
|
|
|
|
+++ b/sendmail/usersmtp.c
|
2020-07-07 20:06:27 +00:00
|
|
|
@@ -1346,9 +1346,7 @@ safesaslfile(context, file)
|
2010-06-11 14:22:33 +00:00
|
|
|
{
|
|
|
|
long sff;
|
|
|
|
int r;
|
|
|
|
-#if SASL <= 10515
|
|
|
|
size_t len;
|
2020-07-07 20:06:27 +00:00
|
|
|
-#endif
|
2010-06-11 14:22:33 +00:00
|
|
|
char *p;
|
|
|
|
|
|
|
|
if (file == NULL || *file == '\0')
|
2020-07-07 20:06:27 +00:00
|
|
|
@@ -1386,9 +1384,16 @@ safesaslfile(context, file)
|
2010-06-11 14:22:33 +00:00
|
|
|
#endif /* SASL <= 10515 */
|
|
|
|
|
|
|
|
p = (char *) file;
|
|
|
|
+ len = strlen(p);
|
|
|
|
if ((r = safefile(p, RunAsUid, RunAsGid, RunAsUserName, sff,
|
|
|
|
S_IRUSR, NULL)) == 0)
|
|
|
|
return SASL_OK;
|
|
|
|
+#if SASL > 10515
|
|
|
|
+ /* Expect /usr/lib/sasl2/Sendmail.conf to be missing - config now in /etc/sasl2 */
|
|
|
|
+ if (type == SASL_VRFY_CONF && r == ENOENT &&
|
|
|
|
+ len >= 8 && strncmp(p, "/usr/lib", 8) == 0)
|
|
|
|
+ return SASL_CONTINUE;
|
|
|
|
+#endif /* SASL > 10515 */
|
|
|
|
if (LogLevel > (r != ENOENT ? 8 : 10))
|
|
|
|
sm_syslog(LOG_WARNING, NOQID, "error: safesasl(%s) failed: %s",
|
|
|
|
p, sm_errstring(r));
|