Acceso a las variables de estado de Ethereum usando web3js (Java Script)

Estoy tratando de ejecutar el siguiente código para obtener las variables de estado utilizando el método getIdBytes del contrato inteligente y asignarlo a una variable de matriz de secuencias de comandos Java, pero parece que no funciona.

Todo lo que puedo hacer es imprimir los valores devueltos usando console.log(return).

¿Puede alguien señalarme en la dirección correcta, por favor?

var coreValues = ['Apple', 'Banana'];
console.log("Before call :"  + coreValues[1]);

if (get_flag)
{
contract3.methods.getIdBytes(index1, abstract_contract_address).call().then(function(result){
   for (var i = 0; i < 5; i++) {
  coreValues[i] =  result[i];
  console.log("Inside Function Call" + coreValues[i]);
  }
});

console.log("After Call :" + coreValues[0]);

Así es como se ve la salida.

Before call :Banana
After Call :Apple
Inside Function call : Steve
Inside Function call : Rogers
Inside Function call : Male
Inside Function call : 0987654
Inside Function call : 12/05/1980

¿Debería usar eventos ?

Respuestas (1)

La ejecución de la llamada web3js es asíncrona, por lo que "After Call" se ejecuta antes que el código dentro del ciclo.

Prueba esto:

var coreValues = ['Apple', 'Banana'];
console.log("Before call :"  + coreValues[1]);

if (get_flag) {
  contract3.methods.getIdBytes(index1, abstract_contract_address).call().then(function(result){
    for (var i = 0; i < 5; i++) {
      coreValues[i] =  result[i];
      console.log("Inside Function Call" + coreValues[i]);
    }
    console.log("End of Call :" + coreValues[0]);
    // continue with your logic here...
  });
}
console.log("Too early: " + coreValues[0]);

Otra opción es usar "esperar":

var coreValues = ['Apple', 'Banana'];
console.log("Before call :"  + coreValues[1]);

if (get_flag) {
  await contract3.methods.getIdBytes(index1, abstract_contract_address).call().then(function(result){
    for (var i = 0; i < 5; i++) {
      coreValues[i] =  result[i];
      console.log("Inside Function Call" + coreValues[i]);
    }
  });
}
console.log("Not too early: " + coreValues[0]);
// continue with your logic here...