mirror of
https://github.com/Instadapp/dsa-connectors.git
synced 2024-07-29 22:37:00 +00:00
47 lines
1.4 KiB
Solidity
47 lines
1.4 KiB
Solidity
|
//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";
|
||
|
}
|