2018-09-06 12:27:19 +02:00
|
|
|
package extensions
|
|
|
|
|
|
|
|
import (
|
|
|
|
"encoding/json"
|
2023-09-18 21:01:38 -05:00
|
|
|
"gitea.watsonlabs.net/watsonb8/fayec/message"
|
2018-09-06 12:27:19 +02:00
|
|
|
"io"
|
|
|
|
"log"
|
|
|
|
)
|
|
|
|
|
|
|
|
func debugJson(v interface{}) string {
|
2018-09-24 16:13:57 +02:00
|
|
|
b, _ := json.MarshalIndent(v, "", " ")
|
2018-09-06 12:27:19 +02:00
|
|
|
return string(b)
|
|
|
|
}
|
|
|
|
|
|
|
|
type DebugExtension struct {
|
|
|
|
in *log.Logger
|
|
|
|
out *log.Logger
|
|
|
|
}
|
|
|
|
|
|
|
|
func NewDebugExtension(out io.Writer) *DebugExtension {
|
|
|
|
li := log.New(out, "InMsg", 0)
|
2018-09-24 16:13:57 +02:00
|
|
|
lo := log.New(out, "OutMsg", 0)
|
2018-09-06 12:27:19 +02:00
|
|
|
return &DebugExtension{in: li, out: lo}
|
|
|
|
}
|
|
|
|
|
|
|
|
func (d *DebugExtension) InExtension(m *message.Message) {
|
|
|
|
d.in.Println(debugJson(m))
|
|
|
|
}
|
|
|
|
func (d *DebugExtension) OutExtension(m *message.Message) {
|
|
|
|
d.out.Println(debugJson(m))
|
|
|
|
}
|