feat: add tx history
This commit is contained in:
parent
540ab55120
commit
307d4341c9
|
|
@ -3,6 +3,10 @@ from asyncio import run
|
||||||
from tonsdk.boc import Cell, begin_cell
|
from tonsdk.boc import Cell, begin_cell
|
||||||
from tonsdk.utils import Address
|
from tonsdk.utils import Address
|
||||||
|
|
||||||
|
import pandas as pd
|
||||||
|
from datetime import datetime
|
||||||
|
from pytonapi import AsyncTonapi
|
||||||
|
|
||||||
from _auth import get_or_create_wallet_settings
|
from _auth import get_or_create_wallet_settings
|
||||||
from _core import unpack_wallet, serialize_command, perform_action, print_actions
|
from _core import unpack_wallet, serialize_command, perform_action, print_actions
|
||||||
|
|
||||||
|
|
@ -11,6 +15,7 @@ async def main():
|
||||||
print('\n' * 30)
|
print('\n' * 30)
|
||||||
wallet_settings = get_or_create_wallet_settings()
|
wallet_settings = get_or_create_wallet_settings()
|
||||||
wallet = unpack_wallet(wallet_settings)
|
wallet = unpack_wallet(wallet_settings)
|
||||||
|
wallet_address = wallet.address.to_string(1, 1, 1)
|
||||||
print(f"=== Successfully loaded wallet {wallet.address.to_string(1, 1, 0)}")
|
print(f"=== Successfully loaded wallet {wallet.address.to_string(1, 1, 0)}")
|
||||||
# print(wallet_settings)
|
# print(wallet_settings)
|
||||||
actions = []
|
actions = []
|
||||||
|
|
@ -24,6 +29,8 @@ async def main():
|
||||||
print("5) Export mnemonic phrase")
|
print("5) Export mnemonic phrase")
|
||||||
print("7) New decentralized note")
|
print("7) New decentralized note")
|
||||||
print("8) Read decentralized note")
|
print("8) Read decentralized note")
|
||||||
|
print("9) View transactions history")
|
||||||
|
print("10) Export transactions history")
|
||||||
print("0) View actions and exit | send transactions")
|
print("0) View actions and exit | send transactions")
|
||||||
|
|
||||||
choice = input("Select an action (1/2/3/4/0): ")
|
choice = input("Select an action (1/2/3/4/0): ")
|
||||||
|
|
@ -33,6 +40,103 @@ async def main():
|
||||||
elif choice in {"5"}:
|
elif choice in {"5"}:
|
||||||
print("=== Mnemonic phrase:")
|
print("=== Mnemonic phrase:")
|
||||||
print(wallet_settings['mnemonic'])
|
print(wallet_settings['mnemonic'])
|
||||||
|
continue
|
||||||
|
elif choice in {"9", "10"}:
|
||||||
|
print("=== Transactions history:")
|
||||||
|
tonapi = AsyncTonapi('AEA5YM3PU2YFXJIAAAAH3JWVNWRM57SFIBJGVJHCOK2GGPJ2L2MNKXBYPO7VTTY26ZRLX6I')
|
||||||
|
|
||||||
|
transactions = []
|
||||||
|
start_ts = None
|
||||||
|
while not start_ts or events.events:
|
||||||
|
try:
|
||||||
|
events = await tonapi.accounts.get_events(wallet_address, end_date=start_ts or None)
|
||||||
|
except BaseException as e:
|
||||||
|
if "rate limit" in str(e):
|
||||||
|
print("Rate limit exceeded. Please try again later.")
|
||||||
|
time.sleep(1)
|
||||||
|
continue
|
||||||
|
else:
|
||||||
|
print(f"TonAPI error: {e}")
|
||||||
|
|
||||||
|
print(f"Fetched {len(events.events)} events from {start_ts}")
|
||||||
|
for event in events.events:
|
||||||
|
if event.in_progress is True:
|
||||||
|
continue
|
||||||
|
|
||||||
|
event_dt = datetime.fromtimestamp(event.timestamp)
|
||||||
|
event_dtf = event_dt.strftime("%Y-%m-%d %H:%M:%S")
|
||||||
|
for event_action in event.actions:
|
||||||
|
transactions.append(
|
||||||
|
(event.event_id, event.lt, event_dtf, event_action.type, event_action)
|
||||||
|
)
|
||||||
|
|
||||||
|
if not start_ts or start_ts > event.timestamp:
|
||||||
|
start_ts = event.timestamp
|
||||||
|
|
||||||
|
if choice == "9":
|
||||||
|
for event_action in reversed(transactions):
|
||||||
|
e_id, e_lt, e_dtf, e_type, e_action = event_action
|
||||||
|
action_formatted = f"TXID: {e_id}, logic time: {e_lt}. {e_dtf} {e_type}:" + '\n' + " " * 6
|
||||||
|
if e_type == "TonTransfer":
|
||||||
|
e_action = e_action.TonTransfer
|
||||||
|
action_formatted += f"{Address(e_action.sender.address.to_raw()).to_string(1, 1, 1)}" \
|
||||||
|
+ f" sent {round(int(e_action.amount) / 10 ** 9, 3)} TON => {Address(e_action.recipient.address.to_raw()).to_string(1, 1, 1)}"
|
||||||
|
if e_action.comment:
|
||||||
|
action_formatted += f". Comment: {e_action.comment}"
|
||||||
|
elif e_type == "JettonTransfer":
|
||||||
|
e_action = e_action.JettonTransfer
|
||||||
|
action_formatted += f"{Address(e_action.sender.address.to_raw()).to_string(1, 1, 1)}" \
|
||||||
|
+ f" sent {round(int(e_action.amount) / 10 ** e_action.jetton.decimals, 3)} {e_action.jetton.symbol} => {Address(e_action.recipient.address.to_raw()).to_string(1, 1, 1)}"
|
||||||
|
if e_action.comment:
|
||||||
|
action_formatted += f". Comment: {e_action.comment}"
|
||||||
|
elif e_type == "NftItemTransfer":
|
||||||
|
e_action = e_action.NftItemTransfer
|
||||||
|
action_formatted += f"{Address(e_action.sender.address.to_raw()).to_string(1, 1, 1)}" \
|
||||||
|
+ f" sent NFT ({e_action.nft}) => {Address(e_action.recipient.address.to_raw()).to_string(1, 1, 1)}"
|
||||||
|
else:
|
||||||
|
e_action = getattr(e_action, e_type)
|
||||||
|
action_formatted += "unknown action: " + str(e_action)
|
||||||
|
|
||||||
|
print(action_formatted + '\n')
|
||||||
|
elif choice == "10":
|
||||||
|
dfr = []
|
||||||
|
for event_action in reversed(transactions):
|
||||||
|
e_id, e_lt, e_dtf, e_type, e_action = event_action
|
||||||
|
if e_type == "TonTransfer":
|
||||||
|
e_action = e_action.TonTransfer
|
||||||
|
dfr.append([
|
||||||
|
e_id, e_lt, e_dtf, e_type,
|
||||||
|
Address(e_action.sender.address.to_raw()).to_string(1, 1, 1),
|
||||||
|
Address(e_action.recipient.address.to_raw()).to_string(1, 1, 1),
|
||||||
|
str(round(int(e_action.amount) / 10 ** 9, 3)),
|
||||||
|
e_action.comment or ''
|
||||||
|
])
|
||||||
|
elif e_type == "JettonTransfer":
|
||||||
|
e_action = e_action.JettonTransfer
|
||||||
|
dfr.append([
|
||||||
|
e_id, e_lt, e_dtf, e_type,
|
||||||
|
Address(e_action.sender.address.to_raw()).to_string(1, 1, 1),
|
||||||
|
Address(e_action.recipient.address.to_raw()).to_string(1, 1, 1),
|
||||||
|
str(round(int(e_action.amount) / 10 ** e_action.jetton.decimals, 3)),
|
||||||
|
e_action.comment or ''
|
||||||
|
])
|
||||||
|
elif e_type == "NftItemTransfer":
|
||||||
|
e_action = e_action.NftItemTransfer
|
||||||
|
dfr.append([
|
||||||
|
e_id, e_lt, e_dtf, e_type,
|
||||||
|
Address(e_action.sender.address.to_raw()).to_string(1, 1, 1),
|
||||||
|
Address(e_action.recipient.address.to_raw()).to_string(1, 1, 1),
|
||||||
|
e_action.nft,
|
||||||
|
''
|
||||||
|
])
|
||||||
|
|
||||||
|
df = pd.DataFrame(dfr, columns=[
|
||||||
|
'TXID', 'Logic Time', 'Time', 'Type', 'Sender', 'Recipient', 'Amount', 'Comment'
|
||||||
|
])
|
||||||
|
df.to_csv('transactions_history.csv', sep=",")
|
||||||
|
print("Transactions history saved to transactions_history.csv")
|
||||||
|
|
||||||
|
continue
|
||||||
elif choice in {"1", "2", "3", "4", "7"}:
|
elif choice in {"1", "2", "3", "4", "7"}:
|
||||||
action_type = int(choice)
|
action_type = int(choice)
|
||||||
action = {"type": action_type, "args": []}
|
action = {"type": action_type, "args": []}
|
||||||
|
|
|
||||||
|
|
@ -1,3 +1,5 @@
|
||||||
httpx==0.25.0
|
httpx==0.25.0
|
||||||
tonsdk==1.0.13
|
tonsdk==1.0.13
|
||||||
pycryptodome==3.19.0
|
pycryptodome==3.19.0
|
||||||
|
pytonapi==0.2.2
|
||||||
|
pandas==2.2.2
|
||||||
|
|
|
||||||
Loading…
Reference in New Issue