Skip to content
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

Decode transaction errors #346

Closed
rndquu opened this issue Oct 22, 2024 · 17 comments · Fixed by #353
Closed

Decode transaction errors #346

rndquu opened this issue Oct 22, 2024 · 17 comments · Fixed by #353

Comments

@rndquu
Copy link
Member

rndquu commented Oct 22, 2024

There's this package which is able to decode transaction errors which really helps in finding out the root cause of why permit or card minting is throwing an error.

As a part of this issue we should decode and show the decoded error to a user on:

  • permit claim
  • card mint (because we send transaction to the treasury address)

Original comment

@ariesgun
Copy link
Contributor

/start

Copy link
Contributor

ubiquity-os bot commented Oct 25, 2024

Deadline Fri, Oct 25, 5:49 PM UTC
Beneficiary 0xE80FC2700ec6faF5f0347a2E7E7798FAf548e1c3

Tip

  • Use /wallet 0x0000...0000 if you want to update your registered payment wallet address.
  • Be sure to open a draft pull request as soon as possible to communicate updates on your progress.
  • Be sure to provide timely updates to us when requested, or you will be automatically unassigned from the task.

@ariesgun
Copy link
Contributor

ariesgun commented Oct 25, 2024

This library needs ethers v6, so we need to upgrade ethers from v5 to v6.
We can't use /ethers-decode-error/v/1.0.0 because it supports node version < 19.

Shall we upgrade ethers to v6?

@0x4007
Copy link
Member

0x4007 commented Oct 25, 2024

I think retaining v5 is more maintainable because LLMs are trained on it but not v6.

@rndquu
Copy link
Member Author

rndquu commented Oct 25, 2024

This library needs ethers v6, so we need to upgrade ethers from v5 to v6. We can't use /ethers-decode-error/v/1.0.0 because it supports node version < 19.

Shall we upgrade ethers to v6?

We've just recently downgraded from v6 to v5. Perhaps there're other libs.

@ariesgun
Copy link
Contributor

This library needs ethers v6, so we need to upgrade ethers from v5 to v6. We can't use /ethers-decode-error/v/1.0.0 because it supports node version < 19.
Shall we upgrade ethers to v6?

We've just recently downgraded from v6 to v5. Perhaps there're other libs.

I see.
Will check if there is any alternative..

@Keyrxng
Copy link
Contributor

Keyrxng commented Oct 25, 2024

One potentially hacky method but it would give better insight maybe is the 4byte API where we can search for fn signatures and log them to the console on tx fail. Obv there are collisions and sometimes the sig has not been uploaded but it's something we can setup internally and it's free to use.

I personally copy paste into 4byte when I'm debugging errors so this would make my life easier at least lmao

@ariesgun
Copy link
Contributor

ariesgun commented Nov 1, 2024

One potentially hacky method but it would give better insight maybe is the 4byte API where we can search for fn signatures and log them to the console on tx fail. Obv there are collisions and sometimes the sig has not been uploaded but it's something we can setup internally and it's free to use.

I personally copy paste into 4byte when I'm debugging errors so this would make my life easier at least lmao

Do you still have the result from 4byte? Curious how it looks like

@Keyrxng
Copy link
Contributor

Keyrxng commented Nov 1, 2024

Copy the selector from the start of the data and then paste it into the function signature search feature on 4byte and it'll show you. You'll need to write logic to deal with the API for my suggestion ofc

I do this when I'm writing tests, debugging, etc that sort of thing. It's tedious manually as sometimes there are 10-15 calls you need to manually track not always in the same order etc. I don't have any stored results or anything, whatever I gather at the time I comment in the code then remove it after I've fixed it.

@ariesgun
Copy link
Contributor

ariesgun commented Nov 2, 2024

Copy the selector from the start of the data and then paste it into the function signature search feature on 4byte and it'll show you. You'll need to write logic to deal with the API for my suggestion ofc

I do this when I'm writing tests, debugging, etc that sort of thing. It's tedious manually as sometimes there are 10-15 calls you need to manually track not always in the same order etc. I don't have any stored results or anything, whatever I gather at the time I comment in the code then remove it after I've fixed it.

I am not sure why we need to use function search feature from 4byte. I tried the data value from here. We can only get the function signature. And it is already visible in the console logger.

image

I thought what we need is to decode the transaction error and not function signature. The transaction error can be decoded by simply using this library ethers-decode-error/. I think it is sufficient.

Did I miss something?

@Keyrxng
Copy link
Contributor

Keyrxng commented Nov 2, 2024

I thought what we need is to decode the transaction error and not function signature.

They both help when debugging in my opinion but both are not required. The spec says to use the lib and decode, so do that and ignore my suggestion.

