Merge pull request 'Refactor(autocompletions): use inventoryStore' (#3927) from hsjobeki/completions into main
Reviewed-on: https://git.clan.lol/clan/clan-core/pulls/3927
This commit is contained in:
@@ -8,7 +8,9 @@ from types import ModuleType
|
||||
from typing import Any
|
||||
|
||||
from clan_lib.cmd import run
|
||||
from clan_lib.flake.flake import Flake
|
||||
from clan_lib.nix import nix_eval
|
||||
from clan_lib.persist.inventory_store import InventoryStore
|
||||
|
||||
"""
|
||||
This module provides dynamic completions.
|
||||
@@ -311,45 +313,11 @@ def complete_tags(
|
||||
flake = clan_dir_result
|
||||
else:
|
||||
flake = "."
|
||||
computed_tags_result = json.loads(
|
||||
run(
|
||||
nix_eval(
|
||||
flags=[
|
||||
f"{flake}#clanInternals.inventory.tags",
|
||||
"--apply",
|
||||
"builtins.attrNames",
|
||||
],
|
||||
),
|
||||
).stdout.strip()
|
||||
)
|
||||
|
||||
tags.extend(computed_tags_result)
|
||||
except subprocess.CalledProcessError:
|
||||
pass
|
||||
|
||||
def run_services_tags_cmd() -> None:
|
||||
services_tags: list[str] = []
|
||||
try:
|
||||
if (clan_dir_result := clan_dir(None)) is not None:
|
||||
flake = clan_dir_result
|
||||
else:
|
||||
flake = "."
|
||||
services_tags_result = json.loads(
|
||||
run(
|
||||
nix_eval(
|
||||
flags=[
|
||||
f"{flake}#clanInternals.inventory.services",
|
||||
],
|
||||
),
|
||||
).stdout.strip()
|
||||
)
|
||||
for service in services_tags_result.values():
|
||||
for environment in service.values():
|
||||
roles = environment.get("roles", {})
|
||||
for role_details in roles.values():
|
||||
services_tags += role_details.get("tags", [])
|
||||
|
||||
tags.extend(services_tags)
|
||||
inventory_store = InventoryStore(Flake(str(flake)))
|
||||
inventory = inventory_store.get_readonly_raw()
|
||||
if "tags" in inventory:
|
||||
tags.extend(inventory["tags"].keys())
|
||||
|
||||
except subprocess.CalledProcessError:
|
||||
pass
|
||||
@@ -361,15 +329,11 @@ def complete_tags(
|
||||
flake = clan_dir_result
|
||||
else:
|
||||
flake = "."
|
||||
machine_tags_result = json.loads(
|
||||
run(
|
||||
nix_eval(
|
||||
flags=[
|
||||
f"{flake}#clanInternals.inventory.machines",
|
||||
],
|
||||
),
|
||||
).stdout.strip()
|
||||
)
|
||||
inventory_store = InventoryStore(Flake(str(flake)))
|
||||
inventory = inventory_store.get_readonly_raw()
|
||||
machine_tags_result = inventory.get("machines")
|
||||
if machine_tags_result is None:
|
||||
return
|
||||
|
||||
for machine in machine_tags_result.values():
|
||||
machine_tags.extend(machine.get("tags", []))
|
||||
@@ -385,7 +349,6 @@ def complete_tags(
|
||||
|
||||
functions_to_run = [
|
||||
run_computed_tags_cmd,
|
||||
run_services_tags_cmd,
|
||||
run_machines_tags_cmd,
|
||||
]
|
||||
|
||||
|
||||
@@ -1,7 +1,7 @@
|
||||
import json
|
||||
from dataclasses import dataclass
|
||||
from pathlib import Path
|
||||
from typing import Any, NotRequired, Protocol, TypedDict
|
||||
from typing import Any, NotRequired, Protocol, TypedDict, cast
|
||||
|
||||
from clan_lib.errors import ClanError
|
||||
from clan_lib.git import commit_file
|
||||
@@ -145,21 +145,27 @@ class InventoryStore:
|
||||
Loads the evaluated inventory.
|
||||
After all merge operations with eventual nix code in buildClan.
|
||||
|
||||
Evaluates clanInternals.inventory with nix. Which is performant.
|
||||
Evaluates clanInternals.inventoryClass.inventory with nix. Which is performant.
|
||||
|
||||
- Contains all clan metadata
|
||||
- Contains all machines
|
||||
- and more
|
||||
"""
|
||||
raw_value = self._flake.select("clanInternals.inventoryClass.inventory")
|
||||
raw_value = self.get_readonly_raw()
|
||||
if self._keys:
|
||||
filtered = {k: v for k, v in raw_value.items() if k in self._keys}
|
||||
filtered = cast(
|
||||
InventorySnapshot,
|
||||
{k: v for k, v in raw_value.items() if k in self._keys},
|
||||
)
|
||||
else:
|
||||
filtered = raw_value
|
||||
filtered = cast(InventorySnapshot, raw_value)
|
||||
sanitized = sanitize(filtered, self._allowed_path_transforms, [])
|
||||
|
||||
return sanitized
|
||||
|
||||
def get_readonly_raw(self) -> Inventory:
|
||||
return self._flake.select("clanInternals.inventoryClass.inventory")
|
||||
|
||||
def _get_persisted(self) -> InventorySnapshot:
|
||||
"""
|
||||
Load the inventory FILE from the flake directory
|
||||
|
||||
Reference in New Issue
Block a user