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

Add retry mechanism for partially failed virtual card order #291

Closed
EresDev opened this issue Sep 2, 2024 · 30 comments · Fixed by #357
Closed

Add retry mechanism for partially failed virtual card order #291

EresDev opened this issue Sep 2, 2024 · 30 comments · Fixed by #357

Comments

@EresDev
Copy link
Contributor

EresDev commented Sep 2, 2024

In the virtual card feature, we have two parts in a single transaction to mint a virtual card.

  1. Claim the permit by transferring the permit reward to the treasury wallet
  2. If the step-1 is successful, order the virtual card at Reloadly

The problem is that the transaction isn't atomic because each step happens in a different system. Step-2 can fail while still leaving the permit amount in the treasury. Why would step-2 fail? There could be one of the many reasons.

  • virtual card suddenly becoming out of stock
  • any network error on user side or Reloadly side
  • user closing browser before the permit transaction confirmation
  • change in the best picked card, suddenly a better card becomes available or currently picked card becomes unavailable
  • RPC-handler failing to find rpc for backend to use, or if it finds one but the rpc stops working

Currently, the solution to this problem is manual. It is either a manual refund or manual resending of the card order request to /post-order with some parameters (productId, tx hash, country).

We can improve this by implementing one of the following solutions.

  • a manual refund can become automatic by issuing a new permit of the same amount
  • resend the mint request to backend to /post-order

I am inclined towards resending the mint request. One problem is that /post-order needs the transaction hash of the permit transfer to the treasury. Sometimes you will have it, and you can store it in the cookies/local storage. But sometimes you will not have it and you will have to read it either from blockchain or ask the user to manually insert the transaction hash to retry minting. I think you can read it from blockchain by looking into permit2 events

The goal of this issue is to implement a mechanism to resend the mint request or a better solution if you can think of one.

Since the best-picked virtual card can change in this duration, a better option is to rename the mint button to "Retry Mint" and let the user click first so that user can see they are ordering a different card now.

Please note that the virtual cards feature is present in beta branch at the moment. But it can move to development branch anytime. So, keep an eye on that and open a PR accordingly.

@0x4007
Copy link
Member

0x4007 commented Sep 2, 2024

I think reading from local storage is ideal, then from the chain, generally speaking for these sorts of things.

@whilefoo
Copy link
Contributor

whilefoo commented Sep 5, 2024

I think this problem will be solved once we implement reward rollup and permits will be generated on demand.

For virtual cards this means when the virtual card is created, a entry in the DB will be created but if there's an error creating a virtual card, you don't write to the DB and everything is as it was. The user can retry the operation until it successfully creates a virtual card.

@EresDev
Copy link
Contributor Author

EresDev commented Sep 9, 2024

I think this problem will be solved once we implement reward rollup and permits will be generated on demand.

What I see is that we are probably going to introduce the virtual card feature before the rollup feature.

@zugdev
Copy link
Contributor

zugdev commented Oct 18, 2024

Can someone dm me sandbox API keys? I can't register in Reloadly since I don't have a business email.

@zugdev
Copy link
Contributor

zugdev commented Oct 18, 2024

/start

Copy link
Contributor

ubiquity-os bot commented Oct 19, 2024

@zugdev the deadline is at Sat, Oct 19, 4:15 AM UTC

@0x4007
Copy link
Member

0x4007 commented Oct 19, 2024

I think you can use any email provider like proton mail

@zugdev
Copy link
Contributor

zugdev commented Oct 19, 2024

It's https://www.reloadly.com/ right?

image

@0x4007
Copy link
Member

0x4007 commented Oct 19, 2024

Im sure that you can use your own domain's email then. Setting up email forwarding is simple on cloudflare and google domains.

@harshmittal1750
Copy link

/start

Copy link
Contributor

ubiquity-os bot commented Oct 27, 2024

! This issue is already assigned. Please choose another unassigned task.

@0x4007
Copy link
Member

0x4007 commented Oct 27, 2024

@gentlementlegen disqualify check

@gentlementlegen
Copy link
Member

You can always check the logs: https://github.com/ubiquity-os-marketplace/daemon-disqualifier/actions/runs/11548428245/job/32139825686

@0x4007
Copy link
Member

0x4007 commented Oct 28, 2024

Can you fix this signature thing across all of our plugins?

@gentlementlegen
Copy link
Member

@whilefoo pointed out that it could potentially be because of the use of both the beta and the release that would require different signatures.

@0x4007
Copy link
Member

0x4007 commented Oct 28, 2024

Do you guys have a solution in mind?

