._.
This commit is contained in:
parent
dc8e914a5f
commit
00beba1b43
@ -10,7 +10,7 @@ class DeliveryOrderEntity(BaseModel):
|
|||||||
deadline: datetime
|
deadline: datetime
|
||||||
price: float
|
price: float
|
||||||
estimated_route_time_in_minutes: Optional[int] = None
|
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_name: Optional[str] = None
|
||||||
truck_id: Optional[int] = None
|
truck_id: Optional[int] = None
|
||||||
total_order_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
|
return None
|
||||||
|
|
||||||
def update_delivery_order_route(self, delivery_order_id: int, estimated_route_time_in_minutes: Optional[int],
|
def update_delivery_order_route(
|
||||||
route: Optional[List[dict]]) -> Optional[DeliveryOrderEntity]:
|
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)
|
delivery_order_model = self.repository.get_by_id(delivery_order_id)
|
||||||
|
|
||||||
if delivery_order_model:
|
if delivery_order_model:
|
||||||
if estimated_route_time_in_minutes is not None:
|
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:
|
if route is not None:
|
||||||
delivery_order_model.route = route
|
delivery_order_model.route = route
|
||||||
|
|
||||||
|
|||||||
@ -3,6 +3,7 @@ from typing import List
|
|||||||
from fastapi import APIRouter, HTTPException, Depends
|
from fastapi import APIRouter, HTTPException, Depends
|
||||||
from sqlalchemy.orm import Session
|
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.core.usecases.auth_service import verify_token
|
||||||
from app.infrastructure.database.dependencies import get_db
|
from app.infrastructure.database.dependencies import get_db
|
||||||
from app.core.entities.delivery_order import DeliveryOrderEntity
|
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)
|
@router.put("/delivery-orders/{delivery_order_id}/route", response_model=DeliveryOrderEntity)
|
||||||
def update_delivery_order_route(
|
def update_delivery_order_route(
|
||||||
delivery_order_id: int,
|
delivery_order_id: int,
|
||||||
estimated_route_time_in_minutes: int,
|
request: UpdateRouteRequest,
|
||||||
route: List[dict],
|
|
||||||
db: Session = Depends(get_db),
|
db: Session = Depends(get_db),
|
||||||
current_user: User = Depends(verify_token)
|
current_user: User = Depends(verify_token)
|
||||||
):
|
):
|
||||||
service = DeliveryOrdersService(db)
|
service = DeliveryOrdersService(db)
|
||||||
updated_delivery_order = service.update_delivery_order_route(delivery_order_id, estimated_route_time_in_minutes,
|
updated_delivery_order = service.update_delivery_order_route(
|
||||||
route)
|
delivery_order_id,
|
||||||
|
request.estimated_route_time_in_minutes,
|
||||||
|
request.route
|
||||||
|
)
|
||||||
|
|
||||||
if updated_delivery_order is None:
|
if updated_delivery_order is None:
|
||||||
raise HTTPException(status_code=404, detail="Delivery order not found")
|
raise HTTPException(status_code=404, detail="Delivery order not found")
|
||||||
return updated_delivery_order
|
return updated_delivery_order
|
||||||
|
|||||||
Loading…
x
Reference in New Issue
Block a user