3 * Program to add users en masse to the moira database
5 * by Mark Rosenstein, July 1992.
7 * Copyright (C) 1992-1998 by the Massachusetts Institute of Technology.
8 * For copying and distribution information, please see the file
12 #include <mit-copyright.h>
14 #include <moira_site.h>
24 #define DEFAULT_SHELL "/bin/athena/tcsh"
26 #define DEFAULT_SHELL "/bin/csh"
29 /* flags from command line */
30 char *class, *comment, *status_str, *shell, *filename;
31 int reg_only, reg, verbose, nodupcheck, securereg;
33 /* argument parsing macro */
34 #define argis(a, b) (!strcmp(*arg + 1, a) || !strcmp(*arg + 1, b))
37 int duplicate, errors;
39 extern int ureg_init(void);
40 extern int grab_login(char *first, char *last, char *idnumber,
41 char *hashidnumber, char *login);
42 extern int set_password(char *first, char *last, char *idnumber,
43 char *hashidnumber, char *password);
46 void usage(char **argv);
47 int usercheck(int argc, char **argv, void *qargv);
49 int main(int argc, char **argv)
52 char **arg = argv, *qargv[U_END];
53 char *motd, *p, *first, *middle, *last, *id, *login, *passwd, *server;
54 char buf[BUFSIZ], idbuf[32];
57 /* clear all flags & lists */
58 reg_only = reg = verbose = lineno = nodupcheck = errors = securereg = 0;
61 shell = DEFAULT_SHELL;
69 while (++arg - argv < argc)
73 if (argis("c", "class"))
75 if (arg - argv < argc - 1)
83 else if (argis("C", "comment"))
85 if (arg - argv < argc - 1)
93 else if (argis("s", "status"))
95 if (arg - argv < argc - 1)
103 else if (argis("h", "shell"))
105 if (arg - argv < argc - 1)
113 else if (argis("6", "secure"))
115 else if (argis("r", "reg_only"))
117 else if (argis("R", "register"))
119 else if (argis("f", "file"))
121 if (arg - argv < argc - 1)
129 else if (argis("v", "verbose"))
131 else if (argis("d", "nodupcheck"))
133 else if (argis("S", "server") || argis("db", "database"))
135 if (arg - argv < argc - 1)
150 if (!strcmp(filename, "-"))
154 input = fopen(filename, "r");
157 com_err(whoami, errno, "opening input file %s", filename);
165 if ((status = mr_connect(server)))
167 com_err(whoami, status, "unable to connect to the Moira server");
170 if ((status = mr_motd(&motd)))
172 com_err(whoami, status, "unable to check server status");
177 fprintf(stderr, "The Moira server is currently unavailable:\n%s\n",
183 if ((status = mr_auth("addusr")))
185 if (status == MR_USER_AUTH)
186 com_err(whoami, status, "");
189 com_err(whoami, status, "unable to authenticate to Moira");
198 qargv[U_NAME] = UNIQUE_LOGIN;
199 qargv[U_UID] = UNIQUE_UID;
200 qargv[U_SHELL] = shell;
201 qargv[U_STATE] = status_str;
202 qargv[U_CLASS] = class;
203 qargv[U_COMMENT] = comment;
204 qargv[U_SIGNATURE] = "";
205 qargv[U_SECURE] = securereg ? "1" : "0";
206 while (fgets(buf, BUFSIZ, input))
208 /* throw away terminating newline */
209 p = &buf[strlen(buf) - 1];
213 if (strlen(buf) == 0)
215 /* Last name is first thing on line */
217 /* First name follows a comma */
218 p = strchr(last, ',');
221 com_err(whoami, MR_BAD_CHAR, "Missing comma on line %d", lineno);
227 while (*p) /* find end-of-line */
235 com_err(whoami, 0, "Missing password on line %d", lineno);
239 passwd = strtrim(&p[1]);
241 /* previous field is login name */
248 com_err(whoami, 0, "Missing login on line %d", lineno);
252 login = strtrim(&p[1]);
257 /* ID is last thing on line */
266 com_err(whoami, 0, "Missing ID on line %d", lineno);
272 /* If something between first name & ID, it's middle name */
284 qargv[U_FIRST] = strtrim(first);
285 qargv[U_MIDDLE] = strtrim(middle);
286 qargv[U_LAST] = strtrim(last);
287 qargv[U_MITID] = strtrim(id);
288 FixCase(qargv[U_FIRST]);
289 FixCase(qargv[U_MIDDLE]);
290 FixCase(qargv[U_LAST]);
291 RemoveHyphens(qargv[U_MITID]);
298 dargv[0] = qargv[U_FIRST];
299 dargv[1] = qargv[U_LAST];
301 status = mr_query("get_user_account_by_name", 2, dargv,
303 if (status && status != MR_NO_MATCH)
305 com_err(whoami, status,
306 "checking to see if user %s %s already exists",
308 com_err(whoami, 0, "NOT ADDING USER");
314 com_err(whoami, MR_EXISTS, "user %s %s already exists",
316 com_err(whoami, 0, "NOT ADDING USER");
320 else if (duplicate < 0)
322 com_err(whoami, MR_EXISTS,
323 "user %s %s already exists with different ID number",
324 qargv[U_FIRST], qargv[U_LAST]);
325 com_err(whoami, 0, "ADDING user anyway");
328 status = mr_query("add_user_account", U_SECURE + 1, qargv,
332 com_err(whoami, status, "adding user %s %s", first, last);
337 printf("Added user %s %s %s (%s)\n", qargv[U_FIRST],
338 qargv[U_MIDDLE], qargv[U_LAST], qargv[U_MITID]);
343 EncryptID(idbuf, qargv[U_MITID], qargv[U_FIRST], qargv[U_LAST]);
344 status = grab_login(qargv[U_FIRST], qargv[U_LAST],
345 qargv[U_MITID], idbuf, login);
348 com_err(whoami, status, "while registering (login) %s %s",
349 qargv[U_FIRST], qargv[U_LAST]);
355 printf("Registered user %s %s as %s\n", qargv[U_FIRST],
356 qargv[U_LAST], login);
358 status = set_password(qargv[U_FIRST], qargv[U_LAST],
359 qargv[U_MITID], idbuf, passwd);
362 com_err(whoami, status, "While registering (passwd) %s %s",
363 qargv[U_FIRST], qargv[U_LAST]);
367 printf("Set password for user %s\n", login);
375 void usage(char **argv)
377 fprintf(stderr, "Usage: %s [options]\n", argv[0]);
378 fprintf(stderr, "Options are\n");
379 fprintf(stderr, " -f | -file filename (default STDIN)\n");
380 fprintf(stderr, " -c | -class class (default TEMP)\n");
381 fprintf(stderr, " -C | -comment \"comment\" (default \"\")\n");
382 fprintf(stderr, " -s | -status status (default 0)\n");
383 fprintf(stderr, " -h | -shell shell (default %s)\n", DEFAULT_SHELL);
384 fprintf(stderr, " -r | -reg_only\n");
385 fprintf(stderr, " -R | -register (and add to database)\n");
386 fprintf(stderr, " -v | -verbose\n");
387 fprintf(stderr, " -d | -nodupcheck (don't check for duplicates)\n");
388 fprintf(stderr, " -db | -database host:port\n");
393 /* query callback routine to check for duplicate users */
395 int usercheck(int argc, char **argv, void *qargv)
397 if (!strcmp(argv[U_MITID], ((char **)qargv)[U_MITID]))