-
Notifications
You must be signed in to change notification settings - Fork 15
Advanced Features
The TimeGate can easily be used as a TimeMap server too.
For that there are two requirements:
- The Handler must implement the
get_all_mementos(uri_r)
function to return the entire history of an Original Resource. - The
conf/config.ini
file must have the variableuse_timemap = true
.
Once this setup is in place, the TimeGate responses' Link
header will contain two new relations:
<HOST/timemap/link/URI-R>; rel="timemap"; type="application/link-format"
<HOST/timemap/json/URI-R>; rel="timemap"; type="application/json"
Where HOST
is the base URI of the program and URI-R
is the URI of the Original Resource.
When a user requests an HTTP GET
on those links, the TimeGate will serve regular Memento TimeMaps and JSON TimeMaps respectively.
For example, suppose http://www.example.com/resourceA
is the URI-R of an Original Resource.
And suppose the TimeGate/TimeMap server's host
configuration is set to http://timegate.example.com
Then, HTTP responses from the TimeGate will include the following:
<http://timegate.example.com/timemap/link/http://www.example.com/resourceA>; rel="timemap"; type="application/link-format"
<http://timegate.example.com/timemap/json/http://www.example.com/resourceA>; rel="timemap"; type="application/json"
Custom error messages can be sent to the client using the custom exception module:
from errors.timegateerrors import HandlerError
.
For instance, a custom message with HTTP status 400
and body Custom error message
can be sent using:
raise HandlerError("Custom error message", status=400)
.
Raising a HandlerError
will stop the request and not return any Memento to the client.