Skip to content

Commit

Permalink
Merge branch 'develop' into paymaster-check-ep-supportedInterface
Browse files Browse the repository at this point in the history
  • Loading branch information
drortirosh committed Jan 3, 2024
2 parents 299d705 + 63d8226 commit 74bad58
Show file tree
Hide file tree
Showing 29 changed files with 323 additions and 732 deletions.
2 changes: 0 additions & 2 deletions .solcover.js
Original file line number Diff line number Diff line change
Expand Up @@ -2,8 +2,6 @@ module.exports = {
skipFiles: [
"test",
"samples/bls/lib",
//solc-coverage fails to compile our Manager module.
"samples/gnosis",
"utils/Exec.sol"
],
configureYulOptimizer: true,
Expand Down
2 changes: 1 addition & 1 deletion contracts/core/BasePaymaster.sol
Original file line number Diff line number Diff line change
Expand Up @@ -17,7 +17,7 @@ import "./Helpers.sol";
abstract contract BasePaymaster is IPaymaster, Ownable {
IEntryPoint public immutable entryPoint;

constructor(IEntryPoint _entryPoint) {
constructor(IEntryPoint _entryPoint) Ownable(msg.sender) {
_validateEntryPointInterface(_entryPoint);
entryPoint = _entryPoint;
}
Expand Down
11 changes: 8 additions & 3 deletions contracts/core/EntryPoint.sol
Original file line number Diff line number Diff line change
@@ -1,6 +1,5 @@
// SPDX-License-Identifier: GPL-3.0
pragma solidity ^0.8.12;

pragma solidity ^0.8.23;
/* solhint-disable avoid-low-level-calls */
/* solhint-disable no-inline-assembly */

Expand All @@ -17,7 +16,7 @@ import "./UserOperationLib.sol";

// we also require '@gnosis.pm/safe-contracts' and both libraries have 'IERC165.sol', leading to conflicts
import "@openzeppelin/contracts/utils/introspection/ERC165.sol" as OpenZeppelin;
import "@openzeppelin/contracts/security/ReentrancyGuard.sol";
import "@openzeppelin/contracts/utils/ReentrancyGuard.sol";

/*
* Account-Abstraction (EIP-4337) singleton EntryPoint implementation.
Expand Down Expand Up @@ -753,4 +752,10 @@ contract EntryPoint is IEntryPoint, StakeManager, NonceManager, ReentrancyGuard,
data := offset
}
}

/// @inheritdoc IEntryPoint
function delegateAndRevert(address target, bytes calldata data) external {
(bool success, bytes memory ret) = target.delegatecall(data);
revert DelegateAndRevert(success, ret);
}
}
9 changes: 9 additions & 0 deletions contracts/interfaces/IEntryPoint.sol
Original file line number Diff line number Diff line change
Expand Up @@ -198,4 +198,13 @@ interface IEntryPoint is IStakeManager, INonceManager {
*/
function getSenderAddress(bytes memory initCode) external;

error DelegateAndRevert(bool success, bytes ret);

/**
* Helper method for dry-run testing.
* @dev calling this method, the EntryPoint will make a delegatecall to the given data, and report (via revert) the result.
* The method always revert, so is only useful off-chain for dry run calls, in cases where state-override to replace
* actual EntryPoint code is less convenient.
*/
function delegateAndRevert(address target, bytes calldata data) external;
}
1 change: 0 additions & 1 deletion contracts/package.json
Original file line number Diff line number Diff line change
Expand Up @@ -24,7 +24,6 @@
"url": "https://github.com/eth-infinitism/account-abstraction/issues"
},
"devDependencies": {
"@gnosis.pm/safe-contracts": "^1.3.0",
"@nomiclabs/hardhat-ethers": "^2.0.2",
"@nomiclabs/hardhat-waffle": "^2.0.1",
"@uniswap/v3-periphery": "^1.4.3"
Expand Down
15 changes: 6 additions & 9 deletions contracts/samples/SimpleAccount.sol
Original file line number Diff line number Diff line change
@@ -1,14 +1,14 @@
// SPDX-License-Identifier: GPL-3.0
pragma solidity ^0.8.12;
pragma solidity ^0.8.23;

/* solhint-disable avoid-low-level-calls */
/* solhint-disable no-inline-assembly */
/* solhint-disable reason-string */

import "@openzeppelin/contracts/utils/cryptography/ECDSA.sol";
import "@openzeppelin/contracts/utils/cryptography/MessageHashUtils.sol";
import "@openzeppelin/contracts/proxy/utils/Initializable.sol";
import "@openzeppelin/contracts/proxy/utils/UUPSUpgradeable.sol";

import "../core/BaseAccount.sol";
import "./callback/TokenCallbackHandler.sol";

Expand All @@ -19,8 +19,6 @@ import "./callback/TokenCallbackHandler.sol";
* has a single signer that can send requests through the entryPoint.
*/
contract SimpleAccount is BaseAccount, TokenCallbackHandler, UUPSUpgradeable, Initializable {
using ECDSA for bytes32;

address public owner;

IEntryPoint private immutable _entryPoint;
Expand All @@ -37,7 +35,6 @@ contract SimpleAccount is BaseAccount, TokenCallbackHandler, UUPSUpgradeable, In
return _entryPoint;
}


// solhint-disable-next-line no-empty-blocks
receive() external payable {}

Expand Down Expand Up @@ -99,14 +96,14 @@ contract SimpleAccount is BaseAccount, TokenCallbackHandler, UUPSUpgradeable, In
/// implement template method of BaseAccount
function _validateSignature(UserOperation calldata userOp, bytes32 userOpHash)
internal override virtual returns (uint256 validationData) {
bytes32 hash = userOpHash.toEthSignedMessageHash();
if (owner != hash.recover(userOp.signature))
bytes32 hash = MessageHashUtils.toEthSignedMessageHash(userOpHash);
if (owner != ECDSA.recover(hash, userOp.signature))
return SIG_VALIDATION_FAILED;
return 0;
}

function _call(address target, uint256 value, bytes memory data) internal {
(bool success, bytes memory result) = target.call{value : value}(data);
(bool success, bytes memory result) = target.call{value: value}(data);
if (!success) {
assembly {
revert(add(result, 32), mload(result))
Expand All @@ -125,7 +122,7 @@ contract SimpleAccount is BaseAccount, TokenCallbackHandler, UUPSUpgradeable, In
* deposit more funds for this account in the entryPoint
*/
function addDeposit() public payable {
entryPoint().depositTo{value : msg.value}(address(this));
entryPoint().depositTo{value: msg.value}(address(this));
}

/**
Expand Down
6 changes: 3 additions & 3 deletions contracts/samples/TokenPaymaster.sol
Original file line number Diff line number Diff line change
Expand Up @@ -29,13 +29,13 @@ contract TokenPaymaster is BasePaymaster, UniswapHelper, OracleHelper {
uint256 priceMarkup;

/// @notice Exchange tokens to native currency if the EntryPoint balance of this Paymaster falls below this value
uint256 minEntryPointBalance;
uint128 minEntryPointBalance;

/// @notice Estimated gas cost for refunding tokens after the transaction is completed
uint256 refundPostopCost;
uint48 refundPostopCost;

/// @notice Transactions are only valid as long as the cached price is not older than this value
uint256 priceMaxAge;
uint48 priceMaxAge;
}

event ConfigUpdated(TokenPaymasterConfig tokenPaymasterConfig);
Expand Down
4 changes: 2 additions & 2 deletions contracts/samples/VerifyingPaymaster.sol
Original file line number Diff line number Diff line change
Expand Up @@ -7,6 +7,7 @@ pragma solidity ^0.8.12;
import "../core/BasePaymaster.sol";
import "../core/UserOperationLib.sol";
import "@openzeppelin/contracts/utils/cryptography/ECDSA.sol";
import "@openzeppelin/contracts/utils/cryptography/MessageHashUtils.sol";
/**
* A sample paymaster that uses external service to decide whether to pay for the UserOp.
* The paymaster trusts an external signer to sign the transaction.
Expand All @@ -18,7 +19,6 @@ import "@openzeppelin/contracts/utils/cryptography/ECDSA.sol";
*/
contract VerifyingPaymaster is BasePaymaster {

using ECDSA for bytes32;
using UserOperationLib for UserOperation;

address public immutable verifyingSigner;
Expand Down Expand Up @@ -78,7 +78,7 @@ contract VerifyingPaymaster is BasePaymaster {
//ECDSA library supports both 64 and 65-byte long signatures.
// we only "require" it here so that the revert reason on invalid signature will be of "VerifyingPaymaster", and not "ECDSA"
require(signature.length == 64 || signature.length == 65, "VerifyingPaymaster: invalid signature length in paymasterAndData");
bytes32 hash = ECDSA.toEthSignedMessageHash(getHash(userOp, validUntil, validAfter));
bytes32 hash = MessageHashUtils.toEthSignedMessageHash(getHash(userOp, validUntil, validAfter));

//don't revert on signature failure: return SIG_VALIDATION_FAILED
if (verifyingSigner != ECDSA.recover(hash, signature)) {
Expand Down
12 changes: 1 addition & 11 deletions contracts/samples/callback/TokenCallbackHandler.sol
Original file line number Diff line number Diff line change
Expand Up @@ -4,24 +4,14 @@ pragma solidity ^0.8.12;
/* solhint-disable no-empty-blocks */

import "@openzeppelin/contracts/utils/introspection/IERC165.sol";
import "@openzeppelin/contracts/token/ERC777/IERC777Recipient.sol";
import "@openzeppelin/contracts/token/ERC721/IERC721Receiver.sol";
import "@openzeppelin/contracts/token/ERC1155/IERC1155Receiver.sol";

/**
* Token callback handler.
* Handles supported tokens' callbacks, allowing account receiving these tokens.
*/
contract TokenCallbackHandler is IERC777Recipient, IERC721Receiver, IERC1155Receiver {
function tokensReceived(
address,
address,
address,
uint256,
bytes calldata,
bytes calldata
) external pure override {
}
contract TokenCallbackHandler is IERC721Receiver, IERC1155Receiver {

function onERC721Received(
address,
Expand Down
89 changes: 0 additions & 89 deletions contracts/samples/gnosis/EIP4337Fallback.sol

This file was deleted.

Loading

0 comments on commit 74bad58

Please sign in to comment.