My suggestion to implement it that way and then to embed it into our official rpc-handler is because it'd be repurposed and likely provide a lot more value across the org. MetaMask lives in the browser and is detached from our rpc-handler but also controls all writes so it does have it's own error handling.

Did I miss something?

No, both approaches were suggested but the spec only lists one. My comment was given a thumbs-up which is usually a sign of approval but only I've mentioned it beyond that. Implement the spec unless someone explicitly approves my suggestion.

Copy link
Contributor

ubiquity-os bot commented Nov 16, 2024

Passed the deadline and no activity is detected, removing assignees: @ariesgun.

@henalolp
Copy link

henalolp commented Dec 2, 2024

/help

Copy link
Contributor

ubiquity-os bot commented Dec 2, 2024

Available Commands

Command Description Example
/help List all available commands. /help
/start Assign yourself and/or others to the issue/task. /start
/stop Unassign yourself from the issue/task. /stop

@henalolp
Copy link

henalolp commented Dec 2, 2024

/start

@ariesgun
Copy link
Contributor

ariesgun commented Dec 2, 2024

/start

Note that there is already a PR open for this issue

Copy link
Contributor

ubiquity-os bot commented Jan 16, 2025

 [ 150 UUSD ] 

@ariesgun
Contributions Overview
ViewContributionCountReward
IssueTask1150
Conversation Incentives
CommentFormattingRelevancePriorityReward

 [ 9.324 UUSD ] 

@0x4007
Contributions Overview
ViewContributionCountReward
IssueComment12.226
ReviewComment67.098
Conversation Incentives
CommentFormattingRelevancePriorityReward
I think retaining v5 is more maintainable because LLMs are train…
1.06
content:
  content:
    p:
      score: 0
      elementCount: 1
  result: 0
regex:
  wordCount: 16
  wordValue: 0.1
  result: 1.06
0.732.226
I think we should self host @rndquu
0.52
content:
  content:
    p:
      score: 0
      elementCount: 1
  result: 0
regex:
  wordCount: 7
  wordValue: 0.1
  result: 0.52
0.731.092
Perhaps we need to get a copy of your repo and then host it. @rn…
1.11
content:
  content:
    p:
      score: 0
      elementCount: 1
  result: 0
regex:
  wordCount: 17
  wordValue: 0.1
  result: 1.11
0.631.998
I suppose all crypto related software should be under ubiquity o…
0.77
content:
  content:
    p:
      score: 0
      elementCount: 1
  result: 0
regex:
  wordCount: 11
  wordValue: 0.1
  result: 0.77
0.330.693
The crypto related stuff should be under @ubiquity
0.59
content:
  content:
    p:
      score: 0
      elementCount: 1
  result: 0
regex:
  wordCount: 8
  wordValue: 0.1
  result: 0.59
0.330.531
That's right we might not have access to the ubiquity npm for so…
1.7
content:
  content:
    p:
      score: 0
      elementCount: 1
  result: 0
regex:
  wordCount: 28
  wordValue: 0.1
  result: 1.7
0.532.55
@rndquu @gentlementlegen lets finalize this
0.39
content:
  content:
    p:
      score: 0
      elementCount: 1
  result: 0
regex:
  wordCount: 5
  wordValue: 0.1
  result: 0.39
0.230.234

 [ 120.534 UUSD ] 

@rndquu
Contributions Overview
ViewContributionCountReward
IssueSpecification146.02
IssueComment12.82
ReviewComment471.694
Conversation Incentives
CommentFormattingRelevancePriorityReward
There's [this](https://github.com/superical/ethers-decode-error)…
15.34
content:
  content:
    p:
      score: 0
      elementCount: 5
    ul:
      score: 1
      elementCount: 1
    li:
      score: 0.5
      elementCount: 2
    a:
      score: 5
      elementCount: 2
  result: 12
regex:
  wordCount: 62
  wordValue: 0.1
  result: 3.34
1346.02
We've just recently downgraded from v6 to v5. Perhaps there're o…
0.94
content:
  content:
    p:
      score: 0
      elementCount: 1
  result: 0
regex:
  wordCount: 14
  wordValue: 0.1
  result: 0.94
