AnnoSearch uses Quickwit as its backend database to efficiently index and query W3C Web Annotation data. AnnoSearch can ingest data directly from IIIF resources such as IIIF collections and web annotation servers such as Miiify and make it available to IIIF viewers through the IIIF Content Search 2.0 API. Annosearch supports type-safe ingestion using the Maniiifest library.
We first need to create an index.
❯ annosearch init --index cookbook
Index created successfully
We can now load the index with the annotations referenced in a IIIF manifest.
❯ annosearch load --index cookbook --type Manifest --uri https://iiif.io/api/cookbook/recipe/0266-full-canvas-annotation/manifest.json
Loading Manifest from https://iiif.io/api/cookbook/recipe/0266-full-canvas-annotation/manifest.json into index cookbook
|+|
After Quickwit finishes ingesting and indexing the data we can perform a search.
❯ annosearch search --index cookbook --query brunnen
{
"@context": "http://iiif.io/api/search/2/context.json",
"id": "http://localhost:3000/cookbook/search?q=brunnen&page=0",
"type": "AnnotationPage",
"startIndex": 0,
"items": [
{
"body": {
"format": "text/plain",
"language": "de",
"type": "TextualBody",
"value": "Göttinger Marktplatz mit Gänseliesel Brunnen"
},
"id": "https://iiif.io/api/cookbook/recipe/0266-full-canvas-annotation/canvas-1/annopage-2/anno-1",
"motivation": "commenting",
"target": {
"id": "https://iiif.io/api/cookbook/recipe/0266-full-canvas-annotation/canvas-1",
"partOf": {
"id": "https://iiif.io/api/cookbook/recipe/0266-full-canvas-annotation/manifest.json",
"type": "Manifest"
}
},
"type": "Annotation"
}
]
}
Make sure you have Quickwit installed and running and then install AnnoSearch.
npm install -g annosearch
Initialize a new index with a specified ID.
annosearch init --index <index-id>
Load an index from a URI, specifying the type of content being loaded (e.g., Manifest, Collection, or AnnotationCollection).
annosearch load --index <index-id> --type <type> --uri <uri>
type
: The type of content (Manifest, Collection, AnnotationCollection).uri
: The URI to load the content from.
Delete an existing index by ID.
annosearch delete --index <index-id>
Perform a search on a specified index.
annosearch search --index <index-id> --query <search-query> [--page <page-number>] [--motivation <motivation>] [--date <date-ranges>] [--user <users>]
query
: A space separated list of search query terms.page
: Optional page number (defaults to 0).motivation
: Optional space separated list of motivation terms.date
: Optional space separated list of date ranges.user
: Optional space separated list of URIs that are the identities of users.
Start a web server that provides a search service using the IIIF Content Search 2.0 API.
annosearch serve --port <port> --host <host>
port
: The port on which to run the server.host
: The host on which to run the server.
Display the current version of AnnoSearch.
annosearch version
Configure AnnoSearch by setting the following environment variables:
-
ANNOSEARCH_MAX_HITS
: Maximum number of search results per query.- Default:
20
- Default:
-
ANNOSEARCH_PORT
: Port on which AnnoSearch runs.- Default:
3000
- Default:
-
ANNOSEARCH_HOST
: Host on which AnnoSearch runs.- Default:
localhost
- Default:
-
ANNOSEARCH_PUBLIC_URL
: URL for public-facing server requests.- Default:
http://localhost:3000
- Default:
Adjust these values as needed to customize AnnoSearch’s configuration and behavior.
- Implement the autocomplete service
- Implement extended API responses
This project is licensed under the MIT License.