Perseus is working towards making all of its data available according to Linked Data Best Practices. Our first step towards that is to publish stable URIs for citations and texts. These URIs leverage Canonical Text Services URNs, enabling us to take advantage of the CTS data model while still supporting Linked Data standards.
All Perseus data URIs are published under the http://data.perseus.org URI prefix.
Individual citations can be retrieved at URIs which adhere to the following syntax:
http://data.perseus.org/citations/<CTS PASSAGE URN>[/format]
CTS PASSAGE URNs which include subreferences (e.g. urn:cts:greekLit:tlg0012.tlg001.perseus-grc1:1.1@μῆνιν[1]) are not yet supported but will be in the future.
Currently supported data formats for citations are HTML and XML. In the future RDF/XML and JSON-LD may also be supported.
The URI syntax for an entire text, without a citation is
http://data.perseus.orgs/texts/<CTS TEXT URN>[/format]
HTML is the only currently supported format for full text URIs, but the XML format will be available in the future.
Combining CTS and URI standards
This is best illustrated by example.
urn:cts:greekLit:tlg0012.tlg001.perseus-grc1
Identifies the unique resource which is Perseus’ TEI XML version of Homer’s Iliad that is identified in the Perseus CTS inventory as ‘perseus-grc1’. (This TEI XML version was based on the Oxford 1920 edition, which information can currently be found out by looking at the description of the version in the GetCapabilities response, but may soon also be reported in the header of the GetPassage response. But see more below on this topic).
urn:cts:greekLit:tlg0012.tlg001.perseus-grc1:1.1 identifies line 1.1 of this version
If you make a GetPassage request directly to the Perseus CTS API (at http://www.perseus.tufts.edu/hopper/CTS) for this resource you will get back a CTS GetPassage response which contains the TEI XML for line 1.1 of this version.
If you make a GetPassage request directly to the Perseus CTS API (at http://www.perseus.tufts.edu/hopper/CTS) for line 1.1 of the notional work the Iliad (identified by urn:cts:greekLit:tlg0012.tlg001:1.1) you will also get back a CTS GetPassage response which contains the TEI XML for line 1.1 of this same edition, because Perseus has decided to make this specific Greek edition the default version it returns if a version hasn’t specifically been requested. (We don’t currently identify the specific version returned in the GetPassage response, but we will soon).
The stable URI for this specific line of this resource is
http://data.perseus.org/citations/urn:cts:greekLit:tlg0012.tlg001.perseus-grc1:1.1
If your request for this resource includes an HTTP Accept header which includes text/html then the response is currently an HTTP 302 redirect to the HTML display for the page that contains this line of text in the Perseus interface.
If your request for this resource does NOT indicate via its HTTP Accept header that it accepts text/html, then currently the response is an HTTP 200 that contains the results of the CTS GetPassage request, but we will be changing this to be an HTTP 302 redirect to the GetPassage response, in order to be consistent with linked data recommendations.
We also now support the following alternative request syntax for citations which doesn’t require use of the HTTP Accept header:
http://data.perseus.org/citations/urn:cts:greekLit:tlg0012.tlg001.perseus-grc1:1.1/html
http://data.perseus.org/citations/urn:cts:greekLit:tlg0012.tlg001.perseus-grc1:1.1/xml
If you issue a request for a resource via CTS urn that Perseus does NOT have, you will be redirected (via an HTTP 303 See Other redirect) to the Perseus Catalog. If the requested text is available at that urn in the Catalog, then you be brought directly to the corresponding catalog record, which may contain links to other locations at which you can find the actual text (such as the Internet Archive or Google Books, etc.). Although not yet supported, in the future, if you request a text which is not listed in the catalog, you will be offered the opportunity to add bibliographic information and links for that text to the Catalog.
Adding a subreference (e.g. @μῆνιν[1]) to any of the above requests, when supported, won’t change way the redirect to the response happens.
Reference
Stable URIs are also under development for other resources in the Perseus Digital Library. The following table provides a summary.
Entity Type | Urispace | Example | Status |
---|---|---|---|
Person | http://data.perseus.org/people/ | http://data.perseus.org/ people/smith:alexander-1 |
Enabled for Smiths Biography; Others Pending; Support for /xml and /html data format URI extensions also pending. |
Place | http://data.perseus.org/places/ | http://data.perseus.org/ places/smith:alexandreia-2 |
Not yet implemented. |
Artifact | http://data.perseus.org/artifacts/ [sculpture|vase|building|gem|site|coin]/ |
http://data.perseus.org/ artifacts/sculpture/Diadoumenos |
Implemented. Support for /xml and /html and /CIDOC data format URI extensions also pending. |
Lexical | http://data.perseus.org/lexical/ | http://data.perseus.org/lexical/ urn:cite:perseus:lexentity.lex1234 |
Pending |
Citations | http://data.perseus.org/ citations/ |
http://data.perseus.org/citations/ urn:cts:greekLit:tlg0012.tlg001:1.1 |
Beta Implementation. Excludes passage subreferences and not all texts are supported. See CTS API for further details. |
Text | http://data.perseus.org/texts/ | http://data.perseus.org/texts/ urn:cts:greekLit:tlg0012.tlg001.perseus-grc1 |
Implemented, including support for /html format extension. Support for xml format extension pending. |
Annotations | http://data.perseus.org/ annotations/ |
http://data.perseus.org/annotations/ occur/places:pleiades/ urn:cts:greekLit:tlg0551.tlg017.perseus-grc1 |
In Progress. Support for /rdf URI format extension pending. |