from LIReC.db.access import LIReC_DB
from LIReC.db.models import *

_db = LIReC_DB()

# >>> Remember to first configure config.py with your username+password! <<<

def next() -> PcfCanonicalConstant or None:
    '''
    Returns the highest priority oldest untweeted PCF.
    '''
    try:
        return _db.session.query(PcfCanonicalConstant).join(Constant)
                  .order_by(Constant.priority.desc(), Constant.time_added)
                  .filter(Constant.tweeted == 0).first()
    except Exception as e:
        _db.session.rollback()
        raise e

def next_relation(const_id: str) -> Relation or None:
    '''
    Returns the highest priority oldest untweeted relation in which the given constant participates.
    '''
    try:
        return _db.session.query(Relation)
                          .order_by(Constant.priority.desc(), Constant.time_added)
                          .filter(Relation.constants.any(Constant.const_id == const_id)).first()
    except Exception as e:
        _db.session.rollback()
        raise e

def set_tweeted(obj: Constant or Relation, auto_commit : bool = True) -> None:
    '''
    Updates the given object to indicate it has been tweeted. This will cause it to be ignored in future calls to next() or next_relation(const_id).
    '''
    obj.tweeted = 1
    if auto_commit:
        commit()

def commit() -> None:
    '''
    Commits all changes to LIReC. Useful if you plan on calling set_tweeted with auto_commit = False.
    
    Since committing can take a while, calling set_tweeted() many times with auto_commit = True will probably take longer than calling with auto_commit = False, and then calling commit(). In any case, commit() must be called at some point to update LIReC.
    '''
    try:
        _db.session.commit()
    except Exception as e:
        _db.session.rollback()
        raise e
