1 /*
2 * CDDL HEADER START
3 *
4 * The contents of this file are subject to the terms of the
5 * Common Development and Distribution License (the "License").
6 * You may not use this file except in compliance with the License.
7 *
8 * You can obtain a copy of the license at usr/src/OPENSOLARIS.LICENSE
9 * or http://www.opensolaris.org/os/licensing.
10 * See the License for the specific language governing permissions
11 * and limitations under the License.
12 *
13 * When distributing Covered Code, include this CDDL HEADER in each
14 * file and include the License file at usr/src/OPENSOLARIS.LICENSE.
15 * If applicable, add the following below this CDDL HEADER, with the
16 * fields enclosed by brackets "[]" replaced with your own identifying
17 * information: Portions Copyright [yyyy] [name of copyright owner]
18 *
19 * CDDL HEADER END
20 */
21
22 /*
23 * Copyright 2006 Sun Microsystems, Inc. All rights reserved.
24 * Use is subject to license terms.
25 *
26 */
27
28 /* $Id: cancel-job.c 146 2006-03-24 00:26:54Z njacobs $ */
29
30 #include <stdio.h>
31 #include <papi.h>
32 #include <ipp.h>
33 #include <ipp-listener.h>
34
35 papi_status_t
ipp_cancel_job(papi_service_t svc,papi_attribute_t ** request,papi_attribute_t *** response)36 ipp_cancel_job(papi_service_t svc, papi_attribute_t **request,
37 papi_attribute_t ***response)
38 {
39 papi_status_t status;
40 papi_attribute_t **operational = NULL;
41
42 char *message = NULL;
43 char *queue = NULL;
44 int id = -1;
45
46 /* Get operational attributes from the request */
47 (void) papiAttributeListGetCollection(request, NULL,
48 "operational-attributes-group", &operational);
49
50 /*
51 * the operational-attributes-group must contain:
52 * job-uri (or printer-uri/job-id)
53 */
54 get_printer_id(operational, &queue, &id);
55 if (id < 0) {
56 ipp_set_status(response, PAPI_BAD_REQUEST,
57 "missing job-uri or job-id");
58 return (PAPI_BAD_REQUEST);
59 } else if (queue == NULL) {
60 ipp_set_status(response, PAPI_BAD_REQUEST,
61 "missing printer-uri or job-uri");
62 return (PAPI_BAD_REQUEST);
63 }
64
65 /*
66 * the operational-attributes-group may contain:
67 * message
68 */
69 (void) papiAttributeListGetString(operational, NULL,
70 "message", &message);
71
72 status = papiJobCancel(svc, queue, id);
73 if (status != PAPI_OK) {
74 ipp_set_status(response, status,
75 "cancel failed: %s-%d: %s",
76 (queue ? queue : "(null)"), id,
77 ipp_svc_status_mesg(svc, status));
78 } else if (message != NULL) { /* add unsupported attribute group */
79 papi_attribute_t **unsupported = NULL;
80
81 papiAttributeListAddValue(&unsupported, PAPI_ATTR_EXCL,
82 "message", PAPI_COLLECTION, NULL);
83 (void) papiAttributeListAddCollection(response,
84 PAPI_ATTR_REPLACE, "unsupported-attributes-group",
85 unsupported);
86 papiAttributeListFree(unsupported);
87
88 status = PAPI_OK_SUBST;
89 ipp_set_status(response, status,
90 "unsupported attribute in request");
91 }
92
93 return (status);
94 }
95