1*2264Sjacobs /* 2*2264Sjacobs * CDDL HEADER START 3*2264Sjacobs * 4*2264Sjacobs * The contents of this file are subject to the terms of the 5*2264Sjacobs * Common Development and Distribution License (the "License"). 6*2264Sjacobs * You may not use this file except in compliance with the License. 7*2264Sjacobs * 8*2264Sjacobs * You can obtain a copy of the license at usr/src/OPENSOLARIS.LICENSE 9*2264Sjacobs * or http://www.opensolaris.org/os/licensing. 10*2264Sjacobs * See the License for the specific language governing permissions 11*2264Sjacobs * and limitations under the License. 12*2264Sjacobs * 13*2264Sjacobs * When distributing Covered Code, include this CDDL HEADER in each 14*2264Sjacobs * file and include the License file at usr/src/OPENSOLARIS.LICENSE. 15*2264Sjacobs * If applicable, add the following below this CDDL HEADER, with the 16*2264Sjacobs * fields enclosed by brackets "[]" replaced with your own identifying 17*2264Sjacobs * information: Portions Copyright [yyyy] [name of copyright owner] 18*2264Sjacobs * 19*2264Sjacobs * CDDL HEADER END 20*2264Sjacobs */ 21*2264Sjacobs 22*2264Sjacobs /* 23*2264Sjacobs * Copyright 2006 Sun Microsystems, Inc. All rights reserved. 24*2264Sjacobs * Use is subject to license terms. 25*2264Sjacobs * 26*2264Sjacobs */ 27*2264Sjacobs 28*2264Sjacobs /* $Id: disable.c 146 2006-03-24 00:26:54Z njacobs $ */ 29*2264Sjacobs 30*2264Sjacobs #pragma ident "%Z%%M% %I% %E% SMI" 31*2264Sjacobs 32*2264Sjacobs #include <stdio.h> 33*2264Sjacobs #include <stdlib.h> 34*2264Sjacobs #include <unistd.h> 35*2264Sjacobs #include <string.h> 36*2264Sjacobs #include <locale.h> 37*2264Sjacobs #include <libintl.h> 38*2264Sjacobs #include <papi.h> 39*2264Sjacobs #include "common.h" 40*2264Sjacobs 41*2264Sjacobs static void 42*2264Sjacobs usage(char *program) 43*2264Sjacobs { 44*2264Sjacobs char *name; 45*2264Sjacobs 46*2264Sjacobs if ((name = strrchr(program, '/')) == NULL) 47*2264Sjacobs name = program; 48*2264Sjacobs else 49*2264Sjacobs name++; 50*2264Sjacobs 51*2264Sjacobs fprintf(stdout, 52*2264Sjacobs gettext("Usage: %s [-c] [-W] [-r reason] destination ...\n"), 53*2264Sjacobs name); 54*2264Sjacobs exit(1); 55*2264Sjacobs } 56*2264Sjacobs 57*2264Sjacobs static void 58*2264Sjacobs cancel_active_job(papi_service_t svc, char *dest) 59*2264Sjacobs { 60*2264Sjacobs papi_status_t status; 61*2264Sjacobs papi_job_t *j = NULL; 62*2264Sjacobs char *req_attrs[] = { "job-state", "job-id", NULL }; 63*2264Sjacobs 64*2264Sjacobs status = papiPrinterListJobs(svc, dest, req_attrs, 0, 0, &j); 65*2264Sjacobs if ((status == PAPI_OK) && (j != NULL)) { 66*2264Sjacobs int i; 67*2264Sjacobs 68*2264Sjacobs for (i = 0; j[i] != NULL; j++) { 69*2264Sjacobs papi_attribute_t **a = papiJobGetAttributeList(j[i]); 70*2264Sjacobs int state = 0; 71*2264Sjacobs 72*2264Sjacobs if (a == NULL) 73*2264Sjacobs continue; 74*2264Sjacobs 75*2264Sjacobs (void) papiAttributeListGetInteger(a, NULL, 76*2264Sjacobs "job-state", &state); 77*2264Sjacobs if (state == 0x05) { /* processing */ 78*2264Sjacobs int32_t id = papiJobGetId(j[i]); 79*2264Sjacobs 80*2264Sjacobs (void) papiJobCancel(svc, dest, id); 81*2264Sjacobs } 82*2264Sjacobs } 83*2264Sjacobs papiJobListFree(j); 84*2264Sjacobs } 85*2264Sjacobs } 86*2264Sjacobs 87*2264Sjacobs int 88*2264Sjacobs main(int ac, char *av[]) 89*2264Sjacobs { 90*2264Sjacobs papi_status_t status; 91*2264Sjacobs papi_service_t svc = NULL; 92*2264Sjacobs papi_encryption_t encryption = PAPI_ENCRYPT_NEVER; 93*2264Sjacobs int exit_status = 0; 94*2264Sjacobs int cancel = 0; 95*2264Sjacobs int pending = 0; /* not implemented */ 96*2264Sjacobs char *reason = NULL; 97*2264Sjacobs int c; 98*2264Sjacobs 99*2264Sjacobs (void) setlocale(LC_ALL, ""); 100*2264Sjacobs (void) textdomain("SUNW_OST_OSCMD"); 101*2264Sjacobs 102*2264Sjacobs while ((c = getopt(ac, av, "EcWr:")) != EOF) 103*2264Sjacobs switch (c) { 104*2264Sjacobs case 'c': /* cancel active job first */ 105*2264Sjacobs cancel = 1; 106*2264Sjacobs break; 107*2264Sjacobs case 'W': /* wait for active request, not implemented */ 108*2264Sjacobs pending = 1; 109*2264Sjacobs break; 110*2264Sjacobs case 'r': /* reason */ 111*2264Sjacobs reason = optarg; 112*2264Sjacobs break; 113*2264Sjacobs case 'E': 114*2264Sjacobs encryption = PAPI_ENCRYPT_NEVER; 115*2264Sjacobs break; 116*2264Sjacobs default: 117*2264Sjacobs usage(av[0]); 118*2264Sjacobs } 119*2264Sjacobs 120*2264Sjacobs if (ac <= optind) 121*2264Sjacobs usage(av[0]); 122*2264Sjacobs 123*2264Sjacobs while (optind < ac) { 124*2264Sjacobs char *printer = av[optind++]; 125*2264Sjacobs 126*2264Sjacobs status = papiServiceCreate(&svc, printer, NULL, NULL, 127*2264Sjacobs cli_auth_callback, encryption, NULL); 128*2264Sjacobs if (status != PAPI_OK) { 129*2264Sjacobs fprintf(stderr, gettext( 130*2264Sjacobs "Failed to contact service for %s: %s\n"), 131*2264Sjacobs printer, verbose_papi_message(svc, status)); 132*2264Sjacobs exit_status = 1; 133*2264Sjacobs } 134*2264Sjacobs 135*2264Sjacobs status = papiPrinterDisable(svc, printer, reason); 136*2264Sjacobs if (status != PAPI_OK) { 137*2264Sjacobs fprintf(stderr, gettext("disable: %s: %s\n"), printer, 138*2264Sjacobs verbose_papi_message(svc, status)); 139*2264Sjacobs exit_status = 1; 140*2264Sjacobs } 141*2264Sjacobs 142*2264Sjacobs if (cancel != 0) 143*2264Sjacobs cancel_active_job(svc, printer); 144*2264Sjacobs 145*2264Sjacobs papiServiceDestroy(svc); 146*2264Sjacobs } 147*2264Sjacobs 148*2264Sjacobs return (exit_status); 149*2264Sjacobs } 150