package serverinterceptors import ( "context" "runtime/debug" "github.com/zeromicro/go-zero/core/logx" "google.golang.org/grpc" "google.golang.org/grpc/codes" "google.golang.org/grpc/status" ) // StreamCrashInterceptor catches panics in processing stream requests and recovers. func StreamCrashInterceptor(srv interface{}, stream grpc.ServerStream, info *grpc.StreamServerInfo, handler grpc.StreamHandler) (err error) { defer handleCrash(func(r interface{}) { err = toPanicError(r) }) return handler(srv, stream) } // UnaryCrashInterceptor catches panics in processing unary requests and recovers. func UnaryCrashInterceptor(ctx context.Context, req interface{}, info *grpc.UnaryServerInfo, handler grpc.UnaryHandler) (resp interface{}, err error) { defer handleCrash(func(r interface{}) { err = toPanicError(r) }) return handler(ctx, req) } func handleCrash(handler func(interface{})) { if r := recover(); r != nil { handler(r) } } func toPanicError(r interface{}) error { logx.Errorf("%+v\n\n%s", r, debug.Stack()) return status.Errorf(codes.Internal, "panic: %v", r) }