mirror of https://gitlab.com/openlp/openlp.git
54 lines
2.1 KiB
Python
54 lines
2.1 KiB
Python
# -*- coding: utf-8 -*-
|
|
|
|
##########################################################################
|
|
# OpenLP - Open Source Lyrics Projection #
|
|
# ---------------------------------------------------------------------- #
|
|
# Copyright (c) 2008-2023 OpenLP Developers #
|
|
# ---------------------------------------------------------------------- #
|
|
# This program is free software: you can redistribute it and/or modify #
|
|
# it under the terms of the GNU General Public License as published by #
|
|
# the Free Software Foundation, either version 3 of the License, or #
|
|
# (at your option) any later version. #
|
|
# #
|
|
# This program is distributed in the hope that it will be useful, #
|
|
# but WITHOUT ANY WARRANTY; without even the implied warranty of #
|
|
# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the #
|
|
# GNU General Public License for more details. #
|
|
# #
|
|
# You should have received a copy of the GNU General Public License #
|
|
# along with this program. If not, see <https://www.gnu.org/licenses/>. #
|
|
##########################################################################
|
|
"""
|
|
The :mod:`db` module provides the database and schema that is the backend for the Alerts plugin.
|
|
"""
|
|
|
|
from sqlalchemy import Column
|
|
from sqlalchemy.orm import Session, declarative_base
|
|
from sqlalchemy.types import Integer, UnicodeText
|
|
|
|
from openlp.core.db.helpers import init_db
|
|
|
|
|
|
Base = declarative_base()
|
|
|
|
|
|
class AlertItem(Base):
|
|
"""
|
|
AlertItem model
|
|
"""
|
|
__tablename__ = 'alerts'
|
|
id = Column(Integer, primary_key=True)
|
|
text = Column(UnicodeText, nullable=False)
|
|
|
|
|
|
def init_schema(url: str) -> Session:
|
|
"""
|
|
Setup the alerts database connection and initialise the database schema
|
|
|
|
:param url:
|
|
The database to setup
|
|
"""
|
|
session, metadata = init_db(url, base=Base)
|
|
metadata.create_all(bind=metadata.bind, checkfirst=True)
|
|
return session
|