Audit database addition

This commit is contained in:
Tim Bentley 2009-09-23 16:51:03 +01:00
parent b44b7e404b
commit cea3de26fa
10 changed files with 122 additions and 76 deletions

View File

@ -405,11 +405,11 @@ class Ui_MainWindow(object):
self.action_Preview_Panel.setStatusTip(translate(u'mainWindow', self.action_Preview_Panel.setStatusTip(translate(u'mainWindow',
u'Toggle the visibility of the Preview Panel')) u'Toggle the visibility of the Preview Panel'))
self.action_Preview_Panel.setShortcut(translate(u'mainWindow', u'F11')) self.action_Preview_Panel.setShortcut(translate(u'mainWindow', u'F11'))
self.ToolsAlertItem.setText(translate(u'mainWindow', u'&Alert')) self.ToolsAlertItem.setText(translate(u'mainWindow', u'Trigger &Alert'))
self.ToolsAlertItem.setStatusTip( self.ToolsAlertItem.setStatusTip(
translate(u'mainWindow', u'Show an alert message')) translate(u'mainWindow', u'Show an alert message'))
self.ToolsAlertItem.setShortcut(translate(u'mainWindow', u'F7')) self.ToolsAlertItem.setShortcut(translate(u'mainWindow', u'F7'))
self.PluginItem.setText(translate(u'mainWindow', u'&Plugin')) self.PluginItem.setText(translate(u'mainWindow', u'List &Plugins'))
self.PluginItem.setStatusTip( self.PluginItem.setStatusTip(
translate(u'mainWindow', u'List the Plugins')) translate(u'mainWindow', u'List the Plugins'))
self.PluginItem.setShortcut(translate(u'mainWindow', u'Alt+F7')) self.PluginItem.setShortcut(translate(u'mainWindow', u'Alt+F7'))
@ -510,16 +510,16 @@ class MainWindow(QtGui.QMainWindow, Ui_MainWindow):
QtCore.SIGNAL(u'triggered()'), self.onOptionsSettingsItemClicked) QtCore.SIGNAL(u'triggered()'), self.onOptionsSettingsItemClicked)
QtCore.QObject.connect(Receiver.get_receiver(), QtCore.QObject.connect(Receiver.get_receiver(),
QtCore.SIGNAL(u'update_global_theme'), self.defaultThemeChanged) QtCore.SIGNAL(u'update_global_theme'), self.defaultThemeChanged)
QtCore.QObject.connect(self.FileNewItem, QtCore.QObject.connect(self.FileNewItem,
QtCore.SIGNAL(u'triggered()'), QtCore.SIGNAL(u'triggered()'),
self.ServiceManagerContents.onNewService) self.ServiceManagerContents.onNewService)
QtCore.QObject.connect(self.FileOpenItem, QtCore.QObject.connect(self.FileOpenItem,
QtCore.SIGNAL(u'triggered()'), QtCore.SIGNAL(u'triggered()'),
self.ServiceManagerContents.onLoadService) self.ServiceManagerContents.onLoadService)
QtCore.QObject.connect(self.FileSaveItem, QtCore.QObject.connect(self.FileSaveItem,
QtCore.SIGNAL(u'triggered()'), QtCore.SIGNAL(u'triggered()'),
self.ServiceManagerContents.onQuickSaveService) self.ServiceManagerContents.onQuickSaveService)
QtCore.QObject.connect(self.FileSaveAsItem, QtCore.QObject.connect(self.FileSaveAsItem,
QtCore.SIGNAL(u'triggered()'), QtCore.SIGNAL(u'triggered()'),
self.ServiceManagerContents.onSaveService) self.ServiceManagerContents.onSaveService)
#warning cyclic dependency #warning cyclic dependency

View File

