Files
caotek_monaa/caotek_mesavoirs/models/default.py
2017-07-23 15:43:34 +02:00

88 lines
3.2 KiB
Python

# -*- 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})