- 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.
73 lines
2 KiB
Text
73 lines
2 KiB
Text
# Development Command Handlers
|
|
# Handles: module, layer, version, pack commands
|
|
|
|
use ../flags.nu *
|
|
# REMOVED: use ../../lib_provisioning * - causes circular import
|
|
|
|
# Helper to run module commands
|
|
def run_module [
|
|
args: string
|
|
module: string
|
|
option?: string
|
|
--exec
|
|
] {
|
|
let use_debug = if ($env.PROVISIONING_DEBUG? | default false) { "-x" } else { "" }
|
|
|
|
if $exec {
|
|
exec $"($env.PROVISIONING_NAME)" $use_debug -mod $module ($option | default "") $args --notitles
|
|
} else {
|
|
^$"($env.PROVISIONING_NAME)" $use_debug -mod $module ($option | default "") $args --notitles
|
|
}
|
|
}
|
|
|
|
# Main development command dispatcher
|
|
export def handle_development_command [
|
|
command: string
|
|
ops: string
|
|
flags: record
|
|
] {
|
|
set_debug_env $flags
|
|
|
|
match $command {
|
|
"module" => { handle_module $ops $flags }
|
|
"layer" => { handle_layer $ops $flags }
|
|
"version" => { handle_version $ops $flags }
|
|
"pack" => { handle_pack $ops $flags }
|
|
_ => {
|
|
print $"❌ Unknown development command: ($command)"
|
|
print ""
|
|
print "Available development commands:"
|
|
print " module - Module discovery and management"
|
|
print " layer - Layer system (explain, show, test, stats)"
|
|
print " version - Version management (check, show, updates)"
|
|
print " pack - Packaging (core, provider, list, clean)"
|
|
print ""
|
|
print "Use 'provisioning help development' for more details"
|
|
exit 1
|
|
}
|
|
}
|
|
}
|
|
|
|
# Module command handler
|
|
def handle_module [ops: string, flags: record] {
|
|
let args = build_module_args $flags $ops
|
|
run_module $args "module" --exec
|
|
}
|
|
|
|
# Layer command handler
|
|
def handle_layer [ops: string, flags: record] {
|
|
let args = build_module_args $flags $ops
|
|
run_module $args "layer" --exec
|
|
}
|
|
|
|
# Version command handler
|
|
def handle_version [ops: string, flags: record] {
|
|
let args = build_module_args $flags $ops
|
|
run_module $args "version" --exec
|
|
}
|
|
|
|
# Pack command handler
|
|
def handle_pack [ops: string, flags: record] {
|
|
let args = build_module_args $flags $ops
|
|
run_module $args "pack" --exec
|
|
}
|