1d6f907dcSJoerg Wunsch /*- 2d6f907dcSJoerg Wunsch * Copyright (c) 1996 by David L. Nugent <davidn@blaze.net.au>. 3d6f907dcSJoerg Wunsch * All rights reserved. 4d6f907dcSJoerg Wunsch * 5d6f907dcSJoerg Wunsch * Redistribution and use in source and binary forms, with or without 6d6f907dcSJoerg Wunsch * modification, are permitted provided that the following conditions 7d6f907dcSJoerg Wunsch * are met: 8d6f907dcSJoerg Wunsch * 1. Redistributions of source code must retain the above copyright 9d6f907dcSJoerg Wunsch * notice, this list of conditions and the following disclaimer as 10d6f907dcSJoerg Wunsch * the first lines of this file unmodified. 11d6f907dcSJoerg Wunsch * 2. Redistributions in binary form must reproduce the above copyright 12d6f907dcSJoerg Wunsch * notice, this list of conditions and the following disclaimer in the 13d6f907dcSJoerg Wunsch * documentation and/or other materials provided with the distribution. 14d6f907dcSJoerg Wunsch * 3. All advertising materials mentioning features or use of this software 15d6f907dcSJoerg Wunsch * must display the following acknowledgement: 16d6f907dcSJoerg Wunsch * This product includes software developed by David L. Nugent. 17d6f907dcSJoerg Wunsch * 4. The name of the author may not be used to endorse or promote products 18d6f907dcSJoerg Wunsch * derived from this software without specific prior written permission. 19d6f907dcSJoerg Wunsch * 20d6f907dcSJoerg Wunsch * THIS SOFTWARE IS PROVIDED BY THE DAVID L. NUGENT ``AS IS'' AND 21d6f907dcSJoerg Wunsch * ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE 22d6f907dcSJoerg Wunsch * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE 23d6f907dcSJoerg Wunsch * ARE DISCLAIMED. IN NO EVENT SHALL DAVID L. NUGENT BE LIABLE 24d6f907dcSJoerg Wunsch * FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL 25d6f907dcSJoerg Wunsch * DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS 26d6f907dcSJoerg Wunsch * OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) 27d6f907dcSJoerg Wunsch * HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT 28d6f907dcSJoerg Wunsch * LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY 29d6f907dcSJoerg Wunsch * OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF 30d6f907dcSJoerg Wunsch * SUCH DAMAGE. 31d6f907dcSJoerg Wunsch * 32d6f907dcSJoerg Wunsch * $Id$ 33d6f907dcSJoerg Wunsch */ 34d6f907dcSJoerg Wunsch 35d6f907dcSJoerg Wunsch #include <stdio.h> 36d6f907dcSJoerg Wunsch #include <stdlib.h> 37d6f907dcSJoerg Wunsch #include <string.h> 38d6f907dcSJoerg Wunsch #include <unistd.h> 39d6f907dcSJoerg Wunsch #include <stdarg.h> 40d6f907dcSJoerg Wunsch #include <errno.h> 41d6f907dcSJoerg Wunsch #include <sys/types.h> 42d6f907dcSJoerg Wunsch #include <sys/stat.h> 43d6f907dcSJoerg Wunsch #include <pwd.h> 44d6f907dcSJoerg Wunsch #include <grp.h> 45d6f907dcSJoerg Wunsch #include <sys/queue.h> 46d6f907dcSJoerg Wunsch 47d6f907dcSJoerg Wunsch #include "psdate.h" 48d6f907dcSJoerg Wunsch 49d6f907dcSJoerg Wunsch enum _mode 50d6f907dcSJoerg Wunsch { 51d6f907dcSJoerg Wunsch M_ADD, 52d6f907dcSJoerg Wunsch M_DELETE, 53d6f907dcSJoerg Wunsch M_UPDATE, 54d6f907dcSJoerg Wunsch M_PRINT, 55d6f907dcSJoerg Wunsch M_NUM 56d6f907dcSJoerg Wunsch }; 57d6f907dcSJoerg Wunsch 58d6f907dcSJoerg Wunsch enum _which 59d6f907dcSJoerg Wunsch { 60d6f907dcSJoerg Wunsch W_USER, 61d6f907dcSJoerg Wunsch W_GROUP, 62d6f907dcSJoerg Wunsch W_NUM 63d6f907dcSJoerg Wunsch }; 64d6f907dcSJoerg Wunsch 65d6f907dcSJoerg Wunsch enum _excode 66d6f907dcSJoerg Wunsch { 67d6f907dcSJoerg Wunsch X_ALLOK, 68d6f907dcSJoerg Wunsch X_CMDERR, 69d6f907dcSJoerg Wunsch X_PERMERR, 70d6f907dcSJoerg Wunsch X_MEMERR, 71d6f907dcSJoerg Wunsch X_NOUPDATE, 72d6f907dcSJoerg Wunsch X_NOTFOUND, 73d6f907dcSJoerg Wunsch X_UPDERROR, 74d6f907dcSJoerg Wunsch X_TOOMANY, 75d6f907dcSJoerg Wunsch X_EXISTS, 76d6f907dcSJoerg Wunsch X_DBERROR, 77d6f907dcSJoerg Wunsch X_CONFIG 78d6f907dcSJoerg Wunsch }; 79d6f907dcSJoerg Wunsch 80d6f907dcSJoerg Wunsch struct carg 81d6f907dcSJoerg Wunsch { 82d6f907dcSJoerg Wunsch int ch; 83d6f907dcSJoerg Wunsch char *val; 84d6f907dcSJoerg Wunsch LIST_ENTRY(carg) list; 85d6f907dcSJoerg Wunsch }; 86d6f907dcSJoerg Wunsch 87d6f907dcSJoerg Wunsch extern LIST_HEAD(cargs, carg) arglist; 88d6f907dcSJoerg Wunsch 89d6f907dcSJoerg Wunsch struct userconf 90d6f907dcSJoerg Wunsch { 91d6f907dcSJoerg Wunsch int default_password; /* Default password for new users? */ 92d6f907dcSJoerg Wunsch int reuse_uids; /* Reuse uids? */ 93d6f907dcSJoerg Wunsch int reuse_gids; /* Reuse gids? */ 94d6f907dcSJoerg Wunsch char *dotdir; /* Where to obtain skeleton files */ 95d6f907dcSJoerg Wunsch char *newmail; /* Mail to send to new accounts */ 96d6f907dcSJoerg Wunsch char *logfile; /* Where to log changes */ 97d6f907dcSJoerg Wunsch char *home; /* Where to create home directory */ 98d6f907dcSJoerg Wunsch char *shelldir; /* Where shells are located */ 99d6f907dcSJoerg Wunsch char **shells; /* List of shells */ 100d6f907dcSJoerg Wunsch char *shell_default; /* Default shell */ 101d6f907dcSJoerg Wunsch char *default_group; /* Default group number */ 102d6f907dcSJoerg Wunsch char **groups; /* Default (additional) groups */ 103d6f907dcSJoerg Wunsch char *default_class; /* Default user class */ 104d6f907dcSJoerg Wunsch uid_t min_uid, max_uid; /* Allowed range of uids */ 105d6f907dcSJoerg Wunsch gid_t min_gid, max_gid; /* Allowed range of gids */ 106d6f907dcSJoerg Wunsch int expire_days; /* Days to expiry */ 107d6f907dcSJoerg Wunsch int password_days; /* Days to password expiry */ 108d6f907dcSJoerg Wunsch }; 109d6f907dcSJoerg Wunsch 110d6f907dcSJoerg Wunsch #define _PATH_PW_CONF "/etc/pw.conf" 111d6f907dcSJoerg Wunsch #define _UC_MAXLINE 1024 112d6f907dcSJoerg Wunsch #define _UC_MAXSHELLS 32 113d6f907dcSJoerg Wunsch #define _UC_MAXGROUPS 200 114d6f907dcSJoerg Wunsch 115d6f907dcSJoerg Wunsch struct userconf *read_userconfig(char const * file); 116d6f907dcSJoerg Wunsch int write_userconfig(char const * file); 117d6f907dcSJoerg Wunsch struct carg *addarg(struct cargs * _args, int ch, char *argstr); 118d6f907dcSJoerg Wunsch struct carg *getarg(struct cargs * _args, int ch); 119d6f907dcSJoerg Wunsch void cmderr(int ec, char const * fmt,...); 120d6f907dcSJoerg Wunsch 121d6f907dcSJoerg Wunsch int pw_user(struct userconf * cnf, int mode, struct cargs * _args); 122d6f907dcSJoerg Wunsch int pw_group(struct userconf * cnf, int mode, struct cargs * _args); 123d6f907dcSJoerg Wunsch 124d6f907dcSJoerg Wunsch int addpwent(struct passwd * pwd); 125d6f907dcSJoerg Wunsch int delpwent(struct passwd * pwd); 126d6f907dcSJoerg Wunsch int chgpwent(char const * login, struct passwd * pwd); 127d6f907dcSJoerg Wunsch int fmtpwent(char *buf, struct passwd * pwd); 128d6f907dcSJoerg Wunsch 129d6f907dcSJoerg Wunsch int addgrent(struct group * grp); 130d6f907dcSJoerg Wunsch int delgrent(struct group * grp); 131d6f907dcSJoerg Wunsch int chggrent(char const * login, struct group * grp); 132d6f907dcSJoerg Wunsch int fmtgrent(char *buf, struct group * grp); 133d6f907dcSJoerg Wunsch 134d6f907dcSJoerg Wunsch int boolean_val(char const * str, int dflt); 135d6f907dcSJoerg Wunsch char const *boolean_str(int val); 136d6f907dcSJoerg Wunsch char *newstr(char const * p); 137d6f907dcSJoerg Wunsch 138d6f907dcSJoerg Wunsch void pw_log(struct userconf * cnf, int mode, int which, char const * fmt,...); 139d6f907dcSJoerg Wunsch char *pw_pwcrypt(char *password); 140d6f907dcSJoerg Wunsch 141d6f907dcSJoerg Wunsch extern const char *Modes[]; 142d6f907dcSJoerg Wunsch extern const char *Which[]; 143