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