Files
hossein-por-shop/backend/order/tasks.py
T
2025-11-18 14:27:22 +03:30

122 lines
4.3 KiB
Python

import logging
from azbankgateways import (
bankfactories,
models as bank_models,
default_settings as settings,
)
from .models import OrderModel
from account.models import PushSubscription
import ghasedak_sms
from product.models import ProductImageModel
from celery import shared_task
@shared_task
def udpate_bank_status():
factory = bankfactories.BankFactory()
bank_models.Bank.objects.update_expire_records()
for item in bank_models.Bank.objects.filter_return_from_bank():
bank = factory.create(
bank_type=item.bank_type, identifier=item.bank_choose_identifier
)
bank.verify(item.tracking_code)
bank_record = bank_models.Bank.objects.get(tracking_code=item.tracking_code)
if bank_record.is_success:
bank_record.order.cart.clear_cart()
bank_record.order.is_paid = True
bank_record.order.save()
logging.debug("This record is verify now.", extra={"pk": bank_record.pk})
else:
order = bank_record.order
order.rollback_stock()
return 'update bank record is done'
@shared_task
def send_change_status_notif(instance_pk, new_status):
instance = OrderModel.objects.get(pk=instance_pk)
user_subs = PushSubscription.objects.filter(user=instance.user)
for user_sub in user_subs:
try:
user_sub.send_notif(f'سفارش شما به {new_status} تغییر کرد', f'سفارش شما به {new_status} تغییر کرد', ProductImageModel.objects.all().first().image.url)
except:
print('log later send notif error')
@shared_task
def send_change_status_sms(instance_pk, new_status):
instance = OrderModel.objects.get(pk=instance_pk)
sms_api = ghasedak_sms.Ghasedak(api_key="1227eaaddcba72bcb0169b37032cf16ae9ac6ed8b3b7c2768b74e2ee351d1b52gyRe3AGomZRPTNEd")
response = sms_api.send_single_sms(
ghasedak_sms.SendSingleSmsInput(
message=f'سفارش شما به {new_status} تغییر کرد',
receptor=instance.user.phone,
line_number='30005006004095',
client_reference_id=str(instance.user.pk)
)
)
if response['statusCode'] == 200:
return 'done log later'
else:
return f'error: {response}'
@shared_task
def generate_daily_shop_reports():
"""Generate daily shop reports for the previous day.
This task aggregates ShopOrderModel entries from yesterday
and creates/updates ShopDailyReport records for each shop.
Scheduled to run daily at midnight.
"""
from django.utils import timezone
from datetime import timedelta
from django.db.models import Sum
from .models import ShopOrderModel, ShopDailyReport
target_date = (timezone.now() - timedelta(days=1)).date()
logging.info(f'Generating shop reports for {target_date}')
shop_orders = ShopOrderModel.objects.filter(created_at__date=target_date)
if not shop_orders.exists():
logging.warning(f'No shop orders found for {target_date}')
return f'No shop orders for {target_date}'
shops = shop_orders.values('shop').distinct()
reports_created = 0
reports_updated = 0
for s in shops:
shop_id = s['shop']
aggr = shop_orders.filter(shop_id=shop_id).aggregate(
total_sales=Sum('subtotal'),
total_commission=Sum('commission_amount'),
total_payable=Sum('payable_amount')
)
total_sales = aggr['total_sales'] or 0
total_commission = aggr['total_commission'] or 0
total_payable = aggr['total_payable'] or 0
report, created = ShopDailyReport.objects.update_or_create(
shop_id=shop_id,
date=target_date,
defaults={
'total_sales': total_sales,
'total_commission': total_commission,
'total_payable': total_payable,
}
)
if created:
reports_created += 1
else:
reports_updated += 1
logging.info(f"Shop {shop_id}: sales={total_sales}, commission={total_commission}, payable={total_payable}")
result = f'Generated reports for {target_date}: {reports_created} created, {reports_updated} updated'
logging.info(result)
return result