dsa-connectors/contracts/mainnet/connectors/euler/euler-rewards/main.sol

47 lines
1.4 KiB
Solidity
Raw Normal View History

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);
require(proof.length > 0, "invalid-assets");
eulerDistribute.claim(user, token, _amt, proof, address(0));
setUint(setId, _amt);
_eventName = "LogClaimed(address,address,uint256,bytes32[],uint256,uint256)";
_eventParam = abi.encode(user, token, _amt, proof, getId, setId);
}
}
contract ConnectV2EulereIncentives is EulerIncentives {
string public constant name = "Euler-Incentives-v1";
}