fix #1562, ajout des services dans les listes, fix liste mes embauches a traiter
[auf_rh_dae.git] / project / dae / managers.py
1 # -*- encoding: utf-8 -*-
2
3 from django.db import models
4 from django.db.models import Q
5 from utils import is_user_dans_service, get_employe_from_user
6 from workflow import POSTE_ETAT_HAUTE_DIRECTION, \
7 POSTE_ETAT_POLE_FINANCIER, \
8 POSTE_ETAT_REFUSE, \
9 DOSSIER_ETAT_REFUSE, \
10 MAP_GROUPE_ETATS_A_FAIRE
11 from workflow import dae_groupes, \
12 grp_administrateurs, \
13 grp_gestionnaires, \
14 grp_directeurs_bureau, \
15 grp_drh, \
16 grp_pole_financier, \
17 grp_haute_direction, \
18 grp_service_utilisateurs, \
19 grp_directeurs_service, \
20 grp_correspondants_rh
21
22
23 class SecurityManager(models.Manager):
24
25 prefixe_service = None
26 prefixe_implantation = None
27
28 def mes_choses_a_faire(self, user):
29 q = Q()
30 rien_a_faire = True
31 for g in user.groups.all():
32 etats = MAP_GROUPE_ETATS_A_FAIRE.get(g, ())
33 for etat in etats:
34 rien_a_faire = False
35 q = q | Q(etat=etat)
36
37 if rien_a_faire:
38 qs = self.ma_region_ou_service(user).none()
39 else:
40 qs = self.ma_region_ou_service(user).filter(q)
41
42 return qs
43
44 def ma_region_ou_service(self, user):
45 """
46 Filtrage des postes en fonction du user connecté (region / service)
47 On s'intéresse aussi au groupe auquel appartient le user car certains groupes
48 peuvent tout voir.
49 """
50 # On s'assure que le manager travaille sur un modèle avec WF, autrement
51 # on ne teste pas sur l'état
52 try:
53 self.model._meta.get_field_by_name('etat')
54 workflowed_model = True
55 except:
56 workflowed_model = False
57
58 employe = get_employe_from_user(user)
59
60 ############################################
61 # TRAITEMENT NORMAL
62 ############################################
63 # SERVICE
64 if workflowed_model and grp_service_utilisateurs in user.groups.all():
65 q = Q(**{ self.prefixe_service : employe.service})
66 # REGION
67 else:
68 q = Q(**{ self.prefixe_implantation : employe.implantation.region })
69
70 if workflowed_model:
71 q_non_refuse = ~Q(etat__in=(POSTE_ETAT_REFUSE, DOSSIER_ETAT_REFUSE,))
72 q = q & q_non_refuse
73
74 liste = self.get_query_set().filter(q)
75
76
77 ############################################
78 # TRAITEMENT POLE FINANCIER
79 ############################################
80 if workflowed_model and grp_pole_financier in user.groups.all():
81 liste = self.get_query_set().filter(q_non_refuse)
82
83 ############################################
84 # TRAITEMENT HAUTE DIRECTION
85 ############################################
86 if workflowed_model and grp_haute_direction in user.groups.all():
87 liste = self.get_query_set().filter(q_non_refuse)
88
89 ############################################
90 # TRAITEMENT DRH
91 ############################################
92 if grp_drh in user.groups.all():
93 liste = self.get_query_set()
94
95 return liste
96
97
98 class PosteManager(SecurityManager):
99 """
100 Chargement de tous les objets FK existants sur chaque QuerySet.
101 """
102 prefixe_service = "service"
103 prefixe_implantation = "implantation__region"
104
105 def ma_region_ou_service(self, user):
106 return super(PosteManager, self).ma_region_ou_service(user).filter(actif=True)
107
108 def get_query_set(self):
109 fkeys = (
110 'id_rh',
111 'responsable',
112 'implantation',
113 'type_poste',
114 'service',
115 'classement_min',
116 'classement_max',
117 'valeur_point_min',
118 'valeur_point_max',
119 )
120 return super(PosteManager, self).get_query_set() \
121 .select_related(*fkeys).all()
122
123
124 class DossierManager(SecurityManager):
125 prefixe_service = "poste__service"
126 prefixe_implantation = "poste__implantation__region"
127
128 def ma_region_ou_service(self, user):
129 return super(DossierManager, self).ma_region_ou_service(user).filter(poste__actif=True)
130
131