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

fix: prevent to print an error message #293

Closed

Conversation

whck6
Copy link

@whck6 whck6 commented Sep 8, 2024

Signed-off-by: Wenhao Ho [email protected]

Resolves #285

@whck6 whck6 requested a review from Keyrxng as a code owner September 8, 2024 16:18
@whck6
Copy link
Author

whck6 commented Sep 8, 2024

@Keyrxng FYI: ethers-io/ethers.js#866

@Keyrxng
Copy link
Contributor

Keyrxng commented Sep 8, 2024

I wasn't aware of that issue that's good to know. Looking through it and the discussion it was moved to it looks like recreating the provider works too and doesn't force a page reload which would be preferred if it works, do you know if it does?

@whck6
Copy link
Author

whck6 commented Sep 9, 2024

@Keyrxng I've revised the code by re-creating means, do you mind helping review and test if it fits our an expectation?

@Keyrxng
Copy link
Contributor

Keyrxng commented Sep 9, 2024

@Keyrxng I've revised the code by re-creating means, do you mind helping review and test if it fits our an expectation?

Thanks but since the issue you are aiming to resolve requires another issue that has not been finalized yet it's a little difficult for me to test the problem as it does not exist on development just yet.

Please bare with me and I'll try to push through other PRs today. Please keep in mind that issues that require other issues to be resolved first sometimes cannot be merged until the underlying issue is merged.

@ubiquity-os-deployer
Copy link

Copy link
Contributor

Preview Deployment
06ec962c7e7ddc80843c174cfc395821721e67b3

@@ -10,7 +10,8 @@ export async function verifyCurrentNetwork(desiredNetworkId: number) {
return;
}

const web3provider = new ethers.providers.Web3Provider(window.ethereum);
let web3provider = new ethers.providers.Web3Provider(window.ethereum);
web3provider = new ethers.providers.Web3Provider(web3provider.provider);
Copy link
Contributor

@Keyrxng Keyrxng Sep 12, 2024

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

The flow without a page reload would be like this:

  1. page renders and we call this function.
  2. Assume no network change is required, nothing happens.
  1. Assume network change is required, the change happens after this in another function.
  2. We do not update our global signer and this function would only be called again if they clicked claim again, which isn't possible with the current setup as it'll have a loader. Plus these objects are in-memory and not used for txs or anything.
  3. The user claim event proceeds and fails against the old provider.

I think a better approach might be for this is to be placed inside connect-wallet() which is the place where the signer comes from which is what we are interested in. connect-wallet is called prior to any claim which makes taking the newly updated web3Provider/signer easier.

P.S: Most, if not all PRs should be accompanied by some kind of QA whether that's a screenshot or small video just to prove the logic works as expected. Here, we'd expect to see a couple of network changes and a claim tx going through, seeing the browser console while these happen is also beneficial and appreciated.

Copy link
Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

@Keyrxng Did you mean not only verify-current-network.ts but also apply it to connect-wallet.ts?

@whck6
Copy link
Author

whck6 commented Sep 13, 2024

By the way, I don't know why I can't exactly reproduce the underlying network changed message.

  1. Connect Polygon network or others
  2. Open https://pay.ubq.fi/?claim=xxxx
  3. Switch network via that is prompted by Metamask
  4. Check console.log

What do you think?

@Keyrxng
Copy link
Contributor

Keyrxng commented Sep 15, 2024

By the way, I don't know why I can't exactly reproduce the underlying network changed message.

  1. Connect Polygon network or others
  2. Open https://pay.ubq.fi/?claim=xxxx
  3. Switch network via that is prompted by Metamask
  4. Check console.log

What do you think?

I'm not 100% sure. I referenced the PR which introduced the bug and that PR has not yet been merged into development. It could be a logic error within the PR itself, it could be the web3Provider causing it all I know is that it was happening intermittently and I tried to give as much info as I could find.

I wasn't sure which is why I said it would require further debugging in the task spec, which meant in relation to the logic added in the referenced PR as it contained a large refactoring of the core logic.

I think your time would be better served resolving other tasks until this task is resolved, the PR was merged and had errors so it was reverted and it has not been fixed by the contributor yet. Sorry about that @whck6.

@rndquu
Copy link
Member

rndquu commented Oct 11, 2024

Closing this because original issue was closed as "not planned"

@rndquu rndquu closed this Oct 11, 2024
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
None yet
Projects
None yet
Development

Successfully merging this pull request may close these issues.

Network switching bug
3 participants