Speed up StateListMessages in some cases

This commit is contained in:
Aayush Rajasekaran 2021-04-10 02:33:34 -04:00
parent 1e6bba5388
commit ff48a70ed9

View File

@ -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