Source code for openlp.plugins.images.lib.db

# -*- coding: utf-8 -*-
# vim: autoindent shiftwidth=4 expandtab textwidth=120 tabstop=4 softtabstop=4

###############################################################################
# OpenLP - Open Source Lyrics Projection                                      #
# --------------------------------------------------------------------------- #
# Copyright (c) 2008-2017 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; version 2 of the License.                              #
#                                                                             #
# 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, write to the Free Software Foundation, Inc., 59  #
# Temple Place, Suite 330, Boston, MA 02111-1307 USA                          #
###############################################################################
"""
The :mod:`db` module provides the database and schema that is the backend for the Images plugin.
"""

from sqlalchemy import Column, ForeignKey, Table, types
from sqlalchemy.orm import mapper

from openlp.core.lib.db import BaseModel, init_db


[docs]class ImageGroups(BaseModel): """ ImageGroups model. """ pass
[docs]class ImageFilenames(BaseModel): """ ImageFilenames model. """ pass
[docs]def init_schema(url): """ Setup the images database connection and initialise the database schema. :param url: The database to setup The images database contains the following tables: * image_groups * image_filenames **image_groups Table** This table holds the names of the images groups. It has the following columns: * id * parent_id * group_name **image_filenames Table** This table holds the filenames of the images and the group they belong to. It has the following columns: * id * group_id * filename """ session, metadata = init_db(url) # Definition of the "image_groups" table image_groups_table = Table('image_groups', metadata, Column('id', types.Integer(), primary_key=True), Column('parent_id', types.Integer()), Column('group_name', types.Unicode(128)) ) # Definition of the "image_filenames" table image_filenames_table = Table('image_filenames', metadata, Column('id', types.Integer(), primary_key=True), Column('group_id', types.Integer(), ForeignKey('image_groups.id'), default=None), Column('filename', types.Unicode(255), nullable=False) ) mapper(ImageGroups, image_groups_table) mapper(ImageFilenames, image_filenames_table) metadata.create_all(checkfirst=True) return session