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

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

Parent Directory Parent Directory | Revision Log Revision Log | View Patch Patch

revision 940 by fmichon, Fri Nov 30 14:17:12 2012 UTC revision 1730 by fmichon, Fri Apr 19 09:43:18 2013 UTC
# Line 9  class consultation extends consultation_ Line 9  class consultation extends consultation_
9      function consultation($id,&$db,$debug) {      function consultation($id,&$db,$debug) {
10          $this->constructeur($id,$db,$debug);          $this->constructeur($id,$db,$debug);
11      }// fin constructeur      }// 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                    //
55                $this->f->addToLog("canAccess(): utilisateur de service sur une consultation d'un autre service", EXTRA_VERBOSE_MODE);
56                return false;
57            }
58            // Si l'utilisateur est un intructeur qui ne correspond pas à la
59            // division du dossier
60            if ($this->f->isUserInstructeur()
61                && $this->f->om_utilisateur["division"] != $this->getDivisionFromDossier()
62                && $this->getParameter("maj") != 3) {
63                //
64                $this->f->addToLog("canAccess(): utilisateur instructeur sur un dossier d'une autre division", EXTRA_VERBOSE_MODE);
65                return false;
66            }
67            //
68            return true;
69        }
70    
71        /**
72         * Cette méthode permet de récupérer la division d'un dossier
73         */
74        function getDivisionFromDossier() {
75            // Si on se trouve en mode MODIFIER ou SUPPRIMER ou CONSULTER alors on
76            // récupère le numéro de dossier dans la consultation et on en retourne
77            // sa division
78            if ($this->getParameter("maj") == 1 || $this->getParameter("maj") == 2
79                || $this->getParameter("maj") == 3) {
80                //
81                if (!isset($this->val[array_search("dossier", $this->champs)])) {
82                    return NULL;
83                }
84                //
85                $sql = "select division from ".DB_PREFIXE."dossier ";
86                $sql .= " where dossier='".$this->val[array_search("dossier", $this->champs)]."'";
87                //
88                $division = $this->db->getOne($sql);
89                $this->addToLog("getDivisionFromDossier(): db->getone(\"".$sql."\")", VERBOSE_MODE);
90                database::isError($division);
91                //
92                return $division;
93            } elseif ($this->getParameter("maj") == 0
94                      && ($this->getParameter("retourformulaire") == "dossier"
95                          || $this->getParameter("retourformulaire") == "dossier_instruction"
96                          || $this->getParameter("retourformulaire") == "dossier_instruction_mes_encours"
97                          || $this->getParameter("retourformulaire") == "dossier_instruction_tous_encours"
98                          || $this->getParameter("retourformulaire") == "dossier_instruction_mes_clotures"
99                          || $this->getParameter("retourformulaire") == "dossier_instruction_tous_clotures")) {
100                // Si on se trouve en mode AJOUTER et en sous formulaire alors on
101                // récupère le numéro de dossier dans les paramètres de sous
102                // formulaires et on en retourne sa division
103                $sql = "select division from ".DB_PREFIXE."dossier ";
104                $sql .= " where dossier='".$this->getParameter("idxformulaire")."'";
105                //
106                $division = $this->db->getOne($sql);
107                $this->addToLog("getDivisionFromDossier(): db->getone(\"".$sql."\")", VERBOSE_MODE);
108                database::isError($division);
109                //
110                return $division;
111            } else {
112                return NULL;
113            }
114    
115        }
116    
117        // }}}
118    
119      function setValsousformulaire(&$form,$maj,$validation,$idxformulaire,$retourformulaire,$typeformulaire){      function setValsousformulaire(&$form,$maj,$validation,$idxformulaire,$retourformulaire,$typeformulaire){
120            // ajout du retourformulaire aux attributs de l'objet
121            $this->retourformulaire = $retourformulaire;
122          if ($validation==0) {          if ($validation==0) {
123              if ($maj == 0){              if ($maj == 0){
124                  $form->setVal("dossier", $idxformulaire);                  $form->setVal("dossier", $idxformulaire);
# Line 32  class consultation extends consultation_ Line 140  class consultation extends consultation_
140      }      }
141    
142      function setvalF($val) {      function setvalF($val) {
143            //
144          parent::setValF($val);          parent::setValF($val);
145          if($this->getParameter('maj')==0) {          //
146              $this->valF["date_reception"]=$this->valF["date_envoi"];          if ($this->getParameter('maj') == 0) {
147                //
148                if (isset($this->valF["date_envoi"])) {
149                    $this->valF["date_reception"] = $this->valF["date_envoi"];
150                }
151                //
152                $this->valF["lu"] = true;
153          }          }
154    
155          // Si un retour d'avis est modifie on passe "lu" a false          // Si un retour d'avis est modifie on passe "lu" a false
# Line 47  class consultation extends consultation_ Line 162  class consultation extends consultation_
162              $this->valF["lu"]=false;              $this->valF["lu"]=false;
163          }          }
164      }      }
165        
166      function verifier($val, &$db, $DEBUG) {      function setLib(&$form, $maj) {
167          parent::verifier($val, $db, $DEBUG);          //
168          // Si le fichier envoye est different de l'existant          parent::setLib($form, $maj);
169          if (isset($this->val[array_search("fichier",$this->champs)])          //
170              && $this->val[array_search("fichier",$this->champs)] != $val["fichier"]          $form->setLib($this->clePrimaire, _("id"));
             && $this->valF['fichier']!="") {  
             // Si le fichier existe dans tmp  
             if(file_exists("../tmp/".$this->valF['fichier'])) {  
                 $contents=file_get_contents("../tmp/".$this->valF['fichier']);  
                 // On essaye de l'enregistrer  
                 $res = $this->f->storeDecisionFile($contents, $this->valF['fichier'],  
                                                $this->valF['dossier'],  
                                                'consultation_'.$this->valF['consultation']."_");  
                 // Si l'enregistrement s'est bien deroule  
                 // on supprime le fichier dans tmp  
                 // on met a jour valF avec le nouveau nom du fichier  
                 if($res===true){  
                     $this->addToMessage(_("Sauvegarde du fichier reussi"));  
                     unlink("../tmp/".$this->valF['fichier']);  
                     $this->valF['fichier']='consultation_'.$this->valF['consultation']."_".$this->valF['fichier'];  
                 // Sinon on supprime le fichier dans tmp  
                 // on reinitialise le nom du fichier a l'ancienne valeur  
                 } else {  
                     $this->correct = false;  
                     $this->addToMessage($res);  
                     unlink("../tmp/".$this->valF['fichier']);  
                     $this->valF['fichier']=$this->val[array_search("fichier",$this->champs)];  
                 }  
             }  
         }  
171      }      }
172        
173      function setType(&$form,$maj) {      function setType(&$form,$maj) {
174          // Appel du parent          // Appel du parent
175          parent::setType($form,$maj);          parent::setType($form,$maj);
# Line 127  class consultation extends consultation_ Line 217  class consultation extends consultation_
217              }              }
218    
219              // Gestion du type du widget sur le champ fichier              // Gestion du type du widget sur le champ fichier
220              if($this->val[array_search("fichier",$this->champs)]=="" OR              if($this->getVal("fichier") == "" OR
221                 $this->f->isAccredited('consultation_modifier_fichier')) {                 $this->f->isAccredited('consultation_modifier_fichier')) {
222                  // Si il n'y a jamais eu de fichier enregistré ou que                  // Si il n'y a jamais eu de fichier enregistré ou que
223                  // l'utilisateur a spécifiquement les droits pour modifier                  // l'utilisateur a spécifiquement les droits pour modifier
224                  // un fichier déjà enregistré alors on positionne un type                  // un fichier déjà enregistré alors on positionne un type
225                  // de widget modifiable                  // de widget modifiable
226                  $form->setType('fichier', 'tmpUpload');                  if($this->retourformulaire == "demande_avis_encours") {
227                        $form->setType('fichier', 'upload2');
228                    } else {
229                        $form->setType('fichier', 'upload');
230                    }
231              } else {              } else {
232                  // Si non on affiche uniquement le nom du fichier                  // Si non on affiche uniquement le nom du fichier
233                  $form->setType('fichier', 'tmpUploadStatic');                  $form->setType('fichier', 'file');
234              }              }
235    
236              // Modification layout : écran de retour d'avis permettant              // Modification layout : écran de retour d'avis permettant
# Line 157  class consultation extends consultation_ Line 251  class consultation extends consultation_
251          }          }
252          // MODE - CONSULTER          // MODE - CONSULTER
253          if ( $maj == 3 ) {          if ( $maj == 3 ) {
254              $form->setType('fichier', 'tmpUploadStatic');              $form->setType('fichier', 'file');
255          }          }
256          //// On cache la clé primaire          //// On cache la clé primaire
257          //$form->setType('consultation', 'hidden');          //$form->setType('consultation', 'hidden');
258            //
259            if ($this->getParameter("retourformulaire") == "dossier"
260                || $this->getParameter("retourformulaire") == "dossier_instruction"
261                || $this->getParameter("retourformulaire") == "dossier_instruction_mes_encours"
262                || $this->getParameter("retourformulaire") == "dossier_instruction_tous_encours"
263                || $this->getParameter("retourformulaire") == "dossier_instruction_mes_clotures"
264                || $this->getParameter("retourformulaire") == "dossier_instruction_tous_clotures") {
265                //
266                $form->setType('dossier', 'hidden');
267            }
268      }      }
269    
270      // TRIGGER AVANT MODIFICATION DE DONNEES      // Cette méthode permet de calculer la date limite en fonction de la date
271      // trigger before modification data      // de réception et du délai de consultation du service consulté
272      function triggerajouter($id,&$db,$val,$DEBUG) {      function calculDateLimite() {
273          // mise a jour instruction avec evenement [return delay]          // mise a jour instruction avec evenement [return delay]
274          if ($this->valF['date_envoi']!=""){          if ($this->valF["date_reception"] != "") {
275              $sql= "select delai from ".DB_PREFIXE."service where service ='".$this->valF['service']."'";              //
276              $delai = $db->getOne($sql);              $sql = " select delai from ".DB_PREFIXE."service ";
277              $this->valF['date_limite'] =  $this->moisdate($this->valF['date_envoi'],$delai);              $sql .= " where service='".$this->valF["service"]."' ";
278                //
279                $delai = $this->db->getOne($sql);
280                $this->addToLog("triggerajouter(): db->getone(\"".$sql."\")", VERBOSE_MODE);
281                //
282                $this->valF["date_limite"] = $this->moisdate($this->valF["date_reception"], $delai);
283                //
284              $this->addToMessage(_("delai")." ".              $this->addToMessage(_("delai")." ".
285                 _("retour")." ".$delai." "._("mois")." -> ".                 _("retour")." ".$delai." "._("mois")." -> ".
286                 _("retour")." ".$this->valF['date_limite']."<br>");                 _("retour")." ".date("d/m/Y", strtotime($this->valF["date_limite"])));
             $this->valF['lu'] = true;  
287          }          }
           
288      }      }
289        
290        // TRIGGER AVANT MODIFICATION DE DONNEES
291        // trigger before modification data
292        function triggerajouter($id,&$db,$val,$DEBUG) {
293            //
294            $this->calculDateLimite();
295        }
296    
297        //
298        function triggermodifier($id,&$db,$val,$DEBUG) {
299            //
300            $this->calculDateLimite();
301        }
302    
303        //
304      function triggerajouterapres($id,&$db,$val,$DEBUG) {      function triggerajouterapres($id,&$db,$val,$DEBUG) {
305                    
306          // Verification de la demande de notif par mail          // Verification de la demande de notif par mail
307          $sql= "SELECT abrege, notification_email, email FROM ".DB_PREFIXE.          $sql= "SELECT abrege, libelle, notification_email, email FROM ".DB_PREFIXE.
308                  "service WHERE service ='".$this->valF['service']."'";                  "service WHERE service ='".$this->valF['service']."'";
309          $res=$db->query($sql);          $res=$db->query($sql);
310          $notif = $res->fetchrow(DB_FETCHMODE_ASSOC);          $notif = $res->fetchrow(DB_FETCHMODE_ASSOC);
# Line 207  class consultation extends consultation_ Line 329  class consultation extends consultation_
329              _("Lien externe (hors VDM)")."</a>";              _("Lien externe (hors VDM)")."</a>";
330              // Envoi du mail avec message de retour              // Envoi du mail avec message de retour
331              if($this->f->sendMail($title, $corps, $notif['email'])) {              if($this->f->sendMail($title, $corps, $notif['email'])) {
332                  $this->addToMessage(_("Envoi d'un mail de notification au service")." ".$notif['abrege']);                  $this->addToMessage(_("Envoi d'un mail de notification au service")." \"(".$notif['abrege'].") ".$notif["libelle"]."\"");
333              } else {              } else {
334                  $this->addToMessage(_("L'envoi du mail de notification a echoue"));                  $this->addToMessage(_("L'envoi du mail de notification a echoue"));
335              }              }
336          }          }
337                    
         // s'il s'agit de la consultation ERP Secu, ERP Accessibilite, ou  
         // deenvoie un  
         // message a ERP  
         $dossier_erp = $this->getFromDB("SELECT erp FROM ".DB_PREFIXE.  
                         "dossier WHERE dossier = '" .$this->valF['dossier'] . "'");  
         $dossier_nature = $this->getFromDB("SELECT nature FROM ".DB_PREFIXE.  
                         "dossier WHERE dossier = '" . $this->valF['dossier'] . "'");  
         if ($dossier_erp == 't'  
             && substr($dossier_nature, 0, 2) == $this->f->getParameter('erp_dossier_nature_pc')) {  
             // envoi du message "Demande d'instruction d'un dossier PC pour un ERP"  
             if (($this->valF['service'] == $this->f->getParameter('erp_service_accessibilite')  
                 || $this->valF['service'] == $this->f->getParameter('erp_service_securite'))) {  
                 $msgenque = new MessageEnqueuer();  
                 $msgenque->setDossierInstructionIdentifier($this->valF['dossier']);  
                 $msgenque->setConsultationIdentifier($this->valF['consultation']);  
                 $msgenque->enqueueMessage($msgenque::$ERP_DEMANDE_INSTRUCTION_PC);  
             }  
               
             // envoi du message "Consultation ERP pour conformite" en cas de creation de la  
             // consultation du service ERP Conformite  
             if ($this->valF['service'] == $this->f->getParameter('erp_service_conformite')) {  
                 $msgenque = new MessageEnqueuer();  
                 $msgenque->setDossierInstructionIdentifier($this->valF['dossier']);  
                 $msgenque->setConsultationIdentifier($this->valF['consultation']);  
                 $msgenque->enqueueMessage($msgenque::$ERP_CONSULTATION_CONFORMITE);                  
             }  
         }  
