|  | 
| META TOPICPARENT | name="IvoaGridAndWebServices" |   UWS v1.1 Proposed Recommendation: Request for Comments Public discussion page for the IVOA UWS 1.1 Proposed Recommendation.
The latest version of the UWS Specification can be found at: Reference Interoperable Implementations Would the implementors of the UWS 1.1 specification please add details; or, please remove your implementation from this list if not correct. CDS / GAVO Implementation (Grégory Mantelet)  Please, report any bug and/or missing feature you may found while testing it!  This beta version supports the following UWS1.1 features: 
 
  The new execution phase: ARCHIVED.   
 since no standard way is described in the UWS1.1 document to set a job into this phase, the library proposes 3 policies:  
 never (at destruction the job is just destroyed completely),
 when the job reaches the destructionTime
 and whenever the job is asked to be destroyed for the first time.
 an archived job can be destroyed as any other job
 an HTTP-GET request on /{jobs} does not list by default archived jobs ; it is therefore possible using job list filter (see below)
 no result is retained in this phase. But input files and error summary are kept.
 the former execution phase (i.e. the phase in which the job was before being ARCHIVED) is kept as additional information in the jobInfo XML node under the name "oldPhase" (this is hardcoded in the library, but it may be changed at any moment before the stable release if anyone notifies me on time) 
 
 Job list filters: PHASE, LAST and AFTER.  
 several PHASE filter may be specified ; if more than one is provided, all jobs in one of the given phase are returned (i.e. UNION of all PHASE filters).
 using the PHASE filter with the value ARCHIVED is the only way to get the archived jobs
 the LAST and AFTER filters work on the starting time (and not on the creation time as it could be intuitively expected)
 only one AFTER filter is expected ; if several are provided, only the one with the most recent date is kept (which actually is the same as taking into account all AFTER filters)
 only one LAST filter is expected ; if several are provided, only the one with the smallest value is kept (here again, it has actually the same behaviour as considering all LAST filters)
 LAST is the only filter which performs a sorting of jobs ; sort by ascending starting time (from the first to the last started job ; from the oldest to the newest)
 these 3 filters may be provided in the same time so that cumulating their effect
 the character case (upper/lower/mixed case) is not important
 
 Blocking behaviour for /{jobs}/{job-id} with the parameter WAIT and PHASE.  
 WAIT is mandatory and is taken into account by the library only if an integer value is provided
 special values for WAIT are: 0=no blocking, <0=unlimited blocking time and >0=waiting time in seconds
 if several WAIT parameters are provided, only the one equivalent to the smallest waiting time is kept
 PHASE is optional, but if provided it represents the phase in which the job MUST be when the blocking is asked ; if not in the specified phase, no blocking is performed
 if several PHASE parameters are provided, only the last legal occurrence is taken into account
 
 Version attribute in the XML nodes <jobs> and <job> when they are the root document: version="1.1"
 
IMPORTANT NOTE: the XML schema for the XML representation of all UWS objects MUST be updated when the document goes into the "Recommended" state.
-- GregoryMantelet - 2015-10-30
Response to the above question:
According to the recently published XML schema versioning document http://ivoa.net/documents/Notes/XMLVers/20151029/NOTE-schemaVersioning-1.0-20151029.html#tth_sEc3, the document located at
http://www.ivoa.net/xml/UWS/v1.0
should remain as it is (UWS 1.0 stuff only), but a modified 'filename' URL will exist at:
http://www.ivoa.net/xml/UWS/UWS-v1.0.xsd
that has the "version=1.1" attribute within and the additions brought above by the 1.1 specification.
-- BrianMajor - 2016-03-11 The new optional attributes "mime-type" and "size" for the XML nodes <result>
  VO Paris Implementation (Mathieu Servillat)  CADC Implementation (Pat Dowler) CADC has implemented all new features introduced UWS 1.1 for all their UWS-based services including TAP: GAVO uws-client Implementation (Kristin Riebe, Adrian Partl)  | 
