File size: 1,565 Bytes
0a40ab8
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
from src.extensions import db
import datetime

class Legislation(db.Model):
    __tablename__ = 'legislation'
    id = db.Column(db.Integer, primary_key=True)
    title = db.Column(db.String, nullable=False)
    full_text = db.Column(db.Text)
    jurisdiction = db.Column(db.String) # e.g., 'Federal', 'State - CA'
    type = db.Column(db.String) # e.g., 'Statute', 'Regulation', 'Policy'
    status = db.Column(db.String, default='Active') # e.g., 'Active', 'Repealed', 'Amended'
    effective_date = db.Column(db.Date)
    enactment_date = db.Column(db.Date)
    source_url = db.Column(db.String)
    last_updated = db.Column(db.DateTime, default=datetime.datetime.utcnow, onupdate=datetime.datetime.utcnow)
    created_at = db.Column(db.DateTime, default=datetime.datetime.utcnow)

    # Relationships
    drafts = db.relationship('Draft', backref='related_legislation', lazy=True)
    amendments = db.relationship('Amendment', backref='legislation', lazy=True)
    monitored_events = db.relationship('MonitoredEvent', backref='related_legislation', lazy=True)
    recommendations = db.relationship('Recommendation', backref='related_legislation', lazy=True)
    source_cross_references = db.relationship('CrossReference', foreign_keys='CrossReference.source_legislation_id', backref='source_legislation', lazy=True)
    target_cross_references = db.relationship('CrossReference', foreign_keys='CrossReference.target_legislation_id', backref='target_legislation', lazy=True)

    def __repr__(self):
        return f'<Legislation {self.id}: {self.title[:50]}>'