Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/gbv/typesense-suggest-backend
Experimental backend for mapping suggestions using Typesense, to be used in Cocoda Mapping Tool.
https://github.com/gbv/typesense-suggest-backend
coli-conc
Last synced: 19 days ago
JSON representation
Experimental backend for mapping suggestions using Typesense, to be used in Cocoda Mapping Tool.
- Host: GitHub
- URL: https://github.com/gbv/typesense-suggest-backend
- Owner: gbv
- License: mit
- Created: 2022-12-06T09:18:07.000Z (about 2 years ago)
- Default Branch: main
- Last Pushed: 2024-12-17T12:24:39.000Z (about 1 month ago)
- Last Synced: 2025-01-06T01:08:23.265Z (19 days ago)
- Topics: coli-conc
- Language: JavaScript
- Homepage:
- Size: 545 KB
- Stars: 0
- Watchers: 2
- Forks: 0
- Open Issues: 0
-
Metadata Files:
- Readme: README.md
- License: LICENSE
Awesome Lists containing this project
README
# typesense-suggest-backend
Backend for mapping suggestions using Typesense, to be used in Cocoda Mapping Tool.Currently not yet stable.
## Requirements
- Node.js 20 or later
- A running [Typesense](https://typesense.org) server (v27)
- Access details need to be configured in `config/config.json`## Setup
```bash
# Install dependencies
npm ci
# Copy and adjust default config
cp config/config.default.json config/config.json
editor config/config.json
# Run setup (always use BARTOC URIs)
# Note: The first run will take a long time as a lot of data will have to be loaded from APIs. However, most data is cached, so subsequent runs will be much faster.# Option 1: Setup each vocabulary separately
# BK
npm run setup "http://bartoc.org/en/node/18785"
# RVK
npm run setup "http://bartoc.org/en/node/533"
# DDC
npm run setup "http://bartoc.org/en/node/241"# Option 2: Provide multiple BARTOC URIs in the `schemes` field in `config/config.json` and run setup without parameters:
npm run setup# Start the server (default port is 3021)
npm run start
```## Usage
The service offers a [jskos-server](https://github.com/gbv/jskos-server) compatible `/search` endpoint. Currently supported query parameters: `voc` (vocabulary URI, required), `search` (search string, required), `limit` (optional), `offset` (optional)
In Cocoda, it can be included as a suggestion registry like this (example for RVK and BK in a local instance):
```json
{
"provider": "LabelSearchSuggestion",
"uri": "http://coli-conc.gbv.de/registry/coli-conc-recommendations-experimental-local",
"schemes": [
{
"uri": "http://bartoc.org/en/node/533"
},
{
"uri": "http://bartoc.org/en/node/18785"
}
],
"overrides": [
{
"uri": "http://bartoc.org/en/node/533",
"identifier": [
"http://uri.gbv.de/terminology/rvk/"
],
"search": "http://localhost:3021/search"
},
{
"uri": "http://bartoc.org/en/node/18785",
"identifier": [
"http://uri.gbv.de/terminology/bk/"
],
"search": "http://localhost:3021/search"
}
],
"notation": [
"CRe"
],
"prefLabel": {
"en": "coli-conc Suggestions (experimental, local)",
"de": "coli-conc Vorschläge (experimentell, lokal)"
}
}
```## To-Dos
### Include Wikidata Mappings
Wikidata mappings could be included, but we need to implement the `download` parameter in [wikidata-jskos](https://github.com/gbv/wikidata-jskos) ([#75](https://github.com/gbv/wikidata-jskos/issues/75)) before we can integrate it here. As soon as that is implemented, all this to the config's `mappingRegistries`:
```json
{
"provider": "MappingsApi",
"uri": "http://coli-conc.gbv.de/registry/wikidata-mappings",
"status": "https://coli-conc.gbv.de/services/wikidata/status"
}
```## License
MIT © 2024 Verbundzentrale des GBV (VZG)