#include "stdio.h"
#include "errno.h"
#include "string.h"
#include "stdlib.h"
#include "lp.h"
#include "access.h"
static char **_loadaccess ( char * );
int
load_userform_access(char *form, char ***pallow, char ***pdeny)
{
return (loadaccess(Lp_A_Forms, form, "", pallow, pdeny));
}
int
load_userprinter_access(char *printer, char ***pallow, char ***pdeny)
{
return (loadaccess(Lp_A_Printers, printer, UACCESSPREFIX, pallow,
pdeny));
}
int
load_formprinter_access(char *printer, char ***pallow, char ***pdeny)
{
return (loadaccess(Lp_A_Printers, printer, FACCESSPREFIX, pallow,
pdeny));
}
int
load_paperprinter_access(char *printer, char ***pallow, char ***pdeny)
{
return (loadaccess(Lp_A_Printers, printer, PACCESSPREFIX, pallow,
pdeny));
}
int
loadaccess(char *dir, char *name, char *prefix, char ***pallow, char ***pdeny)
{
register char *allow_file = 0,
*deny_file = 0;
int ret;
if (
!(allow_file = getaccessfile(dir, name, prefix, ALLOWFILE))
|| !(*pallow = _loadaccess(allow_file)) && errno != ENOENT
|| !(deny_file = getaccessfile(dir, name, prefix, DENYFILE))
|| !(*pdeny = _loadaccess(deny_file)) && errno != ENOENT
)
ret = -1;
else
ret = 0;
if (allow_file)
Free (allow_file);
if (deny_file)
Free (deny_file);
return (ret);
}
static char **
_loadaccess(char *file)
{
register size_t nalloc,
nlist;
register char **list;
int fd;
char buf[BUFSIZ];
if ((fd = open_locked(file, "r", 0)) < 0)
return (0);
nalloc = ACC_MAX_GUESS;
list = (char **)Malloc((nalloc + 1) * sizeof(char *));
if (!list) {
close(fd);
errno = ENOMEM;
return (0);
}
errno = 0;
for (nlist = 0; fdgets(buf, BUFSIZ, fd); ) {
buf[strlen(buf) - 1] = 0;
if (nlist >= nalloc) {
nalloc += ACC_MAX_GUESS;
list = (char **)Realloc(
(char *)list,
(nalloc + 1) * sizeof(char *)
);
if (!list) {
close(fd);
return (0);
}
}
list[nlist] = Strdup(buf);
list[++nlist] = 0;
}
if (errno != 0) {
int save_errno = errno;
close(fd);
freelist (list);
errno = save_errno;
return (0);
}
close(fd);
if (nlist != nalloc) {
list = (char **)Realloc(
(char *)list,
(nlist + 1) * sizeof(char *)
);
if (!list) {
errno = ENOMEM;
return (0);
}
}
list[nlist] = 0;
return (list);
}