Code source de geonature.core.command.main

"""
    Entry point for the command line 'geonature'
"""

import logging
from os import environ
from collections import ChainMap

import toml
import click
from flask.cli import run_command

from geonature.utils.env import GEONATURE_VERSION, ROOT_DIR
from geonature.utils.module import iter_modules_dist
from geonature import create_app
from geonature.utils.config import config
from geonature.utils.config_schema import GnGeneralSchemaConf, GnPySchemaConf
from geonature.utils.command import (
    create_frontend_module_config,
    build_frontend,
)
from os.path import join
import glob

from flask.cli import FlaskGroup


[docs] log = logging.getLogger()
[docs] def normalize(name): return name.replace("_", "-")
@click.group( cls=FlaskGroup, create_app=create_app, context_settings={"token_normalize_func": normalize}, ) @click.version_option(version=GEONATURE_VERSION) @click.pass_context
[docs] def main(ctx): pass
@main.command() @click.option("--host", default="0.0.0.0") @click.option("--port", default=8000) @click.pass_context
[docs] def dev_back(ctx, host, port): """ Lance l'api du backend avec flask Exemples - geonature dev_back - geonature dev_back --port=8080 --port=0.0.0.0 """ if not environ.get("FLASK_DEBUG"): environ["FLASK_DEBUG"] = "true" ctx.invoke( run_command, host=host, port=port, extra_files=[file for file in glob.glob(join(ROOT_DIR, "config", "*.toml"))], )
@main.command() @click.argument("module_code") @click.option( "--output", "output_file", type=click.File("w"), )
[docs] def generate_frontend_module_config(module_code, output_file): """ Génère la config frontend d'un module Example: - geonature generate-frontend-module-config OCCTAX """ create_frontend_module_config(module_code, output_file) click.echo( "Configuration générée. Pensez à rebuilder le frontend pour la production.", err=True )
@main.command() @click.option("--modules", type=bool, required=False, default=True) @click.option("--build", type=bool, required=False, default=True)
[docs] def update_configuration(modules, build): """ Régénère la configuration du front et lance le rebuild. """ click.echo("Génération de la configuration du frontend :") click.echo(" GeoNature … ", nl=False) click.secho("OK", fg="green") if modules: for dist in iter_modules_dist(): module_code = dist.entry_points["code"].load() click.echo(f" Module {module_code} … ", nl=False) if module_code in config["DISABLED_MODULES"]: click.secho("désactivé, ignoré", fg="white") continue create_frontend_module_config(module_code) click.secho("OK", fg="green") if build: click.echo("Rebuild du frontend …") build_frontend() click.secho("Rebuild du frontend terminé.", fg="green")
@main.command()
[docs] def default_config(): """ Afficher l’ensemble des paramètres et leur valeur par défaut. """ required_fields = ( "URL_APPLICATION", "API_ENDPOINT", "SECRET_KEY", "SQLALCHEMY_DATABASE_URI", ) backend_defaults = GnPySchemaConf().load({}, partial=required_fields) frontend_defaults = GnGeneralSchemaConf().load({}, partial=required_fields) defaults = ChainMap(backend_defaults, frontend_defaults) print(toml.dumps(defaults))
@click.argument("key", type=str, required=False) @main.command()
[docs] def get_config(key=None): """ Afficher l’ensemble des paramètres """ printed_config = config.copy() if key: try: printed_config = printed_config[key] except KeyError: click.secho(f"The key {key} does not exist in config", fg="red") return if type(printed_config) is dict: print(toml.dumps(printed_config)) else: print(printed_config)