@gentlementlegen
Copy link
Member

If that is indeed the reason we need to make proper use of environments for the plugins and secrets. I need to check if that's the root cause.

@whilefoo
Copy link
Contributor

We could modify the SDK to verify the signature for either prod or dev bot

Copy link
Contributor

ubiquity-os bot commented Nov 24, 2024

+ Evaluating results. Please wait...

This comment has been minimized.

@rndquu rndquu removed this from Development Nov 25, 2024
@EresDev
Copy link
Contributor Author

EresDev commented Jan 6, 2025

@0x4007
Does the reward created by UbiquityOS here seems right to you? It is 150$ task but it is paying almost 300$ for issue specifications. I haven't claimed it. I will claim it after your confirmation or a fix.

@0x4007 0x4007 reopened this Jan 6, 2025
@0x4007 0x4007 closed this as completed Jan 6, 2025
@0x4007
Copy link
Member

0x4007 commented Jan 6, 2025

That was before the limits were implemented. And yes there was a brief period of time that the specification rewards algorithm was wrong.

@gentlementlegen
Copy link
Member

@0x4007 text-conversation-rewards configuration has to be updated, will fix.
https://github.com/ubiquity-os-marketplace/text-conversation-rewards/actions/runs/12627969570/job/35183364847

@0x4007
Copy link
Member

0x4007 commented Jan 6, 2025

I don't understand these logs but seems overly verbose to dump the source code and all those arrays.

@gentlementlegen
Copy link
Member

node.js dumps the minified code because there is no sourcemap with it currently.

@0x4007
Copy link
Member

0x4007 commented Jan 6, 2025

Adding the source map is definitely a good idea for debugging.

Copy link
Contributor

ubiquity-os bot commented Jan 6, 2025

 [ 252.15 UUSD ] 

@EresDev
Contributions Overview
ViewContributionCountReward
IssueTask1150
IssueSpecification1100.32
IssueComment11.83
Conversation Incentives
CommentFormattingRelevancePriorityReward
In the virtual card feature, we have two parts in a single trans…
33.44
content:
  content:
    p:
      score: 0
      elementCount: 17
    ol:
      score: 1
      elementCount: 1
    li:
      score: 0.5
      elementCount: 9
    ul:
      score: 1
      elementCount: 2
    a:
      score: 5
      elementCount: 2
  result: 17.5
regex:
  wordCount: 390
  wordValue: 0.1
  result: 15.94
13100.32
What I see is that we are probably going to introduce the virtua…
1.22
content:
  content:
    p:
      score: 0
      elementCount: 1
  result: 0
regex:
  wordCount: 19
  wordValue: 0.1
  result: 1.22
0.531.83

 [ 6.684 UUSD ] 

@0x4007
Contributions Overview
ViewContributionCountReward
IssueComment93.66
ReviewComment53.024
Conversation Incentives
CommentFormattingRelevancePriorityReward
I think reading from local storage is ideal, then from the chain…
1.22
content:
  content:
    p:
      score: 0
      elementCount: 1
  result: 0
regex:
  wordCount: 19
  wordValue: 0.1
  result: 1.22
133.66
I think you can use any email provider like proton mail
0.77
content:
  content:
    p:
      score: 0
      elementCount: 1
  result: 0
regex:
  wordCount: 11
  wordValue: 0.1
  result: 0.77
030
Im sure that you can use your own domain's email then. Setting u…
1.44
content:
  content:
    p:
      score: 0
      elementCount: 1
  result: 0
regex:
  wordCount: 23
  wordValue: 0.1
  result: 1.44
030
@gentlementlegen disqualify check
0.25
content:
  content:
    p:
      score: 0
      elementCount: 1
  result: 0
regex:
  wordCount: 3
  wordValue: 0.1
  result: 0.25
030
Can you fix this signature thing across all of our plugins?
0.77
content:
  content:
    p:
      score: 0
      elementCount: 1
  result: 0
regex:
  wordCount: 11
  wordValue: 0.1
  result: 0.77
030
Do you guys have a solution in mind?
0.59
content:
  content:
    p:
      score: 0
      elementCount: 1
  result: 0
regex:
  wordCount: 8
  wordValue: 0.1
  result: 0.59
030
That was before the limits were implemented. And yes there was a…
1.44
content:
  content:
    p:
      score: 0
      elementCount: 1
  result: 0
regex:
  wordCount: 23
  wordValue: 0.1
  result: 1.44
030
I don't understand these logs but seems overly verbose to dump t…
1.22
content:
  content:
    p:
      score: 0
      elementCount: 1
  result: 0
