Overview
Implementation
The oai_repo
module requires you first define an implementation of the
oai_repo.DataInterface
class, filling out functionality for all the
functions within. You can name your implementation class whatever you'd like.
import oai_repo
class MyOAIData(oai_repo.DataInterface):
def get_identify(self):
ident = oai_repo.Identify()
... # fill in the Identify data
return ident
def get_record_header(self, identifier):
rechead = oai_repo.RecordHeader()
... # fill in the RecordHeader data
return rechead
... # fill in the remaining methods
You can feel free to add additional attributes and methods to your implementation,
but at minimum you will need to complete all the methods from DataInterface
.
# Example of adding extra custom attributes and methods to your implementation
class MyOAIData(oai_repo.DataInterface):
...
identifier_transform = oai_repo.helpers.Transform(...)
def localid(self, identifier):
"""Custom method to convert OAI identifer to localid"""
return self.identifier_transform.forward(identifier)
def identifier(self, localid):
"""Custom method to convert from localid to OAI identifier"""
return self.identifier_transform.reverse(localid)
Processing Requests
A good first step is to just implement the get_identify()
method and test that
before working on the completing the entire DataInterface
implementation.
To run your OAI repository, you'll need to pass your custom class into
oai_repo.OAIRepository
, which will serve as your OAI request processor.
# args = { 'verb': 'Identify' }
try:
repo = oai_repo.OAIRepository(MyOAIData())
response = repo.process(args)
except oai_repo.OAIRepoExternalException as exc:
# An API call timed out or returned a non-200 HTTP code.
# Log the failure and abort with server HTTP 503.
except oai_repo.OAIRepoInternalException as exc:
# There is a fault in how the DataInterface was implemented.
# Log the failure and abort with server HTTP 500.
Once you have the response, you can check if the result is an OAIError or not using a boolean check. You don't have to treat OAIError responses any differently than a successful response, it is already a well formed XML OAI compliant response, but this is an easy way to check nonetheless.
To retrieve the response as XML (an lxml.etree._Element
specifically),
use the root()
method.
To get the raw response as bytes, just cast it as bytes()
.
At this point, you can take the response data and return it to the client, or pass it back to whatever web framework you're using. That's it!
Reference for OAIRepository
and OAIResponse
are below, but be sure to read
through the Implementation Classes documentation for
insight on how to create your customized DataInterface
class.
OAIRepository(data: DataInterface)
The primary OAI repository class which processes requests and returns responses.
Initialize OAIRepository by passing in an implementation of the DataInterface class.
Parameters:
Name | Type | Description | Default |
---|---|---|---|
data
|
DataInterface
|
The implemented data class |
required |
process(request: dict) -> OAIResponse
Given request arguments, route to appropriate action, process the request and return a response.
Parameters:
Name | Type | Description | Default |
---|---|---|---|
request
|
dict
|
The request arguments |
required |
Returns:
Type | Description |
---|---|
OAIResponse
|
An completed OAIResponse |
Raises:
Type | Description |
---|---|
OAIRepoInternalException
|
When resp creation fails due to code or API misconfiguration. |
OAIRepoExternalException
|
When resp creation fails due to an external API call. |
OAIResponse
Base class for OAI responses
__bool__()
__bytes__()
root() -> etree.Element
Return the root lxml.etree.Element.
xpath(query: str) -> etree.Element
Return results of an xpath query from the root element.