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";
|
|
|
|
|
2021-10-26 11:48:37 +02:00
|
|
|
/// @dev Extension for original WETHOmnibridgeRouter that stores TornadoPool account registrations.
|
2021-10-06 16:51:46 +02:00
|
|
|
contract L1Helper is WETHOmnibridgeRouter {
|
|
|
|
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);
|
|
|
|
}
|
2021-10-06 16:51:46 +02:00
|
|
|
}
|