-
Notifications
You must be signed in to change notification settings - Fork 2
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
Formating prints according to CERT-7899 #61
Conversation
Co-authored-by: yoav-el-certora <[email protected]>
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.
Price_feed Design issue that needs to be decided.
Quorum/checks/price_feed.py
Outdated
coingecko_name = CoinGeckoAPI().get_name() | ||
token_validation_res = {r for r in overall_verified_vars if r.found_on == coingecko_name} | ||
price_feed_validation_res = overall_verified_vars - token_validation_res | ||
|
||
# Print price feed validation | ||
pp.pprint('Price feed validation', pp.Colors.INFO) | ||
msg = (f'{len(price_feed_validation_res)}/{num_addresses} ' | ||
'were identified as price feeds of the configured providers:\n') | ||
for i, var_res in enumerate(price_feed_validation_res, 1): | ||
msg += (f'\t{i}. {var_res.address} found on {var_res.found_on}\n' | ||
f"\t Name: {var_res.price_feed['name']}\n" | ||
f"\t Decimals: {var_res.price_feed['decimals']}\n") | ||
pp.pprint(msg, pp.Colors.SUCCESS) | ||
|
||
# Print token validation | ||
pp.pprint('Token validation', pp.Colors.INFO) | ||
msg = (f'{len(token_validation_res)}/{num_addresses} ' | ||
'were identified as tokens of the configured providers:\n') | ||
for i, var_res in enumerate(token_validation_res, 1): | ||
msg += (f'\t{i}. {var_res.address} found on {var_res.found_on}\n' | ||
f"\t Name: {var_res.price_feed['name']}\n" | ||
f"\t Symbol: {var_res.price_feed['pair']}\n" | ||
f"\t Decimals: {var_res.price_feed['decimals']}\n") | ||
pp.pprint(msg, pp.Colors.SUCCESS) |
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.
If we decide to go with that insanity eventually, lets do it properly by split the logic for the entry point to the check in order to achieve a general solution which will support additional providers by not import them and check for their name every time. @yoav-el-certora Feel free to decide whether you want this change as part of this PR or open different ticket which i can take later.
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.
I think that I commented/asked this in your previous PR when splitting providers to price feed and tokens.
Lets create a subtask for this.
Great point
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.
Yes I actually wanted to do this but didn't want to take it too far though in this ticket so it wouldn't get prolonged. I aim to do at as another ticket later @yoav-el-certora.
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.
Replace dict usage with already given object usage.
Quorum/checks/price_feed.py
Outdated
''' | ||
address: str | ||
found_on: str | ||
price_feed: dict |
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.
Use the original pydantic class insead of the dict as its more structured approach.
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.
done
# Check if Anthropic API key is configured | ||
if not config.ANTHROPIC_API_KEY: | ||
pp.pretty_print( | ||
"First deposit check is skipped. If you have a LLM API key, you can add it to your environment variables to enable this check", | ||
proposal_code = self.source_codes[0].file_content | ||
proposal_code_str = '\n'.join(proposal_code) | ||
try: | ||
listings: ListingArray | None = FirstDepositChain().execute(proposal_code_str) | ||
except: | ||
pp.pprint( | ||
'New listings were detected in payload but first deposit check is skipped.\n' | ||
'If you have a LLM API key, you can add it to your environment variables to enable this check', |
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.
Why?
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.
Because I found a bug that if you don't have a correct ANTHROPIC_API_KEY but do have a key, the authentication fails (of course) and crashes the program.
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.
Mostly reformatting prints, looks fine for me
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.
Great job
No description provided.