|
| < <
 | The uws-client at https://github.com/aipescience/uws-client is a Python tool to interact with UWS-services from the command line. We are implementing the UWS1.1 features; support for server-side PHASE-filtering (UWS standard section 2.2.2.1), including ARCHIVED-phase is already included as well as the WAIT keyword (with optional PHASE added) for the new blocking behaviour. The new "version" attribute is parsed, the client switches from the new server-side filtering to default client-side phase-filtering, if the version attribute is missing or not set to 1.1. Filtering using AFTER and LAST keywords was added in branch 21_job_list_filter. | 
| > >
 | The uws-client at https://github.com/aipescience/uws-client is a Python tool to interact with UWS-services from the command line. We implemented the new UWS1.1 features, i.e. support for server-side PHASE-filtering (UWS standard section 2.2.2.1), including ARCHIVED-phase, WAIT keyword (with optional PHASE added) for the new blocking behaviour. The new "version" attribute is parsed, the client switches from the new server-side filtering to default client-side phase-filtering, if the version attribute is missing or not set to 1.1. Filtering using AFTER and LAST keywords was added as well. | 
|  |  | 
|
| < <
 | Example usage (using gaia.aip.de as example UWS1.1 service): | 
| > >
 | Example usage (using gaia.aip.de as example UWS1.1 service): | 
|
| < <
 |  | 
|  |  | 
|
| > >
 | The newest updates (sort by creationTime, optional runId, ownerId and creationTime in shortjob-description of the job list) are supported in the version of branch uws11_update. | 
|  |  | 
|
| > >
 | -- KristinRiebe - 2016-03-31 | 
|  |  AIP Daiquiri - update to UWS 1.1 (Kristin Riebe)  | 
|
| < <
 | I've updated our web application Daiquiri to include all (mandatory) UWS 1.1 extensions. It's not a full TAP server, it only supports UWS with a MySQL server in the background. The source code is available at https://github.com/aipescience/daiquiri/tree/uws_1_1. You can test it live at https://gaia.aip.de/uws/query, using the test user I just created with username: uwstest, password: gavo, or register for your own account. This allows you to test it e.g. withhttpielike this: | 
| > >
 | I've updated our web application Daiquiri to include all (mandatory) UWS 1.1 extensions. It's not a full TAP server, it only supports UWS with a MySQL server in the background. The source code is available at https://github.com/aipescience/daiquiri/. You can test it live at https://gaia.aip.de/uws/query, using the test user I just created with username: uwstest, password: gavo, or register for your own account. This allows you to test it e.g. withhttpielike this: | 
|
| < <
 |  | 
|  | 
 http --auth uwstest:gavo "https://gaia.aip.de/uws/query?LAST=10"
 http --auth uwstest:gavo "https://gaia.aip.de/uws/query?PHASE=ERROR&PHASE=PENDING"
 http --auth uwstest:gavo "https://gaia.aip.de/uws/query?PHASE=ERROR&PHASE=PENDING&LAST=5"This will remove all pending jobs from the list, since they do not have a startTime-value (LAST returns the most recently started jobs!)
 http --auth uwstest:gavo "https://gaia.aip.de/uws/query?AFTER=2015-10-26T20:00"
 | 
|
| < <
 | 
 http --auth uwstest:gavo --form --follow POST https://gaia.aip.de/uws/query query="SELECT * FROM GUMS10.Galaxies LIMIT 10"This creates a new pending job. Use it's jobid in the next two steps.
 | 
| > >
 | 
 http --auth uwstest:gavo --form --follow POST https://gaia.aip.de/uws/query query="SELECT * FROM GUMS10.Galaxies LIMIT 10"This creates a new pending job. Use its jobid in the next two steps.
 | 
|  |  | 
|
| < <
 | Notes on implementation: I like the new filter mechanisms and think they are really useful. AFTER and LAST were a bit unclear because they sort by startTime; PENDING and QUEUED jobs and those aborted at these phases do not have a startTime value. Now they are just ignored. I'd like to have a sort by 'creationTime' in the future for these cases. The repeated PHASES keyword caused trouble with standard PHP query parsing (it usually expects PHASE[]=...&PHASE[]=... if values shall be appended), but I solved this by parsing the request parameters manually. The service only returns 1000 jobs by default, but does not do a LAST-redirect since it would then lose all PENDING and QUEUED jobs in the job list. See grid mailing list for more discussions on AFTER/LAST. | 
