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

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

Parent Directory Parent Directory | Revision Log Revision Log


Revision 1005 - (show annotations)
Thu Dec 6 15:48:07 2012 UTC (12 years, 2 months ago) by fmichon
File size: 22005 byte(s)
Merge de la branche 3.2.x pour la reprise du développement dans le trunk

1 <?php
2 //$Id$
3 //gen openMairie le 10/02/2011 20:32
4 require_once ("../gen/obj/consultation.class.php");
5 require_once("../services/outgoing/messageenqueuer.php");
6
7 class consultation extends consultation_gen {
8
9 function consultation($id,&$db,$debug) {
10 $this->constructeur($id,$db,$debug);
11 }// fin constructeur
12
13 // {{{ Gestion de la confidentialité des données spécifiques
14
15 /**
16 * Surcharge pour gérer les actions disponibles dans le portlet
17 */
18 function checkAccessibility() {
19 //
20 parent::checkAccessibility();
21 // Si l'utilisateur est un intructeur qui en correspond pas à la
22 // division du dossier
23 if ($this->f->isUserInstructeur()
24 && isset($this->f->om_utilisateur["division"])
25 && $this->f->om_utilisateur["division"] != $this->getDivisionFromDossier()) {
26 //
27 $this->actions_sup = array();
28 $this->setParameter("actions", array());
29 }
30 // Si une action 'lu' est présente et que le champ lu est à true
31 // on supprime l'action
32 if (isset($this->actions_sup["lu"])
33 && isset($this->val[array_search("lu", $this->champs)])
34 && $this->val[array_search("lu", $this->champs)]== "t") {
35 unset($this->actions_sup["lu"]);
36 }
37 }
38
39 /**
40 * Cette methode est à surcharger elle permet de tester dans chaque classe
41 * des droits des droits spécifiques en fonction des données
42 */
43 function canAccess() {
44 // Si l'utilisateur est un utilisateur de service externe
45 // on vérifie qu'il peut accéder à la consultation
46 if ($this->f->isUserServiceExt()) {
47 // On compare l'id du service de la consultation
48 // aux id des services de utilisateur connecté
49 foreach($this->f->om_utilisateur['service'] as $service) {
50 if($this->val[array_search("service",$this->champs)]===$service['service']) {
51 return true;
52 }
53 }
54 return false;
55 }
56 // Si l'utilisateur est un intructeur qui ne correspond pas à la
57 // division du dossier
58 if ($this->f->isUserInstructeur()
59 && $this->f->om_utilisateur["division"] != $this->getDivisionFromDossier()
60 && $this->getParameter("maj") != 3) {
61 //
62 return false;
63 }
64 //
65 return true;
66 }
67
68 /**
69 * Cette méthode permet de récupérer la division d'un dossier
70 */
71 function getDivisionFromDossier() {
72 //
73 if (!isset($this->val[array_search("dossier", $this->champs)])) {
74 return NULL;
75 }
76 //
77 $sql = "select division from ".DB_PREFIXE."dossier ";
78 $sql .= " where dossier='".$this->val[array_search("dossier", $this->champs)]."'";
79 //
80 $division = $this->db->getOne($sql);
81 $this->addToLog("getDivisionFromDossier(): db->getone(\"".$sql."\")", VERBOSE_MODE);
82 database::isError($division);
83 //
84 return $division;
85 }
86
87 // }}}
88
89 function setValsousformulaire(&$form,$maj,$validation,$idxformulaire,$retourformulaire,$typeformulaire){
90 if ($validation==0) {
91 if ($maj == 0){
92 $form->setVal("dossier", $idxformulaire);
93 $form->setVal("date_envoi",date('d/m/Y'));
94 }
95 if($maj == 1) {
96 if($this->f->isAccredited('consultation_retour_avis_suivi') OR
97 $this->f->isAccredited('consultation_retour_avis_service')) {
98 $form->setVal("date_retour",date('d/m/Y'));
99 }
100 }
101 }
102 }
103
104 function setVal(&$form, $maj, $validation, &$db) {
105 if($maj == 1) {
106 $form->setVal("date_retour",date('d/m/Y'));
107 }
108 }
109
110 function setvalF($val) {
111 parent::setValF($val);
112 if($this->getParameter('maj')==0) {
113 $this->valF["date_reception"]=$this->valF["date_envoi"];
114 }
115
116 // Si un retour d'avis est modifie on passe "lu" a false
117 if($this->getParameter('maj')==1 AND (
118 $this->val[array_search("avis_consultation",$this->champs)] != $val["avis_consultation"] OR
119 $this->val[array_search("date_retour",$this->champs)] != $val["date_retour"] OR
120 $this->val[array_search("motivation",$this->champs)] != $val["motivation"] OR
121 $this->val[array_search("fichier",$this->champs)] != $val["fichier"])
122 ) {
123 $this->valF["lu"]=false;
124 }
125 }
126
127 function verifier($val, &$db, $DEBUG) {
128 parent::verifier($val, $db, $DEBUG);
129 // Si le fichier envoye est different de l'existant
130 if (isset($this->val[array_search("fichier",$this->champs)])
131 && $this->val[array_search("fichier",$this->champs)] != $val["fichier"]
132 && $this->valF['fichier']!="") {
133 // Si le fichier existe dans tmp
134 if(file_exists("../tmp/".$this->valF['fichier'])) {
135 $contents=file_get_contents("../tmp/".$this->valF['fichier']);
136 // On essaye de l'enregistrer
137 $res = $this->f->storeDecisionFile($contents, $this->valF['fichier'],
138 $this->valF['dossier'],
139 'consultation_'.$this->valF['consultation']."_");
140 // Si l'enregistrement s'est bien deroule
141 // on supprime le fichier dans tmp
142 // on met a jour valF avec le nouveau nom du fichier
143 if($res===true){
144 $this->addToMessage(_("Sauvegarde du fichier reussi"));
145 unlink("../tmp/".$this->valF['fichier']);
146 $this->valF['fichier']='consultation_'.$this->valF['consultation']."_".$this->valF['fichier'];
147 // Sinon on supprime le fichier dans tmp
148 // on reinitialise le nom du fichier a l'ancienne valeur
149 } else {
150 $this->correct = false;
151 $this->addToMessage($res);
152 unlink("../tmp/".$this->valF['fichier']);
153 $this->valF['fichier']=$this->val[array_search("fichier",$this->champs)];
154 }
155 }
156 }
157 }
158
159 function setType(&$form,$maj) {
160 // Appel du parent
161 parent::setType($form,$maj);
162 // MODE - AJOUTER
163 if ($maj == 0) {
164 // On cache alors tous les champs que nous ne voulons pas voir
165 // apparaître dans le formulaire d'ajout (principalement les
166 // informations sur le retour d'avis)
167 $form->setType('date_retour', 'hidden');
168 $form->setType('date_reception', 'hidden');
169 $form->setType('date_limite', 'hidden');
170 $form->setType('avis_consultation', 'hidden');
171 $form->setType('motivation', 'hidden');
172 $form->setType('fichier', 'hidden');
173 $form->setType('lu', 'hidden');
174 // On permet la modification de certains champs
175 $form->setType('dossier', 'hiddenstatic');
176 $form->setType('service', 'select');
177 $form->setType('date_envoi', 'date2');
178 }
179 // MODE - MODIFIER
180 if ($maj == 1) {
181
182 // On affiche en statique les informations qui ne sont plus
183 // modifiables
184 $form->setType('dossier', 'hiddenstatic');
185 $form->setType('date_envoi', 'hiddenstaticdate');
186 $form->setType('date_limite', 'hiddenstaticdate');
187 $form->setType('service', 'selecthiddenstatic');
188
189 // La date de réception ne peut être modifiée que par un
190 // utilisateur en ayant spécifiquement la permission
191 if($this->f->isAccredited('consultation_modifier_date_reception')) {
192 $form->setType('date_reception', 'date2');
193 } else {
194 $form->setType('date_reception', 'hiddenstaticdate');
195 }
196
197 // Le marqueur lu/non lu ne peut être modifié que par un
198 // utilisateur en ayant spécifiquement la permission
199 if ($this->f->isAccredited('consultation_modifier_lu')) {
200 $form->setType('lu', 'checkbox');
201 } else {
202 $form->setType('lu', 'hidden');
203 }
204
205 // Gestion du type du widget sur le champ fichier
206 if($this->val[array_search("fichier",$this->champs)]=="" OR
207 $this->f->isAccredited('consultation_modifier_fichier')) {
208 // Si il n'y a jamais eu de fichier enregistré ou que
209 // l'utilisateur a spécifiquement les droits pour modifier
210 // un fichier déjà enregistré alors on positionne un type
211 // de widget modifiable
212 $form->setType('fichier', 'tmpUpload');
213 } else {
214 // Si non on affiche uniquement le nom du fichier
215 $form->setType('fichier', 'tmpUploadStatic');
216 }
217
218 // Modification layout : écran de retour d'avis permettant
219 // uniquement la saisie des trois champs : avis, motivation et fichier
220 if (!$this->f->isAccredited('consultation_consulter_autre_que_retour_avis')) {
221
222 // On cache alors tous les champs que nous ne voulons pas voir
223 $form->setType('dossier', 'hidden');
224 $form->setType('service', 'hidden');
225 $form->setType('date_envoi', 'hidden');
226 $form->setType('date_retour', 'hidden');
227 $form->setType('date_reception', 'hidden');
228 $form->setType('date_limite', 'hidden');
229 $form->setType('lu', 'hidden');
230
231 }
232
233 }
234 // MODE - CONSULTER
235 if ( $maj == 3 ) {
236 $form->setType('fichier', 'tmpUploadStatic');
237 }
238 //// On cache la clé primaire
239 //$form->setType('consultation', 'hidden');
240 }
241
242 // TRIGGER AVANT MODIFICATION DE DONNEES
243 // trigger before modification data
244 function triggerajouter($id,&$db,$val,$DEBUG) {
245 // mise a jour instruction avec evenement [return delay]
246 if ($this->valF['date_envoi']!=""){
247 $sql= "select delai from ".DB_PREFIXE."service where service ='".$this->valF['service']."'";
248 $delai = $db->getOne($sql);
249 $this->valF['date_limite'] = $this->moisdate($this->valF['date_envoi'],$delai);
250 $this->addToMessage(_("delai")." ".
251 _("retour")." ".$delai." "._("mois")." -> ".
252 _("retour")." ".$this->valF['date_limite']."<br>");
253 $this->valF['lu'] = true;
254 }
255
256 }
257
258 function triggerajouterapres($id,&$db,$val,$DEBUG) {
259
260 // Verification de la demande de notif par mail
261 $sql= "SELECT abrege, notification_email, email FROM ".DB_PREFIXE.
262 "service WHERE service ='".$this->valF['service']."'";
263 $res=$db->query($sql);
264 $notif = $res->fetchrow(DB_FETCHMODE_ASSOC);
265 if (database :: isError($sql))die($res->getMessage()."erreur ".$sql);
266 if ($notif['notification_email']=='t') {
267
268 // Recuperation des infos du dossier
269 $sql= "SELECT dossier, terrain_adresse, terrain_adresse_complement, terrain_cp, terrain_ville
270 FROM ".DB_PREFIXE."dossier WHERE dossier ='".$this->valF['dossier']."'";
271 $res=$db->query($sql);
272 $dossier = $res->fetchrow(DB_FETCHMODE_ASSOC);
273
274 // Definition des parametres d'envoi du mail
275 $title=_("Consultation de services : dossier no")." ".$dossier['dossier'];
276 $corps=_("Votre service est consulte concernant le dossier no")." ".$dossier['dossier']."<br/>".
277 _("Il concerne le terrain situe a l'adresse :")." ".utf8_decode($dossier['terrain_adresse']).
278 " ".utf8_decode($dossier['terrain_adresse_complement'])." ".utf8_decode($dossier['terrain_cp'])." ".$dossier['terrain_ville']."<br/>".
279 _("Vous pouvez y acceder et rendre votre avis a l'adresse")." <a href='".$this->f->getParameter('services_consultes_lien_interne').
280 "scr/form.php?obj=consultation&action=3&idx=".$this->valF['consultation']."' >".
281 _("Lien interne (services VDM)")."</a> "._("ou")." <a href='".$this->f->getParameter('services_consultes_lien_externe').
282 "scr/form.php?obj=consultation&action=3&idx=".$this->valF['consultation']."' >".
283 _("Lien externe (hors VDM)")."</a>";
284 // Envoi du mail avec message de retour
285 if($this->f->sendMail($title, $corps, $notif['email'])) {
286 $this->addToMessage(_("Envoi d'un mail de notification au service")." ".$notif['abrege']);
287 } else {
288 $this->addToMessage(_("L'envoi du mail de notification a echoue"));
289 }
290 }
291
292
293 // verification si envoi vers ERP est active
294 if ($this->f->getParameter('option_erp') != "") {
295 // s'il s'agit de la consultation ERP Secu, ERP Accessibilite, ou
296 // deenvoie un
297 // message a ERP
298 $dossier_erp = $this->getFromDB("SELECT erp FROM ".DB_PREFIXE.
299 "dossier WHERE dossier = '" .$this->valF['dossier'] . "'");
300 $dossier_nature = $this->getFromDB("SELECT nature FROM ".DB_PREFIXE.
301 "dossier WHERE dossier = '" . $this->valF['dossier'] . "'");
302 if ($dossier_erp == 't'
303 && substr($dossier_nature, 0, 2) == $this->f->getParameter('erp_dossier_nature_pc')) {
304 // envoi du message "Demande d'instruction d'un dossier PC pour un ERP"
305 if (($this->valF['service'] == $this->f->getParameter('erp_service_accessibilite')
306 || $this->valF['service'] == $this->f->getParameter('erp_service_securite'))) {
307 $msgenque = new MessageEnqueuer();
308 $msgenque->setDossierInstructionIdentifier($this->valF['dossier']);
309 $msgenque->setConsultationIdentifier($this->valF['consultation']);
310 $msgenque->enqueueMessage($msgenque::$ERP_DEMANDE_INSTRUCTION_PC);
311 }
312
313 // envoi du message "Consultation ERP pour conformite" en cas de creation de la
314 // consultation du service ERP Conformite
315 if ($this->valF['service'] == $this->f->getParameter('erp_service_conformite')) {
316 $msgenque = new MessageEnqueuer();
317 $msgenque->setDossierInstructionIdentifier($this->valF['dossier']);
318 $msgenque->setConsultationIdentifier($this->valF['consultation']);
319 $msgenque->enqueueMessage($msgenque::$ERP_CONSULTATION_CONFORMITE);
320 }
321 }
322 } // fin de if($this->f->getParameter('option_erp'))
323 }
324
325 /**
326 * Fait une requette sql pour extraire la valeur d'un champ, et retourne
327 * cette valeur
328 * @param string $sql La requete sql a executer
329 * @return La valeur du champs cherche, sinon NULL. En cas d'erreur de la BD
330 * l'execution s'arrete.
331 */
332 function getFromDB($sql) {
333 //$sql = "SELECT libelle FROM ".DB_PREFIXE."dossier WHERE dossier = '" . $dossier . "'";
334 $res = $this->db->limitquery($sql, 0, 1);
335 $this->addToLog("getDossierERPSpecification(): db->limitquery(\"".
336 str_replace(",",", ",$sql)."\", 0, 1);", VERBOSE_MODE);
337 // Si une erreur survient on die
338 if (database::isError($res, true)) {
339 // Appel de la methode de recuperation des erreurs
340 $this->erreur_db($res->getDebugInfo(), $res->getMessage(), 'instruction');
341 }
342 // retourne la nature du dossier
343 while ($row =& $res->fetchRow()) {
344 return $row[0];
345 }
346 // la nature n'etait pas trouve, ce qui ne devrait pas se passer
347 return NULL;
348
349 }
350
351
352 /**
353 * Returne la nature du dossier auquel la consultation appartient.
354 * @param string $dossier L'identifiant du dossier
355 * @return La nature du dossier si elle existe, sinon NULL. En cas
356 * d'erreur de la BD, l'execution se termine.
357 */
358 function getDossierNature($dossier) {
359 $sql = "SELECT nature FROM ".DB_PREFIXE."dossier WHERE dossier = '" . $dossier . "'";
360 $res = $this->db->limitquery($sql, 0, 1);
361 $this->addToLog("getDossierNature(): db->limitquery(\"".str_replace(",",", ",$sql)."\", 0, 1);", VERBOSE_MODE);
362 // Si une erreur survient on die
363 if (database::isError($res, true)) {
364 // Appel de la methode de recuperation des erreurs
365 $this->erreur_db($res->getDebugInfo(), $res->getMessage(), 'dossier');
366 }
367 // retourne la nature du dossier
368 while ($row =& $res->fetchRow()) {
369 return $row[0];
370 }
371 // la nature n'etait pas trouve, ce qui ne devrait pas se passer
372 return NULL;
373 }
374
375 // =============================================
376 // calcul de date avec ajout de mois (delais)
377 // [add months (delay) and calculation final date]
378 // limite ? => voir fonction instruction
379 // =============================================
380 function moisdate($date,$delaimois) {
381 // rajout de mois à une date (moins de 12)
382 $temp = explode("-" , $date);
383 $jour = (int) $temp[2];
384 $mois = (int) $temp[1];
385 $annee = (int) $temp[0];
386 $mois=$mois+$delaimois;
387 // calcul mois annee
388 if($mois>12){
389 $mois=$mois-12;
390 $annee=$annee+1;
391 }
392 // Calcul du nombre de jours dans le mois sélectionné
393 switch($mois) {
394 case "2":
395 if ($annee % 4 == 0 && $annee % 100 != 0 || $annee % 400 == 0)
396 $jourmax = 29;
397 else
398 $jourmax = 28;
399 break;
400 case "4":
401 case "6":
402 case "9":
403 case "11":
404 $jourmax = 30;
405 break;
406 default:
407 $jourmax = 31;
408 }
409 if ($jour > $jourmax)
410 $jour = $jourmax;
411 return $annee."-".$mois."-".$jour ;
412 }
413
414 // =============================================
415 // Ajout du fielset
416 // Add fieldset
417 // =============================================
418 function setLayout(&$form, $maj){
419
420 // Modification layout : écran de retour d'avis permettant
421 // uniquement la saisie des trois champs : avis, motivation et fichier
422 if ($this->f->isAccredited('consultation_consulter_autre_que_retour_avis')) {
423
424 //Champs sur lequel s'ouvre le fieldset
425 $form->setBloc('dossier','D',"");
426 $form->setFieldset('dossier','D',_('Consultation'));
427
428 //Champs sur lequel se ferme le fieldset
429 $form->setFieldset('date_envoi','F','');
430 $form->setBloc('date_envoi','F');
431
432 }
433
434 // MODE - autre que AJOUTER alors on affiche un fieldset retour
435 // d'avis
436 if ($maj != 0) {
437
438 //Champs sur lequel s'ouvre le fieldset
439 $form->setBloc('date_reception','D',"");
440 $form->setFieldset('date_reception','D',_('Retour d\'avis'));
441
442 //Champs sur lequel se ferme le fieldset
443 $form->setFieldset('lu','F','');
444 $form->setBloc('lu','F');
445
446 }
447 }
448
449 /** Surcharge de la methode retour afin de retourner sur la page de saisie de
450 * code barre si besoin
451 **/
452 function retour($premier = 0, $recherche = "", $tricol = "") {
453 $params ="obj=".get_class($this);
454 if($this->getParameter("retour")=="form") {
455 $params .= "&amp;idx=".$this->getParameter("idx");
456 $params .= "&amp;action=3";
457 }
458 $params .= "&amp;premier=".$this->getParameter("premier");
459 $params .= "&amp;tricol=".$this->getParameter("tricol");
460 $params .= "&amp;recherche=".$this->getParameter("recherche");
461 $params .= "&amp;selectioncol=".$this->getParameter("selectioncol");
462 $params .= "&amp;advs_id=".$this->getParameter("advs_id");
463 $params .= "&amp;valide=".$this->getParameter("valide");
464 echo "\n<a class=\"retour\" ";
465 echo "href=\"";
466 //
467
468 if($this->getParameter("retour")=="form" AND !($this->getParameter("validation")>0 AND $this->getParameter("maj")==2 AND $this->correct)) {
469 echo "form.php?".$params;
470 } elseif($this->getParameter("retour")=="avis_code_barre") {
471 echo "../app/avis_code_barre.php";
472 } else {
473 echo "tab.php?".$params;
474 }
475 //
476 echo "\"";
477 echo ">";
478 //
479 echo _("Retour");
480 //
481 echo "</a>\n";
482 }
483
484 /**
485 * Surcharge du bouton retour pour popup
486 */
487 function retoursousformulaire($idxformulaire, $retourformulaire, $val,
488 $objsf, $premiersf, $tricolsf, $validation,
489 $idx, $maj, $retour) {
490 if($retourformulaire === "demande_avis_encours") {
491 echo "\n<a class=\"retour\" ";
492 echo "href=\"";
493 echo "#";
494 echo "\" ";
495 echo ">";
496 //
497 echo _("Retour");
498 //
499 echo "</a>\n";
500 } else {
501 parent::retoursousformulaire($idxformulaire, $retourformulaire, $val,
502 $objsf, $premiersf, $tricolsf, $validation,
503 $idx, $maj, $retour);
504 }
505 }
506 }// fin classe
507 ?>

[email protected]
ViewVC Help
Powered by ViewVC 1.1.26