Speed up StateListMessages in some cases
This commit is contained in:
parent
1e6bba5388
commit
ff48a70ed9
@ -822,8 +822,31 @@ func (a *StateAPI) StateListMessages(ctx context.Context, match *api.MessageMatc
|
|||||||
|
|
||||||
if match.To == address.Undef && match.From == address.Undef {
|
if match.To == address.Undef && match.From == address.Undef {
|
||||||
return nil, xerrors.Errorf("must specify at least To or From in message filter")
|
return nil, xerrors.Errorf("must specify at least To or From in message filter")
|
||||||
|
} else if match.To != address.Undef {
|
||||||
|
_, err := a.StateLookupID(ctx, match.To, tsk)
|
||||||
|
|
||||||
|
// if the recipient doesn't exist at the start point, we're not gonna find any matches
|
||||||
|
if xerrors.Is(err, types.ErrActorNotFound) {
|
||||||
|
return nil, nil
|
||||||
|
}
|
||||||
|
|
||||||
|
if err != nil {
|
||||||
|
return nil, xerrors.Errorf("looking up match.To: %w", err)
|
||||||
|
}
|
||||||
|
} else if match.From != address.Undef {
|
||||||
|
_, err := a.StateLookupID(ctx, match.From, tsk)
|
||||||
|
|
||||||
|
// if the sender doesn't exist at the start point, we're not gonna find any matches
|
||||||
|
if xerrors.Is(err, types.ErrActorNotFound) {
|
||||||
|
return nil, nil
|
||||||
|
}
|
||||||
|
|
||||||
|
if err != nil {
|
||||||
|
return nil, xerrors.Errorf("looking up match.From: %w", err)
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
// TODO: This should probably match on both ID and robust address, no?
|
||||||
matchFunc := func(msg *types.Message) bool {
|
matchFunc := func(msg *types.Message) bool {
|
||||||
if match.From != address.Undef && match.From != msg.From {
|
if match.From != address.Undef && match.From != msg.From {
|
||||||
return false
|
return false
|
||||||
|
Loading…
Reference in New Issue
Block a user