| > >
 | Notes on implementation: I like the new filter mechanisms and think they are really useful. AFTER and LAST were a bit unclear because they sorted by startTime; PENDING and QUEUED jobs and those aborted at these phases do not have a startTime value, so they were just ignored. | 
|  |  | 
|
| > >
 | This is now improved since sorting is done by a newly introduced 'creationTime'. -- KristinRiebe - 2016-03-31
The repeated PHASES keyword caused trouble with standard PHP query parsing (it usually expects PHASE[]=...&PHASE[]=... if values shall be appended), but I solved this by parsing the request parameters manually. The service only returns 1000 jobs by default, redirect with LAST still needs to be implemented. 
Our datetimes are not returned in UTC, but with timezone; if UWS will require UTC datetimes in the future, I will adjust this. -- KristinRiebe - 2016-03-31 | 
|  |  TOPCAT/STILTS The asynchronous TAP clients in topcat and stilts (prerelease available) now use the blocking behaviour (?WAIT=-1&PHASE...=) rather than repeated polls, for TAP services which identify themselves as UWS1.1 using theversionattribute in the<job>document. This has been tested against Gregory Mantelet's TAP service implementation, and seems to be working fine. -- MarkTaylor - 2015-12-07 Implementations Validators Validator's for UWS 1.1: | 
|
| < <
 | 
 GAVO uws-validator: It's rather a definition of tests for checking the new functionality of UWS 1.1, i.e. mainly job list filtering and blocking behaviour. It is using behave (Python pacakge) and a definition of features and steps for testing the behaviour of UWS services. Some tests may still fail if I defined them too strict. Especially blocking behaviour may not behave as expected, my tests would fail but the service would still be valid. Tested with AIP's Daiquiri service (e.g. gaia.aip.de) and Gregory's TAP service at mintaka. Here are configuration files for these services: userconfig-gaia-aip.json (AIP Daiquiri service),  userconfig-gaia-mintaka.json (CDS/GAVO TAP service).They can be used like this (needs additional installation of behave first):
 | 
| > >
 | 
 GAVO uws-validator: It's rather a definition of tests for checking the new functionality of UWS 1.1, i.e. mainly job list filtering and blocking behaviour. It is using behave (Python pacakge) and a definition of features and steps for testing the behaviour of UWS services. Some tests may still fail if I defined them too strict. Especially blocking behaviour may not behave as expected: my tests would fail but the service would still be valid. Tested with AIP's Daiquiri service (e.g. gaia.aip.de) and Gregory's TAP service at mintaka. Here are configuration files for these services: userconfig-gaia-aip.json (AIP Daiquiri service),  userconfig-gaia-mintaka.json (CDS/GAVO TAP service).They can be used like this (needs additional installation of behave first):
 | 
|  | 
 CADC (and others?) have UWS 1.0 validators that still pass:
 
 For UWS 1.0 services only: behave -D configfile="userconfig-gaia-mintaka.json" --no-skipped --tags=-uws1_1
 For the new UWS 1.1 functionality, excluding slow tests (waiting a long time): behave -D configfile="userconfig-gaia-mintaka.json" --no-skipped --tags=-slow --tags=-neverending
 Any questions and comments are welcome! (Kristin Riebe, GAVO)
 
