2021-11-05 16:57:04 -04:00

51 lines
1.6 KiB
Python

import json
from typing import List
from sqlalchemy import delete
from mev_inspect.models.traces import ClassifiedTraceModel
from mev_inspect.schemas.traces import ClassifiedTrace
async def delete_classified_traces_for_block(
inspect_db_session,
block_number: int,
) -> None:
statement = delete(ClassifiedTraceModel).where(
ClassifiedTraceModel.block_number == block_number
)
await inspect_db_session.execute(statement)
await inspect_db_session.commit()
async def write_classified_traces(
inspect_db_session,
classified_traces: List[ClassifiedTrace],
) -> None:
models = []
for trace in classified_traces:
inputs_json = (json.loads(trace.json(include={"inputs"}))["inputs"],)
models.append(
ClassifiedTraceModel(
transaction_hash=trace.transaction_hash,
block_number=trace.block_number,
classification=trace.classification.value,
trace_type=trace.type.value,
trace_address=trace.trace_address,
protocol=str(trace.protocol),
abi_name=trace.abi_name,
function_name=trace.function_name,
function_signature=trace.function_signature,
inputs=inputs_json,
from_address=trace.from_address,
to_address=trace.to_address,
gas=trace.gas,
value=trace.value,
gas_used=trace.gas_used,
error=trace.error,
)
)
inspect_db_session.add_all(models)
await inspect_db_session.commit()