2025-09-22 22:11:41 +00:00
|
|
|
use std
|
2025-09-23 12:25:31 +00:00
|
|
|
use lib_provisioning/config/accessor.nu *
|
2025-09-22 22:11:41 +00:00
|
|
|
export-env {
|
2025-09-23 12:25:31 +00:00
|
|
|
let config = (get-config)
|
|
|
|
$env.PROVISIONING = (config-get "paths.base" "/usr/local/provisioning" --config $config)
|
2025-09-22 22:11:41 +00:00
|
|
|
$env.PROVISIONING_CORE = ($env.PROVISIONING | path join "core")
|
|
|
|
if ($env.PROVISIONING_CORE | path exists) == false {
|
|
|
|
print $"🛑 ($env.PROVISIONING_CORE) not found. Review PROVISIONING environment setting"
|
|
|
|
exit 1
|
|
|
|
}
|
|
|
|
$env.PROVISIONING_PROVIDERS_PATH = ($env.PROVISIONING | path join "providers")
|
|
|
|
$env.PROVISIONING_TASKSERVS_PATH = ($env.PROVISIONING | path join "taskservs")
|
|
|
|
$env.PROVISIONING_CLUSTERS_PATH = ($env.PROVISIONING | path join "clusters")
|
|
|
|
$env.PROVISIONING_RESOURCES = ($env.PROVISIONING | path join "resources" )
|
|
|
|
$env.PROVISIONING_NOTIFY_ICON = ($env.PROVISIONING_RESOURCES | path join "images"| path join "cloudnative.png")
|
|
|
|
|
2025-09-23 12:25:31 +00:00
|
|
|
$env.PROVISIONING_DEBUG = (config-get "debug.enabled" false --config $config)
|
|
|
|
$env.PROVISIONING_METADATA = (config-get "debug.metadata" false --config $config)
|
2025-09-22 22:11:41 +00:00
|
|
|
|
2025-09-23 12:25:31 +00:00
|
|
|
$env.PROVISIONING_DEBUG_CHECK = (config-get "debug.check" false --config $config)
|
|
|
|
$env.PROVISIONING_DEBUG_REMOTE = (config-get "debug.remote" false --config $config)
|
|
|
|
$env.PROVISIONING_LOG_LEVEL = (config-get "debug.log_level" "" --config $config)
|
2025-09-22 22:11:41 +00:00
|
|
|
|
2025-09-23 12:25:31 +00:00
|
|
|
$env.PROVISIONING_NO_TERMINAL = (config-get "debug.no_terminal" false --config $config)
|
|
|
|
$env.PROVISIONING_ARGS = ($env.PROVISIONING_ARGS? | default "")
|
|
|
|
$env.PROVISIONING_MODULE = ($env.PROVISIONING_MODULE? | default "")
|
|
|
|
$env.PROVISIONING_NAME = (config-get "core.name" "provisioning" --config $config)
|
2025-09-22 22:11:41 +00:00
|
|
|
|
2025-09-23 12:25:31 +00:00
|
|
|
$env.PROVISIONING_FILEVIEWER = (config-get "output.file_viewer" "bat" --config $config)
|
2025-09-22 22:11:41 +00:00
|
|
|
|
|
|
|
$env.PROVISIONING_METADATA = if ($env.PROVISIONING_ARGS? | str contains "--xm" ) { true } else { $env.PROVISIONING_METADATA }
|
|
|
|
$env.PROVISIONING_DEBUG_CHECK = if ($env.PROVISIONING_ARGS? | str contains "--xc" ) { true } else { $env.PROVISIONING_DEBUG_CHECK }
|
|
|
|
$env.PROVISIONING_DEBUG_REMOTE = if ($env.PROVISIONING_ARGS? | str contains "--xr" ) { true } else { $env.PROVISIONING_DEBUG_REMOTE }
|
|
|
|
$env.PROVISIONING_LOG_LEVEL = if ($env.PROVISIONING_ARGS? | str contains "--xld" ) { "debug" } else { $env.PROVISIONING_LOG_LEVEL }
|
|
|
|
|
|
|
|
if $env.PROVISIONING_LOG_LEVEL == "debug" or $env.PROVISIONING_LOG_LEVEL == "DEBUG" { $env.NU_LOG_LEVEL = "DEBUG" } else { $env.NU_LOG_LEVEL = ""}
|
|
|
|
|
|
|
|
$env.PROVISIONING_INFRA_PATH = ($env.PROVISIONING_KLOUD_PATH? | default
|
2025-09-23 12:25:31 +00:00
|
|
|
(config-get "paths.infra" | default $env.PWD ) | into string)
|
2025-09-22 22:11:41 +00:00
|
|
|
|
2025-09-23 12:25:31 +00:00
|
|
|
$env.PROVISIONING_DFLT_SET = (config-get "paths.files.settings" | default "settings.k" | into string)
|
2025-09-22 22:11:41 +00:00
|
|
|
|
|
|
|
$env.NOW = (date now | format date "%Y_%m_%d_%H_%M_%S")
|
2025-09-23 12:25:31 +00:00
|
|
|
$env.PROVISIONING_MATCH_DATE = ($env.PROVISIONING_MATCH_DATE? | default "%Y_%m")
|
2025-09-22 22:11:41 +00:00
|
|
|
|
|
|
|
#$env.PROVISIONING_MATCH_CMD = "v"
|
|
|
|
|
2025-09-23 12:25:31 +00:00
|
|
|
$env.PROVISIONING_WK_FORMAT = (config-get "output.format" | default "yaml" | into string)
|
2025-09-22 22:11:41 +00:00
|
|
|
|
|
|
|
$env.PROVISIONING_REQ_VERSIONS = ($env.PROVISIONING | path join "core" | path join "versions.yaml")
|
|
|
|
$env.PROVISIONING_TOOLS_PATH = ($env.PROVISIONING | path join "core" | path join "tools")
|
|
|
|
$env.PROVISIONING_TEMPLATES_PATH = ($env.PROVISIONING | path join "templates")
|
|
|
|
$env.SSH_OPS = [StrictHostKeyChecking=accept-new UserKnownHostsFile=(if $nu.os-info.name == "windows" { "NUL" } else { "/dev/null" })]
|
|
|
|
|
|
|
|
# Path for cloud local tasks definition can not exist if all tasks are using library install mode from 'lib-tasks'
|
|
|
|
$env.PROVISIONING_RUN_TASKSERVS_PATH = "taskservs"
|
|
|
|
$env.PROVISIONING_RUN_CLUSTERS_PATH = "clusters"
|
|
|
|
$env.PROVISIONING_GENERATE_DIRPATH = "generate"
|
|
|
|
$env.PROVISIONING_GENERATE_DEFSFILE = "defs.toml"
|
|
|
|
|
2025-09-23 12:25:31 +00:00
|
|
|
$env.PROVISIONING_KEYS_PATH = (config-get "paths.files.keys" ".keys.k" --config $config)
|
2025-09-22 22:11:41 +00:00
|
|
|
|
|
|
|
$env.PROVISIONING_USE_KCL = if (^bash -c "type -P kcl" | is-not-empty) { true } else { false }
|
|
|
|
$env.PROVISIONING_USE_KCL_PLUGIN = if ( (version).installed_plugins | str contains "kcl" ) { true } else { false }
|
|
|
|
#$env.PROVISIONING_J2_PARSER = ($env.PROVISIONING_$TOOLS_PATH | path join "parsetemplate.py")
|
|
|
|
#$env.PROVISIONING_J2_PARSER = (^bash -c "type -P tera")
|
|
|
|
$env.PROVISIONING_USE_TERA_PLUGIN = if ( (version).installed_plugins | str contains "tera" ) { true } else { false }
|
|
|
|
|
|
|
|
$env.PROVISIONING_URL = ($env.PROVISIONING_URL? | default "https://provisioning.systems" | into string)
|
|
|
|
#let infra = ($env.PROVISIONING_ARGS | split row "-k" | get -o 1 | split row " " | get -o 1 | default "")
|
|
|
|
#$env.CURR_KLOUD = if $infra == "" { (^pwd) } else { $infra }
|
|
|
|
|
2025-09-23 12:25:31 +00:00
|
|
|
$env.PROVISIONING_USE_SOPS = (config-get "sops.use_sops" | default "age" | into string)
|
|
|
|
$env.PROVISIONING_USE_KMS = (config-get "sops.use_kms" | default "" | into string)
|
|
|
|
$env.PROVISIONING_SECRET_PROVIDER = (config-get "sops.secret_provider" | default "sops" | into string)
|
2025-09-22 22:11:41 +00:00
|
|
|
|
|
|
|
# AI Configuration
|
2025-09-23 12:25:31 +00:00
|
|
|
$env.PROVISIONING_AI_ENABLED = (config-get "ai.enabled" | default false | into bool | into string)
|
|
|
|
$env.PROVISIONING_AI_PROVIDER = (config-get "ai.provider" | default "openai" | into string)
|
2025-09-22 22:11:41 +00:00
|
|
|
$env.PROVISIONING_LAST_ERROR = ""
|
2025-09-23 12:25:31 +00:00
|
|
|
$env.PROVISIONING_KLOUD_PATH = ($env.PROVISIONING_KLOUD_PATH? | default "")
|
2025-09-22 22:11:41 +00:00
|
|
|
|
|
|
|
# For SOPS if settings below fails -> look at: sops_env.nu loaded when is need to set env context
|
2025-09-23 12:25:31 +00:00
|
|
|
let curr_infra = (config-get "paths.infra" "" --config $config)
|
2025-09-22 22:11:41 +00:00
|
|
|
if $curr_infra != "" { $env.CURRENT_INFRA_PATH = $curr_infra }
|
|
|
|
|
2025-09-23 12:25:31 +00:00
|
|
|
let sops_path = (config-get "sops.config_path" | default "" | str replace "KLOUD_PATH" $env.PROVISIONING_KLOUD_PATH)
|
2025-09-22 22:11:41 +00:00
|
|
|
if $sops_path != "" {
|
|
|
|
$env.PROVISIONING_SOPS = $sops_path
|
|
|
|
} else if $env.CURRENT_KLOUD_PATH? != null and ($env.CURRENT_INFRA_PATH | is -not-empty) {
|
|
|
|
$env.PROVISIONING_SOPS = (get_def_sops $env.CURRENT_KLOUD_PATH)
|
|
|
|
}
|
|
|
|
|
2025-09-23 12:25:31 +00:00
|
|
|
let kage_path = (config-get "sops.key_path" | default "" | str replace "KLOUD_PATH" $env.PROVISIONING_KLOUD_PATH)
|
2025-09-22 22:11:41 +00:00
|
|
|
if $kage_path != "" {
|
|
|
|
$env.PROVISIONING_KAGE = $kage_path
|
|
|
|
} else if $env.CURRENT_KLOUD_PATH? != null and ($env.CURRENT_INFRA_PATH | is-not-empty) {
|
|
|
|
$env.PROVISIONING_KAGE = (get_def_age $env.CURRENT_KLOUD_PATH)
|
|
|
|
}
|
|
|
|
|
|
|
|
if $env.PROVISIONING_KAGE? != null and ($env.PROVISIONING_KAGE | is-not-empty) {
|
|
|
|
$env.SOPS_AGE_KEY_FILE = $env.PROVISIONING_KAGE
|
|
|
|
$env.SOPS_AGE_RECIPIENTS = (grep "public key:" $env.SOPS_AGE_KEY_FILE | split row ":" |
|
|
|
|
get -o 1 | str trim | default "")
|
|
|
|
if $env.SOPS_AGE_RECIPIENTS == "" {
|
|
|
|
print $"❗Error no key found in (_ansi red_bold)($env.SOPS_AGE_KEY_FILE)(_ansi reset) file for secure AGE operations "
|
|
|
|
exit 1
|
|
|
|
}
|
|
|
|
}
|
2025-09-23 12:25:31 +00:00
|
|
|
$env.PROVISIONING_OUT = ($env.PROVISIONING_OUT? | default "")
|
2025-09-22 22:11:41 +00:00
|
|
|
if ($env.PROVISIONING_OUT | is-not-empty) {
|
|
|
|
$env.PROVISIONING_NO_TERMINAL = true
|
|
|
|
# if ($env.PROVISIONING_OUT | str ends-with ".yaml") or ($env.PROVISIONING_OUT | str ends-with ".yml") {
|
|
|
|
# $env.PROVISIONING_NO_TERMINAL = true
|
|
|
|
# } else if ($env.PROVISIONING_OUT | str ends-with ".json") {
|
|
|
|
# $env.PROVISIONING_NO_TERMINAL = true
|
|
|
|
# } else {
|
|
|
|
# $env.PROVISIONING_NO_TERMINAL = true
|
|
|
|
# }
|
|
|
|
}
|
|
|
|
# KCL Module Path Configuration
|
|
|
|
# Set up KCL_MOD_PATH to help KCL resolve modules when running from different directories
|
|
|
|
$env.KCL_MOD_PATH = ($env.KCL_MOD_PATH? | default [] | append [
|
|
|
|
($env.PROVISIONING | path join "kcl")
|
|
|
|
($env.PROVISIONING_PROVIDERS_PATH)
|
|
|
|
$env.PWD
|
|
|
|
] | uniq | str join ":")
|
|
|
|
|
|
|
|
# Path helpers for dynamic imports
|
|
|
|
$env.PROVISIONING_CORE_NULIB = ($env.PROVISIONING | path join "core" "nulib")
|
|
|
|
$env.PROVISIONING_PROV_LIB = ($env.PROVISIONING_PROVIDERS_PATH | path join "prov_lib")
|
|
|
|
|
|
|
|
# Extension System Configuration
|
|
|
|
$env.PROVISIONING_EXTENSIONS_PATH = ($env.PROVISIONING_EXTENSIONS_PATH? | default
|
2025-09-23 12:25:31 +00:00
|
|
|
(config-get "extensions.path" | default "") | into string)
|
2025-09-22 22:11:41 +00:00
|
|
|
|
|
|
|
$env.PROVISIONING_EXTENSION_MODE = ($env.PROVISIONING_EXTENSION_MODE? | default
|
2025-09-23 12:25:31 +00:00
|
|
|
(config-get "extensions.mode" | default "full") | into string)
|
2025-09-22 22:11:41 +00:00
|
|
|
|
|
|
|
$env.PROVISIONING_PROFILE = ($env.PROVISIONING_PROFILE? | default
|
2025-09-23 12:25:31 +00:00
|
|
|
(config-get "extensions.profile" | default "") | into string)
|
2025-09-22 22:11:41 +00:00
|
|
|
|
|
|
|
$env.PROVISIONING_ALLOWED_EXTENSIONS = ($env.PROVISIONING_ALLOWED_EXTENSIONS? | default
|
2025-09-23 12:25:31 +00:00
|
|
|
(config-get "extensions.allowed" | default "") | into string)
|
2025-09-22 22:11:41 +00:00
|
|
|
|
|
|
|
$env.PROVISIONING_BLOCKED_EXTENSIONS = ($env.PROVISIONING_BLOCKED_EXTENSIONS? | default
|
2025-09-23 12:25:31 +00:00
|
|
|
(config-get "extensions.blocked" | default "") | into string)
|
2025-09-22 22:11:41 +00:00
|
|
|
|
|
|
|
# Custom paths for extensions
|
|
|
|
$env.PROVISIONING_CUSTOM_PROVIDERS = ($env.PROVISIONING_CUSTOM_PROVIDERS? | default "" | into string)
|
|
|
|
$env.PROVISIONING_CUSTOM_TASKSERVS = ($env.PROVISIONING_CUSTOM_TASKSERVS? | default "" | into string)
|
|
|
|
|
|
|
|
# Project-local environment should be loaded manually if needed
|
|
|
|
# Example: source .env.nu (from project directory)
|
|
|
|
|
|
|
|
# Load providers environment settings...
|
|
|
|
# use ../../providers/prov_lib/env_middleware.nu
|
|
|
|
}
|
|
|
|
|
|
|
|
export def "show_env" [
|
|
|
|
]: nothing -> record {
|
|
|
|
let env_vars = {
|
|
|
|
PROVISIONING: $env.PROVISIONING,
|
|
|
|
PROVISIONING_CORE: $env.PROVISIONING_CORE,
|
|
|
|
PROVISIONING_PROVIDERS_PATH: $env.PROVISIONING_PROVIDERS_PATH,
|
|
|
|
PROVISIONING_TASKSERVS_PATH: $env.PROVISIONING_TASKSERVS_PATH,
|
|
|
|
PROVISIONING_CLUSTERS_PATH: $env.PROVISIONING_CLUSTERS_PATH,
|
|
|
|
PROVISIONING_RESOURCES: $env.PROVISIONING_RESOURCES,
|
|
|
|
PROVISIONING_NOTIFY_ICON: $env.PROVISIONING_NOTIFY_ICON,
|
|
|
|
|
|
|
|
PROVISIONING_DEBUG: $"($env.PROVISIONING_DEBUG)",
|
|
|
|
PROVISIONING_METADATA: $"($env.PROVISIONING_METADATA)",
|
|
|
|
|
|
|
|
PROVISIONING_DEBUG_CHECK: $"($env.PROVISIONING_DEBUG_CHECK)",
|
|
|
|
PROVISIONING_DEBUG_REMOTE: $"($env.PROVISIONING_DEBUG_REMOTE)",
|
|
|
|
PROVISIONING_LOG_LEVEL: $env.PROVISIONING_LOG_LEVEL,
|
|
|
|
|
|
|
|
PROVISIONING_NO_TERMINAL: $env.PROVISIONING_NO_TERMINAL,
|
|
|
|
PROVISIONING_ARGS: $env.PROVISIONING_ARGS,
|
|
|
|
PROVISIONING_MODULE: $env.PROVISIONING_MODULE,
|
|
|
|
PROVISIONING_NAME: $env.PROVISIONING_NAME,
|
|
|
|
|
|
|
|
PROVISIONING_FILEVIEWER: $env.PROVISIONING_FILEVIEWER,
|
|
|
|
|
|
|
|
NU_LOG_LEVEL: ($env.NU_LOG_LEVEL| default null),
|
|
|
|
|
|
|
|
PROVISIONING_KLOUD_PATH: $env.PROVISIONING_KLOUD_PATH,
|
|
|
|
|
|
|
|
PROVISIONING_DFLT_SET: $env.PROVISIONING_DFLT_SET,
|
|
|
|
|
|
|
|
NOW: $env.NOW,
|
|
|
|
PROVISIONING_MATCH_DATE: $env.PROVISIONING_MATCH_DATE,
|
|
|
|
|
|
|
|
PROVISIONING_WK_FORMAT: $env.PROVISIONING_WK_FORMAT,
|
|
|
|
|
|
|
|
PROVISIONING_REQ_VERSIONS: $env.PROVISIONING_REQ_VERSIONS,
|
|
|
|
PROVISIONING_TOOLS_PATH: $env.PROVISIONING_TOOLS_PATH,
|
|
|
|
PROVISIONING_TEMPLATES_PATH: $env.PROVISIONING_TEMPLATES_PATH,
|
|
|
|
SSH_OPS: (if ($env.PROVISIONING_OUT | is-empty) { $env.SSH_OPS } else { $"($env.SSH_OPS | to json)"}),
|
|
|
|
|
|
|
|
PROVISIONING_RUN_TASKSERVS_PATH: $env.PROVISIONING_RUN_TASKSERVS_PATH,
|
|
|
|
PROVISIONING_RUN_CLUSTERS_PATH: $env.PROVISIONING_RUN_CLUSTERS_PATH,
|
|
|
|
PROVISIONING_GENERATE_DIRPATH: $env.PROVISIONING_GENERATE_DIRPATH,
|
|
|
|
PROVISIONING_GENERATE_DEFSFILE: $env.PROVISIONING_GENERATE_DEFSFILE,
|
|
|
|
|
|
|
|
PROVISIONING_KEYS_PATH: $env.PROVISIONING_KEYS_PATH,
|
|
|
|
|
|
|
|
PROVISIONING_USE_KCL: $"($env.PROVISIONING_USE_KCL)",
|
2025-09-23 12:25:31 +00:00
|
|
|
PROVISIONING_J2_PARSER: ($env.PROVISIONING_J2_PARSER? | default ""),
|
2025-09-22 22:11:41 +00:00
|
|
|
|
|
|
|
PROVISIONING_URL: $env.PROVISIONING_URL,
|
|
|
|
|
|
|
|
PROVISIONING_USE_SOPS: $env.PROVISIONING_USE_SOPS,
|
|
|
|
PROVISIONING_LAST_ERROR: $env.PROVISIONING_LAST_ERROR,
|
|
|
|
|
2025-09-23 12:25:31 +00:00
|
|
|
CURRENT_KLOUD_PATH: ($env.CURRENT_INFRA_PATH? | default ""),
|
2025-09-22 22:11:41 +00:00
|
|
|
|
2025-09-23 12:25:31 +00:00
|
|
|
PROVISIONING_SOPS: ($env.PROVISIONING_SOPS? | default ""),
|
2025-09-22 22:11:41 +00:00
|
|
|
|
2025-09-23 12:25:31 +00:00
|
|
|
PROVISIONING_KAGE: ($env.PROVISIONING_KAGE? | default ""),
|
2025-09-22 22:11:41 +00:00
|
|
|
|
|
|
|
PROVISIONING_OUT: $env.PROVISIONING_OUT,
|
|
|
|
};
|
|
|
|
|
|
|
|
if $env.PROVISIONING_KAGE? != null and ($env.PROVISIONING_KAGE | is-not-empty) {
|
|
|
|
$env_vars | merge {
|
|
|
|
SOPS_AGE_KEY_FILE: $env.SOPS_AGE_KEY_FILE,
|
|
|
|
SOPS_AGE_RECIPIENTS: $env.SOPS_AGE_RECIPIENTS,
|
|
|
|
}
|
|
|
|
} else {
|
|
|
|
$env_vars
|
|
|
|
}
|
|
|
|
}
|