2021-02-18 06:04:30 +01:00
# standard imports
import logging
import datetime
2021-05-01 12:34:50 +02:00
# external imports
2021-02-18 06:04:30 +01:00
from cic_cache . db . models . base import SessionBase
2021-05-01 12:34:50 +02:00
from sqlalchemy import text
2021-02-18 06:04:30 +01:00
logg = logging . getLogger ( )
def list_transactions_mined (
session ,
offset ,
limit ,
) :
""" Executes db query to return all confirmed transactions according to the specified offset and limit.
: param offset : Offset in data set to return transactions from
: type offset : int
: param limit : Max number of transactions to retrieve
: type limit : int
: result : Result set
: rtype : SQLAlchemy . ResultProxy
"""
s = " SELECT block_number, tx_index FROM tx ORDER BY block_number DESC, tx_index DESC LIMIT {} OFFSET {} " . format ( limit , offset )
r = session . execute ( s )
return r
def list_transactions_account_mined (
session ,
address ,
offset ,
limit ,
) :
""" Same as list_transactions_mined(...), but only retrieves transaction where the specified account address is sender or recipient.
: param address : Address to retrieve transactions for .
: type address : str , 0 x - hex
: param offset : Offset in data set to return transactions from
: type offset : int
: param limit : Max number of transactions to retrieve
: type limit : int
: result : Result set
: rtype : SQLAlchemy . ResultProxy
"""
s = " SELECT block_number, tx_index FROM tx WHERE sender = ' {} ' OR recipient = ' {} ' ORDER BY block_number DESC, tx_index DESC LIMIT {} OFFSET {} " . format ( address , address , limit , offset )
r = session . execute ( s )
return r
def add_transaction (
2021-05-01 12:34:50 +02:00
session ,
tx_hash ,
2021-02-18 06:04:30 +01:00
block_number ,
tx_index ,
sender ,
receiver ,
source_token ,
destination_token ,
from_value ,
to_value ,
success ,
timestamp ,
) :
date_block = datetime . datetime . fromtimestamp ( timestamp )
s = " INSERT INTO tx (tx_hash, block_number, tx_index, sender, recipient, source_token, destination_token, from_value, to_value, success, date_block) VALUES ( ' {} ' , {} , {} , ' {} ' , ' {} ' , ' {} ' , ' {} ' , {} , {} , {} , ' {} ' ) " . format (
tx_hash ,
block_number ,
tx_index ,
sender ,
receiver ,
source_token ,
destination_token ,
from_value ,
to_value ,
success ,
date_block ,
)
session . execute ( s )
2021-05-01 12:34:50 +02:00
def tag_transaction (
session ,
tx_hash ,
name ,
domain = None ,
) :
s = text ( " SELECT id from tx where tx_hash = :a " )
r = session . execute ( s , { ' a ' : tx_hash } ) . fetchall ( )
tx_id = r [ 0 ] . values ( ) [ 0 ]
if tx_id == None :
raise ValueError ( ' unknown tx hash {} ' . format ( tx_hash ) )
#s = text("SELECT id from tag where value = :a and domain = :b")
if domain == None :
s = text ( " SELECT id from tag where value = :a " )
else :
s = text ( " SELECT id from tag where value = :a and domain = :b " )
r = session . execute ( s , { ' a ' : name , ' b ' : domain } ) . fetchall ( )
tag_id = r [ 0 ] . values ( ) [ 0 ]
logg . debug ( ' type {} {} ' . format ( type ( tag_id ) , type ( tx_id ) ) )
if tag_id == None :
raise ValueError ( ' unknown tag name {} domain {} ' . format ( name , domain ) )
s = text ( " INSERT INTO tag_tx_link (tag_id, tx_id) VALUES (:a, :b) " )
r = session . execute ( s , { ' a ' : int ( tag_id ) , ' b ' : int ( tx_id ) } )
def add_tag (
session ,
name ,
domain = None ,
) :
s = None
if domain == None :
s = text ( " INSERT INTO tag (value) VALUES (:b) " )
else :
s = text ( " INSERT INTO tag (domain, value) VALUES (:a, :b) " )
session . execute ( s , { ' a ' : domain , ' b ' : name } )