Please add your validator (even if 1.0) if applicable. taplint TAP validator within stilts does non-exhaustive validation of the UWS v1.0 functionality of a TAP service: job submission, lifecycle tracking, deletion, job document parsing etc. See UWS Stage. If someone can point me at a running UWS 1.1-compliant TAP service (minimum: WAIT-blocking and job documents labelled version='1.1') I'll try to update the validation for it. -- MarkTaylor - 2015-07-03 ... OK, there is one now, action on me to update the validator -- MarkTaylor - 2015-12-07 I'm removing this action on me :-), since UWS blocking is hard to validate, as it's defined to be backward-compatible and can always behave as if it was non-blocking -- MarkTaylor - 2016-02-17  RFC Review Period: 2015-06-30 - 2015-08-18  TCG Review Period: 2015-09-09 - 2015-10-07  Comments from the IVOA Community during RFC period: 2015-06-30 - 2015-08-18 (Still) a good clearly written document. One or two minor comments/suggestions:
* Notation: I don't understand the usage of curly and round brackets in referencing URL path elements. For instance in sec 2.1.11 I see: "/{jobs}/{job-id}/parameters/(parameter-name)", and in sec 2.2: "/(jobs)/(jobid)", and in sec 2.2.1.1: "/{jobs}/(job-id)". Are () and {} doing different, ahem, jobs here? If not, can you just pick one or the other?
-- MarkTaylor - 2015-07-02 -- Replies PaulHarrison - 2015-09-03
Thanks Paul - fixes all look good. -- MarkTaylor - 2015-09-11
Regarding the new job query capability in Sec 2.2.2.1, it feels like  
 there is no significance in the different types of braces - I have made them all curly.
 Sec 1.3: "an XML document (e.g. ADQL, CEA [harrison05])" - is it anachronistic to refer to ADQL in this context since post-ADQL-2.0 there is no ADQL/X representation?  
 I think you are right - I have removed it
 Sec 2.1: A count indicator ("1") is missing from the Job-Owner link in the UML diagram  
 you are right - and quote should be 0..1
 Sec 2.1.3: The phases "HELD", "SUSPENDED" and "ARCHIVED" do not appear in the diagram.  
 I had not added these in the past as I thought it would complicate the diagram, as the conditions for transition into those states are more complex - you are probably right that they should be included though, and I have produced a version with them all in.
 Sec 2.2: "future versions of this document will add other bindings such as SOAP." Really?  
 highly unlikely - I have made the statement less precise about which binding may be added.
 Sec 2.2: "an non-existant job id" -> "a non-existent job-id"   
 Sec 2.2.1.1: "it should not return a response (i.e. block)" is a bit ambiguous. Prefer "it should not return a response (i.e. it should block)"?   
 Sec 2.2.1.1: "/{jobs}/(job-id)?WAIT&PHASE=QUEUED": I think it has to be "WAIT=<value>" not just "WAIT"?   
 Sec 4.2: "ADQL [1] can serve as a JDL." - bibliography referencing is wrong.   
 Sec 4.3: "Call it CEA v2 to distinguish it from CEA v1 as currently maintained by AstroGrid." - it's a bit anachronistic.  
 changed wording to make it clear that AstroGrid is no longer active
 Sec 4.3: "The JDL in CEA v2 is similar to that in CEA v1 It is a formal ..." - missing full stop   
 Sec 4.3: "the emerging XForms technology" - is it still emerging?  
 not really - have updated wording.
 Schema: versionattribute to be made optional? (see schema evolution discussion)
 done in latest version of document and schema
 we are creating yet another query syntax with new keywords. To be
 concrete, I would change the examples to
 
"QUERY" and "TOP" come from TAP, "STARTTIME" comes from the UWS /{jobs}?QUERY=PHASE=EXECUTING
 /{jobs}?QUERY=STARTTIME>2014-09-10T10:01:02.000
 /{jobs}?QUERY=TOP+100
 SCHEMA. For now, the spec will only specify simple queries. So there
 will be only one parameter in QUERY. But this allows future
 expansion, so a more sophisticated service could allow full SQL
 
Whilst I would normally be a strong advocate of trying to reuse existing syntax and not do re-invention, in this case the filtering capability is not intended to be a full query language for jobs. I think that your suggestions start to introduce the full query language approach which has the following disadvantages /{jobs}?QUERY=(PHASE=EXECUTING+OR+PHASE=COMPLETED+OR+PHASE=SUSPENDED)+AND+STARTTIME>2014-09-10+ORDER+BY+ENDTIME
 
