pragma solidity ^0.7.0; pragma experimental ABIEncoderV2; import { DSMath } from "../../common/math.sol"; import { Basic } from "../../common/basic.sol"; import { ComptrollerInterface, COMPInterface, CompoundMappingInterface } from "./interface.sol"; abstract contract Helpers is DSMath, Basic { /** * @dev Compound Comptroller */ ComptrollerInterface internal constant troller = ComptrollerInterface(0x3d9819210A31b4961b30EF54bE2aeD79B9c9Cd3B); /** * @dev COMP Token */ COMPInterface internal constant compToken = COMPInterface(0xc00e94Cb662C3520282E6f5717214004A7f26888); /** * @dev Compound Mapping */ CompoundMappingInterface internal constant compMapping = CompoundMappingInterface(0xA8F9D4aA7319C54C04404765117ddBf9448E2082); function getMergedCTokens( string[] calldata supplyIds, string[] calldata borrowIds ) internal view returns (address[] memory ctokens, bool isBorrow, bool isSupply) { uint _supplyLen = supplyIds.length; uint _borrowLen = borrowIds.length; uint _totalLen = add(_supplyLen, _borrowLen); ctokens = new address[](_totalLen); if(_supplyLen > 0) { isSupply = true; for (uint i = 0; i < _supplyLen; i++) { (address token, address cToken) = compMapping.getMapping(supplyIds[i]); require(token != address(0) && cToken != address(0), "invalid token/ctoken address"); ctokens[i] = cToken; } } if(_borrowLen > 0) { isBorrow = true; for (uint i = 0; i < _borrowLen; i++) { (address token, address cToken) = compMapping.getMapping(borrowIds[i]); require(token != address(0) && cToken != address(0), "invalid token/ctoken address"); ctokens[_supplyLen + i] = cToken; } } } }