@ -100,7 +100,7 @@ class AuditPlugin(Plugin):
self.auditActive = str_to_bool( self.auditActive = str_to_bool(
self.config.get_config(u'audit active', False)) self.config.get_config(u'audit active', False))
self.ToolsAuditItem.setChecked(self.auditActive) self.ToolsAuditItem.setChecked(self.auditActive)
self.auditmanager = AuditManager() self.auditmanager = AuditManager(self.config)
def toggleAuditState(self): def toggleAuditState(self):
self.auditActive = not self.auditActive self.auditActive = not self.auditActive
@ -135,7 +135,3 @@ class AuditPlugin(Plugin):
self.auditFile.close() self.auditFile.close()
self.auditFile = open(self.auditFileNameNew, u'a') self.auditFile = open(self.auditFileNameNew, u'a')
def finalise(self):
log.debug(u'Finalise')
if self.auditFile is not None:
self.auditFile.close()

View File

@ -21,6 +21,9 @@
# with this program; if not, write to the Free Software Foundation, Inc., 59 # # with this program; if not, write to the Free Software Foundation, Inc., 59 #
# Temple Place, Suite 330, Boston, MA 02111-1307 USA # # Temple Place, Suite 330, Boston, MA 02111-1307 USA #
############################################################################### ###############################################################################
import sys
from audittab import AuditTab try:
from manager import AuditManager from audittab import AuditTab
from manager import AuditManager
except:
print sys.exc_info()

View File

@ -39,7 +39,6 @@ class AuditTab(SettingsTab):
self.AuditModeGroupBox.setObjectName(u'AuditModeGroupBox') self.AuditModeGroupBox.setObjectName(u'AuditModeGroupBox')
self.verticalLayout = QtGui.QVBoxLayout(self.AuditModeGroupBox) self.verticalLayout = QtGui.QVBoxLayout(self.AuditModeGroupBox)
self.verticalLayout.setObjectName("verticalLayout") self.verticalLayout.setObjectName("verticalLayout")
self.verticalLayout.addLayout(self.horizontalLayout)
self.AuditActive = QtGui.QCheckBox(self) self.AuditActive = QtGui.QCheckBox(self)
self.AuditActive.setObjectName("AuditActive") self.AuditActive.setObjectName("AuditActive")
self.verticalLayout.addWidget(self.AuditActive) self.verticalLayout.addWidget(self.AuditActive)
@ -54,12 +53,9 @@ class AuditTab(SettingsTab):
u'A restart is needed for this change to become effective')) u'A restart is needed for this change to become effective'))
def load(self): def load(self):
self.AuditFileName.setText(self.config.get_config(u'Audit file', u''))
self.AuditActive.setChecked(int(self.config.get_config(u'startup', 0))) self.AuditActive.setChecked(int(self.config.get_config(u'startup', 0)))
def save(self): def save(self):
self.config.set_config(
u'Audit file', unicode(self.AuditFileName.text()))
self.config.set_config( self.config.set_config(
u'startup', unicode(self.AuditActive.checkState())) u'startup', unicode(self.AuditActive.checkState()))
Receiver().send_message(u'audit_changed') Receiver().send_message(u'audit_changed')

View File

@ -0,0 +1,45 @@
# -*- coding: utf-8 -*-
# vim: autoindent shiftwidth=4 expandtab textwidth=80 tabstop=4 softtabstop=4
###############################################################################
# OpenLP - Open Source Lyrics Projection #
# --------------------------------------------------------------------------- #
# Copyright (c) 2008-2009 Raoul Snyman #
# Portions copyright (c) 2008-2009 Martin Thompson, Tim Bentley, Carsten #
# Tinggaard, Jon Tibble, Jonathan Corwin, Maikel Stuivenberg, Scott Guerrieri #
# --------------------------------------------------------------------------- #
# 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 #
###############################################################################
class BaseModel(object):
"""
BaseModel provides a base object with a set of generic functions
"""
@classmethod
def populate(cls, **kwargs):
"""
Creates an instance of a class and populates it, returning the instance
"""
me = cls()
keys = kwargs.keys()
for key in keys:
me.__setattr__(key, kwargs[key])
return me
class AuditItem(BaseModel):
"""
Audit model
"""
pass

View File

