dsa-connectors/contracts/mainnet/connectors/erc20_staking/helpers.sol

49 lines
1.5 KiB
Solidity
Raw Normal View History

2022-03-22 15:24:40 +00:00
//SPDX-License-Identifier: MIT
2021-06-10 11:56:39 +00:00
pragma solidity ^0.7.0;
pragma experimental ABIEncoderV2;
import { DSMath } from "../../common/math.sol";
import { Basic } from "../../common/basic.sol";
2021-06-10 18:12:39 +00:00
import { TokenInterface } from "../../common/interfaces.sol";
2021-06-15 15:51:19 +00:00
import { IStakingRewards, StakingERC20Mapping } from "./interface.sol";
2021-06-10 11:56:39 +00:00
abstract contract Helpers is DSMath, Basic {
/**
* @dev Convert String to bytes32.
*/
function stringToBytes32(string memory str) internal pure returns (bytes32 result) {
require(bytes(str).length != 0, "string-empty");
// solium-disable-next-line security/no-inline-assembly
assembly {
result := mload(add(str, 32))
}
}
/**
* @dev Get staking data
*/
function getStakingData(string memory stakingName)
internal
view
returns (
IStakingRewards stakingContract,
TokenInterface stakingToken,
TokenInterface rewardToken,
bytes32 stakingType
)
{
stakingType = stringToBytes32(stakingName);
2021-06-15 15:51:19 +00:00
StakingERC20Mapping.StakingData memory stakingData = StakingERC20Mapping(getMappingAddr()).stakingMapping(stakingType);
2021-06-10 11:56:39 +00:00
require(stakingData.stakingPool != address(0) && stakingData.stakingToken != address(0), "Wrong Staking Name");
stakingContract = IStakingRewards(stakingData.stakingPool);
stakingToken = TokenInterface(stakingData.stakingToken);
rewardToken = TokenInterface(stakingData.rewardToken);
}
function getMappingAddr() internal virtual view returns (address) {
2021-06-15 15:51:19 +00:00
return 0xbE658233bA9990d86155b3902fd05a7AfC7eBdB5; // InstaMapping Address
2021-06-10 11:56:39 +00:00
}
}