A set of runtime extensions of Invenio repository
Project description
OARepo runtime
The base of invenio oarepo
client and a set of classes/functions that help with code-generated features:
Custom fields
Provides support for custom fields identification and iteration and invenio oarepo cf init
initialization tool for customfields.
Expansions
Provides expandable field implementation and service mixin for referenced record (in case you do not want to use relations).
Facets
An implementation of nested labeled facet.
i18n
Validator for language codes.
Relations
Replacement of Invenio relations. Fixes the following issues:
- Invenio relations can occur only on specific paths and for each pattern, different class must be used (Relation, ListRelation, NestedListRelation)
- PID Cache is isolated per request, not set directly on field
- Allows to map keys - A key from related object can be renamed/remapped to a different key/path
- Provides classes to reference parts of the same record
# article, id 12
metadata:
title: blah
with mapping referenced article would look like (mapping: {key: 'metadata.title', target: 'title'}
):
# dataset:
metadata:
articles:
- id: 12
@v: 1
title: blah
With Invenio PID relation, it would be:
# dataset:
metadata:
articles:
- id: 12
"@v": 1
metadata:
title: blah
Validation
This module provides a marshmallow validator for date strings.
Config
Provides interface and definitions for loading preconfigured permission sets to service config.
ICU sort and suggestions
To use ICU sort and suggestion custom fields, provide the following configuration
to oarepo-model-builder
(or put this stuff to your custom superclasses).
record:
imports:
- import: invenio_records_resources.records.api.Record
alias: InvenioRecord
- import: oarepo_runtime.records.SystemFieldDumperExt
- import: oarepo_runtime.records.icu.ICUSortField
- import: oarepo_runtime.records.icu.ICUSuggestField
extra-code: |-2
# extra custom fields for testing ICU sorting and suggesting
sort = ICUSortField(source_field="metadata.title")
suggest = ICUSuggestField(source_field="metadata.title")
search-options:
base-classes:
- I18nSearchOptions
imports:
- import: oarepo_runtime.services.icu.I18nSearchOptions
- import: oarepo_runtime.services.icu.ICUSuggestParser
- import: oarepo_runtime.services.icu.ICUSortOptions
sort-options-field: extra_sort_options
extra-code: |-2
suggest_parser_cls = ICUSuggestParser("records2")
sort_options = ICUSortOptions("records2")
record-dumper:
extensions:
- SystemFieldDumperExt()
Run invenio oarepo cf init
to initialize custom fields,
invenio oarepo index reindex
if you already have data
inside the repository and from this moment on,
/records?sort=title
and /records?suggest=abc
should work
Command-line utils
invenio oarepo version
Prints a json with versions of all installed packages. Format:
{
"package_name": "package_version",
"package_name2": "package_version2",
...
}
invenio oarepo check
Checks the repository if it has access to all infrastructure components and that they have been initialized correctly.
Call as invenio oarepo check -
or invenio oarepo check <output-file>
.
Will print/write to file a json with the following format:
{
"db": "ok|connection_error|not_initialized|migration_pending",
"opensearch": "ok|connection_error|index_missing:<index_name>",
"files": "ok|db_connection_error|default_location_missing|bucket_does_not_exist:<bucket_name>|db_error",
"mq": "ok|connection_error|mq_error",
"cache": "ok|connection_error|cache_error|cache_exception",
"configuration": {
// contains the configuration from the flask app
"key": "value",
"key2": "value2",
...
}
}
Project details
Release history Release notifications | RSS feed
Download files
Download the file for your platform. If you're not sure which to choose, learn more about installing packages.
Source Distribution
Built Distribution
File details
Details for the file oarepo_runtime-1.5.68.tar.gz
.
File metadata
- Download URL: oarepo_runtime-1.5.68.tar.gz
- Upload date:
- Size: 77.1 kB
- Tags: Source
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/5.1.1 CPython/3.12.7
File hashes
Algorithm | Hash digest | |
---|---|---|
SHA256 | 0ad99b30509858c0a0318c965e2bb6948765ea3eba0700b94aa118fb6abe3c99 |
|
MD5 | a6de760ecb9e394f44b64cf9eaef9f1b |
|
BLAKE2b-256 | 88725faad08201e1c88029c46782d14c9eed60e40f4df6d03d773ce66483b91d |
File details
Details for the file oarepo_runtime-1.5.68-py3-none-any.whl
.
File metadata
- Download URL: oarepo_runtime-1.5.68-py3-none-any.whl
- Upload date:
- Size: 114.8 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/5.1.1 CPython/3.12.7
File hashes
Algorithm | Hash digest | |
---|---|---|
SHA256 | 59c263dfdc25351750b221a90b81ffa54d8fd5a9b1b53c594f0b808bb2de67c2 |
|
MD5 | f3ec166876a716b39a478caab0bbc169 |
|
BLAKE2b-256 | dc915ebc0b1f9c8ccdcf09539362ade914ad62b0d036712dc3cfa98796b99f0d |