attachment
<div dir="ltr"><div><div><div><div>Hi Mike,<br><br></div>Apologies for late response.  Been a busy week.<br><br></div>I like most all of this except for two state names, because they're<br></div><div>obscure.  The Job state 'pending' has fuzzy applicability here.<br></div><div><br></div><div>I suggest states/state reasons:<br><br></div><div>'created' - result of Create-Resource<br></div><div><br>'uploaded' - result of Send-Resource-Data, except when Resource<br></div><div>stays 'created' w/ state reason 'resource-incoming' (like job-incoming<br>in RFC 2911)<br></div><div><br>'installed' - result of Install-Resource, except when Resource <br>stays 'uploaded' w/ state reason 'resource-installed'<br></div><div><br>'canceled' - result of Cancel-Resource, except when Resource<br></div><div>stays 'created/loaded/installed' w/ state reason 'resource-canceled'<br></div><div><br></div>'pending-install' meaning "pending but NOT installed" is not symmetric <br>with 'pending-held' meaning "pending AND held"<br><br></div><div>Comments?<br><br></div><div>Cheers,<br></div><div>- Ira<br><br></div><div>PS - Reasoning behind the 'uploaded' state name is potential<br></div><div>first class Admin operation Send-Resource-URI (for local domain<br></div><div>authenticated Resource upload by reference rather than value).<br><br></div></div><div class="gmail_extra"><br clear="all"><div><div class="gmail_signature" data-smartmail="gmail_signature"><div dir="ltr"><div><div dir="ltr">Ira McDonald (Musician / Software Architect)<br>Co-Chair - TCG Trusted Mobility Solutions WG<br>Chair - Linux Foundation Open Printing WG<br>Secretary - IEEE-ISTO Printer Working Group<br>Co-Chair - IEEE-ISTO PWG Internet Printing Protocol WG<br>IETF Designated Expert - IPP & Printer MIB<br>Blue Roof Music / High North Inc<br><a style="color:rgb(51,51,255)" href="http://sites.google.com/site/blueroofmusic" target="_blank">http://sites.google.com/site/blueroofmusic</a><br><a style="color:rgb(102,0,204)" href="http://sites.google.com/site/highnorthinc" target="_blank">http://sites.google.com/site/highnorthinc</a><br>mailto: <a href="mailto:blueroofmusic@gmail.com" target="_blank">blueroofmusic@gmail.com</a><br>Jan-April: 579 Park Place  Saline, MI  48176  734-944-0094<br>May-Dec: PO Box 221  Grand Marais, MI 49839  906-494-2434<br><br><div style="display:inline"></div><div style="display:inline"></div><div style="display:inline"></div><div></div><div></div><div></div><div></div></div></div></div></div></div>
<br><div class="gmail_quote">On Wed, Aug 24, 2016 at 6:07 PM, Michael Sweet <span dir="ltr"><<a href="mailto:msweet@apple.com" target="_blank">msweet@apple.com</a>></span> wrote:<br><blockquote class="gmail_quote" style="margin:0 0 0 .8ex;border-left:1px #ccc solid;padding-left:1ex">All,<br>
<br>
The following outline summarizes how I see the IPP Resource object working in the System Service specification. Feedback welcome, and we can discuss this at the next regular IPP conference call (Sept 19).<br>
<br>
TL;DR summary: Resource states are 'pending', 'pending-install', 'installed', 'aborted', and 'canceled'. No more "resource-category" attribute. State reasons and status codes for resource format and security errors.<br>
<br>
........<br>
<br>
IPP Resource Object<br>
<br>
IPP Resource objects contain metadata and associated firmware, software, templates, and other static data files.  Resource objects have a simple life cycle: creation, installation, history, and deletion.  Resource objects can be listed (Get-Resources) or queried (Get-Resource-Attributes) until they are deleted by the System.<br>
<br>
<br>
           Table N - IPP Resource Object Operations and Life Cycle<br>
<br>
    Operation                resource-state         resource-state-reasons<br>
    -----------------------  ---------------------  ----------------------<br>
    Create-Resource          'pending' (3)          'resource-incomplete'<br>
<br>
    Send-Resource-Data       'pending' (3)          'none'<br>
                                   OR<br>
                             'aborted' (8)          'resource-xxx-error'<br>
<br>
    Install-Resource         'pending-install' (4)  'none'<br>
                                   OR<br>
                             'installed' (5)        'none'<br>
                                   OR<br>
                             'aborted' (8)          'resource-xxx-error'<br>
<br>
    Cancel-Resource          'canceled' (7)         'none'<br>
                                   OR<br>
                             'installed' (5)        'none'<br>
<br>
    Get-Resources            All States             All Reasons<br>
    Get-Resource-Attributes  All States             All Reasons<br>
