mirror of
https://github.com/sheumann/telnetd.git
synced 2024-11-25 20:32:19 +00:00
If the uid of the attempted authentication is 0 and if the pty is
insecure, do not succeed. Copied from login.c. This functionality really should be a PAM module. git-svn-id: http://svn0.us-east.freebsd.org/base/head/contrib/telnet@76610 ccf9f872-aa2e-dd11-9fc8-001c23d0bc1f
This commit is contained in:
parent
4213319244
commit
b482ad5b9e
@ -17,6 +17,8 @@
|
||||
#include <security/pam_appl.h>
|
||||
#endif
|
||||
|
||||
#include <ttyent.h>
|
||||
|
||||
#include "auth.h"
|
||||
#include "misc.h"
|
||||
#include "encrypt.h"
|
||||
@ -28,6 +30,8 @@ DesData ck;
|
||||
IdeaData ik;
|
||||
|
||||
extern int auth_debug_mode;
|
||||
extern char *line;
|
||||
|
||||
static sra_valid = 0;
|
||||
static passwd_sent = 0;
|
||||
|
||||
@ -451,6 +455,26 @@ syslog(LOG_WARNING,"%s\n",save.pw_dir);
|
||||
return (&save);
|
||||
}
|
||||
|
||||
static int
|
||||
isroot(user)
|
||||
char *user;
|
||||
{
|
||||
struct passwd *pw;
|
||||
|
||||
if ((pw=getpwnam(user))==NULL)
|
||||
return 0;
|
||||
return (!pw->pw_uid);
|
||||
}
|
||||
|
||||
static int
|
||||
rootterm(ttyn)
|
||||
char *ttyn;
|
||||
{
|
||||
struct ttyent *t;
|
||||
|
||||
return ((t = getttynam(ttyn)) && t->ty_status & TTY_SECURE);
|
||||
}
|
||||
|
||||
#ifdef NOPAM
|
||||
char *crypt();
|
||||
|
||||
@ -461,6 +485,12 @@ char *pass;
|
||||
register char *cp;
|
||||
char *xpasswd, *salt;
|
||||
|
||||
if (isroot(name) && !rootterm(line))
|
||||
{
|
||||
crypt("AA","*"); /* Waste some time to simulate success */
|
||||
return(0);
|
||||
}
|
||||
|
||||
if (pw = sgetpwnam(name)) {
|
||||
if (pw->pw_shell == NULL) {
|
||||
pw = (struct passwd *) NULL;
|
||||
@ -585,6 +615,9 @@ int check_user(const char *name, const char *pass)
|
||||
} else
|
||||
syslog(LOG_ERR, "Couldn't get PAM_USER: %s",
|
||||
pam_strerror(pamh, e));
|
||||
if (isroot(user) && !rootterm(line))
|
||||
rval = 0;
|
||||
else
|
||||
rval = 1;
|
||||
break;
|
||||
|
||||
|
Loading…
Reference in New Issue
Block a user