2021-10-06 16:51:46 +02:00
|
|
|
// SPDX-License-Identifier: MIT
|
2021-10-26 12:10:30 +02:00
|
|
|
// https://tornado.cash
|
|
|
|
/*
|
|
|
|
* d888888P dP a88888b. dP
|
|
|
|
* 88 88 d8' `88 88
|
|
|
|
* 88 .d8888b. 88d888b. 88d888b. .d8888b. .d888b88 .d8888b. 88 .d8888b. .d8888b. 88d888b.
|
|
|
|
* 88 88' `88 88' `88 88' `88 88' `88 88' `88 88' `88 88 88' `88 Y8ooooo. 88' `88
|
|
|
|
* 88 88. .88 88 88 88 88. .88 88. .88 88. .88 dP Y8. .88 88. .88 88 88 88
|
|
|
|
* dP `88888P' dP dP dP `88888P8 `88888P8 `88888P' 88 Y88888P' `88888P8 `88888P' dP dP
|
|
|
|
* ooooooooooooooooooooooooooooooooooooooooooooooooooooooooooooooooooooooooooooooooooooooooooooooooooooooo
|
|
|
|
*/
|
|
|
|
|
2021-10-06 16:51:46 +02:00
|
|
|
pragma solidity ^0.7.0;
|
|
|
|
pragma abicoder v2;
|
|
|
|
|
|
|
|
import "omnibridge/contracts/helpers/WETHOmnibridgeRouter.sol";
|
2022-01-22 01:21:34 +01:00
|
|
|
import "@openzeppelin/contracts/math/SafeMath.sol";
|
|
|
|
import { BytesHelper } from "../libraries/Bytes.sol";
|
2021-10-06 16:51:46 +02:00
|
|
|
|
2021-10-26 11:48:37 +02:00
|
|
|
/// @dev Extension for original WETHOmnibridgeRouter that stores TornadoPool account registrations.
|
2022-01-22 01:21:34 +01:00
|
|
|
contract L1Unwrapper is WETHOmnibridgeRouter {
|
|
|
|
using SafeMath for uint256;
|
|
|
|
|
2021-10-06 16:51:46 +02:00
|
|
|
event PublicKey(address indexed owner, bytes key);
|
|
|
|
|
|
|
|
struct Account {
|
|
|
|
address owner;
|
|
|
|
bytes publicKey;
|
|
|
|
}
|
|
|
|
|
|
|
|
constructor(
|
|
|
|
IOmnibridge _bridge,
|
|
|
|
IWETH _weth,
|
|
|
|
address _owner
|
|
|
|
) WETHOmnibridgeRouter(_bridge, _weth, _owner) {}
|
|
|
|
|
2021-10-26 11:48:37 +02:00
|
|
|
/** @dev Registers provided public key and its owner in pool
|
|
|
|
* @param _account pair of address and key
|
|
|
|
*/
|
2021-10-06 16:51:46 +02:00
|
|
|
function register(Account memory _account) public {
|
|
|
|
require(_account.owner == msg.sender, "only owner can be registered");
|
|
|
|
_register(_account);
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* @dev Wraps native assets and relays wrapped ERC20 tokens to the other chain.
|
|
|
|
* It also calls receiver on other side with the _data provided.
|
|
|
|
* @param _receiver bridged assets receiver on the other side of the bridge.
|
|
|
|
* @param _data data for the call of receiver on other side.
|
|
|
|
* @param _account tornadoPool account data
|
|
|
|
*/
|
|
|
|
function wrapAndRelayTokens(
|
|
|
|
address _receiver,
|
|
|
|
bytes memory _data,
|
|
|
|
Account memory _account
|
|
|
|
) public payable {
|
|
|
|
WETH.deposit{ value: msg.value }();
|
|
|
|
bridge.relayTokensAndCall(address(WETH), _receiver, msg.value, _data);
|
|
|
|
|
|
|
|
if (_account.owner == msg.sender) {
|
|
|
|
_register(_account);
|
|
|
|
}
|
|
|
|
}
|
2021-10-26 11:48:37 +02:00
|
|
|
|
|
|
|
function _register(Account memory _account) internal {
|
|
|
|
emit PublicKey(_account.owner, _account.publicKey);
|
|
|
|
}
|
2022-01-22 01:21:34 +01:00
|
|
|
|
|
|
|
/**
|
2022-01-22 01:23:33 +01:00
|
|
|
* @dev Bridged callback function used for unwrapping received tokens.
|
|
|
|
* Can only be called by the associated Omnibridge contract.
|
|
|
|
* @param _token bridged token contract address, should be WETH.
|
|
|
|
* @param _value amount of bridged/received tokens.
|
|
|
|
* @param _data extra data passed alongside with relayTokensAndCall on the other side of the bridge.
|
|
|
|
* Should contain coins receiver address and L1 executer fee amount.
|
|
|
|
*/
|
2022-01-22 01:21:34 +01:00
|
|
|
function onTokenBridged(
|
|
|
|
address _token,
|
|
|
|
uint256 _value,
|
|
|
|
bytes memory _data
|
2022-01-22 01:23:33 +01:00
|
|
|
) external override {
|
2022-01-22 01:21:34 +01:00
|
|
|
require(_token == address(WETH));
|
|
|
|
require(msg.sender == address(bridge));
|
|
|
|
require(_data.length == 52);
|
2022-01-22 01:23:33 +01:00
|
|
|
|
2022-01-22 01:21:34 +01:00
|
|
|
WETH.withdraw(_value);
|
|
|
|
|
|
|
|
uint256 l1Fee = BytesHelper.sliceToUint(_data, 20);
|
|
|
|
|
|
|
|
AddressHelper.safeSendValue(payable(BytesHelper.bytesToAddress(_data)), _value.sub(l1Fee));
|
|
|
|
AddressHelper.safeSendValue(payable(tx.origin), l1Fee);
|
|
|
|
}
|
2021-10-06 16:51:46 +02:00
|
|
|
}
|