From 6923b60e5bf4da650736d5a940a3a9101f6f7245 Mon Sep 17 00:00:00 2001 From: Michael Maurer Date: Wed, 21 Aug 2024 12:56:08 -0400 Subject: [PATCH] Convert assert in create into a warning Turn the assert statement in create into a warning, this restores the ability to import tokens through Metamask. Details: When importing tokens, Metamask sends a create call without sender information, triggering an assert failure. Signed-off-by: Michael Maurer --- src/parsec/agent/runners/evm/host.cpp | 15 ++++++++++++++- 1 file changed, 14 insertions(+), 1 deletion(-) diff --git a/src/parsec/agent/runners/evm/host.cpp b/src/parsec/agent/runners/evm/host.cpp index b1191c2ba..68b61778b 100644 --- a/src/parsec/agent/runners/evm/host.cpp +++ b/src/parsec/agent/runners/evm/host.cpp @@ -225,7 +225,15 @@ namespace cbdc::parsec::agent::runner { auto evm_host::create(const evmc_message& msg) noexcept -> evmc::Result { auto maybe_sender_acc = get_account(msg.sender, false); - assert(maybe_sender_acc.has_value()); + if(!maybe_sender_acc.has_value()) { + m_log->warn("EVM CREATE: sender account not found"); + return evmc::Result( + evmc::make_result(evmc_status_code::EVMC_REVERT, + 0, + 0, + nullptr, + 0)); + } auto& sender_acc = maybe_sender_acc.value(); auto new_addr = evmc::address(); @@ -298,6 +306,11 @@ namespace cbdc::parsec::agent::runner { } auto evm_host::call(const evmc_message& msg) noexcept -> evmc::Result { + if(msg.kind == EVMC_CREATE2) { + m_log->info("EVM CREATE2 called"); + } else if(msg.kind == EVMC_CREATE) { + m_log->info("EVM CREATE called"); + } if(msg.kind == EVMC_CREATE2 || msg.kind == EVMC_CREATE) { return create(msg); }