-
Notifications
You must be signed in to change notification settings - Fork 4
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
Andrew7234/add validator names #769
base: main
Are you sure you want to change the base?
Conversation
4dcdc44
to
16805da
Compare
@@ -1511,6 +1511,9 @@ components: | |||
type: string | |||
description: The delegatee (validator) address. | |||
example: *staking_address_1 | |||
validator_name: |
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.
The API's approach to handling validator metadata has become somewhat inconsistent.
Currently, we return validator_name
for these endpoints, EntityInfo
for block proposers and signers, and ValidatorMedia
for validator-specific endpoints. Although these represent the same underlying data, the choice of response fields across different endpoints feels somewhat arbitrary.
To improve this, I suggest either:
- Unify the responses so all relevant endpoints return the same metadata structure, or
- (my preference, but apparently not the forntend's): Keep metadata to be returned only by the validator endpoint. The frontend can cache and reuse this information across different parts of the app - whenever dealing with consensus addresses.
Main Reasoning for Option 2:
- Imagine a design choice is make to also display validator logo next to the name when showing delegations - this would mean updating these endpoints by also including
validator_logo
- If a delegator is a validator, the frontend would likely also want to show the validator name. With the current approach, we'd need to introduce additional fields like
delegator_name
to the delegation endpoint - Consider other endpoints, like
consensus/account/{address}
. When querying account information for a validator, the frontend would want to show the validator's name. Following the current setup, this would mean addingValidatorMedia
to the account endpoint response. - Similarly, if a consensus transaction was submitted by an address that belongs to a validator (or if the recipient is a validator), the frontend would likely want to display the validator's name. This would mean adding the validator metadata to yet more endpoints (
consensus/transactions
), resulting in more redundancy.
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.
(my preference, but apparently not the forntend's): Keep metadata to be returned only by the validator endpoint.
We have discussed this in #779 and I was under the impression that we agreed to handle this on the frontend (PR was created last week oasisprotocol/explorer#1576), since we need the names to be displayed in multiple views.
Per request from explorer folks, we now include the validator human-readable name in
/*delegations*
endpoints when available. Note that the e2e test updates do not reflect this change because themetadata_registry
analyzer isn't enabled for e2e_regression tests. However, I did enable it manually and found a couple outdated tests which are also fixed in this PR.