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: print-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 <stdlib.h>
34 #include <papi.h>
35 #include <ipp.h>
36 #include <ipp-listener.h>
37 
38 papi_status_t
39 ipp_print_job(papi_service_t svc, papi_attribute_t **request,
40 		papi_attribute_t ***response, ipp_reader_t iread, void *fd)
41 {
42 	papi_status_t status;
43 	papi_stream_t s = NULL;
44 	papi_job_t j = NULL;
45 	papi_attribute_t **operational = NULL;
46 	papi_attribute_t **job_attributes = NULL;
47 	char *queue = NULL;
48 	ssize_t rc;
49 	char buf[BUFSIZ];
50 	char *keys[] = { "attributes-natural-language", "attributes-charset",
51 			"printer-uri", NULL };
52 
53 	/* Get operational attributes from the request */
54 	(void) papiAttributeListGetCollection(request, NULL,
55 				"operational-attributes-group", &operational);
56 
57 	/*
58 	 * The operational-attributes-group must contain:
59 	 *	printer-uri
60 	 */
61 	get_printer_id(operational, &queue, NULL);
62 	if (queue == NULL) {
63 		ipp_set_status(response, status, "printer-uri: %s",
64 			papiStatusString(status));
65 		return (PAPI_BAD_REQUEST);
66 	}
67 
68 	/*
69 	 * The operational-attributes-group may contain:
70 	 *	job-name
71 	 *	ipp-attribute-fidelity
72 	 *	document-name
73 	 *	compression
74 	 *	document-format
75 	 *	document-natural-language
76 	 *	job-k-octets
77 	 *	job-impressions
78 	 *	job-media-sheets
79 	 * Simply copy the entire contents of the operational-attributes-group
80 	 * for the PAPI call's possible use.
81 	 */
82 	split_and_copy_attributes(keys, operational, NULL, &job_attributes);
83 
84 	/* copy any job-attributes-group attributes for the PAPI call */
85 	if (papiAttributeListGetCollection(request, NULL,
86 			"job-attributes-group", &operational) == PAPI_OK)
87 		copy_attributes(&job_attributes, operational);
88 
89 	/* request job creation with a resulting stream that we can write to */
90 	status = papiJobStreamOpen(svc, queue, job_attributes, NULL, &s);
91 	papiAttributeListFree(job_attributes);
92 	if (status != PAPI_OK) {
93 		ipp_set_status(response, status, "job submission: %s",
94 				ipp_svc_status_mesg(svc, status));
95 		return (status);
96 	}
97 
98 	/* copy the document data from the IPP connection to the stream */
99 	while ((status == PAPI_OK) && ((rc = iread(fd, buf, sizeof (buf))) > 0))
100 		status = papiJobStreamWrite(svc, s, buf, rc);
101 	if (status != PAPI_OK) {
102 		ipp_set_status(response, status, "write job data: %s",
103 				ipp_svc_status_mesg(svc, status));
104 		return (status);
105 	}
106 
107 	/* close the stream, committing the job */
108 	status = papiJobStreamClose(svc, s, &j);
109 	if (status != PAPI_OK) {
110 		ipp_set_status(response, status, "close job stream: %s",
111 				ipp_svc_status_mesg(svc, status));
112 		papiJobFree(j);	/* we shouldn't have a job, but just in case */
113 		return (status);
114 	}
115 
116 	/* add the job attributes to the response in a job-attributes-group */
117 	if (j != NULL) {
118 		papi_to_ipp_job_group(response, request, PAPI_ATTR_REPLACE, j);
119 		papiJobFree(j);
120 	}
121 
122 	return (status);
123 }
124