layout | title | permalink |
---|---|---|
page |
OpenLink Transformers for generating RDF |
/openlink-rdf-generators/ |
As per the transformer specification a GET request will return an RDF description of the transformer.
curl -i "http://fusepool.openlinksw.com/ext/csv"
The following examples uses the following two CVS files which you should download to the folder in which you're executing the cURL commands:
The following cURL invocation will post the data
curl -i -H "Content-Type: text/csv" -H "Accept: text/turtle" -H "Content-Location: http://fusepool.openlinksw.com/pub" --data-binary @pubs.csv -X POST "http://fusepool.openlinksw.com/ext/csv"
curl -i -H "Content-Type: text/csv" -H "Accept: application/rdf+xml" -H "Content-Location: http://fusepool.openlinksw.com/accommodation" --data-binary @accommodations.csv -X POST "http://fusepool.openlinksw.com/ext/csv"
Note 1: Use of 'Accept' and 'Content-Location' headers is optional. The fall-backs are 'text/turtle' and 'http://fusepool.openlinksw.com/entity'.
Note 2: Even if the call is to a synchronous Transformer, it may internally decide that the time to process is large and start the transformation in an asynchronous mode. This means that you will need an additional GET request to get the transformation result like in the followng section.
The transformer http://fusepool.openlinksw.com/ext-async/csv
alway handles requests asynchronously and can thus be used to try out the asynchronous transformation mode.
No difference here....
curl -i "http://fusepool.openlinksw.com/ext-async/csv"
The transformation of the data requires two steps, POSTing the data and GETting the result:
curl -i -H "Content-Type: text/csv" -H "Accept: text/turtle; q=1.0, application/rdf+xml; q=0.9, application/ld+json; q=0.8" -H "Content-Location: http://fusepool.openlinksw.com/pub" --data-binary @pubs.csv -X POST "http://fusepool.openlinksw.com/ext-async/csv"
curl -i -H "Content-Type: text/csv" -H "Accept: text/turtle; q=0.8, application/rdf+xml; q=1.0, application/ld+json; q=0.9" -H "Content-Location: http://fusepool.openlinksw.com/accommodation" --data-binary @accommodations.csv -X POST "http://fusepool.openlinksw.com/ext-async/csv"
The answer to the request will look similar to this:
HTTP/1.1 202 Accepted
Server: Virtuoso/07.10.3211 (Linux) x86_64-redhat-linux-gnu VDB
Connection: Keep-Alive
Content-Type: text/html; charset=UTF-8
Date: Thu, 30 Oct 2014 11:59:38 GMT
Accept-Ranges: bytes
Location: /ext-async/status/29
Content-Length: 0
Note: Use of 'Accept' and 'Content-Location' headers is optional. The fall-backs are 'text/turtle' and 'http://fusepool.openlinksw.com/entity'.
The results can be retrieved at the location indicated by the Location-Header in the response to the POST request.
curl -i "http://fusepool.openlinksw.com/ext-async/status/29"