You cannot select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
gomud/cmd/echo/telnet.go

83 lines
1.8 KiB
Go

package main
import (
"bufio"
"context"
"log"
"net"
"github.com/ThreeDotsLabs/watermill"
"github.com/ThreeDotsLabs/watermill/message"
1 year ago
"github.com/ThreeDotsLabs/watermill/message/router/middleware"
)
type TELNETParser struct {
1 year ago
s message.Subscriber
c context.Context
logger watermill.LoggerAdapter
}
func (tp *TELNETParser) Handle() {
messages, err := tp.s.Subscribe(tp.c, "telnet.raw")
if err != nil {
log.Fatalln("couldn't subscribe to telnet.raw")
}
for message := range messages {
1 year ago
fields := make(watermill.LogFields)
fields["body"] = string(message.Payload)
fields["correlation_id"] = string(message.Metadata["correlation_id"])
tp.logger.Info("received raw TCP line", fields)
message.Ack()
}
}
1 year ago
func NewTELNETParser(c context.Context, s message.Subscriber, wml watermill.LoggerAdapter) *TELNETParser {
return &TELNETParser{
1 year ago
c: c,
s: s,
logger: wml,
}
}
type TELNETServer struct {
1 year ago
l net.Listener
p message.Publisher
c context.Context
logger watermill.LoggerAdapter
}
1 year ago
func NewTELNETServer(c context.Context, l net.Listener, p message.Publisher, wml watermill.LoggerAdapter) *TELNETServer {
ts := TELNETServer{
1 year ago
c: c,
l: l,
p: p,
logger: wml,
}
return &ts
}
func (ts *TELNETServer) Handle(conn net.Conn) {
s := bufio.NewScanner(conn)
defer conn.Close()
1 year ago
correlationID := watermill.NewUUID()
ts.logger = ts.logger.With(
watermill.LogFields{
"correlation_id": correlationID},
)
for s.Scan() {
t := s.Text()
1 year ago
m := message.NewMessage(watermill.NewUUID(), []byte(t))
middleware.SetCorrelationID(correlationID, m)
err := ts.p.Publish("telnet.raw", m)
if err != nil {
log.Fatalln("couldn't write to telnet.raw")
}
1 year ago
ts.logger.Info("received bytes over telnet", nil)
}
}