Jesús Pérez c62e967ce3
chore: complete KCL to Nickel migration cleanup and setup pre-commit
Clean up 404 KCL references (99.75% complete):
   - Rename kcl_* variables to schema_*/nickel_* (kcl_path→schema_path, etc.)
   - Update functions: parse_kcl_file→parse_nickel_file
   - Update env vars: KCL_MOD_PATH→NICKEL_IMPORT_PATH
   - Fix cli/providers-install: add has_nickel and nickel_version variables
   - Correct import syntax: .nickel.→.ncl.
   - Update 57 files across core, CLI, config, and utilities

   Configure pre-commit hooks:
   - Activate: nushell-check, nickel-typecheck, markdownlint
   - Comment out: Rust hooks (fmt, clippy, test), check-yaml

   Testing:
   - Module discovery: 9 modules (6 providers, 1 taskserv, 2 clusters) 
   - Syntax validation: 15 core files 
   - Pre-commit hooks: all passing 
2026-01-08 20:08:46 +00:00

158 lines
5.7 KiB
Plaintext

#use ../lib_provisioning/defs/lists.nu providers_list
use ../config/accessor.nu *
export def setup_config_path [
provisioning_cfg_name: string = "provisioning"
]: nothing -> string {
($nu.default-config-dir) | path dirname | path join $provisioning_cfg_name
}
export def tools_install [
tool_name?: string
run_args?: string
]: nothing -> bool {
print $"(_ansi cyan)((get-provisioning-name))(_ansi reset) (_ansi yellow_bold)tools(_ansi reset) check:\n"
let bin_install = ((get-base-path) | path join "core" | path join "bin" | path join "tools-install")
if not ($bin_install | path exists) {
print $"🛑 Error running (_ansi yellow)tools_install(_ansi reset) not found (_ansi red_bold)($bin_install | path basename)(_ansi reset)"
if (is-debug-enabled) { print $"($bin_install)" }
return false
}
let res = (^$"($bin_install)" $run_args $tool_name | complete)
if ($res.exit_code == 0 ) {
print $res.stdout
true
} else {
print $"🛑 Error running (_ansi yellow)tools-install(_ansi reset) (_ansi red_bold)($bin_install | path basename)(_ansi reset)\n($res.stdout)"
if (is-debug-enabled) { print $"($bin_install)" }
false
}
}
export def providers_install [
prov_name?: string
run_args?: string
]: nothing -> list {
let providers_path = (get-providers-path)
if not ($providers_path | path exists) { return }
providers_list "full" | each {|prov|
let name = ($prov | get name? | default "")
if ($prov_name | is-empty) or $prov_name == $name {
let bin_install = ($providers_path | path join $name | path join "bin" | path join "install.sh" )
if ($bin_install | path exists) {
let res = (^$"($bin_install)" $run_args | complete)
if ($res.exit_code != 0 ) {
print ($"🛑 Error running (_ansi yellow)($name)(_ansi reset) (_ansi red_bold)($bin_install | path basename)(_ansi reset)\n($res.stdout)")
if (is-debug-enabled) { print $"($bin_install)" }
} else {
print -n $"(_ansi green)($name)(_ansi reset) tools:"
print ($prov | get tools? | default "")
print ""
if ($res.exit_code == 0 ) {
_print $res.stdout
}
}
}
}
}
}
export def create_versions_file [
targetname: string = "versions"
]: nothing -> bool {
let target_name = if ($targetname | is-empty) { "versions" } else { $targetname }
let provisioning_base = ($env.PROVISIONING? | default (get-base-path))
let versions_ncl = ($provisioning_base | path join "core" | path join "versions.ncl")
let versions_target = ($provisioning_base | path join "core" | path join $target_name)
let providers_path = ($provisioning_base | path join "extensions" | path join "providers")
# Check if versions.ncl exists
if not ($versions_ncl | path exists) {
return false
}
# Generate KEY="VALUE" format
mut content = ""
# ============================================================================
# CORE TOOLS
# ============================================================================
let nickel_result = (^nickel export $versions_ncl --format json | complete)
if $nickel_result.exit_code == 0 {
let json_data = ($nickel_result.stdout | from json)
let core_versions = ($json_data | get core_versions? | default [])
for item in $core_versions {
let name = ($item | get name?)
let version_obj = ($item | get version?)
if ($name | is-not-empty) and ($version_obj | is-not-empty) {
let key = ($name | str upcase)
let current = ($version_obj | get current?)
let source = ($version_obj | get source?)
$content += $"($key)_VERSION=\"($current)\"\n"
$content += $"($key)_SOURCE=\"($source)\"\n"
# Add short aliases for common bash scripts (e.g., nushell -> NU)
let short_key = if $name == "nushell" {
"NU"
} else if $name == "nickel" {
"NICKEL"
} else if $name == "sops" {
"SOPS"
} else if $name == "age" {
"AGE"
} else if $name == "k9s" {
"K9S"
} else {
""
}
if ($short_key | is-not-empty) and ($short_key != $key) {
$content += $"($short_key)_VERSION=\"($current)\"\n"
$content += $"($short_key)_SOURCE=\"($source)\"\n"
}
$content += "\n"
}
}
}
# ============================================================================
# PROVIDERS
# ============================================================================
if ($providers_path | path exists) {
for provider_item in (ls $providers_path) {
let provider_dir = ($providers_path | path join $provider_item.name)
let provider_version_file = ($provider_dir | path join "nickel" | path join "version.ncl")
if ($provider_version_file | path exists) {
let provider_result = (^nickel export $provider_version_file --format json | complete)
if $provider_result.exit_code == 0 {
let provider_data = ($provider_result.stdout | from json)
let prov_name = ($provider_data | get name?)
let prov_version_obj = ($provider_data | get version?)
if ($prov_name | is-not-empty) and ($prov_version_obj | is-not-empty) {
let prov_key = $"PROVIDER_($prov_name | str upcase)"
let prov_current = ($prov_version_obj | get current?)
let prov_source = ($prov_version_obj | get source?)
$content += $"($prov_key)_VERSION=\"($prov_current)\"\n"
$content += $"($prov_key)_SOURCE=\"($prov_source)\"\n"
$content += "\n"
}
}
}
}
}
# Save to file
if ($content | is-not-empty) {
$content | save --force $versions_target
true
} else {
false
}
}