forked from jamesp/sasa-membership
stuff changed:
- ui has been made 'kinda better' (after making it worse for a while lol - ESP rfid readers are now supported [ill upload the code for them in another repo later] - admin system has been secured a bit better and seems to be working well
This commit is contained in:
@@ -1,6 +1,7 @@
|
||||
from typing import List, Optional, Dict, Any
|
||||
from datetime import datetime
|
||||
from datetime import datetime, timezone
|
||||
from sqlalchemy.orm import Session
|
||||
from ..core.datetime import to_utc_naive, utc_now
|
||||
from ..models.models import EmailBounce, BounceType
|
||||
from ..core.database import get_db
|
||||
|
||||
@@ -38,7 +39,9 @@ class BounceService:
|
||||
db = next(get_db())
|
||||
|
||||
if bounce_date is None:
|
||||
bounce_date = datetime.utcnow()
|
||||
bounce_date = utc_now()
|
||||
else:
|
||||
bounce_date = to_utc_naive(bounce_date)
|
||||
|
||||
# Check if bounce already exists for this email and type
|
||||
existing_bounce = db.query(EmailBounce).filter(
|
||||
@@ -54,7 +57,7 @@ class BounceService:
|
||||
if smtp2go_message_id:
|
||||
existing_bounce.smtp2go_message_id = smtp2go_message_id
|
||||
existing_bounce.bounce_date = bounce_date
|
||||
existing_bounce.updated_at = datetime.utcnow()
|
||||
existing_bounce.updated_at = utc_now()
|
||||
db.commit()
|
||||
db.refresh(existing_bounce)
|
||||
return existing_bounce
|
||||
@@ -130,7 +133,7 @@ class BounceService:
|
||||
bounce = db.query(EmailBounce).filter(EmailBounce.id == bounce_id).first()
|
||||
if bounce:
|
||||
bounce.is_active = False
|
||||
bounce.updated_at = datetime.utcnow()
|
||||
bounce.updated_at = utc_now()
|
||||
db.commit()
|
||||
return True
|
||||
return False
|
||||
@@ -189,9 +192,10 @@ class BounceService:
|
||||
try:
|
||||
# SMTP2GO timestamps are typically Unix timestamps
|
||||
if isinstance(timestamp, (int, float)):
|
||||
bounce_date = datetime.fromtimestamp(timestamp)
|
||||
bounce_date = datetime.fromtimestamp(timestamp, tz=timezone.utc)
|
||||
elif isinstance(timestamp, str):
|
||||
bounce_date = datetime.fromisoformat(timestamp.replace('Z', '+00:00'))
|
||||
bounce_date = to_utc_naive(bounce_date)
|
||||
except (ValueError, TypeError):
|
||||
pass
|
||||
|
||||
@@ -252,18 +256,18 @@ class BounceService:
|
||||
db = next(get_db())
|
||||
|
||||
from datetime import timedelta
|
||||
cutoff_date = datetime.utcnow() - timedelta(days=days_old)
|
||||
cutoff_date = utc_now() - timedelta(days=days_old)
|
||||
|
||||
# Only deactivate soft bounces, keep hard bounces and complaints active
|
||||
result = db.query(EmailBounce).filter(
|
||||
EmailBounce.bounce_type == BounceType.SOFT,
|
||||
EmailBounce.is_active == True,
|
||||
EmailBounce.bounce_date < cutoff_date
|
||||
).update({'is_active': False, 'updated_at': datetime.utcnow()})
|
||||
).update({'is_active': False, 'updated_at': utc_now()})
|
||||
|
||||
db.commit()
|
||||
return result
|
||||
|
||||
|
||||
# Create a singleton instance
|
||||
bounce_service = BounceService()
|
||||
bounce_service = BounceService()
|
||||
|
||||
@@ -2,6 +2,7 @@ import httpx
|
||||
from typing import List, Optional, Dict, Any
|
||||
from datetime import datetime
|
||||
from ..core.database import get_db
|
||||
from ..core.datetime import utc_now
|
||||
from ..models.models import EmailTemplate
|
||||
from sqlalchemy.orm import Session
|
||||
from ..core.config import settings
|
||||
@@ -147,7 +148,7 @@ class EmailService:
|
||||
"payment_amount": f"£{payment_amount:.2f}",
|
||||
"payment_method": payment_method,
|
||||
"renewal_date": renewal_date,
|
||||
"payment_date": datetime.now().strftime("%d %B %Y"),
|
||||
"payment_date": utc_now().strftime("%d %B %Y"),
|
||||
"app_name": settings.APP_NAME
|
||||
}
|
||||
return await self.send_templated_email("membership_activation", to_email, variables, db)
|
||||
|
||||
Reference in New Issue
Block a user