mirror of
https://github.com/pacnpal/thrillwiki_django_no_react.git
synced 2026-02-05 11:25:19 -05:00
feat: Implement centralized error capture and handling with new middleware, services, and API endpoints, and add new admin and statistics API views.
This commit is contained in:
@@ -12,6 +12,7 @@ from django.core.files.uploadedfile import UploadedFile
|
||||
from django.db import transaction
|
||||
|
||||
from apps.core.services.media_service import MediaService
|
||||
from apps.core.utils import capture_and_log
|
||||
|
||||
from ..models import Ride, RidePhoto
|
||||
|
||||
@@ -190,7 +191,7 @@ class RideMediaService:
|
||||
logger.info(f"Photo {photo.pk} approved by user {approved_by.username}")
|
||||
return True
|
||||
except Exception as e:
|
||||
logger.error(f"Failed to approve photo {photo.pk}: {str(e)}")
|
||||
capture_and_log(e, f'Approve ride photo {photo.pk}', source='service')
|
||||
return False
|
||||
|
||||
@staticmethod
|
||||
@@ -217,7 +218,7 @@ class RideMediaService:
|
||||
logger.info(f"Photo {photo_id} deleted from ride {ride_slug} by user {deleted_by.username}")
|
||||
return True
|
||||
except Exception as e:
|
||||
logger.error(f"Failed to delete photo {photo.pk}: {str(e)}")
|
||||
capture_and_log(e, f'Delete ride photo {photo.pk}', source='service')
|
||||
return False
|
||||
|
||||
@staticmethod
|
||||
|
||||
@@ -21,6 +21,7 @@ from apps.rides.models import (
|
||||
RideRanking,
|
||||
RideReview,
|
||||
)
|
||||
from apps.core.utils import capture_and_log
|
||||
|
||||
logger = logging.getLogger(__name__)
|
||||
|
||||
@@ -96,7 +97,7 @@ class RideRankingService:
|
||||
}
|
||||
|
||||
except Exception as e:
|
||||
self.logger.error(f"Error updating rankings: {e}", exc_info=True)
|
||||
capture_and_log(e, 'Update ride rankings', source='service')
|
||||
raise
|
||||
|
||||
def _get_eligible_rides(self, category: str | None = None) -> list[Ride]:
|
||||
|
||||
@@ -6,6 +6,7 @@ Following Django styleguide pattern for business logic encapsulation.
|
||||
from django.contrib.auth.models import AbstractBaseUser
|
||||
from django.db import transaction
|
||||
|
||||
from apps.core.utils import capture_and_log
|
||||
from apps.rides.models import Ride
|
||||
|
||||
|
||||
@@ -191,14 +192,8 @@ class RideStatusService:
|
||||
ride.apply_post_closing_status()
|
||||
transitioned_rides.append(ride)
|
||||
except Exception as e:
|
||||
# Log error but continue processing other rides
|
||||
import logging
|
||||
|
||||
logger = logging.getLogger(__name__)
|
||||
logger.error(
|
||||
f"Failed to process closing ride {ride.id}: {e}",
|
||||
exc_info=True,
|
||||
)
|
||||
# Capture error to dashboard but continue processing other rides
|
||||
capture_and_log(e, f'Process closing ride {ride.id}', source='service')
|
||||
continue
|
||||
|
||||
return transitioned_rides
|
||||
|
||||
Reference in New Issue
Block a user