📄 log_os4.c
字号:
/* * 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: 9 September 1999 * * Copyright 1999 by the University of Washington * * Permission to use, copy, modify, and distribute this software and its * documentation for any purpose and without fee is hereby granted, provided * that the above copyright notice appears in all copies and that both the * above copyright notice and this permission notice appear in supporting * documentation, and that the name of the University of Washington not be * used in advertising or publicity pertaining to distribution of the software * without specific, written prior permission. This software is made available * "as is", and * THE UNIVERSITY OF WASHINGTON DISCLAIMS ALL WARRANTIES, EXPRESS OR IMPLIED, * WITH REGARD TO THIS SOFTWARE, INCLUDING WITHOUT LIMITATION ALL IMPLIED * WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE, AND IN * NO EVENT SHALL THE UNIVERSITY OF WASHINGTON BE LIABLE FOR ANY SPECIAL, * INDIRECT OR CONSEQUENTIAL DAMAGES OR ANY DAMAGES WHATSOEVER RESULTING FROM * LOSS OF USE, DATA OR PROFITS, WHETHER IN AN ACTION OF CONTRACT, TORT * (INCLUDING NEGLIGENCE) OR STRICT LIABILITY, ARISING OUT OF OR IN CONNECTION * WITH THE USE OR PERFORMANCE OF THIS SOFTWARE. * *//* 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;}
⌨️ 快捷键说明
复制代码
Ctrl + C
搜索代码
Ctrl + F
全屏模式
F11
切换主题
Ctrl + Shift + D
显示快捷键
?
增大字号
Ctrl + =
减小字号
Ctrl + -