mirror of
https://github.com/minio/minio.git
synced 2025-11-07 21:02:58 -05:00
Fix Mux Connect Error (#18567)
`OpMuxConnectError` was not handled correctly. Remove local checks for single request handlers so they can run before being registered locally. Bonus: Only log IAM bootstrap on startup.
This commit is contained in:
@@ -321,10 +321,7 @@ func (c *Connection) Request(ctx context.Context, h HandlerID, req []byte) ([]by
|
||||
if c.State() != StateConnected {
|
||||
return nil, ErrDisconnected
|
||||
}
|
||||
handler := c.handlers.single[h]
|
||||
if handler == nil {
|
||||
return nil, ErrUnknownHandler
|
||||
}
|
||||
// Create mux client and call.
|
||||
client, err := c.newMuxClient(ctx)
|
||||
if err != nil {
|
||||
return nil, err
|
||||
@@ -349,10 +346,7 @@ func (c *Subroute) Request(ctx context.Context, h HandlerID, req []byte) ([]byte
|
||||
if c.State() != StateConnected {
|
||||
return nil, ErrDisconnected
|
||||
}
|
||||
handler := c.handlers.subSingle[makeZeroSubHandlerID(h)]
|
||||
if handler == nil {
|
||||
return nil, ErrUnknownHandler
|
||||
}
|
||||
// Create mux client and call.
|
||||
client, err := c.newMuxClient(ctx)
|
||||
if err != nil {
|
||||
return nil, err
|
||||
@@ -1159,6 +1153,8 @@ func (c *Connection) handleMsg(ctx context.Context, m message, subID *subHandler
|
||||
c.handleAckMux(ctx, m)
|
||||
case OpConnectMux:
|
||||
c.handleConnectMux(ctx, m, subID)
|
||||
case OpMuxConnectError:
|
||||
c.handleConnectMuxError(ctx, m)
|
||||
default:
|
||||
logger.LogIf(ctx, fmt.Errorf("unknown message type: %v", m.Op))
|
||||
}
|
||||
@@ -1210,6 +1206,18 @@ func (c *Connection) handleConnectMux(ctx context.Context, m message, subID *sub
|
||||
}
|
||||
}
|
||||
|
||||
// handleConnectMuxError when mux connect was rejected.
|
||||
func (c *Connection) handleConnectMuxError(ctx context.Context, m message) {
|
||||
if v, ok := c.outgoing.Load(m.MuxID); ok {
|
||||
var cErr muxConnectError
|
||||
_, err := cErr.UnmarshalMsg(m.Payload)
|
||||
logger.LogIf(ctx, err)
|
||||
v.error(RemoteErr(cErr.Error))
|
||||
return
|
||||
}
|
||||
PutByteBuffer(m.Payload)
|
||||
}
|
||||
|
||||
func (c *Connection) handleAckMux(ctx context.Context, m message) {
|
||||
PutByteBuffer(m.Payload)
|
||||
v, ok := c.outgoing.Load(m.MuxID)
|
||||
|
||||
Reference in New Issue
Block a user