Check if order is already settled.

This commit is contained in:
Pablo Martin 2023-08-03 16:22:20 +02:00
parent 1dddbf5ef1
commit 964682716f
2 changed files with 24 additions and 6 deletions

View file

@ -52,9 +52,7 @@ def generate_um_report(start_date: datetime.datetime, end_date: datetime.datetim
"status": "processing,completed",
},
).json()
orders_in_date_range = [Order.from_api_response(order_raw_data) for order_raw_data in orders_in_date_range]
logger.info(f"Received {len(orders_in_date_range)} orders.")
skus_to_keep = ["TEE-05-BBO-BLACK"]
@ -67,15 +65,17 @@ def generate_um_report(start_date: datetime.datetime, end_date: datetime.datetim
logger.info("Checking if all orders have the sats_received entry filled in.")
orders_without_sats_received = find_orders_without_sats_received(relevant_orders)
if orders_without_sats_received:
logger.warning(
f"There are {len(orders_without_sats_received)} orders without a properly filled sats_received entry.")
logger.warning(f"See details below.")
logger.warning(orders_without_sats_received)
raise ValueError("Not all orders have sats_received. Can't compute sats owed without that.")
logger.info("Success, all orders have sats_received filled in.")
logger.info("Removing settled orders.")
unsettled_orders = filter_settled_orders(relevant_orders)
logger.info(f"Kept {len(unsettled_orders)} unsettled orders.")
# Fetch orders:
# - Between specific dates
# - That contain the hardcoded products
@ -114,3 +114,13 @@ def find_orders_without_sats_received(orders: List[Order]) -> List[Order]:
continue
return orders_without_sats_received
def filter_settled_orders(orders: List[Order]) -> List[Order]:
unsettled_orders = []
for order in orders:
if not order.is_settled_with_um():
unsettled_orders.append(order)
return unsettled_orders