1d6f907dcSJoerg Wunsch /*- 2ad7cf975SJoerg Wunsch * Copyright (C) 1996 3ad7cf975SJoerg Wunsch * David L. Nugent. 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 9ad7cf975SJoerg Wunsch * notice, this list of conditions and the following disclaimer. 10d6f907dcSJoerg Wunsch * 2. Redistributions in binary form must reproduce the above copyright 11d6f907dcSJoerg Wunsch * notice, this list of conditions and the following disclaimer in the 12d6f907dcSJoerg Wunsch * documentation and/or other materials provided with the distribution. 13d6f907dcSJoerg Wunsch * 14ad7cf975SJoerg Wunsch * THIS SOFTWARE IS PROVIDED BY DAVID L. NUGENT AND CONTRIBUTORS ``AS IS'' AND 15d6f907dcSJoerg Wunsch * ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE 16d6f907dcSJoerg Wunsch * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE 17ad7cf975SJoerg Wunsch * ARE DISCLAIMED. IN NO EVENT SHALL DAVID L. NUGENT OR CONTRIBUTORS BE LIABLE 18d6f907dcSJoerg Wunsch * FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL 19d6f907dcSJoerg Wunsch * DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS 20d6f907dcSJoerg Wunsch * OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) 21d6f907dcSJoerg Wunsch * HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT 22d6f907dcSJoerg Wunsch * LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY 23d6f907dcSJoerg Wunsch * OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF 24d6f907dcSJoerg Wunsch * SUCH DAMAGE. 25d6f907dcSJoerg Wunsch * 2697d92980SPeter Wemm * $FreeBSD$ 27d6f907dcSJoerg Wunsch */ 28d6f907dcSJoerg Wunsch 29d6f907dcSJoerg Wunsch #include <stdio.h> 30d6f907dcSJoerg Wunsch #include <stdlib.h> 31d6f907dcSJoerg Wunsch #include <string.h> 32d6f907dcSJoerg Wunsch #include <unistd.h> 33d6f907dcSJoerg Wunsch #include <stdarg.h> 34d6f907dcSJoerg Wunsch #include <errno.h> 35d6f907dcSJoerg Wunsch #include <sys/types.h> 36d6f907dcSJoerg Wunsch #include <sys/stat.h> 375f12594aSDavid Nugent #include <sys/param.h> 38d6f907dcSJoerg Wunsch #include <pwd.h> 39d6f907dcSJoerg Wunsch #include <grp.h> 40d6f907dcSJoerg Wunsch #include <sys/queue.h> 4148aee7f3SJoerg Wunsch #include <sysexits.h> 42d6f907dcSJoerg Wunsch 43d6f907dcSJoerg Wunsch #include "psdate.h" 445f12594aSDavid Nugent #include "pwupd.h" 45d6f907dcSJoerg Wunsch 46d6f907dcSJoerg Wunsch enum _mode 47d6f907dcSJoerg Wunsch { 48d6f907dcSJoerg Wunsch M_ADD, 49d6f907dcSJoerg Wunsch M_DELETE, 50d6f907dcSJoerg Wunsch M_UPDATE, 51d6f907dcSJoerg Wunsch M_PRINT, 5248aee7f3SJoerg Wunsch M_NEXT, 532399cd14SDavid Nugent M_LOCK, 542399cd14SDavid Nugent M_UNLOCK, 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 struct carg 66d6f907dcSJoerg Wunsch { 67d6f907dcSJoerg Wunsch int ch; 68d6f907dcSJoerg Wunsch char *val; 69e3975643SJake Burkholder LIST_ENTRY(carg) list; 70d6f907dcSJoerg Wunsch }; 71d6f907dcSJoerg Wunsch 723ce1d6bbSStefan Farfeleder LIST_HEAD(cargs, carg); 73d6f907dcSJoerg Wunsch 74d6f907dcSJoerg Wunsch struct userconf 75d6f907dcSJoerg Wunsch { 76d6f907dcSJoerg Wunsch int default_password; /* Default password for new users? */ 77d6f907dcSJoerg Wunsch int reuse_uids; /* Reuse uids? */ 78d6f907dcSJoerg Wunsch int reuse_gids; /* Reuse gids? */ 79f1d684faSDavid Nugent char *nispasswd; /* Path to NIS version of the passwd file */ 80d6f907dcSJoerg Wunsch char *dotdir; /* Where to obtain skeleton files */ 81d6f907dcSJoerg Wunsch char *newmail; /* Mail to send to new accounts */ 82d6f907dcSJoerg Wunsch char *logfile; /* Where to log changes */ 83d6f907dcSJoerg Wunsch char *home; /* Where to create home directory */ 8485204142SLukas Ertl mode_t homemode; /* Home directory permissions */ 85d6f907dcSJoerg Wunsch char *shelldir; /* Where shells are located */ 86d6f907dcSJoerg Wunsch char **shells; /* List of shells */ 87d6f907dcSJoerg Wunsch char *shell_default; /* Default shell */ 88d6f907dcSJoerg Wunsch char *default_group; /* Default group number */ 89d6f907dcSJoerg Wunsch char **groups; /* Default (additional) groups */ 90d6f907dcSJoerg Wunsch char *default_class; /* Default user class */ 91d6f907dcSJoerg Wunsch uid_t min_uid, max_uid; /* Allowed range of uids */ 92d6f907dcSJoerg Wunsch gid_t min_gid, max_gid; /* Allowed range of gids */ 93d6f907dcSJoerg Wunsch int expire_days; /* Days to expiry */ 94d6f907dcSJoerg Wunsch int password_days; /* Days to password expiry */ 950970881fSDavid Nugent int numgroups; /* (internal) size of default_group array */ 96d6f907dcSJoerg Wunsch }; 97d6f907dcSJoerg Wunsch 98*644af48dSJung-uk Kim #define _DEF_DIRMODE (S_IRWXU | S_IRWXG | S_IRWXO) 99d6f907dcSJoerg Wunsch #define _PATH_PW_CONF "/etc/pw.conf" 100d6f907dcSJoerg Wunsch #define _UC_MAXLINE 1024 101d6f907dcSJoerg Wunsch #define _UC_MAXSHELLS 32 102d6f907dcSJoerg Wunsch 103d6f907dcSJoerg Wunsch struct userconf *read_userconfig(char const * file); 104d6f907dcSJoerg Wunsch int write_userconfig(char const * file); 105d6f907dcSJoerg Wunsch struct carg *addarg(struct cargs * _args, int ch, char *argstr); 106d6f907dcSJoerg Wunsch struct carg *getarg(struct cargs * _args, int ch); 107d6f907dcSJoerg Wunsch 108d6f907dcSJoerg Wunsch int pw_user(struct userconf * cnf, int mode, struct cargs * _args); 109d6f907dcSJoerg Wunsch int pw_group(struct userconf * cnf, int mode, struct cargs * _args); 110d9b711b7SDavid Nugent char *pw_checkname(u_char *name, int gecos); 111d6f907dcSJoerg Wunsch 112d6f907dcSJoerg Wunsch int addpwent(struct passwd * pwd); 113d6f907dcSJoerg Wunsch int delpwent(struct passwd * pwd); 114d6f907dcSJoerg Wunsch int chgpwent(char const * login, struct passwd * pwd); 115d6f907dcSJoerg Wunsch int fmtpwent(char *buf, struct passwd * pwd); 116d6f907dcSJoerg Wunsch 117f1d684faSDavid Nugent int addnispwent(const char *path, struct passwd *pwd); 118f1d684faSDavid Nugent int delnispwent(const char *path, const char *login); 119f1d684faSDavid Nugent int chgnispwent(const char *path, const char *login, struct passwd *pwd); 120f1d684faSDavid Nugent 121d6f907dcSJoerg Wunsch int addgrent(struct group * grp); 122d6f907dcSJoerg Wunsch int delgrent(struct group * grp); 123d6f907dcSJoerg Wunsch int chggrent(char const * login, struct group * grp); 124d6f907dcSJoerg Wunsch 125d6f907dcSJoerg Wunsch int boolean_val(char const * str, int dflt); 126d6f907dcSJoerg Wunsch char const *boolean_str(int val); 127d6f907dcSJoerg Wunsch char *newstr(char const * p); 128d6f907dcSJoerg Wunsch 129cab0fb4eSKris Kennaway void pw_log(struct userconf * cnf, int mode, int which, char const * fmt,...) __printflike(4, 5); 130d6f907dcSJoerg Wunsch char *pw_pwcrypt(char *password); 131d6f907dcSJoerg Wunsch 132d6f907dcSJoerg Wunsch extern const char *Modes[]; 133d6f907dcSJoerg Wunsch extern const char *Which[]; 134