go-tunnel/helper.go

50 lines
813 B
Go
Raw Normal View History

2020-10-21 18:00:15 +02:00
package tunnel
import (
2020-10-23 17:08:42 +02:00
"context"
2020-10-21 18:00:15 +02:00
"io"
"net"
2020-10-23 17:08:42 +02:00
"github.com/pkg/errors"
"gitlab.com/wpetit/goweb/logger"
2020-10-21 18:00:15 +02:00
)
2020-10-23 17:08:42 +02:00
func pipe(ctx context.Context, client net.Conn, server net.Conn) (err error) {
2020-10-21 18:00:15 +02:00
stop := make(chan bool)
2020-10-23 13:42:44 +02:00
go func() {
err = relay(client, server, stop)
2020-10-23 17:08:42 +02:00
if err != nil {
err = errors.WithStack(err)
logger.Debug(ctx, "client->server error", logger.E(err))
}
2020-10-23 13:42:44 +02:00
}()
go func() {
err = relay(server, client, stop)
2020-10-23 17:08:42 +02:00
if err != nil {
err = errors.WithStack(err)
logger.Debug(ctx, "server->client error", logger.E(err))
}
2020-10-23 13:42:44 +02:00
}()
2020-10-21 18:00:15 +02:00
select {
case <-stop:
2020-10-23 13:42:44 +02:00
return err
2020-10-21 18:00:15 +02:00
}
}
2020-10-23 17:08:42 +02:00
func relay(src net.Conn, dst net.Conn, stop chan bool) (err error) {
2020-10-23 13:42:44 +02:00
_, err = io.Copy(dst, src)
2020-10-23 17:08:42 +02:00
if errors.Is(err, io.EOF) {
err = nil
}
2020-10-23 13:42:44 +02:00
2020-10-23 17:08:42 +02:00
if err != nil {
err = errors.WithStack(err)
}
2020-10-23 13:42:44 +02:00
2020-10-21 18:00:15 +02:00
stop <- true
2020-10-23 13:42:44 +02:00
2020-10-21 18:00:15 +02:00
return
}