Reports and stuff
This commit is contained in:
parent
1ca5de8aed
commit
102c4ae31c
2 changed files with 140 additions and 3 deletions
|
|
@ -14,6 +14,14 @@ def check_health():
|
||||||
controllers.check_health()
|
controllers.check_health()
|
||||||
|
|
||||||
|
|
||||||
|
@app.command()
|
||||||
|
def generate_sku_report(
|
||||||
|
start_date: Annotated[datetime.datetime, typer.Option(prompt=True)],
|
||||||
|
end_date: Annotated[datetime.datetime, typer.Option(prompt=True)],
|
||||||
|
sku: Annotated[str, typer.Option(prompt=True)]
|
||||||
|
):
|
||||||
|
controllers.generate_sku_report(start_date, end_date, sku)
|
||||||
|
|
||||||
@app.command()
|
@app.command()
|
||||||
def generate_um_report(
|
def generate_um_report(
|
||||||
start_date: Annotated[datetime.datetime, typer.Option(prompt=True)],
|
start_date: Annotated[datetime.datetime, typer.Option(prompt=True)],
|
||||||
|
|
|
||||||
|
|
@ -98,7 +98,8 @@ def generate_um_report(
|
||||||
"units_sold": order.units_of_sku(relevant_sku),
|
"units_sold": order.units_of_sku(relevant_sku),
|
||||||
"eur_income": order.sales_of_sku(relevant_sku),
|
"eur_income": order.sales_of_sku(relevant_sku),
|
||||||
"sats_income": order.sats_received_for_sku(relevant_sku),
|
"sats_income": order.sats_received_for_sku(relevant_sku),
|
||||||
"sats_owed_to_um": order.sats_received_for_sku(relevant_sku) * um_first_agreement_percentage,
|
"sats_owed_to_um": order.sats_received_for_sku(relevant_sku)
|
||||||
|
* um_first_agreement_percentage,
|
||||||
}
|
}
|
||||||
)
|
)
|
||||||
logger.info("Report generated.")
|
logger.info("Report generated.")
|
||||||
|
|
@ -106,7 +107,135 @@ def generate_um_report(
|
||||||
|
|
||||||
keys = report[0].keys()
|
keys = report[0].keys()
|
||||||
|
|
||||||
with open('report.csv', 'w', newline='') as output_file:
|
with open("report.csv", "w", newline="") as output_file:
|
||||||
|
dict_writer = csv.DictWriter(output_file, keys)
|
||||||
|
dict_writer.writeheader()
|
||||||
|
dict_writer.writerows(report)
|
||||||
|
|
||||||
|
|
||||||
|
def generate_um_report(
|
||||||
|
start_date: datetime.datetime, end_date: datetime.datetime
|
||||||
|
) -> None:
|
||||||
|
logger.info(f"Fetching orders between {start_date} and {end_date}.")
|
||||||
|
|
||||||
|
orders_in_date_range = WC_API.get(
|
||||||
|
endpoint="orders",
|
||||||
|
params={
|
||||||
|
"after": start_date.isoformat(),
|
||||||
|
"before": end_date.isoformat(),
|
||||||
|
"per_page": 100,
|
||||||
|
"status": "processing,completed",
|
||||||
|
},
|
||||||
|
).json()
|
||||||
|
orders_in_date_range = Orders(
|
||||||
|
[
|
||||||
|
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.")
|
||||||
|
|
||||||
|
relevant_sku = "TEE-05-BBO-BLACK"
|
||||||
|
logger.info(f"Filtering by SKU: {relevant_sku}")
|
||||||
|
relevant_orders = orders_in_date_range.filter_orders_by_sku(sku=relevant_sku)
|
||||||
|
logger.info(f"Kept {len(relevant_orders)} orders.")
|
||||||
|
|
||||||
|
logger.info("Checking if all orders have the sats_received entry filled in.")
|
||||||
|
orders_without_sats_received = relevant_orders.filter_orders_without_sats_received()
|
||||||
|
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 = relevant_orders.filter_unsettled_orders()
|
||||||
|
logger.info(f"Kept {len(unsettled_orders)} unsettled orders.")
|
||||||
|
# Fetch orders:
|
||||||
|
# - Between specific dates
|
||||||
|
# - That contain the hardcoded products
|
||||||
|
# - That have been paid, hence status is either processing or completed
|
||||||
|
# - That have not been settled yet (is_settled_with_um = 0)
|
||||||
|
logger.info("Order filtering finished.")
|
||||||
|
|
||||||
|
logger.info(f"Relevant orders: {[order['id'] for order in unsettled_orders]}.")
|
||||||
|
|
||||||
|
report = []
|
||||||
|
for order in unsettled_orders:
|
||||||
|
report.append(
|
||||||
|
{
|
||||||
|
"order_id": order["id"],
|
||||||
|
"sku": relevant_sku,
|
||||||
|
"units_sold": order.units_of_sku(relevant_sku),
|
||||||
|
"eur_income": order.sales_of_sku(relevant_sku),
|
||||||
|
"sats_income": order.sats_received_for_sku(relevant_sku),
|
||||||
|
"sats_owed_to_um": order.sats_received_for_sku(relevant_sku)
|
||||||
|
* um_first_agreement_percentage,
|
||||||
|
}
|
||||||
|
)
|
||||||
|
logger.info("Report generated.")
|
||||||
|
logger.info(report)
|
||||||
|
|
||||||
|
keys = report[0].keys()
|
||||||
|
|
||||||
|
with open("report.csv", "w", newline="") as output_file:
|
||||||
|
dict_writer = csv.DictWriter(output_file, keys)
|
||||||
|
dict_writer.writeheader()
|
||||||
|
dict_writer.writerows(report)
|
||||||
|
|
||||||
|
|
||||||
|
def generate_sku_report(start_date, end_date, sku):
|
||||||
|
logger.info(f"Fetching orders between {start_date} and {end_date}.")
|
||||||
|
|
||||||
|
orders_in_date_range = WC_API.get(
|
||||||
|
endpoint="orders",
|
||||||
|
params={
|
||||||
|
"after": start_date.isoformat(),
|
||||||
|
"before": end_date.isoformat(),
|
||||||
|
"per_page": 100,
|
||||||
|
"status": "processing,completed",
|
||||||
|
},
|
||||||
|
).json()
|
||||||
|
orders_in_date_range = Orders(
|
||||||
|
[
|
||||||
|
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.")
|
||||||
|
|
||||||
|
logger.info(f"Filtering by SKU: {sku}")
|
||||||
|
relevant_orders = orders_in_date_range.filter_orders_by_sku(sku=sku)
|
||||||
|
logger.info(f"Kept {len(relevant_orders)} orders.")
|
||||||
|
|
||||||
|
logger.info("Removing settled orders.")
|
||||||
|
unsettled_orders = relevant_orders.filter_unsettled_orders()
|
||||||
|
logger.info(f"Kept {len(unsettled_orders)} unsettled orders.")
|
||||||
|
logger.info("Order filtering finished.")
|
||||||
|
|
||||||
|
logger.info(f"Relevant orders: {[order['id'] for order in unsettled_orders]}.")
|
||||||
|
|
||||||
|
report = []
|
||||||
|
for order in unsettled_orders:
|
||||||
|
report.append(
|
||||||
|
{
|
||||||
|
"order_id": order["id"],
|
||||||
|
"sku": sku,
|
||||||
|
"units_sold": order.units_of_sku(sku),
|
||||||
|
"eur_income": order.sales_of_sku(sku),
|
||||||
|
}
|
||||||
|
)
|
||||||
|
logger.info("Report generated.")
|
||||||
|
logger.info(report)
|
||||||
|
|
||||||
|
keys = report[0].keys()
|
||||||
|
|
||||||
|
with open("report.csv", "w", newline="") as output_file:
|
||||||
dict_writer = csv.DictWriter(output_file, keys)
|
dict_writer = csv.DictWriter(output_file, keys)
|
||||||
dict_writer.writeheader()
|
dict_writer.writeheader()
|
||||||
dict_writer.writerows(report)
|
dict_writer.writerows(report)
|
||||||
|
|
|
||||||
Loading…
Add table
Add a link
Reference in a new issue