db.py 605 B

1234567891011121314151617181920212223242526272829
  1. from contextlib import contextmanager
  2. from sqlalchemy import create_engine
  3. from sqlalchemy.orm import sessionmaker
  4. from config import DB_FILE
  5. from command_system import ModelBase
  6. engine = create_engine("sqlite:///" + DB_FILE)
  7. Session = sessionmaker(bind=engine)
  8. def init_db():
  9. ModelBase.metadata.create_all(engine)
  10. @contextmanager
  11. def session_scope():
  12. """Provide a transactional scope around a series of operations."""
  13. session = Session()
  14. try:
  15. yield session
  16. session.commit()
  17. except:
  18. session.rollback()
  19. raise
  20. finally:
  21. session.close()