mirror of
https://github.com/pacnpal/thrillwiki_django_no_react.git
synced 2025-12-20 08:51:09 -05:00
- Added migration 0011 to populate unique slugs for existing RideModel records based on manufacturer and model names. - Implemented logic to ensure slug uniqueness during population. - Added reverse migration to clear slugs if needed. feat(rides): enforce unique slugs for RideModel - Created migration 0012 to alter the slug field in RideModel to be unique. - Updated the slug field to include help text and a maximum length of 255 characters. docs: integrate Cloudflare Images into rides and parks models - Updated RidePhoto and ParkPhoto models to use CloudflareImagesField for image storage. - Enhanced API serializers for rides and parks to support Cloudflare Images, including new fields for image URLs and variants. - Provided comprehensive OpenAPI schema metadata for new fields. - Documented database migrations for the integration. - Detailed configuration settings for Cloudflare Images. - Updated API response formats to include Cloudflare Images URLs and variants. - Added examples for uploading photos via API and outlined testing procedures.
60 lines
2.0 KiB
Python
60 lines
2.0 KiB
Python
"""Comprehensive URL routes for Rides domain (API v1).
|
|
|
|
This file exposes a maximal set of "full-fat" endpoints implemented in
|
|
`apps.api.v1.rides.views`. Endpoints are intentionally expansive (aliases,
|
|
bulk operations, action endpoints, analytics, import/export) so the backend
|
|
surface matches the frontend's expectations. Implementations for specific
|
|
actions (bulk, publish, export, import, recommendations) should be added
|
|
to the views module when business logic is available.
|
|
"""
|
|
|
|
from django.urls import path, include
|
|
from rest_framework.routers import DefaultRouter
|
|
|
|
from .views import (
|
|
RideListCreateAPIView,
|
|
RideDetailAPIView,
|
|
FilterOptionsAPIView,
|
|
CompanySearchAPIView,
|
|
RideModelSearchAPIView,
|
|
RideSearchSuggestionsAPIView,
|
|
RideImageSettingsAPIView,
|
|
)
|
|
from .photo_views import RidePhotoViewSet
|
|
|
|
# Create router for nested photo endpoints
|
|
router = DefaultRouter()
|
|
router.register(r"", RidePhotoViewSet, basename="ridephoto")
|
|
|
|
app_name = "api_v1_rides"
|
|
|
|
urlpatterns = [
|
|
# Core list/create endpoints
|
|
path("", RideListCreateAPIView.as_view(), name="ride-list-create"),
|
|
# Filter options
|
|
path("filter-options/", FilterOptionsAPIView.as_view(), name="ride-filter-options"),
|
|
# Autocomplete / suggestion endpoints
|
|
path(
|
|
"search/companies/",
|
|
CompanySearchAPIView.as_view(),
|
|
name="ride-search-companies",
|
|
),
|
|
path(
|
|
"search/ride-models/",
|
|
RideModelSearchAPIView.as_view(),
|
|
name="ride-search-ride-models",
|
|
),
|
|
path(
|
|
"search-suggestions/",
|
|
RideSearchSuggestionsAPIView.as_view(),
|
|
name="ride-search-suggestions",
|
|
),
|
|
# Detail and action endpoints
|
|
path("<int:pk>/", RideDetailAPIView.as_view(), name="ride-detail"),
|
|
# Ride image settings endpoint
|
|
path("<int:pk>/image-settings/", RideImageSettingsAPIView.as_view(),
|
|
name="ride-image-settings"),
|
|
# Ride photo endpoints - domain-specific photo management
|
|
path("<int:ride_pk>/photos/", include(router.urls)),
|
|
]
|