]> git.ipfire.org Git - thirdparty/cups.git/blob - cups/ipp.h
Update all references to OS X to macOS.
[thirdparty/cups.git] / cups / ipp.h
1 /*
2 * Internet Printing Protocol definitions for CUPS.
3 *
4 * Copyright 2007-2014 by Apple Inc.
5 * Copyright 1997-2006 by Easy Software Products.
6 *
7 * These coded instructions, statements, and computer programs are the
8 * property of Apple Inc. and are protected by Federal copyright
9 * law. Distribution and use rights are outlined in the file "LICENSE.txt"
10 * which should have been included with this file. If this file is
11 * file is missing or damaged, see the license at "http://www.cups.org/".
12 *
13 * This file is subject to the Apple OS-Developed Software exception.
14 */
15
16 #ifndef _CUPS_IPP_H_
17 # define _CUPS_IPP_H_
18
19 /*
20 * Include necessary headers...
21 */
22
23 # include "http.h"
24 # include <stdarg.h>
25
26
27 /*
28 * C++ magic...
29 */
30
31 # ifdef __cplusplus
32 extern "C" {
33 # endif /* __cplusplus */
34
35
36 /*
37 * IPP version string...
38 */
39
40 # define IPP_VERSION "\002\001"
41
42 /*
43 * IPP registered port number...
44 *
45 * Note: Applications should never use IPP_PORT, but instead use the
46 * ippPort() function to allow overrides via the IPP_PORT environment
47 * variable and services file if needed!
48 */
49
50 # define IPP_PORT 631
51
52 /*
53 * Common limits...
54 */
55
56 # define IPP_MAX_CHARSET 64 /* Maximum length of charset values w/nul */
57 # define IPP_MAX_KEYWORD 256 /* Maximum length of keyword values w/nul */
58 # define IPP_MAX_LANGUAGE 64 /* Maximum length of naturalLanguage values w/nul */
59 # define IPP_MAX_LENGTH 32767 /* Maximum size of any single value */
60 # define IPP_MAX_MIMETYPE 256 /* Maximum length of mimeMediaType values w/nul */
61 # define IPP_MAX_NAME 256 /* Maximum length of common name values w/nul */
62 # define IPP_MAX_OCTETSTRING 1023 /* Maximum length of octetString values w/o nul */
63 # define IPP_MAX_TEXT 1024 /* Maximum length of text values w/nul */
64 # define IPP_MAX_URI 1024 /* Maximum length of uri values w/nul */
65 # define IPP_MAX_URISCHEME 64 /* Maximum length of uriScheme values w/nul */
66 # define IPP_MAX_VALUES 8 /* Power-of-2 allocation increment */
67
68 /*
69 * Macro to flag a text string attribute as "const" (static storage) vs.
70 * allocated.
71 */
72
73 # define IPP_CONST_TAG(x) (ipp_tag_t)(IPP_TAG_CUPS_CONST | (x))
74
75
76 /*
77 * Types and structures...
78 */
79
80 typedef enum ipp_dstate_e /**** Document states ****/
81 {
82 IPP_DOCUMENT_PENDING = 3, /* Document is pending */
83 IPP_DOCUMENT_PROCESSING = 5, /* Document is processing */
84 IPP_DOCUMENT_CANCELED = 7, /* Document is canceled */
85 IPP_DOCUMENT_ABORTED, /* Document is aborted */
86 IPP_DOCUMENT_COMPLETED /* Document is completed */
87
88 # ifndef _CUPS_NO_DEPRECATED
89 # define IPP_DOCUMENT_PENDING IPP_DSTATE_PENDING
90 # define IPP_DOCUMENT_PROCESSING IPP_DSTATE_PROCESSING
91 # define IPP_DOCUMENT_CANCELED IPP_DSTATE_CANCELED
92 # define IPP_DOCUMENT_ABORTED IPP_DSTATE_ABORTED
93 # define IPP_DOCUMENT_COMPLETED IPP_DSTATE_COMPLETED
94 # endif /* !_CUPS_NO_DEPRECATED */
95 } ipp_dstate_t;
96
97 typedef enum ipp_finishings_e /**** Finishings ****/
98 {
99 IPP_FINISHINGS_NONE = 3, /* No finishing */
100 IPP_FINISHINGS_STAPLE, /* Staple (any location) */
101 IPP_FINISHINGS_PUNCH, /* Punch (any location/count) */
102 IPP_FINISHINGS_COVER, /* Add cover */
103 IPP_FINISHINGS_BIND, /* Bind */
104 IPP_FINISHINGS_SADDLE_STITCH, /* Staple interior */
105 IPP_FINISHINGS_EDGE_STITCH, /* Stitch along any side */
106 IPP_FINISHINGS_FOLD, /* Fold (any type) */
107 IPP_FINISHINGS_TRIM, /* Trim (any type) */
108 IPP_FINISHINGS_BALE, /* Bale (any type) */
109 IPP_FINISHINGS_BOOKLET_MAKER, /* Fold to make booklet */
110 IPP_FINISHINGS_JOG_OFFSET, /* Offset for binding (any type) */
111 IPP_FINISHINGS_COAT, /* Apply protective liquid or powder coating */
112 IPP_FINISHINGS_LAMINATE, /* Apply protective (solid) material */
113 IPP_FINISHINGS_STAPLE_TOP_LEFT = 20, /* Staple top left corner */
114 IPP_FINISHINGS_STAPLE_BOTTOM_LEFT, /* Staple bottom left corner */
115 IPP_FINISHINGS_STAPLE_TOP_RIGHT, /* Staple top right corner */
116 IPP_FINISHINGS_STAPLE_BOTTOM_RIGHT, /* Staple bottom right corner */
117 IPP_FINISHINGS_EDGE_STITCH_LEFT, /* Stitch along left side */
118 IPP_FINISHINGS_EDGE_STITCH_TOP, /* Stitch along top edge */
119 IPP_FINISHINGS_EDGE_STITCH_RIGHT, /* Stitch along right side */
120 IPP_FINISHINGS_EDGE_STITCH_BOTTOM, /* Stitch along bottom edge */
121 IPP_FINISHINGS_STAPLE_DUAL_LEFT, /* Two staples on left */
122 IPP_FINISHINGS_STAPLE_DUAL_TOP, /* Two staples on top */
123 IPP_FINISHINGS_STAPLE_DUAL_RIGHT, /* Two staples on right */
124 IPP_FINISHINGS_STAPLE_DUAL_BOTTOM, /* Two staples on bottom */
125 IPP_FINISHINGS_STAPLE_TRIPLE_LEFT, /* Three staples on left */
126 IPP_FINISHINGS_STAPLE_TRIPLE_TOP, /* Three staples on top */
127 IPP_FINISHINGS_STAPLE_TRIPLE_RIGHT, /* Three staples on right */
128 IPP_FINISHINGS_STAPLE_TRIPLE_BOTTOM, /* Three staples on bottom */
129 IPP_FINISHINGS_BIND_LEFT = 50, /* Bind on left */
130 IPP_FINISHINGS_BIND_TOP, /* Bind on top */
131 IPP_FINISHINGS_BIND_RIGHT, /* Bind on right */
132 IPP_FINISHINGS_BIND_BOTTOM, /* Bind on bottom */
133 IPP_FINISHINGS_TRIM_AFTER_PAGES = 60, /* Trim output after each page */
134 IPP_FINISHINGS_TRIM_AFTER_DOCUMENTS, /* Trim output after each document */
135 IPP_FINISHINGS_TRIM_AFTER_COPIES, /* Trim output after each copy */
136 IPP_FINISHINGS_TRIM_AFTER_JOB, /* Trim output after job */
137 IPP_FINISHINGS_PUNCH_TOP_LEFT = 70, /* Punch 1 hole top left */
138 IPP_FINISHINGS_PUNCH_BOTTOM_LEFT, /* Punch 1 hole bottom left */
139 IPP_FINISHINGS_PUNCH_TOP_RIGHT, /* Punch 1 hole top right */
140 IPP_FINISHINGS_PUNCH_BOTTOM_RIGHT, /* Punch 1 hole bottom right */
141 IPP_FINISHINGS_PUNCH_DUAL_LEFT, /* Punch 2 holes left side */
142 IPP_FINISHINGS_PUNCH_DUAL_TOP, /* Punch 2 holes top edge */
143 IPP_FINISHINGS_PUNCH_DUAL_RIGHT, /* Punch 2 holes right side */
144 IPP_FINISHINGS_PUNCH_DUAL_BOTTOM, /* Punch 2 holes bottom edge */
145 IPP_FINISHINGS_PUNCH_TRIPLE_LEFT, /* Punch 3 holes left side */
146 IPP_FINISHINGS_PUNCH_TRIPLE_TOP, /* Punch 3 holes top edge */
147 IPP_FINISHINGS_PUNCH_TRIPLE_RIGHT, /* Punch 3 holes right side */
148 IPP_FINISHINGS_PUNCH_TRIPLE_BOTTOM, /* Punch 3 holes bottom edge */
149 IPP_FINISHINGS_PUNCH_QUAD_LEFT, /* Punch 4 holes left side */
150 IPP_FINISHINGS_PUNCH_QUAD_TOP, /* Punch 4 holes top edge */
151 IPP_FINISHINGS_PUNCH_QUAD_RIGHT, /* Punch 4 holes right side */
152 IPP_FINISHINGS_PUNCH_QUAD_BOTTOM, /* Punch 4 holes bottom edge */
153 IPP_FINISHINGS_FOLD_ACCORDIAN = 90, /* Accordian-fold the paper vertically into four sections */
154 IPP_FINISHINGS_FOLD_DOUBLE_GATE, /* Fold the top and bottom quarters of the paper towards the midline, then fold in half vertically */
155 IPP_FINISHINGS_FOLD_GATE, /* Fold the top and bottom quarters of the paper towards the midline */
156 IPP_FINISHINGS_FOLD_HALF, /* Fold the paper in half vertically */
157 IPP_FINISHINGS_FOLD_HALF_Z, /* Fold the paper in half horizontally, then Z-fold the paper vertically */
158 IPP_FINISHINGS_FOLD_LEFT_GATE, /* Fold the top quarter of the paper towards the midline */
159 IPP_FINISHINGS_FOLD_LETTER, /* Fold the paper into three sections vertically; sometimes also known as a C fold*/
160 IPP_FINISHINGS_FOLD_PARALLEL, /* Fold the paper in half vertically two times, yielding four sections */
161 IPP_FINISHINGS_FOLD_POSTER, /* Fold the paper in half horizontally and vertically; sometimes also called a cross fold */
162 IPP_FINISHINGS_FOLD_RIGHT_GATE, /* Fold the bottom quarter of the paper towards the midline */
163 IPP_FINISHINGS_FOLD_Z, /* Fold the paper vertically into three sections, forming a Z */
164
165 /* CUPS extensions for finishings (pre-standard versions of values above) */
166 IPP_FINISHINGS_CUPS_PUNCH_TOP_LEFT = 0x40000046,
167 /* Punch 1 hole top left */
168 IPP_FINISHINGS_CUPS_PUNCH_BOTTOM_LEFT,/* Punch 1 hole bottom left */
169 IPP_FINISHINGS_CUPS_PUNCH_TOP_RIGHT, /* Punch 1 hole top right */
170 IPP_FINISHINGS_CUPS_PUNCH_BOTTOM_RIGHT,
171 /* Punch 1 hole bottom right */
172 IPP_FINISHINGS_CUPS_PUNCH_DUAL_LEFT, /* Punch 2 holes left side */
173 IPP_FINISHINGS_CUPS_PUNCH_DUAL_TOP, /* Punch 2 holes top edge */
174 IPP_FINISHINGS_CUPS_PUNCH_DUAL_RIGHT, /* Punch 2 holes right side */
175 IPP_FINISHINGS_CUPS_PUNCH_DUAL_BOTTOM,/* Punch 2 holes bottom edge */
176 IPP_FINISHINGS_CUPS_PUNCH_TRIPLE_LEFT,/* Punch 3 holes left side */
177 IPP_FINISHINGS_CUPS_PUNCH_TRIPLE_TOP, /* Punch 3 holes top edge */
178 IPP_FINISHINGS_CUPS_PUNCH_TRIPLE_RIGHT,
179 /* Punch 3 holes right side */
180 IPP_FINISHINGS_CUPS_PUNCH_TRIPLE_BOTTOM,
181 /* Punch 3 holes bottom edge */
182 IPP_FINISHINGS_CUPS_PUNCH_QUAD_LEFT, /* Punch 4 holes left side */
183 IPP_FINISHINGS_CUPS_PUNCH_QUAD_TOP, /* Punch 4 holes top edge */
184 IPP_FINISHINGS_CUPS_PUNCH_QUAD_RIGHT, /* Punch 4 holes right side */
185 IPP_FINISHINGS_CUPS_PUNCH_QUAD_BOTTOM,/* Punch 4 holes bottom edge */
186
187 IPP_FINISHINGS_CUPS_FOLD_ACCORDIAN = 0x4000005A,
188 /* Accordian-fold the paper vertically into four sections */
189 IPP_FINISHINGS_CUPS_FOLD_DOUBLE_GATE, /* Fold the top and bottom quarters of the paper towards the midline, then fold in half vertically */
190 IPP_FINISHINGS_CUPS_FOLD_GATE, /* Fold the top and bottom quarters of the paper towards the midline */
191 IPP_FINISHINGS_CUPS_FOLD_HALF, /* Fold the paper in half vertically */
192 IPP_FINISHINGS_CUPS_FOLD_HALF_Z, /* Fold the paper in half horizontally, then Z-fold the paper vertically */
193 IPP_FINISHINGS_CUPS_FOLD_LEFT_GATE, /* Fold the top quarter of the paper towards the midline */
194 IPP_FINISHINGS_CUPS_FOLD_LETTER, /* Fold the paper into three sections vertically; sometimes also known as a C fold*/
195 IPP_FINISHINGS_CUPS_FOLD_PARALLEL, /* Fold the paper in half vertically two times, yielding four sections */
196 IPP_FINISHINGS_CUPS_FOLD_POSTER, /* Fold the paper in half horizontally and vertically; sometimes also called a cross fold */
197 IPP_FINISHINGS_CUPS_FOLD_RIGHT_GATE, /* Fold the bottom quarter of the paper towards the midline */
198 IPP_FINISHINGS_CUPS_FOLD_Z /* Fold the paper vertically into three sections, forming a Z */
199 } ipp_finishings_t;
200 # ifndef _CUPS_NO_DEPRECATED
201 # define IPP_FINISHINGS_JOB_OFFSET IPP_FINISHINGS_JOG_OFFSET
202 /* Long-time misspelling... */
203 typedef enum ipp_finishings_e ipp_finish_t;
204 # endif /* !_CUPS_NO_DEPRECATED */
205
206 typedef enum ipp_jcollate_e /**** Job collation types ****/
207 {
208 IPP_JCOLLATE_UNCOLLATED_SHEETS = 3,
209 IPP_JCOLLATE_COLLATED_DOCUMENTS,
210 IPP_JCOLLATE_UNCOLLATED_DOCUMENTS
211
212 # ifndef _CUPS_NO_DEPRECATED
213 # define IPP_JOB_UNCOLLATED_SHEETS IPP_JCOLLATE_UNCOLLATED_SHEETS
214 # define IPP_JOB_COLLATED_DOCUMENTS IPP_JCOLLATE_COLLATED_DOCUMENTS
215 # define IPP_JOB_UNCOLLATED_DOCUMENTS IPP_JCOLLATE_UNCOLLATED_DOCUMENTS
216 # endif /* !_CUPS_NO_DEPRECATED */
217 } ipp_jcollate_t;
218
219 typedef enum ipp_jstate_e /**** Job states ****/
220 {
221 IPP_JSTATE_PENDING = 3, /* Job is waiting to be printed */
222 IPP_JSTATE_HELD, /* Job is held for printing */
223 IPP_JSTATE_PROCESSING, /* Job is currently printing */
224 IPP_JSTATE_STOPPED, /* Job has been stopped */
225 IPP_JSTATE_CANCELED, /* Job has been canceled */
226 IPP_JSTATE_ABORTED, /* Job has aborted due to error */
227 IPP_JSTATE_COMPLETED /* Job has completed successfully */
228
229 # ifndef _CUPS_NO_DEPRECATED
230 # define IPP_JOB_PENDING IPP_JSTATE_PENDING
231 # define IPP_JOB_HELD IPP_JSTATE_HELD
232 # define IPP_JOB_PROCESSING IPP_JSTATE_PROCESSING
233 # define IPP_JOB_STOPPED IPP_JSTATE_STOPPED
234 # define IPP_JOB_CANCELED IPP_JSTATE_CANCELED
235 # define IPP_JOB_ABORTED IPP_JSTATE_ABORTED
236 # define IPP_JOB_COMPLETED IPP_JSTATE_COMPLETED
237 /* Legacy name for canceled state */
238 # define IPP_JOB_CANCELLED IPP_JSTATE_CANCELED
239 # endif /* !_CUPS_NO_DEPRECATED */
240 } ipp_jstate_t;
241
242 typedef enum ipp_op_e /**** IPP operations ****/
243 {
244 IPP_OP_CUPS_INVALID = -1, /* Invalid operation name for @link ippOpValue@ */
245 IPP_OP_CUPS_NONE = 0, /* No operation @private@ */
246 IPP_OP_PRINT_JOB = 0x0002, /* Print a single file */
247 IPP_OP_PRINT_URI, /* Print a single URL */
248 IPP_OP_VALIDATE_JOB, /* Validate job options */
249 IPP_OP_CREATE_JOB, /* Create an empty print job */
250 IPP_OP_SEND_DOCUMENT, /* Add a file to a job */
251 IPP_OP_SEND_URI, /* Add a URL to a job */
252 IPP_OP_CANCEL_JOB, /* Cancel a job */
253 IPP_OP_GET_JOB_ATTRIBUTES, /* Get job attributes */
254 IPP_OP_GET_JOBS, /* Get a list of jobs */
255 IPP_OP_GET_PRINTER_ATTRIBUTES, /* Get printer attributes */
256 IPP_OP_HOLD_JOB, /* Hold a job for printing */
257 IPP_OP_RELEASE_JOB, /* Release a job for printing */
258 IPP_OP_RESTART_JOB, /* Reprint a job */
259 IPP_OP_PAUSE_PRINTER = 0x0010, /* Stop a printer */
260 IPP_OP_RESUME_PRINTER, /* Start a printer */
261 IPP_OP_PURGE_JOBS, /* Cancel all jobs */
262 IPP_OP_SET_PRINTER_ATTRIBUTES, /* Set printer attributes */
263 IPP_OP_SET_JOB_ATTRIBUTES, /* Set job attributes */
264 IPP_OP_GET_PRINTER_SUPPORTED_VALUES, /* Get supported attribute values */
265 IPP_OP_CREATE_PRINTER_SUBSCRIPTIONS, /* Create one or more printer subscriptions @since CUPS 1.2/macOS 10.5@ */
266 IPP_OP_CREATE_JOB_SUBSCRIPTIONS, /* Create one of more job subscriptions @since CUPS 1.2/macOS 10.5@ */
267 IPP_OP_GET_SUBSCRIPTION_ATTRIBUTES, /* Get subscription attributes @since CUPS 1.2/macOS 10.5@ */
268 IPP_OP_GET_SUBSCRIPTIONS, /* Get list of subscriptions @since CUPS 1.2/macOS 10.5@ */
269 IPP_OP_RENEW_SUBSCRIPTION, /* Renew a printer subscription @since CUPS 1.2/macOS 10.5@ */
270 IPP_OP_CANCEL_SUBSCRIPTION, /* Cancel a subscription @since CUPS 1.2/macOS 10.5@ */
271 IPP_OP_GET_NOTIFICATIONS, /* Get notification events @since CUPS 1.2/macOS 10.5@ */
272 IPP_OP_SEND_NOTIFICATIONS, /* Send notification events @private@ */
273 IPP_OP_GET_RESOURCE_ATTRIBUTES, /* Get resource attributes @private@ */
274 IPP_OP_GET_RESOURCE_DATA, /* Get resource data @private@ */
275 IPP_OP_GET_RESOURCES, /* Get list of resources @private@ */
276 IPP_OP_GET_PRINT_SUPPORT_FILES, /* Get printer support files @private@ */
277 IPP_OP_ENABLE_PRINTER, /* Start a printer */
278 IPP_OP_DISABLE_PRINTER, /* Stop a printer */
279 IPP_OP_PAUSE_PRINTER_AFTER_CURRENT_JOB,
280 /* Stop printer after the current job */
281 IPP_OP_HOLD_NEW_JOBS, /* Hold new jobs */
282 IPP_OP_RELEASE_HELD_NEW_JOBS, /* Release new jobs */
283 IPP_OP_DEACTIVATE_PRINTER, /* Stop a printer */
284 IPP_OP_ACTIVATE_PRINTER, /* Start a printer */
285 IPP_OP_RESTART_PRINTER, /* Restart a printer */
286 IPP_OP_SHUTDOWN_PRINTER, /* Turn a printer off */
287 IPP_OP_STARTUP_PRINTER, /* Turn a printer on */
288 IPP_OP_REPROCESS_JOB, /* Reprint a job */
289 IPP_OP_CANCEL_CURRENT_JOB, /* Cancel the current job */
290 IPP_OP_SUSPEND_CURRENT_JOB, /* Suspend the current job */
291 IPP_OP_RESUME_JOB, /* Resume the current job */
292 IPP_OP_PROMOTE_JOB, /* Promote a job to print sooner */
293 IPP_OP_SCHEDULE_JOB_AFTER, /* Schedule a job to print after another */
294 IPP_OP_CANCEL_DOCUMENT = 0x0033, /* Cancel-Document */
295 IPP_OP_GET_DOCUMENT_ATTRIBUTES, /* Get-Document-Attributes */
296 IPP_OP_GET_DOCUMENTS, /* Get-Documents */
297 IPP_OP_DELETE_DOCUMENT, /* Delete-Document */
298 IPP_OP_SET_DOCUMENT_ATTRIBUTES, /* Set-Document-Attributes */
299 IPP_OP_CANCEL_JOBS, /* Cancel-Jobs */
300 IPP_OP_CANCEL_MY_JOBS, /* Cancel-My-Jobs */
301 IPP_OP_RESUBMIT_JOB, /* Resubmit-Job */
302 IPP_OP_CLOSE_JOB, /* Close-Job */
303 IPP_OP_IDENTIFY_PRINTER, /* Identify-Printer */
304 IPP_OP_VALIDATE_DOCUMENT, /* Validate-Document */
305 IPP_OP_SEND_HARDCOPY_DOCUMENT, /* Send-Hardcopy-Document */
306 IPP_OP_ACKNOWLEDGE_DOCUMENT, /* Acknowledge-Document */
307 IPP_OP_ACKNOWLEDGE_IDENTIFY_PRINTER, /* Acknowledge-Identify-Printer */
308 IPP_OP_ACKNOWLEDGE_JOB, /* Acknowledge-Job */
309 IPP_OP_FETCH_DOCUMENT, /* Fetch-Document */
310 IPP_OP_FETCH_JOB, /* Fetch-Job */
311 IPP_OP_GET_OUTPUT_DEVICE_ATTRIBUTES, /* Get-Output-Device-Attributes */
312 IPP_OP_UPDATE_ACTIVE_JOBS, /* Update-Active-Jobs */
313 IPP_OP_DEREGISTER_OUTPUT_DEVICE, /* Deregister-Output-Device */
314 IPP_OP_UPDATE_DOCUMENT_STATUS, /* Update-Document-Status */
315 IPP_OP_UPDATE_JOB_STATUS, /* Update-Job-Status */
316 IPP_OP_UPDATE_OUTPUT_DEVICE_ATTRIBUTES,
317 /* Update-Output-Device-Attributes */
318 IPP_OP_GET_NEXT_DOCUMENT_DATA, /* Get-Next-Document-Data */
319
320 IPP_OP_PRIVATE = 0x4000, /* Reserved @private@ */
321 IPP_OP_CUPS_GET_DEFAULT, /* Get the default printer */
322 IPP_OP_CUPS_GET_PRINTERS, /* Get a list of printers and/or classes */
323 IPP_OP_CUPS_ADD_MODIFY_PRINTER, /* Add or modify a printer */
324 IPP_OP_CUPS_DELETE_PRINTER, /* Delete a printer */
325 IPP_OP_CUPS_GET_CLASSES, /* Get a list of classes @deprecated@ */
326 IPP_OP_CUPS_ADD_MODIFY_CLASS, /* Add or modify a class */
327 IPP_OP_CUPS_DELETE_CLASS, /* Delete a class */
328 IPP_OP_CUPS_ACCEPT_JOBS, /* Accept new jobs on a printer */
329 IPP_OP_CUPS_REJECT_JOBS, /* Reject new jobs on a printer */
330 IPP_OP_CUPS_SET_DEFAULT, /* Set the default printer */
331 IPP_OP_CUPS_GET_DEVICES, /* Get a list of supported devices @deprecated@ */
332 IPP_OP_CUPS_GET_PPDS, /* Get a list of supported drivers @deprecated@ */
333 IPP_OP_CUPS_MOVE_JOB, /* Move a job to a different printer */
334 IPP_OP_CUPS_AUTHENTICATE_JOB, /* Authenticate a job @since CUPS 1.2/macOS 10.5@ */
335 IPP_OP_CUPS_GET_PPD, /* Get a PPD file @deprecated@ */
336 IPP_OP_CUPS_GET_DOCUMENT = 0x4027, /* Get a document file @since CUPS 1.4/macOS 10.6@ */
337 IPP_OP_CUPS_CREATE_LOCAL_PRINTER /* Create a local (temporary) printer @since CUPS 2.2 */
338
339 # ifndef _CUPS_NO_DEPRECATED
340 # define IPP_PRINT_JOB IPP_OP_PRINT_JOB
341 # define IPP_PRINT_URI IPP_OP_PRINT_URI
342 # define IPP_VALIDATE_JOB IPP_OP_VALIDATE_JOB
343 # define IPP_CREATE_JOB IPP_OP_CREATE_JOB
344 # define IPP_SEND_DOCUMENT IPP_OP_SEND_DOCUMENT
345 # define IPP_SEND_URI IPP_OP_SEND_URI
346 # define IPP_CANCEL_JOB IPP_OP_CANCEL_JOB
347 # define IPP_GET_JOB_ATTRIBUTES IPP_OP_GET_JOB_ATTRIBUTES
348 # define IPP_GET_JOBS IPP_OP_GET_JOBS
349 # define IPP_GET_PRINTER_ATTRIBUTES IPP_OP_GET_PRINTER_ATTRIBUTES
350 # define IPP_HOLD_JOB IPP_OP_HOLD_JOB
351 # define IPP_RELEASE_JOB IPP_OP_RELEASE_JOB
352 # define IPP_RESTART_JOB IPP_OP_RESTART_JOB
353 # define IPP_PAUSE_PRINTER IPP_OP_PAUSE_PRINTER
354 # define IPP_RESUME_PRINTER IPP_OP_RESUME_PRINTER
355 # define IPP_PURGE_JOBS IPP_OP_PURGE_JOBS
356 # define IPP_SET_PRINTER_ATTRIBUTES IPP_OP_SET_PRINTER_ATTRIBUTES
357 # define IPP_SET_JOB_ATTRIBUTES IPP_OP_SET_JOB_ATTRIBUTES
358 # define IPP_GET_PRINTER_SUPPORTED_VALUES IPP_OP_GET_PRINTER_SUPPORTED_VALUES
359 # define IPP_CREATE_PRINTER_SUBSCRIPTION IPP_OP_CREATE_PRINTER_SUBSCRIPTIONS
360 # define IPP_CREATE_JOB_SUBSCRIPTION IPP_OP_CREATE_JOB_SUBSCRIPTIONS
361 # define IPP_OP_CREATE_PRINTER_SUBSCRIPTION IPP_OP_CREATE_PRINTER_SUBSCRIPTIONS
362 # define IPP_OP_CREATE_JOB_SUBSCRIPTION IPP_OP_CREATE_JOB_SUBSCRIPTIONS
363 # define IPP_GET_SUBSCRIPTION_ATTRIBUTES IPP_OP_GET_SUBSCRIPTION_ATTRIBUTES
364 # define IPP_GET_SUBSCRIPTIONS IPP_OP_GET_SUBSCRIPTIONS
365 # define IPP_RENEW_SUBSCRIPTION IPP_OP_RENEW_SUBSCRIPTION
366 # define IPP_CANCEL_SUBSCRIPTION IPP_OP_CANCEL_SUBSCRIPTION
367 # define IPP_GET_NOTIFICATIONS IPP_OP_GET_NOTIFICATIONS
368 # define IPP_SEND_NOTIFICATIONS IPP_OP_SEND_NOTIFICATIONS
369 # define IPP_GET_RESOURCE_ATTRIBUTES IPP_OP_GET_RESOURCE_ATTRIBUTES
370 # define IPP_GET_RESOURCE_DATA IPP_OP_GET_RESOURCE_DATA
371 # define IPP_GET_RESOURCES IPP_OP_GET_RESOURCES
372 # define IPP_GET_PRINT_SUPPORT_FILES IPP_OP_GET_PRINT_SUPPORT_FILES
373 # define IPP_ENABLE_PRINTER IPP_OP_ENABLE_PRINTER
374 # define IPP_DISABLE_PRINTER IPP_OP_DISABLE_PRINTER
375 # define IPP_PAUSE_PRINTER_AFTER_CURRENT_JOB IPP_OP_PAUSE_PRINTER_AFTER_CURRENT_JOB
376 # define IPP_HOLD_NEW_JOBS IPP_OP_HOLD_NEW_JOBS
377 # define IPP_RELEASE_HELD_NEW_JOBS IPP_OP_RELEASE_HELD_NEW_JOBS
378 # define IPP_DEACTIVATE_PRINTER IPP_OP_DEACTIVATE_PRINTER
379 # define IPP_ACTIVATE_PRINTER IPP_OP_ACTIVATE_PRINTER
380 # define IPP_RESTART_PRINTER IPP_OP_RESTART_PRINTER
381 # define IPP_SHUTDOWN_PRINTER IPP_OP_SHUTDOWN_PRINTER
382 # define IPP_STARTUP_PRINTER IPP_OP_STARTUP_PRINTER
383 # define IPP_REPROCESS_JOB IPP_OP_REPROCESS_JOB
384 # define IPP_CANCEL_CURRENT_JOB IPP_OP_CANCEL_CURRENT_JOB
385 # define IPP_SUSPEND_CURRENT_JOB IPP_OP_SUSPEND_CURRENT_JOB
386 # define IPP_RESUME_JOB IPP_OP_RESUME_JOB
387 # define IPP_PROMOTE_JOB IPP_OP_PROMOTE_JOB
388 # define IPP_SCHEDULE_JOB_AFTER IPP_OP_SCHEDULE_JOB_AFTER
389 # define IPP_CANCEL_DOCUMENT IPP_OP_CANCEL_DOCUMENT
390 # define IPP_GET_DOCUMENT_ATTRIBUTES IPP_OP_GET_DOCUMENT_ATTRIBUTES
391 # define IPP_GET_DOCUMENTS IPP_OP_GET_DOCUMENTS
392 # define IPP_DELETE_DOCUMENT IPP_OP_DELETE_DOCUMENT
393 # define IPP_SET_DOCUMENT_ATTRIBUTES IPP_OP_SET_DOCUMENT_ATTRIBUTES
394 # define IPP_CANCEL_JOBS IPP_OP_CANCEL_JOBS
395 # define IPP_CANCEL_MY_JOBS IPP_OP_CANCEL_MY_JOBS
396 # define IPP_RESUBMIT_JOB IPP_OP_RESUBMIT_JOB
397 # define IPP_CLOSE_JOB IPP_OP_CLOSE_JOB
398 # define IPP_IDENTIFY_PRINTER IPP_OP_IDENTIFY_PRINTER
399 # define IPP_VALIDATE_DOCUMENT IPP_OP_VALIDATE_DOCUMENT
400 # define IPP_PRIVATE IPP_OP_PRIVATE
401 # define CUPS_GET_DEFAULT IPP_OP_CUPS_GET_DEFAULT
402 # define CUPS_GET_PRINTERS IPP_OP_CUPS_GET_PRINTERS
403 # define CUPS_ADD_MODIFY_PRINTER IPP_OP_CUPS_ADD_MODIFY_PRINTER
404 # define CUPS_DELETE_PRINTER IPP_OP_CUPS_DELETE_PRINTER
405 # define CUPS_GET_CLASSES IPP_OP_CUPS_GET_CLASSES
406 # define CUPS_ADD_MODIFY_CLASS IPP_OP_CUPS_ADD_MODIFY_CLASS
407 # define CUPS_DELETE_CLASS IPP_OP_CUPS_DELETE_CLASS
408 # define CUPS_ACCEPT_JOBS IPP_OP_CUPS_ACCEPT_JOBS
409 # define CUPS_REJECT_JOBS IPP_OP_CUPS_REJECT_JOBS
410 # define CUPS_SET_DEFAULT IPP_OP_CUPS_SET_DEFAULT
411 # define CUPS_GET_DEVICES IPP_OP_CUPS_GET_DEVICES
412 # define CUPS_GET_PPDS IPP_OP_CUPS_GET_PPDS
413 # define CUPS_MOVE_JOB IPP_OP_CUPS_MOVE_JOB
414 # define CUPS_AUTHENTICATE_JOB IPP_OP_CUPS_AUTHENTICATE_JOB
415 # define CUPS_GET_PPD IPP_OP_CUPS_GET_PPD
416 # define CUPS_GET_DOCUMENT IPP_OP_CUPS_GET_DOCUMENT
417 /* Legacy names */
418 # define CUPS_ADD_PRINTER IPP_OP_CUPS_ADD_MODIFY_PRINTER
419 # define CUPS_ADD_CLASS IPP_OP_CUPS_ADD_MODIFY_CLASS
420 # endif /* !_CUPS_NO_DEPRECATED */
421 } ipp_op_t;
422
423 typedef enum ipp_orient_e /**** Orientation values ****/
424 {
425 IPP_ORIENT_PORTRAIT = 3, /* No rotation */
426 IPP_ORIENT_LANDSCAPE, /* 90 degrees counter-clockwise */
427 IPP_ORIENT_REVERSE_LANDSCAPE, /* 90 degrees clockwise */
428 IPP_ORIENT_REVERSE_PORTRAIT, /* 180 degrees */
429 IPP_ORIENT_NONE /* No rotation */
430
431 # ifndef _CUPS_NO_DEPRECATED
432 # define IPP_PORTRAIT IPP_ORIENT_PORTRAIT
433 # define IPP_LANDSCAPE IPP_ORIENT_LANDSCAPE
434 # define IPP_REVERSE_LANDSCAPE IPP_ORIENT_REVERSE_LANDSCAPE
435 # define IPP_REVERSE_PORTRAIT IPP_ORIENT_REVERSE_PORTRAIT
436 # endif /* !_CUPS_NO_DEPRECATED */
437 } ipp_orient_t;
438
439 typedef enum ipp_pstate_e /**** Printer states ****/
440 {
441 IPP_PSTATE_IDLE = 3, /* Printer is idle */
442 IPP_PSTATE_PROCESSING, /* Printer is working */
443 IPP_PSTATE_STOPPED /* Printer is stopped */
444
445 # ifndef _CUPS_NO_DEPRECATED
446 # define IPP_PRINTER_IDLE IPP_PSTATE_IDLE
447 # define IPP_PRINTER_PROCESSING IPP_PSTATE_PROCESSING
448 # define IPP_PRINTER_STOPPED IPP_PSTATE_STOPPED
449 # endif /* _CUPS_NO_DEPRECATED */
450 } ipp_pstate_t;
451
452 typedef enum ipp_quality_e /**** Qualities ****/
453 {
454 IPP_QUALITY_DRAFT = 3, /* Draft quality */
455 IPP_QUALITY_NORMAL, /* Normal quality */
456 IPP_QUALITY_HIGH /* High quality */
457 } ipp_quality_t;
458
459 typedef enum ipp_res_e /**** Resolution units ****/
460 {
461 IPP_RES_PER_INCH = 3, /* Pixels per inch */
462 IPP_RES_PER_CM /* Pixels per centimeter */
463 } ipp_res_t;
464
465 typedef enum ipp_state_e /**** IPP states ****/
466 {
467 IPP_STATE_ERROR = -1, /* An error occurred */
468 IPP_STATE_IDLE, /* Nothing is happening/request completed */
469 IPP_STATE_HEADER, /* The request header needs to be sent/received */
470 IPP_STATE_ATTRIBUTE, /* One or more attributes need to be sent/received */
471 IPP_STATE_DATA /* IPP request data needs to be sent/received */
472
473 # ifndef _CUPS_NO_DEPRECATED
474 # define IPP_ERROR IPP_STATE_ERROR
475 # define IPP_IDLE IPP_STATE_IDLE
476 # define IPP_HEADER IPP_STATE_HEADER
477 # define IPP_ATTRIBUTE IPP_STATE_ATTRIBUTE
478 # define IPP_DATA IPP_STATE_DATA
479 # endif /* !_CUPS_NO_DEPRECATED */
480 } ipp_state_t;
481
482 typedef enum ipp_status_e /**** IPP status codes ****/
483 {
484 IPP_STATUS_CUPS_INVALID = -1, /* Invalid status name for @link ippErrorValue@ */
485 IPP_STATUS_OK = 0x0000, /* successful-ok */
486 IPP_STATUS_OK_IGNORED_OR_SUBSTITUTED, /* successful-ok-ignored-or-substituted-attributes */
487 IPP_STATUS_OK_CONFLICTING, /* successful-ok-conflicting-attributes */
488 IPP_STATUS_OK_IGNORED_SUBSCRIPTIONS, /* successful-ok-ignored-subscriptions */
489 IPP_STATUS_OK_IGNORED_NOTIFICATIONS, /* successful-ok-ignored-notifications @private@ */
490 IPP_STATUS_OK_TOO_MANY_EVENTS, /* successful-ok-too-many-events */
491 IPP_STATUS_OK_BUT_CANCEL_SUBSCRIPTION,/* successful-ok-but-cancel-subscription @private@ */
492 IPP_STATUS_OK_EVENTS_COMPLETE, /* successful-ok-events-complete */
493 IPP_STATUS_REDIRECTION_OTHER_SITE = 0x0200,
494 /* redirection-other-site @private@ */
495 IPP_STATUS_CUPS_SEE_OTHER = 0x0280, /* cups-see-other */
496 IPP_STATUS_ERROR_BAD_REQUEST = 0x0400,/* client-error-bad-request */
497 IPP_STATUS_ERROR_FORBIDDEN, /* client-error-forbidden */
498 IPP_STATUS_ERROR_NOT_AUTHENTICATED, /* client-error-not-authenticated */
499 IPP_STATUS_ERROR_NOT_AUTHORIZED, /* client-error-not-authorized */
500 IPP_STATUS_ERROR_NOT_POSSIBLE, /* client-error-not-possible */
501 IPP_STATUS_ERROR_TIMEOUT, /* client-error-timeout */
502 IPP_STATUS_ERROR_NOT_FOUND, /* client-error-not-found */
503 IPP_STATUS_ERROR_GONE, /* client-error-gone */
504 IPP_STATUS_ERROR_REQUEST_ENTITY, /* client-error-request-entity-too-large */
505 IPP_STATUS_ERROR_REQUEST_VALUE, /* client-error-request-value-too-long */
506 IPP_STATUS_ERROR_DOCUMENT_FORMAT_NOT_SUPPORTED,
507 /* client-error-document-format-not-supported */
508 IPP_STATUS_ERROR_ATTRIBUTES_OR_VALUES,/* client-error-attributes-or-values-not-supported */
509 IPP_STATUS_ERROR_URI_SCHEME, /* client-error-uri-scheme-not-supported */
510 IPP_STATUS_ERROR_CHARSET, /* client-error-charset-not-supported */
511 IPP_STATUS_ERROR_CONFLICTING, /* client-error-conflicting-attributes */
512 IPP_STATUS_ERROR_COMPRESSION_NOT_SUPPORTED,
513 /* client-error-compression-not-supported */
514 IPP_STATUS_ERROR_COMPRESSION_ERROR, /* client-error-compression-error */
515 IPP_STATUS_ERROR_DOCUMENT_FORMAT_ERROR,
516 /* client-error-document-format-error */
517 IPP_STATUS_ERROR_DOCUMENT_ACCESS, /* client-error-document-access-error */
518 IPP_STATUS_ERROR_ATTRIBUTES_NOT_SETTABLE,
519 /* client-error-attributes-not-settable */
520 IPP_STATUS_ERROR_IGNORED_ALL_SUBSCRIPTIONS,
521 /* client-error-ignored-all-subscriptions */
522 IPP_STATUS_ERROR_TOO_MANY_SUBSCRIPTIONS,
523 /* client-error-too-many-subscriptions */
524 IPP_STATUS_ERROR_IGNORED_ALL_NOTIFICATIONS,
525 /* client-error-ignored-all-notifications @private@ */
526 IPP_STATUS_ERROR_PRINT_SUPPORT_FILE_NOT_FOUND,
527 /* client-error-print-support-file-not-found @private@ */
528 IPP_STATUS_ERROR_DOCUMENT_PASSWORD, /* client-error-document-password-error */
529 IPP_STATUS_ERROR_DOCUMENT_PERMISSION, /* client-error-document-permission-error */
530 IPP_STATUS_ERROR_DOCUMENT_SECURITY, /* client-error-document-security-error */
531 IPP_STATUS_ERROR_DOCUMENT_UNPRINTABLE,/* client-error-document-unprintable-error */
532 IPP_STATUS_ERROR_ACCOUNT_INFO_NEEDED, /* client-error-account-info-needed */
533 IPP_STATUS_ERROR_ACCOUNT_CLOSED, /* client-error-account-closed */
534 IPP_STATUS_ERROR_ACCOUNT_LIMIT_REACHED,
535 /* client-error-account-limit-reached */
536 IPP_STATUS_ERROR_ACCOUNT_AUTHORIZATION_FAILED,
537 /* client-error-account-authorization-failed */
538 IPP_STATUS_ERROR_NOT_FETCHABLE, /* client-error-not-fetchable */
539
540 /* Legacy status codes for paid printing */
541 IPP_STATUS_ERROR_CUPS_ACCOUNT_INFO_NEEDED = 0x049C,
542 /* cups-error-account-info-needed @deprecated@ */
543 IPP_STATUS_ERROR_CUPS_ACCOUNT_CLOSED, /* cups-error-account-closed @deprecate@ */
544 IPP_STATUS_ERROR_CUPS_ACCOUNT_LIMIT_REACHED,
545 /* cups-error-account-limit-reached @deprecated@ */
546 IPP_STATUS_ERROR_CUPS_ACCOUNT_AUTHORIZATION_FAILED,
547 /* cups-error-account-authorization-failed @deprecated@ */
548
549 IPP_STATUS_ERROR_INTERNAL = 0x0500, /* server-error-internal-error */
550 IPP_STATUS_ERROR_OPERATION_NOT_SUPPORTED,
551 /* server-error-operation-not-supported */
552 IPP_STATUS_ERROR_SERVICE_UNAVAILABLE, /* server-error-service-unavailable */
553 IPP_STATUS_ERROR_VERSION_NOT_SUPPORTED,
554 /* server-error-version-not-supported */
555 IPP_STATUS_ERROR_DEVICE, /* server-error-device-error */
556 IPP_STATUS_ERROR_TEMPORARY, /* server-error-temporary-error */
557 IPP_STATUS_ERROR_NOT_ACCEPTING_JOBS, /* server-error-not-accepting-jobs */
558 IPP_STATUS_ERROR_BUSY, /* server-error-busy */
559 IPP_STATUS_ERROR_JOB_CANCELED, /* server-error-job-canceled */
560 IPP_STATUS_ERROR_MULTIPLE_JOBS_NOT_SUPPORTED,
561 /* server-error-multiple-document-jobs-not-supported */
562 IPP_STATUS_ERROR_PRINTER_IS_DEACTIVATED,
563 /* server-error-printer-is-deactivated */
564 IPP_STATUS_ERROR_TOO_MANY_JOBS, /* server-error-too-many-jobs */
565 IPP_STATUS_ERROR_TOO_MANY_DOCUMENTS, /* server-error-too-many-documents */
566
567 /* These are internal and never sent over the wire... */
568 IPP_STATUS_ERROR_CUPS_AUTHENTICATION_CANCELED = 0x1000,
569 /* cups-authentication-canceled - Authentication canceled by user @since CUPS 1.5/macOS 10.7@ */
570 IPP_STATUS_ERROR_CUPS_PKI, /* cups-pki-error - Error negotiating a secure connection @since CUPS 1.5/macOS 10.7@ */
571 IPP_STATUS_ERROR_CUPS_UPGRADE_REQUIRED/* cups-upgrade-required - TLS upgrade required */
572
573 # ifndef _CUPS_NO_DEPRECATED
574 # define IPP_OK IPP_STATUS_OK
575 # define IPP_OK_SUBST IPP_STATUS_OK_IGNORED_OR_SUBSTITUTED
576 # define IPP_OK_CONFLICT IPP_STATUS_OK_CONFLICTING
577 # define IPP_OK_IGNORED_SUBSCRIPTIONS IPP_STATUS_OK_IGNORED_SUBSCRIPTIONS
578 # define IPP_OK_IGNORED_NOTIFICATIONS IPP_STATUS_OK_IGNORED_NOTIFICATIONS
579 # define IPP_OK_TOO_MANY_EVENTS IPP_STATUS_OK_TOO_MANY_EVENTS
580 # define IPP_OK_BUT_CANCEL_SUBSCRIPTION IPP_STATUS_OK_BUT_CANCEL_SUBSCRIPTION
581 # define IPP_OK_EVENTS_COMPLETE IPP_STATUS_OK_EVENTS_COMPLETE
582 # define IPP_REDIRECTION_OTHER_SITE IPP_STATUS_REDIRECTION_OTHER_SITE
583 # define CUPS_SEE_OTHER IPP_STATUS_CUPS_SEE_OTHER
584 # define IPP_BAD_REQUEST IPP_STATUS_ERROR_BAD_REQUEST
585 # define IPP_FORBIDDEN IPP_STATUS_ERROR_FORBIDDEN
586 # define IPP_NOT_AUTHENTICATED IPP_STATUS_ERROR_NOT_AUTHENTICATED
587 # define IPP_NOT_AUTHORIZED IPP_STATUS_ERROR_NOT_AUTHORIZED
588 # define IPP_NOT_POSSIBLE IPP_STATUS_ERROR_NOT_POSSIBLE
589 # define IPP_TIMEOUT IPP_STATUS_ERROR_TIMEOUT
590 # define IPP_NOT_FOUND IPP_STATUS_ERROR_NOT_FOUND
591 # define IPP_GONE IPP_STATUS_ERROR_GONE
592 # define IPP_REQUEST_ENTITY IPP_STATUS_ERROR_REQUEST_ENTITY
593 # define IPP_REQUEST_VALUE IPP_STATUS_ERROR_REQUEST_VALUE
594 # define IPP_DOCUMENT_FORMAT IPP_STATUS_ERROR_DOCUMENT_FORMAT_NOT_SUPPORTED
595 # define IPP_ATTRIBUTES IPP_STATUS_ERROR_ATTRIBUTES_OR_VALUES
596 # define IPP_URI_SCHEME IPP_STATUS_ERROR_URI_SCHEME
597 # define IPP_CHARSET IPP_STATUS_ERROR_CHARSET
598 # define IPP_CONFLICT IPP_STATUS_ERROR_CONFLICTING
599 # define IPP_COMPRESSION_NOT_SUPPORTED IPP_STATUS_ERROR_COMPRESSION_NOT_SUPPORTED
600 # define IPP_COMPRESSION_ERROR IPP_STATUS_ERROR_COMPRESSION_ERROR
601 # define IPP_DOCUMENT_FORMAT_ERROR IPP_STATUS_ERROR_DOCUMENT_FORMAT_ERROR
602 # define IPP_DOCUMENT_ACCESS_ERROR IPP_STATUS_ERROR_DOCUMENT_ACCESS
603 # define IPP_ATTRIBUTES_NOT_SETTABLE IPP_STATUS_ERROR_ATTRIBUTES_NOT_SETTABLE
604 # define IPP_IGNORED_ALL_SUBSCRIPTIONS IPP_STATUS_ERROR_IGNORED_ALL_SUBSCRIPTIONS
605 # define IPP_TOO_MANY_SUBSCRIPTIONS IPP_STATUS_ERROR_TOO_MANY_SUBSCRIPTIONS
606 # define IPP_IGNORED_ALL_NOTIFICATIONS IPP_STATUS_ERROR_IGNORED_ALL_NOTIFICATIONS
607 # define IPP_PRINT_SUPPORT_FILE_NOT_FOUND IPP_STATUS_ERROR_PRINT_SUPPORT_FILE_NOT_FOUND
608 # define IPP_DOCUMENT_PASSWORD_ERROR IPP_STATUS_ERROR_DOCUMENT_PASSWORD
609 # define IPP_DOCUMENT_PERMISSION_ERROR IPP_STATUS_ERROR_DOCUMENT_PERMISSION
610 # define IPP_DOCUMENT_SECURITY_ERROR IPP_STATUS_ERROR_DOCUMENT_SECURITY
611 # define IPP_DOCUMENT_UNPRINTABLE_ERROR IPP_STATUS_ERROR_DOCUMENT_UNPRINTABLE
612 # define IPP_INTERNAL_ERROR IPP_STATUS_ERROR_INTERNAL
613 # define IPP_OPERATION_NOT_SUPPORTED IPP_STATUS_ERROR_OPERATION_NOT_SUPPORTED
614 # define IPP_SERVICE_UNAVAILABLE IPP_STATUS_ERROR_SERVICE_UNAVAILABLE
615 # define IPP_VERSION_NOT_SUPPORTED IPP_STATUS_ERROR_VERSION_NOT_SUPPORTED
616 # define IPP_DEVICE_ERROR IPP_STATUS_ERROR_DEVICE
617 # define IPP_TEMPORARY_ERROR IPP_STATUS_ERROR_TEMPORARY
618 # define IPP_NOT_ACCEPTING IPP_STATUS_ERROR_NOT_ACCEPTING_JOBS
619 # define IPP_PRINTER_BUSY IPP_STATUS_ERROR_BUSY
620 # define IPP_ERROR_JOB_CANCELED IPP_STATUS_ERROR_JOB_CANCELED
621 # define IPP_MULTIPLE_JOBS_NOT_SUPPORTED IPP_STATUS_ERROR_MULTIPLE_JOBS_NOT_SUPPORTED
622 # define IPP_PRINTER_IS_DEACTIVATED IPP_STATUS_ERROR_PRINTER_IS_DEACTIVATED
623 # define IPP_TOO_MANY_JOBS IPP_STATUS_ERROR_TOO_MANY_JOBS
624 # define IPP_TOO_MANY_DOCUMENTS IPP_STATUS_ERROR_TOO_MANY_DOCUMENTS
625 # define IPP_AUTHENTICATION_CANCELED IPP_STATUS_ERROR_CUPS_AUTHENTICATION_CANCELED
626 # define IPP_PKI_ERROR IPP_STATUS_ERROR_CUPS_PKI
627 # define IPP_UPGRADE_REQUIRED IPP_STATUS_ERROR_CUPS_UPGRADE_REQUIRED
628 /* Legacy name for canceled status */
629 # define IPP_ERROR_JOB_CANCELLED IPP_STATUS_ERROR_JOB_CANCELED
630 # endif /* _CUPS_NO_DEPRECATED */
631 } ipp_status_t;
632
633 typedef enum ipp_tag_e /**** Format tags for attributes ****/
634 {
635 IPP_TAG_CUPS_INVALID = -1, /* Invalid tag name for @link ippTagValue@ */
636 IPP_TAG_ZERO = 0x00, /* Zero tag - used for separators */
637 IPP_TAG_OPERATION, /* Operation group */
638 IPP_TAG_JOB, /* Job group */
639 IPP_TAG_END, /* End-of-attributes */
640 IPP_TAG_PRINTER, /* Printer group */
641 IPP_TAG_UNSUPPORTED_GROUP, /* Unsupported attributes group */
642 IPP_TAG_SUBSCRIPTION, /* Subscription group */
643 IPP_TAG_EVENT_NOTIFICATION, /* Event group */
644 IPP_TAG_RESOURCE, /* Resource group @private@ */
645 IPP_TAG_DOCUMENT, /* Document group */
646 IPP_TAG_UNSUPPORTED_VALUE = 0x10, /* Unsupported value */
647 IPP_TAG_DEFAULT, /* Default value */
648 IPP_TAG_UNKNOWN, /* Unknown value */
649 IPP_TAG_NOVALUE, /* No-value value */
650 IPP_TAG_NOTSETTABLE = 0x15, /* Not-settable value */
651 IPP_TAG_DELETEATTR, /* Delete-attribute value */
652 IPP_TAG_ADMINDEFINE, /* Admin-defined value */
653 IPP_TAG_INTEGER = 0x21, /* Integer value */
654 IPP_TAG_BOOLEAN, /* Boolean value */
655 IPP_TAG_ENUM, /* Enumeration value */
656 IPP_TAG_STRING = 0x30, /* Octet string value */
657 IPP_TAG_DATE, /* Date/time value */
658 IPP_TAG_RESOLUTION, /* Resolution value */
659 IPP_TAG_RANGE, /* Range value */
660 IPP_TAG_BEGIN_COLLECTION, /* Beginning of collection value */
661 IPP_TAG_TEXTLANG, /* Text-with-language value */
662 IPP_TAG_NAMELANG, /* Name-with-language value */
663 IPP_TAG_END_COLLECTION, /* End of collection value */
664 IPP_TAG_TEXT = 0x41, /* Text value */
665 IPP_TAG_NAME, /* Name value */
666 IPP_TAG_RESERVED_STRING, /* Reserved for future string value @private@ */
667 IPP_TAG_KEYWORD, /* Keyword value */
668 IPP_TAG_URI, /* URI value */
669 IPP_TAG_URISCHEME, /* URI scheme value */
670 IPP_TAG_CHARSET, /* Character set value */
671 IPP_TAG_LANGUAGE, /* Language value */
672 IPP_TAG_MIMETYPE, /* MIME media type value */
673 IPP_TAG_MEMBERNAME, /* Collection member name value */
674 IPP_TAG_EXTENSION = 0x7f, /* Extension point for 32-bit tags */
675 IPP_TAG_CUPS_MASK = 0x7fffffff, /* Mask for copied attribute values @private@ */
676 /* The following expression is used to avoid compiler warnings with +/-0x80000000 */
677 IPP_TAG_CUPS_CONST = -0x7fffffff-1 /* Bitflag for copied/const attribute values @private@ */
678
679 # ifndef _CUPS_NO_DEPRECATED
680 # define IPP_TAG_MASK IPP_TAG_CUPS_MASK
681 # define IPP_TAG_COPY IPP_TAG_CUPS_CONST
682 # endif /* !_CUPS_NO_DEPRECATED */
683 } ipp_tag_t;
684
685 typedef unsigned char ipp_uchar_t; /**** Unsigned 8-bit integer/character ****/
686 typedef struct _ipp_s ipp_t; /**** IPP request/response data ****/
687 typedef struct _ipp_attribute_s ipp_attribute_t;
688 /**** IPP attribute ****/
689
690 /**** New in CUPS 1.2/macOS 10.5 ****/
691 typedef ssize_t (*ipp_iocb_t)(void *context, ipp_uchar_t *buffer, size_t bytes);
692 /**** IPP IO Callback Function @since CUPS 1.2/macOS 10.5@ ****/
693
694 /**** New in CUPS 1.6/macOS 10.8 ****/
695 typedef int (*ipp_copycb_t)(void *context, ipp_t *dst, ipp_attribute_t *attr);
696
697
698 /*
699 * The following structures are PRIVATE starting with CUPS 1.6/macOS 10.8.
700 * Please use the new accessor functions available in CUPS 1.6 and later, as
701 * these definitions will be moved to a private header file in a future release.
702 *
703 * Define _IPP_PRIVATE_STRUCTURES to 1 to cause the private IPP structures to be
704 * exposed in CUPS 1.6. This happens automatically on macOS when compiling for
705 * a deployment target of 10.7 or earlier.
706 *
707 * Define _IPP_PRIVATE_STRUCTURES to 0 to prevent the private IPP structures
708 * from being exposed. This is useful when migrating existing code to the new
709 * accessors.
710 */
711
712 # ifdef _IPP_PRIVATE_STRUCTURES
713 /* Somebody has overridden the value */
714 # elif defined(_CUPS_SOURCE) || defined(_CUPS_IPP_PRIVATE_H_)
715 /* Building CUPS */
716 # define _IPP_PRIVATE_STRUCTURES 1
717 # elif defined(__APPLE__)
718 # if defined(MAC_OS_X_VERSION_10_8) && MAC_OS_X_VERSION_MIN_REQUIRED < MAC_OS_X_VERSION_10_8
719 /* Building for 10.7 and earlier */
720 # define _IPP_PRIVATE_STRUCTURES 1
721 # elif !defined(MAC_OS_X_VERSION_10_8)
722 /* Building for 10.7 and earlier */
723 # define _IPP_PRIVATE_STRUCTURES 1
724 # endif /* MAC_OS_X_VERSION_10_8 && MAC_OS_X_VERSION_MIN_REQUIRED < MAC_OS_X_VERSION_10_8 */
725 # else
726 # define _IPP_PRIVATE_STRUCTURES 0
727 # endif /* _CUPS_SOURCE || _CUPS_IPP_PRIVATE_H_ */
728
729 # if _IPP_PRIVATE_STRUCTURES
730 typedef union _ipp_request_u /**** Request Header ****/
731 {
732 struct /* Any Header */
733 {
734 ipp_uchar_t version[2]; /* Protocol version number */
735 int op_status; /* Operation ID or status code*/
736 int request_id; /* Request ID */
737 } any;
738
739 struct /* Operation Header */
740 {
741 ipp_uchar_t version[2]; /* Protocol version number */
742 ipp_op_t operation_id; /* Operation ID */
743 int request_id; /* Request ID */
744 } op;
745
746 struct /* Status Header */
747 {
748 ipp_uchar_t version[2]; /* Protocol version number */
749 ipp_status_t status_code; /* Status code */
750 int request_id; /* Request ID */
751 } status;
752
753 /**** New in CUPS 1.1.19 ****/
754 struct /* Event Header @since CUPS 1.1.19/macOS 10.3@ */
755 {
756 ipp_uchar_t version[2]; /* Protocol version number */
757 ipp_status_t status_code; /* Status code */
758 int request_id; /* Request ID */
759 } event;
760 } _ipp_request_t;
761
762 /**** New in CUPS 1.1.19 ****/
763
764 typedef union _ipp_value_u /**** Attribute Value ****/
765 {
766 int integer; /* Integer/enumerated value */
767
768 char boolean; /* Boolean value */
769
770 ipp_uchar_t date[11]; /* Date/time value */
771
772 struct
773 {
774 int xres, /* Horizontal resolution */
775 yres; /* Vertical resolution */
776 ipp_res_t units; /* Resolution units */
777 } resolution; /* Resolution value */
778
779 struct
780 {
781 int lower, /* Lower value */
782 upper; /* Upper value */
783 } range; /* Range of integers value */
784
785 struct
786 {
787 char *language; /* Language code */
788 char *text; /* String */
789 } string; /* String with language value */
790
791 struct
792 {
793 int length; /* Length of attribute */
794 void *data; /* Data in attribute */
795 } unknown; /* Unknown attribute type */
796
797 /**** New in CUPS 1.1.19 ****/
798 ipp_t *collection; /* Collection value @since CUPS 1.1.19/macOS 10.3@ */
799 } _ipp_value_t;
800 typedef _ipp_value_t ipp_value_t; /**** Convenience typedef that will be removed @private@ ****/
801
802 struct _ipp_attribute_s /**** Attribute ****/
803 {
804 ipp_attribute_t *next; /* Next attribute in list */
805 ipp_tag_t group_tag, /* Job/Printer/Operation group tag */
806 value_tag; /* What type of value is it? */
807 char *name; /* Name of attribute */
808 int num_values; /* Number of values */
809 _ipp_value_t values[1]; /* Values */
810 };
811
812 struct _ipp_s /**** IPP Request/Response/Notification ****/
813 {
814 ipp_state_t state; /* State of request */
815 _ipp_request_t request; /* Request header */
816 ipp_attribute_t *attrs; /* Attributes */
817 ipp_attribute_t *last; /* Last attribute in list */
818 ipp_attribute_t *current; /* Current attribute (for read/write) */
819 ipp_tag_t curtag; /* Current attribute group tag */
820
821 /**** New in CUPS 1.2 ****/
822 ipp_attribute_t *prev; /* Previous attribute (for read) @since CUPS 1.2/macOS 10.5@ */
823
824 /**** New in CUPS 1.4.4 ****/
825 int use; /* Use count @since CUPS 1.4.4/macOS 10.6.?@ */
826 /**** New in CUPS 2.0 ****/
827 int atend, /* At end of list? */
828 curindex; /* Current attribute index for hierarchical search */
829 };
830 # endif /* _IPP_PRIVATE_STRUCTURES */
831
832
833 /*
834 * Prototypes...
835 */
836
837 extern ipp_attribute_t *ippAddBoolean(ipp_t *ipp, ipp_tag_t group,
838 const char *name, char value);
839 extern ipp_attribute_t *ippAddBooleans(ipp_t *ipp, ipp_tag_t group,
840 const char *name, int num_values,
841 const char *values);
842 extern ipp_attribute_t *ippAddDate(ipp_t *ipp, ipp_tag_t group,
843 const char *name, const ipp_uchar_t *value);
844 extern ipp_attribute_t *ippAddInteger(ipp_t *ipp, ipp_tag_t group,
845 ipp_tag_t value_tag, const char *name,
846 int value);
847 extern ipp_attribute_t *ippAddIntegers(ipp_t *ipp, ipp_tag_t group,
848 ipp_tag_t value_tag, const char *name,
849 int num_values, const int *values);
850 extern ipp_attribute_t *ippAddRange(ipp_t *ipp, ipp_tag_t group,
851 const char *name, int lower, int upper);
852 extern ipp_attribute_t *ippAddRanges(ipp_t *ipp, ipp_tag_t group,
853 const char *name, int num_values,
854 const int *lower, const int *upper);
855 extern ipp_attribute_t *ippAddResolution(ipp_t *ipp, ipp_tag_t group,
856 const char *name, ipp_res_t units,
857 int xres, int yres);
858 extern ipp_attribute_t *ippAddResolutions(ipp_t *ipp, ipp_tag_t group,
859 const char *name, int num_values,
860 ipp_res_t units, const int *xres,
861 const int *yres);
862 extern ipp_attribute_t *ippAddSeparator(ipp_t *ipp);
863 extern ipp_attribute_t *ippAddString(ipp_t *ipp, ipp_tag_t group,
864 ipp_tag_t value_tag, const char *name,
865 const char *language, const char *value);
866 extern ipp_attribute_t *ippAddStrings(ipp_t *ipp, ipp_tag_t group,
867 ipp_tag_t value_tag, const char *name,
868 int num_values, const char *language,
869 const char * const *values);
870 extern time_t ippDateToTime(const ipp_uchar_t *date);
871 extern void ippDelete(ipp_t *ipp);
872 extern const char *ippErrorString(ipp_status_t error);
873 extern ipp_attribute_t *ippFindAttribute(ipp_t *ipp, const char *name,
874 ipp_tag_t value_tag);
875 extern ipp_attribute_t *ippFindNextAttribute(ipp_t *ipp, const char *name,
876 ipp_tag_t value_tag);
877 extern size_t ippLength(ipp_t *ipp);
878 extern ipp_t *ippNew(void);
879 extern ipp_state_t ippRead(http_t *http, ipp_t *ipp);
880 extern const ipp_uchar_t *ippTimeToDate(time_t t);
881 extern ipp_state_t ippWrite(http_t *http, ipp_t *ipp);
882 extern int ippPort(void);
883 extern void ippSetPort(int p);
884
885 /**** New in CUPS 1.1.19 ****/
886 extern ipp_attribute_t *ippAddCollection(ipp_t *ipp, ipp_tag_t group,
887 const char *name, ipp_t *value) _CUPS_API_1_1_19;
888 extern ipp_attribute_t *ippAddCollections(ipp_t *ipp, ipp_tag_t group,
889 const char *name, int num_values,
890 const ipp_t **values) _CUPS_API_1_1_19;
891 extern void ippDeleteAttribute(ipp_t *ipp, ipp_attribute_t *attr) _CUPS_API_1_1_19;
892 extern ipp_state_t ippReadFile(int fd, ipp_t *ipp) _CUPS_API_1_1_19;
893 extern ipp_state_t ippWriteFile(int fd, ipp_t *ipp) _CUPS_API_1_1_19;
894
895 /**** New in CUPS 1.2/macOS 10.5 ****/
896 extern ipp_attribute_t *ippAddOctetString(ipp_t *ipp, ipp_tag_t group,
897 const char *name,
898 const void *data, int datalen) _CUPS_API_1_2;
899 extern ipp_status_t ippErrorValue(const char *name) _CUPS_API_1_2;
900 extern ipp_t *ippNewRequest(ipp_op_t op) _CUPS_API_1_2;
901 extern const char *ippOpString(ipp_op_t op) _CUPS_API_1_2;
902 extern ipp_op_t ippOpValue(const char *name) _CUPS_API_1_2;
903 extern ipp_state_t ippReadIO(void *src, ipp_iocb_t cb, int blocking,
904 ipp_t *parent, ipp_t *ipp) _CUPS_API_1_2;
905 extern ipp_state_t ippWriteIO(void *dst, ipp_iocb_t cb, int blocking,
906 ipp_t *parent, ipp_t *ipp) _CUPS_API_1_2;
907
908 /**** New in CUPS 1.4/macOS 10.6 ****/
909 extern const char *ippTagString(ipp_tag_t tag) _CUPS_API_1_4;
910 extern ipp_tag_t ippTagValue(const char *name) _CUPS_API_1_4;
911
912 /**** New in CUPS 1.6/macOS 10.8 ****/
913 extern ipp_attribute_t *ippAddOutOfBand(ipp_t *ipp, ipp_tag_t group,
914 ipp_tag_t value_tag, const char *name)
915 _CUPS_API_1_6;
916 extern size_t ippAttributeString(ipp_attribute_t *attr, char *buffer,
917 size_t bufsize) _CUPS_API_1_6;
918 extern ipp_attribute_t *ippCopyAttribute(ipp_t *dst, ipp_attribute_t *attr,
919 int quickcopy) _CUPS_API_1_6;
920 extern int ippCopyAttributes(ipp_t *dst, ipp_t *src,
921 int quickcopy, ipp_copycb_t cb,
922 void *context) _CUPS_API_1_6;
923 extern int ippDeleteValues(ipp_t *ipp, ipp_attribute_t **attr,
924 int element, int count) _CUPS_API_1_6;
925 extern const char *ippEnumString(const char *attrname, int enumvalue)
926 _CUPS_API_1_6;
927 extern int ippEnumValue(const char *attrname,
928 const char *enumstring) _CUPS_API_1_6;
929 extern ipp_attribute_t *ippFirstAttribute(ipp_t *ipp) _CUPS_API_1_6;
930 extern int ippGetBoolean(ipp_attribute_t *attr, int element)
931 _CUPS_API_1_6;
932 extern ipp_t *ippGetCollection(ipp_attribute_t *attr,
933 int element) _CUPS_API_1_6;
934 extern int ippGetCount(ipp_attribute_t *attr) _CUPS_API_1_6;
935 extern const ipp_uchar_t *ippGetDate(ipp_attribute_t *attr, int element)
936 _CUPS_API_1_6;
937 extern ipp_tag_t ippGetGroupTag(ipp_attribute_t *attr) _CUPS_API_1_6;
938 extern int ippGetInteger(ipp_attribute_t *attr, int element)
939 _CUPS_API_1_6;
940 extern const char *ippGetName(ipp_attribute_t *attr) _CUPS_API_1_6;
941 extern ipp_op_t ippGetOperation(ipp_t *ipp) _CUPS_API_1_6;
942 extern int ippGetRange(ipp_attribute_t *attr, int element,
943 int *upper) _CUPS_API_1_6;
944 extern int ippGetRequestId(ipp_t *ipp) _CUPS_API_1_6;
945 extern int ippGetResolution(ipp_attribute_t *attr, int element,
946 int *yres, ipp_res_t *units)
947 _CUPS_API_1_6;
948 extern ipp_state_t ippGetState(ipp_t *ipp) _CUPS_API_1_6;
949 extern ipp_status_t ippGetStatusCode(ipp_t *ipp) _CUPS_API_1_6;
950 extern const char *ippGetString(ipp_attribute_t *attr, int element,
951 const char **language) _CUPS_API_1_6;
952 extern ipp_tag_t ippGetValueTag(ipp_attribute_t *attr) _CUPS_API_1_6;
953 extern int ippGetVersion(ipp_t *ipp, int *minor) _CUPS_API_1_6;
954 extern ipp_attribute_t *ippNextAttribute(ipp_t *ipp) _CUPS_API_1_6;
955 extern int ippSetBoolean(ipp_t *ipp, ipp_attribute_t **attr,
956 int element, int boolvalue) _CUPS_API_1_6;
957 extern int ippSetCollection(ipp_t *ipp, ipp_attribute_t **attr,
958 int element, ipp_t *colvalue)
959 _CUPS_API_1_6;
960 extern int ippSetDate(ipp_t *ipp, ipp_attribute_t **attr,
961 int element, const ipp_uchar_t *datevalue)
962 _CUPS_API_1_6;
963 extern int ippSetGroupTag(ipp_t *ipp, ipp_attribute_t **attr,
964 ipp_tag_t group_tag) _CUPS_API_1_6;
965 extern int ippSetInteger(ipp_t *ipp, ipp_attribute_t **attr,
966 int element, int intvalue) _CUPS_API_1_6;
967 extern int ippSetName(ipp_t *ipp, ipp_attribute_t **attr,
968 const char *name) _CUPS_API_1_6;
969 extern int ippSetOperation(ipp_t *ipp, ipp_op_t op) _CUPS_API_1_6;
970 extern int ippSetRange(ipp_t *ipp, ipp_attribute_t **attr,
971 int element, int lowervalue, int uppervalue)
972 _CUPS_API_1_6;
973 extern int ippSetRequestId(ipp_t *ipp, int request_id)
974 _CUPS_API_1_6;
975 extern int ippSetResolution(ipp_t *ipp, ipp_attribute_t **attr,
976 int element, ipp_res_t unitsvalue,
977 int xresvalue, int yresvalue)
978 _CUPS_API_1_6;
979 extern int ippSetState(ipp_t *ipp, ipp_state_t state)
980 _CUPS_API_1_6;
981 extern int ippSetStatusCode(ipp_t *ipp, ipp_status_t status)
982 _CUPS_API_1_6;
983 extern int ippSetString(ipp_t *ipp, ipp_attribute_t **attr,
984 int element, const char *strvalue)
985 _CUPS_API_1_6;
986 extern int ippSetValueTag(ipp_t *ipp, ipp_attribute_t **attr,
987 ipp_tag_t value_tag) _CUPS_API_1_6;
988 extern int ippSetVersion(ipp_t *ipp, int major, int minor)
989 _CUPS_API_1_6;
990
991 /**** New in CUPS 1.7 ****/
992 extern ipp_attribute_t *ippAddStringf(ipp_t *ipp, ipp_tag_t group,
993 ipp_tag_t value_tag, const char *name,
994 const char *language, const char *format,
995 ...) _CUPS_API_1_7;
996 extern ipp_attribute_t *ippAddStringfv(ipp_t *ipp, ipp_tag_t group,
997 ipp_tag_t value_tag, const char *name,
998 const char *language,
999 const char *format, va_list ap)
1000 _CUPS_API_1_7;
1001 extern int ippContainsInteger(ipp_attribute_t *attr, int value)
1002 _CUPS_API_1_7;
1003 extern int ippContainsString(ipp_attribute_t *attr,
1004 const char *value) _CUPS_API_1_7;
1005 extern cups_array_t *ippCreateRequestedArray(ipp_t *request) _CUPS_API_1_7;
1006 extern void *ippGetOctetString(ipp_attribute_t *attr, int element,
1007 int *datalen) _CUPS_API_1_7;
1008 extern ipp_t *ippNewResponse(ipp_t *request) _CUPS_API_1_7;
1009 extern int ippSetOctetString(ipp_t *ipp, ipp_attribute_t **attr,
1010 int element, const void *data,
1011 int datalen) _CUPS_API_1_7;
1012 extern int ippSetStringf(ipp_t *ipp, ipp_attribute_t **attr,
1013 int element, const char *format,
1014 ...) _CUPS_API_1_7;
1015 extern int ippSetStringfv(ipp_t *ipp, ipp_attribute_t **attr,
1016 int element, const char *format,
1017 va_list ap) _CUPS_API_1_7;
1018 extern int ippValidateAttribute(ipp_attribute_t *attr)
1019 _CUPS_API_1_7;
1020 extern int ippValidateAttributes(ipp_t *ipp) _CUPS_API_1_7;
1021
1022
1023 /**** New in CUPS 2.0 ****/
1024 extern const char *ippStateString(ipp_state_t state) _CUPS_API_2_0;
1025
1026
1027 /*
1028 * C++ magic...
1029 */
1030
1031 # ifdef __cplusplus
1032 }
1033 # endif /* __cplusplus */
1034 #endif /* !_CUPS_IPP_H_ */