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")