package utils import ( "fmt" "strings" "github.com/pkg/errors" ) func WrapErrWithLog(err error, msg, log string) error { return errors.Wrapf(err, "%v %v", msg, GetLogErrMsg(log, "log")) } func GetLogErrMsg(s string, logLabel string) string { logToInclude := strings.ReplaceAll(s, "\n", "\\n") logToInclude = strings.TrimSuffix(logToInclude, "\\n") logToInclude = ClearUnprintableChars(logToInclude, false) origLogLen := len(logToInclude) const maxLogLen = 256 if origLogLen > maxLogLen { logToInclude = fmt.Sprintf("[%v chars trimmed]", origLogLen-maxLogLen) + logToInclude[len(logToInclude)-maxLogLen:] } return fmt.Sprintf("(%v: '%v')", logLabel, logToInclude) }