diff options
author | jacobs <none@none> | 2006-06-22 13:28:31 -0700 |
---|---|---|
committer | jacobs <none@none> | 2006-06-22 13:28:31 -0700 |
commit | 355b4669e025ff377602b6fc7caaf30dbc218371 (patch) | |
tree | 29a740456e8d09f935e18068ce72814285fafeec /usr/src/lib/print/libprint/common/misc.c | |
parent | 5d0bc3ededb82d77f7c33d8f58e517a837ba5140 (diff) | |
download | illumos-gate-355b4669e025ff377602b6fc7caaf30dbc218371.tar.gz |
LSARC/2003/547 PAPI Print Commands
LSARC/2006/172 PAPI Print Commands Packaging Breakout
4144591 lpstat -d reports *process* default printer as *system* default printer
4299193 lp -cd <queue> <file> causes multiple -d options errors
4327963 RFE cancel on local queue should not require in.lpd
4331220 lpmove doesn't work on remote print queues
4470602 Customer wants to increase print limit of 52 files to 300
4949866 lpstat shows FAILED printers due to expanded status message
4994469 lpadmin doesn't add filter definitions for printers
6302778 RUNPATH & RPATH errors in SUNWipplu package
6314007 lpstat should report paper type list supported by a printer
6317991 lprm -Pprintername - command results in aSegmentation fault
6338002 lpsched support for PAPI is incomplete
6346505 print commands should use PAPI for service interaction (LSARC/2003/547)
6364267 psm-lpsched has replicated code
6389273 RUNPATH and RPATH failures in SUNWippcore
--HG--
rename : usr/src/cmd/lp/cmd/cancel.c => deleted_files/usr/src/cmd/lp/cmd/cancel.c
rename : usr/src/cmd/lp/cmd/comb.c => deleted_files/usr/src/cmd/lp/cmd/comb.c
rename : usr/src/cmd/lp/cmd/lp.c => deleted_files/usr/src/cmd/lp/cmd/lp.c
rename : usr/src/cmd/lp/cmd/lpc/Makefile => deleted_files/usr/src/cmd/lp/cmd/lpc/Makefile
rename : usr/src/cmd/lp/cmd/lpc/cmds.c => deleted_files/usr/src/cmd/lp/cmd/lpc/cmds.c
rename : usr/src/cmd/lp/cmd/lpc/cmdtab.c => deleted_files/usr/src/cmd/lp/cmd/lpc/cmdtab.c
rename : usr/src/cmd/lp/cmd/lpc/fatalmsg.c => deleted_files/usr/src/cmd/lp/cmd/lpc/fatalmsg.c
rename : usr/src/cmd/lp/cmd/lpc/global.c => deleted_files/usr/src/cmd/lp/cmd/lpc/global.c
rename : usr/src/cmd/lp/cmd/lpc/lpc.c => deleted_files/usr/src/cmd/lp/cmd/lpc/lpc.c
rename : usr/src/cmd/lp/cmd/lpc/lpc.h => deleted_files/usr/src/cmd/lp/cmd/lpc/lpc.h
rename : usr/src/cmd/lp/cmd/lpc/process.c => deleted_files/usr/src/cmd/lp/cmd/lpc/process.c
rename : usr/src/cmd/lp/cmd/lpc/sndrcv.c => deleted_files/usr/src/cmd/lp/cmd/lpc/sndrcv.c
rename : usr/src/cmd/lp/cmd/lpc/topq.c => deleted_files/usr/src/cmd/lp/cmd/lpc/topq.c
rename : usr/src/cmd/lp/cmd/lpmove.c => deleted_files/usr/src/cmd/lp/cmd/lpmove.c
rename : usr/src/cmd/lp/cmd/lpstat/Makefile => deleted_files/usr/src/cmd/lp/cmd/lpstat/Makefile
rename : usr/src/cmd/lp/cmd/lpstat/accept.c => deleted_files/usr/src/cmd/lp/cmd/lpstat/accept.c
rename : usr/src/cmd/lp/cmd/lpstat/add_mounted.c => deleted_files/usr/src/cmd/lp/cmd/lpstat/add_mounted.c
rename : usr/src/cmd/lp/cmd/lpstat/charset.c => deleted_files/usr/src/cmd/lp/cmd/lpstat/charset.c
rename : usr/src/cmd/lp/cmd/lpstat/class.c => deleted_files/usr/src/cmd/lp/cmd/lpstat/class.c
rename : usr/src/cmd/lp/cmd/lpstat/device.c => deleted_files/usr/src/cmd/lp/cmd/lpstat/device.c
rename : usr/src/cmd/lp/cmd/lpstat/done.c => deleted_files/usr/src/cmd/lp/cmd/lpstat/done.c
rename : usr/src/cmd/lp/cmd/lpstat/form.c => deleted_files/usr/src/cmd/lp/cmd/lpstat/form.c
rename : usr/src/cmd/lp/cmd/lpstat/lpstat.c => deleted_files/usr/src/cmd/lp/cmd/lpstat/lpstat.c
rename : usr/src/cmd/lp/cmd/lpstat/lpstat.h => deleted_files/usr/src/cmd/lp/cmd/lpstat/lpstat.h
rename : usr/src/cmd/lp/cmd/lpstat/output.c => deleted_files/usr/src/cmd/lp/cmd/lpstat/output.c
rename : usr/src/cmd/lp/cmd/lpstat/parse.c => deleted_files/usr/src/cmd/lp/cmd/lpstat/parse.c
rename : usr/src/cmd/lp/cmd/lpstat/printer.c => deleted_files/usr/src/cmd/lp/cmd/lpstat/printer.c
rename : usr/src/cmd/lp/cmd/lpstat/request.c => deleted_files/usr/src/cmd/lp/cmd/lpstat/request.c
rename : usr/src/cmd/lp/cmd/lpstat/send_message.c => deleted_files/usr/src/cmd/lp/cmd/lpstat/send_message.c
rename : usr/src/cmd/lp/lib/papi/attribute.c => deleted_files/usr/src/cmd/lp/lib/papi/attribute.c
rename : usr/src/cmd/lp/lib/papi/list.c => deleted_files/usr/src/cmd/lp/lib/papi/list.c
rename : usr/src/cmd/lp/lib/papi/papi.h => deleted_files/usr/src/cmd/lp/lib/papi/papi.h
rename : usr/src/cmd/lp/lib/papi/status.c => deleted_files/usr/src/cmd/lp/lib/papi/status.c
rename : usr/src/cmd/print/cancel/Makefile => deleted_files/usr/src/cmd/print/cancel/Makefile
rename : usr/src/cmd/print/cancel/cancel.c => deleted_files/usr/src/cmd/print/cancel/cancel.c
rename : usr/src/cmd/print/cancel/cancel_list.c => deleted_files/usr/src/cmd/print/cancel/cancel_list.c
rename : usr/src/cmd/print/cancel/cancel_list.h => deleted_files/usr/src/cmd/print/cancel/cancel_list.h
rename : usr/src/cmd/print/lp/Makefile => deleted_files/usr/src/cmd/print/lp/Makefile
rename : usr/src/cmd/print/lpmove/Makefile => deleted_files/usr/src/cmd/print/lpmove/Makefile
rename : usr/src/cmd/print/lpmove/lpmove.c => deleted_files/usr/src/cmd/print/lpmove/lpmove.c
rename : usr/src/cmd/print/lpstat/Makefile => deleted_files/usr/src/cmd/print/lpstat/Makefile
rename : usr/src/cmd/print/lpstat/bsd-functions.c => deleted_files/usr/src/cmd/print/lpstat/bsd-functions.c
rename : usr/src/cmd/print/lpstat/bsd-functions.h => deleted_files/usr/src/cmd/print/lpstat/bsd-functions.h
rename : usr/src/cmd/print/lpstat/lpstat.c => deleted_files/usr/src/cmd/print/lpstat/lpstat.c
rename : usr/src/cmd/print/lpstat/parse.h => deleted_files/usr/src/cmd/print/lpstat/parse.h
rename : usr/src/cmd/print/lpstat/parse_bsd.c => deleted_files/usr/src/cmd/print/lpstat/parse_bsd.c
rename : usr/src/cmd/print/lpstat/sysv-functions.c => deleted_files/usr/src/cmd/print/lpstat/sysv-functions.c
rename : usr/src/cmd/print/lpstat/sysv-functions.h => deleted_files/usr/src/cmd/print/lpstat/sysv-functions.h
rename : usr/src/cmd/print/scripts/accept => deleted_files/usr/src/cmd/print/scripts/accept
rename : usr/src/cmd/lp/lib/papi/mapfile-vers => usr/src/cmd/lp/lib/papi/mapfile
rename : usr/src/cmd/print/lp/cleanup.xml => usr/src/cmd/print/gateway/cleanup.xml
rename : usr/src/cmd/print/lp/print-cleanup => usr/src/cmd/print/gateway/print-cleanup
rename : usr/src/cmd/print/lp/lp.c => usr/src/cmd/print/gateway/printd.c
rename : usr/src/lib/print/job.c => usr/src/lib/print/libprint/common/job.c
rename : usr/src/lib/print/job.h => usr/src/lib/print/libprint/common/job.h
rename : usr/src/lib/print/list.c => usr/src/lib/print/libprint/common/list.c
rename : usr/src/lib/print/list.h => usr/src/lib/print/libprint/common/list.h
rename : usr/src/lib/print/llib-lprint => usr/src/lib/print/libprint/common/llib-lprint
rename : usr/src/lib/print/mapfile-vers => usr/src/lib/print/libprint/common/mapfile-vers
rename : usr/src/lib/print/misc.c => usr/src/lib/print/libprint/common/misc.c
rename : usr/src/lib/print/misc.h => usr/src/lib/print/libprint/common/misc.h
rename : usr/src/lib/print/network.c => usr/src/lib/print/libprint/common/network.c
rename : usr/src/lib/print/network.h => usr/src/lib/print/libprint/common/network.h
rename : usr/src/lib/print/ns.c => usr/src/lib/print/libprint/common/ns.c
rename : usr/src/lib/print/ns.h => usr/src/lib/print/libprint/common/ns.h
rename : usr/src/lib/print/ns_bsd_addr.c => usr/src/lib/print/libprint/common/ns_bsd_addr.c
rename : usr/src/lib/print/ns_cmn_kvp.c => usr/src/lib/print/libprint/common/ns_cmn_kvp.c
rename : usr/src/lib/print/ns_cmn_printer.c => usr/src/lib/print/libprint/common/ns_cmn_printer.c
rename : usr/src/lib/print/nss_convert.c => usr/src/lib/print/libprint/common/nss_convert.c
rename : usr/src/lib/print/nss_ldap.c => usr/src/lib/print/libprint/common/nss_ldap.c
rename : usr/src/lib/print/nss_printer.c => usr/src/lib/print/libprint/common/nss_printer.c
rename : usr/src/lib/print/nss_write.c => usr/src/lib/print/libprint/common/nss_write.c
rename : usr/src/lib/print/sunPrinter.at.conf.txt => usr/src/lib/print/libprint/common/sunPrinter.at.conf.txt
rename : usr/src/lib/print/sunPrinter.oc.conf.txt => usr/src/lib/print/libprint/common/sunPrinter.oc.conf.txt
Diffstat (limited to 'usr/src/lib/print/libprint/common/misc.c')
-rw-r--r-- | usr/src/lib/print/libprint/common/misc.c | 433 |
1 files changed, 433 insertions, 0 deletions
diff --git a/usr/src/lib/print/libprint/common/misc.c b/usr/src/lib/print/libprint/common/misc.c new file mode 100644 index 0000000000..f9d7e4e966 --- /dev/null +++ b/usr/src/lib/print/libprint/common/misc.c @@ -0,0 +1,433 @@ +/* + * CDDL HEADER START + * + * The contents of this file are subject to the terms of the + * Common Development and Distribution License (the "License"). + * You may not use this file except in compliance with the License. + * + * You can obtain a copy of the license at usr/src/OPENSOLARIS.LICENSE + * or http://www.opensolaris.org/os/licensing. + * See the License for the specific language governing permissions + * and limitations under the License. + * + * When distributing Covered Code, include this CDDL HEADER in each + * file and include the License file at usr/src/OPENSOLARIS.LICENSE. + * If applicable, add the following below this CDDL HEADER, with the + * fields enclosed by brackets "[]" replaced with your own identifying + * information: Portions Copyright [yyyy] [name of copyright owner] + * + * CDDL HEADER END + */ +/* + * Copyright 2006 Sun Microsystems, Inc. All rights reserved. + * Use is subject to license terms. + */ + +#pragma ident "%Z%%M% %I% %E% SMI" + +/*LINTLIBRARY*/ + +#include <stdio.h> +#include <stdlib.h> +#include <sys/types.h> +#include <sys/stat.h> +#include <signal.h> +#include <fcntl.h> +#include <unistd.h> +#include <string.h> +#include <pwd.h> +#include <sys/mman.h> +#include <time.h> +#include <syslog.h> +#include <errno.h> + +#include <misc.h> +#include <job.h> +#include <list.h> + + +/* + * info about spool directory that we validate and fix + */ +#define ROOT_UID 0 +#define LP_GID 8 +#define SPOOL_MODE (S_IFDIR|S_IRWXU|S_IRGRP|S_IXGRP|S_IROTH|S_IXOTH) + +/*ARGSUSED*/ +int +check_client_spool(char *printer) +{ + char *dir = SPOOL_DIR; + struct stat st; + + if ((stat(dir, &st) < 0) && (errno == ENOENT)) { + syslog(LOG_ERR, "no spool dir, creating %s", dir); + if (mkdir(dir, 0755) < 0) { + syslog(LOG_ERR, "mkdir(%s): %m", dir); + return (-1); + } + if (chown(dir, ROOT_UID, LP_GID) < 0) { + syslog(LOG_ERR, "chown(%s): %m", dir); + return (-1); + } + return (0); + } + if ((st.st_uid != ROOT_UID) || (st.st_gid != LP_GID)) { + syslog(LOG_ERR, + "correcting spool directory owner/group (was %d/%d)", + st.st_uid, st.st_gid); + if (chown(dir, ROOT_UID, LP_GID) < 0) { + syslog(LOG_ERR, "chown(%s): %m", dir); + return (-1); + } + } + if (st.st_mode != (S_IFDIR | SPOOL_MODE)) { + syslog(LOG_ERR, + "spool dir (%s), incorrect permission (%0), correcting", + dir, st.st_mode); + if (chmod(dir, 0755) < 0) { + syslog(LOG_ERR, "chmod(%s): %m", dir); + return (-1); + } + } + return (0); +} + +int +get_lock(char *name, int write_pid) +{ + int fd; + + syslog(LOG_DEBUG, "get_lock(%s, %d)", ((name != NULL) ? name : "NULL"), + write_pid); + if ((fd = open(name, O_RDWR|O_CREAT, 0640)) < 0) + return (fd); + + if (lockf(fd, F_TLOCK, 0) < 0) { + close(fd); + return (-1); + } + + if (write_pid != 0) { + char pid[16]; + + if (ftruncate(fd, 0) < 0) { + close(fd); + return (-1); + } + if (snprintf(pid, sizeof (pid), "%d\n", (int)getpid()) + >= sizeof (pid)) { + syslog(LOG_ERR, "get_lock: pid buffer overflow"); + return (-1); + } + write(fd, pid, strlen(pid)); + } + (void) fsync(fd); + + syslog(LOG_DEBUG, "get_lock(%s, %d) - have lock", + ((name != NULL) ? name : "NULL"), write_pid); + return (fd); +} + +uid_t +get_user_id(char *name) +{ + struct passwd *p = NULL; + + if (name == NULL) + return (-1); + if ((p = getpwnam(name)) != NULL) + return (p->pw_uid); + else if ((p = getpwnam("nobody")) != NULL) + return (p->pw_uid); + else + return (-2); +} + + +/* + * get_user_name() + */ +char * +get_user_name() +{ + struct passwd *p = NULL; + + if ((p = getpwuid(getuid())) != NULL) + return (strdup(p->pw_name)); + else + return (strdup("unknown")); +} + + + +/* + * strcdup() - duplicate a string up to the first occurence of a character + */ +char * +strcdup(char *p, char c) +{ + char *q, + *r; + + if (p == NULL) + return (NULL); + if ((c == NULL) || ((q = strchr(p, c)) == NULL)) + return (strdup(p)); + + if ((r = malloc((q - p) + 1)) != NULL) + (void) strlcpy(r, p, ((q - p) + 1)); + return (r); +} + + +/* + * Should be obvious + */ +char * +strndup(char *s, int l) +{ + char *t; + + if ((s == NULL) || (l < 1)) + return (NULL); + + if ((t = malloc(l + 1)) != NULL) + (void) strlcpy(t, s, (l + 1)); + return (t); +} + + +/* + * file_size() - need I say more + */ +int +file_size(char *path) +{ + struct stat st; + + if (stat(path, &st) < 0) + return (-1); + else + return (st.st_size); +} + + +/* + * copy_file() - need I say more + */ +int +copy_file(char *src, char *dst) +{ + char *buf; + int size; + + syslog(LOG_DEBUG, "copy_file(%s, %s)", ((src != NULL) ? src : "NULL"), + ((dst != NULL) ? dst : "NULL")); + + if ((src == NULL) || (dst == NULL)) + return (-1); + + if ((size = map_in_file(src, &buf, 1)) < 0) + return (-1); + if (write_buffer(dst, buf, size) < 0) { + (void) munmap(buf, size); + return (-1); + } + + (void) munmap(buf, size); + return (0); +} + +int +backup_file(char *name) +{ + char buf[BUFSIZ]; + + if (snprintf(buf, sizeof (buf), "%s-", name) >= sizeof (buf)) { + syslog(LOG_ERR, "libprint:backup_file: buffer overrun"); + return (-1); + } + return (copy_file(name, buf)); +} + +/* + * map_in_file() - mmaps in a file into a buffer *buf. returns the size of + * the mmapped buffer. + */ +int +map_in_file(const char *file, char **buf, int as_me) +{ + struct stat st; + int fd; + + syslog(LOG_DEBUG, "map_in_file(%s)", (file ? file : "NULL")); + + if (buf == NULL) + return (-1); + + if (as_me != 0) + seteuid(getuid()); /* if we are suid, lose privilege */ + + if ((fd = open(file, O_RDONLY)) < 0) + return (-1); + + if (as_me != 0) + seteuid(0); /* if we fail, didn't have privilege before */ + + if (fstat(fd, &st) < 0) { + close(fd); + return (-1); + } + + if (st.st_size == 0) { + close(fd); + *buf = NULL; + return (0); + } + + if ((*buf = mmap((caddr_t)0, (size_t)st.st_size, PROT_READ, + (MAP_PRIVATE | MAP_NORESERVE), + fd, (off_t)0)) == MAP_FAILED) { + syslog(LOG_ERR, "map_in_file(%s) - mmap:%m", + (file ? file : "NULL")); + close(fd); + return (-1); + } + close(fd); + + syslog(LOG_DEBUG, "map_in_file(%s) - size(%d), addr(0x%x)", + (file ? file : "NULL"), st.st_size, *buf); + return (st.st_size); +} + + +/* + * write_buffer() - writes a buffer in memory out to the file name passed in. + * uses mmap and ftruncate to do this. + */ +int +write_buffer(char *file, char *buf, int len) +{ + int fd; + char *tmp; + + syslog(LOG_DEBUG, "write_buffer(%s, 0x%x, %d)", (file ? file : "NULL"), + buf, len); + + if ((fd = open(file, O_CREAT|O_EXCL|O_RDWR, 0640)) < 0) + return (-1); + if (ftruncate(fd, len) < 0) { + close(fd); + return (-1); + } + if ((tmp = mmap((caddr_t)0, (size_t)len, PROT_READ| PROT_WRITE, + (MAP_SHARED | MAP_NORESERVE), + fd, (off_t)0)) == MAP_FAILED) { + syslog(LOG_ERR, "write_buffer(%s, 0x%x, %d) - mmap:%m", + (file ? file : "NULL"), buf, len); + close(fd); + return (-1); + } + close(fd); + + (void) memcpy(tmp, buf, len); + (void) munmap(tmp, len); + + syslog(LOG_DEBUG, "write_buffer(%s, 0x%x, %d) - ok", + (file ? file : "NULL"), buf, len); + + return (0); +} + + +/* + * start_daemon() - check for jobs queued, check if the lock is free. If + * so, start a daemon either by forking and execing or just execing + * depending on the flag passed in. + */ +void +start_daemon(int do_fork) +{ + int lock; + job_t **jobs = NULL; + + if ((jobs = job_list_append(NULL, NULL, NULL, SPOOL_DIR)) == NULL) + return; + + list_iterate((void **)jobs, (VFUNC_T)job_free); + free(jobs); + + close(lock = get_lock(MASTER_LOCK, 0)); + if (lock < 0) + return; + if (do_fork == 0) { + (void) execle("/usr/lib/print/printd", MASTER_NAME, NULL, NULL); + syslog(LOG_ERR, "start_daemon() - execl: %m"); + exit(-1); + } else + switch (fork()) { + case -1: + syslog(LOG_ERR, "start_daemon() - fork: %m"); + exit(-1); + /* NOTREACHED */ + case 0: + break; + default: + (void) execl("/usr/lib/print/printd", MASTER_NAME, + NULL); + syslog(LOG_ERR, "start_daemon() - execl: %m"); + exit(-1); + /* NOTREACHED */ + } + +} + + +/* + * kill_daemon() - read the master lock file and send SIGTERM to the process + * id stored in the file. + */ +int +kill_process(char *file) +{ + int fd, + pid; + char buf[BUFSIZ], + *p; + + if ((fd = open(file, O_RDONLY)) < 0) + return (-1); + + (void) memset(buf, NULL, sizeof (buf)); + if (read(fd, buf, sizeof (buf)) <= 0) + return (-1); + + if ((p = strchr(buf, '\n')) == NULL) { /* skip the 1st line */ + close(fd); + return (-1); + } + pid = atoi(++p); /* convert the PID */ + + if ((pid < 2) || (kill(pid, SIGTERM) < 0)) { + close(fd); + return (-1); + } + close(fd); + return (0); +} + + +char ** +strsplit(char *string, char *seperators) +{ + char **list = NULL; + char *where = NULL; + char *element; + + for (element = strtok_r(string, seperators, &where); element != NULL; + element = strtok_r(NULL, seperators, &where)) + list = (char **)list_append((void **)list, element); + + return (list); +} |