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: set-printer-attributes.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 36 ipp_set_printer_attributes(papi_service_t svc, papi_attribute_t **request, 37 papi_attribute_t ***response, ipp_reader_t iread, void *fd) 38 { 39 papi_status_t status; 40 papi_printer_t p = NULL; 41 papi_attribute_t **operational = NULL; 42 papi_attribute_t **printer_attributes = NULL; 43 44 char *queue = NULL; 45 46 /* Get operational attributes from the request */ 47 (void) papiAttributeListGetCollection(request, NULL, 48 "operational-attributes-group", &operational); 49 50 /* 51 * The operational-attributes-group must contain: 52 * printer-uri 53 */ 54 get_printer_id(operational, &queue, NULL); 55 if (queue == NULL) { 56 ipp_set_status(response, PAPI_BAD_REQUEST, 57 "missing printer-uri or job-uri"); 58 return (PAPI_BAD_REQUEST); 59 } 60 61 /* get the printer-attributes-group attributes for the PAPI call */ 62 papiAttributeListGetCollection(request, NULL, 63 "printer-attributes-group", &printer_attributes); 64 65 /* request job modification */ 66 status = papiPrinterModify(svc, queue, printer_attributes, &p); 67 if (status != PAPI_OK) { 68 ipp_set_status(response, status, "printer modification: %s", 69 ipp_svc_status_mesg(svc, status)); 70 return (status); 71 } 72 73 /* add the job attributes to the response in a job-attributes-group */ 74 if (p != NULL) { 75 papi_to_ipp_printer_group(response, request, 76 PAPI_ATTR_REPLACE, p); 77 papiPrinterFree(p); 78 } 79 80 return (status); 81 } 82