The fragmentation I’ve outlined primarily relates to dapps rather than wallets. What I mean by “initiate fragmentation” is that 3074 will set in motion a parallel track of smart wallet development that does not seamlessly align with the roadmap for full account abstraction.
I acknowledge the importance of additional functionalities to EOAs. Infinite approval scams have hunted the ecosystem for too long, and batch transactions is the solution. Gas sponsorship is crucial for usability beyond today’s users. I do agree that upgrading EOAs isn’t a trivial task, as you’ve rightly pointed out. It poses risks because someone will inevitably honor the key.
Although 3074 seems straightforward to implement, its implications on wallet ecosystem development are profound if integrated into L1. It further encourages EOA development. It slows down users and developers from transitioning to to a better model where it protects users with key rotation and different signature schemes.
EOAs will eventually be deprecated, not by choice, but due to quantum advancement. Further enshrinement encourages not only its continued spread and adoption, but also it’s gets us away further from the end goal of full native AA.
Not to sound too much like a broken record, but EIP-3074 was designed to allow changing the signature format/algorithm. Whatever approach is adopted by EOA and ecrecover signatures, EIP-3074 can adopt too.
I believe EIP-3074 can possibly bypass the first check msg.sender == tx.origin, contracts have zero codesize can bypass the second check codeSize == 0, but they can never be bypassed together? You have to authorize an existing contract to AUTHCALL, right?