2022-07-31 05:02:53 +00:00
|
|
|
//SPDX-License-Identifier: MIT
|
|
|
|
pragma solidity ^0.7.0;
|
|
|
|
import "./helpers.sol";
|
|
|
|
import "./events.sol";
|
|
|
|
|
|
|
|
/**
|
|
|
|
* @title Euler Rewards.
|
|
|
|
* @dev Claim Euler rewards.
|
|
|
|
*/
|
|
|
|
|
|
|
|
contract EulerIncentives is Helpers, Events {
|
|
|
|
|
|
|
|
/**
|
|
|
|
* @dev Claim Pending Rewards.
|
|
|
|
* @notice Claim Pending Rewards from Euler incentives contract.
|
|
|
|
* @param user Address that should receive tokens.
|
|
|
|
* @param token Address of token being claimed (ie EUL)
|
|
|
|
* @param amt The amount of reward to claim.
|
|
|
|
* @param proof Merkle proof that validates this claim.
|
|
|
|
* @param getId ID to retrieve amt.
|
|
|
|
* @param setId ID stores the amount of rewards claimed.
|
|
|
|
*/
|
|
|
|
function claim(
|
|
|
|
address user,
|
|
|
|
address token,
|
|
|
|
uint256 amt,
|
|
|
|
bytes32[] memory proof,
|
|
|
|
uint256 getId,
|
|
|
|
uint256 setId
|
|
|
|
) external payable returns (string memory _eventName, bytes memory _eventParam) {
|
|
|
|
uint _amt = getUint(getId, amt);
|
|
|
|
|
2022-07-31 18:27:12 +00:00
|
|
|
require(proof.length > 0, "proofs-empty");
|
2022-07-31 05:02:53 +00:00
|
|
|
|
|
|
|
eulerDistribute.claim(user, token, _amt, proof, address(0));
|
|
|
|
|
|
|
|
setUint(setId, _amt);
|
|
|
|
|
2022-07-31 18:30:15 +00:00
|
|
|
_eventName = "LogClaimed(address,address,uint256,uint256,uint256)";
|
|
|
|
_eventParam = abi.encode(user, token, _amt, getId, setId);
|
2022-07-31 05:02:53 +00:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
contract ConnectV2EulereIncentives is EulerIncentives {
|
|
|
|
string public constant name = "Euler-Incentives-v1";
|
|
|
|
}
|