integrated oclib

This commit is contained in:
pb
2024-08-09 18:44:33 +02:00
parent 0540fbefb4
commit 7c03e4891a
12 changed files with 265 additions and 813 deletions

View File

@@ -1,32 +1,45 @@
package daemons
import "oc-scheduler/logger"
import (
"fmt"
"oc-scheduler/logger"
"os/exec"
)
type LocalMonitor struct{
LokiURL string
KubeURL string
ArgoFile string
LokiURL string
KubeURL string
WorkflowName string
}
func (lm *LocalMonitor) LaunchLocalMonitor (){
if (lm.LokiURL == "" || lm.KubeURL == "" || lm.ArgoFile == ""){
if (lm.LokiURL == "" || lm.KubeURL == "" || lm.WorkflowName == ""){
logger.Logger.Error().Msg("Missing parameter in LocalMonitor")
}
// For dev purposes, in prod KubeURL must be a kube API's URL
if(lm.KubeURL == "localhost"){
lm.ExecLocalKube()
lm.execLocalKube()
} else{
lm.ExecRemoteKube()
lm.execRemoteKube()
}
}
func (lm *LocalMonitor) ExecLocalKube (){
func (lm *LocalMonitor) execLocalKube (){
// kube_url := ""
cmd := exec.Command("../oc-monitor/oc-monitor", "-w",lm.WorkflowName, "-u", lm.LokiURL)
// cmd_ls := exec.Command("ls", "../oc-monitor")
output, err := cmd.CombinedOutput()
// output, err := cmd_ls.CombinedOutput()
fmt.Println(string(output))
if err !=nil {
logger.Logger.Error().Msg("Could not start oc-monitor for " + lm.WorkflowName + " : " + err.Error())
}
}
func (lm *LocalMonitor) ExecRemoteKube (){
func (lm *LocalMonitor) execRemoteKube (){
}