xref: /titanic_50/usr/src/cmd/print/bsd-sysv-commands/lpstat.c (revision 5eb9a62c342548561cae704776d448a516c4cdfe)
1355b4669Sjacobs /*
2355b4669Sjacobs  * CDDL HEADER START
3355b4669Sjacobs  *
4355b4669Sjacobs  * The contents of this file are subject to the terms of the
5355b4669Sjacobs  * Common Development and Distribution License (the "License").
6355b4669Sjacobs  * You may not use this file except in compliance with the License.
7355b4669Sjacobs  *
8355b4669Sjacobs  * You can obtain a copy of the license at usr/src/OPENSOLARIS.LICENSE
9355b4669Sjacobs  * or http://www.opensolaris.org/os/licensing.
10355b4669Sjacobs  * See the License for the specific language governing permissions
11355b4669Sjacobs  * and limitations under the License.
12355b4669Sjacobs  *
13355b4669Sjacobs  * When distributing Covered Code, include this CDDL HEADER in each
14355b4669Sjacobs  * file and include the License file at usr/src/OPENSOLARIS.LICENSE.
15355b4669Sjacobs  * If applicable, add the following below this CDDL HEADER, with the
16355b4669Sjacobs  * fields enclosed by brackets "[]" replaced with your own identifying
17355b4669Sjacobs  * information: Portions Copyright [yyyy] [name of copyright owner]
18355b4669Sjacobs  *
19355b4669Sjacobs  * CDDL HEADER END
20355b4669Sjacobs  */
21355b4669Sjacobs 
22355b4669Sjacobs /*
23853389e3Swendyp  * Copyright 2008 Sun Microsystems, Inc.  All rights reserved.
24355b4669Sjacobs  * Use is subject to license terms.
25355b4669Sjacobs  *
26355b4669Sjacobs  */
27355b4669Sjacobs 
28355b4669Sjacobs /* $Id: lpstat.c 173 2006-05-25 04:52:06Z njacobs $ */
29355b4669Sjacobs 
30355b4669Sjacobs 
31355b4669Sjacobs #include <stdio.h>
32355b4669Sjacobs #include <stdlib.h>
33355b4669Sjacobs #include <unistd.h>
34355b4669Sjacobs #include <string.h>
35355b4669Sjacobs #include <locale.h>
36355b4669Sjacobs #include <libintl.h>
3791216fe4Swendyp #include <ctype.h>
38355b4669Sjacobs #include <pwd.h>
39355b4669Sjacobs #include <papi.h>
40355b4669Sjacobs #include <uri.h>
41355b4669Sjacobs #include "common.h"
42355b4669Sjacobs 
43355b4669Sjacobs static void
44355b4669Sjacobs usage(char *program)
45355b4669Sjacobs {
46355b4669Sjacobs 	char *name;
47355b4669Sjacobs 
48355b4669Sjacobs 	if ((name = strrchr(program, '/')) == NULL)
49355b4669Sjacobs 		name = program;
50355b4669Sjacobs 	else
51355b4669Sjacobs 		name++;
52355b4669Sjacobs 
53355b4669Sjacobs 	fprintf(stdout, gettext("Usage: %s [-d] [-r] [-s] [-t] [-a [list]] "
54355b4669Sjacobs 		"[-c [list]] [-o [list] [-l]] [-R [list] [-l]] "
55355b4669Sjacobs 		"[-p [list] [-D] [-l]] [-v [list]] [-S [list] [-l]] "
56355b4669Sjacobs 		"[-f [list] [-l]] [-u list]\n"),
57355b4669Sjacobs 		name);
58355b4669Sjacobs 	exit(1);
59355b4669Sjacobs }
60355b4669Sjacobs 
61355b4669Sjacobs static char *
62355b4669Sjacobs nctime(time_t *t)
63355b4669Sjacobs {
64355b4669Sjacobs 	static char buf[64];
65355b4669Sjacobs 	struct tm *tm = localtime(t);
66355b4669Sjacobs 
67355b4669Sjacobs 	(void) strftime(buf, sizeof (buf), "%c", tm);
68355b4669Sjacobs 
69355b4669Sjacobs 	return (buf);
70355b4669Sjacobs }
71355b4669Sjacobs 
72355b4669Sjacobs static char *
73355b4669Sjacobs printer_name(papi_printer_t printer)
74355b4669Sjacobs {
75355b4669Sjacobs 	papi_attribute_t **attributes = papiPrinterGetAttributeList(printer);
76355b4669Sjacobs 	char *result = NULL;
77355b4669Sjacobs 
78355b4669Sjacobs 	if (attributes != NULL)
79355b4669Sjacobs 		papiAttributeListGetString(attributes, NULL,
80355b4669Sjacobs 				"printer-name", &result);
81355b4669Sjacobs 
82355b4669Sjacobs 	return (result);
83355b4669Sjacobs }
84355b4669Sjacobs 
85355b4669Sjacobs static int
86355b4669Sjacobs lpstat_default_printer(papi_encryption_t encryption)
87355b4669Sjacobs {
88355b4669Sjacobs 	papi_status_t status;
89355b4669Sjacobs 	papi_service_t svc = NULL;
90355b4669Sjacobs 	papi_printer_t p = NULL;
91355b4669Sjacobs 	char *name = NULL;
92355b4669Sjacobs 
93355b4669Sjacobs 	status = papiServiceCreate(&svc, NULL, NULL, NULL, cli_auth_callback,
94355b4669Sjacobs 					encryption, NULL);
95355b4669Sjacobs 	if (status == PAPI_OK) {
96355b4669Sjacobs 		char *req[] = { "printer-name", NULL };
97355b4669Sjacobs 
98355b4669Sjacobs 		status = papiPrinterQuery(svc, DEFAULT_DEST, req, NULL, &p);
99355b4669Sjacobs 		if (p != NULL)
100355b4669Sjacobs 			name = printer_name(p);
101355b4669Sjacobs 	}
102355b4669Sjacobs 	if (name != NULL)
103355b4669Sjacobs 		printf(gettext("system default printer: %s\n"), name);
104355b4669Sjacobs 	else
105355b4669Sjacobs 		printf(gettext("no system default destination\n"));
106355b4669Sjacobs 	papiPrinterFree(p);
107355b4669Sjacobs 	papiServiceDestroy(svc);
108355b4669Sjacobs 
109355b4669Sjacobs 	return (0);
110355b4669Sjacobs }
111355b4669Sjacobs 
112355b4669Sjacobs static int
113355b4669Sjacobs lpstat_service_status(papi_encryption_t encryption)
114355b4669Sjacobs {
115355b4669Sjacobs 	int result = 0;
116355b4669Sjacobs 	papi_status_t status;
117355b4669Sjacobs 	papi_service_t svc = NULL;
118355b4669Sjacobs 	char *name = NULL;
119355b4669Sjacobs 
120355b4669Sjacobs 	if (((name = getenv("PAPI_SERVICE_URI")) == NULL) &&
121355b4669Sjacobs 	    ((name = getenv("IPP_SERVER")) == NULL) &&
122355b4669Sjacobs 	    ((name = getenv("CUPS_SERVER")) == NULL))
123355b4669Sjacobs 		name = DEFAULT_SERVICE_URI;
124355b4669Sjacobs 
125355b4669Sjacobs 	status = papiServiceCreate(&svc, name, NULL, NULL, cli_auth_callback,
126355b4669Sjacobs 					encryption, NULL);
127355b4669Sjacobs 	if (status != PAPI_OK) {
128355b4669Sjacobs 		printf(gettext("scheduler is not running\n"));
129355b4669Sjacobs 		result = -1;
130355b4669Sjacobs 	} else
131355b4669Sjacobs 		printf(gettext("scheduler is running\n"));
132355b4669Sjacobs 	papiServiceDestroy(svc);
133355b4669Sjacobs 
134355b4669Sjacobs 	return (result);
135355b4669Sjacobs }
136355b4669Sjacobs 
137355b4669Sjacobs static char *
138355b4669Sjacobs get_device_uri(papi_service_t svc, char *name)
139355b4669Sjacobs {
140355b4669Sjacobs 	papi_status_t status;
141355b4669Sjacobs 	papi_printer_t p = NULL;
142355b4669Sjacobs 	char *keys[] = { "device-uri", NULL };
143355b4669Sjacobs 	char *result = NULL;
144355b4669Sjacobs 
145355b4669Sjacobs 	status = papiPrinterQuery(svc, name, keys, NULL, &p);
146355b4669Sjacobs 	if ((status == PAPI_OK) && (p != NULL)) {
147355b4669Sjacobs 		papi_attribute_t **attrs = papiPrinterGetAttributeList(p);
148355b4669Sjacobs 
149355b4669Sjacobs 		(void) papiAttributeListGetString(attrs, NULL,
150355b4669Sjacobs 					"device-uri", &result);
151355b4669Sjacobs 		if (result != NULL)
152355b4669Sjacobs 			result = strdup(result);
153355b4669Sjacobs 
154355b4669Sjacobs 		papiPrinterFree(p);
155355b4669Sjacobs 	}
156355b4669Sjacobs 
157355b4669Sjacobs 	return (result);
158355b4669Sjacobs }
159355b4669Sjacobs 
160355b4669Sjacobs static char *report_device_keys[] = { "printer-name", "printer-uri-supported",
161355b4669Sjacobs 					NULL };
162355b4669Sjacobs /* ARGSUSED2 */
163355b4669Sjacobs static int
164355b4669Sjacobs report_device(papi_service_t svc, char *name, papi_printer_t printer,
165355b4669Sjacobs 		int verbose, int description)
166355b4669Sjacobs {
167355b4669Sjacobs 	papi_status_t status;
168355b4669Sjacobs 	papi_attribute_t **attrs = papiPrinterGetAttributeList(printer);
169355b4669Sjacobs 	char *uri = NULL;
170355b4669Sjacobs 	char *device = NULL;
171355b4669Sjacobs 	uri_t *u = NULL;
172355b4669Sjacobs 
173355b4669Sjacobs 	if (name == NULL) {
174355b4669Sjacobs 		status = papiAttributeListGetString(attrs, NULL,
175355b4669Sjacobs 					"printer-name", &name);
176355b4669Sjacobs 		if (status != PAPI_OK)
177355b4669Sjacobs 			status = papiAttributeListGetString(attrs, NULL,
178355b4669Sjacobs 					"printer-uri-supported", &name);
179355b4669Sjacobs 	}
180355b4669Sjacobs 
181355b4669Sjacobs 	if (name == NULL)
182355b4669Sjacobs 		return (-1);
183355b4669Sjacobs 
184355b4669Sjacobs 	(void) papiAttributeListGetString(attrs, NULL,
185355b4669Sjacobs 					"printer-uri-supported", &uri);
186355b4669Sjacobs 
187355b4669Sjacobs 	if ((uri != NULL) && (uri_from_string(uri, &u) == 0)) {
188355b4669Sjacobs 		char *nodename = localhostname();
189355b4669Sjacobs 
190355b4669Sjacobs 		if ((u->host == NULL) ||
191355b4669Sjacobs 		    (strcasecmp(u->host, "localhost") == 0) ||
192355b4669Sjacobs 		    (strcasecmp(u->host, nodename) == 0))
193355b4669Sjacobs 			device = get_device_uri(svc, name);
194355b4669Sjacobs 
195355b4669Sjacobs 		if (device != NULL) {
196355b4669Sjacobs 			printf(gettext("device for %s: %s\n"), name, device);
197355b4669Sjacobs 			return (0);
198355b4669Sjacobs 		} else if (uri != NULL) {
199355b4669Sjacobs 			printf(gettext("system for %s: %s (as %s)\n"), name,
200355b4669Sjacobs 				u->host, uri);
201355b4669Sjacobs 			return (0);
202355b4669Sjacobs 		}
203355b4669Sjacobs 
204355b4669Sjacobs 		uri_free(u);
205355b4669Sjacobs 	}
206355b4669Sjacobs 
207355b4669Sjacobs 	return (0);
208355b4669Sjacobs }
209355b4669Sjacobs 
210355b4669Sjacobs static char *report_accepting_keys[] = { "printer-name",
211355b4669Sjacobs 			"printer-uri-supported", "printer-is-accepting-jobs",
212355b4669Sjacobs 			"printer-up-time", "printer-state-time",
213355b4669Sjacobs 			"lpsched-reject-date", "lpsched-reject-reason", NULL };
214355b4669Sjacobs /* ARGSUSED2 */
215355b4669Sjacobs static int
216355b4669Sjacobs report_accepting(papi_service_t svc, char *name, papi_printer_t printer,
217355b4669Sjacobs 		int verbose, int description)
218355b4669Sjacobs {
219355b4669Sjacobs 	papi_status_t status;
220355b4669Sjacobs 	papi_attribute_t **attrs = papiPrinterGetAttributeList(printer);
221355b4669Sjacobs 	time_t curr;
222355b4669Sjacobs 	char boolean = PAPI_FALSE;
223355b4669Sjacobs 
224355b4669Sjacobs 	if (name == NULL) {
225355b4669Sjacobs 		status = papiAttributeListGetString(attrs, NULL,
226355b4669Sjacobs 					"printer-name", &name);
227355b4669Sjacobs 		if (status != PAPI_OK)
228355b4669Sjacobs 			status = papiAttributeListGetString(attrs, NULL,
229355b4669Sjacobs 					"printer-uri-supported", &name);
230355b4669Sjacobs 	}
231355b4669Sjacobs 	if (name == NULL)
232355b4669Sjacobs 		return (-1);
233355b4669Sjacobs 
234355b4669Sjacobs 	(void) papiAttributeListGetBoolean(attrs, NULL,
235355b4669Sjacobs 				"printer-is-accepting-jobs", &boolean);
236355b4669Sjacobs 	(void) time(&curr);
237355b4669Sjacobs 	(void) papiAttributeListGetDatetime(attrs, NULL,
238355b4669Sjacobs 					"printer-up-time", &curr);
239355b4669Sjacobs 	(void) papiAttributeListGetDatetime(attrs, NULL,
240355b4669Sjacobs 					"printer-state-time", &curr);
241355b4669Sjacobs 	(void) papiAttributeListGetDatetime(attrs, NULL,
242355b4669Sjacobs 					"lpsched-reject-date", &curr);
243355b4669Sjacobs 
244355b4669Sjacobs 	if (boolean == PAPI_TRUE) {
245355b4669Sjacobs 		printf(gettext("%s accepting requests since %s\n"),
246355b4669Sjacobs 			name, nctime(&curr));
247355b4669Sjacobs 	} else {
248355b4669Sjacobs 		char *reason = "unknown reason";
249355b4669Sjacobs 
250355b4669Sjacobs 		(void) papiAttributeListGetString(attrs, NULL,
251355b4669Sjacobs 					"lpsched-reject-reason", &reason);
252355b4669Sjacobs 
253355b4669Sjacobs 		printf(gettext("%s not accepting requests since %s\n\t%s\n"),
254355b4669Sjacobs 			name, nctime(&curr), reason);
255355b4669Sjacobs 	}
256355b4669Sjacobs 
257355b4669Sjacobs 	return (0);
258355b4669Sjacobs }
259355b4669Sjacobs 
260355b4669Sjacobs static char *report_class_keys[] = { "printer-name", "printer-uri-supported",
261355b4669Sjacobs 					"member-names", NULL };
262355b4669Sjacobs /* ARGSUSED2 */
263355b4669Sjacobs static int
264355b4669Sjacobs report_class(papi_service_t svc, char *name, papi_printer_t printer,
265355b4669Sjacobs 		int verbose, int description)
266355b4669Sjacobs {
267355b4669Sjacobs 	papi_status_t status;
268355b4669Sjacobs 	papi_attribute_t **attrs = papiPrinterGetAttributeList(printer);
269355b4669Sjacobs 	char *member = NULL;
270355b4669Sjacobs 	void *iter = NULL;
271355b4669Sjacobs 
272355b4669Sjacobs 	status = papiAttributeListGetString(attrs, &iter,
273355b4669Sjacobs 				"member-names", &member);
274355b4669Sjacobs 	if (status == PAPI_NOT_FOUND)	/* it's not a class */
275355b4669Sjacobs 		return (0);
276355b4669Sjacobs 
277355b4669Sjacobs 	if (name == NULL) {
278355b4669Sjacobs 		status = papiAttributeListGetString(attrs, NULL,
279355b4669Sjacobs 					"printer-name", &name);
280355b4669Sjacobs 		if (status != PAPI_OK)
281355b4669Sjacobs 			status = papiAttributeListGetString(attrs, NULL,
282355b4669Sjacobs 					"printer-uri-supported", &name);
283355b4669Sjacobs 	}
284355b4669Sjacobs 	if (name == NULL)
285355b4669Sjacobs 		return (-1);
286355b4669Sjacobs 
287355b4669Sjacobs 	printf(gettext("members of class %s:\n\t%s\n"), name, member);
288355b4669Sjacobs 	while (papiAttributeListGetString(attrs, &iter, NULL, &member)
289355b4669Sjacobs 			== PAPI_OK)
290355b4669Sjacobs 		printf("\t%s\n", member);
291355b4669Sjacobs 
292355b4669Sjacobs 	return (0);
293355b4669Sjacobs }
294355b4669Sjacobs 
295355b4669Sjacobs static char *report_printer_keys[] = { "printer-name",
296355b4669Sjacobs 			"printer-uri-supported", "printer-state",
297355b4669Sjacobs 			"printer-up-time", "printer-state-time",
298355b4669Sjacobs 			"lpsched-disable-date", "printer-state-reasons",
299355b4669Sjacobs 			"lpsched-disable-reason", NULL };
300355b4669Sjacobs /* ARGSUSED2 */
301355b4669Sjacobs static int
302355b4669Sjacobs report_printer(papi_service_t svc, char *name, papi_printer_t printer,
303355b4669Sjacobs 		int verbose, int description)
304355b4669Sjacobs {
305355b4669Sjacobs 	papi_status_t status;
306355b4669Sjacobs 	papi_attribute_t **attrs = papiPrinterGetAttributeList(printer);
307355b4669Sjacobs 	time_t curr;
308355b4669Sjacobs 	int32_t pstat = 0;
309355b4669Sjacobs 	char *member = NULL;
310355b4669Sjacobs 
311355b4669Sjacobs 	status = papiAttributeListGetString(attrs, NULL,
312355b4669Sjacobs 				"member-names", &member);
313355b4669Sjacobs 	if (status == PAPI_OK)	/* it's a class */
314355b4669Sjacobs 		return (0);
315355b4669Sjacobs 
316355b4669Sjacobs 	if (name == NULL) {
317355b4669Sjacobs 		status = papiAttributeListGetString(attrs, NULL,
318355b4669Sjacobs 					"printer-name", &name);
319355b4669Sjacobs 		if (status != PAPI_OK)
320355b4669Sjacobs 			status = papiAttributeListGetString(attrs, NULL,
321355b4669Sjacobs 					"printer-uri-supported", &name);
322355b4669Sjacobs 	}
323355b4669Sjacobs 	if (name == NULL)
324355b4669Sjacobs 		return (-1);
325355b4669Sjacobs 
326355b4669Sjacobs 	printf(gettext("printer %s "), name);
327355b4669Sjacobs 
328355b4669Sjacobs 	status = papiAttributeListGetInteger(attrs, NULL,
329355b4669Sjacobs 					"printer-state", &pstat);
330355b4669Sjacobs 
331355b4669Sjacobs 	switch (pstat) {
332355b4669Sjacobs 	case 0x03:	/* idle */
333355b4669Sjacobs 		printf(gettext("idle. enabled"));
334355b4669Sjacobs 		break;
335355b4669Sjacobs 	case 0x04: {	/* processing */
336355b4669Sjacobs 		char *requested[] = { "job-id", NULL };
337355b4669Sjacobs 		papi_job_t *j = NULL;
338355b4669Sjacobs 		int32_t jobid = 0;
339355b4669Sjacobs 
340355b4669Sjacobs 		(void) papiPrinterListJobs(svc, name, requested, 0, 1, &j);
341355b4669Sjacobs 		if ((j != NULL) && (j[0] != NULL))
342355b4669Sjacobs 			jobid = papiJobGetId(j[0]);
343355b4669Sjacobs 		papiJobListFree(j);
344355b4669Sjacobs 
345355b4669Sjacobs 		printf(gettext("now printing %s-%d. enabled"), name, jobid);
346355b4669Sjacobs 		}
347355b4669Sjacobs 		break;
348355b4669Sjacobs 	case 0x05:	/* stopped */
349355b4669Sjacobs 		printf(gettext("disabled"));
350355b4669Sjacobs 		break;
351355b4669Sjacobs 	default:
352355b4669Sjacobs 		printf(gettext("unknown state(0x%x)."), pstat);
353355b4669Sjacobs 		break;
354355b4669Sjacobs 	}
355355b4669Sjacobs 
356355b4669Sjacobs 	(void) time(&curr);
357355b4669Sjacobs 	(void) papiAttributeListGetDatetime(attrs, NULL,
358355b4669Sjacobs 					"printer-up-time", &curr);
359355b4669Sjacobs 	(void) papiAttributeListGetDatetime(attrs, NULL,
360355b4669Sjacobs 					"printer-state-time", &curr);
361355b4669Sjacobs 	(void) papiAttributeListGetDatetime(attrs, NULL,
362355b4669Sjacobs 					"lpsched-disable-date", &curr);
363355b4669Sjacobs 	printf(gettext(" since %s. available.\n"), nctime(&curr));
364355b4669Sjacobs 
365355b4669Sjacobs 	if (pstat == 0x05) {
366355b4669Sjacobs 		char *reason = "unknown reason";
367355b4669Sjacobs 
368355b4669Sjacobs 		(void) papiAttributeListGetString(attrs, NULL,
369355b4669Sjacobs 					"printer-state-reasons", &reason);
370355b4669Sjacobs 		(void) papiAttributeListGetString(attrs, NULL,
371355b4669Sjacobs 					"lpsched-disable-reason", &reason);
372355b4669Sjacobs 		printf(gettext("\t%s\n"), reason);
373355b4669Sjacobs 	}
374355b4669Sjacobs 
375355b4669Sjacobs 	if (verbose == 1) {
376355b4669Sjacobs 		void *iter;
377355b4669Sjacobs 		char *str;
378355b4669Sjacobs 
379355b4669Sjacobs 		str = "";
380355b4669Sjacobs 		(void) papiAttributeListGetString(attrs, NULL,
381355b4669Sjacobs 					"form-ready", &str);
382355b4669Sjacobs 		printf(gettext("\tForm mounted: %s\n"), str);
383355b4669Sjacobs 
384355b4669Sjacobs 		str = "";
385355b4669Sjacobs 		iter = NULL;
386355b4669Sjacobs 		(void) papiAttributeListGetString(attrs, &iter,
387355b4669Sjacobs 					"document-format-supported", &str);
388355b4669Sjacobs 		printf(gettext("\tContent types: %s"), str);
389355b4669Sjacobs 		while (papiAttributeListGetString(attrs, &iter, NULL, &str)
390355b4669Sjacobs 				== PAPI_OK)
391355b4669Sjacobs 			printf(", %s", str);
392355b4669Sjacobs 		printf("\n");
393355b4669Sjacobs 
394355b4669Sjacobs 		str = "";
395355b4669Sjacobs 		(void) papiAttributeListGetString(attrs, NULL,
396355b4669Sjacobs 					"printer-info", &str);
397355b4669Sjacobs 		printf(gettext("\tDescription: %s\n"), str);
398355b4669Sjacobs 
399355b4669Sjacobs 		str = "";
400853389e3Swendyp 		iter = NULL;
401853389e3Swendyp 		(void) papiAttributeListGetString(attrs, &iter,
402853389e3Swendyp 		    "lpsched-printer-type", &str);
403853389e3Swendyp 		printf(gettext("\tPrinter types: %s"), str);
404853389e3Swendyp 		while (papiAttributeListGetString(attrs, &iter, NULL, &str)
405853389e3Swendyp 		    == PAPI_OK)
406853389e3Swendyp 			printf(", %s", str);
407853389e3Swendyp 		printf("\n");
408853389e3Swendyp 
409853389e3Swendyp 		str = "";
410355b4669Sjacobs 		(void) papiAttributeListGetString(attrs, NULL,
411355b4669Sjacobs 					"lpsched-dial-info", &str);
412355b4669Sjacobs 		printf(gettext("\tConnection: %s\n"),
413*5eb9a62cSJonathan Cowper-Andrewes 		    ((str[0] == '\0') ? gettext("direct") : str));
414355b4669Sjacobs 
415355b4669Sjacobs 		str = "";
416355b4669Sjacobs 		(void) papiAttributeListGetString(attrs, NULL,
417355b4669Sjacobs 					"lpsched-interface-script", &str);
418355b4669Sjacobs 		printf(gettext("\tInterface: %s\n"), str);
419355b4669Sjacobs 
420355b4669Sjacobs 		str = NULL;
421355b4669Sjacobs 		(void) papiAttributeListGetString(attrs, NULL,
422355b4669Sjacobs 					"ppd-file-uri", &str);
423355b4669Sjacobs 		(void) papiAttributeListGetString(attrs, NULL,
424355b4669Sjacobs 					"lpsched-ppd-source-path", &str);
425355b4669Sjacobs 		if (str != NULL)
426355b4669Sjacobs 			printf(gettext("\tPPD: %s\n"), str);
427355b4669Sjacobs 
428355b4669Sjacobs 		str = NULL;
429355b4669Sjacobs 		(void) papiAttributeListGetString(attrs, NULL,
430355b4669Sjacobs 					"lpsched-fault-alert-command", &str);
431355b4669Sjacobs 		if (str != NULL)
432355b4669Sjacobs 			printf(gettext("\tOn fault: %s\n"), str);
433355b4669Sjacobs 
434355b4669Sjacobs 		str = "";
435355b4669Sjacobs 		(void) papiAttributeListGetString(attrs, NULL,
436355b4669Sjacobs 					"lpsched-fault-recovery", &str);
437355b4669Sjacobs 		printf(gettext("\tAfter fault: %s\n"),
438355b4669Sjacobs 			((str[0] == '\0') ? gettext("continue") : str));
439355b4669Sjacobs 
440355b4669Sjacobs 		str = "(all)";
441355b4669Sjacobs 		iter = NULL;
442355b4669Sjacobs 		(void) papiAttributeListGetString(attrs, &iter,
443355b4669Sjacobs 					"requesting-user-name-allowed", &str);
444355b4669Sjacobs 		printf(gettext("\tUsers allowed:\n\t\t%s\n"),
445355b4669Sjacobs 			((str[0] == '\0') ? gettext("(none)") : str));
446355b4669Sjacobs 		if ((str != NULL) && (str[0] != '\0'))
447355b4669Sjacobs 			while (papiAttributeListGetString(attrs, &iter, NULL,
448355b4669Sjacobs 					&str) == PAPI_OK)
449355b4669Sjacobs 				printf("\t\t%s\n", str);
450355b4669Sjacobs 
451355b4669Sjacobs 		str = NULL;
452355b4669Sjacobs 		iter = NULL;
453355b4669Sjacobs 		(void) papiAttributeListGetString(attrs, &iter,
454355b4669Sjacobs 					"requesting-user-name-denied", &str);
455355b4669Sjacobs 		if (str != NULL) {
456355b4669Sjacobs 			printf(gettext("\tUsers denied:\n\t\t%s\n"),
457355b4669Sjacobs 				((str[0] == '\0') ? gettext("(none)") : str));
458355b4669Sjacobs 			if ((str != NULL) && (str[0] != '\0'))
459355b4669Sjacobs 				while (papiAttributeListGetString(attrs, &iter,
460355b4669Sjacobs 						NULL, &str) == PAPI_OK)
461355b4669Sjacobs 					printf("\t\t%s\n", str);
462355b4669Sjacobs 		}
463355b4669Sjacobs 
464355b4669Sjacobs 		str = "(none)";
465355b4669Sjacobs 		iter = NULL;
466355b4669Sjacobs 		(void) papiAttributeListGetString(attrs, &iter,
467355b4669Sjacobs 					"form-supported", &str);
468355b4669Sjacobs 		printf(gettext("\tForms allowed:\n\t\t%s\n"),
469355b4669Sjacobs 			((str[0] == '\0') ? gettext("(none)") : str));
470355b4669Sjacobs 		if ((str != NULL) && (str[0] != '\0'))
471355b4669Sjacobs 			while (papiAttributeListGetString(attrs, &iter, NULL,
472355b4669Sjacobs 					&str) == PAPI_OK)
473355b4669Sjacobs 				printf("\t\t%s\n", str);
474355b4669Sjacobs 
475355b4669Sjacobs 		str = "";
476355b4669Sjacobs 		iter = NULL;
477355b4669Sjacobs 		(void) papiAttributeListGetString(attrs, &iter,
478355b4669Sjacobs 					"media-supported", &str);
479355b4669Sjacobs 		printf(gettext("\tMedia supported:\n\t\t%s\n"),
480355b4669Sjacobs 			((str[0] == '\0') ? gettext("(none)") : str));
481355b4669Sjacobs 		if ((str != NULL) && (str[0] != '\0'))
482355b4669Sjacobs 			while (papiAttributeListGetString(attrs, &iter, NULL,
483355b4669Sjacobs 					&str) == PAPI_OK)
484355b4669Sjacobs 				printf("\t\t%s\n", str);
485355b4669Sjacobs 
486355b4669Sjacobs 		str = "";
487355b4669Sjacobs 		(void) papiAttributeListGetString(attrs, NULL,
488355b4669Sjacobs 					"job-sheets-supported", &str);
489853389e3Swendyp 		if ((strcasecmp(str, "none")) == 0)
490853389e3Swendyp 			str = gettext("page never printed");
491853389e3Swendyp 		else if (strcasecmp(str, "optional") == 0)
492853389e3Swendyp 			str = gettext("not required");
493853389e3Swendyp 		else
494853389e3Swendyp 			str = gettext("required");
495853389e3Swendyp 
496853389e3Swendyp 		printf(gettext("\tBanner %s\n"), str);
497853389e3Swendyp 
498355b4669Sjacobs 
499355b4669Sjacobs 		str = "";
500355b4669Sjacobs 		iter = NULL;
501355b4669Sjacobs 		(void) papiAttributeListGetString(attrs, &iter,
502355b4669Sjacobs 					"lpsched-print-wheels", &str);
503355b4669Sjacobs 		printf(gettext("\tCharacter sets:\n\t\t%s\n"),
504355b4669Sjacobs 			((str[0] == '\0') ? gettext("(none)") : str));
505355b4669Sjacobs 		if ((str != NULL) && (str[0] != '\0'))
506355b4669Sjacobs 			while (papiAttributeListGetString(attrs, &iter, NULL,
507355b4669Sjacobs 					&str) == PAPI_OK)
508355b4669Sjacobs 				printf("\t\t%s\n", str);
509355b4669Sjacobs 
510355b4669Sjacobs 		printf(gettext("\tDefault pitch:\n"));
511355b4669Sjacobs 		printf(gettext("\tDefault page size:\n"));
512355b4669Sjacobs 		printf(gettext("\tDefault port setting:\n"));
513355b4669Sjacobs 
514355b4669Sjacobs 		str = "";
515355b4669Sjacobs 		iter = NULL;
516355b4669Sjacobs 		(void) papiAttributeListGetString(attrs, &iter,
517355b4669Sjacobs 					"lpsched-options", &str);
518355b4669Sjacobs 		if (str != NULL) {
519355b4669Sjacobs 			printf(gettext("\tOptions: %s"), str);
520355b4669Sjacobs 			while (papiAttributeListGetString(attrs, &iter, NULL,
521355b4669Sjacobs 						&str) == PAPI_OK)
522355b4669Sjacobs 				printf(", %s", str);
523355b4669Sjacobs 			printf("\n");
524355b4669Sjacobs 		}
525355b4669Sjacobs 
526355b4669Sjacobs 	} else if (description == 1) {
527355b4669Sjacobs 		char *str = "";
528355b4669Sjacobs 		(void) papiAttributeListGetString(attrs, NULL,
529355b4669Sjacobs 					"printer-description", &str);
530355b4669Sjacobs 		printf(gettext("\tDescription: %s\n"), str);
531355b4669Sjacobs 	} else if (verbose > 1)
532355b4669Sjacobs 		papiAttributeListPrint(stdout, attrs, "\t");
533355b4669Sjacobs 
534355b4669Sjacobs 	if (verbose > 0)
535355b4669Sjacobs 		printf("\n");
536355b4669Sjacobs 
537355b4669Sjacobs 	return (0);
538355b4669Sjacobs }
539355b4669Sjacobs 
540355b4669Sjacobs static int
541355b4669Sjacobs printer_query(char *name, int (*report)(papi_service_t, char *, papi_printer_t,
542355b4669Sjacobs 					int, int), papi_encryption_t encryption,
543355b4669Sjacobs 		int verbose, int description)
544355b4669Sjacobs {
545355b4669Sjacobs 	int result = 0;
546355b4669Sjacobs 	papi_status_t status;
547355b4669Sjacobs 	papi_service_t svc = NULL;
548355b4669Sjacobs 
549355b4669Sjacobs 	status = papiServiceCreate(&svc, name, NULL, NULL, cli_auth_callback,
550355b4669Sjacobs 					encryption, NULL);
551355b4669Sjacobs 	if (status != PAPI_OK) {
552022ba35cSjacobs 		if (status == PAPI_NOT_FOUND)
553022ba35cSjacobs 			fprintf(stderr, gettext("%s: unknown printer\n"),
554022ba35cSjacobs 				name ? name : "(NULL)");
555022ba35cSjacobs 		else
556355b4669Sjacobs 			fprintf(stderr, gettext(
557355b4669Sjacobs 				"Failed to contact service for %s: %s\n"),
558355b4669Sjacobs 				name ? name : "(NULL)",
559355b4669Sjacobs 				verbose_papi_message(svc, status));
560355b4669Sjacobs 		papiServiceDestroy(svc);
561355b4669Sjacobs 		return (-1);
562355b4669Sjacobs 	}
563355b4669Sjacobs 
564355b4669Sjacobs 	if (name == NULL) { /* all */
565355b4669Sjacobs 		char **interest = interest_list(svc);
566355b4669Sjacobs 
567355b4669Sjacobs 		if (interest != NULL) {
568355b4669Sjacobs 			int i;
569355b4669Sjacobs 
570355b4669Sjacobs 			for (i = 0; interest[i] != NULL; i++)
571355b4669Sjacobs 				result += printer_query(interest[i], report,
572355b4669Sjacobs 							encryption, verbose,
573355b4669Sjacobs 							description);
574355b4669Sjacobs 		}
575355b4669Sjacobs 	} else {
576355b4669Sjacobs 		papi_printer_t printer = NULL;
577355b4669Sjacobs 		char **keys = NULL;
578355b4669Sjacobs 
579355b4669Sjacobs 		/*
580355b4669Sjacobs 		 * Limit the query to only required data to reduce the need
581355b4669Sjacobs 		 * to go remote for information.
582355b4669Sjacobs 		 */
583355b4669Sjacobs 		if (report == report_device)
584355b4669Sjacobs 			keys = report_device_keys;
585355b4669Sjacobs 		else if (report == report_class)
586355b4669Sjacobs 			keys = report_class_keys;
587355b4669Sjacobs 		else if (report == report_accepting)
588355b4669Sjacobs 			keys = report_accepting_keys;
589355b4669Sjacobs 		else if ((report == report_printer) && (verbose == 0))
590355b4669Sjacobs 			keys = report_printer_keys;
591355b4669Sjacobs 
592355b4669Sjacobs 		status = papiPrinterQuery(svc, name, keys, NULL, &printer);
593355b4669Sjacobs 		if (status != PAPI_OK) {
594355b4669Sjacobs 			fprintf(stderr, gettext(
595355b4669Sjacobs 				"Failed to get printer info for %s: %s\n"),
596355b4669Sjacobs 				name, verbose_papi_message(svc, status));
597355b4669Sjacobs 			papiServiceDestroy(svc);
598355b4669Sjacobs 			return (-1);
599355b4669Sjacobs 		}
600355b4669Sjacobs 
601355b4669Sjacobs 		if (printer != NULL)
602355b4669Sjacobs 			result = report(svc, name, printer, verbose,
603355b4669Sjacobs 					description);
604355b4669Sjacobs 
605355b4669Sjacobs 		papiPrinterFree(printer);
606355b4669Sjacobs 	}
607355b4669Sjacobs 
608355b4669Sjacobs 	papiServiceDestroy(svc);
609355b4669Sjacobs 
610355b4669Sjacobs 	return (result);
611355b4669Sjacobs }
612355b4669Sjacobs 
613355b4669Sjacobs static int
614355b4669Sjacobs match_user(char *user, char **list)
615355b4669Sjacobs {
616355b4669Sjacobs 	int i;
617355b4669Sjacobs 
618355b4669Sjacobs 	for (i = 0; list[i] != NULL; i++) {
619355b4669Sjacobs 		if (strcmp(user, list[i]) == 0)
620355b4669Sjacobs 			return (0);
621355b4669Sjacobs 	}
622355b4669Sjacobs 
623355b4669Sjacobs 	return (-1);
624355b4669Sjacobs }
625355b4669Sjacobs 
626355b4669Sjacobs static char **users = NULL;
627355b4669Sjacobs 
628355b4669Sjacobs static int
629355b4669Sjacobs report_job(papi_job_t job, int show_rank, int verbose)
630355b4669Sjacobs {
631355b4669Sjacobs 	papi_attribute_t **attrs = papiJobGetAttributeList(job);
632355b4669Sjacobs 	time_t clock = 0;
633355b4669Sjacobs 	char date[24];
634355b4669Sjacobs 	char request[26];
635355b4669Sjacobs 	char *user = "unknown";
636355b4669Sjacobs 	int32_t size = 0;
637355b4669Sjacobs 	int32_t jstate = 0;
638355b4669Sjacobs 
639355b4669Sjacobs 	char *destination = "unknown";
640355b4669Sjacobs 	int32_t id = -1;
641355b4669Sjacobs 
642355b4669Sjacobs 	(void) papiAttributeListGetString(attrs, NULL,
643355b4669Sjacobs 				"job-originating-user-name", &user);
644355b4669Sjacobs 
645355b4669Sjacobs 	if ((users != NULL) && (match_user(user, users) < 0))
646355b4669Sjacobs 		return (0);
647355b4669Sjacobs 
648355b4669Sjacobs 	(void) papiAttributeListGetInteger(attrs, NULL, "job-k-octets", &size);
649355b4669Sjacobs 	size *= 1024;	/* for the approximate byte size */
650355b4669Sjacobs 	(void) papiAttributeListGetInteger(attrs, NULL, "job-octets", &size);
651355b4669Sjacobs 
652355b4669Sjacobs 	(void) time(&clock);
653355b4669Sjacobs 	(void) papiAttributeListGetInteger(attrs, NULL,
654355b4669Sjacobs 				"time-at-creation", (int32_t *)&clock);
655355b4669Sjacobs 	(void) strftime(date, sizeof (date), "%b %d %R", localtime(&clock));
656355b4669Sjacobs 
657355b4669Sjacobs 	(void) papiAttributeListGetString(attrs, NULL,
658355b4669Sjacobs 				"job-printer-uri", &destination);
659355b4669Sjacobs 	(void) papiAttributeListGetString(attrs, NULL,
660355b4669Sjacobs 				"printer-name", &destination);
661355b4669Sjacobs 	(void) papiAttributeListGetInteger(attrs, NULL,
662355b4669Sjacobs 				"job-id", &id);
663355b4669Sjacobs 	snprintf(request, sizeof (request), "%s-%d", destination, id);
664355b4669Sjacobs 
665355b4669Sjacobs 	if (show_rank != 0) {
666355b4669Sjacobs 		int32_t rank = -1;
667355b4669Sjacobs 
668355b4669Sjacobs 		(void) papiAttributeListGetInteger(attrs, NULL,
669355b4669Sjacobs 				"number-of-intervening-jobs", &rank);
670355b4669Sjacobs 		rank++;
671355b4669Sjacobs 
672355b4669Sjacobs 		printf("%3d %-21s %-14s %7ld %s",
673355b4669Sjacobs 			rank, request, user, size, date);
674355b4669Sjacobs 	} else
675355b4669Sjacobs 		printf("%-23s %-14s %7ld   %s", request, user, size, date);
676355b4669Sjacobs 
677355b4669Sjacobs 	(void) papiAttributeListGetInteger(attrs, NULL,
678355b4669Sjacobs 				"job-state", &jstate);
679355b4669Sjacobs 	if (jstate == 0x04)
680355b4669Sjacobs 		printf(gettext(", being held"));
681355b4669Sjacobs 	else if (jstate == 0x07)
682355b4669Sjacobs 		printf(gettext(", cancelled"));
683355b4669Sjacobs 	else if (jstate == 0x09)
684355b4669Sjacobs 		printf(gettext(", complete"));
685355b4669Sjacobs 
686355b4669Sjacobs 	if (verbose == 1) {
6870a44ef6dSjacobs 		char *form = NULL;
6880a44ef6dSjacobs 
689355b4669Sjacobs 		(void) papiAttributeListGetString(attrs, NULL,
690355b4669Sjacobs 				"output-device-assigned", &destination);
691355b4669Sjacobs 		printf("\n\t assigned %s", destination);
6920a44ef6dSjacobs 
6930a44ef6dSjacobs 		(void) papiAttributeListGetString(attrs, NULL, "form", &form);
6940a44ef6dSjacobs 		if (form != NULL)
6950a44ef6dSjacobs 			printf(", form %s", form);
696355b4669Sjacobs 	} else if (verbose > 1) {
697355b4669Sjacobs 		printf("\n");
698355b4669Sjacobs 		papiAttributeListPrint(stdout, attrs, "\t");
699355b4669Sjacobs 	}
700355b4669Sjacobs 
701355b4669Sjacobs 	printf("\n");
702355b4669Sjacobs 
703355b4669Sjacobs 	return (0);
704355b4669Sjacobs }
705355b4669Sjacobs 
706355b4669Sjacobs static int
707355b4669Sjacobs job_query(char *request, int (*report)(papi_job_t, int, int),
708355b4669Sjacobs 		papi_encryption_t encryption, int show_rank, int verbose)
709355b4669Sjacobs {
710355b4669Sjacobs 	int result = 0;
711355b4669Sjacobs 	papi_status_t status;
712355b4669Sjacobs 	papi_service_t svc = NULL;
713355b4669Sjacobs 	char *printer = NULL;
714355b4669Sjacobs 	int32_t id = -1;
715355b4669Sjacobs 
716355b4669Sjacobs 	get_printer_id(request, &printer, &id);
717355b4669Sjacobs 
718355b4669Sjacobs 	status = papiServiceCreate(&svc, printer, NULL, NULL, cli_auth_callback,
719355b4669Sjacobs 					encryption, NULL);
720355b4669Sjacobs 	if (status != PAPI_OK) {
721355b4669Sjacobs 		fprintf(stderr, gettext(
722355b4669Sjacobs 			"Failed to contact service for %s: %s\n"),
723355b4669Sjacobs 			(printer ? printer : "all"),
724355b4669Sjacobs 			verbose_papi_message(svc, status));
725355b4669Sjacobs 		return (-1);
726355b4669Sjacobs 	}
727355b4669Sjacobs 
728355b4669Sjacobs 	if (printer == NULL) { /* all */
729355b4669Sjacobs 		char **interest = interest_list(svc);
730355b4669Sjacobs 
731355b4669Sjacobs 		if (interest != NULL) {
732355b4669Sjacobs 			int i;
733355b4669Sjacobs 
734355b4669Sjacobs 			for (i = 0; interest[i] != NULL; i++)
735355b4669Sjacobs 				result += job_query(interest[i], report,
736355b4669Sjacobs 						encryption, show_rank, verbose);
737355b4669Sjacobs 		}
738355b4669Sjacobs 	} else if (id == -1) { /* a printer */
739355b4669Sjacobs 		papi_job_t *jobs = NULL;
740355b4669Sjacobs 
741355b4669Sjacobs 		status = papiPrinterListJobs(svc, printer, NULL, 0, 0, &jobs);
742355b4669Sjacobs 		if (status != PAPI_OK) {
743355b4669Sjacobs 			fprintf(stderr, gettext(
744355b4669Sjacobs 				"Failed to get job list: %s\n"),
745355b4669Sjacobs 				verbose_papi_message(svc, status));
746355b4669Sjacobs 			papiServiceDestroy(svc);
747355b4669Sjacobs 			return (-1);
748355b4669Sjacobs 		}
749355b4669Sjacobs 
750355b4669Sjacobs 		if (jobs != NULL) {
751355b4669Sjacobs 			int i;
752355b4669Sjacobs 
753355b4669Sjacobs 			for (i = 0; jobs[i] != NULL; i++)
754355b4669Sjacobs 				result += report(jobs[i], show_rank, verbose);
755355b4669Sjacobs 		}
756355b4669Sjacobs 
757355b4669Sjacobs 		papiJobListFree(jobs);
758355b4669Sjacobs 	} else {	/* a job */
759355b4669Sjacobs 		papi_job_t job = NULL;
760355b4669Sjacobs 
761355b4669Sjacobs 		status = papiJobQuery(svc, printer, id, NULL, &job);
762355b4669Sjacobs 		if (status != PAPI_OK) {
763355b4669Sjacobs 			fprintf(stderr, gettext(
764355b4669Sjacobs 				"Failed to get job info for %s: %s\n"),
765355b4669Sjacobs 				request, verbose_papi_message(svc, status));
766355b4669Sjacobs 			papiServiceDestroy(svc);
767355b4669Sjacobs 			return (-1);
768355b4669Sjacobs 		}
769355b4669Sjacobs 
770355b4669Sjacobs 		if (job != NULL)
771355b4669Sjacobs 			result = report(job, show_rank, verbose);
772355b4669Sjacobs 
773355b4669Sjacobs 		papiJobFree(job);
774355b4669Sjacobs 	}
775355b4669Sjacobs 
776355b4669Sjacobs 	papiServiceDestroy(svc);
777355b4669Sjacobs 
778355b4669Sjacobs 	return (result);
779355b4669Sjacobs }
780355b4669Sjacobs 
781355b4669Sjacobs static int
782355b4669Sjacobs report_form(char *name, papi_attribute_t **attrs, int verbose)
783355b4669Sjacobs {
784355b4669Sjacobs 	papi_status_t status;
785355b4669Sjacobs 	char *form = NULL;
786355b4669Sjacobs 	void *iter = NULL;
787355b4669Sjacobs 
788355b4669Sjacobs 	for (status = papiAttributeListGetString(attrs, &iter,
789355b4669Sjacobs 					"form-supported", &form);
790355b4669Sjacobs 		status == PAPI_OK;
791355b4669Sjacobs 		status = papiAttributeListGetString(attrs, &iter,
792355b4669Sjacobs 							NULL, &form)) {
793355b4669Sjacobs 		if ((name == NULL) || (strcmp(name, form) == 0)) {
794355b4669Sjacobs 			printf(gettext("form %s is available to you\n"), form);
795355b4669Sjacobs 			if (verbose != 0) {
796355b4669Sjacobs 				char *detail = NULL;
797355b4669Sjacobs 				status = papiAttributeListGetString(attrs, NULL,
798355b4669Sjacobs 						"form-supported-detail",
799355b4669Sjacobs 						&detail);
800355b4669Sjacobs 				if (status == PAPI_OK)
801355b4669Sjacobs 					printf("%s\n", detail);
802355b4669Sjacobs 			}
803355b4669Sjacobs 		}
804355b4669Sjacobs 	}
805355b4669Sjacobs 
806355b4669Sjacobs 	return (0);
807355b4669Sjacobs }
808355b4669Sjacobs 
809355b4669Sjacobs static int
810355b4669Sjacobs report_print_wheels(char *name, papi_attribute_t **attrs, int verbose)
811355b4669Sjacobs {
812355b4669Sjacobs 	papi_status_t status;
813355b4669Sjacobs 	char *pw = NULL;
814355b4669Sjacobs 	void *iter = NULL;
815355b4669Sjacobs 
816355b4669Sjacobs 	for (status = papiAttributeListGetString(attrs, &iter,
817355b4669Sjacobs 					"pw-supported", &pw);
818355b4669Sjacobs 		status == PAPI_OK;
819355b4669Sjacobs 		status = papiAttributeListGetString(attrs, &iter, NULL, &pw)) {
820355b4669Sjacobs 		if ((name == NULL) || (strcmp(name, pw) == 0)) {
821355b4669Sjacobs 			printf(gettext("charset %s is available\n"), pw);
822355b4669Sjacobs 			if (verbose != 0) {
823355b4669Sjacobs 				char *info = NULL;
824355b4669Sjacobs 				status = papiAttributeListGetString(attrs, NULL,
825355b4669Sjacobs 						"pw-supported-extra", &info);
826355b4669Sjacobs 				if (status == PAPI_OK)
827355b4669Sjacobs 					printf("%s\n", info);
828355b4669Sjacobs 			}
829355b4669Sjacobs 		}
830355b4669Sjacobs 	}
831355b4669Sjacobs 
832355b4669Sjacobs 	return (0);
833355b4669Sjacobs }
834355b4669Sjacobs 
835355b4669Sjacobs static int
836355b4669Sjacobs service_query(char *name, int (*report)(char *, papi_attribute_t **, int),
837355b4669Sjacobs 		papi_encryption_t encryption, int verbose)
838355b4669Sjacobs {
839355b4669Sjacobs 	int result = 0;
840355b4669Sjacobs 	papi_status_t status;
841355b4669Sjacobs 	papi_service_t svc = NULL;
842355b4669Sjacobs 	papi_attribute_t **attrs = NULL;
843355b4669Sjacobs 
844355b4669Sjacobs 	status = papiServiceCreate(&svc, name, NULL, NULL, cli_auth_callback,
845355b4669Sjacobs 					encryption, NULL);
846355b4669Sjacobs 	if (status != PAPI_OK) {
847355b4669Sjacobs 		papiServiceDestroy(svc);
848355b4669Sjacobs 		return (-1);
849355b4669Sjacobs 	}
850355b4669Sjacobs 
851355b4669Sjacobs 	attrs = papiServiceGetAttributeList(svc);
852355b4669Sjacobs 	if (attrs != NULL) {
853355b4669Sjacobs 		result = report(name, attrs, verbose);
854355b4669Sjacobs 
855355b4669Sjacobs 		if (verbose > 1) {
856355b4669Sjacobs 			printf("\n");
857355b4669Sjacobs 			papiAttributeListPrint(stdout, attrs, "\t");
858355b4669Sjacobs 			printf("\n");
859355b4669Sjacobs 		}
860355b4669Sjacobs 	}
861355b4669Sjacobs 
862355b4669Sjacobs 	papiServiceDestroy(svc);
863355b4669Sjacobs 
864355b4669Sjacobs 	return (result);
865355b4669Sjacobs }
866355b4669Sjacobs 
867355b4669Sjacobs int
868355b4669Sjacobs main(int ac, char *av[])
869355b4669Sjacobs {
870355b4669Sjacobs 	int exit_code = 0;
871355b4669Sjacobs 	papi_encryption_t encryption = PAPI_ENCRYPT_NEVER;
872355b4669Sjacobs 	int rank = 0;
873355b4669Sjacobs 	int verbose = 0;
874355b4669Sjacobs 	int description = 0;
875355b4669Sjacobs 	int c;
876355b4669Sjacobs 	char **argv;
877355b4669Sjacobs 
878355b4669Sjacobs 	(void) setlocale(LC_ALL, "");
879355b4669Sjacobs 	(void) textdomain("SUNW_OST_OSCMD");
880355b4669Sjacobs 
881355b4669Sjacobs 	argv = (char **)calloc((ac + 1), sizeof (char *));
88291216fe4Swendyp 	for (c = 0; c < ac; c++) {
88391216fe4Swendyp 		if ((av[c][0] == '-') && (av[c][1] == 'l') &&
88491216fe4Swendyp 			(isalpha(av[c][2]) != 0)) {
88591216fe4Swendyp 			/* preserve old "-l[po...]" behavior */
88691216fe4Swendyp 			argv[c] = &av[c][1];
88791216fe4Swendyp 			argv[c][0] = '-';
88891216fe4Swendyp 			verbose = 1;
88991216fe4Swendyp 
89091216fe4Swendyp 		} else
891355b4669Sjacobs 			argv[c] = av[c];
89291216fe4Swendyp 	}
89391216fe4Swendyp 
894355b4669Sjacobs 	argv[c++] = "--";
895355b4669Sjacobs 	ac = c;
896355b4669Sjacobs 
897355b4669Sjacobs 	/* preprocess argument list looking for '-l' or '-R' so it can trail */
898355b4669Sjacobs 	while ((c = getopt(ac, argv, "LEDf:S:stc:p:a:drs:v:l:o:R:u:")) != EOF)
899355b4669Sjacobs 		switch (c) {
900355b4669Sjacobs 		case 'l':
901355b4669Sjacobs 			if ((optarg == NULL) || (optarg[0] == '-'))
902355b4669Sjacobs 				optarg = "1";
903355b4669Sjacobs 			verbose = atoi(optarg);
904355b4669Sjacobs 			break;
905355b4669Sjacobs 		case 'D':
906355b4669Sjacobs 			description = 1;
907355b4669Sjacobs 			break;
908355b4669Sjacobs 		case 'R':
909355b4669Sjacobs 			rank = 1;
910355b4669Sjacobs 			break;
911355b4669Sjacobs 		case 'E':
912355b4669Sjacobs 			encryption = PAPI_ENCRYPT_REQUIRED;
913355b4669Sjacobs 			break;
914355b4669Sjacobs 		default:
915355b4669Sjacobs 			break;
916355b4669Sjacobs 		}
917355b4669Sjacobs 	optind = 1;
918355b4669Sjacobs 
919355b4669Sjacobs 	/* process command line arguments */
920355b4669Sjacobs 	while ((c = getopt(ac, argv, "LEDf:S:stc:p:a:drs:v:l:o:R:u:")) != EOF) {
921355b4669Sjacobs 		switch (c) {	/* these may or may not have an option */
922355b4669Sjacobs 		case 'a':
923355b4669Sjacobs 		case 'c':
924355b4669Sjacobs 		case 'p':
925355b4669Sjacobs 		case 'o':
926355b4669Sjacobs 		case 'R':
927355b4669Sjacobs 		case 'u':
928355b4669Sjacobs 		case 'v':
929355b4669Sjacobs 		case 'l':
930355b4669Sjacobs 		case 'f':
931355b4669Sjacobs 		case 'S':
932355b4669Sjacobs 			if (optarg[0] == '-') {
933355b4669Sjacobs 				/* this check stop a possible infinite loop */
934355b4669Sjacobs 				if ((optind > 1) && (argv[optind-1][1] != c))
935355b4669Sjacobs 					optind--;
936355b4669Sjacobs 				optarg = NULL;
937355b4669Sjacobs 			} else if (strcmp(optarg, "all") == 0)
938355b4669Sjacobs 				optarg = NULL;
939355b4669Sjacobs 		}
940355b4669Sjacobs 
941355b4669Sjacobs 		switch (c) {
942355b4669Sjacobs 		case 'a':
943355b4669Sjacobs 			exit_code += printer_query(optarg, report_accepting,
944355b4669Sjacobs 						encryption, verbose, 0);
945355b4669Sjacobs 			break;
946355b4669Sjacobs 		case 'c':
947355b4669Sjacobs 			exit_code += printer_query(optarg, report_class,
948355b4669Sjacobs 						encryption, verbose, 0);
949355b4669Sjacobs 			break;
950355b4669Sjacobs 		case 'p':
951355b4669Sjacobs 			exit_code += printer_query(optarg, report_printer,
952355b4669Sjacobs 						encryption, verbose,
953355b4669Sjacobs 						description);
954355b4669Sjacobs 			break;
955355b4669Sjacobs 		case 'd':
956355b4669Sjacobs 			exit_code += lpstat_default_printer(encryption);
957355b4669Sjacobs 			break;
958355b4669Sjacobs 		case 'r':
959355b4669Sjacobs 			exit_code += lpstat_service_status(encryption);
960355b4669Sjacobs 			break;
961355b4669Sjacobs 		case 'u':
962355b4669Sjacobs 			if (optarg != NULL)
963355b4669Sjacobs 				users = strsplit(optarg, ", \n");
964355b4669Sjacobs 			exit_code += job_query(NULL, report_job,
965355b4669Sjacobs 						encryption, rank, verbose);
966355b4669Sjacobs 			if (users != NULL) {
967355b4669Sjacobs 				free(users);
968355b4669Sjacobs 				users = NULL;
969355b4669Sjacobs 			}
970355b4669Sjacobs 			break;
971355b4669Sjacobs 		case 'v':
972355b4669Sjacobs 			exit_code += printer_query(optarg, report_device,
973355b4669Sjacobs 						encryption, verbose, 0);
974355b4669Sjacobs 			break;
975355b4669Sjacobs 		case 'o':
976355b4669Sjacobs 			exit_code += job_query(optarg, report_job,
977355b4669Sjacobs 						encryption, rank, verbose);
978355b4669Sjacobs 			break;
979355b4669Sjacobs 		case 'f':
980355b4669Sjacobs 			exit_code += service_query(optarg, report_form,
981355b4669Sjacobs 						encryption, verbose);
982355b4669Sjacobs 			break;
983355b4669Sjacobs 		case 'S':
984355b4669Sjacobs 			exit_code += service_query(optarg, report_print_wheels,
985355b4669Sjacobs 						encryption, verbose);
986355b4669Sjacobs 			break;
987355b4669Sjacobs 		case 's':
988355b4669Sjacobs 			exit_code += lpstat_service_status(encryption);
989355b4669Sjacobs 			exit_code += lpstat_default_printer(encryption);
990355b4669Sjacobs 			exit_code += printer_query(NULL, report_class,
991355b4669Sjacobs 						encryption, verbose, 0);
992355b4669Sjacobs 			exit_code += printer_query(NULL, report_device,
993355b4669Sjacobs 						encryption, verbose, 0);
994355b4669Sjacobs 			exit_code += service_query(optarg, report_form,
995355b4669Sjacobs 						encryption, verbose);
996355b4669Sjacobs 			exit_code += service_query(optarg, report_print_wheels,
997355b4669Sjacobs 						encryption, verbose);
998355b4669Sjacobs 			break;
999355b4669Sjacobs 		case 't':
1000355b4669Sjacobs 			exit_code += lpstat_service_status(encryption);
1001355b4669Sjacobs 			exit_code += lpstat_default_printer(encryption);
1002355b4669Sjacobs 			exit_code += printer_query(NULL, report_class,
1003355b4669Sjacobs 						encryption, verbose, 0);
1004355b4669Sjacobs 			exit_code += printer_query(NULL, report_device,
1005355b4669Sjacobs 						encryption, verbose, 0);
1006355b4669Sjacobs 			exit_code += printer_query(NULL, report_accepting,
1007355b4669Sjacobs 						encryption, verbose, 0);
1008355b4669Sjacobs 			exit_code += printer_query(NULL, report_printer,
1009355b4669Sjacobs 						encryption, verbose, 0);
1010355b4669Sjacobs 			exit_code += service_query(optarg, report_form,
1011355b4669Sjacobs 						encryption, verbose);
1012355b4669Sjacobs 			exit_code += service_query(optarg, report_print_wheels,
1013355b4669Sjacobs 						encryption, verbose);
1014355b4669Sjacobs 			exit_code += job_query(NULL, report_job,
1015355b4669Sjacobs 						encryption, rank, verbose);
1016355b4669Sjacobs 			break;
1017355b4669Sjacobs 		case 'L':	/* local-only, ignored */
1018355b4669Sjacobs 		case 'l':	/* increased verbose level in first pass */
1019355b4669Sjacobs 		case 'D':	/* set "description" flag in first pass */
1020355b4669Sjacobs 		case 'R':	/* set "rank" flag in first pass */
1021355b4669Sjacobs 		case 'E':	/* set encryption in the first pass */
1022355b4669Sjacobs 			break;
1023355b4669Sjacobs 		default:
1024355b4669Sjacobs 			usage(av[0]);
1025355b4669Sjacobs 		}
1026355b4669Sjacobs 	}
1027355b4669Sjacobs 	ac--;
1028355b4669Sjacobs 
1029355b4669Sjacobs 	if (ac == 1) {	/* report on my jobs */
1030355b4669Sjacobs 		struct passwd *pw = getpwuid(getuid());
1031355b4669Sjacobs 
1032355b4669Sjacobs 		if (pw != NULL)
1033355b4669Sjacobs 			users = strsplit(pw->pw_name, "");
1034355b4669Sjacobs 		exit_code += job_query(NULL, report_job, encryption,
1035355b4669Sjacobs 					rank, verbose);
1036355b4669Sjacobs 		if (users != NULL) {
1037355b4669Sjacobs 			free(users);
1038355b4669Sjacobs 			users = NULL;
1039355b4669Sjacobs 		}
1040355b4669Sjacobs 	} else {
1041355b4669Sjacobs 		for (c = optind; c < ac; c++)
1042355b4669Sjacobs 			exit_code += job_query(argv[c], report_job, encryption,
1043355b4669Sjacobs 					rank, verbose);
1044355b4669Sjacobs 	}
1045355b4669Sjacobs 
1046355b4669Sjacobs 
1047355b4669Sjacobs 	if (exit_code != 0)
1048355b4669Sjacobs 		exit_code = 1;
1049355b4669Sjacobs 
1050355b4669Sjacobs 	return (exit_code);
1051355b4669Sjacobs }
1052