/[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 675 by nhaye, Tue Nov 13 11:23:15 2012 UTC revision 1005 by fmichon, Thu Dec 6 15:48:07 2012 UTC
# Line 2  Line 2 
2  //$Id$  //$Id$
3  //gen openMairie le 10/02/2011 20:32  //gen openMairie le 10/02/2011 20:32
4  require_once ("../gen/obj/consultation.class.php");  require_once ("../gen/obj/consultation.class.php");
5    require_once("../services/outgoing/messageenqueuer.php");
6    
7  class consultation extends consultation_gen {  class consultation extends consultation_gen {
8    
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                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){      function setValsousformulaire(&$form,$maj,$validation,$idxformulaire,$retourformulaire,$typeformulaire){
90          if ($validation==0) {          if ($validation==0) {
91              if ($maj == 0){              if ($maj == 0){
# Line 212  class consultation extends consultation_ Line 289  class consultation extends consultation_
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      // =============================================      // =============================================
# Line 321  class consultation extends consultation_ Line 479  class consultation extends consultation_
479          echo _("Retour");          echo _("Retour");
480          //          //
481          echo "</a>\n";          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  }// fin classe
507  ?>  ?>

Legend:
Removed from v.675  
changed lines
  Added in v.1005

[email protected]
ViewVC Help
Powered by ViewVC 1.1.26