Some time ago, Ben wrote about a PrintLastLog patch:> If the person who originally submitted it wants to write a complete
> patch and submit it.  Then we would be happy to debate if it will be
> included.
Well, here it is, because: "You Asked For It!"
PS: I'm tired of maintaining my own version of Debian's ssh just to
    have this option available, so I hope you find it acceptable.
-- 
Chip Salzenberg              - a.k.a. -             <chip at valinux.com>
 "We have no fuel on board, plus or minus 8 kilograms."  -- NEAR tech
-------------- next part --------------
Index: servconf.h
--- servconf.h.prev
+++ servconf.h	Thu Feb 22 20:59:45 2001
@@ -52,4 +52,5 @@
 						 * for RhostsRsaAuth */
 	int     print_motd;	/* If true, print /etc/motd. */
+	int	print_lastlog;	/* If true, print lastlog */
 	int     check_mail;	/* If true, check for new mail. */
 	int     x11_forwarding;	/* If true, permit inet (spoofing) X11 fwd. */
Index: servconf.c
--- servconf.c.prev
+++ servconf.c	Thu Feb 22 20:59:45 2001
@@ -56,4 +56,5 @@ initialize_server_options(ServerOptions 
 	options->ignore_user_known_hosts = -1;
 	options->print_motd = -1;
+	options->print_lastlog = -1;
 	options->check_mail = -1;
 	options->x11_forwarding = -1;
@@ -133,4 +134,6 @@ fill_default_server_options(ServerOption
 	if (options->print_motd == -1)
 		options->print_motd = 1;
+	if (options->print_lastlog == -1)
+		options->print_lastlog = 1;
 	if (options->x11_forwarding == -1)
 		options->x11_forwarding = 0;
@@ -209,5 +212,6 @@ typedef enum {
 	sChallengeResponseAuthentication,
 	sPasswordAuthentication, sKbdInteractiveAuthentication, sListenAddress,
-	sPrintMotd, sIgnoreRhosts, sX11Forwarding, sX11DisplayOffset,
+	sPrintMotd, sPrintLastLog, sIgnoreRhosts,
+	sX11Forwarding, sX11DisplayOffset,
 	sStrictModes, sEmptyPasswd, sRandomSeedFile, sKeepAlives, sCheckMail,
 	sUseLogin, sAllowTcpForwarding,
@@ -254,4 +258,5 @@ static struct {
 	{ "listenaddress", sListenAddress },
 	{ "printmotd", sPrintMotd },
+	{ "printlastlog", sPrintLastLog },
 	{ "ignorerhosts", sIgnoreRhosts },
 	{ "ignoreuserknownhosts", sIgnoreUserKnownHosts },
@@ -555,4 +560,8 @@ parse_flag:
 		case sPrintMotd:
 			intptr = &options->print_motd;
+			goto parse_flag;
+
+		case sPrintLastLog:
+			intptr = &options->print_lastlog;
 			goto parse_flag;
 
Index: session.c
--- session.c.prev
+++ session.c	Thu Feb 22 20:59:45 2001
@@ -708,8 +708,10 @@ do_login(Session *s, const char *command
 	}
 
-	/* Get the time and hostname when the user last logged in. */
-	hostname[0] = '\0';
-	last_login_time = get_last_login_time(pw->pw_uid, pw->pw_name,
-	    hostname, sizeof(hostname));
+	if (options.print_lastlog) {
+	    /* Get the time and hostname when the user last logged in. */
+	    hostname[0] = '\0';
+	    last_login_time = get_last_login_time(pw->pw_uid, pw->pw_name,
+		hostname, sizeof(hostname));
+	}
 
 	/* Record that there was a login on that tty from the remote host. */
@@ -748,5 +750,5 @@ do_login(Session *s, const char *command
 #endif /* WITH_AIXAUTHENTICATE */
 
-	if (last_login_time != 0) {
+	if (options.print_lastlog && last_login_time != 0) {
 		time_string = ctime(&last_login_time);
 		if (strchr(time_string, '\n'))
Index: sshd.8
--- sshd.8.prev
+++ sshd.8	Thu Feb 22 20:59:46 2001
@@ -350,4 +350,20 @@
 The default is
 .Dq no .
+.Pp
+Note: These messages can also be generated by PAM, so if you find that
+you are getting the message twice, switch this one
+.Dq off
+and let PAM handle it.
+.It Cm PrintLastLogin
+Specifies whether
+.Nm
+should print the date and tty of last login when a user logs in
+interactively.  The default is
+.Dq no .
+.Pp
+Note: These messages can also be generated by PAM, so if you find that
+you are getting the message twice, switch this one
+.Dq off
+and let PAM handle it.
 .It Cm DenyGroups
 This keyword can be followed by a number of group names, separated
Index: sshd_config
--- sshd_config.prev
+++ sshd_config	Thu Feb 22 20:59:46 2001
@@ -19,4 +19,5 @@
 X11DisplayOffset 10
 PrintMotd yes
+PrintLastLog yes
 KeepAlive yes