2009-09-22 19:37:36 +00:00
|
|
|
# -*- coding: utf-8 -*-
|
|
|
|
# vim: autoindent shiftwidth=4 expandtab textwidth=80 tabstop=4 softtabstop=4
|
|
|
|
|
|
|
|
###############################################################################
|
|
|
|
# OpenLP - Open Source Lyrics Projection #
|
|
|
|
# --------------------------------------------------------------------------- #
|
2010-12-26 11:04:47 +00:00
|
|
|
# Copyright (c) 2008-2011 Raoul Snyman #
|
|
|
|
# Portions copyright (c) 2008-2011 Tim Bentley, Jonathan Corwin, Michael #
|
2011-03-24 19:04:02 +00:00
|
|
|
# Gorven, Scott Guerrieri, Matthias Hub, Meinert Jordan, Armin Köhler, #
|
|
|
|
# Andreas Preikschat, Mattias Põldaru, Christian Richter, Philip Ridout, #
|
|
|
|
# Maikel Stuivenberg, Martin Thompson, Jon Tibble, Frode Woldsund #
|
2009-09-22 19:37:36 +00:00
|
|
|
# --------------------------------------------------------------------------- #
|
|
|
|
# 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 #
|
|
|
|
###############################################################################
|
2010-06-15 02:08:22 +00:00
|
|
|
"""
|
|
|
|
The :mod:`db` module provides the database and schema that is the backend for
|
|
|
|
the SongUsage plugin
|
|
|
|
"""
|
2009-09-22 19:37:36 +00:00
|
|
|
|
2010-06-15 02:08:22 +00:00
|
|
|
from sqlalchemy import Column, Table, types
|
|
|
|
from sqlalchemy.orm import mapper
|
2009-09-22 19:37:36 +00:00
|
|
|
|
2010-06-15 02:08:22 +00:00
|
|
|
from openlp.core.lib.db import BaseModel, init_db
|
|
|
|
|
|
|
|
class SongUsageItem(BaseModel):
|
|
|
|
"""
|
|
|
|
SongUsageItem model
|
|
|
|
"""
|
|
|
|
pass
|
|
|
|
|
|
|
|
def init_schema(url):
|
|
|
|
"""
|
|
|
|
Setup the songusage database connection and initialise the database schema
|
|
|
|
|
|
|
|
``url``
|
|
|
|
The database to setup
|
|
|
|
"""
|
|
|
|
session, metadata = init_db(url)
|
|
|
|
|
|
|
|
songusage_table = Table(u'songusage_data', metadata,
|
|
|
|
Column(u'id', types.Integer(), primary_key=True),
|
|
|
|
Column(u'usagedate', types.Date, index=True, nullable=False),
|
|
|
|
Column(u'usagetime', types.Time, index=True, nullable=False),
|
|
|
|
Column(u'title', types.Unicode(255), nullable=False),
|
|
|
|
Column(u'authors', types.Unicode(255), nullable=False),
|
|
|
|
Column(u'copyright', types.Unicode(255)),
|
|
|
|
Column(u'ccl_number', types.Unicode(65))
|
|
|
|
)
|
2009-09-22 19:37:36 +00:00
|
|
|
|
2009-10-27 08:38:02 +00:00
|
|
|
mapper(SongUsageItem, songusage_table)
|
2010-06-15 02:08:22 +00:00
|
|
|
|
|
|
|
metadata.create_all(checkfirst=True)
|
2011-02-24 05:47:38 +00:00
|
|
|
return session
|