Skip to content

Commit

Permalink
Do not call node.GetChains() if node is nil (#1588)
Browse files Browse the repository at this point in the history
In `NewSessionNodes`, the variable `node` can be `nil` if the node is
unstaked between `sessionCtx` and `ctx`. In such a case,
`node.GetChains()` causes a panic. This patch makes sure we don't call
it if the `node` is `nil`.
This is a regression from #1582.

## Description

<!-- reviewpad:summarize:start -->
### Summary generated by Reviewpad on 21 Dec 23 10:23 UTC
This pull request fixes a regression introduced in #1582. The patch
ensures that the function `node.GetChains()` is not called if the `node`
is `nil`, preventing a panic in the `NewSessionNodes` function.
<!-- reviewpad:summarize:end -->
  • Loading branch information
msmania authored Dec 21, 2023
1 parent 762dd5a commit 0479a7f
Showing 1 changed file with 1 addition and 2 deletions.
3 changes: 1 addition & 2 deletions x/pocketcore/types/session.go
Original file line number Diff line number Diff line change
Expand Up @@ -150,10 +150,9 @@ func NewSessionNodes(

// cross check the node from the `new` or `end` world state
node = keeper.Validator(ctx, n)
lenNodeChains := int64(len(node.GetChains()))
// if not found or jailed or is overstaked to chains
if node == nil ||
(isEnforceMaxChains && lenNodeChains > nodeMaxChains) ||
(isEnforceMaxChains && int64(len(node.GetChains())) > nodeMaxChains) ||
node.IsJailed() ||
!NodeHasChain(chain, node) ||
sessionNodes.Contains(node.GetAddress()) {
Expand Down

0 comments on commit 0479a7f

Please sign in to comment.