2025-10-07 10:32:04 +01:00

166 lines
5.9 KiB
Plaintext

use ../lib_provisioning/config/accessor.nu *
use ../lib_provisioning/utils/logging.nu *
# Create infrastructure and services with enhanced validation and logging
export def "main create" [
target?: string # server (s) | taskserv (t) | cluster (c)
name?: string # Target name in settings
...args # Args for create command
--serverpos (-p): int # Server position in settings
--check (-c) # Only check mode no servers will be created
--wait (-w) # Wait servers to be created
--infra (-i): string # Infra path
--settings (-s): string # Settings path
--outfile (-o): string # Output file
--debug (-x) # Use Debug mode
--xm # Debug with PROVISIONING_METADATA
--xc # Debug for task and services locally PROVISIONING_DEBUG_CHECK
--xr # Debug for remote servers PROVISIONING_DEBUG_REMOTE
--xld # Log level with DEBUG PROVISIONING_LOG_LEVEL=debug
--metadata # Error with metadata (-xm)
--notitles # not titles
--out: string # Print Output format: json, yaml, text (default)
--dry-run # Show what would be done without executing
--verbose (-v) # Verbose output with enhanced logging
]: nothing -> nothing {
# Enhanced validation and logging
if ($target | is-empty) {
log-error "Target parameter is required" "create"
print "💡 Valid targets: server(s), taskserv(t), cluster(cl)"
print "💡 Example: provisioning create server my-server"
return
}
# Validate target value with enhanced error messages
let valid_targets = ["server", "servers", "s", "taskserv", "taskservs", "task", "tasks", "t", "clusters", "cluster", "cl"]
let is_valid_target = ($valid_targets | where {|t| $t == $target} | length) > 0
if not $is_valid_target {
log-error $"Invalid target: ($target)" "create"
print $"💡 Valid targets: ($valid_targets | str join ', ')"
return
}
# Enhanced output handling
if ($out | is-not-empty) {
$env.PROVISIONING_OUT = $out
$env.PROVISIONING_NO_TERMINAL = true
if $verbose { log-info $"Output format set to: ($out)" "create" }
}
if ($outfile | is-not-empty) {
$env.PROVISIONING_OUT = $outfile
$env.PROVISIONING_NO_TERMINAL = true
if $verbose { log-info $"Output file set to: ($outfile)" "create" }
}
# Enhanced debug mode with logging
if $debug {
$env.PROVISIONING_DEBUG = true
if $verbose { log-debug "Debug mode enabled" "create" }
}
let use_debug = if $debug or (is-debug-enabled) { "-x" } else { "" }
# Validate settings path if provided
if ($settings | is-not-empty) {
if not ($settings | path exists) {
log-error $"Settings file not found: ($settings)" "create"
return
}
if $verbose { log-info $"Using settings: ($settings)" "create" }
}
# Validate infra path if provided
if ($infra | is-not-empty) {
if not ($infra | path exists) {
log-error $"Infra path not found: ($infra)" "create"
return
}
if $verbose { log-info $"Using infra: ($infra)" "create" }
}
# Enhanced operation logging
if $verbose {
log-section $"Creating ($target)" "create"
log-info $"Target: ($target)" "create"
log-info $"Name: ($name | default 'default')" "create"
if $dry_run {
log-warning "DRY RUN MODE - No actual changes will be made" "create"
}
}
# Execute the appropriate creation command with enhanced error handling
let result = (do {
match $target {
"server"| "servers" | "s" => {
if $verbose { log-subsection "Creating server" "create" }
if $dry_run {
log-info "Would execute: server creation command" "create"
} else {
^$"((get-provisioning-name))" $use_debug -mod "server" ($env.PROVISIONING_ARGS? | default "" | str replace $target '') --notitles
}
},
"taskserv" | "taskservs" | "task" | "tasks" | "t" => {
let ops = ($env.PROVISIONING_ARGS? | default "" | split row " ")
let task = ($ops | get -o 0 | default "")
if $verbose { log-subsection $"Creating taskserv: ($task)" "create" }
if $dry_run {
log-info $"Would execute: taskserv creation for task ($task)" "create"
} else {
^$"((get-provisioning-name))" $use_debug -mod "taskserv" $task ($env.PROVISIONING_ARGS? | default "" | str replace $"($task) ($target)" '') --notitles
}
},
"clusters"| "cluster" | "cl" => {
if $verbose { log-subsection "Creating cluster" "create" }
if $dry_run {
log-info "Would execute: cluster creation command" "create"
} else {
^$"((get-provisioning-name))" $use_debug -mod "cluster" ($env.PROVISIONING_ARGS? | default "" | str replace $target '') --notitles
}
}
}
} | complete)
if $result.exit_code != 0 {
log-error $"Failed to create ($target)" "create" $result.stderr
} else {
if not $dry_run and $verbose {
log-success $"Successfully created ($target)" "create"
} else if $dry_run and $verbose {
log-success "Dry run completed successfully" "create"
}
}
}
# Enhanced helper function to validate server configuration
export def validate-server-config [
server_config: record
]: nothing -> bool {
let required_fields = ["hostname", "ip", "provider"]
let missing_fields = ($required_fields | where {|field|
($server_config | get -o $field | is-empty)
})
if ($missing_fields | length) > 0 {
log-error "Missing required server configuration fields" "validation"
$missing_fields | each {|field|
print $" - ($field)"
}
return false
}
log-success "Server configuration is valid" "validation"
true
}
# Enhanced helper function to show creation progress
export def show-creation-progress [
current: int
total: int
operation: string
]: nothing -> nothing {
let percent = (($current * 100) / $total | into int)
log-progress $operation $percent "progress"
}