338                    
339            // verification si envoi vers ERP est active
340            if ($this->f->getParameter('option_erp') != "") {
341                // s'il s'agit de la consultation ERP Secu, ERP Accessibilite, ou
342                // deenvoie un
343                // message a ERP
344                $dossier_erp = $this->getFromDB("SELECT erp FROM ".DB_PREFIXE.
345                                "dossier WHERE dossier = '" .$this->valF['dossier'] . "'");
346                $dossier_nature = $this->getFromDB("SELECT dossier_autorisation_type_detaille.code FROM ".DB_PREFIXE.
347                                "dossier
348                                INNER JOIN ".DB_PREFIXE."dossier_autorisation
349                                    ON dossier.dossier_autorisation=dossier_autorisation.dossier_autorisation
350                                INNER JOIN ".DB_PREFIXE."dossier_autorisation_type_detaille
351                                    ON dossier_autorisation.dossier_autorisation_type_detaille
352                                    = dossier_autorisation_type_detaille.dossier_autorisation_type_detaille
353                                WHERE dossier = '" . $this->valF['dossier'] . "'");
354                if ($dossier_erp == 't'
355                    && substr($dossier_nature, 0, 2) == $this->f->getParameter('erp_dossier_nature_pc')) {
356                    // envoi du message "Demande d'instruction d'un dossier PC pour un ERP"
357                    if (($this->valF['service'] == $this->f->getParameter('erp_service_accessibilite')
358                        || $this->valF['service'] == $this->f->getParameter('erp_service_securite'))) {
359                        $msgenque = new MessageEnqueuer();
360                        $msgenque->setDossierInstructionIdentifier($this->valF['dossier']);
361                        $msgenque->setConsultationIdentifier($this->valF['consultation']);
362                        $msgenque->enqueueMessage($msgenque::$ERP_DEMANDE_INSTRUCTION_PC);
363                    }
364                    
365                    // envoi du message "Consultation ERP pour conformite" en cas de creation de la
366                    // consultation du service ERP Conformite
367                    if ($this->valF['service'] == $this->f->getParameter('erp_service_conformite')) {
368                        $msgenque = new MessageEnqueuer();
369                        $msgenque->setDossierInstructionIdentifier($this->valF['dossier']);
370                        $msgenque->setConsultationIdentifier($this->valF['consultation']);
371                        $msgenque->enqueueMessage($msgenque::$ERP_CONSULTATION_CONFORMITE);                
372                    }
373                }
374            } // fin de if($this->f->getParameter('option_erp'))
375      }      }
376            
377      /**      /**
# Line 269  class consultation extends consultation_ Line 400  class consultation extends consultation_
400    
401      }      }
402    
       
     /**  
      * Returne la nature du dossier auquel la consultation appartient.  
      * @param string $dossier L'identifiant du dossier  
      * @return La nature du dossier si elle existe, sinon NULL. En cas  
      * d'erreur de la BD, l'execution se termine.  
      */  
     function getDossierNature($dossier) {  
         $sql = "SELECT nature FROM ".DB_PREFIXE."dossier WHERE dossier = '" . $dossier . "'";  
         $res = $this->db->limitquery($sql, 0, 1);  
         $this->addToLog("getDossierNature(): db->limitquery(\"".str_replace(",",", ",$sql)."\", 0, 1);", VERBOSE_MODE);  
         // Si une erreur survient on die  
         if (database::isError($res, true)) {  
             // Appel de la methode de recuperation des erreurs  
             $this->erreur_db($res->getDebugInfo(), $res->getMessage(), 'dossier');  
         }  
         // retourne la nature du dossier  
         while ($row =& $res->fetchRow()) {  
             return $row[0];  
         }  
         // la nature n'etait pas trouve, ce qui ne devrait pas se passer  
         return NULL;  
     }  
   
