Open janniksam opened 1 year ago
The current version of the VM doesn't know how to extract data from transfer-execute calls to provide the call value in the callback. It can only do that if the called contract returns the tokens via another async call.
Using this code causes the tests to pass:
#[endpoint(foo)]
#[payable("EGLD")]
fn foo(&self) {
let payment = self.payment().get();
self.send().transfer_esdt_via_async_call(
self.blockchain().get_caller(),
payment.token_identifier,
payment.token_nonce,
payment.amount,
);
}
This limitation will be lifted in the next version of the VM, we are working on it as we speak.
Should be fixed with backtransfers, right @andrei-marinica?
When calling another SC from my SC, when accessing the call_value() inside the callback, the call_value does contain the tokens of the initial call instead of the sent tokens coming from the asynchronously called SC.
I created a minimal reproduction project you can find here (branch: bug/callvalue) https://github.com/janniksam/mvx_sellnftbug/tree/bug/callvalue
Here are the basic steps, pretty straightforward:
reproduce
on the first smart contractreproduce
calls the second smart contractsfoo
endpoint and forward the EGLD to it.foo_callback
gets called. When trying to usecall_value().single_esdt()
inside that callback it will fail.Is there ANY temporary workaround for this? I'm currently stuck and cannot proceed, because I definitely need to know the amount I get back from the second SC (which in my real scenario is created by third party).