2025-04-09 13:24:34 +00:00

24 lines
1005 B
Python

from sqlalchemy import Column, String, Integer, DateTime, ForeignKey
from sqlalchemy.dialects.postgresql import UUID
from sqlalchemy.orm import relationship
from sqlalchemy.sql import func
from core.database import Base
import uuid
class Route(Base):
__tablename__ = "routes"
id = Column(UUID(as_uuid=True), primary_key=True, default=uuid.uuid4)
name = Column(String, nullable=False, unique=True)
description = Column(String, nullable=True)
origin = Column(String, nullable=False)
destination = Column(String, nullable=False)
distance = Column(Integer, nullable=False)
duration = Column(Integer, nullable=False)
created_at = Column(DateTime, default=func.now())
updated_at = Column(DateTime, default=func.now(), onupdate=func.now())
waypoints = Column(ARRAY(String), nullable=True)
optimized_distance = Column(Integer, nullable=True)
optimized_duration = Column(Integer, nullable=True)
shipments = relationship("Shipment", back_populates="route")