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: cancel.c 147 2006-04-25 16:51:06Z 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, "Usage: %s [-u user] (printer|request-id ...)\n", name);
52*2264Sjacobs 	exit(1);
53*2264Sjacobs }
54*2264Sjacobs 
55*2264Sjacobs int
56*2264Sjacobs main(int ac, char *av[])
57*2264Sjacobs {
58*2264Sjacobs 	int exit_code = 0;
59*2264Sjacobs 	char *user = NULL;
60*2264Sjacobs 	papi_encryption_t encryption = PAPI_ENCRYPT_NEVER;
61*2264Sjacobs 	int c;
62*2264Sjacobs 
63*2264Sjacobs 	(void) setlocale(LC_ALL, "");
64*2264Sjacobs 	(void) textdomain("SUNW_OST_OSCMD");
65*2264Sjacobs 
66*2264Sjacobs 	while ((c = getopt(ac, av, "Eu:")) != EOF)
67*2264Sjacobs 		switch (c) {
68*2264Sjacobs 		case 'E':
69*2264Sjacobs 			encryption = PAPI_ENCRYPT_REQUIRED;
70*2264Sjacobs 			break;
71*2264Sjacobs 		case 'u':
72*2264Sjacobs 			user = optarg;
73*2264Sjacobs 			break;
74*2264Sjacobs 		default:
75*2264Sjacobs 			usage(av[0]);
76*2264Sjacobs 		}
77*2264Sjacobs 
78*2264Sjacobs 	for (c = optind; c < ac; c++) {
79*2264Sjacobs 		papi_status_t status;
80*2264Sjacobs 		papi_service_t svc = NULL;
81*2264Sjacobs 		papi_job_t *jobs = NULL;
82*2264Sjacobs 		char *printer = NULL;
83*2264Sjacobs 		int32_t id = -1;
84*2264Sjacobs 
85*2264Sjacobs 		(void) get_printer_id(av[c], &printer, &id);
86*2264Sjacobs 
87*2264Sjacobs 		status = papiServiceCreate(&svc, printer, user, NULL,
88*2264Sjacobs 					cli_auth_callback, encryption, NULL);
89*2264Sjacobs 		if (status != PAPI_OK) {
90*2264Sjacobs 			fprintf(stderr, gettext(
91*2264Sjacobs 				"Failed to contact service for %s: %s\n"),
92*2264Sjacobs 				printer, verbose_papi_message(svc, status));
93*2264Sjacobs 			exit(1);
94*2264Sjacobs 		}
95*2264Sjacobs 
96*2264Sjacobs #define	OUT	((status == PAPI_OK) ? stdout : stderr)
97*2264Sjacobs 
98*2264Sjacobs 		if (id != -1) {	/* it's a job */
99*2264Sjacobs 			char *mesg = "cancelled";
100*2264Sjacobs 
101*2264Sjacobs 			status = papiJobCancel(svc, printer, id);
102*2264Sjacobs 			if (status != PAPI_OK) {
103*2264Sjacobs 				mesg = verbose_papi_message(svc, status);
104*2264Sjacobs 				exit_code = 1;
105*2264Sjacobs 			}
106*2264Sjacobs 			fprintf(OUT, "%s-%d: %s\n", printer, id, mesg);
107*2264Sjacobs 		} else {	/* it's a printer */
108*2264Sjacobs 			status = papiPrinterPurgeJobs(svc, printer, &jobs);
109*2264Sjacobs 			if (status != PAPI_OK) {
110*2264Sjacobs 				fprintf(stderr, gettext("PurgeJobs %s: %s\n"),
111*2264Sjacobs 					printer,
112*2264Sjacobs 					verbose_papi_message(svc, status));
113*2264Sjacobs 				exit_code = 1;
114*2264Sjacobs 			}
115*2264Sjacobs 
116*2264Sjacobs 			while ((jobs != NULL) && (*jobs != NULL))
117*2264Sjacobs 				fprintf(OUT, "%s-%d: %s\n", printer,
118*2264Sjacobs 					papiJobGetId(*jobs++), "cancelled");
119*2264Sjacobs 
120*2264Sjacobs 			papiJobListFree(jobs);
121*2264Sjacobs 		}
122*2264Sjacobs 
123*2264Sjacobs 		papiServiceDestroy(svc);
124*2264Sjacobs 	}
125*2264Sjacobs 
126*2264Sjacobs 	return (exit_code);
127*2264Sjacobs }
128