prvng_core/nulib/servers/list.nu
Jesús Pérez 894046ef5a
feat(core): three-layer DAG, unified component arch, commands-registry cache, Nushell 0.112.2 migration
- DAG architecture: `dag show/validate/export` (nulib/main_provisioning/dag.nu),
    config loader (lib_provisioning/config/loader/dag.nu), taskserv dag-executor.
    Backed by schemas/lib/dag/*.ncl; orchestrator emits NATS events via
    WorkspaceComposition::into_workflow. See ADR-020, ADR-021.
  - Unified Component Architecture: components/mod.nu, main_provisioning/
    {components,workflow,extensions,ontoref-queries}.nu. Full workflow engine with
    topological sort and NATS subject emission. Blocks A-H complete (libre-daoshi).
  - Commands-registry: nulib/commands-registry.ncl (Nickel source, 314 lines) +
    JSON cache at ~/.cache/provisioning/commands-registry.json rebuilt on source
    change. cli/provisioning fast-path alias expansion avoids cold Nu startup.
    ADDING_COMMANDS.md documents new-command workflow.
  - Platform service manager: service-manager.nu (+573), startup.nu (+611),
    service-check.nu (+255); autostart/bootstrap/health/target refactored.
  - Nushell 0.112.2 migration: removed all try/catch and bash redirections;
    external commands prefixed with ^; type signatures enforced. Driven by
    scripts/refactor-try-catch{,-simplified}.nu.
  - TTY stack: removed shlib/*-tty.sh; replaced by cli/tty-dispatch.sh,
    tty-filter.sh, tty-commands.conf.
  - New domain modules: images/ (golden image lifecycle), workspace/{state,sync}.nu,
    main_provisioning/{bootstrap,cluster-deploy,fip,state}.nu, commands/{state,
    build,integrations/auth,utilities/alias}.nu, platform.nu expanded (+874).
  - Config loader overhaul: loader/core.nu slimmed (-759), cache/core.nu
    refactored (-454), removed legacy loaders/file_loader.nu (-330).
  - Thirteen new provisioning-<domain>.nu top-level modules for bash dispatcher.
  - Tests: test_workspace_state.nu (+351); updates to test_oci_registry,
    test_services.
  - README + CHANGELOG updated.
2026-04-17 04:27:33 +01:00

108 lines
4.1 KiB
Text

# REMOVED: use lib_provisioning * - causes circular import
use utils.nu *
use ../lib_provisioning/config/accessor.nu *
use ../lib_provisioning/utils/init.nu [provisioning_init]
use ../lib_provisioning/utils/settings.nu [find_get_settings]
use ../lib_provisioning/utils/interface.nu [set-provisioning-no-terminal set-provisioning-out get-provisioning-out _print end_run]
use ../lib_provisioning/utils/logging.nu [set-debug-enabled set-metadata-enabled is-debug-enabled]
use delete.nu [sync-servers-state-post-op]
# List all servers
export def "main list" [
...args # Args for list command
--infra (-i): string # Infra directory
--settings (-s): string # Settings path
--outfile (-o): string # Output file
--check (-c) # Only check mode
--debug (-x) # Use Debug mode
--xm # Debug with PROVISIONING_METADATA
--xc # Debug for task and services locally
--xr # Debug for remote servers
--xld # Log level with DEBUG
--metadata # Error with metadata
--notitles # not titles
--helpinfo (-h) # For more details use options "help"
--out: string # Print Output format: json, yaml, text (default)
] {
if ($out | is-not-empty) {
set-provisioning-out $out
set-provisioning-no-terminal true
}
provisioning_init $helpinfo "servers list" $args
if $debug { set-debug-enabled true }
if $metadata { set-metadata-enabled true }
# Load server settings
let curr_settings = (find_get_settings --infra $infra --settings $settings)
# Get servers info
let servers_table = (mw_servers_info $curr_settings)
# Check if any servers exist
if ($servers_table | length) == 0 {
if (get-provisioning-out | is-empty) {
_print "No servers configured"
} else {
_print ([] | to json) "json" "result" "table"
}
} else {
# Display servers
if ($out | is-empty) {
# Terminal output with formatting
_print ($servers_table | table -i false)
} else {
# Structured output (JSON, YAML)
match (get-provisioning-out) {
"json" => { _print ($servers_table | to json) "json" "result" "table" }
"yaml" => { _print ($servers_table | to yaml) "yaml" "result" "table" }
_ => { _print ($servers_table | table -i false) }
}
}
}
if not $notitles and not (is-debug-enabled) { end_run "" }
}
# Sync server state from Hetzner Cloud to .servers-state.json.
# Run after server create, delete, or any manual change in Hetzner.
export def "main sync" [
--infra (-i): string = ""
]: nothing -> nothing {
# Resolve workspace path from user config (same as query-servers.nu — env var not propagated)
let user_config_path = (
$env.HOME
| path join "Library" "Application Support" "provisioning" "user_config.yaml"
)
if not ($user_config_path | path exists) {
error make { msg: $"user_config.yaml not found at ($user_config_path)" }
}
let config = (open $user_config_path)
let active_name = ($config | get -o active_workspace | default "")
let workspaces = ($config | get -o workspaces | default [])
if ($active_name | is-empty) {
error make { msg: "active_workspace not set in user_config.yaml" }
}
let active_ws = ($workspaces | where { $in.name == $active_name } | first | default null)
if $active_ws == null {
error make { msg: $"Workspace '($active_name)' not found in user_config.yaml" }
}
let ws_root = $active_ws.path
let infra_name = if ($infra | is-not-empty) {
$infra | path basename
} else {
$active_ws | get -o default_infra | default ""
}
if ($infra_name | is-empty) {
error make { msg: "Specify --infra <name> or set a default_infra in the workspace config" }
}
print $"Syncing server state: workspace=($active_ws.name) infra=($infra_name)"
sync-servers-state-post-op $ws_root $infra_name
}