diff options
author | peter <peter@FreeBSD.org> | 1996-08-13 07:53:54 +0000 |
---|---|---|
committer | peter <peter@FreeBSD.org> | 1996-08-13 07:53:54 +0000 |
commit | 7e745e3e6f861028c4e50937c77cacfc22f9752e (patch) | |
tree | 8cdbce3248f9b9255913263cbf0c08606a79e6ea /secure/libexec/telnetd | |
parent | 027cdb6a44811bd1249b20a80b2010bc5ff7241c (diff) | |
download | FreeBSD-src-7e745e3e6f861028c4e50937c77cacfc22f9752e.zip FreeBSD-src-7e745e3e6f861028c4e50937c77cacfc22f9752e.tar.gz |
Same as non-secure telnetd, add support for ``-P altlogin'' to specify
an alternate /usr/bin/login type program to be run.
Diffstat (limited to 'secure/libexec/telnetd')
-rw-r--r-- | secure/libexec/telnetd/sys_term.c | 12 | ||||
-rw-r--r-- | secure/libexec/telnetd/telnetd.8 | 6 | ||||
-rw-r--r-- | secure/libexec/telnetd/telnetd.c | 7 |
3 files changed, 21 insertions, 4 deletions
diff --git a/secure/libexec/telnetd/sys_term.c b/secure/libexec/telnetd/sys_term.c index 87db574..cb8245f 100644 --- a/secure/libexec/telnetd/sys_term.c +++ b/secure/libexec/telnetd/sys_term.c @@ -42,6 +42,8 @@ static char sccsid[] = "@(#)sys_term.c 8.4+1 (Berkeley) 5/30/95"; #include <libtelnet/auth.h> #endif +extern char *altlogin; + #if defined(CRAY) || defined(__hpux) # define PARENT_DOES_UTMP #endif @@ -1781,10 +1783,14 @@ start_login(host, autologin, name) close(pty); #endif closelog(); - execv(_PATH_LOGIN, argv); - syslog(LOG_ERR, "%s: %m\n", _PATH_LOGIN); - fatalperror(net, _PATH_LOGIN); + if (altlogin == NULL) { + altlogin = _PATH_LOGIN; + } + execv(altlogin, argv); + + syslog(LOG_ERR, "%s: %m\n", altlogin); + fatalperror(net, altlogin); /*NOTREACHED*/ } diff --git a/secure/libexec/telnetd/telnetd.8 b/secure/libexec/telnetd/telnetd.8 index f618385..846189d 100644 --- a/secure/libexec/telnetd/telnetd.8 +++ b/secure/libexec/telnetd/telnetd.8 @@ -48,6 +48,7 @@ protocol server .Op Fl X Ar authtype .Op Fl a Ar authmode .Op Fl edebug +.Op Fl P Ar loginprog .Op Fl r Ns Ar lowpty-highpty .Op Fl u Ar len .Op Fl debug Op Ar port @@ -187,6 +188,11 @@ If has been compiled with support for data encryption, then the .Fl edebug option may be used to enable encryption debugging code. +.It Fl P Ar loginprog +Specifies an alternate +.Xr login 1 +command to run to complete the login. The alternate command must +understand the same command arguments as the standard login. .It Fl h Disables the printing of host-specific information before login has been completed. diff --git a/secure/libexec/telnetd/telnetd.c b/secure/libexec/telnetd/telnetd.c index 707c68a..40fdad5 100644 --- a/secure/libexec/telnetd/telnetd.c +++ b/secure/libexec/telnetd/telnetd.c @@ -124,6 +124,7 @@ int lowpty = 0, highpty; /* low, high pty numbers */ int debug = 0; int keepalive = 1; char *progname; +char *altlogin; extern void usage P((void)); @@ -133,7 +134,7 @@ extern void usage P((void)); * passed off to getopt(). */ char valid_opts[] = { - 'd', ':', 'h', 'k', 'n', 'S', ':', 'u', ':', 'U', + 'd', ':', 'h', 'k', 'n', 'p', ':', 'S', ':', 'u', ':', 'U', #ifdef AUTHENTICATION 'a', ':', 'X', ':', #endif @@ -301,6 +302,10 @@ main(argc, argv) keepalive = 0; break; + case 'p': + altlogin = optarg; + break; + #ifdef CRAY case 'r': { |