use std use ../lib_provisioning * # Cluster workflow definitions export def cluster_workflow [ cluster_type: string # Cluster type operation: string # Operation: create, delete infra?: string # Infrastructure target settings?: string # Settings file path --check (-c) # Check mode only --wait (-w) # Wait for completion --orchestrator: string = "http://localhost:8080" # Orchestrator URL ]: nothing -> record { let workflow_data = { cluster_type: $cluster_type, operation: $operation, infra: ($infra | default ""), settings: ($settings | default ""), check_mode: $check, wait: $wait } # Submit to orchestrator let response = (http post $"($orchestrator)/workflows/cluster/create" --content-type "application/json" ($workflow_data | to json)) if not ($response | get success) { return { status: "error", message: ($response | get error) } } let task_id = ($response | get data) _print $"Cluster ($operation) workflow submitted: ($task_id)" if $wait { wait_for_workflow_completion $orchestrator $task_id } else { { status: "submitted", task_id: $task_id } } } # Specific cluster operations export def "cluster create" [ cluster_type: string # Cluster type infra?: string # Infrastructure target settings?: string # Settings file path --check (-c) # Check mode only --wait (-w) # Wait for completion --orchestrator: string = "http://localhost:8080" # Orchestrator URL ]: nothing -> record { cluster_workflow $cluster_type "create" $infra $settings --check=$check --wait=$wait --orchestrator $orchestrator } export def "cluster delete" [ cluster_type: string # Cluster type infra?: string # Infrastructure target settings?: string # Settings file path --check (-c) # Check mode only --wait (-w) # Wait for completion --orchestrator: string = "http://localhost:8080" # Orchestrator URL ]: nothing -> record { cluster_workflow $cluster_type "delete" $infra $settings --check=$check --wait=$wait --orchestrator $orchestrator } def wait_for_workflow_completion [orchestrator: string, task_id: string]: nothing -> record { _print "Waiting for workflow completion..." mut result = { status: "pending" } while true { let status_response = (http get $"($orchestrator)/tasks/($task_id)") if not ($status_response | get success) { return { status: "error", message: "Failed to get task status" } } let task = ($status_response | get data) let task_status = ($task | get status) match $task_status { "Completed" => { _print $"✅ Workflow completed successfully" if ($task | get output | is-not-empty) { _print "Output:" _print ($task | get output) } $result = { status: "completed", task: $task } break }, "Failed" => { _print $"❌ Workflow failed" if ($task | get error | is-not-empty) { _print "Error:" _print ($task | get error) } $result = { status: "failed", task: $task } break }, "Running" => { _print $"🔄 Workflow is running..." }, _ => { _print $"⏳ Workflow status: ($task_status)" } } sleep 2sec } return $result }