123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869 |
- // SPDX-License-Identifier: MIT
- pragma solidity ^0.8.0;
- import "../token/ERC1155/IERC1155ReceiverUpgradeable.sol";
- import "../utils/introspection/ERC165Upgradeable.sol";
- import "../proxy/utils/Initializable.sol";
- contract ERC1155ReceiverMockUpgradeable is Initializable, ERC165Upgradeable, IERC1155ReceiverUpgradeable {
- bytes4 private _recRetval;
- bool private _recReverts;
- bytes4 private _batRetval;
- bool private _batReverts;
- event Received(address operator, address from, uint256 id, uint256 value, bytes data, uint256 gas);
- event BatchReceived(address operator, address from, uint256[] ids, uint256[] values, bytes data, uint256 gas);
- function __ERC1155ReceiverMock_init(
- bytes4 recRetval,
- bool recReverts,
- bytes4 batRetval,
- bool batReverts
- ) internal onlyInitializing {
- __ERC1155ReceiverMock_init_unchained(recRetval, recReverts, batRetval, batReverts);
- }
- function __ERC1155ReceiverMock_init_unchained(
- bytes4 recRetval,
- bool recReverts,
- bytes4 batRetval,
- bool batReverts
- ) internal onlyInitializing {
- _recRetval = recRetval;
- _recReverts = recReverts;
- _batRetval = batRetval;
- _batReverts = batReverts;
- }
- function onERC1155Received(
- address operator,
- address from,
- uint256 id,
- uint256 value,
- bytes calldata data
- ) external override returns (bytes4) {
- require(!_recReverts, "ERC1155ReceiverMock: reverting on receive");
- emit Received(operator, from, id, value, data, gasleft());
- return _recRetval;
- }
- function onERC1155BatchReceived(
- address operator,
- address from,
- uint256[] calldata ids,
- uint256[] calldata values,
- bytes calldata data
- ) external override returns (bytes4) {
- require(!_batReverts, "ERC1155ReceiverMock: reverting on batch receive");
- emit BatchReceived(operator, from, ids, values, data, gasleft());
- return _batRetval;
- }
- /**
- * @dev This empty reserved space is put in place to allow future versions to add new
- * variables without shifting down storage in the inheritance chain.
- * See https://docs.openzeppelin.com/contracts/4.x/upgradeable#storage_gaps
- */
- uint256[49] private __gap;
- }
|