It is for these reasons that I think that the "parameterized filter" style is more appropriate to a 1.1 update - if it turns out that there is demand for sophisticated querying then we can include a full ADQL query and associated schema in 2.0 - however in truth , I am still skeptical, as a UWS client should most of the time be keeping a local list of JOBIDs for the jobs that it submits and do all "queries" directly using the JOBID. The filtering mechanism in 1.1 is there just to make it easier for generic admin style web clients to not get overwhelmed with a long list of JOBs More effort has to be made in defining the query language than the current standard does - e.g. TOP in ADQL does not imply any ordering - by using the "keyword" style filtering that the current document specifies exactly what LAST means - so to be consistent with ADQL the "query language" should be something like /{jobs}?QUERY=TOP+100+ORDER+BY+STARTTIME+DES
 There is a greater burden on the implementors to do the query parsing.
 
  Comments from TCG members during the TCG Review Period: 2015-09-09 - 2015-10-07 WG chairs or vice chairs must read the Document, provide comments if any and formally indicate if they approve or do not approve of the Standard.
IG chairs or vice chairs are also encouraged to do the same, although their inputs are not compulsory. TCG Chair & Vice Chair ( _Matthew Graham, Pat Dowler )  Applications Working Group ( _Pierre Fernique, Tom Donaldson )  Data Access Layer Working Group ( François Bonnarel, Marco Molinaro )  Data Model Working Group ( _Mark Cresitello-Dittmar, Laurent Michel )  Grid & Web Services Working Group ( Brian Major, Giuliano Taffoni ) I approve this document.
-- BrianMajor - 2016-03-11 Registry Working Group ( _Markus Demleitner, Theresa Dower ) p.7, paragraph "ARCHIVED: At...": I believe "but the metadata associated with the job must be retained" was actually intended to be "but the metadata associated with the job have been retained" (or I don't get what this is intended to say).
p.9, "Indicated in the job XML as a Nill element": I believe this should be "Nil" and that the double l in "nillable" is just morphological reduplication. (Also, Quote one paragraph down has "nil" with one l and in lower case; whatever you choose, it should be consistent) agreed - changed in latest version
 
2.1.11 I thought that during RFC I had ranted somewhere to the effect that one single way to change parameters should be made "canoical" and the other deprecated. This would greatly help the implementation of UWS generic clients. I still believe this would have been a good thing, though I admit introducing such a change during TCG review might be inapproriate.
2.2.1 .../quote now returns an ISO timestamp. This differs from REC-1.0, where it returns an integer number of seconds. Since I'm not aware of any client making good use of quote and few servers actually returning something meaningful there, I'd not consider this serious, 2.0-justifying breaking the standard, but it should certainly be noted in the change log. Incidentally, I'd rather reference DALI here, since the ISO standard actually allows an almost infinite number of serialisations, so standards trolls might be tempted to play games with the current formulation. have used xsi:nil in both places to be more precise about what is meant.
 
On p. 11 it says "This URI should be given as the access URL in the UWS registration," but then no further comment is made on how such a registration might actually look like. To foster registration of UWS services, I would volunteer to contribute an informative appendix with a sample registry record for a UWS service.
Relatedly, I should have intervened a bit earlier because there's actually stuff a special UWS capability should note (support for ARCHIVED, perhaps limits on blocking times, plus there's limits on execution duration and retention time as in TAPRegExt...). Actually, I wonder if we shouldn't extend TAPRegExt for that purpose. This would mean adding a couple of (optional) elements and making language and outputFormat optional. If you agree that'd be a good idea unless bad things result, all that it would take was "UWS services SHOULD use TAPRegExt 1.1 capabilities as those become available" somewhere near the existing registration language. actually the description of quote was the biggest inconsistency in REC1.0 - it was an error to descibe it in the table as being integer seconds as in the schema it was xs:dateTime. The text description mentions comparing with the Destruction Time (implying that quote is a dateTime) but in a contadiction also talks of returning a negative value to indicate "don't know"(I will remove this too!). The decision was to clarify in 1.1 and follow the schema - The quote always was intended to be a "wall-clock" time for the server to try to indicate how busy it though it was, however the usual caveat applies that it is almost impossible for a server to provide a reasonable estimate.
 