<br>
<br>
Resource Creation Phase<br>
<br>
Resources are created using the Create-Resource operation which creates the object and the Send-Resource-Data operation which provides the data for the resource. The state during creation is 'pending' (3). The state after creation is either 'pending' or 'aborted' (8) if the resource data contains errors or if the Send-Resource-Data operation is not done quickly enough.<br>
<br>
<br>
Resource Installation Phase<br>
<br>
Resources are installed using the Install-Resource operation. The state after installation is either 'pending-install' (4) if the Resource data must be installed after a reboot, 'installed' (5) if the Resource data can be installed immediately, or 'aborted' if the Resource data contains errors and cannot be installed.<br>
<br>
<br>
Resource History Phase<br>
<br>
Resources in the history phase of their life cycle are in the 'canceled' or 'aborted' states.<br>
<br>
Resources are aborted by the System when it determines the Resource data contains errors, is missing, or has been replaced.<br>
<br>
Resources are canceled using the Cancel-Resource operation. That state after cancellation is 'canceled' (7) unless the Resource cannot be canceled, such as running firmware that must be replaced before it can be canceled.<br>
<br>
Systems delete Resource data when placing a Resource in the 'canceled' or 'aborted' state. Historical resources MUST be retained in these states for at least 300 seconds before deletion of the Resource object by the System service.<br>
<br>
<br>
Resource Status Attributes<br>
<br>
    date-time-at-creation (dateTime)<br>
    date-time-at-history (dateTime)<br>
    date-time-at-installed (dateTime)<br>
    resource-data-uri (uri | no-value)<br>
    resource-format (mimeMediaType)<br>
    resource-id (integer(1:MAX))<br>
    resource-job-id (integer(1:MAX))<br>
    resource-k-octets (integer(0:MAX))<br>
    resource-printer-id (integer(1:MAX))<br>
    resource-state (type1 enum)<br>
    resource-state-message (text(MAX))<br>
    resource-state-reasons (1setOf type2 keyword)<br>
    resource-string-version (text(MAX))<br>
    resource-type (type2 keyword)<br>
    resource-uuid (uri)<br>
    time-at-creation (integer(MIN:MAX))<br>
    time-at-history (integer(MIN:MAX))<br>
    time-at-installed (integer(MIN:MAX))<br>
<br>
<br>
Resource Description Attributes:<br>
<br>
    resource-info (name(MAX))<br>
    resource-name (name(MAX))<br>
    resource-owner-col (collection)<br>
      owner-uri (uri)<br>
      owner-vcard (1setOf text(MAX))<br>
<br>
<br>
"resource-state" values:<br>
<br>
    - 3 ('pending'): state after creation but before installation<br>
    - 4 ('pending-install'): state after install for resources that require a reboot<br>
    - 5 ('installed'): state when a resource is installed<br>
    - 7 ('canceled'): state when a resource has been canceled by Cancel-Resource operation<br>
    - 8 ('aborted'): state when a resource has been canceled by System service (bad resource, etc.)<br>
<br>
<br>
"resource-state-reasons" values:<br>
<br>
    - 'none': No additional state.<br>
    - 'resource-format-error': The Resource data contains format errors.<br>
    - 'resource-incomplete': The Resource object has been created but no data has been sent.<br>
    - 'resource-security-error': The Resource data's digital signature or other security features could not be verified.<br>
    - 'resource-timeout': The Resource was not installed within the multiple-operation-time-out period.<br>
<br>
"resource-type" values:<br>
<br>
    - 'document': Template for creating Document object.<br>
    - 'firmware': Executable firmware (reboot generally required).<br>
    - 'font': Static font.<br>
    - 'icc-profile': Static ICC profile.<br>
    - 'image': Static image (icon, logo, etc.)<br>
    - 'job': Template for creating Job object.<br>
    - 'software': Executable software/application (reboot generally not required).<br>
    - 'strings': Static message catalog (strings file).<br>
<br>
"status-code" values (and operations that can return them):<br>
<br>
    - 'successful-ok': All<br>
    - 'client-error-bad-request': All<br>
    - 'client-error-forbidden': All<br>
    - 'client-error-not-<wbr>authenticated': All<br>
    - 'client-error-not-authorized': All<br>
    - 'client-error-not-found': Cancel-Resource<br>
    - 'client-error-request-entity-<wbr>too-large': Send-Resource-Data<br>
    - 'client-error-document-format-<wbr>not-supported': Send-Resource-Data<br>
    - 'client-error-attributes-or-<wbr>values-not-supported': Create-Resource<br>
    - 'client-error-charset-not-<wbr>supported': All<br>
    - 'client-error-conflicting-<wbr>attributes': Create-Resource<br>
    - 'client-error-document-<wbr>security-error': Send-Resource-Data, Install-Resource<br>
    - 'server-error-internal-error': All<br>
    - 'server-error-busy': Cancel-Resource, Create-Resource, Send-Resource-Data<br>
    - (NEW) 'server-error-too-many-<wbr>resources': Create-Resource<br>
<br>
______________________________<wbr>___________________________<br>
Michael Sweet, Senior Printing System Engineer<br>
<br>
______________________________<wbr>_________________<br>
ipp mailing list<br>
<a href="mailto:ipp@pwg.org">ipp@pwg.org</a><br>
<a href="https://www.pwg.org/mailman/listinfo/ipp" rel="noreferrer" target="_blank">https://www.pwg.org/mailman/<wbr>listinfo/ipp</a><br>
</blockquote></div><br></div>