Call
WEB3DEV Team
# Call
call
é uma função de baixo nível para interagir com outros contratos.
Este é o método recomendado para ser usado quando você está somente enviando Ether via chamada da função fallback
.
Contudo, não é uma forma recomendada para chamar funções existentes.
// SPDX-License-Identifier: MIT
pragma solidity ^0.8.20;
contract Receptor {
event Received(address caller, uint amount, string message);
fallback() external payable {
emit Received(msg.sender, msg.value, "Fallback foi chamado");
}
function foo(string memory _message, uint _x) public payable returns (uint) {
emit Received(msg.sender, msg.value, _message);
return _x + 1;
}
}
contract Chamador {
event Response(bool success, bytes data);
// Vamos imaginar que o contrato Chamador não tenha o código fonte para o
// contrato Receptor, mas nós sabemos o endereço de Receptor e a função para chamar.
function testCallFoo(address payable _addr) public payable {
// Você pode enviar ether e especificar uma quantidade de gás personalizada
(bool success, bytes memory data) = _addr.call{value: msg.value, gas: 5000}(
abi.encodeWithSignature("foo(string,uint256)", "call foo", 123)
);
emit Response(success, data);
}
// Chamando uma função que não existe aciona a função fallback.
function testCallDoesNotExist(address _addr) public {
(bool success, bytes memory data) = _addr.call(
abi.encodeWithSignature("doesNotExist()")
);
emit Response(success, data);
}
}