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