The locator resolver is a service provided by the streamer that can take a location as an input and resolve it by providing a Locator Object as its output.
It is based on the list of locations as defined in the main locators document on this repo.
The service is exposed in the manifest using a Link Object.
It can be identified by:
- its media-type:
application/vnd.readium.locator-resolver+json
- its relationship:
http://readium.org/locator-resolver
{
"href": "https://example.com/resolve{?href,cfi,id,position,progression}",
"type": "application/vnd.readium.locator-resolver+json",
"rel": "http://readium.org/locator-resolver",
"templated": true
}
In order to use the location resolver, a client must send a location to the service using the appropriate query parameters.
Locations can be broken down into two categories:
- global locations (
position
andprogression
) for which a single query parameter is required - local locations (
cfi
andid
) for which the request must include both a reference to the resource (href
) along with a location
If the location can be resolved, the service returns a Locator Object.
GET https://example.com/resolver?position=27
{
"href": "http://example.com/chapter2",
"locations": {
"cfi": "/4[body01]",
"position": 27,
"progression": 0.07289
},
"text": {
"before": "This is the text before the position",
"after": "and this is the text after it."
}
}
If the service can't locate the location requested by a client, it returns a 404 status code.