sintonia/shared
jo bcd877266f feat(shared): load env config using jsonschema
The env loader is now capable of loading lists of objects, union types
or list of union types from the env variables.
They are some limitations: for example it doesn't support unions of
different shapes `list | dict` or `str | dict`.
2022-07-31 21:43:34 +02:00
..
libretime_shared feat(shared): load env config using jsonschema 2022-07-31 21:43:34 +02:00
tests feat(shared): load env config using jsonschema 2022-07-31 21:43:34 +02:00
Makefile test(shared): add bandit linter check 2022-02-14 21:01:35 +02:00
README.md feat(shared): remove unused abstract app (#1828) 2022-05-04 14:12:06 +02:00
pyproject.toml test: enable logs when running pytest (#2008) 2022-07-31 11:23:27 +02:00
requirements.txt chore(shared): update pydantic version range 2022-07-17 21:25:37 +02:00
setup.py chore: remove chdir in setup.py files 2022-07-27 15:35:57 +02:00

README.md

Shared

The libretime_shared package contains reusable functions and classes for the LibreTime project.

Usage

This library assumes that:

  • You will use Click to build a CLI for your app.
  • You will use Loguru to log messages from your app.
  • You will use Pydantic to validate objects in your app.

Configuration

First define a schema for your configuration in order to validate it. A schema is a class that inherit from pydantic.BaseModel. Some existing schemas can be reused such as libretime_shared.config.RabbitMQ or libretime_shared.config.Database.

Load your configuration using a subclass of libretime_shared.config.BaseConfig.

from pydantic import BaseModel

from libretime_shared.config import RabbitMQConfig, BaseConfig

class AnalyzerConfig(BaseModel):
    bpm_enabled: bool = False
    bpm_track_max_length: int

class Config(BaseConfig):
    rabbitmq: RabbitMQConfig
    analyzer: AnalyzerConfig

config = Config(filepath="/etc/libretime/config.yml")

Don't instantiate a sub model if it has a required field, otherwise the Config class import will raise a ValidationError.

CLI

Decorate your CLI commands with the shared decorators to add extra flags.

import click
from libretime_shared.cli import cli_logging_options, cli_config_options

from .app import App

@click.group()
def cli():
    pass

@cli.command()
@cli_config_options()
@cli_logging_options()
def run(**kwargs):
    app = App(**kwargs)
    return app.run()