Commit d40772d
authored
fix(eip7702): validate factory field with eip7702 requirements (#712)
* fix(eip7702): validate factory field with eip7702 requirements
- Add validation for 0x7702 factory address in both short and padded
forms
- Require eip7702Auth when factory is set to 0x7702
- Add comprehensive test coverage for both factory address formats
* fix(rpc): add eip7702Auth validation for 0x7702 factory
- Add early validation check for EIP-7702 userOps with 0x7702 factory
- Ensure eip7702Auth is provided when factory is 0x7702
- Update error message for consistency
* chore: format
* fix(rpc): remove incorrect eip7702 factory validation
- Removed validation check that incorrectly rejected userOps with factory 0x7702 but no eip7702Auth
- This check was overly restrictive and not aligned with EIP-7702 specification
* feat(gas-estimation): add userOp field validation for estimation
- Add early userOp field validation in eth_estimateUserOperationGas
- Add isEstimation flag to skip gas checks during estimation
- Consolidate EIP-7702 factory validation and remove duplication
* style(rpc): fix line wrapping in factory validation
* chore: format
* test(e2e): add ERC-7702 factory validation test
- Add test cases for rejecting estimation with 0x7702 factory without eip7702Auth
- Test both short form (0x7702) and zero-padded form validation
- Skip test for v0.6 which doesn't support factory field
* test(eth_estimateUserOperationGas): use bundler client for gas estimation
- Separate bundler client creation for gas estimation calls
- Rename smartAccountClient for clarity
- Pass entryPointAddress explicitly to estimateUserOperationGas1 parent b39bdd5 commit d40772d
4 files changed
Lines changed: 158 additions & 2 deletions
File tree
- src/rpc
- methods
- test/e2e/tests
| Original file line number | Diff line number | Diff line change | |
|---|---|---|---|
| |||
284 | 284 | | |
285 | 285 | | |
286 | 286 | | |
| 287 | + | |
| 288 | + | |
| 289 | + | |
| 290 | + | |
| 291 | + | |
| 292 | + | |
| 293 | + | |
| 294 | + | |
| 295 | + | |
| 296 | + | |
287 | 297 | | |
288 | 298 | | |
289 | 299 | | |
| |||
| Original file line number | Diff line number | Diff line change | |
|---|---|---|---|
| |||
145 | 145 | | |
146 | 146 | | |
147 | 147 | | |
148 | | - | |
| 148 | + | |
| 149 | + | |
149 | 150 | | |
150 | 151 | | |
151 | 152 | | |
152 | 153 | | |
| 154 | + | |
153 | 155 | | |
| 156 | + | |
| 157 | + | |
| 158 | + | |
| 159 | + | |
| 160 | + | |
| 161 | + | |
| 162 | + | |
| 163 | + | |
| 164 | + | |
| 165 | + | |
| 166 | + | |
| 167 | + | |
| 168 | + | |
| 169 | + | |
| 170 | + | |
| 171 | + | |
| 172 | + | |
| 173 | + | |
154 | 174 | | |
155 | 175 | | |
156 | 176 | | |
| |||
341 | 361 | | |
342 | 362 | | |
343 | 363 | | |
| 364 | + | |
344 | 365 | | |
345 | 366 | | |
346 | 367 | | |
347 | 368 | | |
348 | | - | |
| 369 | + | |
349 | 370 | | |
350 | 371 | | |
351 | 372 | | |
| |||
| Original file line number | Diff line number | Diff line change | |
|---|---|---|---|
| |||
379 | 379 | | |
380 | 380 | | |
381 | 381 | | |
| 382 | + | |
| 383 | + | |
| 384 | + | |
| 385 | + | |
| 386 | + | |
| 387 | + | |
| 388 | + | |
| 389 | + | |
| 390 | + | |
| 391 | + | |
| 392 | + | |
| 393 | + | |
| 394 | + | |
| 395 | + | |
| 396 | + | |
| 397 | + | |
| 398 | + | |
| 399 | + | |
| 400 | + | |
| 401 | + | |
| 402 | + | |
| 403 | + | |
| 404 | + | |
| 405 | + | |
| 406 | + | |
| 407 | + | |
| 408 | + | |
| 409 | + | |
| 410 | + | |
| 411 | + | |
| 412 | + | |
| 413 | + | |
| 414 | + | |
| 415 | + | |
| 416 | + | |
| 417 | + | |
| 418 | + | |
| 419 | + | |
| 420 | + | |
| 421 | + | |
| 422 | + | |
| 423 | + | |
| 424 | + | |
| 425 | + | |
| 426 | + | |
| 427 | + | |
| 428 | + | |
| 429 | + | |
| 430 | + | |
| 431 | + | |
| 432 | + | |
| 433 | + | |
| 434 | + | |
| 435 | + | |
| 436 | + | |
| 437 | + | |
| 438 | + | |
| 439 | + | |
| 440 | + | |
| 441 | + | |
| 442 | + | |
| 443 | + | |
| 444 | + | |
| 445 | + | |
| 446 | + | |
382 | 447 | | |
383 | 448 | | |
384 | 449 | | |
| |||
| Original file line number | Diff line number | Diff line change | |
|---|---|---|---|
| |||
533 | 533 | | |
534 | 534 | | |
535 | 535 | | |
| 536 | + | |
| 537 | + | |
| 538 | + | |
| 539 | + | |
| 540 | + | |
| 541 | + | |
| 542 | + | |
| 543 | + | |
| 544 | + | |
| 545 | + | |
| 546 | + | |
| 547 | + | |
| 548 | + | |
| 549 | + | |
| 550 | + | |
| 551 | + | |
| 552 | + | |
| 553 | + | |
| 554 | + | |
| 555 | + | |
| 556 | + | |
| 557 | + | |
| 558 | + | |
| 559 | + | |
| 560 | + | |
| 561 | + | |
| 562 | + | |
| 563 | + | |
| 564 | + | |
| 565 | + | |
| 566 | + | |
| 567 | + | |
| 568 | + | |
| 569 | + | |
| 570 | + | |
| 571 | + | |
| 572 | + | |
| 573 | + | |
| 574 | + | |
| 575 | + | |
| 576 | + | |
| 577 | + | |
| 578 | + | |
| 579 | + | |
| 580 | + | |
| 581 | + | |
| 582 | + | |
| 583 | + | |
| 584 | + | |
| 585 | + | |
| 586 | + | |
| 587 | + | |
| 588 | + | |
| 589 | + | |
| 590 | + | |
| 591 | + | |
| 592 | + | |
| 593 | + | |
| 594 | + | |
| 595 | + | |
536 | 596 | | |
537 | 597 | | |
538 | 598 | | |
| |||
0 commit comments