-
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
Audit fixes #32
Audit fixes #32
Changes from all commits
3f7e75c
64c28b0
74ee9da
6eb9732
b12c144
e0cea6d
2a7aa66
File filter
Filter by extension
Conversations
Jump to
Diff view
Diff view
There are no files selected for viewing
Original file line number | Diff line number | Diff line change |
---|---|---|
|
@@ -118,8 +118,7 @@ zxerr_t _sign(uint8_t *output, uint16_t outputLen, const uint8_t *message, uint1 | |
const err_convert_e err_c = | ||
convertDERtoRSV(signature->der_signature, tmpInfo, signature->r, signature->s, &signature->v); | ||
if (err_c == no_error) { | ||
*sigSize = | ||
sizeof_field(signature_t, r) + sizeof_field(signature_t, s) + sizeof_field(signature_t, v) + signatureLength; | ||
There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. Was this signaatureLength empty (0) before? or was not this working? There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. In the rypto-sign for non-evm transactions, we are only returning the signature in the r,s,v format. |
||
*sigSize = sizeof_field(signature_t, r) + sizeof_field(signature_t, s) + sizeof_field(signature_t, v); | ||
if (info != NULL) { | ||
*info = tmpInfo; | ||
} | ||
|
+18 −0 | app/ui/view.c | |
+8 −0 | app/ui/view.h | |
+22 −0 | app/ui/view_internal.h | |
+107 −7 | app/ui/view_s.c | |
+92 −0 | app/ui/view_x.c | |
+2 −2 | include/zxversion.h |
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 are we doing this so explicit when we don't do the same on other apps? any difference?
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 change is discussible, and I'm glad you point it out.
There might be a case where the transaction has ETH_CLA, and it comes with an ETH instruction not supported but that collides with a flare app instruction.
The app would treat this ETH transaction has a flare transaction.
The format of the transactions is different, so I would say it's impossible the app would parse and sign with success an ETH transaction using the flare parser.
But the auditors pointed this out, so I decided to add that extra check to make sure only flare transactions go through.
What do you think @emmanuelm41 ?