/* Copyright (c) 2013-2018 Dovecot authors, see the included COPYING file */
#include "lib.h"
#include "smtp-syntax.h"
#include "smtp-server-private.h"
/* VRFY command */
const char *params)
{
int ret;
/* vrfy = "VRFY" SP String CRLF */
if (ret < 0) {
501, "5.5.4",
"Invalid string parameter: %s", error);
} else {
501, "5.5.4", "Invalid parameters");
}
return;
}
/* specific implementation of VRFY command */
/* command is waiting for external event or it failed */
return;
}
}
/* RFC 5321, Section 3.5.3:
A server MUST NOT return a 250 code in response to a VRFY or EXPN
command unless it has actually verified the address. In particular,
a server MUST NOT return 250 if all it has done is to verify that the
syntax given is valid. In that case, 502 (Command not implemented)
or 500 (Syntax error, command unrecognized) SHOULD be returned. As
stated elsewhere, implementation (in the sense of actually validating
addresses and returning information) of VRFY and EXPN are strongly
recommended. Hence, implementations that return 500 or 502 for VRFY
are not in full compliance with this specification.
There may be circumstances where an address appears to be valid but
cannot reasonably be verified in real time, particularly when a
server is acting as a mail exchanger for another server or domain.
"Apparent validity", in this case, would normally involve at least
syntax checking and might involve verification that any domains
specified were ones to which the host expected to be able to relay
mail. In these situations, reply code 252 SHOULD be returned.
*/
}