403      // =============================================      // =============================================
404      // calcul de date avec ajout de mois (delais)      // calcul de date avec ajout de mois (delais)
405      // [add months (delay) and calculation final date]      // [add months (delay) and calculation final date]
# Line 388  class consultation extends consultation_ Line 495  class consultation extends consultation_
495    
496          if($this->getParameter("retour")=="form" AND !($this->getParameter("validation")>0 AND $this->getParameter("maj")==2 AND $this->correct)) {          if($this->getParameter("retour")=="form" AND !($this->getParameter("validation")>0 AND $this->getParameter("maj")==2 AND $this->correct)) {
497              echo "form.php?".$params;              echo "form.php?".$params;
498          } elseif($this->getParameter("retour")=="avis_code_barre") {          } elseif($this->getParameter("retour")=="suivi_retours_de_consultation") {
499              echo "../app/avis_code_barre.php";              echo "../app/suivi_retours_de_consultation.php";
500          } else {          } else {
501              echo "tab.php?".$params;              echo "tab.php?".$params;
502          }          }
# Line 401  class consultation extends consultation_ Line 508  class consultation extends consultation_
508          //          //
509          echo "</a>\n";          echo "</a>\n";
510      }      }
       
     /**  
      * Surcharge pour gérer les actions disponibles dans le portlet  
      */  
     function checkAccessibility() {  
         // Si une action 'lu' est présente et que le champ lu est à true  
         // on supprime l'action  
         if (isset($this->actions_sup["lu"])  
             && $this->val[array_search("lu", $this->champs)] == "t") {  
             unset($this->actions_sup["lu"]);  
         }  
         //  
         parent::checkAccessibility();  
     }  
   
     /**  
      * Méthode de verification d'accèssibilité de la consultation  
      * à l'utilisateur connecté  
      */  
     function canAccess() {  
         parent::canAccess();  
         if($this->f->isUserServiceExt()) {  
             // On compare l'id du service de la consultation  
             // aux id des services de utilisateur connecté  
             foreach($this->f->om_utilisateur['service'] as $service) {  
                 if($this->val[array_search("service",$this->champs)]===$service['service']) {  
                     return true;  
                 }  
             }  
             return false;  
         } else{  
             return true;  
         }  
     }  
511    
512      /**      /**
513       * Surcharge du bouton retour pour popup       * Surcharge du bouton retour pour popup

Legend:
Removed from v.940  
changed lines
  Added in v.1730

[email protected]
ViewVC Help
Powered by ViewVC 1.1.26