// 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; }