8322 nl: misleading-indentation
[unleashed/tickless.git] / usr / src / lib / print / libpapi-common / common / papi.h
blob5fcaccc58409e2ca39f18602abaa80d2cdc82ebb
1 /*
2 * CDDL HEADER START
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.
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.
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]
19 * CDDL HEADER END
23 * Copyright 2008 Sun Microsystems, Inc. All rights reserved.
24 * Use is subject to license terms.
28 #ifndef _PAPI_H
29 #define _PAPI_H
31 /* $Id: papi.h 161 2006-05-03 04:32:59Z njacobs $ */
33 #pragma ident "%Z%%M% %I% %E% SMI"
35 #include <sys/types.h>
36 #include <time.h>
37 #include <stdio.h>
39 #ifdef __cplusplus
40 extern "C" {
41 #endif
44 * Types
47 /* service related types */
48 typedef void *papi_service_t;
49 typedef void *papi_printer_t;
50 typedef void *papi_job_t;
51 typedef void *papi_stream_t;
53 typedef enum {
54 PAPI_ENCRYPT_IF_REQUESTED, /* Encrypt if requested (TLS upgrade) */
55 PAPI_ENCRYPT_NEVER, /* Never encrypt */
56 PAPI_ENCRYPT_REQUIRED, /* Encryption required (TLS upgrade) */
57 PAPI_ENCRYPT_ALWAYS /* Always encrypt (SSL) */
58 } papi_encryption_t;
60 /* attribute related types */
61 typedef enum {
62 PAPI_STRING,
63 PAPI_INTEGER,
64 PAPI_BOOLEAN,
65 PAPI_RANGE,
66 PAPI_RESOLUTION,
67 PAPI_DATETIME,
68 PAPI_COLLECTION,
69 PAPI_METADATA
70 } papi_attribute_value_type_t;
72 typedef enum {
73 PAPI_RES_PER_INCH = 3,
74 PAPI_RES_PER_CM
75 } papi_resolution_unit_t;
77 enum { /* for boolean values */
78 PAPI_FALSE = 0,
79 PAPI_TRUE = 1
82 typedef enum {
83 PAPI_UNSUPPORTED = 0x10,
84 PAPI_DEFAULT = 0x11,
85 PAPI_UNKNOWN,
86 PAPI_NO_VALUE,
87 PAPI_NOT_SETTABLE = 0x15,
88 PAPI_DELETE = 0x16
89 } papi_metadata_t;
91 #define PAPI_LIST_JOBS_OTHERS 0x0001
92 #define PAPI_LIST_JOBS_COMPLETED 0x0002
93 #define PAPI_LIST_JOBS_NOT_COMPLETED 0x0004
94 #define PAPI_LIST_JOBS_ALL 0xFFFF
96 typedef struct papi_attribute_s papi_attribute_t;
98 typedef union {
99 char *string; /* PAPI_STRING value */
100 int integer; /* PAPI_INTEGER value */
101 char boolean; /* PAPI_BOOLEAN value */
102 struct { /* PAPI_RANGE value */
103 int lower;
104 int upper;
105 } range;
106 struct { /* PAPI_RESOLUTION value */
107 int xres;
108 int yres;
109 papi_resolution_unit_t units;
110 } resolution;
111 time_t datetime; /* PAPI_DATETIME value */
112 papi_attribute_t **collection; /* PAPI_COLLECTION value */
113 papi_metadata_t metadata; /* PAPI_METADATA value */
114 } papi_attribute_value_t;
116 struct papi_attribute_s {
117 char *name; /* attribute name */
118 papi_attribute_value_type_t type; /* type of values */
119 papi_attribute_value_t **values; /* list of values */
122 #define PAPI_ATTR_APPEND 0x0001 /* Add values to attr */
123 #define PAPI_ATTR_REPLACE 0x0002 /* Delete existing values, then add */
124 #define PAPI_ATTR_EXCL 0x0004 /* Fail if attr exists */
126 /* job related types */
127 typedef enum {
128 PAPI_JT_FORMAT_JDF = 0,
129 PAPI_JT_FORMAT_PWG = 1
130 } papi_jt_format_t;
132 typedef struct {
133 papi_jt_format_t format;
134 char *ticket_data;
135 char *file_name;
136 } papi_job_ticket_t;
138 /* status related types */
139 typedef enum {
140 PAPI_OK = 0x0000,
141 PAPI_OK_SUBST,
142 PAPI_OK_CONFLICT,
143 PAPI_OK_IGNORED_SUBSCRIPTIONS,
144 PAPI_OK_IGNORED_NOTIFICATIONS,
145 PAPI_OK_TOO_MANY_EVENTS,
146 PAPI_OK_BUT_CANCEL_SUBSCRIPTION,
147 PAPI_REDIRECTION_OTHER_SITE = 0x0300,
148 PAPI_BAD_REQUEST = 0x0400,
149 PAPI_FORBIDDEN,
150 PAPI_NOT_AUTHENTICATED,
151 PAPI_NOT_AUTHORIZED,
152 PAPI_NOT_POSSIBLE,
153 PAPI_TIMEOUT,
154 PAPI_NOT_FOUND,
155 PAPI_GONE,
156 PAPI_REQUEST_ENTITY,
157 PAPI_REQUEST_VALUE,
158 PAPI_DOCUMENT_FORMAT,
159 PAPI_ATTRIBUTES,
160 PAPI_URI_SCHEME,
161 PAPI_CHARSET,
162 PAPI_CONFLICT,
163 PAPI_COMPRESSION_NOT_SUPPORTED,
164 PAPI_COMPRESSION_ERROR,
165 PAPI_DOCUMENT_FORMAT_ERROR,
166 PAPI_DOCUMENT_ACCESS_ERROR,
167 PAPI_ATTRIBUTES_NOT_SETTABLE,
168 PAPI_IGNORED_ALL_SUBSCRIPTIONS,
169 PAPI_TOO_MANY_SUBSCRIPTIONS,
170 PAPI_IGNORED_ALL_NOTIFICATIONS,
171 PAPI_PRINT_SUPPORT_FILE_NOT_FOUND,
172 PAPI_INTERNAL_ERROR = 0x0500,
173 PAPI_OPERATION_NOT_SUPPORTED,
174 PAPI_SERVICE_UNAVAILABLE,
175 PAPI_VERSION_NOT_SUPPORTED,
176 PAPI_DEVICE_ERROR,
177 PAPI_TEMPORARY_ERROR,
178 PAPI_NOT_ACCEPTING,
179 PAPI_PRINTER_BUSY,
180 PAPI_ERROR_JOB_CANCELLED,
181 PAPI_MULTIPLE_JOBS_NOT_SUPPORTED,
182 PAPI_PRINTER_IS_DEACTIVATED,
183 PAPI_BAD_ARGUMENT,
184 PAPI_JOB_TICKET_NOT_SUPPORTED
185 } papi_status_t;
187 /* list filter related */
188 typedef enum {
189 PAPI_FILTER_BITMASK = 0
190 } papi_filter_type_t;
192 typedef struct {
193 papi_filter_type_t type;
194 union {
195 struct { /* PAPI_FILTER_BITMASK */
196 unsigned int mask;
197 unsigned int value;
198 } bitmask;
199 } filter;
200 } papi_filter_t;
202 enum {
203 PAPI_PRINTER_LOCAL = 0x0000, /* Local destination */
204 PAPI_PRINTER_CLASS = 0x0001, /* Printer class */
205 PAPI_PRINTER_REMOTE = 0x0002, /* Remote destination */
206 PAPI_PRINTER_BW = 0x0004, /* Can do B&W printing */
207 PAPI_PRINTER_COLOR = 0x0008, /* Can do color printing */
208 PAPI_PRINTER_DUPLEX = 0x0010, /* Can do duplex printing */
209 PAPI_PRINTER_STAPLE = 0x0020, /* Can do stapling */
210 PAPI_PRINTER_COPIES = 0x0040, /* Can do copies */
211 PAPI_PRINTER_COLLATE = 0x0080, /* Can collate copies */
212 PAPI_PRINTER_PUNCH = 0x0100, /* Can punch output */
213 PAPI_PRINTER_COVER = 0x0200, /* Can cover output */
214 PAPI_PRINTER_BIND = 0x0400, /* Can bind output */
215 PAPI_PRINTER_SORT = 0x0800, /* Can sort output */
216 PAPI_PRINTER_SMALL = 0x1000, /* Can do letter/legal/a4 */
217 PAPI_PRINTER_MEDIUM = 0x2000, /* Can do tabloid/B/C/A3/A2 */
218 PAPI_PRINTER_LARGE = 0x4000, /* Can do D/E/A1/A0 */
219 PAPI_PRINTER_VARIABLE = 0x8000, /* Can do variable sizes */
220 PAPI_PRINTER_IMPLICIT = 0x10000, /* implicit class */
221 PAPI_PRINTER_DEFAULT = 0x20000, /* Default printer on network */
222 PAPI_PRINTER_OPTIONS = 0xfffc /* ~ (CLASS | REMOTE | IMPLICIT) */
226 * Functions
229 /* Service related */
230 extern papi_status_t papiServiceCreate(papi_service_t *handle,
231 char *service_name, char *user_name,
232 char *password,
233 int (*authCB)(papi_service_t svc,
234 void *app_data),
235 papi_encryption_t encryption,
236 void *app_data);
237 extern void papiServiceDestroy(papi_service_t handle);
238 extern papi_status_t papiServiceSetUserName(papi_service_t handle,
239 char *user_name);
240 extern papi_status_t papiServiceSetPassword(papi_service_t handle,
241 char *password);
242 extern papi_status_t papiServiceSetEncryption(papi_service_t handle,
243 papi_encryption_t encryption);
244 extern papi_status_t papiServiceSetAuthCB(papi_service_t handle,
245 int (*authCB)(papi_service_t s,
246 void *app_data));
247 extern papi_status_t papiServiceSetAppData(papi_service_t handle,
248 void *app_data);
249 extern char *papiServiceGetServiceName(papi_service_t handle);
250 extern char *papiServiceGetUserName(papi_service_t handle);
251 extern char *papiServiceGetPassword(papi_service_t handle);
252 extern papi_encryption_t papiServiceGetEncryption(papi_service_t handle);
253 extern void *papiServiceGetAppData(papi_service_t handle);
254 extern papi_attribute_t **papiServiceGetAttributeList(papi_service_t handle);
255 extern char *papiServiceGetStatusMessage(papi_service_t handle);
257 /* Attribute related */
258 extern papi_status_t papiAttributeListAddValue(papi_attribute_t ***attrs,
259 int flags, char *name,
260 papi_attribute_value_type_t type,
261 papi_attribute_value_t *value);
262 extern papi_status_t papiAttributeListAddString(papi_attribute_t ***attrs,
263 int flags, char *name, char *string);
264 extern papi_status_t papiAttributeListAddInteger(papi_attribute_t ***attrs,
265 int flags, char *name, int integer);
266 extern papi_status_t papiAttributeListAddBoolean(papi_attribute_t ***attrs,
267 int flags, char *name, char boolean);
268 extern papi_status_t papiAttributeListAddRange(papi_attribute_t ***attrs,
269 int flags, char *name,
270 int lower, int upper);
271 extern papi_status_t papiAttributeListAddResolution(papi_attribute_t ***attrs,
272 int flags, char *name,
273 int xres, int yres,
274 papi_resolution_unit_t units);
275 extern papi_status_t papiAttributeListAddDatetime(papi_attribute_t ***attrs,
276 int flags, char *name, time_t datetime);
277 extern papi_status_t papiAttributeListAddCollection(papi_attribute_t ***attrs,
278 int flags, char *name,
279 papi_attribute_t **collection);
280 extern papi_status_t papiAttributeListAddMetadata(papi_attribute_t ***attrs,
281 int flags, char *name,
282 papi_metadata_t metadata);
283 extern papi_status_t papiAttributeListDelete(papi_attribute_t ***attributes,
284 char *name);
285 extern papi_status_t papiAttributeListGetValue(papi_attribute_t **list,
286 void **iterator, char *name,
287 papi_attribute_value_type_t type,
288 papi_attribute_value_t **value);
289 extern papi_status_t papiAttributeListGetString(papi_attribute_t **list,
290 void **iterator, char *name,
291 char **vptr);
292 extern papi_status_t papiAttributeListGetInteger(papi_attribute_t **list,
293 void **iterator, char *name, int *vptr);
294 extern papi_status_t papiAttributeListGetBoolean(papi_attribute_t **list,
295 void **iterator, char *name,
296 char *vptr);
297 extern papi_status_t papiAttributeListGetRange(papi_attribute_t **list,
298 void **iterator, char *name,
299 int *min, int *max);
300 extern papi_status_t papiAttributeListGetResolution(papi_attribute_t **list,
301 void **iterator, char *name,
302 int *x, int *y,
303 papi_resolution_unit_t *units);
304 extern papi_status_t papiAttributeListGetDatetime(papi_attribute_t **list,
305 void **iterator, char *name,
306 time_t *dt);
307 extern papi_status_t papiAttributeListGetCollection(papi_attribute_t **list,
308 void **iterator, char *name,
309 papi_attribute_t ***collection);
310 extern papi_status_t papiAttributeListGetMetadata(papi_attribute_t **list,
311 void **iterator, char *name,
312 papi_metadata_t *vptr);
313 extern papi_attribute_t *papiAttributeListFind(papi_attribute_t **list,
314 char *name);
315 extern papi_attribute_t *papiAttributeListGetNext(papi_attribute_t **list,
316 void **iterator);
317 extern void papiAttributeListFree(papi_attribute_t **attributes);
319 extern papi_status_t papiAttributeListFromString(papi_attribute_t ***attrs,
320 int flags, char *string);
321 extern papi_status_t papiAttributeListToString(papi_attribute_t **attrs,
322 char *delim,
323 char *buffer, size_t buflen);
324 extern void papiAttributeListPrint(FILE *fp, papi_attribute_t **list,
325 char *prefix_fmt, ...);
327 /* Printer related */
328 extern papi_status_t papiPrintersList(papi_service_t handle,
329 char **requested_attrs,
330 papi_filter_t *filter,
331 papi_printer_t **printers);
332 extern papi_status_t papiPrinterQuery(papi_service_t handle, char *name,
333 char **requested_attrs,
334 papi_attribute_t **job_attributes,
335 papi_printer_t *printer);
336 extern papi_status_t papiPrinterAdd(papi_service_t handle, char *name,
337 papi_attribute_t **attributes,
338 papi_printer_t *printer);
339 extern papi_status_t papiPrinterModify(papi_service_t handle, char *name,
340 papi_attribute_t **attributes,
341 papi_printer_t *printer);
342 extern papi_status_t papiPrinterRemove(papi_service_t handle, char *name);
343 extern papi_status_t papiPrinterDisable(papi_service_t handle, char *name,
344 char *message);
345 extern papi_status_t papiPrinterEnable(papi_service_t handle, char *name);
346 extern papi_status_t papiPrinterPause(papi_service_t handle, char *name,
347 char *message);
348 extern papi_status_t papiPrinterResume(papi_service_t handle, char *name);
349 extern papi_status_t papiPrinterPurgeJobs(papi_service_t handle,
350 char *name, papi_job_t **jobs);
351 extern papi_status_t papiPrinterListJobs(papi_service_t handle,
352 char *name, char **requested_attrs,
353 int type_mask, int max_num_jobs,
354 papi_job_t **jobs);
355 extern papi_attribute_t **papiPrinterGetAttributeList(papi_printer_t printer);
356 extern void papiPrinterFree(papi_printer_t printer);
357 extern void papiPrinterListFree(papi_printer_t *printers);
359 /* Job related */
360 extern papi_status_t papiJobSubmit(papi_service_t handle, char *printer,
361 papi_attribute_t **job_attributes,
362 papi_job_ticket_t *job_ticket,
363 char **files, papi_job_t *job);
364 extern papi_status_t papiJobSubmitByReference(papi_service_t handle,
365 char *printer,
366 papi_attribute_t **job_attributes,
367 papi_job_ticket_t *job_ticket,
368 char **files, papi_job_t *job);
369 extern papi_status_t papiJobValidate(papi_service_t handle, char *printer,
370 papi_attribute_t **job_attributes,
371 papi_job_ticket_t *job_ticket,
372 char **files, papi_job_t *job);
373 extern papi_status_t papiJobStreamOpen(papi_service_t handle,
374 char *printer,
375 papi_attribute_t **job_attributes,
376 papi_job_ticket_t *job_ticket,
377 papi_stream_t *stream);
378 extern papi_status_t papiJobStreamWrite(papi_service_t handle,
379 papi_stream_t stream,
380 void *buffer, size_t buflen);
381 extern papi_status_t papiJobStreamClose(papi_service_t handle,
382 papi_stream_t stream,
383 papi_job_t *job);
384 extern papi_status_t papiJobQuery(papi_service_t handle, char *printer,
385 int32_t job_id, char **requested_attrs,
386 papi_job_t *job);
387 extern papi_status_t papiJobModify(papi_service_t handle, char *printer,
388 int32_t job_id,
389 papi_attribute_t **attributes,
390 papi_job_t *job);
391 extern papi_status_t papiJobMove(papi_service_t handle, char *printer,
392 int32_t job_id, char *destination);
393 extern papi_status_t papiJobCancel(papi_service_t handle, char *printer,
394 int32_t job_id);
395 extern papi_status_t papiJobHold(papi_service_t handle, char *printer,
396 int32_t job_id);
397 extern papi_status_t papiJobRelease(papi_service_t handle, char *printer,
398 int32_t job_id);
399 extern papi_status_t papiJobRestart(papi_service_t handle, char *printer,
400 int32_t job_id);
401 extern papi_status_t papiJobPromote(papi_service_t handle, char *printer,
402 int32_t job_id);
403 extern papi_attribute_t **papiJobGetAttributeList(papi_job_t printer);
404 extern char *papiJobGetPrinterName(papi_job_t printer);
405 extern int32_t papiJobGetId(papi_job_t printer);
406 extern papi_job_ticket_t *papiJobGetJobTicket(papi_job_t printer);
407 extern void papiJobFree(papi_job_t job);
408 extern void papiJobListFree(papi_job_t *jobs);
410 #ifdef SOLARIS_PRIVATE_POST_0_9
412 * These have been added to support IPP create-job/send-document with PAPI v0.9
413 * in an IPP listener using PAPI as it's spooler interface. A future version
414 * of the API is expected to support this type of functionality
416 extern papi_status_t papiJobCreate(papi_service_t handle, char *printer,
417 papi_attribute_t **job_attributes,
418 papi_job_ticket_t *job_ticket,
419 papi_job_t *job);
420 extern papi_status_t papiJobStreamAdd(papi_service_t handle, char *printer,
421 int32_t id, papi_stream_t *stream);
422 extern papi_status_t papiJobCommit(papi_service_t handle, char *printer,
423 int32_t id);
424 extern papi_status_t papiServiceSetPeer(papi_service_t handle, int peerfd);
425 #endif /* SOLARIS_PRIVATE_POST_0_9 */
427 extern char *papiStatusString(papi_status_t status);
430 * Internal functions that aren't in the API, but are shared across
431 * protocol support implementations(psms) and the tightly bound
432 * listener library. Do not use these in your applications.
434 extern void list_append();
435 extern void list_concatenate();
436 extern void list_remove();
437 extern void copy_attributes(papi_attribute_t ***result,
438 papi_attribute_t **list);
439 extern void split_and_copy_attributes(char **list,
440 papi_attribute_t **attributes,
441 papi_attribute_t ***in,
442 papi_attribute_t ***out);
444 extern papi_attribute_t **getprinterbyname(char *name, char *ns);
446 extern int is_localhost(char *hostname);
448 #ifdef __cplusplus
450 #endif
452 #endif /* _PAPI_H */