-
Notifications
You must be signed in to change notification settings - Fork 328
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
[api] archive-mode for eth_getBalance & eth_call #4529
base: master
Are you sure you want to change the base?
Conversation
type intrinsicGasCalculator interface { | ||
IntrinsicGas() (uint64, error) | ||
} | ||
|
||
var ( | ||
// ErrNotFound indicates the record isn't found | ||
ErrNotFound = errors.New("not found") | ||
ErrNotFound = errors.New("not found") | ||
ErrArchiveNotSupported = errors.New("archive-mode not supported") |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
comment
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
removed L261 comment, the name clears explains what the error is
} | ||
|
||
func (core *coreServiceReaderWithHeight) Account(addr address.Address) (*iotextypes.AccountMeta, *iotextypes.BlockIdentifier, error) { | ||
if !core.cs.archiveSupported { |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
bd7ca1f#diff-699e59a265a0599d1a49698bbf378f57a7aeb60957441a257249102ac8785a8dR50 will return error if archive is not supported
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
|
||
type ( | ||
// CoreServiceReaderWithHeight is an interface for state reader at certain height | ||
CoreServiceReaderWithHeight interface { |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
could you explain why we need to create such an interface?
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
this interface is created to represent APIs needed for archive-mode query (there will be a total 4-6 of them, 2 enabled in this PR, and more to enable in upcoming PR), so we can keep using existing API without having to add the height
parameter to it, that is, we can avoid changes like below
Account(address.Address, height uint64) (*iotextypes.AccountMeta, *iotextypes.BlockIdentifier, error)
if err != nil { | ||
return nil, nil, status.Error(codes.Internal, err.Error()) | ||
} | ||
ws, err = core.sf.WorkingSet(ctx) |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
these lines would be duplicated multiple times if use ws
instead of boolean as input
Quality Gate passedIssues Measures |
var ( | ||
accountMeta *iotextypes.AccountMeta | ||
height, archive = blockNumberToHeight(bn) | ||
) | ||
if !archive { | ||
accountMeta, _, err = svr.coreService.Account(ioAddr) | ||
} else { | ||
accountMeta, _, err = svr.coreService.WithHeight(height).Account(ioAddr) | ||
} |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
such that we can always return a Reader
from svr.coreService
by calling svr.coreService.Reader(bn).Account(ioAddr)
Description
as title. Based on #4526
Fixes #(issue)
Type of change
Please delete options that are not relevant.
How Has This Been Tested?
Please describe the tests that you ran to verify your changes. Provide instructions so we can reproduce. Please also list any relevant details for your test configuration
Test Configuration:
Checklist: