Skip to content

Commit

Permalink
Fixed connectionMode, getMode() invoked at the time when it's needed
Browse files Browse the repository at this point in the history
  • Loading branch information
sacOO7 committed Jun 28, 2024
1 parent dd8236f commit f00cb0f
Showing 1 changed file with 5 additions and 11 deletions.
16 changes: 5 additions & 11 deletions ably/realtime_conn.go
Original file line number Diff line number Diff line change
Expand Up @@ -201,9 +201,6 @@ func (c *Connection) Close() {
// If not in connecting or connected state, this method causes the connection to open, entering the
// [ably.ConnectionStateConnecting] state (RTC1b, RTN3, RTN11).
func (c *Connection) connect(arg connArgs) (result, error) {
c.mtx.Lock()
arg.mode = c.getMode()
c.mtx.Unlock()
return c.connectWithRetryLoop(arg)
}

Expand All @@ -212,27 +209,21 @@ type connArgs struct {
connDetails *connectionDetails
result bool
dialOnce bool
mode connectionMode
retryIn time.Duration
}

func (c *Connection) reconnect(arg connArgs) (result, error) {
c.mtx.Lock()

var mode connectionMode
if arg.connDetails != nil && c.opts.Now().Sub(arg.lastActivityAt) >= time.Duration(arg.connDetails.ConnectionStateTTL+arg.connDetails.MaxIdleInterval) {
// RTN15g
c.msgSerial = 0
c.key = ""
// c.id isn't cleared since it's used later to determine if the
// reconnection resulted in a new transport-level connection.
mode = normalMode
} else {
mode = c.getMode()
}

c.mtx.Unlock()
arg.mode = mode
r, err := c.connectWithRetryLoop(arg)
if err != nil {
return nil, err
Expand All @@ -248,6 +239,8 @@ func (c *Connection) reconnect(arg connArgs) (result, error) {
}

func (c *Connection) getMode() connectionMode {
c.mtx.Lock()
defer c.mtx.Unlock()
if c.key != "" {
return resumeMode
}
Expand Down Expand Up @@ -392,7 +385,8 @@ func (c *Connection) connectWith(arg connArgs) (result, error) {
ConnectionStateDisconnected,
)
}
query, err := c.params(arg.mode)
connectMode := c.getMode()
query, err := c.params(connectMode)
if err != nil {
return nil, err
}
Expand All @@ -416,7 +410,7 @@ func (c *Connection) connectWith(arg connArgs) (result, error) {
// Start eventloop
go c.eventloop()

c.reconnecting = arg.mode == recoveryMode || arg.mode == resumeMode
c.reconnecting = connectMode == recoveryMode || connectMode == resumeMode
c.arg = arg
return res, nil
}
Expand Down

0 comments on commit f00cb0f

Please sign in to comment.