# -*- coding: utf8 -*- from sqlalchemy import text from sqlalchemy.ext.declarative import declarative_base from sqlalchemy.orm import ( scoped_session, sessionmaker, ) from zope.sqlalchemy import ZopeTransactionExtension, mark_changed from datetime import * import transaction def execute_query(request, query, params): """Execute query and mark session as changed""" request.dbsession.execute(query, params) mark_changed(request.dbsession) transaction.commit() def get_docs(request, doc_id): """Lire les doc""" if doc_id == 0: query = "SELECT * FROM docs ORDER BY theme, intitule;" results = request.dbsession.execute(query).fetchall() elif doc_id == -1: query = "SELECT * FROM docs where theme <> 'INTERNE' ORDER BY theme, intitule;" results = request.dbsession.execute(query).fetchall() else: query = "SELECT * FROM docs where doc_id = :doc_id;" results = request.dbsession.execute(query, {'doc_id': doc_id}).first() return results def update_doc(request, doc_id, intitule, texte, theme): """créér ou modifier le doc""" if doc_id == '0': query = "INSERT INTO docs (intitule, texte, theme) VALUES(:intitule, :texte, :theme);" execute_query(request, query, {'intitule': intitule, 'texte': texte, 'theme': theme}) else: query = "update docs set intitule=:intitule, texte=:texte, theme=:theme where doc_id = :doc_id;" execute_query(request, query, {'doc_id': doc_id, 'intitule': intitule, 'texte': texte, 'theme': theme}) def delete_doc(request, doc_id): """supprimer la doc""" query = "delete from docs where doc_id = :doc_id;" results = request.dbsession.execute(query, {'doc_id': doc_id}) def get_actifs(request, no_id): if no_id == '0': query = "SELECT * FROM actifs ORDER BY symbole" results = request.dbsession.execute(query).fetchall() else: # lire le actif par son identifiant query = """SELECT * FROM actifs WHERE no_id=:no_id;""" results = request.dbsession.execute(query, {'no_id': no_id}).first() return results def get_categories(request, cat_id): if cat_id == '0': query = "SELECT * FROM categories ORDER BY categorie" results = request.dbsession.execute(query).fetchall() else: # lire le actif par son identifiant query = """SELECT * FROM categories WHERE cat_id=:cat_id;""" results = request.dbsession.execute(query, {'cat_id': cat_id}).first() return results def update_actif(request, no_id, new_values): # formater les champs s = '' for param in new_values.keys(): if param == 'symbole': new_values['symbole'] = new_values['symbole'].upper() if s: s += ",%s=:%s" % (param, param) else: s = "%s=:%s" % (param, param) if no_id == '0': query = "INSERT INTO actifs SET %s" % s else: new_values['no_id'] = no_id query = "UPDATE actifs SET %s WHERE no_id = :no_id;" % s execute_query(request, query, new_values) def delete_actif(request, no_id): query = "DELETE FROM actifs WHERE no_id = :no_id ;" execute_query(request, query, {'no_id': no_id})