Has anyone already written a StandardsRegExt record for this standard? If not and no one else steps forward, I volunteer to go ahead and draft one. I am ideologically opposed to having the UWS capability derived from TAPRegExt as TAP derives partly from UWS and I do not like the circular relationships such a derivation would imply. In the original "grand vision" UWS can be used as a generalised pattern for any type of parameterised service beyond simply those that are part of DAL - as such the main piece of metadata for the service would be a reference to the PDL for the service - there was a start made to a specific UWSRegExt quite a time ago 
 
Like Mark, I'd like to see a bit more details on the implementations and where they actually run. I'd also feel much better if the blocking mode were demonstrated with an actual client^W^W^WTOPCAT.
-- MarkusDemleitner - 2015-09-25 replies in bullets -- PaulHarrison - 2015-10-15
*
Given that clients have now demonstrated blocking mode, I approve this document with the caveat that a standards RegExt for UWS needs to be created separately.
-- TheresaDower - 2016-03-17 I think that you may be one of the few people who has the tools available to do this!
  Semantics Working Group ( _Mireille Louys, Alberto Accomazzi ) 1- The last line of the document reads: | 
|
| < <
 | $Revision: 1.27 $ $Date: | 
| > >
 | $Revision: 1.28 $ $Date: | 
|  | 2015-09-02 17:41:42 +0100 (Wed, 02 Sep 2015) $ $HeadURL:
        https://volute.g-vo.org/svn/trunk/projects/grid/uws/doc/UWS.html$
is it needed in the standard document ? 
2- Section 2.2.1.1.Determining the Protocol Version It is not a requirement, but I think that it is useful for a future author to know where the source file is managed - I think that you will see these sorts of references in future in most of the documents that are authored using the IVOATeX preparation system
 refers to the VOSI specification , but the VOSI label not appear
 on the architecture diagram .
 
-- MireilleLouys - 2015-10-31 replies in bullets by PaulHarrison I will update the diagram
  Education Interest Group ( _Massimo Ramella, Sudhanshu Barway )  Time Domain Interest Group ( _John Swinbank, Mike Fitzpatrick )  Data Curation & Preservation Interest Group ( Françoise Genova )  Operations Interest Group ( _Tom McGlynn, Mark Taylor ) As I noted above, this is basically a good document.
However, the Implementations/Validators part of the RFC page still looks to me rather underpopulated for a document in TCG review.
Three implementations are listed, but the implementation authors have not as requested filled in details, so it's not clear what the status of these implementations is, or where to go to see the code or running UWS 1.1 services. In particular, it's important that the implementations conform to the version determination arrangements described in sec 2.2.1.1, which have been revised during this RFC period.
There are no validators listed that test UWS 1.1-specific functionality, partly (in taplint's case at least) because there are no services to validate (if service providers want to blame validators for this chicken-and-egg problem - OK then let me know and I'll write the validation code first).
Since TAP is currently the most important(?) UWS client standard, before recommending approval I'd really like to see a TAP service whose async endpoint implements the new UWS features (I'm especially personally interested in the WAIT blocking in accordance with sections 2.2.1.1 and 2.2.1.2). Possibly there is one out there, but (despite my request in the Implementations Validators section) it's not clear from the information on this page where it can be found. If no TAP service can be persuaded to do that, I'd at least like to see a running UWS service implementing the new features.
-- MarkTaylor - 2015-09-11
I have tested a working implementation of UWS1.1 blocking, against Gregory Mantelet's mintaka TAP service on 2015-12-07. Good! The list of implementations now looks much more healthy too. Ops is now happy to see this progress to REC. -- MarkTaylor - 2016-02-17 Knowledge Discovery in Databases Interest Group ( George Djorgovski )  Theory Interest Group ( _Franck Le Petit, Carlos Rodrigo )  Standards and Processes Committee ( Françoise Genova) 
 <-- --> 
| META FILEATTACHMENT | attachment="userconfig-gaia-mintaka.json" attr="" comment="" date="1456302914" name="userconfig-gaia-mintaka.json" path="userconfig-gaia-mintaka.json" size="743" user="KristinRiebe" version="1" |  
| META FILEATTACHMENT | attachment="userconfig-gaia-aip.json" attr="" comment="" date="1456303205" name="userconfig-gaia-aip.json" path="userconfig-gaia-aip.json" size="720" user="KristinRiebe" version="1" |  |