from sqlalchemy import Column, String, Integer, Boolean, DateTime, ForeignKey, Text, JSON, ARRAY, relationship from sqlalchemy.dialects.postgresql import UUID from src.config.database import Base from sqlalchemy.sql import func import uuid class PayerRule(Base): __tablename__ = 'payer_rules' id = Column(UUID(as_uuid=True), primary_key=True, default=uuid.uuid4, nullable=False) payer_id = Column(UUID(as_uuid=True), nullable=False) rule_name = Column(String(255), nullable=False) rule_type = Column(String(255), nullable=False) rule_description = Column(Text, nullable=False) rule_logic = Column(JSON, nullable=False) affected_cpt_codes = Column(JSON, nullable=True) affected_icd10_codes = Column(JSON, nullable=True) effective_date = Column(DateTime, nullable=False) termination_date = Column(DateTime, nullable=True) created_by_user_id = Column(UUID(as_uuid=True), nullable=True) updated_by_user_id = Column(UUID(as_uuid=True), nullable=True) denial_count = Column(Integer, nullable=False) last_denial_date = Column(DateTime, nullable=True) payer_id = Column(UUID(as_uuid=True), ForeignKey('payers.id'), nullable=False) payer = relationship('Payer', back_populates='') created_by_user_id = Column(UUID(as_uuid=True), ForeignKey('users.id'), nullable=True) user = relationship('User', back_populates='') updated_by_user_id = Column(UUID(as_uuid=True), ForeignKey('users.id'), nullable=True) user = relationship('User', back_populates='') created_at = Column(DateTime(timezone=True), server_default=func.now(), nullable=False) updated_at = Column(DateTime(timezone=True), server_default=func.now(), onupdate=func.now(), nullable=False) def __repr__(self): return f''