clan-config: unbreak + include data files

This commit is contained in:
DavHau
2023-08-09 17:59:07 +02:00
parent 3d3dcc800b
commit f9aaa5ad39
5 changed files with 23 additions and 21 deletions

View File

@@ -1,7 +1,7 @@
import argparse
import sys
from . import admin, secrets
from . import admin, config, secrets
from .errors import ClanError
from .ssh import cli as ssh_cli
@@ -20,12 +20,8 @@ def main() -> None:
parser_admin = subparsers.add_parser("admin")
admin.register_parser(parser_admin)
# Currently broken
# parser_config = subparsers.add_parser("config")
# try:
# config.register_parser(parser_config)
# except subprocess.CalledProcessError as e:
# warn(f"The config command does not work in the nix sandbox: {e}")
parser_config = subparsers.add_parser("config")
config.register_parser(parser_config)
parser_ssh = subparsers.add_parser("ssh", help="ssh to a remote machine")
ssh_cli.register_parser(parser_ssh)

View File

@@ -1,7 +1,6 @@
# !/usr/bin/env python3
import argparse
import json
import os
import subprocess
import sys
from pathlib import Path
@@ -9,7 +8,7 @@ from typing import Any, Optional, Type, Union
from clan_cli.errors import ClanError
CLAN_FLAKE = os.getenv("CLAN_FLAKE")
script_dir = Path(__file__).parent
class Kwargs:
@@ -23,14 +22,14 @@ class Kwargs:
def schema_from_module_file(
file: Union[str, Path] = "./tests/config/example-interface.nix",
file: Union[str, Path] = f"{script_dir}/jsonschema/example-schema.json",
) -> dict[str, Any]:
absolute_path = Path(file).absolute()
# define a nix expression that loads the given module file using lib.evalModules
nix_expr = f"""
let
lib = import <nixpkgs/lib>;
slib = import {CLAN_FLAKE}/lib/jsonschema.nix {{inherit lib;}};
slib = import {script_dir}/jsonschema {{inherit lib;}};
in
slib.parseModule {absolute_path}
"""
@@ -44,7 +43,7 @@ def schema_from_module_file(
def register_parser(
parser: argparse.ArgumentParser,
file: Path = Path("./tests/config/example-interface.nix"),
file: Path = Path(f"{script_dir}/jsonschema/example-schema.json"),
) -> None:
if file.name.endswith(".nix"):
schema = schema_from_module_file(file)
@@ -74,7 +73,8 @@ def _register_parser(
"string": str,
}
parser = argparse.ArgumentParser(description=schema.get("description"))
if parser is None:
parser = argparse.ArgumentParser(description=schema.get("description"))
subparsers = parser.add_subparsers(
title="more options",

View File

@@ -0,0 +1 @@
../../../../lib/jsonschema