Files
kubevpn/pkg/util/grpc.go
naison bb991fc1d7 refactor: use grpc stream send cancel operation (#629)
* refactor: use grpc stream send cancel operation

* refactor: ssh jump remove flags
2025-06-07 12:24:28 +08:00

106 lines
1.8 KiB
Go

package util
import (
"context"
"encoding/json"
"errors"
"fmt"
"io"
"os"
"runtime/debug"
"google.golang.org/grpc"
"github.com/wencaiwulue/kubevpn/v2/pkg/daemon/rpc"
plog "github.com/wencaiwulue/kubevpn/v2/pkg/log"
)
type Printable interface {
GetMessage() string
}
func PrintGRPCStream[T any](ctx context.Context, clientStream grpc.ClientStream, writers ...io.Writer) error {
var out io.Writer = os.Stdout
for _, writer := range writers {
out = writer
break
}
go func() {
if ctx != nil {
<-ctx.Done()
_ = clientStream.SendMsg(&rpc.Cancel{})
}
}()
for {
var t = new(T)
err := clientStream.RecvMsg(t)
if errors.Is(err, io.EOF) {
return nil
}
if err != nil {
return err
}
if out == nil {
continue
}
if p, ok := any(t).(Printable); ok {
_, _ = fmt.Fprintf(out, p.GetMessage())
} else {
buf, _ := json.Marshal(t)
_, _ = fmt.Fprintf(out, string(buf))
}
}
}
func CopyGRPCStream[T any](r grpc.ClientStream, w grpc.ServerStream) error {
for {
var t = new(T)
err := r.RecvMsg(t)
if errors.Is(err, io.EOF) {
return nil
}
if err != nil {
return err
}
err = w.SendMsg(t)
if err != nil {
return err
}
}
}
func CopyAndConvertGRPCStream[I any, O any](r grpc.ClientStream, w grpc.ServerStream, convert func(*I) *O) error {
for {
var i = new(I)
err := r.RecvMsg(i)
if errors.Is(err, io.EOF) {
return nil
}
if err != nil {
return err
}
o := convert(i)
err = w.SendMsg(o)
if err != nil {
return err
}
}
}
func HandleCrash() {
if r := recover(); r != nil {
plog.GetLogger(context.Background()).Error(r)
plog.GetLogger(context.Background()).Panicf("Panic: %s", string(debug.Stack()))
panic(r)
}
}
func ListenCancel(resp grpc.ServerStream, cancelFunc context.CancelFunc) {
var s rpc.Cancel
if resp.RecvMsg(&s) == nil {
cancelFunc()
}
}