@ -27,7 +27,7 @@ import sys
from sqlalchemy import asc, desc from sqlalchemy import asc, desc
from openlp.plugins.audit.lib.models import init_models, metadata, session, \ from openlp.plugins.audit.lib.models import init_models, metadata, session, \
engine, audit_table, Audit engine, AuditItem, audit_table
import logging import logging
@ -38,7 +38,7 @@ class AuditManager():
""" """
global log global log
log = logging.getLogger(u'AuditManager') log=logging.getLogger(u'AuditManager')
log.info(u'Audit manager loaded') log.info(u'Audit manager loaded')
def __init__(self, config): def __init__(self, config):
@ -51,54 +51,61 @@ class AuditManager():
self.db_url = u'' self.db_url = u''
db_type = self.config.get_config(u'db type', u'sqlite') db_type = self.config.get_config(u'db type', u'sqlite')
if db_type == u'sqlite': if db_type == u'sqlite':
self.db_url = u'sqlite:///%s/Audit.sqlite' % \ self.db_url = u'sqlite:///%s/audit.sqlite' % \
self.config.get_data_path() self.config.get_data_path()
else: else:
self.db_url = db_type + 'u://' + \ self.db_url = u'%s://%s:%s@%s/%s' % \
self.config.get_config(u'db username') + u':' + \ (db_type, self.config.get_config(u'db username'),
self.config.get_config(u'db password') + u'@' + \ self.config.get_config(u'db password'),
self.config.get_config(u'db hostname') + u'/' + \ self.config.get_config(u'db hostname'),
self.config.get_config(u'db database') self.config.get_config(u'db database'))
self.session = init_models(self.db_url) self.session = init_models(self.db_url)
metadata.create_all(checkfirst=True) metadata.create_all(checkfirst=True)
log.debug(u'AuditInitialised')
def get_audits(self): log.debug(u'Audit Initialised')
"""
Returns a list of all the audits
"""
return self.session.query(audit).order_by(audit.whensung).all()
def get_audit(self, id): def get_all_audits(self):
""" """
Details of the audit Returns the details of a audit
""" """
return self.session.query(audit).get(id) return self.session.query(AuditItem).order_by(AuditItem.title).all()
def save_audit(self, audit): def insert_audit(self, audititem):
""" """
Save the audit and refresh the cache Saves an audit to the database
""" """
log.debug(u'Audit added')
try: try:
self.session.add(audit) self.session.add(audititem)
self.session.commit() self.session.commit()
return True return True
except: except:
self.session.rollback() self.session.rollback()
log.exception(u'Could not save audit to song database') log.excertion(u'Audit item failed to save')
return False return False
def delete_audit(self, auditid): def get_audit(self, id=None):
""" """
Delete the audit Returns the details of an audit
""" """
audit = self.get_audit(auditid) if id is None:
try: return AuditItem()
self.session.delete(audit) else:
self.session.commit() return self.session.query(AuditItem).get(id)
def delete_audit(self, id):
"""
Delete a audit record
"""
if id !=0:
audititem = self.get_audit(id)
try:
self.session.delete(audititem)
self.session.commit()
return True
except:
self.session.rollback()
log.excertion(u'Audit Item failed to delete')
return False
else:
return True return True
except:
self.session.rollback()
log.exception(u'Could not delete audit from song database')
return False

View File

@ -27,11 +27,12 @@ from sqlalchemy.orm import scoped_session, sessionmaker, mapper, relation
from openlp.plugins.audit.lib.meta import session, metadata, engine from openlp.plugins.audit.lib.meta import session, metadata, engine
from openlp.plugins.audit.lib.tables import * from openlp.plugins.audit.lib.tables import *
from openlp.plugins.audit.lib.classes import *
def init_models(url): def init_models(url):
engine = create_engine(url) engine = create_engine(url)
metadata.bind = engine metadata.bind = engine
session = scoped_session(sessionmaker(autoflush=False, session = scoped_session(sessionmaker(autoflush=True, autocommit=False,
autocommit=False, bind=engine)) bind=engine))
mapper(Audit, audit_table) mapper(AuditItem, audit_table)
return session return session

View File

