Skip to main content

An utility library that generates OARepo required data model files from a JSON specification file

Project description

OARepo model builder

Work in progress

A library and command-line tool to generate invenio model project from a single model file.

CLI Usage

To use the model builder client, you first have to install the model builder somewhere.

Installing model builder as dev dependency

Initialize your new project with poetry create and then add model builder with poetry add --dev oarepo-model-builder. This is the simplest solution but has a disadvantage - as poetry always installs dev dependencies in build & test, but not in production, in your development environment you will have extra packages installed. If you happen to use them, you will break your production build.

Installing model builder in a separate virtualenv

Create a separate virtualenv and install model builder into it:

python3.10 -m venv .venv-builder
(source .venv-builder/bin/activate; pip install -U pip setuptools wheel; pip install oarepo-model-builder)

Then for ease of use add the following aliases

alias oarepo-compile-model="$PWD/.venv-builder/bin/oarepo-compile-model"
alias oarepo-model-builder-pip="$PWD/.venv-builder/bin/pip"

Use the oarepo-model-builder-pip if you need to install plugins to the model builder.

Running model builder

oarepo-compile-model model.yaml

will compile the model.yaml into the current directory. Options:

  --output-directory <dir> Output directory where the generated files will be
                           placed. Defaults to "."
  --package <name>         Package into which the model is generated. If not
                           passed, the name of the current directory,
                           converted into python package name, is used.
  --set <name=value>       Overwrite option in the model file. 
                           Example --set settings.elasticsearch.keyword-ignore-above=20
  -v                       Increase the verbosity. This option can be used
                           multiple times.
  --config <filename>      Load a config file and replace parts of the model
                           with it. The config file can be a json, yaml or a
                           python file. If it is a python file, it is
                           evaluated with the current model stored in the
                           "oarepo_model" global variable and after the
                           evaluation all globals are set on the model.
  --isort / --skip-isort   Call isort on generated sources (default: yes)
  --black / --skip-black   Call black on generated sources (default: yes)

Model file

A model is a json/yaml file including description of the model and processing settings. Example:

version: 1.0.0
oarepo:use: invenio
model:
  properties:
    metadata:
      properties:
        title:
          type: fulltext+keyword
          oarepo:ui:
            label: Title
          oarepo:mapping:
          # anything in here will be put into the mapping file
          # fulltext+keyword type automatically creates "type: text" 
          # with subfield 'keyword' of type keyword
settings:
  package: uct.titled_model 

Model file structure

A model is a json/yaml file with the following structure:

version: 1.0.0
model:
  properties:
    title:
      type: fulltext+keyword
settings:
  <generic settings here>
  python: ...
  elasticsearch: ...
plugins: ...

There might be more sections (documentation etc.), but only the settings, model and plugins are currently processed.

"model" section

This section is described in model.md

"settings" section

The settings section contains various configuration settings. In most cases you want to set only the package option as in above because all other settings are derived from it. Even the package option might be omitted - in this case the package name will be the last component of the output directory (with dashes converted to underscores).

The rest of the settings are described in model-generic-settings.md

Advanced use cases might require to modify the python settings or elasticsearch settings (for example, to define custom analyzers).

"plugins" section

See plugins and the processing order for details.

Builder as a library (using via API)

To invoke the builder programmatically, see using the API.

Writing custom plugins

See writing plugins if you want to extend the building process with your own plugins.

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

oarepo-model-builder-1.0.0.dev5.tar.gz (53.1 kB view details)

Uploaded Source

Built Distribution

If you're not sure about the file name format, learn more about wheel file names.

oarepo_model_builder-1.0.0.dev5-py3-none-any.whl (90.5 kB view details)

Uploaded Python 3

File details

Details for the file oarepo-model-builder-1.0.0.dev5.tar.gz.

File metadata

  • Download URL: oarepo-model-builder-1.0.0.dev5.tar.gz
  • Upload date:
  • Size: 53.1 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/3.8.0 pkginfo/1.8.2 readme-renderer/34.0 requests/2.27.1 requests-toolbelt/0.9.1 urllib3/1.26.8 tqdm/4.63.0 importlib-metadata/4.11.3 keyring/23.5.0 rfc3986/2.0.0 colorama/0.4.4 CPython/3.9.10

File hashes

Hashes for oarepo-model-builder-1.0.0.dev5.tar.gz
Algorithm Hash digest
SHA256 e16de1b211407cb3a53a42e1af094c83b596cae26950ddf901aba941c2ab0baf
MD5 6497f2ccffaefce8231c06e424088ca5
BLAKE2b-256 46edfa92b7c68acb42020e282cbf5608d1ea4b36d833eb918a63579f86b9415a

See more details on using hashes here.

File details

Details for the file oarepo_model_builder-1.0.0.dev5-py3-none-any.whl.

File metadata

  • Download URL: oarepo_model_builder-1.0.0.dev5-py3-none-any.whl
  • Upload date:
  • Size: 90.5 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/3.8.0 pkginfo/1.8.2 readme-renderer/34.0 requests/2.27.1 requests-toolbelt/0.9.1 urllib3/1.26.8 tqdm/4.63.0 importlib-metadata/4.11.3 keyring/23.5.0 rfc3986/2.0.0 colorama/0.4.4 CPython/3.9.10

File hashes

Hashes for oarepo_model_builder-1.0.0.dev5-py3-none-any.whl
Algorithm Hash digest
SHA256 42e704d317e9b30a4b3442c804e2ce430fe81cf165c0ae6ab1521e7cb4a0c02a
MD5 3341345284a007fe1060008d6eaf6294
BLAKE2b-256 999c28215a05c8269068a039d9f18d6d5870cec2bfd52cc32f10ba10b518b15c

See more details on using hashes here.

Supported by

AWS Cloud computing and Security Sponsor Datadog Monitoring Depot Continuous Integration Fastly CDN Google Download Analytics Pingdom Monitoring Sentry Error logging StatusPage Status page