._.
This commit is contained in:
parent
dc8e914a5f
commit
00beba1b43
@ -10,7 +10,7 @@ class DeliveryOrderEntity(BaseModel):
|
||||
deadline: datetime
|
||||
price: float
|
||||
estimated_route_time_in_minutes: Optional[int] = None
|
||||
route: Optional[List[dict]] = None
|
||||
route: Optional[List[List[float]]] = None
|
||||
truck_name: Optional[str] = None
|
||||
truck_id: Optional[int] = None
|
||||
total_order_id: Optional[int] = None
|
||||
|
||||
12
app/core/entities/update_route_request.py
Normal file
12
app/core/entities/update_route_request.py
Normal file
@ -0,0 +1,12 @@
|
||||
from typing import List
|
||||
|
||||
from pydantic import BaseModel
|
||||
|
||||
|
||||
class UpdateRouteRequest(BaseModel):
|
||||
estimated_route_time_in_minutes: float
|
||||
route: List[List[float]]
|
||||
|
||||
class Config:
|
||||
from_attributes = True
|
||||
|
||||
@ -116,13 +116,18 @@ class DeliveryOrdersService:
|
||||
)
|
||||
return None
|
||||
|
||||
def update_delivery_order_route(self, delivery_order_id: int, estimated_route_time_in_minutes: Optional[int],
|
||||
route: Optional[List[dict]]) -> Optional[DeliveryOrderEntity]:
|
||||
def update_delivery_order_route(
|
||||
self,
|
||||
delivery_order_id: int,
|
||||
estimated_route_time_in_minutes: float,
|
||||
route: List[List[float]]
|
||||
) -> Optional[DeliveryOrderEntity]:
|
||||
|
||||
delivery_order_model = self.repository.get_by_id(delivery_order_id)
|
||||
|
||||
if delivery_order_model:
|
||||
if estimated_route_time_in_minutes is not None:
|
||||
delivery_order_model.estimated_route_time_in_minutes = estimated_route_time_in_minutes
|
||||
delivery_order_model.estimated_route_time_in_minutes = round(estimated_route_time_in_minutes)
|
||||
if route is not None:
|
||||
delivery_order_model.route = route
|
||||
|
||||
|
||||
@ -3,6 +3,7 @@ from typing import List
|
||||
from fastapi import APIRouter, HTTPException, Depends
|
||||
from sqlalchemy.orm import Session
|
||||
|
||||
from app.core.entities.update_route_request import UpdateRouteRequest
|
||||
from app.core.usecases.auth_service import verify_token
|
||||
from app.infrastructure.database.dependencies import get_db
|
||||
from app.core.entities.delivery_order import DeliveryOrderEntity
|
||||
@ -69,14 +70,17 @@ def delete_delivery_order(delivery_order_id: int, db: Session = Depends(get_db),
|
||||
@router.put("/delivery-orders/{delivery_order_id}/route", response_model=DeliveryOrderEntity)
|
||||
def update_delivery_order_route(
|
||||
delivery_order_id: int,
|
||||
estimated_route_time_in_minutes: int,
|
||||
route: List[dict],
|
||||
request: UpdateRouteRequest,
|
||||
db: Session = Depends(get_db),
|
||||
current_user: User = Depends(verify_token)
|
||||
):
|
||||
service = DeliveryOrdersService(db)
|
||||
updated_delivery_order = service.update_delivery_order_route(delivery_order_id, estimated_route_time_in_minutes,
|
||||
route)
|
||||
updated_delivery_order = service.update_delivery_order_route(
|
||||
delivery_order_id,
|
||||
request.estimated_route_time_in_minutes,
|
||||
request.route
|
||||
)
|
||||
|
||||
if updated_delivery_order is None:
|
||||
raise HTTPException(status_code=404, detail="Delivery order not found")
|
||||
return updated_delivery_order
|
||||
|
||||
Loading…
x
Reference in New Issue
Block a user