import json from typing import List from mev_inspect.models.punks import ( PunkSnipeModel, PunkBidModel, ) from mev_inspect.schemas.punk_snipe import PunkSnipe from mev_inspect.schemas.punk_bid import PunkBid def delete_punk_bids_for_block( db_session, block_number: int, ) -> None: ( db_session.query(PunkBidModel) .filter(PunkBidModel.block_number == block_number) .delete() ) db_session.commit() def write_punk_bids( db_session, punk_bids: List[PunkBid], ) -> None: models = [PunkBidModel(**json.loads(punk_bid.json())) for punk_bid in punk_bids] db_session.bulk_save_objects(models) db_session.commit() def delete_punk_snipes_for_block( db_session, block_number: int, ) -> None: ( db_session.query(PunkSnipeModel) .filter(PunkSnipeModel.block_number == block_number) .delete() ) db_session.commit() def write_punk_snipes( db_session, punk_snipes: List[PunkSnipe], ) -> None: models = [ PunkSnipeModel(**json.loads(punk_snipe.json())) for punk_snipe in punk_snipes ] db_session.bulk_save_objects(models) db_session.commit()