Address.sol 2.9 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768
  1. pragma solidity ^0.5.5;
  2. /**
  3. * @dev Collection of functions related to the address type
  4. */
  5. library Address {
  6. /**
  7. * @dev Returns true if `account` is a contract.
  8. *
  9. * This test is non-exhaustive, and there may be false-negatives: during the
  10. * execution of a contract's constructor, its address will be reported as
  11. * not containing a contract.
  12. *
  13. * IMPORTANT: It is unsafe to assume that an address for which this
  14. * function returns false is an externally-owned account (EOA) and not a
  15. * contract.
  16. */
  17. function isContract(address account) internal view returns (bool) {
  18. // This method relies in extcodesize, which returns 0 for contracts in
  19. // construction, since the code is only stored at the end of the
  20. // constructor execution.
  21. // According to EIP-1052, 0x0 is the value returned for not-yet created accounts
  22. // and 0xc5d2460186f7233c927e7db2dcc703c0e500b653ca82273b7bfad8045d85a470 is returned
  23. // for accounts without code, i.e. `keccak256('')`
  24. bytes32 codehash;
  25. bytes32 accountHash = 0xc5d2460186f7233c927e7db2dcc703c0e500b653ca82273b7bfad8045d85a470;
  26. // solhint-disable-next-line no-inline-assembly
  27. assembly { codehash := extcodehash(account) }
  28. return (codehash != 0x0 && codehash != accountHash);
  29. }
  30. /**
  31. * @dev Converts an `address` into `address payable`. Note that this is
  32. * simply a type cast: the actual underlying value is not changed.
  33. *
  34. * _Available since v2.4.0._
  35. */
  36. function toPayable(address account) internal pure returns (address payable) {
  37. return address(uint160(account));
  38. }
  39. /**
  40. * @dev Replacement for Solidity's `transfer`: sends `amount` wei to
  41. * `recipient`, forwarding all available gas and reverting on errors.
  42. *
  43. * https://eips.ethereum.org/EIPS/eip-1884[EIP1884] increases the gas cost
  44. * of certain opcodes, possibly making contracts go over the 2300 gas limit
  45. * imposed by `transfer`, making them unable to receive funds via
  46. * `transfer`. {sendValue} removes this limitation.
  47. *
  48. * https://diligence.consensys.net/posts/2019/09/stop-using-soliditys-transfer-now/[Learn more].
  49. *
  50. * IMPORTANT: because control is transferred to `recipient`, care must be
  51. * taken to not create reentrancy vulnerabilities. Consider using
  52. * {ReentrancyGuard} or the
  53. * https://solidity.readthedocs.io/en/v0.5.11/security-considerations.html#use-the-checks-effects-interactions-pattern[checks-effects-interactions pattern].
  54. *
  55. * _Available since v2.4.0._
  56. */
  57. function sendValue(address payable recipient, uint256 amount) internal {
  58. require(address(this).balance >= amount, "Address: insufficient balance");
  59. // solhint-disable-next-line avoid-call-value
  60. (bool success, ) = recipient.call.value(amount)("");
  61. require(success, "Address: unable to send value, recipient may have reverted");
  62. }
  63. }