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