Skip to content

Commit

Permalink
Merge branch 'main' into lyova-integrate-timestamp-asserter
Browse files Browse the repository at this point in the history
  • Loading branch information
ly0va authored Nov 25, 2024
2 parents 1e07c45 + 7464e21 commit bdf7d6f
Show file tree
Hide file tree
Showing 8 changed files with 28 additions and 19 deletions.
2 changes: 2 additions & 0 deletions cspell-config/cspell-sol.txt
Original file line number Diff line number Diff line change
Expand Up @@ -32,3 +32,5 @@ RPID
Raphson
solady
xbatch
tload
tstore
5 changes: 4 additions & 1 deletion hardhat.config.ts
Original file line number Diff line number Diff line change
Expand Up @@ -52,7 +52,10 @@ const config: HardhatUserConfig = {
},
},
solidity: {
version: "0.8.24",
version: "0.8.28",
settings: {
evmVersion: "cancun",
}
},
};

Expand Down
2 changes: 1 addition & 1 deletion src/helpers/Base64.sol
Original file line number Diff line number Diff line change
@@ -1,7 +1,7 @@
// SPDX-License-Identifier: MIT
// OpenZeppelin Contracts (last updated v5.0.0) (utils/Base64.sol)

pragma solidity 0.8.24;
pragma solidity ^0.8.24;

/**
* @dev Provides a set of functions to operate with Base64 strings.
Expand Down
2 changes: 1 addition & 1 deletion src/helpers/EIP712.sol
Original file line number Diff line number Diff line change
@@ -1,7 +1,7 @@
// SPDX-License-Identifier: MIT
// OpenZeppelin Contracts (last updated v5.0.0) (utils/cryptography/EIP712.sol)

pragma solidity 0.8.24;
pragma solidity ^0.8.24;

// OpenZeppelin Contracts (last updated v5.0.0) (utils/cryptography/MessageHashUtils.sol)

Expand Down
2 changes: 1 addition & 1 deletion src/helpers/TokenCallbackHandler.sol
Original file line number Diff line number Diff line change
@@ -1,5 +1,5 @@
// SPDX-License-Identifier: GPL-3.0
pragma solidity 0.8.24;
pragma solidity ^0.8.24;
import "@openzeppelin/contracts/utils/introspection/IERC165.sol";
import "@openzeppelin/contracts/token/ERC721/IERC721Receiver.sol";
import "@openzeppelin/contracts/token/ERC1155/IERC1155Receiver.sol";
Expand Down
2 changes: 1 addition & 1 deletion src/helpers/VerifierCaller.sol
Original file line number Diff line number Diff line change
@@ -1,5 +1,5 @@
// SPDX-License-Identifier: GPL-3.0
pragma solidity 0.8.24;
pragma solidity ^0.8.24;

abstract contract VerifierCaller {
/**
Expand Down
2 changes: 1 addition & 1 deletion src/test/VerifierCaller.sol
Original file line number Diff line number Diff line change
@@ -1,5 +1,5 @@
// SPDX-License-Identifier: GPL-3.0
pragma solidity 0.8.24;
pragma solidity ^0.8.24;

abstract contract VerifierCaller {
/**
Expand Down
30 changes: 17 additions & 13 deletions src/validators/SessionKeyValidator.sol
Original file line number Diff line number Diff line change
@@ -1,5 +1,5 @@
// SPDX-License-Identifier: MIT
pragma solidity ^0.8.23;
pragma solidity ^0.8.24;

import { EnumerableSet } from "@openzeppelin/contracts/utils/structs/EnumerableSet.sol";
import { IERC165 } from "@openzeppelin/contracts/utils/introspection/IERC165.sol";
Expand Down Expand Up @@ -42,8 +42,14 @@ contract SessionKeyValidator is IValidationHook, IModuleValidator, IModule {
}

function handleValidation(bytes32 signedHash, bytes memory signature) external view returns (bool) {
// this only validates that the session key is linked to the account, not the transaction against the session spec
return isValidSignature(signedHash, signature) == EIP1271_SUCCESS_RETURN_VALUE;
// This only succeeds if the validationHook has previously succeeded for this hash.
uint256 slot = uint256(signedHash);
uint256 hookResult;
assembly {
hookResult := tload(slot)
}
require(hookResult == 1, "Can't call this function without calling validationHook");
return true;
}

function addValidationKey(bytes memory sessionData) external returns (bool) {
Expand Down Expand Up @@ -114,9 +120,9 @@ contract SessionKeyValidator is IValidationHook, IModuleValidator, IModule {
}

/*
* If there are any spend limits configured
* Check if the validator is registered for the smart account
* @param smartAccount The smart account to check
* @return true if spend limits are configured initialized, false otherwise
* @return true if validator is registered for the account, false otherwise
*/
function isInitialized(address smartAccount) external view returns (bool) {
return _isInitialized(smartAccount);
Expand All @@ -127,14 +133,6 @@ contract SessionKeyValidator is IValidationHook, IModuleValidator, IModule {
// && IValidatorManager(smartAccount).isModuleValidator(address(this));
}

/*
* Currently doing 1271 validation, but might update the interface to match the zksync account validation
*/
function isValidSignature(bytes32 hash, bytes memory signature) public view returns (bytes4 magic) {
magic = EIP1271_SUCCESS_RETURN_VALUE;
// TODO: Does this method have to work standalone? If not, validationHook is sufficient for validation.
}

function validationHook(bytes32 signedHash, Transaction calldata transaction, bytes calldata hookData) external {
(bytes memory signature, address validator, ) = abi.decode(transaction.signature, (bytes, address, bytes[]));
if (validator != address(this)) {
Expand All @@ -149,6 +147,12 @@ contract SessionKeyValidator is IValidationHook, IModuleValidator, IModule {
require(recoveredAddress == spec.signer, "Invalid signer");
bytes32 sessionHash = keccak256(abi.encode(spec));
sessions[sessionHash].validate(transaction, spec, periodIds);

// Set the validation result to 1 for this hash, so that isValidSignature succeeds
uint256 slot = uint256(signedHash);
assembly {
tstore(slot, 1)
}
}

/**
Expand Down

0 comments on commit bdf7d6f

Please sign in to comment.