From 4e6e4c515e60802fa4f663d0dea9d20c61605f8b Mon Sep 17 00:00:00 2001 From: postmannen Date: Tue, 3 Dec 2024 15:39:15 +0100 Subject: [PATCH] implemented reading and embedding the content of a local file with {{CTRL_FILE}} --- requests_cli.go | 3 +++ server.go | 50 ++++++++++++++++++++++++++++++++++++++++++++++++- 2 files changed, 52 insertions(+), 1 deletion(-) diff --git a/requests_cli.go b/requests_cli.go index ef23bac..f8cb03c 100644 --- a/requests_cli.go +++ b/requests_cli.go @@ -55,7 +55,10 @@ func methodCliCommand(proc process, message Message, node string) ([]byte, error // data payload there. var foundEnvData bool var envData string + //var foundEnvFile bool + //var envFile string for i, v := range message.MethodArgs { + // Check if to use the content of the data field are specified. if strings.Contains(v, "{{CTRL_DATA}}") { foundEnvData = true // Replace the found env variable placeholder with an actual env variable diff --git a/server.go b/server.go index 78cc3e7..7401ae3 100644 --- a/server.go +++ b/server.go @@ -5,11 +5,14 @@ import ( "context" "encoding/json" "fmt" + "io" "log" "net" "net/http" "os" "path/filepath" + "regexp" + "strings" "sync" "time" @@ -537,9 +540,54 @@ func (s *server) routeMessagesToPublisherProcess() { } // --- + // Check for {{CTRL_FILE}} and if we should read and load a local file into + // the message before sending. + + var filePathToOpen string + foundFile := false + var argPos int + for i, v := range message.MethodArgs { + if strings.Contains(v, "{{CTRL_FILE:") { + foundFile = true + argPos = i + + // Example to split: + // echo {{CTRL_FILE:/somedir/msg_file.yaml}}>ctrlfile.txt + // + // Split at colon. We want the part after. + ss := strings.Split(v, ":") + // Split at "}}",so pos [0] in the result contains just the file path. + sss := strings.Split(ss[1], "}}") + filePathToOpen = sss[0] + + } + } + + if foundFile { + + fh, err := os.Open(filePathToOpen) + if err != nil { + er := fmt.Errorf("error: routeMessagesToPublisherProcess: failed to open file given as CTRL_FILE argument: %v", err) + s.errorKernel.logError(er) + return + } + defer fh.Close() + + b, err := io.ReadAll(fh) + if err != nil { + er := fmt.Errorf("error: routeMessagesToPublisherProcess: failed to read file %v given as CTRL_FILE argument: %v", filePathToOpen, err) + s.errorKernel.logError(er) + return + } + + // Replace the {{CTRL_FILE}} with the actual content read from file. + re := regexp.MustCompile(`(.*)({{CTRL_FILE.*}})(.*)`) + message.MethodArgs[argPos] = re.ReplaceAllString(message.MethodArgs[argPos], `${1}`+string(b)+`${3}`) + // --- + + } message.ArgSignature = s.processInitial.addMethodArgSignature(message) - // fmt.Printf(" * DEBUG: add signature, fromNode: %v, method: %v, len of signature: %v\n", m.FromNode, m.Method, len(m.ArgSignature)) go s.processInitial.publishAMessage(message, s.natsConn)