12264Sjacobs /*
22264Sjacobs  * CDDL HEADER START
32264Sjacobs  *
42264Sjacobs  * The contents of this file are subject to the terms of the
52264Sjacobs  * Common Development and Distribution License (the "License").
62264Sjacobs  * You may not use this file except in compliance with the License.
72264Sjacobs  *
82264Sjacobs  * You can obtain a copy of the license at usr/src/OPENSOLARIS.LICENSE
92264Sjacobs  * or http://www.opensolaris.org/os/licensing.
102264Sjacobs  * See the License for the specific language governing permissions
112264Sjacobs  * and limitations under the License.
122264Sjacobs  *
132264Sjacobs  * When distributing Covered Code, include this CDDL HEADER in each
142264Sjacobs  * file and include the License file at usr/src/OPENSOLARIS.LICENSE.
152264Sjacobs  * If applicable, add the following below this CDDL HEADER, with the
162264Sjacobs  * fields enclosed by brackets "[]" replaced with your own identifying
172264Sjacobs  * information: Portions Copyright [yyyy] [name of copyright owner]
182264Sjacobs  *
192264Sjacobs  * CDDL HEADER END
202264Sjacobs  */
212264Sjacobs 
222264Sjacobs /*
238534SSonam.Gupta@Sun.COM  * Copyright 2009 Sun Microsystems, Inc.  All rights reserved.
242264Sjacobs  * Use is subject to license terms.
252264Sjacobs  *
262264Sjacobs  */
272264Sjacobs 
282264Sjacobs /* $Id: lpstat.c 173 2006-05-25 04:52:06Z njacobs $ */
292264Sjacobs 
302264Sjacobs 
312264Sjacobs #include <stdio.h>
322264Sjacobs #include <stdlib.h>
332264Sjacobs #include <unistd.h>
342264Sjacobs #include <string.h>
352264Sjacobs #include <locale.h>
362264Sjacobs #include <libintl.h>
374286Swendyp #include <ctype.h>
382264Sjacobs #include <pwd.h>
392264Sjacobs #include <papi.h>
402264Sjacobs #include <uri.h>
412264Sjacobs #include "common.h"
422264Sjacobs 
432264Sjacobs static void
442264Sjacobs usage(char *program)
452264Sjacobs {
462264Sjacobs 	char *name;
472264Sjacobs 
482264Sjacobs 	if ((name = strrchr(program, '/')) == NULL)
492264Sjacobs 		name = program;
502264Sjacobs 	else
512264Sjacobs 		name++;
522264Sjacobs 
532264Sjacobs 	fprintf(stdout, gettext("Usage: %s [-d] [-r] [-s] [-t] [-a [list]] "
548962SSonam.Gupta@Sun.COM 	    "[-c [list]] [-o [list] [-l]] [-R [list] [-l]] "
558962SSonam.Gupta@Sun.COM 	    "[-p [list] [-D] [-l]] [-v [list]] [-S [list] [-l]] "
568962SSonam.Gupta@Sun.COM 	    "[-f [list] [-l]] [-u list]\n"),
578962SSonam.Gupta@Sun.COM 	    name);
582264Sjacobs 	exit(1);
592264Sjacobs }
602264Sjacobs 
612264Sjacobs static char *
622264Sjacobs nctime(time_t *t)
632264Sjacobs {
642264Sjacobs 	static char buf[64];
652264Sjacobs 	struct tm *tm = localtime(t);
662264Sjacobs 
672264Sjacobs 	(void) strftime(buf, sizeof (buf), "%c", tm);
682264Sjacobs 
692264Sjacobs 	return (buf);
702264Sjacobs }
712264Sjacobs 
722264Sjacobs static char *
732264Sjacobs printer_name(papi_printer_t printer)
742264Sjacobs {
752264Sjacobs 	papi_attribute_t **attributes = papiPrinterGetAttributeList(printer);
762264Sjacobs 	char *result = NULL;
772264Sjacobs 
782264Sjacobs 	if (attributes != NULL)
792264Sjacobs 		papiAttributeListGetString(attributes, NULL,
808962SSonam.Gupta@Sun.COM 		    "printer-name", &result);
812264Sjacobs 
822264Sjacobs 	return (result);
832264Sjacobs }
842264Sjacobs 
852264Sjacobs static int
862264Sjacobs lpstat_default_printer(papi_encryption_t encryption)
872264Sjacobs {
882264Sjacobs 	papi_status_t status;
892264Sjacobs 	papi_service_t svc = NULL;
902264Sjacobs 	papi_printer_t p = NULL;
912264Sjacobs 	char *name = NULL;
922264Sjacobs 
932264Sjacobs 	status = papiServiceCreate(&svc, NULL, NULL, NULL, cli_auth_callback,
948962SSonam.Gupta@Sun.COM 	    encryption, NULL);
952264Sjacobs 	if (status == PAPI_OK) {
962264Sjacobs 		char *req[] = { "printer-name", NULL };
972264Sjacobs 
982264Sjacobs 		status = papiPrinterQuery(svc, DEFAULT_DEST, req, NULL, &p);
992264Sjacobs 		if (p != NULL)
1002264Sjacobs 			name = printer_name(p);
1012264Sjacobs 	}
1022264Sjacobs 	if (name != NULL)
1032264Sjacobs 		printf(gettext("system default printer: %s\n"), name);
1042264Sjacobs 	else
1052264Sjacobs 		printf(gettext("no system default destination\n"));
1062264Sjacobs 	papiPrinterFree(p);
1072264Sjacobs 	papiServiceDestroy(svc);
1082264Sjacobs 
1092264Sjacobs 	return (0);
1102264Sjacobs }
1112264Sjacobs 
1122264Sjacobs static int
1132264Sjacobs lpstat_service_status(papi_encryption_t encryption)
1142264Sjacobs {
1152264Sjacobs 	int result = 0;
1162264Sjacobs 	papi_status_t status;
1172264Sjacobs 	papi_service_t svc = NULL;
1182264Sjacobs 	char *name = NULL;
1192264Sjacobs 
1202264Sjacobs 	if (((name = getenv("PAPI_SERVICE_URI")) == NULL) &&
1212264Sjacobs 	    ((name = getenv("IPP_SERVER")) == NULL) &&
1222264Sjacobs 	    ((name = getenv("CUPS_SERVER")) == NULL))
1232264Sjacobs 		name = DEFAULT_SERVICE_URI;
1242264Sjacobs 
1252264Sjacobs 	status = papiServiceCreate(&svc, name, NULL, NULL, cli_auth_callback,
1268962SSonam.Gupta@Sun.COM 	    encryption, NULL);
1272264Sjacobs 	if (status != PAPI_OK) {
1282264Sjacobs 		printf(gettext("scheduler is not running\n"));
1292264Sjacobs 		result = -1;
1302264Sjacobs 	} else
1312264Sjacobs 		printf(gettext("scheduler is running\n"));
1322264Sjacobs 	papiServiceDestroy(svc);
1332264Sjacobs 
1342264Sjacobs 	return (result);
1352264Sjacobs }
1362264Sjacobs 
1372264Sjacobs static char *
1382264Sjacobs get_device_uri(papi_service_t svc, char *name)
1392264Sjacobs {
1402264Sjacobs 	papi_status_t status;
1412264Sjacobs 	papi_printer_t p = NULL;
1422264Sjacobs 	char *keys[] = { "device-uri", NULL };
1432264Sjacobs 	char *result = NULL;
1442264Sjacobs 
1452264Sjacobs 	status = papiPrinterQuery(svc, name, keys, NULL, &p);
1462264Sjacobs 	if ((status == PAPI_OK) && (p != NULL)) {
1472264Sjacobs 		papi_attribute_t **attrs = papiPrinterGetAttributeList(p);
1482264Sjacobs 
1492264Sjacobs 		(void) papiAttributeListGetString(attrs, NULL,
1508962SSonam.Gupta@Sun.COM 		    "device-uri", &result);
1512264Sjacobs 		if (result != NULL)
1522264Sjacobs 			result = strdup(result);
1532264Sjacobs 
1542264Sjacobs 		papiPrinterFree(p);
1552264Sjacobs 	}
1562264Sjacobs 
1572264Sjacobs 	return (result);
1582264Sjacobs }
1592264Sjacobs 
1608534SSonam.Gupta@Sun.COM static void
1618534SSonam.Gupta@Sun.COM print_description(papi_attribute_t **list, char *printer_name)
1628534SSonam.Gupta@Sun.COM {
1638534SSonam.Gupta@Sun.COM 	char *str = "";
1648534SSonam.Gupta@Sun.COM 
1658534SSonam.Gupta@Sun.COM 	(void) papiAttributeListGetString(list, NULL,
1668534SSonam.Gupta@Sun.COM 	    "printer-info", &str);
1678534SSonam.Gupta@Sun.COM 
1688534SSonam.Gupta@Sun.COM 	/*
1698534SSonam.Gupta@Sun.COM 	 * If no printer-info is read then
1708534SSonam.Gupta@Sun.COM 	 * by default the printer-info is <printer-name>@<server>
1718534SSonam.Gupta@Sun.COM 	 */
1728534SSonam.Gupta@Sun.COM 	if (str[0] == '\0') {
1738534SSonam.Gupta@Sun.COM 		char *uri = NULL;
1748534SSonam.Gupta@Sun.COM 		uri_t *u = NULL;
1758534SSonam.Gupta@Sun.COM 
1768534SSonam.Gupta@Sun.COM 		(void) papiAttributeListGetString(list, NULL,
1778534SSonam.Gupta@Sun.COM 		    "printer-uri-supported", &uri);
1788534SSonam.Gupta@Sun.COM 
1798534SSonam.Gupta@Sun.COM 		if ((uri != NULL) && (uri_from_string(uri, &u) == 0)) {
1808534SSonam.Gupta@Sun.COM 			char *nodename = localhostname();
1818534SSonam.Gupta@Sun.COM 
1828534SSonam.Gupta@Sun.COM 			if ((u->host == NULL) ||
1838534SSonam.Gupta@Sun.COM 			    (strcasecmp(u->host, "localhost") == 0) ||
1848534SSonam.Gupta@Sun.COM 			    (strcasecmp(u->host, nodename) == 0))
1858534SSonam.Gupta@Sun.COM 				printf(gettext("\tDescription:\n"));
1868534SSonam.Gupta@Sun.COM 			else
1878534SSonam.Gupta@Sun.COM 				printf(gettext("\tDescription: %s@%s\n"),
1888534SSonam.Gupta@Sun.COM 				    printer_name, u->host);
1898534SSonam.Gupta@Sun.COM 
1908534SSonam.Gupta@Sun.COM 			uri_free(u);
1918534SSonam.Gupta@Sun.COM 		} else
1928534SSonam.Gupta@Sun.COM 			printf(gettext("\tDescription:\n"));
1938534SSonam.Gupta@Sun.COM 	} else
1948534SSonam.Gupta@Sun.COM 		printf(gettext("\tDescription: %s\n"), str);
1958534SSonam.Gupta@Sun.COM }
1968534SSonam.Gupta@Sun.COM 
1972264Sjacobs static char *report_device_keys[] = { "printer-name", "printer-uri-supported",
1982264Sjacobs 					NULL };
1992264Sjacobs /* ARGSUSED2 */
2002264Sjacobs static int
2012264Sjacobs report_device(papi_service_t svc, char *name, papi_printer_t printer,
2022264Sjacobs 		int verbose, int description)
2032264Sjacobs {
2042264Sjacobs 	papi_status_t status;
2052264Sjacobs 	papi_attribute_t **attrs = papiPrinterGetAttributeList(printer);
2062264Sjacobs 	char *uri = NULL;
2072264Sjacobs 	char *device = NULL;
2082264Sjacobs 	uri_t *u = NULL;
2092264Sjacobs 
2102264Sjacobs 	if (name == NULL) {
2112264Sjacobs 		status = papiAttributeListGetString(attrs, NULL,
2128962SSonam.Gupta@Sun.COM 		    "printer-name", &name);
2132264Sjacobs 		if (status != PAPI_OK)
2142264Sjacobs 			status = papiAttributeListGetString(attrs, NULL,
2158962SSonam.Gupta@Sun.COM 			    "printer-uri-supported", &name);
2162264Sjacobs 	}
2172264Sjacobs 
2182264Sjacobs 	if (name == NULL)
2192264Sjacobs 		return (-1);
2202264Sjacobs 
2212264Sjacobs 	(void) papiAttributeListGetString(attrs, NULL,
2228962SSonam.Gupta@Sun.COM 	    "printer-uri-supported", &uri);
2232264Sjacobs 
2242264Sjacobs 	if ((uri != NULL) && (uri_from_string(uri, &u) == 0)) {
2252264Sjacobs 		char *nodename = localhostname();
2262264Sjacobs 
2272264Sjacobs 		if ((u->host == NULL) ||
2282264Sjacobs 		    (strcasecmp(u->host, "localhost") == 0) ||
2292264Sjacobs 		    (strcasecmp(u->host, nodename) == 0))
2302264Sjacobs 			device = get_device_uri(svc, name);
2312264Sjacobs 
2322264Sjacobs 		if (device != NULL) {
2332264Sjacobs 			printf(gettext("device for %s: %s\n"), name, device);
2342264Sjacobs 			return (0);
2352264Sjacobs 		} else if (uri != NULL) {
2362264Sjacobs 			printf(gettext("system for %s: %s (as %s)\n"), name,
2378962SSonam.Gupta@Sun.COM 			    u->host, uri);
2382264Sjacobs 			return (0);
2392264Sjacobs 		}
2402264Sjacobs 
2412264Sjacobs 		uri_free(u);
2422264Sjacobs 	}
2432264Sjacobs 
2442264Sjacobs 	return (0);
2452264Sjacobs }
2462264Sjacobs 
2472264Sjacobs static char *report_accepting_keys[] = { "printer-name",
2482264Sjacobs 			"printer-uri-supported", "printer-is-accepting-jobs",
2492264Sjacobs 			"printer-up-time", "printer-state-time",
2502264Sjacobs 			"lpsched-reject-date", "lpsched-reject-reason", NULL };
2512264Sjacobs /* ARGSUSED2 */
2522264Sjacobs static int
2532264Sjacobs report_accepting(papi_service_t svc, char *name, papi_printer_t printer,
2542264Sjacobs 		int verbose, int description)
2552264Sjacobs {
2562264Sjacobs 	papi_status_t status;
2572264Sjacobs 	papi_attribute_t **attrs = papiPrinterGetAttributeList(printer);
2582264Sjacobs 	time_t curr;
2592264Sjacobs 	char boolean = PAPI_FALSE;
2602264Sjacobs 
2612264Sjacobs 	if (name == NULL) {
2622264Sjacobs 		status = papiAttributeListGetString(attrs, NULL,
2638962SSonam.Gupta@Sun.COM 		    "printer-name", &name);
2642264Sjacobs 		if (status != PAPI_OK)
2652264Sjacobs 			status = papiAttributeListGetString(attrs, NULL,
2668962SSonam.Gupta@Sun.COM 			    "printer-uri-supported", &name);
2672264Sjacobs 	}
2682264Sjacobs 	if (name == NULL)
2692264Sjacobs 		return (-1);
2702264Sjacobs 
2712264Sjacobs 	(void) papiAttributeListGetBoolean(attrs, NULL,
2728962SSonam.Gupta@Sun.COM 	    "printer-is-accepting-jobs", &boolean);
2732264Sjacobs 	(void) time(&curr);
2742264Sjacobs 	(void) papiAttributeListGetDatetime(attrs, NULL,
2758962SSonam.Gupta@Sun.COM 	    "printer-up-time", &curr);
2762264Sjacobs 	(void) papiAttributeListGetDatetime(attrs, NULL,
2778962SSonam.Gupta@Sun.COM 	    "printer-state-time", &curr);
2782264Sjacobs 	(void) papiAttributeListGetDatetime(attrs, NULL,
2798962SSonam.Gupta@Sun.COM 	    "lpsched-reject-date", &curr);
2802264Sjacobs 
2812264Sjacobs 	if (boolean == PAPI_TRUE) {
2822264Sjacobs 		printf(gettext("%s accepting requests since %s\n"),
2838962SSonam.Gupta@Sun.COM 		    name, nctime(&curr));
2842264Sjacobs 	} else {
2852264Sjacobs 		char *reason = "unknown reason";
2862264Sjacobs 
2872264Sjacobs 		(void) papiAttributeListGetString(attrs, NULL,
2888962SSonam.Gupta@Sun.COM 		    "lpsched-reject-reason", &reason);
2892264Sjacobs 
2902264Sjacobs 		printf(gettext("%s not accepting requests since %s\n\t%s\n"),
2918962SSonam.Gupta@Sun.COM 		    name, nctime(&curr), reason);
2922264Sjacobs 	}
2932264Sjacobs 
2942264Sjacobs 	return (0);
2952264Sjacobs }
2962264Sjacobs 
2972264Sjacobs static char *report_class_keys[] = { "printer-name", "printer-uri-supported",
2982264Sjacobs 					"member-names", NULL };
2992264Sjacobs /* ARGSUSED2 */
3002264Sjacobs static int
3012264Sjacobs report_class(papi_service_t svc, char *name, papi_printer_t printer,
3022264Sjacobs 		int verbose, int description)
3032264Sjacobs {
3042264Sjacobs 	papi_status_t status;
3052264Sjacobs 	papi_attribute_t **attrs = papiPrinterGetAttributeList(printer);
3062264Sjacobs 	char *member = NULL;
3072264Sjacobs 	void *iter = NULL;
3082264Sjacobs 
3092264Sjacobs 	status = papiAttributeListGetString(attrs, &iter,
3108962SSonam.Gupta@Sun.COM 	    "member-names", &member);
3112264Sjacobs 	if (status == PAPI_NOT_FOUND)	/* it's not a class */
3122264Sjacobs 		return (0);
3132264Sjacobs 
3142264Sjacobs 	if (name == NULL) {
3152264Sjacobs 		status = papiAttributeListGetString(attrs, NULL,
3168962SSonam.Gupta@Sun.COM 		    "printer-name", &name);
3172264Sjacobs 		if (status != PAPI_OK)
3182264Sjacobs 			status = papiAttributeListGetString(attrs, NULL,
3198962SSonam.Gupta@Sun.COM 			    "printer-uri-supported", &name);
3202264Sjacobs 	}
3212264Sjacobs 	if (name == NULL)
3222264Sjacobs 		return (-1);
3232264Sjacobs 
3242264Sjacobs 	printf(gettext("members of class %s:\n\t%s\n"), name, member);
3252264Sjacobs 	while (papiAttributeListGetString(attrs, &iter, NULL, &member)
3268962SSonam.Gupta@Sun.COM 	    == PAPI_OK)
3272264Sjacobs 		printf("\t%s\n", member);
3282264Sjacobs 
3292264Sjacobs 	return (0);
3302264Sjacobs }
3312264Sjacobs 
3322264Sjacobs static char *report_printer_keys[] = { "printer-name",
3332264Sjacobs 			"printer-uri-supported", "printer-state",
3342264Sjacobs 			"printer-up-time", "printer-state-time",
3352264Sjacobs 			"lpsched-disable-date", "printer-state-reasons",
3362264Sjacobs 			"lpsched-disable-reason", NULL };
3372264Sjacobs /* ARGSUSED2 */
3382264Sjacobs static int
3392264Sjacobs report_printer(papi_service_t svc, char *name, papi_printer_t printer,
3402264Sjacobs 		int verbose, int description)
3412264Sjacobs {
3422264Sjacobs 	papi_status_t status;
3432264Sjacobs 	papi_attribute_t **attrs = papiPrinterGetAttributeList(printer);
3442264Sjacobs 	time_t curr;
3452264Sjacobs 	int32_t pstat = 0;
3462264Sjacobs 	char *member = NULL;
3478962SSonam.Gupta@Sun.COM 	papi_job_t *j = NULL;
3482264Sjacobs 
3492264Sjacobs 	status = papiAttributeListGetString(attrs, NULL,
3508962SSonam.Gupta@Sun.COM 	    "member-names", &member);
3512264Sjacobs 	if (status == PAPI_OK)	/* it's a class */
3522264Sjacobs 		return (0);
3532264Sjacobs 
3542264Sjacobs 	if (name == NULL) {
3552264Sjacobs 		status = papiAttributeListGetString(attrs, NULL,
3568962SSonam.Gupta@Sun.COM 		    "printer-name", &name);
3572264Sjacobs 		if (status != PAPI_OK)
3582264Sjacobs 			status = papiAttributeListGetString(attrs, NULL,
3598962SSonam.Gupta@Sun.COM 			    "printer-uri-supported", &name);
3602264Sjacobs 	}
3612264Sjacobs 	if (name == NULL)
3622264Sjacobs 		return (-1);
3632264Sjacobs 
3642264Sjacobs 	printf(gettext("printer %s "), name);
3652264Sjacobs 
3662264Sjacobs 	status = papiAttributeListGetInteger(attrs, NULL,
3678962SSonam.Gupta@Sun.COM 	    "printer-state", &pstat);
3682264Sjacobs 
3692264Sjacobs 	switch (pstat) {
3702264Sjacobs 	case 0x03:	/* idle */
3712264Sjacobs 		printf(gettext("idle. enabled"));
3722264Sjacobs 		break;
3738962SSonam.Gupta@Sun.COM 	case 0x04: /* processing */
3748962SSonam.Gupta@Sun.COM 		status = papiPrinterListJobs(svc, name, NULL,
3758962SSonam.Gupta@Sun.COM 		    0, 0, &j);
3768962SSonam.Gupta@Sun.COM 
3778962SSonam.Gupta@Sun.COM 		if (status == PAPI_OK) {
3788962SSonam.Gupta@Sun.COM 			if (j != NULL) {
3798962SSonam.Gupta@Sun.COM 				int i = 0;
3808962SSonam.Gupta@Sun.COM 				int32_t jobid = 0;
3818962SSonam.Gupta@Sun.COM 				int32_t jstate = 0;
3828962SSonam.Gupta@Sun.COM 				int flag = 0;
3838962SSonam.Gupta@Sun.COM 
3848962SSonam.Gupta@Sun.COM 				for (i = 0; j[i] != NULL; ++i) {
3858962SSonam.Gupta@Sun.COM 					attrs = papiJobGetAttributeList(j[i]);
3868962SSonam.Gupta@Sun.COM 
3878962SSonam.Gupta@Sun.COM 					papiAttributeListGetInteger(attrs,
3888962SSonam.Gupta@Sun.COM 					    NULL, "job-state", &jstate);
3898962SSonam.Gupta@Sun.COM 					papiAttributeListGetInteger(attrs,
3908962SSonam.Gupta@Sun.COM 					    NULL, "job-id", &jobid);
3912264Sjacobs 
3928962SSonam.Gupta@Sun.COM 					/*
3938962SSonam.Gupta@Sun.COM 					 * If the job-state is not
3948962SSonam.Gupta@Sun.COM 					 * "held", "cancelled" or
3958962SSonam.Gupta@Sun.COM 					 * "completed" then only print.
3968962SSonam.Gupta@Sun.COM 					 */
3978962SSonam.Gupta@Sun.COM 					if ((jstate != 0x04) &&
3988962SSonam.Gupta@Sun.COM 					    (jstate != 0x07) &&
3998962SSonam.Gupta@Sun.COM 					    (jstate != 0x09)) {
4008962SSonam.Gupta@Sun.COM 						if (flag == 0)
4018962SSonam.Gupta@Sun.COM 							printf(gettext
4028962SSonam.Gupta@Sun.COM 							    ("now printing"\
4038962SSonam.Gupta@Sun.COM 							    " %s-%d. enabled"),
4048962SSonam.Gupta@Sun.COM 							    name, jobid);
4058962SSonam.Gupta@Sun.COM 						flag = 1;
4068962SSonam.Gupta@Sun.COM 					}
4078962SSonam.Gupta@Sun.COM 				}
4088962SSonam.Gupta@Sun.COM 				papiJobListFree(j);
4098962SSonam.Gupta@Sun.COM 			}
4102264Sjacobs 		}
4112264Sjacobs 		break;
4122264Sjacobs 	case 0x05:	/* stopped */
4132264Sjacobs 		printf(gettext("disabled"));
4142264Sjacobs 		break;
4152264Sjacobs 	default:
4162264Sjacobs 		printf(gettext("unknown state(0x%x)."), pstat);
4172264Sjacobs 		break;
4182264Sjacobs 	}
4192264Sjacobs 
4202264Sjacobs 	(void) time(&curr);
4212264Sjacobs 	(void) papiAttributeListGetDatetime(attrs, NULL,
4228962SSonam.Gupta@Sun.COM 	    "printer-up-time", &curr);
4232264Sjacobs 	(void) papiAttributeListGetDatetime(attrs, NULL,
4248962SSonam.Gupta@Sun.COM 	    "printer-state-time", &curr);
4252264Sjacobs 	(void) papiAttributeListGetDatetime(attrs, NULL,
4268962SSonam.Gupta@Sun.COM 	    "lpsched-disable-date", &curr);
4272264Sjacobs 	printf(gettext(" since %s. available.\n"), nctime(&curr));
4282264Sjacobs 
4292264Sjacobs 	if (pstat == 0x05) {
4302264Sjacobs 		char *reason = "unknown reason";
4312264Sjacobs 
4322264Sjacobs 		(void) papiAttributeListGetString(attrs, NULL,
4338962SSonam.Gupta@Sun.COM 		    "printer-state-reasons", &reason);
4342264Sjacobs 		(void) papiAttributeListGetString(attrs, NULL,
4358962SSonam.Gupta@Sun.COM 		    "lpsched-disable-reason", &reason);
4362264Sjacobs 		printf(gettext("\t%s\n"), reason);
4372264Sjacobs 	}
4382264Sjacobs 
4392264Sjacobs 	if (verbose == 1) {
4402264Sjacobs 		void *iter;
4412264Sjacobs 		char *str;
4422264Sjacobs 
4432264Sjacobs 		str = "";
4442264Sjacobs 		(void) papiAttributeListGetString(attrs, NULL,
4458962SSonam.Gupta@Sun.COM 		    "form-ready", &str);
4462264Sjacobs 		printf(gettext("\tForm mounted: %s\n"), str);
4472264Sjacobs 
4482264Sjacobs 		str = "";
4492264Sjacobs 		iter = NULL;
4502264Sjacobs 		(void) papiAttributeListGetString(attrs, &iter,
4518962SSonam.Gupta@Sun.COM 		    "document-format-supported", &str);
4522264Sjacobs 		printf(gettext("\tContent types: %s"), str);
4532264Sjacobs 		while (papiAttributeListGetString(attrs, &iter, NULL, &str)
4548962SSonam.Gupta@Sun.COM 		    == PAPI_OK)
4552264Sjacobs 			printf(", %s", str);
4562264Sjacobs 		printf("\n");
4572264Sjacobs 
4588534SSonam.Gupta@Sun.COM 		/* Display the printer description */
4598534SSonam.Gupta@Sun.COM 		print_description(attrs, name);
4602264Sjacobs 
4612264Sjacobs 		str = "";
4626676Swendyp 		iter = NULL;
4636676Swendyp 		(void) papiAttributeListGetString(attrs, &iter,
4646676Swendyp 		    "lpsched-printer-type", &str);
4656676Swendyp 		printf(gettext("\tPrinter types: %s"), str);
4666676Swendyp 		while (papiAttributeListGetString(attrs, &iter, NULL, &str)
4676676Swendyp 		    == PAPI_OK)
4686676Swendyp 			printf(", %s", str);
4696676Swendyp 		printf("\n");
4706676Swendyp 
4716676Swendyp 		str = "";
4722264Sjacobs 		(void) papiAttributeListGetString(attrs, NULL,
4738962SSonam.Gupta@Sun.COM 		    "lpsched-dial-info", &str);
4742264Sjacobs 		printf(gettext("\tConnection: %s\n"),
4757653SJonathan.Ca@Sun.COM 		    ((str[0] == '\0') ? gettext("direct") : str));
4762264Sjacobs 
4772264Sjacobs 		str = "";
4782264Sjacobs 		(void) papiAttributeListGetString(attrs, NULL,
4798962SSonam.Gupta@Sun.COM 		    "lpsched-interface-script", &str);
4802264Sjacobs 		printf(gettext("\tInterface: %s\n"), str);
4812264Sjacobs 
4822264Sjacobs 		str = NULL;
4832264Sjacobs 		(void) papiAttributeListGetString(attrs, NULL,
4848962SSonam.Gupta@Sun.COM 		    "ppd-file-uri", &str);
4852264Sjacobs 		(void) papiAttributeListGetString(attrs, NULL,
4868962SSonam.Gupta@Sun.COM 		    "lpsched-ppd-source-path", &str);
4872264Sjacobs 		if (str != NULL)
4882264Sjacobs 			printf(gettext("\tPPD: %s\n"), str);
4892264Sjacobs 
4902264Sjacobs 		str = NULL;
4912264Sjacobs 		(void) papiAttributeListGetString(attrs, NULL,
4928962SSonam.Gupta@Sun.COM 		    "lpsched-fault-alert-command", &str);
4932264Sjacobs 		if (str != NULL)
4942264Sjacobs 			printf(gettext("\tOn fault: %s\n"), str);
4952264Sjacobs 
4962264Sjacobs 		str = "";
4972264Sjacobs 		(void) papiAttributeListGetString(attrs, NULL,
4988962SSonam.Gupta@Sun.COM 		    "lpsched-fault-recovery", &str);
4992264Sjacobs 		printf(gettext("\tAfter fault: %s\n"),
5008962SSonam.Gupta@Sun.COM 		    ((str[0] == '\0') ? gettext("continue") : str));
5012264Sjacobs 
5022264Sjacobs 		str = "(all)";
5032264Sjacobs 		iter = NULL;
5042264Sjacobs 		(void) papiAttributeListGetString(attrs, &iter,
5058962SSonam.Gupta@Sun.COM 		    "requesting-user-name-allowed", &str);
5062264Sjacobs 		printf(gettext("\tUsers allowed:\n\t\t%s\n"),
5078962SSonam.Gupta@Sun.COM 		    ((str[0] == '\0') ? gettext("(none)") : str));
5082264Sjacobs 		if ((str != NULL) && (str[0] != '\0'))
5092264Sjacobs 			while (papiAttributeListGetString(attrs, &iter, NULL,
5108962SSonam.Gupta@Sun.COM 			    &str) == PAPI_OK)
5112264Sjacobs 				printf("\t\t%s\n", str);
5122264Sjacobs 
5132264Sjacobs 		str = NULL;
5142264Sjacobs 		iter = NULL;
5152264Sjacobs 		(void) papiAttributeListGetString(attrs, &iter,
5168962SSonam.Gupta@Sun.COM 		    "requesting-user-name-denied", &str);
5172264Sjacobs 		if (str != NULL) {
5182264Sjacobs 			printf(gettext("\tUsers denied:\n\t\t%s\n"),
5198962SSonam.Gupta@Sun.COM 			    ((str[0] == '\0') ? gettext("(none)") : str));
5202264Sjacobs 			if ((str != NULL) && (str[0] != '\0'))
5212264Sjacobs 				while (papiAttributeListGetString(attrs, &iter,
5228962SSonam.Gupta@Sun.COM 				    NULL, &str) == PAPI_OK)
5232264Sjacobs 					printf("\t\t%s\n", str);
5242264Sjacobs 		}
5252264Sjacobs 
5268238SSonam.Gupta@Sun.COM 		str = "none";
5272264Sjacobs 		iter = NULL;
5282264Sjacobs 		(void) papiAttributeListGetString(attrs, &iter,
5298962SSonam.Gupta@Sun.COM 		    "form-supported", &str);
5308238SSonam.Gupta@Sun.COM 		printf(gettext("\tForms allowed:\n\t\t(%s)\n"),
5318962SSonam.Gupta@Sun.COM 		    ((str[0] == '\0') ? gettext("none") : str));
5322264Sjacobs 		if ((str != NULL) && (str[0] != '\0'))
5332264Sjacobs 			while (papiAttributeListGetString(attrs, &iter, NULL,
5348962SSonam.Gupta@Sun.COM 			    &str) == PAPI_OK)
5358238SSonam.Gupta@Sun.COM 				printf("\t\t(%s)\n", str);
5362264Sjacobs 
5372264Sjacobs 		str = "";
5382264Sjacobs 		iter = NULL;
5392264Sjacobs 		(void) papiAttributeListGetString(attrs, &iter,
5408962SSonam.Gupta@Sun.COM 		    "media-supported", &str);
5412264Sjacobs 		printf(gettext("\tMedia supported:\n\t\t%s\n"),
5428962SSonam.Gupta@Sun.COM 		    ((str[0] == '\0') ? gettext("(none)") : str));
5432264Sjacobs 		if ((str != NULL) && (str[0] != '\0'))
5442264Sjacobs 			while (papiAttributeListGetString(attrs, &iter, NULL,
5458962SSonam.Gupta@Sun.COM 			    &str) == PAPI_OK)
5462264Sjacobs 				printf("\t\t%s\n", str);
5472264Sjacobs 
5482264Sjacobs 		str = "";
5492264Sjacobs 		(void) papiAttributeListGetString(attrs, NULL,
5508962SSonam.Gupta@Sun.COM 		    "job-sheets-supported", &str);
5516676Swendyp 		if ((strcasecmp(str, "none")) == 0)
5526676Swendyp 			str = gettext("page never printed");
5536676Swendyp 		else if (strcasecmp(str, "optional") == 0)
5546676Swendyp 			str = gettext("not required");
5556676Swendyp 		else
5566676Swendyp 			str = gettext("required");
5576676Swendyp 
5586676Swendyp 		printf(gettext("\tBanner %s\n"), str);
5596676Swendyp 
5602264Sjacobs 
5612264Sjacobs 		str = "";
5622264Sjacobs 		iter = NULL;
5632264Sjacobs 		(void) papiAttributeListGetString(attrs, &iter,
5648962SSonam.Gupta@Sun.COM 		    "lpsched-print-wheels", &str);
5652264Sjacobs 		printf(gettext("\tCharacter sets:\n\t\t%s\n"),
5668962SSonam.Gupta@Sun.COM 		    ((str[0] == '\0') ? gettext("(none)") : str));
5672264Sjacobs 		if ((str != NULL) && (str[0] != '\0'))
5682264Sjacobs 			while (papiAttributeListGetString(attrs, &iter, NULL,
5698962SSonam.Gupta@Sun.COM 			    &str) == PAPI_OK)
5702264Sjacobs 				printf("\t\t%s\n", str);
5712264Sjacobs 
5722264Sjacobs 		printf(gettext("\tDefault pitch:\n"));
5732264Sjacobs 		printf(gettext("\tDefault page size:\n"));
5742264Sjacobs 		printf(gettext("\tDefault port setting:\n"));
5752264Sjacobs 
5762264Sjacobs 		str = "";
5772264Sjacobs 		iter = NULL;
5782264Sjacobs 		(void) papiAttributeListGetString(attrs, &iter,
5798962SSonam.Gupta@Sun.COM 		    "lpsched-options", &str);
5802264Sjacobs 		if (str != NULL) {
5812264Sjacobs 			printf(gettext("\tOptions: %s"), str);
5822264Sjacobs 			while (papiAttributeListGetString(attrs, &iter, NULL,
5838962SSonam.Gupta@Sun.COM 			    &str) == PAPI_OK)
5842264Sjacobs 				printf(", %s", str);
5852264Sjacobs 			printf("\n");
5862264Sjacobs 		}
5872264Sjacobs 
5888534SSonam.Gupta@Sun.COM 	} else if (description == 1)
5898534SSonam.Gupta@Sun.COM 		/* Display printer description */
5908534SSonam.Gupta@Sun.COM 		print_description(attrs, name);
5918534SSonam.Gupta@Sun.COM 	else if (verbose > 1)
5922264Sjacobs 		papiAttributeListPrint(stdout, attrs, "\t");
5932264Sjacobs 
5942264Sjacobs 	if (verbose > 0)
5952264Sjacobs 		printf("\n");
5962264Sjacobs 
5972264Sjacobs 	return (0);
5982264Sjacobs }
5992264Sjacobs 
6002264Sjacobs static int
6012264Sjacobs printer_query(char *name, int (*report)(papi_service_t, char *, papi_printer_t,
6022264Sjacobs 					int, int), papi_encryption_t encryption,
6032264Sjacobs 		int verbose, int description)
6042264Sjacobs {
6052264Sjacobs 	int result = 0;
6062264Sjacobs 	papi_status_t status;
6072264Sjacobs 	papi_service_t svc = NULL;
6082264Sjacobs 
6092264Sjacobs 	status = papiServiceCreate(&svc, name, NULL, NULL, cli_auth_callback,
6108962SSonam.Gupta@Sun.COM 	    encryption, NULL);
6112264Sjacobs 	if (status != PAPI_OK) {
6124062Sjacobs 		if (status == PAPI_NOT_FOUND)
6134062Sjacobs 			fprintf(stderr, gettext("%s: unknown printer\n"),
6148962SSonam.Gupta@Sun.COM 			    name ? name : "(NULL)");
6154062Sjacobs 		else
6164062Sjacobs 			fprintf(stderr, gettext(
6178962SSonam.Gupta@Sun.COM 			    "Failed to contact service for %s: %s\n"),
6188962SSonam.Gupta@Sun.COM 			    name ? name : "(NULL)",
6198962SSonam.Gupta@Sun.COM 			    verbose_papi_message(svc, status));
6202264Sjacobs 		papiServiceDestroy(svc);
6212264Sjacobs 		return (-1);
6222264Sjacobs 	}
6232264Sjacobs 
6242264Sjacobs 	if (name == NULL) { /* all */
6252264Sjacobs 		char **interest = interest_list(svc);
6262264Sjacobs 
6272264Sjacobs 		if (interest != NULL) {
6282264Sjacobs 			int i;
6292264Sjacobs 
6302264Sjacobs 			for (i = 0; interest[i] != NULL; i++)
6312264Sjacobs 				result += printer_query(interest[i], report,
6328962SSonam.Gupta@Sun.COM 				    encryption, verbose,
6338962SSonam.Gupta@Sun.COM 				    description);
6342264Sjacobs 		}
6352264Sjacobs 	} else {
6362264Sjacobs 		papi_printer_t printer = NULL;
6372264Sjacobs 		char **keys = NULL;
6382264Sjacobs 
6392264Sjacobs 		/*
6402264Sjacobs 		 * Limit the query to only required data to reduce the need
6412264Sjacobs 		 * to go remote for information.
6422264Sjacobs 		 */
6432264Sjacobs 		if (report == report_device)
6442264Sjacobs 			keys = report_device_keys;
6452264Sjacobs 		else if (report == report_class)
6462264Sjacobs 			keys = report_class_keys;
6472264Sjacobs 		else if (report == report_accepting)
6482264Sjacobs 			keys = report_accepting_keys;
6492264Sjacobs 		else if ((report == report_printer) && (verbose == 0))
6502264Sjacobs 			keys = report_printer_keys;
6512264Sjacobs 
6522264Sjacobs 		status = papiPrinterQuery(svc, name, keys, NULL, &printer);
6532264Sjacobs 		if (status != PAPI_OK) {
6542264Sjacobs 			fprintf(stderr, gettext(
6558962SSonam.Gupta@Sun.COM 			    "Failed to get printer info for %s: %s\n"),
6568962SSonam.Gupta@Sun.COM 			    name, verbose_papi_message(svc, status));
6572264Sjacobs 			papiServiceDestroy(svc);
6582264Sjacobs 			return (-1);
6592264Sjacobs 		}
6602264Sjacobs 
6612264Sjacobs 		if (printer != NULL)
6622264Sjacobs 			result = report(svc, name, printer, verbose,
6638962SSonam.Gupta@Sun.COM 			    description);
6642264Sjacobs 
6652264Sjacobs 		papiPrinterFree(printer);
6662264Sjacobs 	}
6672264Sjacobs 
6682264Sjacobs 	papiServiceDestroy(svc);
6692264Sjacobs 
6702264Sjacobs 	return (result);
6712264Sjacobs }
6722264Sjacobs 
6732264Sjacobs static int
6742264Sjacobs match_user(char *user, char **list)
6752264Sjacobs {
6762264Sjacobs 	int i;
6772264Sjacobs 
6782264Sjacobs 	for (i = 0; list[i] != NULL; i++) {
6792264Sjacobs 		if (strcmp(user, list[i]) == 0)
6802264Sjacobs 			return (0);
6812264Sjacobs 	}
6822264Sjacobs 
6832264Sjacobs 	return (-1);
6842264Sjacobs }
6852264Sjacobs 
6862264Sjacobs static char **users = NULL;
6872264Sjacobs 
6882264Sjacobs static int
6892264Sjacobs report_job(papi_job_t job, int show_rank, int verbose)
6902264Sjacobs {
6912264Sjacobs 	papi_attribute_t **attrs = papiJobGetAttributeList(job);
6922264Sjacobs 	time_t clock = 0;
6932264Sjacobs 	char date[24];
6942264Sjacobs 	char request[26];
6952264Sjacobs 	char *user = "unknown";
6968321SSonam.Gupta@Sun.COM 	char *host = NULL;
6972264Sjacobs 	int32_t size = 0;
6982264Sjacobs 	int32_t jstate = 0;
6998321SSonam.Gupta@Sun.COM 	char User[50];
7002264Sjacobs 
7012264Sjacobs 	char *destination = "unknown";
7022264Sjacobs 	int32_t id = -1;
703*9152SSonam.Gupta@Sun.COM 	static int check = 0;
704*9152SSonam.Gupta@Sun.COM 	static char *uri = NULL;
7052264Sjacobs 
7062264Sjacobs 	(void) papiAttributeListGetString(attrs, NULL,
7078962SSonam.Gupta@Sun.COM 	    "job-originating-user-name", &user);
7082264Sjacobs 
7092264Sjacobs 	if ((users != NULL) && (match_user(user, users) < 0))
7102264Sjacobs 		return (0);
7112264Sjacobs 
7128321SSonam.Gupta@Sun.COM 	(void) papiAttributeListGetString(attrs, NULL,
7138321SSonam.Gupta@Sun.COM 	    "job-originating-host-name", &host);
7148321SSonam.Gupta@Sun.COM 
715*9152SSonam.Gupta@Sun.COM 	if (check == 0) {
716*9152SSonam.Gupta@Sun.COM 		/*
717*9152SSonam.Gupta@Sun.COM 		 * Read the attribute "job-printer-uri"
718*9152SSonam.Gupta@Sun.COM 		 * just once
719*9152SSonam.Gupta@Sun.COM 		 */
720*9152SSonam.Gupta@Sun.COM 		(void) papiAttributeListGetString(attrs, NULL,
721*9152SSonam.Gupta@Sun.COM 		    "job-printer-uri", &uri);
722*9152SSonam.Gupta@Sun.COM 		check = 1;
723*9152SSonam.Gupta@Sun.COM 	}
724*9152SSonam.Gupta@Sun.COM 
725*9152SSonam.Gupta@Sun.COM 	if (host) {
726*9152SSonam.Gupta@Sun.COM 		/* Check if it is local printer or remote printer */
727*9152SSonam.Gupta@Sun.COM 		uri_t *u = NULL;
728*9152SSonam.Gupta@Sun.COM 
729*9152SSonam.Gupta@Sun.COM 		if ((uri != NULL) && (uri_from_string(uri, &u) == 0)) {
730*9152SSonam.Gupta@Sun.COM 			char *nodename = localhostname();
731*9152SSonam.Gupta@Sun.COM 
732*9152SSonam.Gupta@Sun.COM 			if ((u->host == NULL) ||
733*9152SSonam.Gupta@Sun.COM 			    (strcasecmp(u->host, "localhost") == 0) ||
734*9152SSonam.Gupta@Sun.COM 			    (strcasecmp(u->host, nodename) == 0)) {
7358321SSonam.Gupta@Sun.COM 
736*9152SSonam.Gupta@Sun.COM 				if (strcasecmp(host, nodename) == 0) {
737*9152SSonam.Gupta@Sun.COM 					/*
738*9152SSonam.Gupta@Sun.COM 					 * Request submitted locally
739*9152SSonam.Gupta@Sun.COM 					 * for the local queue.
740*9152SSonam.Gupta@Sun.COM 					 * Hostname will not be displayed
741*9152SSonam.Gupta@Sun.COM 					 */
742*9152SSonam.Gupta@Sun.COM 					snprintf(User, sizeof (User), "%s",
743*9152SSonam.Gupta@Sun.COM 					    user);
744*9152SSonam.Gupta@Sun.COM 				}
745*9152SSonam.Gupta@Sun.COM 				else
746*9152SSonam.Gupta@Sun.COM 					snprintf(User, sizeof (User), "%s@%s",
747*9152SSonam.Gupta@Sun.COM 					    user, host);
748*9152SSonam.Gupta@Sun.COM 			} else if (uri != NULL) {
749*9152SSonam.Gupta@Sun.COM 				/*
750*9152SSonam.Gupta@Sun.COM 				 * It's a remote printer.
751*9152SSonam.Gupta@Sun.COM 				 * In case of remote printers hostname is
752*9152SSonam.Gupta@Sun.COM 				 * always displayed.
753*9152SSonam.Gupta@Sun.COM 				 */
754*9152SSonam.Gupta@Sun.COM 				snprintf(User, sizeof (User), "%s@%s",
755*9152SSonam.Gupta@Sun.COM 				    user, host);
756*9152SSonam.Gupta@Sun.COM 			}
757*9152SSonam.Gupta@Sun.COM 			uri_free(u);
758*9152SSonam.Gupta@Sun.COM 		} else {
759*9152SSonam.Gupta@Sun.COM 			/*
760*9152SSonam.Gupta@Sun.COM 			 * If attribute "job-printer-uri"
761*9152SSonam.Gupta@Sun.COM 			 * cannot be read
762*9152SSonam.Gupta@Sun.COM 			 * by default append the hostname
763*9152SSonam.Gupta@Sun.COM 			 */
764*9152SSonam.Gupta@Sun.COM 			snprintf(User, sizeof (User), "%s@%s", user, host);
765*9152SSonam.Gupta@Sun.COM 		}
766*9152SSonam.Gupta@Sun.COM 	} else {
767*9152SSonam.Gupta@Sun.COM 		/*
768*9152SSonam.Gupta@Sun.COM 		 * When print server is s10u4 and ipp service is used
769*9152SSonam.Gupta@Sun.COM 		 * "job-originating-hostname" attribute is not set
770*9152SSonam.Gupta@Sun.COM 		 * So get the host information from the uri
771*9152SSonam.Gupta@Sun.COM 		 */
772*9152SSonam.Gupta@Sun.COM 		uri_t *u = NULL;
773*9152SSonam.Gupta@Sun.COM 		if ((uri != NULL) && (uri_from_string(uri, &u) == 0)) {
774*9152SSonam.Gupta@Sun.COM 			if ((u != NULL) && (u->host != NULL))
775*9152SSonam.Gupta@Sun.COM 				snprintf(User, sizeof (User), "%s@%s",
776*9152SSonam.Gupta@Sun.COM 				    user, u->host);
777*9152SSonam.Gupta@Sun.COM 			else
778*9152SSonam.Gupta@Sun.COM 				snprintf(User, sizeof (User), "%s", user);
779*9152SSonam.Gupta@Sun.COM 
780*9152SSonam.Gupta@Sun.COM 			uri_free(u);
781*9152SSonam.Gupta@Sun.COM 		} else
782*9152SSonam.Gupta@Sun.COM 			snprintf(User, sizeof (User), "%s", user);
783*9152SSonam.Gupta@Sun.COM 	}
7842264Sjacobs 	(void) papiAttributeListGetInteger(attrs, NULL, "job-k-octets", &size);
7852264Sjacobs 	size *= 1024;	/* for the approximate byte size */
7862264Sjacobs 	(void) papiAttributeListGetInteger(attrs, NULL, "job-octets", &size);
7872264Sjacobs 
7882264Sjacobs 	(void) time(&clock);
7892264Sjacobs 	(void) papiAttributeListGetInteger(attrs, NULL,
7908962SSonam.Gupta@Sun.COM 	    "time-at-creation", (int32_t *)&clock);
7912264Sjacobs 	(void) strftime(date, sizeof (date), "%b %d %R", localtime(&clock));
7922264Sjacobs 
7932264Sjacobs 	(void) papiAttributeListGetString(attrs, NULL,
7948962SSonam.Gupta@Sun.COM 	    "job-printer-uri", &destination);
7952264Sjacobs 	(void) papiAttributeListGetString(attrs, NULL,
7968962SSonam.Gupta@Sun.COM 	    "printer-name", &destination);
7972264Sjacobs 	(void) papiAttributeListGetInteger(attrs, NULL,
7988962SSonam.Gupta@Sun.COM 	    "job-id", &id);
7992264Sjacobs 	snprintf(request, sizeof (request), "%s-%d", destination, id);
8002264Sjacobs 
8012264Sjacobs 	if (show_rank != 0) {
8022264Sjacobs 		int32_t rank = -1;
8032264Sjacobs 
8042264Sjacobs 		(void) papiAttributeListGetInteger(attrs, NULL,
8058962SSonam.Gupta@Sun.COM 		    "number-of-intervening-jobs", &rank);
8062264Sjacobs 		rank++;
8072264Sjacobs 
8082264Sjacobs 		printf("%3d %-21s %-14s %7ld %s",
8098321SSonam.Gupta@Sun.COM 		    rank, request, User, size, date);
8102264Sjacobs 	} else
8118321SSonam.Gupta@Sun.COM 		printf("%-23s %-14s %7ld   %s", request, User, size, date);
8122264Sjacobs 
8132264Sjacobs 	(void) papiAttributeListGetInteger(attrs, NULL,
8148962SSonam.Gupta@Sun.COM 	    "job-state", &jstate);
8152264Sjacobs 	if (jstate == 0x04)
8162264Sjacobs 		printf(gettext(", being held"));
8172264Sjacobs 	else if (jstate == 0x07)
8182264Sjacobs 		printf(gettext(", cancelled"));
8192264Sjacobs 	else if (jstate == 0x09)
8202264Sjacobs 		printf(gettext(", complete"));
8212264Sjacobs 
8222264Sjacobs 	if (verbose == 1) {
8233125Sjacobs 		char *form = NULL;
8243125Sjacobs 
8252264Sjacobs 		(void) papiAttributeListGetString(attrs, NULL,
8268962SSonam.Gupta@Sun.COM 		    "output-device-assigned", &destination);
8272264Sjacobs 		printf("\n\t assigned %s", destination);
8283127Sjacobs 
8293125Sjacobs 		(void) papiAttributeListGetString(attrs, NULL, "form", &form);
8303125Sjacobs 		if (form != NULL)
8313125Sjacobs 			printf(", form %s", form);
8322264Sjacobs 	} else if (verbose > 1) {
8332264Sjacobs 		printf("\n");
8342264Sjacobs 		papiAttributeListPrint(stdout, attrs, "\t");
8352264Sjacobs 	}
8362264Sjacobs 
8372264Sjacobs 	printf("\n");
8382264Sjacobs 
8392264Sjacobs 	return (0);
8402264Sjacobs }
8412264Sjacobs 
8422264Sjacobs static int
8432264Sjacobs job_query(char *request, int (*report)(papi_job_t, int, int),
8442264Sjacobs 		papi_encryption_t encryption, int show_rank, int verbose)
8452264Sjacobs {
8462264Sjacobs 	int result = 0;
8472264Sjacobs 	papi_status_t status;
8482264Sjacobs 	papi_service_t svc = NULL;
8498295SSonam.Gupta@Sun.COM 	char *printer = request;
8502264Sjacobs 	int32_t id = -1;
8518295SSonam.Gupta@Sun.COM 	int flag1 = 0;
8528295SSonam.Gupta@Sun.COM 	int flag = 1;
8538295SSonam.Gupta@Sun.COM 	int print_flag = 0;
8542264Sjacobs 
8558295SSonam.Gupta@Sun.COM 	do {
8568295SSonam.Gupta@Sun.COM 		status = papiServiceCreate(&svc, printer, NULL, NULL,
8578962SSonam.Gupta@Sun.COM 		    cli_auth_callback, encryption, NULL);
8582264Sjacobs 
8598295SSonam.Gupta@Sun.COM 		if ((status == PAPI_OK) && (printer != NULL))
8608295SSonam.Gupta@Sun.COM 			print_flag = 1;
8612264Sjacobs 
8628295SSonam.Gupta@Sun.COM 		/* <name>-# printer name does not exist */
8638295SSonam.Gupta@Sun.COM 		if (status != PAPI_OK) {
8648295SSonam.Gupta@Sun.COM 			/*
8658295SSonam.Gupta@Sun.COM 			 * Check if <name>-# is a request-id
8668295SSonam.Gupta@Sun.COM 			 * Once this check is done flag1 is set
8678295SSonam.Gupta@Sun.COM 			 */
8688295SSonam.Gupta@Sun.COM 			if (flag1 == 1)
8698295SSonam.Gupta@Sun.COM 				break;
8708295SSonam.Gupta@Sun.COM 
8718295SSonam.Gupta@Sun.COM 			get_printer_id(printer, &printer, &id);
8722264Sjacobs 
8738295SSonam.Gupta@Sun.COM 			status = papiServiceCreate(&svc, printer, NULL, NULL,
8748962SSonam.Gupta@Sun.COM 			    cli_auth_callback, encryption, NULL);
8752264Sjacobs 
8768295SSonam.Gupta@Sun.COM 			if (status != PAPI_OK) {
8778295SSonam.Gupta@Sun.COM 				fprintf(stderr, gettext(
8788295SSonam.Gupta@Sun.COM 				    "Failed to contact service for %s: %s\n"),
8798295SSonam.Gupta@Sun.COM 				    (printer ? printer : "all"),
8808295SSonam.Gupta@Sun.COM 				    verbose_papi_message(svc, status));
8818295SSonam.Gupta@Sun.COM 				return (-1);
8828295SSonam.Gupta@Sun.COM 			}
8832264Sjacobs 		}
8842264Sjacobs 
8858295SSonam.Gupta@Sun.COM 		if (printer == NULL) { /* all */
8868295SSonam.Gupta@Sun.COM 			char **interest = interest_list(svc);
8878295SSonam.Gupta@Sun.COM 
8888295SSonam.Gupta@Sun.COM 			if (interest != NULL) {
8898295SSonam.Gupta@Sun.COM 				int i;
8908295SSonam.Gupta@Sun.COM 
8918295SSonam.Gupta@Sun.COM 				for (i = 0; interest[i] != NULL; i++)
8928295SSonam.Gupta@Sun.COM 					result += job_query(interest[i], report,
8938962SSonam.Gupta@Sun.COM 					    encryption, show_rank, verbose);
8948295SSonam.Gupta@Sun.COM 			}
8958295SSonam.Gupta@Sun.COM 		} else if (id == -1) { /* a printer */
8968295SSonam.Gupta@Sun.COM 			papi_job_t *jobs = NULL;
8978295SSonam.Gupta@Sun.COM 
8988295SSonam.Gupta@Sun.COM 			status = papiPrinterListJobs(svc, printer, NULL,
8998962SSonam.Gupta@Sun.COM 			    0, 0, &jobs);
9008295SSonam.Gupta@Sun.COM 			if (status != PAPI_OK) {
9018295SSonam.Gupta@Sun.COM 				fprintf(stderr, gettext(
9028295SSonam.Gupta@Sun.COM 				    "Failed to get job list: %s\n"),
9038295SSonam.Gupta@Sun.COM 				    verbose_papi_message(svc, status));
9048295SSonam.Gupta@Sun.COM 				papiServiceDestroy(svc);
9058295SSonam.Gupta@Sun.COM 				return (-1);
9068295SSonam.Gupta@Sun.COM 			}
9078295SSonam.Gupta@Sun.COM 
9088295SSonam.Gupta@Sun.COM 			if (jobs != NULL) {
9098295SSonam.Gupta@Sun.COM 				int i;
9102264Sjacobs 
9118295SSonam.Gupta@Sun.COM 				for (i = 0; jobs[i] != NULL; i++)
9128295SSonam.Gupta@Sun.COM 					result += report(jobs[i],
9138962SSonam.Gupta@Sun.COM 					    show_rank, verbose);
9148295SSonam.Gupta@Sun.COM 			}
9158295SSonam.Gupta@Sun.COM 
9168295SSonam.Gupta@Sun.COM 			papiJobListFree(jobs);
9178295SSonam.Gupta@Sun.COM 		} else {	/* a job */
9188295SSonam.Gupta@Sun.COM 			papi_job_t job = NULL;
9198295SSonam.Gupta@Sun.COM 
9208295SSonam.Gupta@Sun.COM 			/* Once a job has been found stop processing */
9218295SSonam.Gupta@Sun.COM 			flag = 0;
9228295SSonam.Gupta@Sun.COM 
9238295SSonam.Gupta@Sun.COM 			status = papiJobQuery(svc, printer, id, NULL, &job);
9248295SSonam.Gupta@Sun.COM 			if (status != PAPI_OK) {
9258295SSonam.Gupta@Sun.COM 				if (!print_flag)
9268295SSonam.Gupta@Sun.COM 					fprintf(stderr, gettext(
9278962SSonam.Gupta@Sun.COM 					    "Failed to get job"\
9288962SSonam.Gupta@Sun.COM 					    " info for %s: %s\n"),
9298962SSonam.Gupta@Sun.COM 					    request,
9308962SSonam.Gupta@Sun.COM 					    verbose_papi_message(svc, status));
9318295SSonam.Gupta@Sun.COM 				papiServiceDestroy(svc);
9328295SSonam.Gupta@Sun.COM 				return (-1);
9338295SSonam.Gupta@Sun.COM 			}
9348295SSonam.Gupta@Sun.COM 
9358295SSonam.Gupta@Sun.COM 			if (job != NULL)
9368295SSonam.Gupta@Sun.COM 				result = report(job, show_rank, verbose);
9378295SSonam.Gupta@Sun.COM 
9388295SSonam.Gupta@Sun.COM 			papiJobFree(job);
9392264Sjacobs 		}
9402264Sjacobs 
9418295SSonam.Gupta@Sun.COM 		if (flag) {
9428295SSonam.Gupta@Sun.COM 			id = -1;
9438295SSonam.Gupta@Sun.COM 			get_printer_id(printer, &printer, &id);
9448295SSonam.Gupta@Sun.COM 			if (id == -1)
9458295SSonam.Gupta@Sun.COM 				flag = 0;
9468295SSonam.Gupta@Sun.COM 			else
9478295SSonam.Gupta@Sun.COM 				flag1 = 1;
9482264Sjacobs 		}
9498295SSonam.Gupta@Sun.COM 	} while (flag);
9502264Sjacobs 
9512264Sjacobs 	papiServiceDestroy(svc);
9522264Sjacobs 
9532264Sjacobs 	return (result);
9542264Sjacobs }
9552264Sjacobs 
9562264Sjacobs static int
9572264Sjacobs report_form(char *name, papi_attribute_t **attrs, int verbose)
9582264Sjacobs {
9592264Sjacobs 	papi_status_t status;
9602264Sjacobs 	char *form = NULL;
9612264Sjacobs 	void *iter = NULL;
9622264Sjacobs 
9632264Sjacobs 	for (status = papiAttributeListGetString(attrs, &iter,
9648962SSonam.Gupta@Sun.COM 	    "form-supported", &form);
9658962SSonam.Gupta@Sun.COM 	    status == PAPI_OK;
9668962SSonam.Gupta@Sun.COM 	    status = papiAttributeListGetString(attrs, &iter,
9678962SSonam.Gupta@Sun.COM 	    NULL, &form)) {
9682264Sjacobs 		if ((name == NULL) || (strcmp(name, form) == 0)) {
9692264Sjacobs 			printf(gettext("form %s is available to you\n"), form);
9702264Sjacobs 			if (verbose != 0) {
9712264Sjacobs 				char *detail = NULL;
9722264Sjacobs 				status = papiAttributeListGetString(attrs, NULL,
9738962SSonam.Gupta@Sun.COM 				    "form-supported-detail", &detail);
9742264Sjacobs 				if (status == PAPI_OK)
9752264Sjacobs 					printf("%s\n", detail);
9762264Sjacobs 			}
9772264Sjacobs 		}
9782264Sjacobs 	}
9792264Sjacobs 
9802264Sjacobs 	return (0);
9812264Sjacobs }
9822264Sjacobs 
9832264Sjacobs static int
9842264Sjacobs report_print_wheels(char *name, papi_attribute_t **attrs, int verbose)
9852264Sjacobs {
9862264Sjacobs 	papi_status_t status;
9872264Sjacobs 	char *pw = NULL;
9882264Sjacobs 	void *iter = NULL;
9892264Sjacobs 
9902264Sjacobs 	for (status = papiAttributeListGetString(attrs, &iter,
9918962SSonam.Gupta@Sun.COM 	    "pw-supported", &pw);
9928962SSonam.Gupta@Sun.COM 	    status == PAPI_OK;
9938962SSonam.Gupta@Sun.COM 	    status = papiAttributeListGetString(attrs, &iter, NULL, &pw)) {
9942264Sjacobs 		if ((name == NULL) || (strcmp(name, pw) == 0)) {
9952264Sjacobs 			printf(gettext("charset %s is available\n"), pw);
9962264Sjacobs 			if (verbose != 0) {
9972264Sjacobs 				char *info = NULL;
9982264Sjacobs 				status = papiAttributeListGetString(attrs, NULL,
9998962SSonam.Gupta@Sun.COM 				    "pw-supported-extra", &info);
10002264Sjacobs 				if (status == PAPI_OK)
10012264Sjacobs 					printf("%s\n", info);
10022264Sjacobs 			}
10032264Sjacobs 		}
10042264Sjacobs 	}
10052264Sjacobs 
10062264Sjacobs 	return (0);
10072264Sjacobs }
10082264Sjacobs 
10092264Sjacobs static int
10102264Sjacobs service_query(char *name, int (*report)(char *, papi_attribute_t **, int),
10112264Sjacobs 		papi_encryption_t encryption, int verbose)
10122264Sjacobs {
10132264Sjacobs 	int result = 0;
10142264Sjacobs 	papi_status_t status;
10152264Sjacobs 	papi_service_t svc = NULL;
10162264Sjacobs 	papi_attribute_t **attrs = NULL;
10172264Sjacobs 
10182264Sjacobs 	status = papiServiceCreate(&svc, name, NULL, NULL, cli_auth_callback,
10198962SSonam.Gupta@Sun.COM 	    encryption, NULL);
10202264Sjacobs 	if (status != PAPI_OK) {
10212264Sjacobs 		papiServiceDestroy(svc);
10222264Sjacobs 		return (-1);
10232264Sjacobs 	}
10242264Sjacobs 
10252264Sjacobs 	attrs = papiServiceGetAttributeList(svc);
10262264Sjacobs 	if (attrs != NULL) {
10272264Sjacobs 		result = report(name, attrs, verbose);
10282264Sjacobs 
10292264Sjacobs 		if (verbose > 1) {
10302264Sjacobs 			printf("\n");
10312264Sjacobs 			papiAttributeListPrint(stdout, attrs, "\t");
10322264Sjacobs 			printf("\n");
10332264Sjacobs 		}
10342264Sjacobs 	}
10352264Sjacobs 
10362264Sjacobs 	papiServiceDestroy(svc);
10372264Sjacobs 
10382264Sjacobs 	return (result);
10392264Sjacobs }
10402264Sjacobs 
10412264Sjacobs int
10422264Sjacobs main(int ac, char *av[])
10432264Sjacobs {
10442264Sjacobs 	int exit_code = 0;
10452264Sjacobs 	papi_encryption_t encryption = PAPI_ENCRYPT_NEVER;
10462264Sjacobs 	int rank = 0;
10472264Sjacobs 	int verbose = 0;
10482264Sjacobs 	int description = 0;
10492264Sjacobs 	int c;
10502264Sjacobs 	char **argv;
10512264Sjacobs 
10522264Sjacobs 	(void) setlocale(LC_ALL, "");
10532264Sjacobs 	(void) textdomain("SUNW_OST_OSCMD");
10542264Sjacobs 
10552264Sjacobs 	argv = (char **)calloc((ac + 1), sizeof (char *));
10564286Swendyp 	for (c = 0; c < ac; c++) {
10574286Swendyp 		if ((av[c][0] == '-') && (av[c][1] == 'l') &&
10588962SSonam.Gupta@Sun.COM 		    (isalpha(av[c][2]) != 0)) {
10594286Swendyp 			/* preserve old "-l[po...]" behavior */
10604286Swendyp 			argv[c] = &av[c][1];
10614286Swendyp 			argv[c][0] = '-';
10624286Swendyp 			verbose = 1;
10634286Swendyp 
10644286Swendyp 		} else
10654286Swendyp 			argv[c] = av[c];
10664286Swendyp 	}
10674286Swendyp 
10682264Sjacobs 	argv[c++] = "--";
10692264Sjacobs 	ac = c;
10702264Sjacobs 
10712264Sjacobs 	/* preprocess argument list looking for '-l' or '-R' so it can trail */
10722264Sjacobs 	while ((c = getopt(ac, argv, "LEDf:S:stc:p:a:drs:v:l:o:R:u:")) != EOF)
10732264Sjacobs 		switch (c) {
10742264Sjacobs 		case 'l':
10752264Sjacobs 			if ((optarg == NULL) || (optarg[0] == '-'))
10762264Sjacobs 				optarg = "1";
10772264Sjacobs 			verbose = atoi(optarg);
10782264Sjacobs 			break;
10792264Sjacobs 		case 'D':
10802264Sjacobs 			description = 1;
10812264Sjacobs 			break;
10822264Sjacobs 		case 'R':
10832264Sjacobs 			rank = 1;
10842264Sjacobs 			break;
10852264Sjacobs 		case 'E':
10862264Sjacobs 			encryption = PAPI_ENCRYPT_REQUIRED;
10872264Sjacobs 			break;
10882264Sjacobs 		default:
10892264Sjacobs 			break;
10902264Sjacobs 		}
10912264Sjacobs 	optind = 1;
10922264Sjacobs 
10932264Sjacobs 	/* process command line arguments */
10942264Sjacobs 	while ((c = getopt(ac, argv, "LEDf:S:stc:p:a:drs:v:l:o:R:u:")) != EOF) {
10952264Sjacobs 		switch (c) {	/* these may or may not have an option */
10962264Sjacobs 		case 'a':
10972264Sjacobs 		case 'c':
10982264Sjacobs 		case 'p':
10992264Sjacobs 		case 'o':
11002264Sjacobs 		case 'R':
11012264Sjacobs 		case 'u':
11022264Sjacobs 		case 'v':
11032264Sjacobs 		case 'l':
11042264Sjacobs 		case 'f':
11052264Sjacobs 		case 'S':
11062264Sjacobs 			if (optarg[0] == '-') {
11072264Sjacobs 				/* this check stop a possible infinite loop */
11082264Sjacobs 				if ((optind > 1) && (argv[optind-1][1] != c))
11092264Sjacobs 					optind--;
11102264Sjacobs 				optarg = NULL;
11112264Sjacobs 			} else if (strcmp(optarg, "all") == 0)
11122264Sjacobs 				optarg = NULL;
11132264Sjacobs 		}
11142264Sjacobs 
11152264Sjacobs 		switch (c) {
11162264Sjacobs 		case 'a':
11172264Sjacobs 			exit_code += printer_query(optarg, report_accepting,
11188962SSonam.Gupta@Sun.COM 			    encryption, verbose, 0);
11192264Sjacobs 			break;
11202264Sjacobs 		case 'c':
11212264Sjacobs 			exit_code += printer_query(optarg, report_class,
11228962SSonam.Gupta@Sun.COM 			    encryption, verbose, 0);
11232264Sjacobs 			break;
11242264Sjacobs 		case 'p':
11252264Sjacobs 			exit_code += printer_query(optarg, report_printer,
11268962SSonam.Gupta@Sun.COM 			    encryption, verbose, description);
11272264Sjacobs 			break;
11282264Sjacobs 		case 'd':
11292264Sjacobs 			exit_code += lpstat_default_printer(encryption);
11302264Sjacobs 			break;
11312264Sjacobs 		case 'r':
11322264Sjacobs 			exit_code += lpstat_service_status(encryption);
11332264Sjacobs 			break;
11342264Sjacobs 		case 'u':
11352264Sjacobs 			if (optarg != NULL)
11362264Sjacobs 				users = strsplit(optarg, ", \n");
11372264Sjacobs 			exit_code += job_query(NULL, report_job,
11388962SSonam.Gupta@Sun.COM 			    encryption, rank, verbose);
11392264Sjacobs 			if (users != NULL) {
11402264Sjacobs 				free(users);
11412264Sjacobs 				users = NULL;
11422264Sjacobs 			}
11432264Sjacobs 			break;
11442264Sjacobs 		case 'v':
11452264Sjacobs 			exit_code += printer_query(optarg, report_device,
11468962SSonam.Gupta@Sun.COM 			    encryption, verbose, 0);
11472264Sjacobs 			break;
11488604SGowtham.Thommandra@Sun.COM 		case 'R':	/* set "rank" flag in first pass */
11492264Sjacobs 		case 'o':
11502264Sjacobs 			exit_code += job_query(optarg, report_job,
11518962SSonam.Gupta@Sun.COM 			    encryption, rank, verbose);
11522264Sjacobs 			break;
11532264Sjacobs 		case 'f':
11542264Sjacobs 			exit_code += service_query(optarg, report_form,
11558962SSonam.Gupta@Sun.COM 			    encryption, verbose);
11562264Sjacobs 			break;
11572264Sjacobs 		case 'S':
11582264Sjacobs 			exit_code += service_query(optarg, report_print_wheels,
11598962SSonam.Gupta@Sun.COM 			    encryption, verbose);
11602264Sjacobs 			break;
11612264Sjacobs 		case 's':
11622264Sjacobs 			exit_code += lpstat_service_status(encryption);
11632264Sjacobs 			exit_code += lpstat_default_printer(encryption);
11642264Sjacobs 			exit_code += printer_query(NULL, report_class,
11658962SSonam.Gupta@Sun.COM 			    encryption, verbose, 0);
11662264Sjacobs 			exit_code += printer_query(NULL, report_device,
11678962SSonam.Gupta@Sun.COM 			    encryption, verbose, 0);
11682264Sjacobs 			exit_code += service_query(optarg, report_form,
11698962SSonam.Gupta@Sun.COM 			    encryption, verbose);
11702264Sjacobs 			exit_code += service_query(optarg, report_print_wheels,
11718962SSonam.Gupta@Sun.COM 			    encryption, verbose);
11722264Sjacobs 			break;
11732264Sjacobs 		case 't':
11742264Sjacobs 			exit_code += lpstat_service_status(encryption);
11752264Sjacobs 			exit_code += lpstat_default_printer(encryption);
11762264Sjacobs 			exit_code += printer_query(NULL, report_class,
11778962SSonam.Gupta@Sun.COM 			    encryption, verbose, 0);
11782264Sjacobs 			exit_code += printer_query(NULL, report_device,
11798962SSonam.Gupta@Sun.COM 			    encryption, verbose, 0);
11802264Sjacobs 			exit_code += printer_query(NULL, report_accepting,
11818962SSonam.Gupta@Sun.COM 			    encryption, verbose, 0);
11822264Sjacobs 			exit_code += printer_query(NULL, report_printer,
11838962SSonam.Gupta@Sun.COM 			    encryption, verbose, 0);
11842264Sjacobs 			exit_code += service_query(optarg, report_form,
11858962SSonam.Gupta@Sun.COM 			    encryption, verbose);
11862264Sjacobs 			exit_code += service_query(optarg, report_print_wheels,
11878962SSonam.Gupta@Sun.COM 			    encryption, verbose);
11882264Sjacobs 			exit_code += job_query(NULL, report_job,
11898962SSonam.Gupta@Sun.COM 			    encryption, rank, verbose);
11902264Sjacobs 			break;
11912264Sjacobs 		case 'L':	/* local-only, ignored */
11922264Sjacobs 		case 'l':	/* increased verbose level in first pass */
11932264Sjacobs 		case 'D':	/* set "description" flag in first pass */
11942264Sjacobs 		case 'E':	/* set encryption in the first pass */
11952264Sjacobs 			break;
11962264Sjacobs 		default:
11972264Sjacobs 			usage(av[0]);
11982264Sjacobs 		}
11992264Sjacobs 	}
12002264Sjacobs 	ac--;
12012264Sjacobs 
12022264Sjacobs 	if (ac == 1) {	/* report on my jobs */
12032264Sjacobs 		struct passwd *pw = getpwuid(getuid());
12042264Sjacobs 
12052264Sjacobs 		if (pw != NULL)
12062264Sjacobs 			users = strsplit(pw->pw_name, "");
12072264Sjacobs 		exit_code += job_query(NULL, report_job, encryption,
12088962SSonam.Gupta@Sun.COM 		    rank, verbose);
12092264Sjacobs 		if (users != NULL) {
12102264Sjacobs 			free(users);
12112264Sjacobs 			users = NULL;
12122264Sjacobs 		}
12132264Sjacobs 	} else {
12142264Sjacobs 		for (c = optind; c < ac; c++)
12152264Sjacobs 			exit_code += job_query(argv[c], report_job, encryption,
12168962SSonam.Gupta@Sun.COM 			    rank, verbose);
12172264Sjacobs 	}
12182264Sjacobs 
12192264Sjacobs 
12202264Sjacobs 	if (exit_code != 0)
12212264Sjacobs 		exit_code = 1;
12222264Sjacobs 
12232264Sjacobs 	return (exit_code);
12242264Sjacobs }
1225