1
0
Fork 0
mirror of https://github.com/postmannen/ctrl.git synced 2025-01-07 12:59:15 +00:00

added check for correctness for path for copy messages

This commit is contained in:
postmannen 2023-06-09 09:09:37 +02:00
parent b2215181e7
commit f23fa053f6

View file

@ -105,6 +105,15 @@ func (m methodREQCopySrc) handler(proc process, message Message, node string) ([
return nil, fmt.Errorf("info: the copy message was forwarded to %v message, %v", message.ToNode, message) return nil, fmt.Errorf("info: the copy message was forwarded to %v message, %v", message.ToNode, message)
} }
// Check if the filepaths for the socket a realpaths.
file := filepath.Join(message.Directory, message.FileName)
if strings.HasPrefix(file, "./") || !strings.HasPrefix(file, "/") {
er := fmt.Errorf("error: copySrcSubHandler: path in message started with ./ or no directory at all, only full paths are allowed, path given was : %v", file)
proc.errorKernel.errSend(proc, message, er, logError)
newReplyMessage(proc, message, []byte(er.Error()))
return nil, er
}
var subProcessName string var subProcessName string
proc.processes.wg.Add(1) proc.processes.wg.Add(1)
@ -447,10 +456,11 @@ func copySrcSubProcFunc(proc process, cia copyInitialData, cancel context.Cancel
// suffix to the filename. // suffix to the filename.
file := filepath.Join(initialMessage.Directory, initialMessage.FileName) file := filepath.Join(initialMessage.Directory, initialMessage.FileName)
fmt.Printf(" ** DEBUG: BEFORE STAT FILE CONTAINS: %v\n", file)
// Check the file is a unix socket, and if it is we write the // Check the file is a unix socket, and if it is we write the
// data to the socket instead of writing it to a normal file. // data to the socket instead of writing it to a normal file.
fi, err := os.Stat(file) fi, err := os.Stat(file)
if err == nil { if err != nil {
fmt.Printf(" ** DEBUG: STAT ERROR: %v\n", err) fmt.Printf(" ** DEBUG: STAT ERROR: %v\n", err)
} }