diff --git a/blockchain/src/main/java/com/tangem/blockchain/blockchains/ethereum/EthereumAddressService.kt b/blockchain/src/main/java/com/tangem/blockchain/blockchains/ethereum/EthereumAddressService.kt index b6e69da05..5d1fba4b3 100644 --- a/blockchain/src/main/java/com/tangem/blockchain/blockchains/ethereum/EthereumAddressService.kt +++ b/blockchain/src/main/java/com/tangem/blockchain/blockchains/ethereum/EthereumAddressService.kt @@ -16,4 +16,4 @@ class EthereumAddressService : AddressService() { ).toAddress().withERC55Checksum().hex override fun validate(address: String): Boolean = Address(address).hasValidERC55ChecksumOrNoChecksum() -} \ No newline at end of file +} diff --git a/blockchain/src/main/java/com/tangem/blockchain/blockchains/ethereum/EthereumTransactionHistoryProvider.kt b/blockchain/src/main/java/com/tangem/blockchain/blockchains/ethereum/EthereumTransactionHistoryProvider.kt index b4bfa6010..c949982b4 100644 --- a/blockchain/src/main/java/com/tangem/blockchain/blockchains/ethereum/EthereumTransactionHistoryProvider.kt +++ b/blockchain/src/main/java/com/tangem/blockchain/blockchains/ethereum/EthereumTransactionHistoryProvider.kt @@ -17,6 +17,8 @@ import kotlinx.coroutines.withContext import java.math.BigDecimal import java.util.concurrent.TimeUnit +private const val ETHEREUM_METHOD_ID_LENGTH = 8 + internal class EthereumTransactionHistoryProvider( private val blockchain: Blockchain, private val blockBookApi: BlockBookApi, @@ -121,9 +123,9 @@ internal class EthereumTransactionHistoryProvider( } private fun extractType(tx: GetAddressResponse.Transaction): TransactionHistoryItem.TransactionType { - val methodId = tx.ethereumSpecific?.parsedData?.methodId.guard { - return TransactionHistoryItem.TransactionType.Transfer - } + val ethereumSpecific = tx.ethereumSpecific + val methodId = ethereumSpecific?.parsedData?.methodId ?: methodIdFromRawData(ethereumSpecific?.data) + .guard { return TransactionHistoryItem.TransactionType.Transfer } // MethodId is empty for the coin transfers if (methodId.isEmpty()) return TransactionHistoryItem.TransactionType.Transfer @@ -131,6 +133,11 @@ internal class EthereumTransactionHistoryProvider( return TransactionHistoryItem.TransactionType.ContractMethod(id = methodId) } + private fun methodIdFromRawData(rawData: String?): String? { + val methodId = rawData?.removePrefix("0x")?.take(ETHEREUM_METHOD_ID_LENGTH) + return if (methodId?.length == ETHEREUM_METHOD_ID_LENGTH) methodId else null + } + private fun isOutgoing( walletAddress: String, transaction: GetAddressResponse.Transaction, diff --git a/blockchain/src/main/java/com/tangem/blockchain/common/txhistory/TransactionHistoryProviderExt.kt b/blockchain/src/main/java/com/tangem/blockchain/common/txhistory/TransactionHistoryProviderExt.kt index d9d6983eb..153decbaf 100644 --- a/blockchain/src/main/java/com/tangem/blockchain/common/txhistory/TransactionHistoryProviderExt.kt +++ b/blockchain/src/main/java/com/tangem/blockchain/common/txhistory/TransactionHistoryProviderExt.kt @@ -29,6 +29,7 @@ internal fun Blockchain.getTransactionHistoryProvider( Blockchain.Ethereum, Blockchain.EthereumTestnet, + Blockchain.EthereumClassic, // Blockchain.Arbitrum, Blockchain.Avalanche, Blockchain.BSC, diff --git a/blockchain/src/main/java/com/tangem/blockchain/network/blockbook/config/BlockBookConfig.kt b/blockchain/src/main/java/com/tangem/blockchain/network/blockbook/config/BlockBookConfig.kt index 870e6f941..749346c46 100644 --- a/blockchain/src/main/java/com/tangem/blockchain/network/blockbook/config/BlockBookConfig.kt +++ b/blockchain/src/main/java/com/tangem/blockchain/network/blockbook/config/BlockBookConfig.kt @@ -36,6 +36,7 @@ sealed class BlockBookConfig(val credentials: BlockBookCredentials?) { Blockchain.Polygon -> "https://${prefix}book.$baseHost" Blockchain.Kava -> "https://kava-tendermint.$baseHost" Blockchain.Ethereum, + Blockchain.EthereumClassic, Blockchain.Avalanche, Blockchain.EthereumPow, Blockchain.Tron,