1<!DOCTYPE HTML> 2<html> 3<!-- SECTION: Man Pages --> 4<head> 5 <link rel="stylesheet" type="text/css" href="../cups-printable.css"> 6 <title>ipptoolfile(5)</title> 7</head> 8<body> 9<h1 class="title">ipptoolfile(5)</h1> 10<h2 class="title"><a name="NAME">Name</a></h2> 11ipptoolfile - ipptool file format 12<h2 class="title"><a name="DESCRIPTION">Description</a></h2> 13The 14<b>ipptool</b>(1) 15program accepts free-form plain text files that describe one or more IPP requests. 16Comments start with the "#" character and continue to the end of the line. 17Each request is enclosed by curly braces, for example: 18<pre class="man"> 19 20 # This is a comment 21 { 22 # The name of the test 23 NAME "Print PDF File" 24 25 # The request to send 26 OPERATION Print-Job 27 28 GROUP operation-attributes-tag 29 ATTR charset attributes-charset utf-8 30 ATTR language attributes-natural-language en 31 ATTR uri printer-uri $uri 32 ATTR name requesting-user-name $user 33 ATTR mimeMediaType document-format application/pdf 34 35 GROUP job-attributes-tag 36 ATTR collection media-col { 37 # US Letter plain paper from the "main" tray 38 MEMBER collection media-size { 39 MEMBER integer x-dimension 21590 40 MEMBER integer y-dimension 27940 41 } 42 MEMBER integer media-top-margin 423 43 MEMBER integer media-bottom-margin 423 44 MEMBER integer media-left-margin 423 45 MEMBER integer media-right-margin 423 46 MEMBER keyword media-source "main" 47 MEMBER keyword media-type "stationery" 48 } 49 50 FILE testfile.pdf 51 52 # The response to expect 53 STATUS successful-ok 54 EXPECT job-id OF-TYPE integer WITH-VALUE >0 55 EXPECT job-uri OF-TYPE uri 56 } 57 { 58 # The name of the test 59 NAME "Wait for Job to Complete" 60 61 # The request to send 62 OPERATION Get-Job-Attributes 63 64 GROUP operation-attributes-tag 65 ATTR charset attributes-charset utf-8 66 ATTR language attributes-natural-language en 67 ATTR uri printer-uri $uri 68 ATTR integer job-id $job-id 69 ATTR name requesting-user-name $user 70 71 # The response to expect 72 STATUS successful-ok 73 EXPECT job-id OF-TYPE integer WITH-VALUE $job-id 74 EXPECT job-uri OF-TYPE uri 75 EXPECT job-state OF-TYPE enum WITH-VALUE >5 REPEAT-NO-MATCH 76 EXPECT job-originating-user-name OF-TYPE name WITH-VALUE "$user" 77 78 # Show the job state until completed... 79 DISPLAY job-state 80 DISPLAY job-state-reasons 81 } 82</pre> 83<h3><a name="TOP_LEVEL_DIRECTIVES">Top-level Directives</a></h3> 84The following directives can be used outside of a <i>test</i>: 85<dl class="man"> 86<dt><b>{ </b><i>test </i><b>}</b> 87<dd style="margin-left: 5.0em">Defines a test. 88<dt><b>DEFINE </b><i>variable-name value</i> 89<dd style="margin-left: 5.0em">Defines the named variable to the given value. This is equivalent to specifying <i>-d variable-name=value</i> on the 90<b>ipptool</b>(8) 91command-line. 92<dt><b>DEFINE-DEFAULT </b><i>variable-name value</i> 93<dd style="margin-left: 5.0em">Defines the named variable to the given value if it does not already have a value. 94<dt><b>FILE-ID "</b><i>identifier</i><b>"</b> 95<dd style="margin-left: 5.0em">Specifies an identifier string for the current file. 96<dt><b>IGNORE-ERRORS yes</b> 97<dd style="margin-left: 5.0em"><dt><b>IGNORE-ERRORS no</b> 98<dd style="margin-left: 5.0em">Specifies whether, by default, 99<b>ipptool</b>(8) 100will ignore errors and continue with subsequent tests. 101<dt><b>INCLUDE "</b><i>filename</i><b>"</b> 102<dd style="margin-left: 5.0em"><dt><b>INCLUDE <</b><i>filename</i><b>></b> 103<dd style="margin-left: 5.0em">Includes another test file. The first form includes a file relative to the current test file, while the second form includes a file from the 104<b>ipptool</b>(8) 105include directory. 106<dt><b>INCLUDE-IF-DEFINED </b><i>name </i><b>"</b><i>filename</i><b>"</b> 107<dd style="margin-left: 5.0em"><dt><b>INCLUDE-IF-DEFINED </b><i>name </i><b><</b><i>filename</i><b>></b> 108<dd style="margin-left: 5.0em">Includes another test file if the named variable is defined. The first form includes a file relative to the current test file, while the second form includes a file from the 109<b>ipptool</b>(8) 110include directory. 111<dt><b>INCLUDE-IF-NOT-DEFINED </b><i>name </i><b>"</b><i>filename</i><b>"</b> 112<dd style="margin-left: 5.0em"><dt><b>INCLUDE-IF-NOT-DEFINED </b><i>name </i><b><</b><i>filename</i><b>></b> 113<dd style="margin-left: 5.0em">Includes another test file if the named variable is not defined. The first form includes a file relative to the current test file, while the second form includes a file from the 114<b>ipptool</b>(8) 115include directory. 116<dt><b>SKIP-IF-DEFINED </b><i>variable-name</i> 117<dd style="margin-left: 5.0em"><dt><b>SKIP-IF-NOT-DEFINED </b><i>variable-name</i> 118<dd style="margin-left: 5.0em">Specifies that the remainder of the test file should be skipped when the variable is or is not defined. 119<dt><b>STOP-AFTER-INCLUDE-ERROR no</b> 120<dd style="margin-left: 5.0em"><dt><b>STOP-AFTER-INCLUDE-ERROR yes</b> 121<dd style="margin-left: 5.0em">Specifies whether tests will be stopped after an error in an included file. 122<dt><b>TRANSFER auto</b> 123<dd style="margin-left: 5.0em">Specifies that tests will, by default, use "Transfer-Encoding: chunked" for requests with attached files and "Content-Length:" for requests without attached files. 124<dt><b>TRANSFER chunked</b> 125<dd style="margin-left: 5.0em">Specifies that tests will, by default, use the HTTP/1.1 "Transfer-Encoding: chunked" header. This is the default and is equivalent to specifying <i>-c</i> on the 126<b>ipptool</b>(8) 127command-line. Support for chunked requests is required for conformance with all versions of IPP. 128<dt><b>TRANSFER length</b> 129<dd style="margin-left: 5.0em">Specifies that tests will, by default, use the HTTP/1.0 "Content-Length:" header. This is equivalent to specifying <i>-l</i> on the 130<b>ipptool</b>(8) 131command-line. Support for content length requests is required for conformance with all versions of IPP. 132<dt><b>VERSION 1.0</b> 133<dd style="margin-left: 5.0em"><dt><b>VERSION 1.1</b> 134<dd style="margin-left: 5.0em"><dt><b>VERSION 2.0</b> 135<dd style="margin-left: 5.0em"><dt><b>VERSION 2.1</b> 136<dd style="margin-left: 5.0em"><dt><b>VERSION 2.2</b> 137<dd style="margin-left: 5.0em">Specifies the default IPP version number to use for the tests that follow. 138</dl> 139<h3><a name="TEST_DIRECTIVES">Test Directives</a></h3> 140The following directives are understood within a <i>test</i>: 141<dl class="man"> 142<dt><b>ATTR </b><i>out-of-band-tag attribute-name</i> 143<dd style="margin-left: 5.0em"><dt><b>ATTR </b><i>tag attribute-name value(s)</i> 144<dd style="margin-left: 5.0em">Adds an attribute to the test request. 145Out-of-band tags (admin-define, delete-attribute, no-value, not-settable, unknown, unsupported) have no value. 146Values for other tags are delimited by the comma (",") character - escape commas using the "\" character. 147Common attributes and values are listed in the IANA IPP registry - see references below. 148<dt><b>ATTR collection </b><i>attribute-name </i><b>{ MEMBER </b><i>tag member-name value(s) ... </i><b>}</b> [ <i>... </i><b>,{ </b><i>... </i><b>} </b>] 149<dd style="margin-left: 5.0em">Adds a collection attribute to the test request. 150Member attributes follow the same syntax as regular attributes and can themselves be nested collections. 151Multiple collection values can be supplied as needed, separated by commas. 152<dt><b>COMPRESSION deflate</b> 153<dd style="margin-left: 5.0em"><dt><b>COMPRESSION gzip</b> 154<dd style="margin-left: 5.0em"><dt><b>COMPRESSION none</b> 155<dd style="margin-left: 5.0em">Uses the specified compression on the document data following the attributes in a Print-Job or Send-Document request. 156<dt><b>DELAY </b><i>seconds</i>[<i>,repeat-seconds</i>] 157<dd style="margin-left: 5.0em">Specifies a delay in seconds before this test will be run. 158If two values are specified, the second value is used as the delay between repeated tests. 159<dt><b>DISPLAY </b><i>attribute-name</i> 160<dd style="margin-left: 5.0em">Specifies that value of the named attribute should be output as part of the 161test report. 162<dt><b>EXPECT </b><i>attribute-name </i>[ <i>predicate(s) </i>] 163<dd style="margin-left: 5.0em"><dt><b>EXPECT ?</b><i>attribute-name predicate(s)</i> 164<dd style="margin-left: 5.0em"><dt><b>EXPECT !</b><i>attribute-name</i> 165<dd style="margin-left: 5.0em">Specifies that the response must/may/must not include the named attribute. Additional requirements can be added as predicates - see the "EXPECT PREDICATES" section for more information on predicates. Attribute names can specify member attributes by separating the attribute and member names with the forward slash, for example "media-col/media-size/x-dimension". 166<dt><b>EXPECT-ALL </b><i>attribute-name </i>[ <i>predicate(s) </i>] 167<dd style="margin-left: 5.0em"><dt><b>EXPECT-ALL ?</b><i>attribute-name predicate(s)</i> 168<dd style="margin-left: 5.0em">Specifies that the response must/may include the named attribute and that all occurrences of that attribute must match the given predicates. 169<dt><b>FILE filename</b> 170<dd style="margin-left: 5.0em">Specifies a file to include at the end of the request. This is typically used when sending a test print file. 171<dt><b>GROUP tag</b> 172<dd style="margin-left: 5.0em">Specifies the group tag for subsequent attributes in the request. 173<dt><b>IGNORE-ERRORS yes</b> 174<dd style="margin-left: 5.0em"><dt><b>IGNORE-ERRORS no</b> 175<dd style="margin-left: 5.0em">Specifies whether 176<b>ipptool</b>(8) 177will ignore errors and continue with subsequent tests. 178<dt><b>NAME "</b><i>literal string</i><b>"</b> 179<dd style="margin-left: 5.0em">Specifies the human-readable name of the test. 180<dt><b>OPERATION </b><i>operation-code</i> 181<dd style="margin-left: 5.0em">Specifies the operation to be performed. 182<dt><b>PAUSE "</b><i>message</i><b>"</b> 183<dd style="margin-left: 5.0em">Displays the provided message and waits for the user to press a key to continue. 184<dt><b>REQUEST-ID </b><i>number</i> 185<dd style="margin-left: 5.0em"><dt><b>REQUEST-ID random</b> 186<dd style="margin-left: 5.0em">Specifies the request-id value to use in the request, either an integer or the word "random" to use a randomly generated value (the default). 187<dt><b>RESOURCE </b><i>path</i> 188<dd style="margin-left: 5.0em">Specifies an alternate resource path that is used for the HTTP POST request. The default is the resource from the URI provided to the 189<b>ipptool</b>(8) 190program. 191<dt><b>SKIP-IF-DEFINED </b><i>variable-name</i> 192<dd style="margin-left: 5.0em"><dt><b>SKIP-IF-NOT-DEFINED </b><i>variable-name</i> 193<dd style="margin-left: 5.0em">Specifies that the current test should be skipped when the variable is or is not defined. 194<dt><b>SKIP-PREVIOUS-ERROR yes</b> 195<dd style="margin-left: 5.0em"><dt><b>SKIP-PREVIOUS-ERROR no</b> 196<dd style="margin-left: 5.0em">Specifies whether 197<b>ipptool</b>(8) 198will skip the current test if the previous test resulted in an error/failure. 199<dt><b>STATUS </b><i>status-code </i>[ <i>predicate</i> ] 200<dd style="margin-left: 5.0em">Specifies an expected response status-code value. Additional requirements can be added as predicates - see the "STATUS PREDICATES" section for more information on predicates. 201<dt><b>TEST-ID "</b><i>identifier</i>" 202<dd style="margin-left: 5.0em">Specifies an identifier string for the current test. 203<dt><b>TRANSFER auto</b> 204<dd style="margin-left: 5.0em">Specifies that this test will use "Transfer-Encoding: chunked" if it has an attached file or "Content-Length:" otherwise. 205<dt><b>TRANSFER chunked</b> 206<dd style="margin-left: 5.0em">Specifies that this test will use the HTTP/1.1 "Transfer-Encoding: chunked" header. 207<dt><b>TRANSFER length</b> 208<dd style="margin-left: 5.0em">Specifies that this test will use the HTTP/1.0 "Content-Length:" header. 209<dt><b>VERSION 1.0</b> 210<dd style="margin-left: 5.0em"><dt><b>VERSION 1.1</b> 211<dd style="margin-left: 5.0em"><dt><b>VERSION 2.0</b> 212<dd style="margin-left: 5.0em"><dt><b>VERSION 2.1</b> 213<dd style="margin-left: 5.0em"><dt><b>VERSION 2.2</b> 214<dd style="margin-left: 5.0em">Specifies the IPP version number to use for this test. 215</dl> 216<h3><a name="EXPECT_PREDICATES">Expect Predicates</a></h3> 217The following predicates are understood following the <b>EXPECT</b> test directive: 218<dl class="man"> 219<dt><b>COUNT </b><i>number</i> 220<dd style="margin-left: 5.0em">Requires the <b>EXPECT</b> attribute to have the specified number of values. 221<dt><b>DEFINE-MATCH </b><i>variable-name</i> 222<dd style="margin-left: 5.0em">Defines the variable to "1" when the <b>EXPECT</b> condition matches. A side-effect of this predicate is that this <b>EXPECT</b> will never fail a test. 223<dt><b>DEFINE-NO-MATCH </b><i>variable-name</i> 224<dd style="margin-left: 5.0em">Defines the variable to "1" when the <b>EXPECT</b> condition does not match. A side-effect of this predicate is that this <b>EXPECT</b> will never fail a test. 225<dt><b>DEFINE-VALUE </b><i>variable-name</i> 226<dd style="margin-left: 5.0em">Defines the variable to the value of the attribute when the <b>EXPECT</b> condition matches. A side-effect of this predicate is that this <b>EXPECT</b> will never fail a test. 227<dt><b>IF-DEFINED </b><i>variable-name</i> 228<dd style="margin-left: 5.0em">Makes the <b>EXPECT</b> conditions apply only if the specified variable is defined. 229<dt><b>IF-NOT-DEFINED </b><i>variable-name</i> 230<dd style="margin-left: 5.0em">Makes the <b>EXPECT</b> conditions apply only if the specified variable is not defined. 231<dt><b>IN-GROUP </b><i>tag</i> 232<dd style="margin-left: 5.0em">Requires the <b>EXPECT</b> attribute to be in the specified group tag. 233<dt><b>OF-TYPE </b><i>tag[|tag,...]</i> 234<dd style="margin-left: 5.0em">Requires the <b>EXPECT</b> attribute to use one of the specified value tag(s). 235<dt><b>REPEAT-LIMIT </b><i>number</i> 236<dd style="margin-left: 5.0em"><br> 237Specifies the maximum number of times to repeat if the <b>REPEAT-MATCH</b> or <b>REPEAT-NO-MATCH</b> predicate is specified. The default value is 1000. 238<dt><b>REPEAT-MATCH</b> 239<dd style="margin-left: 5.0em"><dt><b>REPEAT-NO-MATCH</b> 240<dd style="margin-left: 5.0em">Specifies that the current test should be repeated when the <b>EXPECT</b> condition matches or does not match. 241<dt><b>SAME-COUNT-AS </b><i>attribute-name</i> 242<dd style="margin-left: 5.0em">Requires the <b>EXPECT</b> attribute to have the same number of values as the specified parallel attribute. 243<dt><b>WITH-ALL-HOSTNAMES "</b><i>literal string</i><b>"</b> 244<dd style="margin-left: 5.0em"><dt><b>WITH-ALL-HOSTNAMES "/</b><i>regular expression</i><b>/"</b> 245<dd style="margin-left: 5.0em">Requires that all URI values contain a matching hostname. 246<dt><b>WITH-ALL-RESOURCES "</b><i>literal string</i><b>"</b> 247<dd style="margin-left: 5.0em"><dt><b>WITH-ALL-RESOURCES "/</b><i>regular expression</i><b>/"</b> 248<dd style="margin-left: 5.0em">Requires that all URI values contain a matching resource (including leading /). 249<dt><b>WITH-ALL-SCHEMES "</b><i>literal string</i><b>"</b> 250<dd style="margin-left: 5.0em"><dt><b>WITH-ALL-SCHEMES "/</b><i>regular expression</i><b>/"</b> 251<dd style="margin-left: 5.0em">Requires that all URI values contain a matching scheme. 252<dt><b>WITH-ALL-VALUES "</b><i>literal string</i><b>"</b> 253<dd style="margin-left: 5.0em">Requires that all values of the <b>EXPECT</b> attribute match the literal string. Comparisons are case-sensitive. 254<dt><b>WITH-ALL-VALUES <</b><i>number</i> 255<dd style="margin-left: 5.0em"><dt><b>WITH-ALL-VALUES =</b><i>number</i> 256<dd style="margin-left: 5.0em"><dt><b>WITH-ALL-VALUES ></b><i>number</i> 257<dd style="margin-left: 5.0em"><dt><b>WITH-ALL-VALUES </b><i>number</i>[<i>,...,number</i>] 258<dd style="margin-left: 5.0em">Requires that all values of the <b>EXPECT</b> attribute match the number(s) or numeric comparison. When comparing rangeOfInteger values, the "<" and ">" operators only check the upper bound of the range. 259<dt><b>WITH-ALL-VALUES "false"</b> 260<dd style="margin-left: 5.0em"><dt><b>WITH-ALL-VALUES "true"</b> 261<dd style="margin-left: 5.0em">Requires that all values of the <b>EXPECT</b> attribute match the boolean value given. 262<dt><b>WITH-ALL-VALUES "/</b><i>regular expression</i><b>/"</b> 263<dd style="margin-left: 5.0em">Requires that all values of the <b>EXPECT</b> attribute match the regular expression, which must conform to the POSIX regular expression syntax. Comparisons are case-sensitive. 264<dt><b>WITH-HOSTNAME "</b><i>literal string</i><b>"</b> 265<dd style="margin-left: 5.0em"><dt><b>WITH-HOSTNAME "/</b><i>regular expression</i><b>/"</b> 266<dd style="margin-left: 5.0em">Requires that at least one URI value contains a matching hostname. 267<dt><b>WITH-RESOURCE "</b><i>literal string</i><b>"</b> 268<dd style="margin-left: 5.0em"><dt><b>WITH-RESOURCE "/</b><i>regular expression</i><b>/"</b> 269<dd style="margin-left: 5.0em">Requires that at least one URI value contains a matching resource (including leading /). 270<dt><b>WITH-SCHEME "</b><i>literal string</i><b>"</b> 271<dd style="margin-left: 5.0em"><dt><b>WITH-SCHEME "/</b><i>regular expression</i><b>/"</b> 272<dd style="margin-left: 5.0em">Requires that at least one URI value contains a matching scheme. 273<dt><b>WITH-VALUE "</b><i>literal string</i><b>"</b> 274<dd style="margin-left: 5.0em">Requires that at least one value of the <b>EXPECT</b> attribute matches the literal string. Comparisons are case-sensitive. 275<dt><b>WITH-VALUE <</b><i>number</i> 276<dd style="margin-left: 5.0em"><dt><b>WITH-VALUE =</b><i>number</i> 277<dd style="margin-left: 5.0em"><dt><b>WITH-VALUE ></b><i>number</i> 278<dd style="margin-left: 5.0em"><dt><b>WITH-VALUE </b><i>number</i>[<i>,...,number</i>] 279<dd style="margin-left: 5.0em">Requires that at least one value of the <b>EXPECT</b> attribute matches the number(s) or numeric comparison. When comparing rangeOfInteger values, the "<" and ">" operators only check the upper bound of the range. 280<dt><b>WITH-VALUE "false"</b> 281<dd style="margin-left: 5.0em"><dt><b>WITH-VALUE "true"</b> 282<dd style="margin-left: 5.0em">Requires that at least one value of the <b>EXPECT</b> attribute matches the boolean value given. 283<dt><b>WITH-VALUE "/</b><i>regular expression</i><b>/"</b> 284<dd style="margin-left: 5.0em">Requires that at least one value of the <b>EXPECT</b> attribute matches the regular expression, which must conform to the POSIX regular expression syntax. Comparisons are case-sensitive. 285<dt><b>WITH-VALUE-FROM </b><i>attribute-name</i> 286<dd style="margin-left: 5.0em">Requires that the value(s) of the <b>EXPECT</b> attribute matches the value(s) in the specified attribute. 287For example, "EXPECT job-sheets WITH-VALUE-FROM job-sheets-supported" requires that the "job-sheets" value is listed as a value of the "job-sheets-supported" attribute. 288</dl> 289<h3><a name="STATUS_PREDICATES">Status Predicates</a></h3> 290The following predicates are understood following the <b>STATUS</b> test directive: 291<dl class="man"> 292<dt><b>DEFINE-MATCH </b><i>variable-name</i> 293<dd style="margin-left: 5.0em">Defines the variable to "1" when the <b>STATUS</b> matches. A side-effect of this predicate is that this <b>STATUS</b> will never fail a test. 294<dt><b>DEFINE-NO-MATCH </b><i>variable-name</i> 295<dd style="margin-left: 5.0em">Defines the variable to "1" when the <b>STATUS</b> does not match. A side-effect of this predicate is that this <b>STATUS</b> will never fail a test. 296<dt><b>IF-DEFINED </b><i>variable-name</i> 297<dd style="margin-left: 5.0em">Makes the <b>STATUS</b> apply only if the specified variable is defined. 298<dt><b>IF-NOT-DEFINED </b><i>variable-name</i> 299<dd style="margin-left: 5.0em">Makes the <b>STATUS</b> apply only if the specified variable is not defined. 300<dt><b>REPEAT-LIMIT </b><i>number</i> 301<dd style="margin-left: 5.0em"><br> 302Specifies the maximum number of times to repeat. The default value is 1000. 303<dt><b>REPEAT-MATCH</b> 304<dd style="margin-left: 5.0em"><dt><b>REPEAT-NO-MATCH</b> 305<dd style="margin-left: 5.0em">Specifies that the current test should be repeated when the response status-code matches or does not match the value specified by the STATUS directive. 306</dl> 307<h3><a name="OPERATION_CODES">Operation Codes</a></h3> 308Operation codes correspond to the hexadecimal numbers (0xHHHH) and names from RFC 8011 and other IPP extension specifications. Here is a complete list of names supported by 309<b>ipptool</b>(8): 310<pre class="man"> 311 312 Activate-Printer 313 CUPS-Accept-Jobs 314 CUPS-Add-Modify-Class 315 CUPS-Add-Modify-Printer 316 CUPS-Authenticate-Job 317 CUPS-Delete-Class 318 CUPS-Delete-Printer 319 CUPS-Get-Classes 320 CUPS-Get-Default 321 CUPS-Get-Devices 322 CUPS-Get-Document 323 CUPS-Get-PPD 324 CUPS-Get-PPDs 325 CUPS-Get-Printers 326 CUPS-Move-Job 327 CUPS-Reject-Jobs 328 CUPS-Set-Default 329 Cancel-Current-Job 330 Cancel-Job 331 Cancel-Jobs 332 Cancel-My-Jobs 333 Cancel-Subscription 334 Close-Job 335 Create-Job 336 Create-Job-Subscriptions 337 Create-Printer-Subscriptions 338 Deactivate-Printer 339 Disable-Printer 340 Enable-Printer 341 Get-Job-Attributes 342 Get-Jobs 343 Get-Notifications 344 Get-Printer-Attributes 345 Get-Printer-Support-Files 346 Get-Printer-Supported-Values 347 Get-Subscription-Attributes 348 Get-Subscriptions 349 Hold-Job 350 Hold-New-Jobs 351 Identify-Printer 352 Pause-Printer 353 Pause-Printer-After-Current-Job 354 Print-Job 355 Print-URI 356 Promote-Job 357 Purge-Jobs 358 Release-Held-New-Jobs 359 Release-Job 360 Renew-Subscription 361 Reprocess-Job 362 Restart-Job 363 Restart-Printer 364 Resubmit-Job 365 Resume-Job 366 Resume-Printer 367 Schedule-Job-After 368 Send-Document 369 Send-Hardcopy-Document 370 Send-Notifications 371 Send-URI 372 Set-Job-Attributes 373 Set-Printer-Attributes 374 Shutdown-Printer 375 Startup-Printer 376 Suspend-Current-Job 377 Validate-Document 378 Validate-Job 379</pre> 380<h3><a name="STATUS_CODES">Status Codes</a></h3> 381Status codes correspond to the hexadecimal numbers (0xHHHH) and names from RFC 8011 and other IPP extension specifications. Here is a complete list of the names supported by 382<b>ipptool</b>(8): 383<pre class="man"> 384 385 client-error-account-authorization-failed 386 client-error-account-closed 387 client-error-account-info-needed 388 client-error-account-limit-reached 389 client-error-attributes-not-settable 390 client-error-attributes-or-values-not-supported 391 client-error-bad-request 392 client-error-charset-not-supported 393 client-error-compression-error 394 client-error-compression-not-supported 395 client-error-conflicting-attributes 396 client-error-document-access-error 397 client-error-document-format-error 398 client-error-document-format-not-supported 399 client-error-document-password-error 400 client-error-document-permission-error 401 client-error-document-security-error 402 client-error-document-unprintable-error 403 client-error-forbidden 404 client-error-gone 405 client-error-ignored-all-notifications 406 client-error-ignored-all-subscriptions 407 client-error-not-authenticated 408 client-error-not-authorized 409 client-error-not-found 410 client-error-not-possible 411 client-error-print-support-file-not-found 412 client-error-request-entity-too-large 413 client-error-request-value-too-long 414 client-error-timeout 415 client-error-too-many-subscriptions 416 client-error-uri-scheme-not-supported 417 cups-error-account-authorization-failed 418 cups-error-account-closed 419 cups-error-account-info-needed 420 cups-error-account-limit-reached 421 cups-see-other 422 redirection-other-site 423 server-error-busy 424 server-error-device-error 425 server-error-internal-error 426 server-error-job-canceled 427 server-error-multiple-document-jobs-not-supported 428 server-error-not-accepting-jobs 429 server-error-operation-not-supported 430 server-error-printer-is-deactivated 431 server-error-service-unavailable 432 server-error-temporary-error 433 server-error-version-not-supported 434 successful-ok 435 successful-ok-but-cancel-subscription 436 successful-ok-conflicting-attributes 437 successful-ok-events-complete 438 successful-ok-ignored-notifications 439 successful-ok-ignored-or-substituted-attributes 440 successful-ok-ignored-subscriptions 441 successful-ok-too-many-events 442</pre> 443<h3><a name="TAGS">Tags</a></h3> 444Value and group tags correspond to the names from RFC 8011 and other IPP extension specifications. Here are the group tags: 445<pre class="man"> 446 447 document-attributes-tag 448 event-notification-attributes-tag 449 job-attributes-tag 450 operation-attributes-tag 451 printer-attributes-tag 452 subscription-attributes-tag 453 unsupported-attributes-tag 454</pre> 455<p>Here are the value tags: 456<pre class="man"> 457 458 admin-define 459 boolean 460 charset 461 collection 462 dateTime 463 default 464 delete-attribute 465 enum 466 integer 467 keyword 468 mimeMediaType 469 nameWithLanguage 470 nameWithoutLanguage 471 naturalLanguage 472 no-value 473 not-settable 474 octetString 475 rangeOfInteger 476 resolution 477 textWithLanguage 478 textWithoutLanguage 479 unknown 480 unsupported 481 uri 482 uriScheme 483</pre> 484<h3><a name="VARIABLES">Variables</a></h3> 485The 486<b>ipptool</b>(8) 487program maintains a list of variables that can be used in any literal string or attribute value by specifying "<i>$variable-name</i>". Aside from variables defined using the <i>-d</i> option or <b>DEFINE</b> directive, the following pre-defined variables are available: 488<dl class="man"> 489<dt><b>$$</b> 490<dd style="margin-left: 5.0em">Inserts a single "$" character. 491<dt><b>$ENV[</b><i>name</i><b>]</b> 492<dd style="margin-left: 5.0em">Inserts the value of the named environment variable, or an empty string if the environment variable is not defined. 493<dt><b>$date-current</b> 494<dd style="margin-left: 5.0em">Inserts the current date and time using the ISO-8601 format ("yyyy-mm-ddThh:mm:ssZ"). 495<dt><b>$date-start</b> 496<dd style="margin-left: 5.0em">Inserts the starting date and time using the ISO-8601 format ("yyyy-mm-ddThh:mm:ssZ"). 497<dt><b>$filename</b> 498<dd style="margin-left: 5.0em">Inserts the filename provided to 499<b>ipptool</b>(8) 500with the <i>-f</i> option. 501<dt><b>$filetype</b> 502<dd style="margin-left: 5.0em">Inserts the MIME media type for the filename provided to 503<b>ipptool</b>(8) 504with the <i>-f</i> option. 505<dt><b>$hostname</b> 506<dd style="margin-left: 5.0em">Inserts the hostname from the URI provided to 507<b>ipptool</b>(8). 508<dt><b>$job-id</b> 509<dd style="margin-left: 5.0em">Inserts the last "job-id" attribute value returned in a test response or 0 if no "job-id" attribute has been seen. 510<dt><b>$job-uri</b> 511<dd style="margin-left: 5.0em">Inserts the last "job-uri" attribute value returned in a test response or an empty string if no "job-uri" attribute has been seen. 512<dt><b>$notify-subscription-id</b> 513<dd style="margin-left: 5.0em">Inserts the last "notify-subscription-id" attribute value returned in a test response or 0 if no "notify-subscription-id" attribute has been seen. 514<dt><b>$port</b> 515<dd style="margin-left: 5.0em">Inserts the port number from the URI provided to 516<b>ipptool</b>(8). 517<dt><b>$resource</b> 518<dd style="margin-left: 5.0em">Inserts the resource path from the URI provided to 519<b>ipptool</b>(8). 520<dt><b>$scheme</b> 521<dd style="margin-left: 5.0em">Inserts the scheme from the URI provided to 522<b>ipptool</b>(8). 523<dt><b>$uri</b> 524<dd style="margin-left: 5.0em">Inserts the URI provided to 525<b>ipptool</b>(8). 526<dt><b>$uriuser</b> 527<dd style="margin-left: 5.0em">Inserts the username from the URI provided to 528<b>ipptool</b>(8), 529if any. 530<dt><b>$user</b> 531<dd style="margin-left: 5.0em">Inserts the current user's login name. 532</dl> 533<h2 class="title"><a name="SEE_ALSO">See Also</a></h2> 534<b>ipptool</b>(1), 535IANA IPP Registry (<a href="http://www.iana.org/assignments/ipp-registrations)">http://www.iana.org/assignments/ipp-registrations)</a>, 536PWG Internet Printing Protocol Workgroup (<a href="http://www.pwg.org/ipp)">http://www.pwg.org/ipp)</a>, 537RFC 8011 (<a href="http://tools.ietf.org/html/rfc8011">http://tools.ietf.org/html/rfc8011</a>) 538<h2 class="title"><a name="COPYRIGHT">Copyright</a></h2> 539Copyright © 2007-2019 by Apple Inc. 540 541</body> 542</html> 543