Contents Digital-SNOWTAM Trial Introduction REST Introduction REST in the Digital-SNOWTAM Trial Why it is used Architecture How it is used Example http://en.wikipedia.org/wiki/Representational_State_Transfer AIXM XML Developers' Seminar
Digital-SNOWTAM Trial Introduction
Digital SNOWTAM Trial 2009-2010 SNOWTAM Message Sample 0902020400 ESSA S ESSA S0 C)01L F)71/71/71 G)01/01/01 H)69/63/60 SFH N)71/GOOD C)08 F)71/71/71 G)01/01/01 H)62/65/68 SFH N)71/GOOD C)01R F)71/71/71 G)01/01/01 H)70/66/68 SFH N)71/GOOD R)7/MEDIUM-GOOD T)RWYS AND TWYS CONT 10 PER CENT. APRONS CONT 25 PER CENT Demonstrate xNOTAM benefits to end users -> Airlines Verification of the AIXM 5 Surface Contamination model Continue the testing of Web service standards REST architecture Start work on algorithms and open source code structured SNOWTAM text to AIXM 5 AIXM 5.0 to SNOWTAM text
Scope Execution: Winter 2009-2010 Service provider End user Originator Briefing FPL chart FMS data etc. Originator (Digital NOTAM) End user Pilot Airline OPS ATC etc. Image Text Application AIXM 5 (Digital NOTAM) xNOTAM Trial (origination only) xSNOWTAM Trial (end-to-end)
Trial – application architecture
Digital SNOWTAM Trial (2009-2010)
REST Introduction
REST Representational State Transfer An architectural style A technology agnostic abstraction The Web is RESTful REST Representational State Transfer It is an architectural style. An abstraction that could be implemented with any technology. Some people have made a (weird) proof of concept REST over SOAP implementation. The largest known implementation of a system conforming to the REST architectural style is the World-Wide Web. In fact, REST can be considered as a post-hoc description of the features of the Web that made the Web successful. (OFTEN LEAD TO REStful Web Services E.g. Amazon S3 REST API.) AIXM XML Developers' Seminar
Key principles Identifiable Resources Representations Hypermedia Uniform Interface Actions – Verbs Client-server Transparency and layering Type of data REST is about ***resources***, not services AIXM XML Developers' Seminar
Resources A resource is a real thing that can be acted upon with a request Anything that can be named and identified can be a resource They are found/identified using URIs Unified Resource Identifier = network address ~ URL Collection URI (../airports) Member URI (/airports/732d64d4-cd11) Anything can be a resource (an airport, a runway, a list of taxiways, a book, a shopping cart...) A resource is a real thing that can be acted upon with a request Probably anything that can be converted into an Object (in OO) could be converted into a resource (no one-to-one relationship) These are identified using URIs WIKIPEDIA: Uniform Resource Identifier (URI) is a string of characters used to identify or name a resource on the Internet. In its current strict technical meaning, a URL is a URI that, “in addition to identifying a resource, provides a means of locating the resource by describing its primary access mechanism (e.g., its network ‘location’). AIXM XML Developers' Seminar
Resources and time Resources can vary over time. The only thing that must be static is the semantic of the mapping (name). An id doesn’t identify a particular state of the resource, so subsequent calls to the same resource can give different results, depending on the current state of the resource AIXM XML Developers' Seminar
Representations Resources are always accessed through a representation Captures the current or intended state of the resource There can be more than one (html, xml, pdf…) HTTP provides well known/standardized content types and content negotiation The data transmitted to and from the resource is called a representation. This is a conceptual idea, it means that the server doesn’t send its database, but something that represents one or more records. HTTP/Content-types allows for machine to machine communication. A computer can tell the other one or more representation(s) he is able to process, in which priority, so the server can decide which representation to deliver --- It can be a copy of the file or a description of it. The interaction of the representation on the resource is determined by the verb. AIXM XML Developers' Seminar
Hypermedia Allows access to related resources Master-detail and other connections URIs in hypertext links Links should always be provided by the server Enables seemless evolution and distribution Different application and servers AIXM XML Developers' Seminar
Uniform Interface Once you know a resource’s ID, you can interact with it in a single standard way Limited set of operations (verbs) in HTTP: GET, PUT, POST, DELETE Pre-defined semantics allows for optimizations Resource’s ID is just a like a “void pointer”. You have no idea of what you can do with it. An interface you can rely on, with pre-defined semantics, verbs like get/put a new representation/post. Defined in http specification. Ex: Enables caching. GET is a safe operation. You know you can do 1000s of get without side effect. (obviously, it depends on the implementation, but BaseCamp/Google bot example with links to delete stuff) AIXM XML Developers' Seminar
Actions GET Used to read a resource or as a query Should be side-effect free POST Creates a new resource or invoke arbitrary processing PUT Updates the resource with new data and create it if necessary DELETE Removes the resource AIXM XML Developers' Seminar
Client Server Interactions Interactions in both directions: from and to the server Interactions are stateless: no client context stored on the server between requests Once the resource has been found, an action can be performed. These use the HTTP verbs: GET, PUT, POST and DELETE AIXM XML Developers' Seminar
Transparency / Layering An application can interact with a resource by knowing two things: the identifier of the resource and the action required. That’s all! How the representation is found should be transparent to the user Layered system A client cannot ordinarily tell whether it is connected directly to the end server, or to an intermediary along the way. What happens behind the scenes stays behind the scenes. AIXM XML Developers' Seminar
REST in the Digital-SNOWTAM Trial
Why it is used Support the provision of AIXM 5.1 data to end-user applications The REST interface shall enable digital users to: Query the Digital SNOWTAM database for the list of airports contained in the database and select one of these airports; Get the list of airport’s features for a selected airport; Get the surface contamination records for each such feature; Get the related feature through xlink:href; Get the SNOWTAM text and the free text translation associated with an Airport. Read-Only Except for the list of Airports always returns an AIXM Basic Message which contains features There is no AIXM message yet for list of airports AIXM XML Developers' Seminar
Architecture The REST framework used is Struts 2 REST plugin. See http://struts.apache.org/2.x/docs/rest-plugin.html for more information. http://struts.apache.org/2.x/docs/rest-plugin.html REST plugin in turn uses the Convention plug-in: http://struts.apache.org/2.x/docs/convention-plugin.html AIXM XML Developers' Seminar
Implementation Only GET is needed for the trial. AIXM XML Developers' Seminar
Workflow In order to interrogate the database: request the list of airports select one airport and use the xlink:href to get the details about this airport select a related feature and use the corresponding xlink:href to get the details about it The xlink:href is a URL compliant to the Digital SNOWTAM REST request structure Use the UUID for subsequent calls Xlink href: see Hypermedia. It is generated by the server AIXM XML Developers' Seminar
Base URL Base: http://<server>/<app> E.g. http://l-accept-04.pulsar.be/ec-xsnowtam-rest-accept Then add a Suffix: /<REST suffix> Will work on HTTPS AIXM XML Developers' Seminar
Find Airports Suffix: /airportheliports[?designator=<pattern>] There are about 15000 airports/heliports in the database so… Optional Parameter: The pattern is of the form [A-Z*]{1,4} where * is the wildcard character. Pattern samples: EB* matches any designator beginning with EB *BBR matches any designator ending in BBR E*R matches any designator beginning with E and ending with R The response to this request is not AIXM5.1-compliant since AIXM5.1 doesn’t define the concept of list of airports/heliports. Can add date&time if needed. AIXM XML Developers' Seminar
Query an Airport Suffix: /airportheliports/<gml:identifier>[?features=yes/no&contaminations=yes/no&date=<date&time>] Mandatory parameter: gml:identifier – UUID Optional parameters: date - <date&time> is the search date&time features - specify if xlink:href pointing to related features must be included in the results, e.g. runways, taxiways, etc contaminations - specify if contaminations must be included or not in the result Use the gml identidfier from the Find Airport stage Here are a few remarks valid for all the suffixes described below: date is an optional parameter and <date&time> is the search date&time in the format dd/mm/yyyy hh:mm (e.g.: 11/06/2009 12:35). In each case, the response will be limited to data valid at that date&time. If no date&time is provided, the current date and time is used. features is an optional parameter to specify if xlink:href pointing to related features must be included in the results,e.g. runways, taxiways, apron of an airport or runway directions of a runway. Possible values are yes and no. If missing, no is assumed. contaminations is an optional parameter to specifiy if contaminations must be included or not in the result. Possible values are yes and no. If missing, no is assumed. AIXM XML Developers' Seminar
Examples
1 – Create Contamination Use Bromma to create a contamination AIXM XML Developers' Seminar
2 – Use REST to find the airport http://l-accept-04.pulsar.be/ec-xsnowtam-rest-accept/airportheliports?designator=ESSB <ResultList> <AirportHeliportFeature designator="ESSB" id="77a0de0e-277a-4824-a561-2ba779a3658c" href="http://l-accept-04.pulsar.be/ec-xsnowtam-rest-accept/airportheliports/77a0de0e-277a-4824-a561-2ba779a3658c"/> </ResultList> Use FireFox with text link plug in: https://addons.mozilla.org/en-US/firefox/addon/1939 AIXM XML Developers' Seminar
3 – Find SNOWTAM Text http://l-accept-04.pulsar.be/ec-xsnowtam-rest-accept/airportheliports/77a0de0e-277a-4824-a561-2ba779a3658c?features=yes&contaminations=yes <aixm:annotation> <aixm:Note> <aixm:definition>snowtam-icao</aixm:definition> <aixm:translatedNote> <aixm:LinguisticNote> <aixm:note lang="eng"> SW** ESSB 10090900 (SNOWTAM A)ESSB B)10090900 C)12 F)3/2/2 G)1/1/1 H)2/3/3 BRD ) </aixm:note> </aixm:LinguisticNote> </aixm:translatedNote> </aixm:Note> </aixm:annotation> AIXM XML Developers' Seminar
4 – Get Airport data http://l-accept-04.pulsar.be/ec-xsnowtam-rest-accept/airportheliports/77a0de0e-277a-4824-a561-2ba779a3658c?features=yes … <aixm:associatedRunways> <aixm:associatedRunway id="12/30" xlink:href="http://l-accept-04.pulsar.be/ec-xsnowtam-rest-accept/runways/58ea128d-1bbe-47f6-92fe-a8961b4bf5ee"/> </aixm:associatedRunways> AIXM XML Developers' Seminar
5- Get Runway contamination http://l-accept-04.pulsar.be/ec-xsnowtam-rest-accept/runways/58ea128d-1bbe-47f6-92fe-a8961b4bf5ee?contaminations=yes <aixm:areaContaminant> <aixm:RunwaySectionContamination> <aixm:observationTime>2009-10-09T09:00:00Z</aixm:observationTime> <aixm:depth uom="MM">1</aixm:depth> <aixm:frictionEstimation>MEDIUM</aixm:frictionEstimation> <aixm:frictionDevice>BRD</aixm:frictionDevice> <aixm:obscuredLights>NO</aixm:obscuredLights> <aixm:layer> <aixm:SurfaceContaminationLayer> <aixm:layerOrder>1</aixm:layerOrder> <aixm:type>WATER</aixm:type> </aixm:SurfaceContaminationLayer> </aixm:layer> <aixm:section>2_THIRD</aixm:section> </aixm:RunwaySectionContamination> </aixm:areaContaminant> http://l-accept-04.pulsar.be/ec-xsnowtam-rest-accept/runways/58ea128d-1bbe-47f6-92fe-a8961b4bf5ee?date=9/10/2009%2009:00&contaminations=yes AIXM XML Developers' Seminar
6 - Time based http://l-accept-04.pulsar.be/ec-xsnowtam-rest-accept/runways/58ea128d-1bbe-47f6-92fe-a8961b4bf5ee?date=9/10/2009%2009:00&contaminations=yes AIXM XML Developers' Seminar
AIXM 5.1 TEMPDELTA and a BASELINE AIXM XML Developers' Seminar