- inits centralizados, READMEs atualizados
- padronizando o nome de get_db_connection e session para get_db_session, para não confundir com session do Flask ou sessoes web
- corrigindo potenciais erros
-- has_permission nao consegue com lazy load carregar permission depois de load_user fechar a conexao, entao joinedLoad com Permission antes de fechar
-- db.rollback não existe caso db = get_db_session() apareça muito depois dentro do try, padronizando antes de try
--- comparar role por nivel (Role.SECRETARIO_GERAL) e nao por nome ("Secretario Geral")
- unificacao de get_otp_qr_code
- mudança de nowutc() para now(UTC) conforme novo padrão
This commit is contained in:
@@ -1,5 +1,5 @@
|
||||
from flask import Blueprint, request, render_template, redirect, url_for, flash, jsonify
|
||||
from functions.database import get_db_connection, MaterialVendido, Militante, TipoMaterial
|
||||
from functions.database import get_db_session, MaterialVendido, Militante, TipoMaterial
|
||||
from functions.decorators import require_login
|
||||
from utils.date_utils import validar_data, converter_data
|
||||
from datetime import datetime
|
||||
@@ -11,7 +11,7 @@ material_bp = Blueprint('material', __name__)
|
||||
@require_login
|
||||
def listar():
|
||||
"""Lista todos os materiais com controle de permissões no nível de dados"""
|
||||
db = get_db_connection()
|
||||
db = get_db_session()
|
||||
try:
|
||||
# SEMPRE renderizar o template, mas filtrar os dados baseado nas permissões
|
||||
materiais = []
|
||||
@@ -46,6 +46,7 @@ def listar():
|
||||
def novo():
|
||||
"""Cria um novo material vendido"""
|
||||
if request.method == "POST":
|
||||
db = get_db_session()
|
||||
try:
|
||||
militante_id = request.form.get("militante_id")
|
||||
tipo_material_id = request.form.get("tipo_material_id")
|
||||
@@ -57,7 +58,6 @@ def novo():
|
||||
flash('Data de venda inválida ou futura', 'danger')
|
||||
return redirect(url_for('material.novo'))
|
||||
|
||||
db = get_db_connection()
|
||||
material = MaterialVendido(
|
||||
militante_id=militante_id,
|
||||
tipo_material_id=tipo_material_id,
|
||||
@@ -77,7 +77,7 @@ def novo():
|
||||
db.close()
|
||||
|
||||
# GET - Renderizar formulário
|
||||
db = get_db_connection()
|
||||
db = get_db_session()
|
||||
try:
|
||||
militantes = db.query(Militante).order_by(Militante.nome).all()
|
||||
tipos_material = db.query(TipoMaterial).order_by(TipoMaterial.descricao).all()
|
||||
@@ -89,7 +89,7 @@ def novo():
|
||||
@require_login
|
||||
def editar(id):
|
||||
"""Edita um material vendido"""
|
||||
db = get_db_connection()
|
||||
db = get_db_session()
|
||||
try:
|
||||
material = db.query(MaterialVendido).get(id)
|
||||
if not material:
|
||||
@@ -122,7 +122,7 @@ def editar(id):
|
||||
@require_login
|
||||
def excluir(id):
|
||||
"""Exclui um material vendido"""
|
||||
db = get_db_connection()
|
||||
db = get_db_session()
|
||||
try:
|
||||
material = db.query(MaterialVendido).get(id)
|
||||
if not material:
|
||||
@@ -146,7 +146,7 @@ def excluir(id):
|
||||
@require_login
|
||||
def listar_tipos():
|
||||
"""Lista todos os tipos de materiais com controle de permissões no nível de dados"""
|
||||
db = get_db_connection()
|
||||
db = get_db_session()
|
||||
try:
|
||||
# SEMPRE renderizar o template, mas filtrar os dados baseado nas permissões
|
||||
tipos_materiais = []
|
||||
@@ -174,10 +174,10 @@ def listar_tipos():
|
||||
def novo_tipo():
|
||||
"""Cria um novo tipo de material"""
|
||||
if request.method == "POST":
|
||||
db = get_db_session()
|
||||
try:
|
||||
descricao = request.form.get("descricao")
|
||||
|
||||
db = get_db_connection()
|
||||
tipo = TipoMaterial(descricao=descricao)
|
||||
db.add(tipo)
|
||||
db.commit()
|
||||
@@ -196,7 +196,7 @@ def novo_tipo():
|
||||
@require_login
|
||||
def editar_tipo(id):
|
||||
"""Edita um tipo de material"""
|
||||
db = get_db_connection()
|
||||
db = get_db_session()
|
||||
try:
|
||||
tipo = db.query(TipoMaterial).get(id)
|
||||
if not tipo:
|
||||
@@ -222,7 +222,7 @@ def editar_tipo(id):
|
||||
@require_login
|
||||
def excluir_tipo(id):
|
||||
"""Exclui um tipo de material"""
|
||||
db = get_db_connection()
|
||||
db = get_db_session()
|
||||
try:
|
||||
tipo = db.query(TipoMaterial).get(id)
|
||||
if not tipo:
|
||||
|
||||
Reference in New Issue
Block a user