Skip to content
This repository has been archived by the owner on Jan 29, 2019. It is now read-only.

Commit

Permalink
#173 update isAlive implementation for etherdelta
Browse files Browse the repository at this point in the history
  • Loading branch information
Valentin Stavetski committed May 3, 2018
1 parent af02233 commit 6271b7b
Showing 1 changed file with 6 additions and 7 deletions.
Original file line number Diff line number Diff line change
Expand Up @@ -38,6 +38,7 @@ import java.util.concurrent.TimeUnit

private const val ETHERDELTA_CONTRACT_ADDRESS = "0x8d12a197cb00d4747a1fe03395095ce2a5cc6819"
private const val ETH_SYMBOL = "ETH"
private const val ETHERDELTA_CONNECTION_TIMEOUT_MS: Long = 5 * 60 * 1000

@Component
class EtherdeltaTradeConnector : Connector {
Expand All @@ -46,6 +47,7 @@ class EtherdeltaTradeConnector : Connector {
private val exchangeName = "ETHERDELTA"
private val tradesTopicName by lazy { TRADES_TOPIC_PREFIX + exchangeName }
private lateinit var etherdeltaContract: EtherdeltaContract
private var lastTradeTimestamp: Long? = null

@Autowired
private lateinit var web3j: Web3j
Expand Down Expand Up @@ -84,15 +86,11 @@ class EtherdeltaTradeConnector : Connector {
}

override fun isAlive(): Boolean {
val test: String?
val currentTimestamp = Date().time

try {
test = etherdeltaContract.accountLevelsAddr().send()
} catch (e: Throwable) {
return false
}
return lastTradeTimestamp != null &&
currentTimestamp - lastTradeTimestamp!! < ETHERDELTA_CONNECTION_TIMEOUT_MS

return test != null
}

/**
Expand Down Expand Up @@ -170,6 +168,7 @@ class EtherdeltaTradeConnector : Connector {
}

val timestamp = Numeric.toBigInt(block.block.timestampRaw).multiply(BigInteger.valueOf(1000)).toLong()
lastTradeTimestamp = timestamp

if (tokenGive.symbol == ETH_SYMBOL) {
val price = amountGive.divide(amountGet, tokenGive.decimals, RoundingMode.HALF_EVEN)
Expand Down

0 comments on commit 6271b7b

Please sign in to comment.