/[openfoncier]/trunk/obj/consultation.class.php
ViewVC logotype

Annotation of /trunk/obj/consultation.class.php

Parent Directory Parent Directory | Revision Log Revision Log


Revision 2857 - (hide annotations)
Mon Mar 24 09:52:48 2014 UTC (10 years, 10 months ago) by nmeucci
File size: 51363 byte(s)
Correction du type des champs dates cachés (remplacement hidden par hiddendate).

1 fraynaud 3 <?php
2     //$Id$
3     //gen openMairie le 10/02/2011 20:32
4     require_once ("../gen/obj/consultation.class.php");
5 mlimic 843 require_once("../services/outgoing/messageenqueuer.php");
6 fraynaud 3
7     class consultation extends consultation_gen {
8 nhaye 601
9 nhaye 1917 var $abstract_type = array(
10     "fichier" => "file",
11     );
12    
13 nhaye 1935 var $metadata = array(
14 nhaye 1938 "om_fichier_consultation" => array(
15 nhaye 1935 "dossier" => "getDossier",
16 softime 2016 "dossier_version" => "getDossierVersion",
17 softime 2025 "numDemandeAutor" => "getNumDemandeAutor",
18     "anneemoisDemandeAutor" => "getAnneemoisDemandeAutor",
19     "typeInstruction" => "getTypeInstruction",
20     "statutAutorisation" => "getStatutAutorisation",
21     "typeAutorisation" => "getTypeAutorisation",
22     "dateEvenementDocument" => "getDateEvenementDocument",
23 softime 2016 "groupeInstruction" => 'getGroupeInstruction',
24 softime 2025 "title" => 'getTitle',
25 nhaye 1935 ),
26 softime 2002 "fichier" => array(
27     "dossier" => "getDossier",
28 softime 2016 "dossier_version" => "getDossierVersion",
29 softime 2025 "numDemandeAutor" => "getNumDemandeAutor",
30     "anneemoisDemandeAutor" => "getAnneemoisDemandeAutor",
31     "typeInstruction" => "getTypeInstruction",
32     "statutAutorisation" => "getStatutAutorisation",
33     "typeAutorisation" => "getTypeAutorisation",
34     "dateEvenementDocument" => "getDateEvenementDocument",
35 softime 2016 "groupeInstruction" => 'getGroupeInstruction',
36 softime 2025 "title" => 'getTitle',
37 softime 2002 ),
38 nhaye 1935 );
39    
40 fraynaud 20 function consultation($id,&$db,$debug) {
41     $this->constructeur($id,$db,$debug);
42     }// fin constructeur
43 fmichon 943
44     // {{{ Gestion de la confidentialité des données spécifiques
45    
46     /**
47     * Surcharge pour gérer les actions disponibles dans le portlet
48     */
49     function checkAccessibility() {
50     //
51     parent::checkAccessibility();
52     // Si l'utilisateur est un intructeur qui en correspond pas à la
53     // division du dossier
54     if ($this->f->isUserInstructeur()
55     && isset($this->f->om_utilisateur["division"])
56     && $this->f->om_utilisateur["division"] != $this->getDivisionFromDossier()) {
57     //
58 vpihour 2104 $this->parameters["actions"]["modifier"] = NULL;
59     $this->parameters["actions"]["supprimer"] = NULL;
60     $this->actions_sup["finalisation"] = NULL;
61     $this->actions_sup["definalisation"] = NULL;
62     $this->actions_sup["lu"] = NULL;
63 fmichon 943 }
64     // Si une action 'lu' est présente et que le champ lu est à true
65     // on supprime l'action
66     if (isset($this->actions_sup["lu"])
67     && isset($this->val[array_search("lu", $this->champs)])
68     && $this->val[array_search("lu", $this->champs)]== "t") {
69     unset($this->actions_sup["lu"]);
70     }
71 vpihour 1974
72     //Si le document est déjà finalisé, le lien de l'édition est celui du stockage
73 vpihour 2603 $om_final_consultation = $this->getVal("om_final_consultation");
74     if ( $om_final_consultation== "t" ){
75    
76 vpihour 1974 //On affiche le bon lien pour l'édition
77     $this->actions_sup["pdfetat"]["lien"] = "../spg/file.php?id=";
78     $this->actions_sup["pdfetat"]["id"] =
79     "&amp;obj=consultation&amp;champ=om_fichier_consultation";
80 vpihour 2603 //On cache les liens d'action
81 vpihour 1986 $this->parameters["actions"]["modifier"] = NULL;
82     $this->parameters["actions"]["supprimer"] = NULL;
83 vpihour 2603 $this->actions_sup["finalisation"] = NULL;
84 vpihour 1974 }
85     //Si le document n'est pas finalisé, le lien de l'édition est le lien de
86     //génération à la volée
87 vpihour 2603 if ( $om_final_consultation!= "t" ){
88 vpihour 1974
89     //On affiche le bon lien pour l'édition
90     $this->actions_sup["pdfetat"]["lien"] = "../app/pdf_consultation.php?idx=";
91     $this->actions_sup["pdfetat"]["id"] = "&obj=consultation";
92 vpihour 2603 $this->actions_sup["definalisation"] = NULL;
93     if( $this->f->isUserInstructeur() ){
94     $this->parameters["actions"]["modifier"] = NULL;
95     }
96 vpihour 1974 }
97 vpihour 1978
98     $idxformulaire = $this->getParameter("idxformulaire");
99     $retourformulaire = $this->getParameter("retourformulaire");
100     //Si le dossier d'instruction auquel est rattachée la consultation est
101     //cloturé, on affiche pas les liens du portlet
102     if ( $idxformulaire != '' &&
103     (
104     $retourformulaire == 'dossier' ||
105     $retourformulaire == 'dossier_instruction' ||
106     $retourformulaire == 'dossier_instruction_mes_encours' ||
107     $retourformulaire == 'dossier_instruction_tous_encours' ||
108     $retourformulaire == 'dossier_instruction_mes_clotures' ||
109     $retourformulaire == 'dossier_instruction_tous_clotures'
110     )){
111    
112     //On récuppère le statut du dossier d'instruction
113 vpihour 2039 $statut = $this->f->getStatutDossier($idxformulaire);
114 vpihour 1978 if ( $this->f->isUserInstructeur() && $statut == "cloture" ){
115    
116     //On cache le lien de modification
117     $this->parameters["actions"]["modifier"] = NULL;
118     $this->parameters["actions"]["supprimer"] = NULL;
119     $this->actions_sup["finalisation"] = NULL;
120     $this->actions_sup["definalisation"] = NULL;
121     $this->actions_sup["lu"] = NULL;
122     }
123     }
124 fmichon 943 }
125    
126     /**
127     * Cette methode est à surcharger elle permet de tester dans chaque classe
128     * des droits des droits spécifiques en fonction des données
129     */
130     function canAccess() {
131     // Si l'utilisateur est un utilisateur de service externe
132     // on vérifie qu'il peut accéder à la consultation
133 softime 2120 if ($this->f->isUserService()) {
134 fmichon 943 // On compare l'id du service de la consultation
135     // aux id des services de utilisateur connecté
136     foreach($this->f->om_utilisateur['service'] as $service) {
137     if($this->val[array_search("service",$this->champs)]===$service['service']) {
138     return true;
139     }
140     }
141 fmichon 1088 //
142     $this->f->addToLog("canAccess(): utilisateur de service sur une consultation d'un autre service", EXTRA_VERBOSE_MODE);
143 fmichon 943 return false;
144     }
145     // Si l'utilisateur est un intructeur qui ne correspond pas à la
146     // division du dossier
147     if ($this->f->isUserInstructeur()
148     && $this->f->om_utilisateur["division"] != $this->getDivisionFromDossier()
149     && $this->getParameter("maj") != 3) {
150     //
151 fmichon 1088 $this->f->addToLog("canAccess(): utilisateur instructeur sur un dossier d'une autre division", EXTRA_VERBOSE_MODE);
152 fmichon 943 return false;
153     }
154 vpihour 1978
155     $retourformulaire = $this->getParameter("retourformulaire");
156     // Si l'utilisateur est un instructeur et que le dossier est cloturé
157     if ( $this->f->isUserInstructeur() &&
158 vpihour 2039 $this->f->getStatutDossier($this->getParameter("idxformulaire")) == "cloture" &&
159 vpihour 1978 (
160     $retourformulaire == 'dossier' ||
161     $retourformulaire == 'dossier_instruction' ||
162     $retourformulaire == 'dossier_instruction_mes_encours' ||
163     $retourformulaire == 'dossier_instruction_tous_encours' ||
164     $retourformulaire == 'dossier_instruction_mes_clotures' ||
165     $retourformulaire == 'dossier_instruction_tous_clotures'
166     ) &&
167     $this->getParameter("maj") != 3) {
168    
169     return false;
170     }
171 fmichon 943 //
172     return true;
173     }
174    
175     /**
176 fmichon 1908 * Cette variable permet de stocker le résultat de la méthode
177     * getDivisionFromDossier() afin de ne pas effectuer le recalcul à chacun de
178     * ces appels.
179     * @var string Code de la division du dossier en cours
180 fmichon 943 */
181 fmichon 1908 var $_division_from_dossier = NULL;
182    
183     /**
184     * Cette méthode permet de récupérer le code de division correspondant
185     * au dossier sur lequel on se trouve.
186     *
187     * @return string Code de la division du dossier en cours
188     */
189 fmichon 943 function getDivisionFromDossier() {
190 fmichon 1908
191     // Cette méthode peut être appelée plusieurs fois lors d'une requête.
192     // Pour éviter de refaire le traitement de recherche de la division
193     // alors on vérifie si nous ne l'avons pas déjà calculé.
194     if ($this->_division_from_dossier != NULL) {
195     // Logger
196     $this->addToLog("getDivisionFromDossier(): retour de la valeur déjà calculée - '".$this->_division_from_dossier."'", EXTRA_VERBOSE_MODE);
197     // On retourne la valeur déjà calculée
198     return $this->_division_from_dossier;
199     }
200    
201     // Par défaut, on définit la valeur du dossier à NULL
202     $dossier = NULL;
203     // Test sur le mode et le contexte du formulaire
204     if ($this->getParameter("maj") == 0
205     && ($this->getParameter("retourformulaire") == "dossier"
206     || $this->getParameter("retourformulaire") == "dossier_instruction"
207     || $this->getParameter("retourformulaire") == "dossier_instruction_mes_encours"
208     || $this->getParameter("retourformulaire") == "dossier_instruction_tous_encours"
209     || $this->getParameter("retourformulaire") == "dossier_instruction_mes_clotures"
210     || $this->getParameter("retourformulaire") == "dossier_instruction_tous_clotures")) {
211     // Si on se trouve en mode AJOUT (seul mode où l'enregistrement
212     // n'existe pas en base de données) ET que nous nous trouvons
213     // dans le contexte d'un dossier d'instruction alors on récupère
214     // le numéro de dossier depuis le paramètre 'idxformulaire'
215     $dossier = $this->getParameter("idxformulaire");
216 fmichon 1088 } else {
217 fmichon 1908 // Sinon on récupère le numéro de dossier dans le champs dossier de
218     // l'enregistrement (en base de données)
219     $dossier = $this->getVal("dossier");
220 fmichon 943 }
221 fmichon 1088
222 fmichon 1908 // On appelle la méthode de la classe utils qui renvoi le code de la
223     // division d'un dossier, on la stocke pour ne pas refaire le calcul au
224     // prochain appel de cette méthode
225     $this->_division_from_dossier = $this->f->getDivisionFromDossier($dossier);
226     // Logger
227     $this->addToLog("getDivisionFromDossier(): retour de la valeur nouvellement calculée - '".$this->_division_from_dossier."'", EXTRA_VERBOSE_MODE);
228     // On retourne la valeur retournée
229     return $this->_division_from_dossier;
230    
231 fmichon 943 }
232    
233     // }}}
234    
235 fraynaud 20 function setValsousformulaire(&$form,$maj,$validation,$idxformulaire,$retourformulaire,$typeformulaire){
236 nhaye 1683 // ajout du retourformulaire aux attributs de l'objet
237     $this->retourformulaire = $retourformulaire;
238 fraynaud 20 if ($validation==0) {
239     if ($maj == 0){
240 nhaye 569 $form->setVal("dossier", $idxformulaire);
241     $form->setVal("date_envoi",date('d/m/Y'));
242 fraynaud 20 }
243 nhaye 587 if($maj == 1) {
244 nhaye 594 if($this->f->isAccredited('consultation_retour_avis_suivi') OR
245     $this->f->isAccredited('consultation_retour_avis_service')) {
246     $form->setVal("date_retour",date('d/m/Y'));
247     }
248 nhaye 587 }
249 fraynaud 20 }
250     }
251 nhaye 587
252     function setVal(&$form, $maj, $validation, &$db) {
253     if($maj == 1) {
254     $form->setVal("date_retour",date('d/m/Y'));
255     }
256     }
257 fraynaud 20
258 nhaye 561 function setvalF($val) {
259 fmichon 1730 //
260 nhaye 561 parent::setValF($val);
261 fmichon 1730 //
262     if ($this->getParameter('maj') == 0) {
263     //
264     if (isset($this->valF["date_envoi"])) {
265     $this->valF["date_reception"] = $this->valF["date_envoi"];
266     }
267     //
268 fmichon 1172 $this->valF["lu"] = true;
269 nhaye 587 }
270 nhaye 598
271 nhaye 561 // Si un retour d'avis est modifie on passe "lu" a false
272 nhaye 598 if($this->getParameter('maj')==1 AND (
273     $this->val[array_search("avis_consultation",$this->champs)] != $val["avis_consultation"] OR
274     $this->val[array_search("date_retour",$this->champs)] != $val["date_retour"] OR
275     $this->val[array_search("motivation",$this->champs)] != $val["motivation"] OR
276 nhaye 674 $this->val[array_search("fichier",$this->champs)] != $val["fichier"])
277 nhaye 598 ) {
278     $this->valF["lu"]=false;
279 nhaye 561 }
280 nhaye 675 }
281 fmichon 1730
282     function setLib(&$form, $maj) {
283     //
284     parent::setLib($form, $maj);
285     //
286     $form->setLib($this->clePrimaire, _("id"));
287     }
288    
289 fraynaud 20 function setType(&$form,$maj) {
290 fmichon 671 // Appel du parent
291 nhaye 459 parent::setType($form,$maj);
292 softime 2112 $form->setType('dossier', 'hidden');
293 fmichon 671 // MODE - AJOUTER
294     if ($maj == 0) {
295     // On cache alors tous les champs que nous ne voulons pas voir
296     // apparaître dans le formulaire d'ajout (principalement les
297     // informations sur le retour d'avis)
298 nmeucci 2857 $form->setType('date_retour', 'hiddendate');
299     $form->setType('date_reception', 'hiddendate');
300     $form->setType('date_limite', 'hiddendate');
301 fmichon 671 $form->setType('avis_consultation', 'hidden');
302     $form->setType('motivation', 'hidden');
303     $form->setType('fichier', 'hidden');
304     $form->setType('lu', 'hidden');
305     // On permet la modification de certains champs
306 softime 2112 $form->setType('dossier_libelle', 'hiddenstatic');
307 fmichon 671 $form->setType('service', 'select');
308     $form->setType('date_envoi', 'date2');
309     }
310     // MODE - MODIFIER
311     if ($maj == 1) {
312    
313     // On affiche en statique les informations qui ne sont plus
314     // modifiables
315 softime 2112 $form->setType('dossier_libelle', 'hiddenstatic');
316 fmichon 671 $form->setType('date_envoi', 'hiddenstaticdate');
317     $form->setType('date_limite', 'hiddenstaticdate');
318     $form->setType('service', 'selecthiddenstatic');
319    
320     // La date de réception ne peut être modifiée que par un
321     // utilisateur en ayant spécifiquement la permission
322     if($this->f->isAccredited('consultation_modifier_date_reception')) {
323     $form->setType('date_reception', 'date2');
324     } else {
325     $form->setType('date_reception', 'hiddenstaticdate');
326     }
327    
328     // Le marqueur lu/non lu ne peut être modifié que par un
329     // utilisateur en ayant spécifiquement la permission
330     if ($this->f->isAccredited('consultation_modifier_lu')) {
331     $form->setType('lu', 'checkbox');
332     } else {
333     $form->setType('lu', 'hidden');
334     }
335    
336     // Gestion du type du widget sur le champ fichier
337 nhaye 1683 if($this->getVal("fichier") == "" OR
338 fmichon 671 $this->f->isAccredited('consultation_modifier_fichier')) {
339     // Si il n'y a jamais eu de fichier enregistré ou que
340     // l'utilisateur a spécifiquement les droits pour modifier
341     // un fichier déjà enregistré alors on positionne un type
342     // de widget modifiable
343 nhaye 1683 if($this->retourformulaire == "demande_avis_encours") {
344     $form->setType('fichier', 'upload2');
345     } else {
346     $form->setType('fichier', 'upload');
347     }
348 fmichon 671 } else {
349     // Si non on affiche uniquement le nom du fichier
350 nhaye 1683 $form->setType('fichier', 'file');
351 fmichon 671 }
352    
353     // Modification layout : écran de retour d'avis permettant
354     // uniquement la saisie des trois champs : avis, motivation et fichier
355     if (!$this->f->isAccredited('consultation_consulter_autre_que_retour_avis')) {
356    
357     // On cache alors tous les champs que nous ne voulons pas voir
358 softime 2112 $form->setType('dossier_libelle', 'hidden');
359 fmichon 671 $form->setType('service', 'hidden');
360 nmeucci 2857 $form->setType('date_envoi', 'hiddendate');
361     $form->setType('date_retour', 'hiddendate');
362     $form->setType('date_reception', 'hiddendate');
363     $form->setType('date_limite', 'hiddendate');
364 nhaye 561 $form->setType('lu', 'hidden');
365 fmichon 671
366 fraynaud 20 }
367 vpihour 1784
368 fraynaud 20 }
369 nhaye 1895 // Mode supprimer
370     if ($maj == 2) {
371     $form->setType('fichier', 'filestatic');
372     }
373 nhaye 674 // MODE - CONSULTER
374     if ( $maj == 3 ) {
375 nhaye 1683 $form->setType('fichier', 'file');
376 nhaye 674 }
377 fmichon 671 //// On cache la clé primaire
378     //$form->setType('consultation', 'hidden');
379 fmichon 1730 //
380     if ($this->getParameter("retourformulaire") == "dossier"
381     || $this->getParameter("retourformulaire") == "dossier_instruction"
382     || $this->getParameter("retourformulaire") == "dossier_instruction_mes_encours"
383     || $this->getParameter("retourformulaire") == "dossier_instruction_tous_encours"
384     || $this->getParameter("retourformulaire") == "dossier_instruction_mes_clotures"
385     || $this->getParameter("retourformulaire") == "dossier_instruction_tous_clotures") {
386     //
387 softime 2112 $form->setType('dossier_libelle', 'hidden');
388 fmichon 1730 }
389 vpihour 1784
390     $form->setType('code_barres', 'hidden');
391 vpihour 1899
392     //Cache les champs pour la finalisation
393     $form->setType('om_fichier_consultation', 'hidden');
394     $form->setType('om_final_consultation', 'hidden');
395 fraynaud 20 }
396    
397 fmichon 1170 // Cette méthode permet de calculer la date limite en fonction de la date
398     // de réception et du délai de consultation du service consulté
399     function calculDateLimite() {
400 fraynaud 20 // mise a jour instruction avec evenement [return delay]
401 fmichon 1170 if ($this->valF["date_reception"] != "") {
402     //
403     $sql = " select delai from ".DB_PREFIXE."service ";
404     $sql .= " where service='".$this->valF["service"]."' ";
405     //
406     $delai = $this->db->getOne($sql);
407     $this->addToLog("triggerajouter(): db->getone(\"".$sql."\")", VERBOSE_MODE);
408     //
409 softime 2771 $this->valF["date_limite"] = $this->f->mois_date($this->valF["date_reception"], $delai);
410 fmichon 1170 //
411 nhaye 532 $this->addToMessage(_("delai")." ".
412 fraynaud 41 _("retour")." ".$delai." "._("mois")." -> ".
413 fmichon 1170 _("retour")." ".date("d/m/Y", strtotime($this->valF["date_limite"])));
414 fraynaud 41 }
415 fraynaud 20 }
416 fmichon 1170
417     // TRIGGER AVANT MODIFICATION DE DONNEES
418     // trigger before modification data
419     function triggerajouter($id,&$db,$val,$DEBUG) {
420     //
421     $this->calculDateLimite();
422 vpihour 1784
423     // Identifiant du type de courrier
424     $idTypeCourrier = '12';
425     $idCourrier = str_pad($this->valF["consultation"], 10, "0", STR_PAD_LEFT);
426     // Code barres
427     $this->valF["code_barres"] = $idTypeCourrier . $idCourrier;
428 fmichon 1170 }
429    
430     //
431     function triggermodifier($id,&$db,$val,$DEBUG) {
432     //
433     $this->calculDateLimite();
434     }
435    
436     //
437 nhaye 532 function triggerajouterapres($id,&$db,$val,$DEBUG) {
438    
439     // Verification de la demande de notif par mail
440 fmichon 1168 $sql= "SELECT abrege, libelle, notification_email, email FROM ".DB_PREFIXE.
441 nhaye 532 "service WHERE service ='".$this->valF['service']."'";
442     $res=$db->query($sql);
443     $notif = $res->fetchrow(DB_FETCHMODE_ASSOC);
444     if (database :: isError($sql))die($res->getMessage()."erreur ".$sql);
445     if ($notif['notification_email']=='t') {
446    
447     // Recuperation des infos du dossier
448 softime 2081 $sql= "SELECT dossier, terrain_adresse_voie_numero, terrain_adresse_voie, terrain_adresse_code_postal, terrain_adresse_localite
449 nhaye 532 FROM ".DB_PREFIXE."dossier WHERE dossier ='".$this->valF['dossier']."'";
450     $res=$db->query($sql);
451     $dossier = $res->fetchrow(DB_FETCHMODE_ASSOC);
452    
453     // Definition des parametres d'envoi du mail
454     $title=_("Consultation de services : dossier no")." ".$dossier['dossier'];
455     $corps=_("Votre service est consulte concernant le dossier no")." ".$dossier['dossier']."<br/>".
456 softime 2081 _("Il concerne le terrain situe a l'adresse :")." ".$dossier['terrain_adresse_voie_numero'].
457     " ".$dossier['terrain_adresse_voie']." ".$dossier['terrain_adresse_code_postal']." ".$dossier['terrain_adresse_localite']."<br/>".
458 fmichon 668 _("Vous pouvez y acceder et rendre votre avis a l'adresse")." <a href='".$this->f->getParameter('services_consultes_lien_interne').
459 nhaye 532 "scr/form.php?obj=consultation&action=3&idx=".$this->valF['consultation']."' >".
460 fmichon 668 _("Lien interne (services VDM)")."</a> "._("ou")." <a href='".$this->f->getParameter('services_consultes_lien_externe').
461 nhaye 532 "scr/form.php?obj=consultation&action=3&idx=".$this->valF['consultation']."' >".
462     _("Lien externe (hors VDM)")."</a>";
463     // Envoi du mail avec message de retour
464 softime 2084 if($this->f->sendMail(iconv("UTF-8", "CP1252", $title), iconv("UTF-8", "CP1252", $corps), iconv("UTF-8", "CP1252", $notif['email']))) {
465 fmichon 1168 $this->addToMessage(_("Envoi d'un mail de notification au service")." \"(".$notif['abrege'].") ".$notif["libelle"]."\"");
466 nhaye 532 } else {
467     $this->addToMessage(_("L'envoi du mail de notification a echoue"));
468     }
469     }
470    
471 fmichon 1005
472     // verification si envoi vers ERP est active
473     if ($this->f->getParameter('option_erp') != "") {
474     // s'il s'agit de la consultation ERP Secu, ERP Accessibilite, ou
475     // deenvoie un
476     // message a ERP
477     $dossier_erp = $this->getFromDB("SELECT erp FROM ".DB_PREFIXE.
478     "dossier WHERE dossier = '" .$this->valF['dossier'] . "'");
479 nhaye 1140 $dossier_nature = $this->getFromDB("SELECT dossier_autorisation_type_detaille.code FROM ".DB_PREFIXE.
480     "dossier
481     INNER JOIN ".DB_PREFIXE."dossier_autorisation
482     ON dossier.dossier_autorisation=dossier_autorisation.dossier_autorisation
483     INNER JOIN ".DB_PREFIXE."dossier_autorisation_type_detaille
484     ON dossier_autorisation.dossier_autorisation_type_detaille
485     = dossier_autorisation_type_detaille.dossier_autorisation_type_detaille
486     WHERE dossier = '" . $this->valF['dossier'] . "'");
487 fmichon 1005 if ($dossier_erp == 't'
488     && substr($dossier_nature, 0, 2) == $this->f->getParameter('erp_dossier_nature_pc')) {
489     // envoi du message "Demande d'instruction d'un dossier PC pour un ERP"
490     if (($this->valF['service'] == $this->f->getParameter('erp_service_accessibilite')
491     || $this->valF['service'] == $this->f->getParameter('erp_service_securite'))) {
492     $msgenque = new MessageEnqueuer();
493     $msgenque->setDossierInstructionIdentifier($this->valF['dossier']);
494     $msgenque->setConsultationIdentifier($this->valF['consultation']);
495 vpihour 2842 $return = $msgenque->enqueueMessage($msgenque::$ERP_DEMANDE_INSTRUCTION_PC);
496     //Si une erreur s'est produite on arrête le traitement et on
497     //retourne une erreur
498     if ($return !== 0){
499    
500     $this->addToMessage(_("Une erreur s'est produite lors de ".
501     "l'envoi du message au referentiel ERP. Merci de ".
502     "contacter votre administrateur"));
503     //Si c'est un problème de connexion vers rabbitMQ et AMQP
504     //On ne valide pas le formulaire
505     if ( $return === -3 ){
506     $this->addToMessage("<br/>"._("SAISIE NON ENREGISTREE")."<br/>");
507     $this->correct = false;
508     return false;
509     }
510     }
511     else {
512     $this->addToMessage(_("Le message a ete transmis au ".
513     "referentiel ERP."));
514     }
515 fmichon 1005 }
516    
517     // envoi du message "Consultation ERP pour conformite" en cas de creation de la
518     // consultation du service ERP Conformite
519     if ($this->valF['service'] == $this->f->getParameter('erp_service_conformite')) {
520     $msgenque = new MessageEnqueuer();
521     $msgenque->setDossierInstructionIdentifier($this->valF['dossier']);
522     $msgenque->setConsultationIdentifier($this->valF['consultation']);
523 vpihour 2842 $return = $msgenque->enqueueMessage($msgenque::$ERP_CONSULTATION_CONFORMITE);
524     //Si une erreur s'est produite on arrête le traitement et on
525     //retourne une erreur
526     if ($return !== 0){
527    
528     $this->addToMessage(_("Une erreur s'est produite lors de ".
529     "l'envoi du message au referentiel ERP. Merci de ".
530     "contacter votre administrateur"));
531     //Si c'est un problème de connexion vers rabbitMQ et AMQP
532     //On ne valide pas le formulaire
533     if ( $return === -3 ){
534     $this->addToMessage("<br/>"._("SAISIE NON ENREGISTREE")."<br/>");
535     $this->correct = false;
536     return false;
537     }
538     }
539     else {
540     $this->addToMessage(_("Le message a ete transmis au ".
541     "referentiel ERP."));
542     }
543 fmichon 1005 }
544 mlimic 936 }
545 fmichon 1005 } // fin de if($this->f->getParameter('option_erp'))
546 vpihour 1930
547     // Finalisation du document
548     $this->finaliserAjouter();
549 nhaye 532 }
550 mlimic 843
551 mlimic 936 /**
552     * Fait une requette sql pour extraire la valeur d'un champ, et retourne
553     * cette valeur
554     * @param string $sql La requete sql a executer
555     * @return La valeur du champs cherche, sinon NULL. En cas d'erreur de la BD
556     * l'execution s'arrete.
557     */
558     function getFromDB($sql) {
559     //$sql = "SELECT libelle FROM ".DB_PREFIXE."dossier WHERE dossier = '" . $dossier . "'";
560     $res = $this->db->limitquery($sql, 0, 1);
561 vpihour 1777 $this->f->addToLog("getDossierERPSpecification(): db->limitquery(\"".
562 mlimic 936 str_replace(",",", ",$sql)."\", 0, 1);", VERBOSE_MODE);
563     // Si une erreur survient on die
564     if (database::isError($res, true)) {
565     // Appel de la methode de recuperation des erreurs
566     $this->erreur_db($res->getDebugInfo(), $res->getMessage(), 'instruction');
567     }
568     // retourne la nature du dossier
569     while ($row =& $res->fetchRow()) {
570     return $row[0];
571     }
572     // la nature n'etait pas trouve, ce qui ne devrait pas se passer
573     return NULL;
574    
575     }
576    
577 fraynaud 20 // =============================================
578 vpihour 497 // Ajout du fielset
579     // Add fieldset
580     // =============================================
581 nhaye 569 function setLayout(&$form, $maj){
582 fmichon 671
583     // Modification layout : écran de retour d'avis permettant
584     // uniquement la saisie des trois champs : avis, motivation et fichier
585     if ($this->f->isAccredited('consultation_consulter_autre_que_retour_avis')) {
586    
587 nhaye 569 //Champs sur lequel s'ouvre le fieldset
588     $form->setBloc('dossier','D',"");
589     $form->setFieldset('dossier','D',_('Consultation'));
590    
591     //Champs sur lequel se ferme le fieldset
592     $form->setFieldset('date_envoi','F','');
593     $form->setBloc('date_envoi','F');
594 fmichon 671
595 nhaye 569 }
596 fmichon 671
597     // MODE - autre que AJOUTER alors on affiche un fieldset retour
598     // d'avis
599     if ($maj != 0) {
600    
601 nhaye 569 //Champs sur lequel s'ouvre le fieldset
602     $form->setBloc('date_reception','D',"");
603     $form->setFieldset('date_reception','D',_('Retour d\'avis'));
604 fmichon 671
605 nhaye 569 //Champs sur lequel se ferme le fieldset
606     $form->setFieldset('lu','F','');
607     $form->setBloc('lu','F');
608 fmichon 671
609 nhaye 569 }
610     }
611 nhaye 595
612     /** Surcharge de la methode retour afin de retourner sur la page de saisie de
613     * code barre si besoin
614     **/
615     function retour($premier = 0, $recherche = "", $tricol = "") {
616     $params ="obj=".get_class($this);
617     if($this->getParameter("retour")=="form") {
618     $params .= "&amp;idx=".$this->getParameter("idx");
619     $params .= "&amp;action=3";
620     }
621     $params .= "&amp;premier=".$this->getParameter("premier");
622     $params .= "&amp;tricol=".$this->getParameter("tricol");
623     $params .= "&amp;recherche=".$this->getParameter("recherche");
624     $params .= "&amp;selectioncol=".$this->getParameter("selectioncol");
625     $params .= "&amp;advs_id=".$this->getParameter("advs_id");
626     $params .= "&amp;valide=".$this->getParameter("valide");
627     echo "\n<a class=\"retour\" ";
628     echo "href=\"";
629     //
630    
631     if($this->getParameter("retour")=="form" AND !($this->getParameter("validation")>0 AND $this->getParameter("maj")==2 AND $this->correct)) {
632     echo "form.php?".$params;
633 fmichon 1666 } elseif($this->getParameter("retour")=="suivi_retours_de_consultation") {
634     echo "../app/suivi_retours_de_consultation.php";
635 nhaye 595 } else {
636     echo "tab.php?".$params;
637     }
638     //
639     echo "\"";
640     echo ">";
641     //
642     echo _("Retour");
643     //
644     echo "</a>\n";
645     }
646 fmichon 938
647     /**
648 nhaye 802 * Surcharge du bouton retour pour popup
649     */
650     function retoursousformulaire($idxformulaire, $retourformulaire, $val,
651     $objsf, $premiersf, $tricolsf, $validation,
652     $idx, $maj, $retour) {
653     if($retourformulaire === "demande_avis_encours") {
654     echo "\n<a class=\"retour\" ";
655     echo "href=\"";
656     echo "#";
657     echo "\" ";
658     echo ">";
659     //
660     echo _("Retour");
661     //
662     echo "</a>\n";
663     } else {
664     parent::retoursousformulaire($idxformulaire, $retourformulaire, $val,
665     $objsf, $premiersf, $tricolsf, $validation,
666     $idx, $maj, $retour);
667     }
668     }
669 vpihour 1784
670 vpihour 1881 /**
671     * Ajout des contraintes spécifiques pour l'ajout d'un fichier en retour de
672     * consultation
673     */
674     function setSelect(&$form, $maj,&$db,$debug) {
675 atreal 2731 if(file_exists ("../sql/".$db->phptype."/".$this->table.".form.inc.php"))
676     include ("../sql/".$db->phptype."/".$this->table.".form.inc.php");
677     elseif(file_exists ("../sql/".$db->phptype."/".$this->table.".form.inc"))
678     include ("../sql/".$db->phptype."/".$this->table.".form.inc");
679    
680     // avis_consultation
681     $this->init_select($form, $db, $maj, $debug, "avis_consultation",
682     $sql_avis_consultation, $sql_avis_consultation_by_id, true);
683    
684     // service
685     $this->init_select($form, $db, $maj, $debug, "service",
686     $sql_service, $sql_service_by_id, true);
687    
688 vpihour 1881 //Seulement dans le cas d'un retour d'avis
689     if($this->retourformulaire == "demande_avis_encours") {
690    
691     //Tableau des contraintes spécifiques
692     $params = array(
693     "constraint" => array(
694     "size_max" => 2,
695     "extension" => ".pdf"
696     ),
697     );
698    
699     $form->setSelect("fichier", $params);
700     }
701     }
702 vpihour 2603
703 vpihour 1930 /**
704     * Finalisation du document lors de l'ajout d'une consultation
705     */
706     function finaliserAjouter(){
707    
708     //Génération du PDF
709     $_GET['output'] = "string";
710     $_GET['obj'] = "consultation";
711     $_GET['idx'] = $this->valF[$this->clePrimaire];
712     $f = $this->f;
713     include '../app/pdf_consultation.php';
714    
715     //Métadonnées du document
716     $metadata = array(
717     'filename' => 'consultation_'.$idx.'.pdf',
718     'mimetype' => 'application/pdf',
719     'size' => strlen($pdf_output)
720     );
721    
722 nhaye 1935 // Récupération des métadonnées calculées après validation
723 nhaye 1938 $spe_metadata = $this->getMetadata("om_fichier_consultation");
724 nhaye 1935
725     $metadata = array_merge($metadata, $spe_metadata);
726    
727 vpihour 1930 //On ajoute le document et on récupère son uid
728     $uid = $this->f->storage->create($pdf_output, $metadata);
729    
730     //Mise à jour des données
731 vpihour 2789 if ( $uid != '' && $uid != 'OP_FAILURE' ){
732 vpihour 1930 // Logger
733     $this->addToLog("finaliserAjouter() - begin", EXTRA_VERBOSE_MODE);
734    
735     $valF = array(
736     "om_final_consultation"=> TRUE,
737     "om_fichier_consultation"=>$uid);
738    
739     // Execution de la requête de modification des donnees de l'attribut
740     // valF de l'objet dans l'attribut table de l'objet
741     $res = $this->db->autoExecute(DB_PREFIXE.$this->table, $valF,
742     DB_AUTOQUERY_UPDATE, $this->getCle($idx));
743     $this->addToLog("finaliserAjouter() : db->autoExecute(\"".DB_PREFIXE.$this->table."\", ".print_r($valF, true).", DB_AUTOQUERY_UPDATE, \"".$this->getCle($idx)."\")", VERBOSE_MODE);
744     // Si une erreur survient
745     if (database::isError($res)) {
746     // Appel de la methode de recuperation des erreurs
747     $this->erreur_db($res->getDebugInfo(), $res->getMessage(), '');
748     } else {
749     // Log
750     $this->addToLog(_("Requete executee"), VERBOSE_MODE);
751     // Log
752     $message = _("Enregistrement")."&nbsp;".$idx."&nbsp;";
753     $message .= _("de la table")."&nbsp;\"".$this->table."\"&nbsp;";
754     $message .= "[&nbsp;".$this->db->affectedRows()."&nbsp;";
755     $message .= _("enregistrement(s) mis a jour")."&nbsp;]";
756     $this->addToLog($message, VERBOSE_MODE);
757     }
758     }
759     }
760 nhaye 1935
761 vpihour 2603 /**
762     * Finalisation des documents.
763     * @param string $champ champ du fichier à finaliser
764     * @param booleen $status permet de définir si on finalise ou définalise
765     * @param string $sousform permet de savoir si se trouve dans un sousformulaire (passé au javascript)
766     */
767     function finaliser($champ = '', $status, $sousform, $retourformulaire) {
768 nhaye 1935
769 vpihour 2603 // Si on finalise le document
770     if ($status == 1) {
771    
772     // Génération du PDF
773     $_GET['output'] = "string";
774     $f = $this->f;
775     include '../app/pdf_consultation.php';
776    
777     // Métadonnées du document
778     $metadata = array(
779     'filename' => 'consultation_'.$idx.'.pdf',
780     'mimetype' => 'application/pdf',
781     'size' => strlen($pdf_output)
782     );
783    
784     // Récupération des métadonnées calculées après validation
785     $spe_metadata = $this->getMetadata("om_fichier_consultation");
786    
787     $metadata = array_merge($metadata, $spe_metadata);
788    
789     // Si le document a déjà été finalisé
790     if ( $this->getVal("om_fichier_consultation") != '' ){
791    
792     // Met à jour le document mais pas son uid
793     $uid = $this->f->storage->update(
794     $this->getVal("om_fichier_consultation"), $pdf_output, $metadata);
795     }
796     // Sinon, ajoute le document et récupère son uid
797     else {
798    
799     // Stockage du PDF
800     $uid = $this->f->storage->create($pdf_output, $metadata);
801     }
802    
803     }
804     //
805     else {
806    
807     //Récupération de l'uid du document finalisé
808     $uid = $this->getVal("om_fichier_consultation");
809    
810     //On dé-finalise avant de finaliser
811     if ( $uid == '' || $uid == 'OP_FAILURE' ){
812     return -1;
813     }
814     }
815    
816     //Mise à jour des données
817 vpihour 2789 if ($uid != '' && $uid != 'OP_FAILURE') {
818 vpihour 2603
819     // Logger
820     $this->addToLog("finaliser() - begin", EXTRA_VERBOSE_MODE);
821    
822     // Recuperation de la valeur de la cle primaire de l'objet
823     if ($this->getVal($this->clePrimaire) != '') {
824     //
825     $id = $this->getVal($this->clePrimaire);
826     }
827     else {
828     //
829     $id=$this->id;
830     }
831    
832     $actions = array();
833    
834     // Tableau contenant le lien vers le PDF et lien du portlet pour la
835     // mise à jour de l'interface
836     if ($status == 0) {
837    
838     // Lien pour ouvrir le PDF
839     $lien = '../app/pdf_consultation.php?idx='.$id;
840    
841     //
842     if ($this->f->isAccredited('consultation') ||
843     $this->f->isAccredited('consultation_modifier')) {
844    
845     $actions["modifier"] = ($sousform!='')?
846     '<li><a href="#" onclick="ajaxIt(\'consultation\',
847     \'../scr/sousform.php?obj=consultation&amp;action=1&amp;idx='.
848     $this->getVal($this->clePrimaire).
849     '&amp;premiersf=0&amp;trisf=&amp;retourformulaire='.$retourformulaire.'&amp;idxformulaire='.
850     $this->getVal("dossier").
851     '&amp;retour=form\');">
852     <span class="om-prev-icon om-icon-16 edit-16" title="'.
853     _('Modifier').'">'.
854     _('Modifier').
855     '</span></a></li>':
856     '<li>
857     <a href="form.php?obj=consultation&amp;action=1'.'&amp;idx='.
858     $this->getVal($this->clePrimaire).
859     '&amp;premier=&amp;advs_id=&amp;recherche=&amp;tricol=&amp;selectioncol=&amp;valide=&amp;retour=form">
860     <span class="om-prev-icon om-icon-16 edit-16" title="'.
861     _('Modifier').'">'.
862     _('Modifier').
863     '</span></a></li>';
864     }
865    
866     //Si l'utilisateur a le droit de supprimer l'objet
867     if ( $this->f->isAccredited('consultation') ||
868     $this->f->isAccredited('consultation_supprimer') ){
869    
870     $actions["supprimer"] = ($sousform!='')?
871     '<li><a href="#" onclick="ajaxIt(\'consultation\',
872     \'../scr/sousform.php?obj=consultation&amp;action=2&amp;idx='.
873     $this->getVal($this->clePrimaire).
874     '&amp;premiersf=0&amp;trisf=&amp;retourformulaire='.$retourformulaire.'&amp;idxformulaire='.
875     $this->getVal("dossier").
876     '&amp;retour=form\');">
877     <span class="om-prev-icon om-icon-16 delete-16" title="'.
878     _('Supprimer').'">'.
879     _('Supprimer').
880     '</span></a></li>':
881     '<li>
882     <a href="form.php?obj=consultation&amp;action=1'.'&amp;idx='.
883     $this->getVal($this->clePrimaire).
884     '&amp;premier=&amp;advs_id=&amp;recherche=&amp;tricol=&amp;selectioncol=&amp;valide=&amp;retour=form">
885     <span class="om-prev-icon om-icon-16 delete-16" title="'.
886     _('Supprimer').'">'.
887     _('Supprimer').
888     '</span></a></li>';
889     }
890     }
891     else {
892    
893     // Lien permettant d'afficher le PDF
894     $lien = '../spg/file.php?obj=consultation&'.
895     'champ=om_fichier_consultation&id='.$id;
896     }
897    
898     //
899     $retour = array(
900     "portlet"=> "<a href=\"#\" onclick=\"finalizeDocument(".
901     $id.", 'consultation', '".$sousform."', ".(($status==0)?1:0).")\">
902     <span class=\"om-prev-icon om-icon-16 om-icon-fix "
903     .(($status==1)?"de":"")."finalise\" title=\"".
904     (($status==1)?_("Reprendre la redaction du document"):_("Finaliser le document"))."\">".
905     (($status==1)?_("Reprendre la redaction du document"):_("Finaliser le document"))."</span>
906     </a>",
907     "pdf" => $lien,
908     "actions" => $actions
909     );
910    
911     foreach ($this->champs as $key => $value) {
912     //
913     $val[$value] = $this->val[$key];
914     }
915    
916     $this->setvalF($val);
917    
918     // Verification de la validite des donnees
919     $this->verifier($this->val, $this->db, DEBUG);
920     // Verification du verrou
921     $this->testverrou();
922     // Si les verifications precedentes sont correctes, on procede a
923     // la modification, sinon on ne fait rien et on retourne une erreur
924     if ($this->correct) {
925    
926     // Execution du trigger 'before' specifique au MODE 'update'
927     $this->triggermodifier( $id, $this->db, $this->val, DEBUG);
928    
929     //
930     $valF = '';
931     $valF["om_final_consultation"] = ($status==1)?TRUE:FALSE;
932     $valF["om_fichier_consultation"] = $uid;
933    
934     // Execution de la requête de modification des donnees de l'attribut
935     // valF de l'objet dans l'attribut table de l'objet
936     $res = $this->db->autoExecute(DB_PREFIXE.$this->table, $valF,
937     DB_AUTOQUERY_UPDATE, $this->getCle($id));
938     $this->addToLog("finaliser() : db->autoExecute(\"".DB_PREFIXE.$this->table."\", ".print_r($valF, true).", DB_AUTOQUERY_UPDATE, \"".$this->getCle($id)."\")", VERBOSE_MODE);
939    
940     // Si une erreur survient
941     if (database::isError($res)) {
942    
943     // Appel de la methode de recuperation des erreurs
944     $this->erreur_db($res->getDebugInfo(), $res->getMessage(), '');
945     } else {
946    
947     // Log
948     $this->addToLog(_("Requete executee"), VERBOSE_MODE);
949     // Log
950     $message = _("Enregistrement")."&nbsp;".$id."&nbsp;";
951     $message .= _("de la table")."&nbsp;\"".$this->table."\"&nbsp;";
952     $message .= "[&nbsp;".$this->db->affectedRows()."&nbsp;";
953     $message .= _("enregistrement(s) mis a jour")."&nbsp;]";
954     $this->addToLog($message, VERBOSE_MODE);
955     // Mise en place du verrou pour ne pas finaliser plusieurs fois
956     // le meme document
957     $this->verrouille();
958     // Execution du trigger 'after' specifique au MODE 'update'
959     $this->triggermodifierapres($id, $this->db, $this->val, DEBUG);
960    
961     return $retour;
962     }
963     //
964     } else {
965    
966     // Message d'echec (saut d'une ligne supplementaire avant le
967     // message pour qu'il soit mis en evidence)
968     $this->addToLog(_("Finalisation non enregistree"));
969     return -1;
970     }
971     }
972     // Si le document n'a pas été stocké
973     else{
974    
975     return -1;
976     }
977     }
978    
979    
980 nhaye 1935 /**
981     * Récupération du numéro de dossier d'instruction à ajouter aux métadonnées
982 nhaye 1949 * @return string numéro de dossier d'instruction
983 nhaye 1935 */
984     protected function getDossier() {
985     if(empty($this->specificMetadata)) {
986     $this->getSpecificMetadata();
987     }
988     return $this->specificMetadata->dossier;
989     }
990     /**
991 softime 2016 * Récupération la version du dossier d'instruction à ajouter aux métadonnées
992     * @return int Version
993     */
994     protected function getDossierVersion() {
995     if(empty($this->specificMetadata)) {
996     $this->getSpecificMetadata();
997     }
998     return $this->specificMetadata->version;
999     }
1000     /**
1001 nhaye 1935 * Récupération du numéro de dossier d'autorisation à ajouter aux métadonnées
1002 nhaye 1949 * @return string numéro de dossier d'autorisation
1003 nhaye 1935 */
1004 softime 2025 protected function getNumDemandeAutor() {
1005 nhaye 1935 if(empty($this->specificMetadata)) {
1006     $this->getSpecificMetadata();
1007     }
1008     return $this->specificMetadata->dossier_autorisation;
1009     }
1010     /**
1011     * Récupération de la date de demande initiale du dossier à ajouter aux métadonnées
1012 nhaye 1949 * @return date demande initiale
1013 nhaye 1935 */
1014 softime 2025 protected function getAnneemoisDemandeAutor() {
1015 nhaye 1935 if(empty($this->specificMetadata)) {
1016     $this->getSpecificMetadata();
1017     }
1018     return $this->specificMetadata->date_demande_initiale;
1019     }
1020     /**
1021     * Récupération du type de dossier d'instruction à ajouter aux métadonnées
1022 nhaye 1949 * @return string type de dossier d'instruction
1023 nhaye 1935 */
1024 softime 2025 protected function getTypeInstruction() {
1025 nhaye 1935 if(empty($this->specificMetadata)) {
1026     $this->getSpecificMetadata();
1027     }
1028     return $this->specificMetadata->dossier_instruction_type;
1029     }
1030     /**
1031     * Récupération du statut du dossier d'autorisation à ajouter aux métadonnées
1032 nhaye 1949 * @return string avis
1033 nhaye 1935 */
1034 softime 2025 protected function getStatutAutorisation() {
1035 nhaye 1935 if(empty($this->specificMetadata)) {
1036     $this->getSpecificMetadata();
1037     }
1038     return $this->specificMetadata->statut;
1039     }
1040     /**
1041     * Récupération du type de dossier d'autorisation à ajouter aux métadonnées
1042 nhaye 1949 * @return string type d'autorisation
1043 nhaye 1935 */
1044 softime 2025 protected function getTypeAutorisation() {
1045 nhaye 1935 if(empty($this->specificMetadata)) {
1046     $this->getSpecificMetadata();
1047     }
1048     return $this->specificMetadata->dossier_autorisation_type;
1049     }
1050     /**
1051     * Récupération de la date d'ajout de document à ajouter aux métadonnées
1052 nhaye 1949 * @return date de l'évènement
1053 nhaye 1935 */
1054 softime 2025 protected function getDateEvenementDocument() {
1055 softime 2046 return date("Y-m-d");
1056 nhaye 1935 }
1057     /**
1058     * Récupération du groupe d'instruction à ajouter aux métadonnées
1059     * @return string Groupe d'instruction
1060     */
1061     protected function getGroupeInstruction() {
1062     if(empty($this->specificMetadata)) {
1063     $this->getSpecificMetadata();
1064     }
1065     return $this->specificMetadata->groupe_instruction;
1066     }
1067 softime 2002 /**
1068     * Récupération du type de document à ajouter aux métadonnées
1069     * @return string Type de document
1070     */
1071 softime 2025 protected function getTitle() {
1072 softime 2002 if ($this->retourformulaire == "demande_avis_encours") {
1073     return 'Retour de consultation';
1074     } else {
1075     return 'Demande de consultation';
1076     }
1077     }
1078 nhaye 1935
1079     /**
1080     * Cette méthode permet de stocker en attribut toutes les métadonnées
1081     * nécessaire à l'ajout d'un document.
1082     */
1083     public function getSpecificMetadata() {
1084     if (isset($this->valF["dossier"]) AND $this->valF["dossier"] != "") {
1085     $dossier = $this->valF["dossier"];
1086     } else {
1087     $dossier = $this->getVal("dossier");
1088     }
1089     //Requête pour récupérer les informations essentiels sur le dossier d'instruction
1090     $sql = "SELECT dossier.dossier as dossier,
1091     dossier_autorisation.dossier_autorisation as dossier_autorisation,
1092     to_char(dossier.date_demande, 'YYYY/MM') as date_demande_initiale,
1093     dossier_instruction_type.code as dossier_instruction_type,
1094     etat_dossier_autorisation.libelle as statut,
1095     dossier_autorisation_type.code as dossier_autorisation_type,
1096     groupe.code as groupe_instruction
1097     FROM ".DB_PREFIXE."dossier
1098     LEFT JOIN ".DB_PREFIXE."dossier_instruction_type
1099     ON dossier.dossier_instruction_type = dossier_instruction_type.dossier_instruction_type
1100     LEFT JOIN ".DB_PREFIXE."dossier_autorisation
1101     ON dossier.dossier_autorisation = dossier_autorisation.dossier_autorisation
1102     LEFT JOIN ".DB_PREFIXE."etat_dossier_autorisation
1103     ON dossier_autorisation.etat_dossier_autorisation = etat_dossier_autorisation.etat_dossier_autorisation
1104     LEFT JOIN ".DB_PREFIXE."dossier_autorisation_type_detaille
1105     ON dossier_autorisation.dossier_autorisation_type_detaille = dossier_autorisation_type_detaille.dossier_autorisation_type_detaille
1106     LEFT JOIN ".DB_PREFIXE."dossier_autorisation_type
1107     ON dossier_autorisation_type_detaille.dossier_autorisation_type = dossier_autorisation_type.dossier_autorisation_type
1108     LEFT JOIN ".DB_PREFIXE."groupe
1109     ON dossier_autorisation_type.groupe = groupe.groupe
1110     WHERE dossier.dossier = '".$dossier."'";
1111     $res = $this->db->query($sql);
1112     $this->f->addToLog("obj/document_numerise.class.php : db->query(".$sql.")", VERBOSE_MODE);
1113     if ( database::isError($res)){
1114     die();
1115     }
1116    
1117     //Le résultat est récupéré dans un objet
1118     $row =& $res->fetchRow(DB_FETCHMODE_OBJECT);
1119    
1120     //Si il y a un résultat
1121     if ($row !== null) {
1122 vpihour 2119
1123     //Génération du numéro de version
1124     $sql = "SELECT
1125     count(*)
1126     FROM
1127     ".DB_PREFIXE."dossier
1128     LEFT JOIN
1129     ".DB_PREFIXE."dossier_autorisation
1130     ON
1131     dossier_autorisation.dossier_autorisation = dossier.dossier_autorisation
1132     LEFT JOIN
1133     ".DB_PREFIXE."dossier_instruction_type
1134     ON
1135     dossier_instruction_type.dossier_instruction_type = dossier.dossier_instruction_type
1136     WHERE
1137 softime 2120 dossier_autorisation.dossier_autorisation = '".$row->dossier_autorisation."'
1138 vpihour 2119 AND
1139 softime 2120 dossier_instruction_type.code = '".$row->dossier_instruction_type."'";
1140     $row->version = $this->db->getOne($sql);
1141 vpihour 2119 $this->f->addToLog("getInfosForFoldername(): db->getOne(\"".$sql."\")", VERBOSE_MODE);
1142 softime 2120 if ( database::isError($row->version)){
1143     $this->f->addToError("", $row->version, $row->version);
1144 vpihour 2119 return false;
1145     }
1146    
1147     //Formatage du numéro de version
1148 softime 2120 $row->version = str_pad($row->version, 2, "0", STR_PAD_LEFT);
1149 nhaye 1935
1150     //Alors on créé l'objet dossier_instruction
1151     $this->specificMetadata = $row;
1152    
1153     }
1154     }
1155 softime 2112
1156 fraynaud 3 }// fin classe
1157 vpihour 2603 ?>

Properties

Name Value
svn:keywords Id

[email protected]
ViewVC Help
Powered by ViewVC 1.1.26