xref: /illumos-gate/usr/src/cmd/print/lpget/lpget.c (revision 35a5a3587fd94b666239c157d3722745250ccbd7)
1 /*
2  * CDDL HEADER START
3  *
4  * The contents of this file are subject to the terms of the
5  * Common Development and Distribution License (the "License").
6  * You may not use this file except in compliance with the License.
7  *
8  * You can obtain a copy of the license at usr/src/OPENSOLARIS.LICENSE
9  * or http://www.opensolaris.org/os/licensing.
10  * See the License for the specific language governing permissions
11  * and limitations under the License.
12  *
13  * When distributing Covered Code, include this CDDL HEADER in each
14  * file and include the License file at usr/src/OPENSOLARIS.LICENSE.
15  * If applicable, add the following below this CDDL HEADER, with the
16  * fields enclosed by brackets "[]" replaced with your own identifying
17  * information: Portions Copyright [yyyy] [name of copyright owner]
18  *
19  * CDDL HEADER END
20  */
21 /*
22  * Copyright 2008 Sun Microsystems, Inc.  All rights reserved.
23  * Use is subject to license terms.
24  */
25 
26 #pragma ident	"%Z%%M%	%I%	%E% SMI"
27 
28 #include <stdio.h>
29 #include <stdlib.h>
30 #include <sys/types.h>
31 #include <stdarg.h>
32 #include <unistd.h>
33 #include <string.h>
34 #include <syslog.h>
35 #include <locale.h>
36 #ifndef SUNOS_4
37 #include <libintl.h>
38 #endif
39 
40 #include <ns.h>
41 #include <list.h>
42 
43 extern char *optarg;
44 extern int optind, opterr, optopt;
45 extern char *getenv(const char *);
46 
47 
48 static void
49 Usage(char *name)
50 {
51 	(void) fprintf(stderr,
52 		gettext("Usage: %s [-k key] [list|(printer) ...]\n"),
53 		name);
54 	exit(1);
55 }
56 
57 static int
58 display_kvp(char *key, char *value)
59 {
60 	int rc = -1;
61 
62 	if (value != NULL) {
63 		rc = 0;
64 		(void) printf("\n\t%s=%s", key, value);
65 	} else
66 		(void) printf(gettext("\n\t%s - undefined"), key);
67 
68 	return (rc);
69 }
70 
71 
72 static int
73 display_value(ns_printer_t *printer, char *name, char **keys)
74 {
75 	int rc = -1;
76 
77 	if (printer != NULL) {
78 		rc = 0;
79 		(void) printf("%s:", name);
80 		if (keys != NULL) {
81 			while (*keys != NULL) {
82 				char *string = ns_get_value_string(*keys,
83 							printer);
84 				rc += display_kvp(*keys, string);
85 				keys++;
86 			}
87 		} else {
88 			ns_kvp_t **list = printer->attributes;
89 
90 			for (list = printer->attributes;
91 			    (list != NULL && *list != NULL); list++) {
92 				char *string;
93 				if (((*list)->key[0] == '\t') ||
94 				    ((*list)->key[0] == ' '))
95 					continue;
96 
97 				string = ns_get_value_string((*list)->key,
98 							    printer);
99 				rc += display_kvp((*list)->key, string);
100 			}
101 		}
102 		(void) printf("\n");
103 	} else
104 		(void) printf(gettext("%s: Not Found\n"), name);
105 
106 	return (rc);
107 }
108 
109 
110 /*
111  *  main() calls the appropriate routine to parse the command line arguments
112  *	and then calls the local remove routine, followed by the remote remove
113  *	routine to remove jobs.
114  */
115 int
116 main(int ac, char *av[])
117 {
118 	char *program;
119 	int c;
120 	char **keys = NULL;
121 	char *ns = NULL;
122 	int exit_code = 0;
123 
124 	(void) setlocale(LC_ALL, "");
125 
126 #if	!defined(TEXT_DOMAIN)
127 #define	TEXT_DOMAIN "SYS_TEST"
128 #endif
129 	(void) textdomain(TEXT_DOMAIN);
130 
131 	if ((program = strrchr(av[0], '/')) == NULL)
132 		program = av[0];
133 	else
134 		program++;
135 
136 	openlog(program, LOG_PID, LOG_LPR);
137 	while ((c = getopt(ac, av, "k:t:n:")) != EOF)
138 		switch (c) {
139 		case 'k':
140 		case 't':
141 			keys = (char **)list_append((void **)keys,
142 						    (void *)optarg);
143 			break;
144 		case 'n':
145 			ns = optarg;
146 			break;
147 		default:
148 			Usage(program);
149 		}
150 
151 	if (optind >= ac)
152 		Usage(program);
153 
154 	ns = normalize_ns_name(ns);
155 
156 	while (optind < ac) {
157 		char *name = av[optind++];
158 
159 		if (strcmp(name, "list") == 0) {
160 			ns_printer_t **printers = ns_printer_get_list(ns);
161 
162 			while (printers != NULL && *printers != NULL) {
163 				exit_code += display_value(*printers,
164 						(*printers)->name, keys);
165 				printers++;
166 			}
167 		} else
168 			exit_code = display_value(ns_printer_get_name(name, ns),
169 						name, keys);
170 
171 
172 	}
173 	return (exit_code);
174 }
175