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: validate-job.c 146 2006-03-24 00:26:54Z njacobs $ */
29*355b4669Sjacobs 
30*355b4669Sjacobs #include <stdio.h>
31*355b4669Sjacobs #include <stdlib.h>
32*355b4669Sjacobs #include <papi.h>
33*355b4669Sjacobs #include <ipp.h>
34*355b4669Sjacobs #include <ipp-listener.h>
35*355b4669Sjacobs 
36*355b4669Sjacobs papi_status_t
ipp_validate_job(papi_service_t svc,papi_attribute_t ** request,papi_attribute_t *** response,ipp_reader_t iread,void * fd)37*355b4669Sjacobs ipp_validate_job(papi_service_t svc, papi_attribute_t **request,
38*355b4669Sjacobs 		papi_attribute_t ***response, ipp_reader_t iread, void *fd)
39*355b4669Sjacobs {
40*355b4669Sjacobs 	papi_status_t status;
41*355b4669Sjacobs 	papi_job_t j = NULL;
42*355b4669Sjacobs 	papi_attribute_t **operational = NULL;
43*355b4669Sjacobs 	papi_attribute_t **job_attributes = NULL;
44*355b4669Sjacobs 	char *queue = NULL;
45*355b4669Sjacobs 	char *files[] = { "/etc/syslog.conf", NULL };
46*355b4669Sjacobs 	ssize_t rc;
47*355b4669Sjacobs 	char buf[BUFSIZ];
48*355b4669Sjacobs 	char *keys[] = { "attributes-natural-language", "attributes-charset",
49*355b4669Sjacobs 			"printer-uri", NULL };
50*355b4669Sjacobs 
51*355b4669Sjacobs 	/* Get operational attributes from the request */
52*355b4669Sjacobs 	(void) papiAttributeListGetCollection(request, NULL,
53*355b4669Sjacobs 				"operational-attributes-group", &operational);
54*355b4669Sjacobs 
55*355b4669Sjacobs 	/*
56*355b4669Sjacobs 	 * The operational-attributes-group must contain:
57*355b4669Sjacobs 	 *	printer-uri
58*355b4669Sjacobs 	 */
59*355b4669Sjacobs 	get_printer_id(operational, &queue, NULL);
60*355b4669Sjacobs 	if (queue == NULL) {
61*355b4669Sjacobs 		ipp_set_status(response, status, "printer-uri: %s",
62*355b4669Sjacobs 			papiStatusString(status));
63*355b4669Sjacobs 		return (PAPI_BAD_REQUEST);
64*355b4669Sjacobs 	}
65*355b4669Sjacobs 
66*355b4669Sjacobs 	/*
67*355b4669Sjacobs 	 * The operational-attributes-group may contain:
68*355b4669Sjacobs 	 *	job-name
69*355b4669Sjacobs 	 *	ipp-attribute-fidelity
70*355b4669Sjacobs 	 *	document-name
71*355b4669Sjacobs 	 *	compression
72*355b4669Sjacobs 	 *	document-format
73*355b4669Sjacobs 	 *	document-natural-language
74*355b4669Sjacobs 	 *	job-k-octets
75*355b4669Sjacobs 	 *	job-impressions
76*355b4669Sjacobs 	 *	job-media-sheets
77*355b4669Sjacobs 	 * Simply copy the entire contents of the operational-attributes-group
78*355b4669Sjacobs 	 * for the PAPI call's possible use.
79*355b4669Sjacobs 	 */
80*355b4669Sjacobs 	split_and_copy_attributes(keys, operational, NULL, &job_attributes);
81*355b4669Sjacobs 
82*355b4669Sjacobs 	/* copy any job-attributes-group attributes for the PAPI call */
83*355b4669Sjacobs 	if (papiAttributeListGetCollection(request, NULL,
84*355b4669Sjacobs 			"job-attributes-group", &operational) == PAPI_OK)
85*355b4669Sjacobs 		copy_attributes(&job_attributes, operational);
86*355b4669Sjacobs 
87*355b4669Sjacobs 	/* request job validation */
88*355b4669Sjacobs 	status = papiJobValidate(svc, queue, job_attributes, NULL, files, &j);
89*355b4669Sjacobs 	papiAttributeListFree(job_attributes);
90*355b4669Sjacobs 
91*355b4669Sjacobs 	if (status != PAPI_OK) {
92*355b4669Sjacobs 		ipp_set_status(response, status, "validating job: %s",
93*355b4669Sjacobs 				ipp_svc_status_mesg(svc, status));
94*355b4669Sjacobs 		papiJobFree(j);	/* we shouldn't have a job, but just in case */
95*355b4669Sjacobs 		return (status);
96*355b4669Sjacobs 	}
97*355b4669Sjacobs 
98*355b4669Sjacobs 	/* add the job attributes to the response in a job-attributes-group */
99*355b4669Sjacobs 	if (j != NULL) {
100*355b4669Sjacobs 		papi_to_ipp_job_group(response, request, PAPI_ATTR_REPLACE, j);
101*355b4669Sjacobs 		papiJobFree(j);
102*355b4669Sjacobs 	}
103*355b4669Sjacobs 
104*355b4669Sjacobs 	return (status);
105*355b4669Sjacobs }
106