regex:
  wordCount: 19
  wordValue: 0.1
  result: 1.22
030
Adding the source map is definitely a good idea for debugging.
0.77
content:
  content:
    p:
      score: 0
      elementCount: 1
  result: 0
regex:
  wordCount: 11
  wordValue: 0.1
  result: 0.77
030
Code seems fine. What's the best way to test it?
0.77
content:
  content:
    p:
      score: 0
      elementCount: 1
  result: 0
regex:
  wordCount: 11
  wordValue: 0.1
  result: 0.77
0.230.462
Code looks fine
0.25
content:
  content:
    p:
      score: 0
      elementCount: 1
  result: 0
regex:
  wordCount: 3
  wordValue: 0.1
  result: 0.25
0.130.075
Perhaps you should always return a response
0.52
content:
  content:
    p:
      score: 0
      elementCount: 1
  result: 0
regex:
  wordCount: 7
  wordValue: 0.1
  result: 0.52
0.831.248
Shouldn't we default to the international one
0.59
content:
  content:
    p:
      score: 0
      elementCount: 1
  result: 0
regex:
  wordCount: 8
  wordValue: 0.1
  result: 0.59
0.731.239
```suggestionlet signedMessage;```
0
content:
  content: {}
  result: 0
regex:
  wordCount: 0
  wordValue: 0.1
  result: 0
0.630

 [ 13.14 UUSD ] 

@whilefoo
Contributions Overview
ViewContributionCountReward
IssueComment213.14
Conversation Incentives
CommentFormattingRelevancePriorityReward
I think this problem will be solved once we implement reward rol…
3.88
content:
  content:
    p:
      score: 0
      elementCount: 2
  result: 0
regex:
  wordCount: 74
  wordValue: 0.1
  result: 3.88
1311.64
We could modify the SDK to verify the signature for either prod …
1
content:
  content:
    p:
      score: 0
      elementCount: 1
  result: 0
regex:
  wordCount: 15
  wordValue: 0.1
  result: 1
0.531.5

 [ 4.86 UUSD ] 

@gentlementlegen
Contributions Overview
ViewContributionCountReward
IssueComment54.86
Conversation Incentives
CommentFormattingRelevancePriorityReward
You can always check the logs: https://github.com/ubiquity-os-ma…
5.46
content:
  content:
    p:
      score: 0
      elementCount: 1
    a:
      score: 5
      elementCount: 1
  result: 5
regex:
  wordCount: 6
  wordValue: 0.1
  result: 0.46
030
@whilefoo pointed out that it could potentially be because of th…
1.49
content:
  content:
    p:
      score: 0
      elementCount: 1
  result: 0
regex:
  wordCount: 24
  wordValue: 0.1
  result: 1.49
0.532.235
If that is indeed the reason we need to make proper use of envir…
1.75
content:
  content:
    p:
      score: 0
      elementCount: 1
  result: 0
regex:
  wordCount: 29
  wordValue: 0.1
  result: 1.75
0.532.625
@0x4007 `text-conversation-rewards` configuration has to…
5.59
content:
  content:
    p:
      score: 0
      elementCount: 2
    a:
      score: 5
      elementCount: 1
  result: 5
regex:
  wordCount: 8
  wordValue: 0.1
  result: 0.59
030
`node.js` dumps the minified code because there is no so…
0.83
content:
  content:
    p:
      score: 0
      elementCount: 1
  result: 0
regex:
  wordCount: 12
  wordValue: 0.1
  result: 0.83
030

 [ 44.712 UUSD ] 

@rndquu
Contributions Overview
ViewContributionCountReward
ReviewComment244.712
Conversation Incentives
CommentFormattingRelevancePriorityReward
Works fine
0.18
content:
  content:
    p:
      score: 0
      elementCount: 1
  result: 0
regex:
  wordCount: 2
  wordValue: 0.1
  result: 0.18
0.130.054
@EresDev 1. Could you add a unit test for a successfull "parti…
16.54
content:
  content:
    p:
      score: 0
      elementCount: 3
    ol:
      score: 1
      elementCount: 1
    li:
      score: 0.5
      elementCount: 2
    a:
      score: 5
      elementCount: 2
  result: 12
regex:
  wordCount: 89
  wordValue: 0.1
  result: 4.54
0.9344.658

@gentlementlegen
Copy link
Member

Sorry about all the spam, I forgot that this repo had a different configuration and wouldn't understand why the changes wouldn't work, it is now up to date.

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

Successfully merging a pull request may close this issue.

7 participants