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#pragma ident	"%Z%%M%	%I%	%E% SMI"
31
32#include <stdio.h>
33#include <papi.h>
34#include <ipp.h>
35#include <ipp-listener.h>
36
37papi_status_t
38ipp_cancel_job(papi_service_t svc, papi_attribute_t **request,
39		papi_attribute_t ***response)
40{
41	papi_status_t status;
42	papi_attribute_t **operational = NULL;
43
44	char *message = NULL;
45	char *queue = NULL;
46	int id = -1;
47
48	/* Get operational attributes from the request */
49	(void) papiAttributeListGetCollection(request, NULL,
50				"operational-attributes-group", &operational);
51
52	/*
53	 * the operational-attributes-group must contain:
54	 *	job-uri (or printer-uri/job-id)
55	 */
56	get_printer_id(operational, &queue, &id);
57	if (id < 0) {
58		ipp_set_status(response, PAPI_BAD_REQUEST,
59				"missing job-uri or job-id");
60		return (PAPI_BAD_REQUEST);
61	} else if (queue == NULL) {
62		ipp_set_status(response, PAPI_BAD_REQUEST,
63				"missing printer-uri or job-uri");
64		return (PAPI_BAD_REQUEST);
65	}
66
67	/*
68	 * the operational-attributes-group may contain:
69	 *	message
70	 */
71	(void) papiAttributeListGetString(operational, NULL,
72				"message", &message);
73
74	status = papiJobCancel(svc, queue, id);
75	if (status != PAPI_OK) {
76		ipp_set_status(response, status,
77				"cancel failed: %s-%d: %s",
78				(queue ? queue : "(null)"), id,
79				ipp_svc_status_mesg(svc, status));
80	} else if (message != NULL) {	/* add unsupported attribute group */
81		papi_attribute_t **unsupported = NULL;
82
83		papiAttributeListAddValue(&unsupported, PAPI_ATTR_EXCL,
84					"message", PAPI_COLLECTION, NULL);
85		(void) papiAttributeListAddCollection(response,
86			PAPI_ATTR_REPLACE, "unsupported-attributes-group",
87			unsupported);
88		papiAttributeListFree(unsupported);
89
90		status = PAPI_OK_SUBST;
91		ipp_set_status(response, status,
92			"unsupported attribute in request");
93	}
94
95	return (status);
96}
97