fix: stream closing/reset

This commit is contained in:
Richard Ramos 2023-10-20 20:09:20 -04:00 committed by richΛrd
parent 519fa2977a
commit 9161c4f7fe

View File

@ -98,16 +98,11 @@ func (wakuM *WakuMetadata) Request(ctx context.Context, peerID peer.ID) (*protoc
return nil, err return nil, err
} }
defer stream.Close()
defer func() {
err := stream.Reset()
if err != nil {
logger.Error("resetting connection", zap.Error(err))
}
}()
clusterID, shards, err := wakuM.getClusterAndShards() clusterID, shards, err := wakuM.getClusterAndShards()
if err != nil { if err != nil {
if err := stream.Reset(); err != nil {
wakuM.log.Error("resetting connection", zap.Error(err))
}
return nil, err return nil, err
} }
@ -121,6 +116,9 @@ func (wakuM *WakuMetadata) Request(ctx context.Context, peerID peer.ID) (*protoc
err = writer.WriteMsg(request) err = writer.WriteMsg(request)
if err != nil { if err != nil {
logger.Error("writing request", zap.Error(err)) logger.Error("writing request", zap.Error(err))
if err := stream.Reset(); err != nil {
wakuM.log.Error("resetting connection", zap.Error(err))
}
return nil, err return nil, err
} }
@ -128,9 +126,14 @@ func (wakuM *WakuMetadata) Request(ctx context.Context, peerID peer.ID) (*protoc
err = reader.ReadMsg(response) err = reader.ReadMsg(response)
if err != nil { if err != nil {
logger.Error("reading response", zap.Error(err)) logger.Error("reading response", zap.Error(err))
if err := stream.Reset(); err != nil {
wakuM.log.Error("resetting connection", zap.Error(err))
}
return nil, err return nil, err
} }
stream.Close()
if response.ClusterId == nil { if response.ClusterId == nil {
return nil, nil // Node is not using sharding return nil, nil // Node is not using sharding
} }
@ -144,18 +147,20 @@ func (wakuM *WakuMetadata) Request(ctx context.Context, peerID peer.ID) (*protoc
return result, nil return result, nil
} }
func (wakuM *WakuMetadata) onRequest(ctx context.Context) func(s network.Stream) { func (wakuM *WakuMetadata) onRequest(ctx context.Context) func(network.Stream) {
return func(s network.Stream) { return func(stream network.Stream) {
defer s.Close() logger := wakuM.log.With(logging.HostID("peer", stream.Conn().RemotePeer()))
logger := wakuM.log.With(logging.HostID("peer", s.Conn().RemotePeer()))
request := &pb.WakuMetadataRequest{} request := &pb.WakuMetadataRequest{}
writer := pbio.NewDelimitedWriter(s) writer := pbio.NewDelimitedWriter(stream)
reader := pbio.NewDelimitedReader(s, math.MaxInt32) reader := pbio.NewDelimitedReader(stream, math.MaxInt32)
err := reader.ReadMsg(request) err := reader.ReadMsg(request)
if err != nil { if err != nil {
logger.Error("reading request", zap.Error(err)) logger.Error("reading request", zap.Error(err))
if err := stream.Reset(); err != nil {
wakuM.log.Error("resetting connection", zap.Error(err))
}
return return
} }
@ -172,8 +177,13 @@ func (wakuM *WakuMetadata) onRequest(ctx context.Context) func(s network.Stream)
err = writer.WriteMsg(response) err = writer.WriteMsg(response)
if err != nil { if err != nil {
logger.Error("writing response", zap.Error(err)) logger.Error("writing response", zap.Error(err))
_ = s.Reset() if err := stream.Reset(); err != nil {
wakuM.log.Error("resetting connection", zap.Error(err))
} }
return
}
stream.Close()
} }
} }