diff options
author | Eduardo Chappa <echappa@gmx.com> | 2013-02-03 00:59:38 -0700 |
---|---|---|
committer | Eduardo Chappa <echappa@gmx.com> | 2013-02-03 00:59:38 -0700 |
commit | 094ca96844842928810f14844413109fc6cdd890 (patch) | |
tree | e60efbb980f38ba9308ccb4fb2b77b87bbc115f3 /imap/src/osdep/unix/log_os4.c | |
download | alpine-094ca96844842928810f14844413109fc6cdd890.tar.xz |
Initial Alpine Version
Diffstat (limited to 'imap/src/osdep/unix/log_os4.c')
-rw-r--r-- | imap/src/osdep/unix/log_os4.c | 58 |
1 files changed, 58 insertions, 0 deletions
diff --git a/imap/src/osdep/unix/log_os4.c b/imap/src/osdep/unix/log_os4.c new file mode 100644 index 00000000..dec704e5 --- /dev/null +++ b/imap/src/osdep/unix/log_os4.c @@ -0,0 +1,58 @@ +/* ======================================================================== + * Copyright 1988-2006 University of Washington + * + * Licensed under the Apache License, Version 2.0 (the "License"); + * you may not use this file except in compliance with the License. + * You may obtain a copy of the License at + * + * http://www.apache.org/licenses/LICENSE-2.0 + * + * + * ======================================================================== + */ + +/* + * Program: OSF/1 (Digital UNIX) 4 login + * + * Author: Mark Crispin + * Networks and Distributed Computing + * Computing & Communications + * University of Washington + * Administration Building, AG-44 + * Seattle, WA 98195 + * Internet: MRC@CAC.Washington.EDU + * + * Date: 1 August 1988 + * Last Edited: 30 August 2006 + */ + +/* Log in + * Accepts: login passwd struct + * argument count + * argument vector + * Returns: T if success, NIL otherwise + */ + +long loginpw (struct passwd *pw,int argc,char *argv[]) +{ + int i; + char *s; + char *name = cpystr (pw->pw_name); + char *host = cpystr (tcp_clienthost ()); + uid_t uid = pw->pw_uid; + long ret = NIL; + /* tie off address */ + if (s = strchr (host,' ')) *s = '\0'; + if (*host == '[') { /* convert [a.b.c.d] to a.b.c.d */ + memmove (host,host+1,i = strlen (host + 2)); + host[i] = '\0'; + } + if (sia_become_user (checkpw_collect,argc,argv,host,name,NIL,NIL,NIL,NIL, + SIA_BEU_REALLOGIN|SIA_BEU_OKROOTDIR) != SIASUCCESS) + setreuid (0,0); /* make sure have root again */ + /* probable success, complete login */ + else ret = (!setreuid (0,0) && !setuid (uid)); + fs_give ((void **) &name); + fs_give ((void **) &host); + return ret; +} |