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

feat: merge CAIP69 into CAIP10 for specifying EOA wallets #107

Merged
merged 11 commits into from
Apr 4, 2024

Conversation

jainkrati
Copy link
Contributor

@jainkrati jainkrati commented Mar 19, 2024

The goal of this PR is to empower CAIP 10 to specify EOA across EVM Chains with chainID of 0.

We raised a PR for this earlier in CAIP repo ChainAgnostic/CAIPs#268 and based on review comments/suggestions, we are raising this PR.

@jainkrati jainkrati changed the title feat: updates CAIP10 for EOA feat: merge CAIP69 into CAIP10 for specifying EOA wallets Mar 21, 2024
eip155/caip10.md Outdated Show resolved Hide resolved
eip155/caip10.md Outdated Show resolved Hide resolved
eip155/caip10.md Outdated Show resolved Hide resolved
eip155/caip10.md Outdated Show resolved Hide resolved
@obstropolos obstropolos self-requested a review March 22, 2024 22:19
Copy link
Contributor

@obstropolos obstropolos left a comment

Choose a reason for hiding this comment

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

Approved pending final feedback review for @jainkrati

@jainkrati
Copy link
Contributor Author

re-requesting review from @bumblefudge to confirm if changes look good and I did not miss any review comments.

eip155/caip10.md Outdated Show resolved Hide resolved
eip155/caip10.md Outdated Show resolved Hide resolved
eip155/caip10.md Outdated Show resolved Hide resolved
Copy link
Collaborator

@bumblefudge bumblefudge left a comment

Choose a reason for hiding this comment

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

Hey, almost done here, just noticed a TODO and a header change and a regex change. Apologies for the inefficiency!

jainkrati and others added 3 commits March 26, 2024 19:54
Co-authored-by: Bumblefudge <[email protected]>
Co-authored-by: Bumblefudge <[email protected]>
Co-authored-by: Bumblefudge <[email protected]>
eip155/caip10.md Show resolved Hide resolved
@GregTheGreek
Copy link

GregTheGreek commented Mar 26, 2024

I'm really not a fan of this, namely this adds a weird edge case that is non-specific to the naming convention of chain_id. I would much rather append a new variable to the string, where EOA == 0, Smart Account == 1, and reserve future numbers for any future account types that may arise, specifically if L2's adopt some sort of unique case.

I'd suggest the following:

chain_id:    namespace + ":" + network_id + ":" + account_type + ":" + reference
namespace:   [-a-z0-9]{3,8}
network_id:    [0-9]{1,19}
account_type: [0-9]{1,2}
reference:   0x[a-fA-F0-9]{1,32}

We can still maintain backward compatibility by doing a simple check:

if (chainIdString.match(/:/g) || []).length === 3) {
  // Contains account type
} else if (chainIdString.match(/:/g) || []).length == 2) {
  // Old chainIdString
} else {
  // error
}

We can then verify if this account is EOA or SCW by doing the following checks:

  1. EOA: Have them sign a message, and try to perform ec_recover
  2. SCW: Have them sign a EIP-1271 message
  3. Counterfactual SCW: Have them sign a ERC-6492 message

@bumblefudge
Copy link
Collaborator

this adds a weird edge case that is non-specific to the naming convention of chain_id. I would much rather append a new variable to the string

by "append a new [segment] to the string" do you mean breaking CAIP-10? non-EVM devs might consider ethereum's evolving concept of an account the weird edge case, in that the EOA/SCA distinction is entirely specific to EVM wallet interfaces (I can't think of any other namespace that would use this new segment). What I'm getting at is that if we added a segment to all CAIP-10s, every non-EVM CAIP-10 would A.) break, and B.) have to insert, going forward, a :0 segment that expresses a distinction their addressing namespace doesn't make or need...

in defense of the original proposal, I don't think this edge case is so weird in the EVM tradition-- it continues the tradition of the wallet_ namespace for dapp<>wallet RPCs (as opposed to eth_ namespace for node RPCs), in the chainId namespace. By shoehorning the wallet_ context into the chainId system, they are encouraging people NOT to mix wallet_ methods and eth_ methods. This would also make "off-chain signatures" impossible to replay on any chain...

  1. EOA: Have them sign a[n offchain] message, and try to perform ec_recover
  2. SCW: Have them sign a EIP-1271 message
  3. Counterfactual SCW: Have them sign a ERC-6492 message

The way I see it, 1/2/3 is already status quo, or to put it another way, what you describe as the verification step in the future where CAIP-10s mark accounts by type is today's clunky discovery step for lack of any such type discovery. Both the original proposal and your "additional segment" counterproposal both add a declarative standard notation for what, today, is guessed at or deduced at the last minute. My argument is that 2 and 3 ARE chain-specific and 1 is specifically chain-independent/offchain, and I feel like future types (the values other than 0 and 1 in your proposal) will all be either chain-specific or off-chain, so i'm not sure we need to hold space for future wallet-typing. If anything, typing of wallets is a legacy problem, and the "let's phase out EOAs forever" crowd would probably like us to sunset the special case of EOAs and move to an entirely abstracted future in which there is no need to type (or sniff) wallets...

@bumblefudge
Copy link
Collaborator

bumblefudge commented Apr 3, 2024

@GregTheGreek I hope that didn't come across as dismissive, just trying to read you in on the history of CAIP-10 design (and implementation) before this PR and explain why the odds are so stacked against a new segment. Does this new information address your qualms? Would merging this make you less likely to use or trust CAIP-10s in future multichain/cross-chain projects? Can you think of other alternatives that might be more palatable to CAIP-10's existing users and downstream projects?

@jainkrati @GriffGreen are you guys happy with the new version? feel free to roll back individual edits or push back, i'm just an editor here. Sorry to slow things down, I was just trying to factor in a few corner-cases I know of from other implementers.

I talked to Obstropolous out-of-band (well, at a public meeting of the CASA editorial WG) and I don't think his approval needs to be staled/rerequested, he workshopped my edits and is happy either way as long as nothing normative/major changes in further edits. he's pretty deep in implementation on the topic from Spruce days, after all.

Co-authored-by: Bumblefudge <[email protected]>
@jainkrati
Copy link
Contributor Author

Thanks @bumblefudge ! Really appreciate your help here for progressing this PR

@bumblefudge
Copy link
Collaborator

OK I'd say that's affirmative consent enough to merge, but DO feel free to tag each other and any other stakeholder you think would have useful feedback in follow-on PRs if you still have misgivings or if new counter-proposals or extensions come to mind over time, @GregTheGreek and @GriffGreen !

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.

4 participants