/* permsfile.c: implement SunOS /etc/fbtab and Solaris /etc/logindevperm functionality to set device permissions on login %%% portions-copyright-cmetz-96 Portions of this software are Copyright 1996-1999 by Craig Metz, All Rights Reserved. The Inner Net License Version 2 applies to these portions of the software. You should have received a copy of the license with this software. If you didn't get a copy, you may request one from . Portions of this software are Copyright 1995 by Randall Atkinson and Dan McDonald, All Rights Reserved. All Rights under this copyright are assigned to the U.S. Naval Research Laboratory (NRL). The NRL Copyright Notice and License Agreement applies to this software. History: Modified by cmetz for OPIE 2.31. Include unistd.h. Modified by cmetz for OPIE 2.3. Check for NULL return from ftpglob(), combine some expressions, fix a typo. Made file selection a bit more generic. Modified by cmetz for OPIE 2.2. Use FUNCTION declaration et al. Add opie.h. Ifdef around a header. Written at NRL for OPIE 2.0. */ #include "opie_cfg.h" #ifdef HAVE_LOGIN_PERMFILE #include #include #if HAVE_STRING_H #include #endif /* HAVE_STRING_H */ #if HAVE_UNISTD_H #include #endif /* HAVE_UNISTD_H */ #include #include "opie.h" /* Line buffer size (one more than max line length) */ #define BUFSIZE 128 /* Maximum number of list items in a field */ #define LISTSIZE 10 static char buf[BUFSIZE], buf2[8]; char **ftpglob __P((char *)); VOIDRET opiefatal FUNCTION((x), char *x) { fprintf(stderr, x); exit(1); } #include "glob.c" static int getalist FUNCTION((string, list), char **string AND char **list) { char *s = *string; int i = 0; while (*s && (*s != '\n') && (*s != ' ') && (*s != '\t')) if ((*s == ':') || (*s == ',')) { *(s++) = 0; list[i++] = *string; *string = s; if (i == LISTSIZE) return i; } else s++; if ((int) (s) - (int) (*string)) { *s = 0; list[i++] = *string; } *string = ++s; return i; } static VOIDRET doaline FUNCTION((line, name, ttyn, uid, gid), char *line AND char *name AND char *ttyn AND uid_t uid AND gid_t gid) { char *ptr; int i; int applies, llen; char *listbuf[LISTSIZE], **globlist; if (ptr = strchr(buf, '#')) *ptr = 0; /* Skip whitespace */ for (ptr = buf; *ptr && ((*ptr == ' ') || (*ptr == '\t')); ptr++); if (!*ptr) return; /* (Optional) Field 1: user name(s) */ if ((*ptr != '/') && (*ptr != '~')) { llen = getalist(&ptr, listbuf); for (applies = i = 0; (i < llen) && !applies; i++) if (!strcmp(listbuf[i], name)) applies++; while (*ptr && ((*ptr == ' ') || (*ptr == '\t'))) ptr++; if (!applies || !*ptr) return; } /* Field 2: terminal(s) */ llen = getalist(&ptr, listbuf); for (applies = i = 0; (i < llen) && !applies; i++) if (!strcmp(listbuf[i], ttyn)) applies++; while (*ptr && ((*ptr == ' ') || (*ptr == '\t'))) ptr++; if (!applies || !*ptr) return; /* Field 3: mode */ for (applies = 0; *ptr && (*ptr >= '0') && (*ptr <= '7'); applies = (applies << 3) | (*(ptr++) - '0')); while (*ptr && ((*ptr == ' ') || (*ptr == '\t'))) ptr++; if (!*ptr) return; /* Field 4: devices (the fun part...) */ llen = getalist(&ptr, listbuf); for (i = 0; i < llen; i++) { if (globlist = ftpglob(listbuf[i])) while (*globlist) { #ifdef DEBUG syslog(LOG_DEBUG, "setting %s to %d/%d %o", *globlist, uid, gid, applies); #endif /* DEBUG */ if ((chown(*globlist, uid, gid) < 0) && (errno != ENOENT)) perror("chown"); if ((chmod(*(globlist++), applies) < 0) && (errno != ENOENT)) perror("chmod"); } } } VOIDRET permsfile FUNCTION((name, ttyn, uid, gid), char *name AND char *ttyn AND uid_t uid AND gid_t gid) { FILE *fh; if (!(fh = fopen(HAVE_LOGIN_PERMFILE, "r"))) { syslog(LOG_ERR, "Can't open %s!", HAVE_LOGIN_PERMFILE); fprintf(stderr, "Warning: Can't set device permissions.\n"); return; } do { if (feof(fh)) return; if (fgets(buf, BUFSIZE, fh) == NULL) return; buf[BUFSIZE] = 0; doaline(buf, name, ttyn, uid, gid); } while (1); } #endif /* HAVE_LOGIN_PERMFILE */