/[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 936 by mlimic, Fri Nov 30 13:20:10 2012 UTC revision 1088 by fmichon, Tue Dec 18 08:40:17 2012 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          if ($validation==0) {          if ($validation==0) {
121              if ($maj == 0){              if ($maj == 0){
# Line 213  class consultation extends consultation_ Line 319  class consultation extends consultation_
319              }              }
320          }          }
321                    
         // 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'] . "'");  
         print '$dossier_erp:'.$dossier_erp;  
         print 'param in db:'.$this->f->getParameter('erp_dossier_nature_pc').' ';  
         print 'dossier_nature:'.$dossier_nature;  
         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);                  
             }  
         }  
322                    
323            // verification si envoi vers ERP est active
324            if ($this->f->getParameter('option_erp') != "") {
325                // s'il s'agit de la consultation ERP Secu, ERP Accessibilite, ou
326                // deenvoie un
327                // message a ERP
328                $dossier_erp = $this->getFromDB("SELECT erp FROM ".DB_PREFIXE.
329                                "dossier WHERE dossier = '" .$this->valF['dossier'] . "'");
330                $dossier_nature = $this->getFromDB("SELECT nature FROM ".DB_PREFIXE.
331                                "dossier WHERE dossier = '" . $this->valF['dossier'] . "'");
332                if ($dossier_erp == 't'
333                    && substr($dossier_nature, 0, 2) == $this->f->getParameter('erp_dossier_nature_pc')) {
334                    // envoi du message "Demande d'instruction d'un dossier PC pour un ERP"
335                    if (($this->valF['service'] == $this->f->getParameter('erp_service_accessibilite')
336                        || $this->valF['service'] == $this->f->getParameter('erp_service_securite'))) {
337                        $msgenque = new MessageEnqueuer();
338                        $msgenque->setDossierInstructionIdentifier($this->valF['dossier']);
339                        $msgenque->setConsultationIdentifier($this->valF['consultation']);
340                        $msgenque->enqueueMessage($msgenque::$ERP_DEMANDE_INSTRUCTION_PC);
341                    }
342                    
343                    // envoi du message "Consultation ERP pour conformite" en cas de creation de la
344                    // consultation du service ERP Conformite
345                    if ($this->valF['service'] == $this->f->getParameter('erp_service_conformite')) {
346                        $msgenque = new MessageEnqueuer();
347                        $msgenque->setDossierInstructionIdentifier($this->valF['dossier']);
348                        $msgenque->setConsultationIdentifier($this->valF['consultation']);
349                        $msgenque->enqueueMessage($msgenque::$ERP_CONSULTATION_CONFORMITE);                
350                    }
351                }
352            } // fin de if($this->f->getParameter('option_erp'))
353      }      }
354            
355      /**      /**
# Line 404  class consultation extends consultation_ Line 510  class consultation extends consultation_
510          //          //
511          echo "</a>\n";          echo "</a>\n";
512      }      }
       
     /**  
      * 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;  
         }  
     }  
513    
514      /**      /**
515       * Surcharge du bouton retour pour popup       * Surcharge du bouton retour pour popup

Legend:
Removed from v.936  
changed lines
  Added in v.1088

[email protected]
ViewVC Help
Powered by ViewVC 1.1.26