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: get-jobs.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_get_jobs(papi_service_t svc,papi_attribute_t ** request,papi_attribute_t *** response)36 ipp_get_jobs(papi_service_t svc, papi_attribute_t **request,
37 		papi_attribute_t ***response)
38 {
39 	papi_status_t status;
40 	papi_job_t *j = NULL;
41 	papi_attribute_t **operational = NULL;
42 
43 	char **req_attrs = NULL;
44 	char *queue = NULL;
45 	int limit = 0;
46 	char my_jobs = PAPI_FALSE;
47 	char *which;
48 	int type = 0;
49 
50 	/* Get operational attributes from the request */
51 	(void) papiAttributeListGetCollection(request, NULL,
52 				"operational-attributes-group", &operational);
53 
54 	/*
55 	 * The operational-attributes-group must contain:
56 	 *	printer-uri
57 	 */
58 	get_printer_id(operational, &queue, NULL);
59 	if (queue == NULL) {
60 		ipp_set_status(response, status, "printer-uri: %s",
61 			papiStatusString(status));
62 		return (PAPI_BAD_REQUEST);
63 	}
64 
65 	/*
66 	 * The operational-attributes-group may contain:
67 	 *	limit
68 	 *	requested-attributes
69 	 *	which-jobs
70 	 *	my-jobs
71 	 */
72 	(void) papiAttributeListGetString(operational, NULL,
73 				"which-jobs", &which);
74 	(void) papiAttributeListGetBoolean(operational, NULL,
75 				"my-jobs", &my_jobs);
76 	(void) papiAttributeListGetInteger(operational, NULL, "limit", &limit);
77 	get_string_list(operational, "requested-attributes", &req_attrs);
78 
79 	status = papiPrinterListJobs(svc, queue, req_attrs, type, limit, &j);
80 	if (status != PAPI_OK) {
81 		ipp_set_status(response, status, "query jobs: %s",
82 				ipp_svc_status_mesg(svc, status));
83 		return (status);
84 	}
85 
86 	/* add any job's attributes to the response in job-attribute-groups */
87 	if (j != NULL) {
88 		int i;
89 
90 		for (i = 0; j[i] != NULL; i++)
91 			papi_to_ipp_job_group(response, request,
92 					PAPI_ATTR_APPEND, j[i]);
93 		papiJobListFree(j);
94 	}
95 
96 	return (status);
97 }
98