132.82
[This](https://github.com/ubiquity/pay.ubq.fi/pull/353#issuecomm…
14.97
content:
  content:
    p:
      score: 0
      elementCount: 5
    ol:
      score: 1
      elementCount: 1
    li:
      score: 0.5
      elementCount: 2
    a:
      score: 5
      elementCount: 2
  result: 12
regex:
  wordCount: 54
  wordValue: 0.1
  result: 2.97
1344.91
Did you try NFT minting with this line added?
0.65
content:
  content:
    p:
      score: 0
      elementCount: 1
  result: 0
regex:
  wordCount: 9
  wordValue: 0.1
  result: 0.65
0.631.17
Isn't [NPM_TOKEN](https://github.com/ubiquity/ethers-decode-erro…
11.44
content:
  content:
    p:
      score: 0
      elementCount: 1
    a:
      score: 5
      elementCount: 2
  result: 10
regex:
  wordCount: 23
  wordValue: 0.1
  result: 1.44
0.5317.16
As far as I understand everything is fine right now:- https://…
14.09
content:
  content:
    p:
      score: 0
      elementCount: 4
    ul:
      score: 1
      elementCount: 1
    li:
      score: 0.5
      elementCount: 3
    a:
      score: 5
      elementCount: 2
  result: 12.5
regex:
  wordCount: 26
  wordValue: 0.1
  result: 1.59
0.238.454

 [ 64.215 UUSD ] 

@Keyrxng
Contributions Overview
ViewContributionCountReward
IssueComment336.039
ReviewComment228.176
Conversation Incentives
CommentFormattingRelevancePriorityReward
One potentially hacky method but it would give better insight ma…
9.06
content:
  content:
    p:
      score: 0
      elementCount: 2
    a:
      score: 5
      elementCount: 1
  result: 5
regex:
  wordCount: 78
  wordValue: 0.1
  result: 4.06
0.5313.59
Copy the selector from the start of the data and then paste it i…
5.27
content:
  content:
    p:
      score: 0
      elementCount: 2
  result: 0
regex:
  wordCount: 106
  wordValue: 0.1
  result: 5.27
0.537.905
They both help when debugging in my opinion but both are not req…
6.06
content:
  content:
    p:
      score: 0
      elementCount: 3
  result: 0
regex:
  wordCount: 125
  wordValue: 0.1
  result: 6.06
0.8314.544
Yeah we do.Also Ana shared QA on another issue that showed the…
3.84
content:
  content:
    p:
      score: 0
      elementCount: 3
  result: 0
regex:
  wordCount: 73
  wordValue: 0.1
  result: 3.84
0.738.064
Looks good. Idk if it's worth it to also log the onchain functio…
8.38
content:
  content:
    p:
      score: 0
      elementCount: 2
    a:
      score: 5
      elementCount: 1
  result: 5
regex:
  wordCount: 63
  wordValue: 0.1
  result: 3.38
0.8320.112

 [ 65.979 UUSD ] 

@gentlementlegen
Contributions Overview
ViewContributionCountReward
ReviewComment865.979
Conversation Incentives
CommentFormattingRelevancePriorityReward
I opened a PR on that regard here: https://github.com/ubiquity/e…
6.17
content:
  content:
    p:
      score: 0
      elementCount: 2
    a:
      score: 5
      elementCount: 1
  result: 5
regex:
  wordCount: 18
  wordValue: 0.1
  result: 1.17
0.335.553
I had implemented our own `ethers-decode-error` but ever…
7.3
content:
  content:
    p:
      score: 0
      elementCount: 3
    a:
      score: 5
      elementCount: 1
  result: 5
regex:
  wordCount: 40
  wordValue: 0.1
  result: 2.3
0.6313.14
@0x4007 You are the one with `NPM` credentials if you ca…
0.94
content:
  content:
    p:
      score: 0
      elementCount: 1
  result: 0
regex:
  wordCount: 14
  wordValue: 0.1
  result: 0.94
0.431.128
@rndquu yeah I tried several times:https://github.com/ubiquity…
7.73
content:
  content:
    p:
      score: 0
      elementCount: 3
    a:
      score: 5
      elementCount: 1
  result: 5
regex:
  wordCount: 49
  wordValue: 0.1
  result: 2.73
0.5311.595
I published it under `ubiquity-os`: https://www.npmjs.co…
11.17
content:
  content:
    p:
      score: 0
      elementCount: 2
    a:
      score: 5
      elementCount: 2
  result: 10
regex:
  wordCount: 18
  wordValue: 0.1
  result: 1.17
0.7323.457
@0x4007 Please move it because I have no access and the NPM toke…
6.9
content:
  content:
    p:
      score: 0
      elementCount: 2
    a:
      score: 5
      elementCount: 1
  result: 5
regex:
  wordCount: 32
  wordValue: 0.1
  result: 1.9
0.336.21
@0x4007 would need the token to be updated in order to publish t…
1.11
content:
  content:
    p:
      score: 0
      elementCount: 1
  result: 0
regex:
  wordCount: 17
  wordValue: 0.1
  result: 1.11
0.431.332
@rndquu if you can delete https://github.com/ubiquity/ethers-dec…
5.94
content:
  content:
    p:
      score: 0
      elementCount: 1
    a:
      score: 5
      elementCount: 1
  result: 5
regex:
  wordCount: 14
  wordValue: 0.1
  result: 0.94
0.233.564

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Projects
Status: Done
Development

Successfully merging a pull request may close this issue.

5 participants