Skip to content

W3C web annotation search using the IIIF content search API

Notifications You must be signed in to change notification settings

nationalarchives/annosearch

Repository files navigation

Annotation Search

AnnoSearch

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.

Tutorial

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"
    }
  ]
}

Usage

Make sure you have Quickwit installed and running and then install AnnoSearch.

npm install -g annosearch

Commands

init

Initialize a new index with a specified ID.

annosearch init --index <index-id>

load

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

Delete an existing index by ID.

annosearch delete --index <index-id>

search

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.

serve

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.

version

Display the current version of AnnoSearch.

annosearch version

Configuration

Configure AnnoSearch by setting the following environment variables:

  • ANNOSEARCH_MAX_HITS: Maximum number of search results per query.

    • Default: 20
  • ANNOSEARCH_PORT: Port on which AnnoSearch runs.

    • Default: 3000
  • ANNOSEARCH_HOST: Host on which AnnoSearch runs.

    • Default: localhost
  • ANNOSEARCH_PUBLIC_URL: URL for public-facing server requests.

    • Default: http://localhost:3000

Adjust these values as needed to customize AnnoSearch’s configuration and behavior.

Todo

  • Implement the autocomplete service
  • Implement extended API responses

License

This project is licensed under the MIT License.

About

W3C web annotation search using the IIIF content search API

Topics

Resources

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published