Add transactions for a watched contract
This commit is contained in:
parent
874051cf89
commit
0b9930dd9c
@ -2,4 +2,5 @@ package core
|
|||||||
|
|
||||||
type WatchedContract struct {
|
type WatchedContract struct {
|
||||||
Hash string
|
Hash string
|
||||||
|
Transactions []Transaction
|
||||||
}
|
}
|
||||||
|
@ -20,7 +20,18 @@ func (repository *InMemory) IsWatchedContract(contractHash string) bool {
|
|||||||
}
|
}
|
||||||
|
|
||||||
func (repository *InMemory) FindWatchedContract(contractHash string) *core.WatchedContract {
|
func (repository *InMemory) FindWatchedContract(contractHash string) *core.WatchedContract {
|
||||||
return repository.watchedContracts[contractHash]
|
var transactions []core.Transaction
|
||||||
|
if _, ok := repository.watchedContracts[contractHash]; !ok {
|
||||||
|
return nil
|
||||||
|
}
|
||||||
|
for _, block := range repository.blocks {
|
||||||
|
for _, transaction := range block.Transactions {
|
||||||
|
if transaction.To == contractHash {
|
||||||
|
transactions = append(transactions, transaction)
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
return &core.WatchedContract{Hash: contractHash, Transactions: transactions}
|
||||||
}
|
}
|
||||||
|
|
||||||
func (repository *InMemory) MissingBlockNumbers(startingBlockNumber int64, endingBlockNumber int64) []int64 {
|
func (repository *InMemory) MissingBlockNumbers(startingBlockNumber int64, endingBlockNumber int64) []int64 {
|
||||||
|
@ -43,7 +43,7 @@ func (repository Postgres) CreateWatchedContract(contract core.WatchedContract)
|
|||||||
func (repository Postgres) IsWatchedContract(contractHash string) bool {
|
func (repository Postgres) IsWatchedContract(contractHash string) bool {
|
||||||
var exists bool
|
var exists bool
|
||||||
err := repository.Db.QueryRow(
|
err := repository.Db.QueryRow(
|
||||||
`SELECT exists(select 1 from watched_contracts where contract_hash=$1) FROM watched_contracts`, contractHash).Scan(&exists)
|
`SELECT exists(SELECT 1 FROM watched_contracts WHERE contract_hash=$1) FROM watched_contracts`, contractHash).Scan(&exists)
|
||||||
if err != nil && err != sql.ErrNoRows {
|
if err != nil && err != sql.ErrNoRows {
|
||||||
log.Fatalf("error checking if row exists %v", err)
|
log.Fatalf("error checking if row exists %v", err)
|
||||||
}
|
}
|
||||||
@ -53,13 +53,8 @@ func (repository Postgres) IsWatchedContract(contractHash string) bool {
|
|||||||
func (repository Postgres) FindWatchedContract(contractHash string) *core.WatchedContract {
|
func (repository Postgres) FindWatchedContract(contractHash string) *core.WatchedContract {
|
||||||
var savedContracts []core.WatchedContract
|
var savedContracts []core.WatchedContract
|
||||||
contractRows, _ := repository.Db.Query(
|
contractRows, _ := repository.Db.Query(
|
||||||
`select contract_hash from watched_contracts where contract_hash=$1`, contractHash)
|
`SELECT contract_hash FROM watched_contracts WHERE contract_hash=$1`, contractHash)
|
||||||
for contractRows.Next() {
|
savedContracts = repository.loadContract(contractRows)
|
||||||
var savedContractHash string
|
|
||||||
contractRows.Scan(&savedContractHash)
|
|
||||||
savedContract := core.WatchedContract{Hash: savedContractHash}
|
|
||||||
savedContracts = append(savedContracts, savedContract)
|
|
||||||
}
|
|
||||||
if len(savedContracts) > 0 {
|
if len(savedContracts) > 0 {
|
||||||
return &savedContracts[0]
|
return &savedContracts[0]
|
||||||
} else {
|
} else {
|
||||||
@ -104,7 +99,7 @@ func (repository Postgres) FindBlockByNumber(blockNumber int64) *core.Block {
|
|||||||
|
|
||||||
func (repository Postgres) BlockCount() int {
|
func (repository Postgres) BlockCount() int {
|
||||||
var count int
|
var count int
|
||||||
repository.Db.Get(&count, "SELECT COUNT(*) FROM blocks")
|
repository.Db.Get(&count, `SELECT COUNT(*) FROM blocks`)
|
||||||
return count
|
return count
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -158,7 +153,8 @@ func (repository Postgres) loadBlock(blockRows *sql.Rows) core.Block {
|
|||||||
var gasUsed float64
|
var gasUsed float64
|
||||||
var uncleHash string
|
var uncleHash string
|
||||||
blockRows.Scan(&blockId, &blockNumber, &gasLimit, &gasUsed, &blockTime, &difficulty, &blockHash, &blockNonce, &blockParentHash, &blockSize, &uncleHash)
|
blockRows.Scan(&blockId, &blockNumber, &gasLimit, &gasUsed, &blockTime, &difficulty, &blockHash, &blockNonce, &blockParentHash, &blockSize, &uncleHash)
|
||||||
transactions := repository.loadTransactions(blockId)
|
transactionRows, _ := repository.Db.Query(`SELECT tx_hash, tx_nonce, tx_to, tx_from, tx_gaslimit, tx_gasprice, tx_value FROM transactions WHERE block_id = $1`, blockId)
|
||||||
|
transactions := repository.loadTransactions(transactionRows)
|
||||||
return core.Block{
|
return core.Block{
|
||||||
Difficulty: difficulty,
|
Difficulty: difficulty,
|
||||||
GasLimit: int64(gasLimit),
|
GasLimit: int64(gasLimit),
|
||||||
@ -173,8 +169,8 @@ func (repository Postgres) loadBlock(blockRows *sql.Rows) core.Block {
|
|||||||
UncleHash: uncleHash,
|
UncleHash: uncleHash,
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
func (repository Postgres) loadTransactions(blockId int64) []core.Transaction {
|
|
||||||
transactionRows, _ := repository.Db.Query(`SELECT tx_hash, tx_nonce, tx_to, tx_from, tx_gaslimit, tx_gasprice, tx_value FROM transactions`)
|
func (repository Postgres) loadTransactions(transactionRows *sql.Rows) []core.Transaction {
|
||||||
var transactions []core.Transaction
|
var transactions []core.Transaction
|
||||||
for transactionRows.Next() {
|
for transactionRows.Next() {
|
||||||
var hash string
|
var hash string
|
||||||
@ -198,3 +194,16 @@ func (repository Postgres) loadTransactions(blockId int64) []core.Transaction {
|
|||||||
}
|
}
|
||||||
return transactions
|
return transactions
|
||||||
}
|
}
|
||||||
|
|
||||||
|
func (repository Postgres) loadContract(contractRows *sql.Rows) []core.WatchedContract {
|
||||||
|
var savedContracts []core.WatchedContract
|
||||||
|
for contractRows.Next() {
|
||||||
|
var savedContractHash string
|
||||||
|
contractRows.Scan(&savedContractHash)
|
||||||
|
transactionRows, _ := repository.Db.Query(`SELECT tx_hash, tx_nonce, tx_to, tx_from, tx_gaslimit, tx_gasprice, tx_value FROM transactions WHERE tx_to = $1`, savedContractHash)
|
||||||
|
transactions := repository.loadTransactions(transactionRows)
|
||||||
|
savedContract := core.WatchedContract{Hash: savedContractHash, Transactions: transactions}
|
||||||
|
savedContracts = append(savedContracts, savedContract)
|
||||||
|
}
|
||||||
|
return savedContracts
|
||||||
|
}
|
||||||
|
@ -227,6 +227,35 @@ var _ = Describe("Repositories", func() {
|
|||||||
watchedContract := repository.FindWatchedContract("x123")
|
watchedContract := repository.FindWatchedContract("x123")
|
||||||
Expect(watchedContract).To(BeNil())
|
Expect(watchedContract).To(BeNil())
|
||||||
})
|
})
|
||||||
|
|
||||||
|
It("returns empty array when no transactions 'To' a watched contract", func() {
|
||||||
|
repository.CreateWatchedContract(core.WatchedContract{Hash: "x123"})
|
||||||
|
watchedContract := repository.FindWatchedContract("x123")
|
||||||
|
Expect(watchedContract).ToNot(BeNil())
|
||||||
|
Expect(watchedContract.Transactions).To(BeEmpty())
|
||||||
|
|
||||||
|
})
|
||||||
|
|
||||||
|
It("returns transactions 'To' a watched contract", func() {
|
||||||
|
block := core.Block{
|
||||||
|
Number: 123,
|
||||||
|
Transactions: []core.Transaction{
|
||||||
|
{Hash: "TRANSACTION1", To: "x123"},
|
||||||
|
{Hash: "TRANSACTION2", To: "x345"},
|
||||||
|
{Hash: "TRANSACTION3", To: "x123"},
|
||||||
|
},
|
||||||
|
}
|
||||||
|
repository.CreateBlock(block)
|
||||||
|
|
||||||
|
repository.CreateWatchedContract(core.WatchedContract{Hash: "x123"})
|
||||||
|
watchedContract := repository.FindWatchedContract("x123")
|
||||||
|
Expect(watchedContract).ToNot(BeNil())
|
||||||
|
Expect(watchedContract.Transactions).To(
|
||||||
|
Equal([]core.Transaction{
|
||||||
|
{Hash: "TRANSACTION1", To: "x123"},
|
||||||
|
{Hash: "TRANSACTION3", To: "x123"},
|
||||||
|
}))
|
||||||
|
})
|
||||||
})
|
})
|
||||||
}
|
}
|
||||||
|
|
||||||
|
Loading…
Reference in New Issue
Block a user