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"), 4135eb9a62cSJonathan 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 464f06271beSsonam gupta - Sun Microsystems - Bangalore India str = "none"; 465355b4669Sjacobs iter = NULL; 466355b4669Sjacobs (void) papiAttributeListGetString(attrs, &iter, 467355b4669Sjacobs "form-supported", &str); 468f06271beSsonam gupta - Sun Microsystems - Bangalore India printf(gettext("\tForms allowed:\n\t\t(%s)\n"), 469f06271beSsonam gupta - Sun Microsystems - Bangalore India ((str[0] == '\0') ? gettext("none") : str)); 470355b4669Sjacobs if ((str != NULL) && (str[0] != '\0')) 471355b4669Sjacobs while (papiAttributeListGetString(attrs, &iter, NULL, 472355b4669Sjacobs &str) == PAPI_OK) 473f06271beSsonam gupta - Sun Microsystems - Bangalore India 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"; 636*b9c04f6bSsonam gupta - Sun Microsystems - Bangalore India char *host = NULL; 637355b4669Sjacobs int32_t size = 0; 638355b4669Sjacobs int32_t jstate = 0; 639*b9c04f6bSsonam gupta - Sun Microsystems - Bangalore India char User[50]; 640355b4669Sjacobs 641355b4669Sjacobs char *destination = "unknown"; 642355b4669Sjacobs int32_t id = -1; 643355b4669Sjacobs 644355b4669Sjacobs (void) papiAttributeListGetString(attrs, NULL, 645355b4669Sjacobs "job-originating-user-name", &user); 646355b4669Sjacobs 647355b4669Sjacobs if ((users != NULL) && (match_user(user, users) < 0)) 648355b4669Sjacobs return (0); 649355b4669Sjacobs 650*b9c04f6bSsonam gupta - Sun Microsystems - Bangalore India (void) papiAttributeListGetString(attrs, NULL, 651*b9c04f6bSsonam gupta - Sun Microsystems - Bangalore India "job-originating-host-name", &host); 652*b9c04f6bSsonam gupta - Sun Microsystems - Bangalore India 653*b9c04f6bSsonam gupta - Sun Microsystems - Bangalore India if (host) 654*b9c04f6bSsonam gupta - Sun Microsystems - Bangalore India snprintf(User, sizeof (User), "%s@%s", user, host); 655*b9c04f6bSsonam gupta - Sun Microsystems - Bangalore India else 656*b9c04f6bSsonam gupta - Sun Microsystems - Bangalore India snprintf(User, sizeof (User), "%s", user); 657*b9c04f6bSsonam gupta - Sun Microsystems - Bangalore India 658355b4669Sjacobs (void) papiAttributeListGetInteger(attrs, NULL, "job-k-octets", &size); 659355b4669Sjacobs size *= 1024; /* for the approximate byte size */ 660355b4669Sjacobs (void) papiAttributeListGetInteger(attrs, NULL, "job-octets", &size); 661355b4669Sjacobs 662355b4669Sjacobs (void) time(&clock); 663355b4669Sjacobs (void) papiAttributeListGetInteger(attrs, NULL, 664355b4669Sjacobs "time-at-creation", (int32_t *)&clock); 665355b4669Sjacobs (void) strftime(date, sizeof (date), "%b %d %R", localtime(&clock)); 666355b4669Sjacobs 667355b4669Sjacobs (void) papiAttributeListGetString(attrs, NULL, 668355b4669Sjacobs "job-printer-uri", &destination); 669355b4669Sjacobs (void) papiAttributeListGetString(attrs, NULL, 670355b4669Sjacobs "printer-name", &destination); 671355b4669Sjacobs (void) papiAttributeListGetInteger(attrs, NULL, 672355b4669Sjacobs "job-id", &id); 673355b4669Sjacobs snprintf(request, sizeof (request), "%s-%d", destination, id); 674355b4669Sjacobs 675355b4669Sjacobs if (show_rank != 0) { 676355b4669Sjacobs int32_t rank = -1; 677355b4669Sjacobs 678355b4669Sjacobs (void) papiAttributeListGetInteger(attrs, NULL, 679355b4669Sjacobs "number-of-intervening-jobs", &rank); 680355b4669Sjacobs rank++; 681355b4669Sjacobs 682355b4669Sjacobs printf("%3d %-21s %-14s %7ld %s", 683*b9c04f6bSsonam gupta - Sun Microsystems - Bangalore India rank, request, User, size, date); 684355b4669Sjacobs } else 685*b9c04f6bSsonam gupta - Sun Microsystems - Bangalore India printf("%-23s %-14s %7ld %s", request, User, size, date); 686355b4669Sjacobs 687355b4669Sjacobs (void) papiAttributeListGetInteger(attrs, NULL, 688355b4669Sjacobs "job-state", &jstate); 689355b4669Sjacobs if (jstate == 0x04) 690355b4669Sjacobs printf(gettext(", being held")); 691355b4669Sjacobs else if (jstate == 0x07) 692355b4669Sjacobs printf(gettext(", cancelled")); 693355b4669Sjacobs else if (jstate == 0x09) 694355b4669Sjacobs printf(gettext(", complete")); 695355b4669Sjacobs 696355b4669Sjacobs if (verbose == 1) { 6970a44ef6dSjacobs char *form = NULL; 6980a44ef6dSjacobs 699355b4669Sjacobs (void) papiAttributeListGetString(attrs, NULL, 700355b4669Sjacobs "output-device-assigned", &destination); 701355b4669Sjacobs printf("\n\t assigned %s", destination); 7020a44ef6dSjacobs 7030a44ef6dSjacobs (void) papiAttributeListGetString(attrs, NULL, "form", &form); 7040a44ef6dSjacobs if (form != NULL) 7050a44ef6dSjacobs printf(", form %s", form); 706355b4669Sjacobs } else if (verbose > 1) { 707355b4669Sjacobs printf("\n"); 708355b4669Sjacobs papiAttributeListPrint(stdout, attrs, "\t"); 709355b4669Sjacobs } 710355b4669Sjacobs 711355b4669Sjacobs printf("\n"); 712355b4669Sjacobs 713355b4669Sjacobs return (0); 714355b4669Sjacobs } 715355b4669Sjacobs 716355b4669Sjacobs static int 717355b4669Sjacobs job_query(char *request, int (*report)(papi_job_t, int, int), 718355b4669Sjacobs papi_encryption_t encryption, int show_rank, int verbose) 719355b4669Sjacobs { 720355b4669Sjacobs int result = 0; 721355b4669Sjacobs papi_status_t status; 722355b4669Sjacobs papi_service_t svc = NULL; 7234749ecc3Ssonam gupta - Sun Microsystems - Bangalore India char *printer = request; 724355b4669Sjacobs int32_t id = -1; 7254749ecc3Ssonam gupta - Sun Microsystems - Bangalore India int flag1 = 0; 7264749ecc3Ssonam gupta - Sun Microsystems - Bangalore India int flag = 1; 7274749ecc3Ssonam gupta - Sun Microsystems - Bangalore India int print_flag = 0; 728355b4669Sjacobs 7294749ecc3Ssonam gupta - Sun Microsystems - Bangalore India do { 7304749ecc3Ssonam gupta - Sun Microsystems - Bangalore India status = papiServiceCreate(&svc, printer, NULL, NULL, 7314749ecc3Ssonam gupta - Sun Microsystems - Bangalore India cli_auth_callback, encryption, NULL); 732355b4669Sjacobs 7334749ecc3Ssonam gupta - Sun Microsystems - Bangalore India if ((status == PAPI_OK) && (printer != NULL)) 7344749ecc3Ssonam gupta - Sun Microsystems - Bangalore India print_flag = 1; 7354749ecc3Ssonam gupta - Sun Microsystems - Bangalore India 7364749ecc3Ssonam gupta - Sun Microsystems - Bangalore India /* <name>-# printer name does not exist */ 7374749ecc3Ssonam gupta - Sun Microsystems - Bangalore India if (status != PAPI_OK) { 7384749ecc3Ssonam gupta - Sun Microsystems - Bangalore India /* 7394749ecc3Ssonam gupta - Sun Microsystems - Bangalore India * Check if <name>-# is a request-id 7404749ecc3Ssonam gupta - Sun Microsystems - Bangalore India * Once this check is done flag1 is set 7414749ecc3Ssonam gupta - Sun Microsystems - Bangalore India */ 7424749ecc3Ssonam gupta - Sun Microsystems - Bangalore India if (flag1 == 1) 7434749ecc3Ssonam gupta - Sun Microsystems - Bangalore India break; 7444749ecc3Ssonam gupta - Sun Microsystems - Bangalore India 7454749ecc3Ssonam gupta - Sun Microsystems - Bangalore India get_printer_id(printer, &printer, &id); 7464749ecc3Ssonam gupta - Sun Microsystems - Bangalore India 7474749ecc3Ssonam gupta - Sun Microsystems - Bangalore India status = papiServiceCreate(&svc, printer, NULL, NULL, 7484749ecc3Ssonam gupta - Sun Microsystems - Bangalore India cli_auth_callback, encryption, NULL); 7494749ecc3Ssonam gupta - Sun Microsystems - Bangalore India 750355b4669Sjacobs if (status != PAPI_OK) { 751355b4669Sjacobs fprintf(stderr, gettext( 752355b4669Sjacobs "Failed to contact service for %s: %s\n"), 753355b4669Sjacobs (printer ? printer : "all"), 754355b4669Sjacobs verbose_papi_message(svc, status)); 755355b4669Sjacobs return (-1); 756355b4669Sjacobs } 7574749ecc3Ssonam gupta - Sun Microsystems - Bangalore India } 758355b4669Sjacobs 759355b4669Sjacobs if (printer == NULL) { /* all */ 760355b4669Sjacobs char **interest = interest_list(svc); 761355b4669Sjacobs 762355b4669Sjacobs if (interest != NULL) { 763355b4669Sjacobs int i; 764355b4669Sjacobs 765355b4669Sjacobs for (i = 0; interest[i] != NULL; i++) 766355b4669Sjacobs result += job_query(interest[i], report, 767355b4669Sjacobs encryption, show_rank, verbose); 768355b4669Sjacobs } 769355b4669Sjacobs } else if (id == -1) { /* a printer */ 770355b4669Sjacobs papi_job_t *jobs = NULL; 771355b4669Sjacobs 7724749ecc3Ssonam gupta - Sun Microsystems - Bangalore India status = papiPrinterListJobs(svc, printer, NULL, 7734749ecc3Ssonam gupta - Sun Microsystems - Bangalore India 0, 0, &jobs); 774355b4669Sjacobs if (status != PAPI_OK) { 775355b4669Sjacobs fprintf(stderr, gettext( 776355b4669Sjacobs "Failed to get job list: %s\n"), 777355b4669Sjacobs verbose_papi_message(svc, status)); 778355b4669Sjacobs papiServiceDestroy(svc); 779355b4669Sjacobs return (-1); 780355b4669Sjacobs } 781355b4669Sjacobs 782355b4669Sjacobs if (jobs != NULL) { 783355b4669Sjacobs int i; 784355b4669Sjacobs 785355b4669Sjacobs for (i = 0; jobs[i] != NULL; i++) 7864749ecc3Ssonam gupta - Sun Microsystems - Bangalore India result += report(jobs[i], 7874749ecc3Ssonam gupta - Sun Microsystems - Bangalore India show_rank, verbose); 788355b4669Sjacobs } 789355b4669Sjacobs 790355b4669Sjacobs papiJobListFree(jobs); 791355b4669Sjacobs } else { /* a job */ 792355b4669Sjacobs papi_job_t job = NULL; 793355b4669Sjacobs 7944749ecc3Ssonam gupta - Sun Microsystems - Bangalore India /* Once a job has been found stop processing */ 7954749ecc3Ssonam gupta - Sun Microsystems - Bangalore India flag = 0; 7964749ecc3Ssonam gupta - Sun Microsystems - Bangalore India 797355b4669Sjacobs status = papiJobQuery(svc, printer, id, NULL, &job); 798355b4669Sjacobs if (status != PAPI_OK) { 7994749ecc3Ssonam gupta - Sun Microsystems - Bangalore India if (!print_flag) 800355b4669Sjacobs fprintf(stderr, gettext( 801355b4669Sjacobs "Failed to get job info for %s: %s\n"), 802355b4669Sjacobs request, verbose_papi_message(svc, status)); 803355b4669Sjacobs papiServiceDestroy(svc); 804355b4669Sjacobs return (-1); 805355b4669Sjacobs } 806355b4669Sjacobs 807355b4669Sjacobs if (job != NULL) 808355b4669Sjacobs result = report(job, show_rank, verbose); 809355b4669Sjacobs 810355b4669Sjacobs papiJobFree(job); 811355b4669Sjacobs } 812355b4669Sjacobs 8134749ecc3Ssonam gupta - Sun Microsystems - Bangalore India if (flag) { 8144749ecc3Ssonam gupta - Sun Microsystems - Bangalore India id = -1; 8154749ecc3Ssonam gupta - Sun Microsystems - Bangalore India get_printer_id(printer, &printer, &id); 8164749ecc3Ssonam gupta - Sun Microsystems - Bangalore India if (id == -1) 8174749ecc3Ssonam gupta - Sun Microsystems - Bangalore India flag = 0; 8184749ecc3Ssonam gupta - Sun Microsystems - Bangalore India else 8194749ecc3Ssonam gupta - Sun Microsystems - Bangalore India flag1 = 1; 8204749ecc3Ssonam gupta - Sun Microsystems - Bangalore India } 8214749ecc3Ssonam gupta - Sun Microsystems - Bangalore India } while (flag); 8224749ecc3Ssonam gupta - Sun Microsystems - Bangalore India 823355b4669Sjacobs papiServiceDestroy(svc); 824355b4669Sjacobs 825355b4669Sjacobs return (result); 826355b4669Sjacobs } 827355b4669Sjacobs 828355b4669Sjacobs static int 829355b4669Sjacobs report_form(char *name, papi_attribute_t **attrs, int verbose) 830355b4669Sjacobs { 831355b4669Sjacobs papi_status_t status; 832355b4669Sjacobs char *form = NULL; 833355b4669Sjacobs void *iter = NULL; 834355b4669Sjacobs 835355b4669Sjacobs for (status = papiAttributeListGetString(attrs, &iter, 836355b4669Sjacobs "form-supported", &form); 837355b4669Sjacobs status == PAPI_OK; 838355b4669Sjacobs status = papiAttributeListGetString(attrs, &iter, 839355b4669Sjacobs NULL, &form)) { 840355b4669Sjacobs if ((name == NULL) || (strcmp(name, form) == 0)) { 841355b4669Sjacobs printf(gettext("form %s is available to you\n"), form); 842355b4669Sjacobs if (verbose != 0) { 843355b4669Sjacobs char *detail = NULL; 844355b4669Sjacobs status = papiAttributeListGetString(attrs, NULL, 845355b4669Sjacobs "form-supported-detail", 846355b4669Sjacobs &detail); 847355b4669Sjacobs if (status == PAPI_OK) 848355b4669Sjacobs printf("%s\n", detail); 849355b4669Sjacobs } 850355b4669Sjacobs } 851355b4669Sjacobs } 852355b4669Sjacobs 853355b4669Sjacobs return (0); 854355b4669Sjacobs } 855355b4669Sjacobs 856355b4669Sjacobs static int 857355b4669Sjacobs report_print_wheels(char *name, papi_attribute_t **attrs, int verbose) 858355b4669Sjacobs { 859355b4669Sjacobs papi_status_t status; 860355b4669Sjacobs char *pw = NULL; 861355b4669Sjacobs void *iter = NULL; 862355b4669Sjacobs 863355b4669Sjacobs for (status = papiAttributeListGetString(attrs, &iter, 864355b4669Sjacobs "pw-supported", &pw); 865355b4669Sjacobs status == PAPI_OK; 866355b4669Sjacobs status = papiAttributeListGetString(attrs, &iter, NULL, &pw)) { 867355b4669Sjacobs if ((name == NULL) || (strcmp(name, pw) == 0)) { 868355b4669Sjacobs printf(gettext("charset %s is available\n"), pw); 869355b4669Sjacobs if (verbose != 0) { 870355b4669Sjacobs char *info = NULL; 871355b4669Sjacobs status = papiAttributeListGetString(attrs, NULL, 872355b4669Sjacobs "pw-supported-extra", &info); 873355b4669Sjacobs if (status == PAPI_OK) 874355b4669Sjacobs printf("%s\n", info); 875355b4669Sjacobs } 876355b4669Sjacobs } 877355b4669Sjacobs } 878355b4669Sjacobs 879355b4669Sjacobs return (0); 880355b4669Sjacobs } 881355b4669Sjacobs 882355b4669Sjacobs static int 883355b4669Sjacobs service_query(char *name, int (*report)(char *, papi_attribute_t **, int), 884355b4669Sjacobs papi_encryption_t encryption, int verbose) 885355b4669Sjacobs { 886355b4669Sjacobs int result = 0; 887355b4669Sjacobs papi_status_t status; 888355b4669Sjacobs papi_service_t svc = NULL; 889355b4669Sjacobs papi_attribute_t **attrs = NULL; 890355b4669Sjacobs 891355b4669Sjacobs status = papiServiceCreate(&svc, name, NULL, NULL, cli_auth_callback, 892355b4669Sjacobs encryption, NULL); 893355b4669Sjacobs if (status != PAPI_OK) { 894355b4669Sjacobs papiServiceDestroy(svc); 895355b4669Sjacobs return (-1); 896355b4669Sjacobs } 897355b4669Sjacobs 898355b4669Sjacobs attrs = papiServiceGetAttributeList(svc); 899355b4669Sjacobs if (attrs != NULL) { 900355b4669Sjacobs result = report(name, attrs, verbose); 901355b4669Sjacobs 902355b4669Sjacobs if (verbose > 1) { 903355b4669Sjacobs printf("\n"); 904355b4669Sjacobs papiAttributeListPrint(stdout, attrs, "\t"); 905355b4669Sjacobs printf("\n"); 906355b4669Sjacobs } 907355b4669Sjacobs } 908355b4669Sjacobs 909355b4669Sjacobs papiServiceDestroy(svc); 910355b4669Sjacobs 911355b4669Sjacobs return (result); 912355b4669Sjacobs } 913355b4669Sjacobs 914355b4669Sjacobs int 915355b4669Sjacobs main(int ac, char *av[]) 916355b4669Sjacobs { 917355b4669Sjacobs int exit_code = 0; 918355b4669Sjacobs papi_encryption_t encryption = PAPI_ENCRYPT_NEVER; 919355b4669Sjacobs int rank = 0; 920355b4669Sjacobs int verbose = 0; 921355b4669Sjacobs int description = 0; 922355b4669Sjacobs int c; 923355b4669Sjacobs char **argv; 924355b4669Sjacobs 925355b4669Sjacobs (void) setlocale(LC_ALL, ""); 926355b4669Sjacobs (void) textdomain("SUNW_OST_OSCMD"); 927355b4669Sjacobs 928355b4669Sjacobs argv = (char **)calloc((ac + 1), sizeof (char *)); 92991216fe4Swendyp for (c = 0; c < ac; c++) { 93091216fe4Swendyp if ((av[c][0] == '-') && (av[c][1] == 'l') && 93191216fe4Swendyp (isalpha(av[c][2]) != 0)) { 93291216fe4Swendyp /* preserve old "-l[po...]" behavior */ 93391216fe4Swendyp argv[c] = &av[c][1]; 93491216fe4Swendyp argv[c][0] = '-'; 93591216fe4Swendyp verbose = 1; 93691216fe4Swendyp 93791216fe4Swendyp } else 938355b4669Sjacobs argv[c] = av[c]; 93991216fe4Swendyp } 94091216fe4Swendyp 941355b4669Sjacobs argv[c++] = "--"; 942355b4669Sjacobs ac = c; 943355b4669Sjacobs 944355b4669Sjacobs /* preprocess argument list looking for '-l' or '-R' so it can trail */ 945355b4669Sjacobs while ((c = getopt(ac, argv, "LEDf:S:stc:p:a:drs:v:l:o:R:u:")) != EOF) 946355b4669Sjacobs switch (c) { 947355b4669Sjacobs case 'l': 948355b4669Sjacobs if ((optarg == NULL) || (optarg[0] == '-')) 949355b4669Sjacobs optarg = "1"; 950355b4669Sjacobs verbose = atoi(optarg); 951355b4669Sjacobs break; 952355b4669Sjacobs case 'D': 953355b4669Sjacobs description = 1; 954355b4669Sjacobs break; 955355b4669Sjacobs case 'R': 956355b4669Sjacobs rank = 1; 957355b4669Sjacobs break; 958355b4669Sjacobs case 'E': 959355b4669Sjacobs encryption = PAPI_ENCRYPT_REQUIRED; 960355b4669Sjacobs break; 961355b4669Sjacobs default: 962355b4669Sjacobs break; 963355b4669Sjacobs } 964355b4669Sjacobs optind = 1; 965355b4669Sjacobs 966355b4669Sjacobs /* process command line arguments */ 967355b4669Sjacobs while ((c = getopt(ac, argv, "LEDf:S:stc:p:a:drs:v:l:o:R:u:")) != EOF) { 968355b4669Sjacobs switch (c) { /* these may or may not have an option */ 969355b4669Sjacobs case 'a': 970355b4669Sjacobs case 'c': 971355b4669Sjacobs case 'p': 972355b4669Sjacobs case 'o': 973355b4669Sjacobs case 'R': 974355b4669Sjacobs case 'u': 975355b4669Sjacobs case 'v': 976355b4669Sjacobs case 'l': 977355b4669Sjacobs case 'f': 978355b4669Sjacobs case 'S': 979355b4669Sjacobs if (optarg[0] == '-') { 980355b4669Sjacobs /* this check stop a possible infinite loop */ 981355b4669Sjacobs if ((optind > 1) && (argv[optind-1][1] != c)) 982355b4669Sjacobs optind--; 983355b4669Sjacobs optarg = NULL; 984355b4669Sjacobs } else if (strcmp(optarg, "all") == 0) 985355b4669Sjacobs optarg = NULL; 986355b4669Sjacobs } 987355b4669Sjacobs 988355b4669Sjacobs switch (c) { 989355b4669Sjacobs case 'a': 990355b4669Sjacobs exit_code += printer_query(optarg, report_accepting, 991355b4669Sjacobs encryption, verbose, 0); 992355b4669Sjacobs break; 993355b4669Sjacobs case 'c': 994355b4669Sjacobs exit_code += printer_query(optarg, report_class, 995355b4669Sjacobs encryption, verbose, 0); 996355b4669Sjacobs break; 997355b4669Sjacobs case 'p': 998355b4669Sjacobs exit_code += printer_query(optarg, report_printer, 999355b4669Sjacobs encryption, verbose, 1000355b4669Sjacobs description); 1001355b4669Sjacobs break; 1002355b4669Sjacobs case 'd': 1003355b4669Sjacobs exit_code += lpstat_default_printer(encryption); 1004355b4669Sjacobs break; 1005355b4669Sjacobs case 'r': 1006355b4669Sjacobs exit_code += lpstat_service_status(encryption); 1007355b4669Sjacobs break; 1008355b4669Sjacobs case 'u': 1009355b4669Sjacobs if (optarg != NULL) 1010355b4669Sjacobs users = strsplit(optarg, ", \n"); 1011355b4669Sjacobs exit_code += job_query(NULL, report_job, 1012355b4669Sjacobs encryption, rank, verbose); 1013355b4669Sjacobs if (users != NULL) { 1014355b4669Sjacobs free(users); 1015355b4669Sjacobs users = NULL; 1016355b4669Sjacobs } 1017355b4669Sjacobs break; 1018355b4669Sjacobs case 'v': 1019355b4669Sjacobs exit_code += printer_query(optarg, report_device, 1020355b4669Sjacobs encryption, verbose, 0); 1021355b4669Sjacobs break; 1022355b4669Sjacobs case 'o': 1023355b4669Sjacobs exit_code += job_query(optarg, report_job, 1024355b4669Sjacobs encryption, rank, verbose); 1025355b4669Sjacobs break; 1026355b4669Sjacobs case 'f': 1027355b4669Sjacobs exit_code += service_query(optarg, report_form, 1028355b4669Sjacobs encryption, verbose); 1029355b4669Sjacobs break; 1030355b4669Sjacobs case 'S': 1031355b4669Sjacobs exit_code += service_query(optarg, report_print_wheels, 1032355b4669Sjacobs encryption, verbose); 1033355b4669Sjacobs break; 1034355b4669Sjacobs case 's': 1035355b4669Sjacobs exit_code += lpstat_service_status(encryption); 1036355b4669Sjacobs exit_code += lpstat_default_printer(encryption); 1037355b4669Sjacobs exit_code += printer_query(NULL, report_class, 1038355b4669Sjacobs encryption, verbose, 0); 1039355b4669Sjacobs exit_code += printer_query(NULL, report_device, 1040355b4669Sjacobs encryption, verbose, 0); 1041355b4669Sjacobs exit_code += service_query(optarg, report_form, 1042355b4669Sjacobs encryption, verbose); 1043355b4669Sjacobs exit_code += service_query(optarg, report_print_wheels, 1044355b4669Sjacobs encryption, verbose); 1045355b4669Sjacobs break; 1046355b4669Sjacobs case 't': 1047355b4669Sjacobs exit_code += lpstat_service_status(encryption); 1048355b4669Sjacobs exit_code += lpstat_default_printer(encryption); 1049355b4669Sjacobs exit_code += printer_query(NULL, report_class, 1050355b4669Sjacobs encryption, verbose, 0); 1051355b4669Sjacobs exit_code += printer_query(NULL, report_device, 1052355b4669Sjacobs encryption, verbose, 0); 1053355b4669Sjacobs exit_code += printer_query(NULL, report_accepting, 1054355b4669Sjacobs encryption, verbose, 0); 1055355b4669Sjacobs exit_code += printer_query(NULL, report_printer, 1056355b4669Sjacobs encryption, verbose, 0); 1057355b4669Sjacobs exit_code += service_query(optarg, report_form, 1058355b4669Sjacobs encryption, verbose); 1059355b4669Sjacobs exit_code += service_query(optarg, report_print_wheels, 1060355b4669Sjacobs encryption, verbose); 1061355b4669Sjacobs exit_code += job_query(NULL, report_job, 1062355b4669Sjacobs encryption, rank, verbose); 1063355b4669Sjacobs break; 1064355b4669Sjacobs case 'L': /* local-only, ignored */ 1065355b4669Sjacobs case 'l': /* increased verbose level in first pass */ 1066355b4669Sjacobs case 'D': /* set "description" flag in first pass */ 1067355b4669Sjacobs case 'R': /* set "rank" flag in first pass */ 1068355b4669Sjacobs case 'E': /* set encryption in the first pass */ 1069355b4669Sjacobs break; 1070355b4669Sjacobs default: 1071355b4669Sjacobs usage(av[0]); 1072355b4669Sjacobs } 1073355b4669Sjacobs } 1074355b4669Sjacobs ac--; 1075355b4669Sjacobs 1076355b4669Sjacobs if (ac == 1) { /* report on my jobs */ 1077355b4669Sjacobs struct passwd *pw = getpwuid(getuid()); 1078355b4669Sjacobs 1079355b4669Sjacobs if (pw != NULL) 1080355b4669Sjacobs users = strsplit(pw->pw_name, ""); 1081355b4669Sjacobs exit_code += job_query(NULL, report_job, encryption, 1082355b4669Sjacobs rank, verbose); 1083355b4669Sjacobs if (users != NULL) { 1084355b4669Sjacobs free(users); 1085355b4669Sjacobs users = NULL; 1086355b4669Sjacobs } 1087355b4669Sjacobs } else { 1088355b4669Sjacobs for (c = optind; c < ac; c++) 1089355b4669Sjacobs exit_code += job_query(argv[c], report_job, encryption, 1090355b4669Sjacobs rank, verbose); 1091355b4669Sjacobs } 1092355b4669Sjacobs 1093355b4669Sjacobs 1094355b4669Sjacobs if (exit_code != 0) 1095355b4669Sjacobs exit_code = 1; 1096355b4669Sjacobs 1097355b4669Sjacobs return (exit_code); 1098355b4669Sjacobs } 1099