@ -22,19 +22,15 @@
# Temple Place, Suite 330, Boston, MA 02111-1307 USA # # Temple Place, Suite 330, Boston, MA 02111-1307 USA #
############################################################################### ###############################################################################
from datetime import now
from sqlalchemy import *
from sqlalchemy import Column, Table, ForeignKey, types from sqlalchemy import Column, Table, ForeignKey, types
from openlp.plugins.audit.lib.meta import metadata from openlp.plugins.audit.lib.meta import metadata
# Definition of the "audits" table # Definition of the "songs" table
audit_table = Table(u'audits', metadata, audit_table = Table(u'custom_slide', metadata,
Column(u'id', types.Integer, primary_key=True), Column(u'id', types.Integer(), primary_key=True),
Column('whensung', types.DateTime, nullable=False, default=datetime.now()), Column(u'title', types.Unicode(255), nullable=False),
Column(u'authors', types.Unicode(255)), Column(u'text', types.UnicodeText, nullable=False),
Column(u'ccli_number', types.Unicode(64)), Column(u'credits', types.UnicodeText),
Column(u'theme_name', types.Unicode(128))
) )
Index(u'audits_id',audit_table.c.timestamp, audit_table.c.id)

View File

@ -40,6 +40,6 @@ class BaseModel(object):
class CustomSlide(BaseModel): class CustomSlide(BaseModel):
""" """
Author model Custom Slide model
""" """
pass pass

View File

@ -51,8 +51,8 @@ class CustomManager():
self.db_url = u'' self.db_url = u''
db_type = self.config.get_config(u'db type', u'sqlite') db_type = self.config.get_config(u'db type', u'sqlite')
if db_type == u'sqlite': if db_type == u'sqlite':
self.db_url = u'sqlite:///' + self.config.get_data_path() + \ self.db_url = u'sqlite:///%s/custom.sqlite' % \
u'/custom.sqlite' self.config.get_data_path()
else: else:
self.db_url = u'%s://%s:%s@%s/%s' % \ self.db_url = u'%s://%s:%s@%s/%s' % \
(db_type, self.config.get_config(u'db username'), (db_type, self.config.get_config(u'db username'),
@ -60,23 +60,19 @@ class CustomManager():
self.config.get_config(u'db hostname'), self.config.get_config(u'db hostname'),
self.config.get_config(u'db database')) self.config.get_config(u'db database'))
self.session = init_models(self.db_url) self.session = init_models(self.db_url)
if not custom_slide_table.exists(): metadata.create_all(checkfirst=True)
metadata.create_all()
log.debug(u'Custom Initialised') log.debug(u'Custom Initialised')
#
# def process_dialog(self, dialogobject):
# self.dialogobject = dialogobject
#
def get_all_slides(self): def get_all_slides(self):
""" """
Returns the details of a song Returns the details of a Custom Slide Show
""" """
return self.session.query(CustomSlide).order_by(CustomSlide.title).all() return self.session.query(CustomSlide).order_by(CustomSlide.title).all()
def save_slide(self, customslide): def save_slide(self, customslide):
""" """
Saves a song to the database Saves a Custom slide show to the database
""" """
log.debug(u'Custom Slide added') log.debug(u'Custom Slide added')
try: try:
@ -85,7 +81,8 @@ class CustomManager():
log.debug(u'Custom Slide saved') log.debug(u'Custom Slide saved')
return True return True
except: except:
log.debug(u'Custom Slide failed') self.session.rollback()
log.excertion(u'Custom Slide save failed')
return False return False
def get_custom(self, id=None): def get_custom(self, id=None):
@ -98,6 +95,9 @@ class CustomManager():
return self.session.query(CustomSlide).get(id) return self.session.query(CustomSlide).get(id)
def delete_custom(self, id): def delete_custom(self, id):
"""
Delete a Custom slide show
"""
if id !=0: if id !=0:
customslide = self.get_custom(id) customslide = self.get_custom(id)
try: try:
@ -105,6 +105,8 @@ class CustomManager():
self.session.commit() self.session.commit()
return True return True
except: except:
self.session.rollback()
log.excertion(u'Custom Slide deleton failed')
return False return False
else: else:
return True return True