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

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

Parent Directory Parent Directory | Revision Log Revision Log


Revision 4760 - (hide annotations)
Fri Jul 22 17:38:27 2016 UTC (8 years, 6 months ago) by softime
File size: 62106 byte(s)
* Suppression des anciennes références à openfoncier.

1 mbroquet 3730 <?php
2     /**
3     * Ce fichier est destine a permettre la surcharge de certaines methodes de
4     * la classe om_application pour des besoins specifiques de l'application
5     *
6     * @package openmairie_exemple
7     * @version SVN : $Id: utils.class.php 6132 2016-03-09 09:18:18Z stimezouaght $
8     */
9    
10     /**
11     *
12     */
13     require_once "../dyn/locales.inc.php";
14    
15     /**
16     *
17     */
18     require_once "../dyn/include.inc.php";
19    
20     /**
21     *
22     */
23     require_once "../dyn/debug.inc.php";
24    
25     /**
26     *
27     */
28     (defined("PATH_OPENMAIRIE") ? "" : define("PATH_OPENMAIRIE", ""));
29    
30     /**
31     *
32     */
33     require_once PATH_OPENMAIRIE."om_application.class.php";
34    
35     /**
36     *
37     */
38     class utils extends application {
39    
40 fmichon 4471 /**
41     * Gestion du favicon de l'application.
42     *
43     * @var mixed Configuration niveau application.
44     */
45     var $html_head_favicon = '../app/img/favicon.ico';
46    
47 mbroquet 3730 // {{{
48    
49     /**
50 softime 4752 *
51     */
52     function isAccredited($obj = NULL, $operator = "AND") {
53     // Lorsque l'utilisateur a le login 'admin' alors il est authorisé à
54     // accéder à toutes les fonctions du logiciel
55     // XXX à modifier pour changer ça vers un profil et non un login utilisateur
56     if ($_SESSION["login"] == "admin") {
57     return true;
58     }
59     // Fonctionnement standard
60     return parent::isAccredited($obj, $operator);
61     }
62    
63    
64     /**
65 mbroquet 3730 * SURCHARGE DE LA CLASSE OM_APPLICATION.
66     *
67     * @see Documentation sur la méthode parent 'om_application:getCollectivite'.
68     */
69     function getCollectivite($om_collectivite_idx = null) {
70     // On vérifie si une valeur a été passée en paramètre ou non.
71     if ($om_collectivite_idx === null) {
72     // Cas d'utilisation n°1 : nous sommes dans le cas où on
73     // veut récupérer les informations de la collectivité de
74     // l'utilisateur et on stocke l'info dans un flag.
75     $is_get_collectivite_from_user = true;
76     // On initialise l'identifiant de la collectivité
77     // à partir de la variable de session de l'utilisateur.
78     $om_collectivite_idx = $_SESSION['collectivite'];
79     } else {
80     // Cas d'utilisation n°2 : nous sommes dans le cas où on
81     // veut récupérer les informations de la collectivité
82     // passée en paramètre et on stocke l'info dans le flag.
83     $is_get_collectivite_from_user = false;
84     }
85     //
86     $collectivite_parameters = parent::getCollectivite($om_collectivite_idx);
87    
88     //// BEGIN - SURCHARGE OPENADS
89    
90     // Ajout du paramétrage du sig pour la collectivité
91     if (file_exists("../dyn/var.inc")) {
92     include "../dyn/var.inc";
93     }
94     if (file_exists("../dyn/sig.inc.php")) {
95     include "../dyn/sig.inc.php";
96     }
97 softime 4760 if (!isset($sig_externe)) {
98     $sig_externe = "sig-default";
99     }
100 mbroquet 3730 $idx_multi = $this->get_idx_collectivite_multi();
101    
102 softime 4749 if (isset($collectivite_parameters['om_collectivite_idx'])
103     && isset($conf[$sig_externe][$collectivite_parameters['om_collectivite_idx']])
104     && isset($conf[$sig_externe]["sig_treatment_mod"])
105     && isset($collectivite_parameters["option_sig"])
106     && $collectivite_parameters["option_sig"] == "sig_externe"
107 mbroquet 3730 ) {
108    
109     // Cas numéro 1 : conf sig définie sur la collectivité et option sig active
110     $collectivite_parameters["sig"] = $conf[$sig_externe][$collectivite_parameters['om_collectivite_idx']];
111 nhaye 4099 $collectivite_parameters["sig"]["sig_treatment_mod"] = $conf[$sig_externe]["sig_treatment_mod"];
112 mbroquet 3730
113 softime 4749 } elseif($idx_multi != ''
114     && isset($conf[$sig_externe][$idx_multi])
115     && isset($conf[$sig_externe]["sig_treatment_mod"])
116     && isset($collectivite_parameters["option_sig"])
117     && $collectivite_parameters["option_sig"] == "sig_externe") {
118 mbroquet 3730 // Cas numéro : conf sig définie sur la collectivité multi et
119     // option_sig activé pour la collectivité mono
120     $collectivite_parameters["sig"] = $conf[$sig_externe][$idx_multi];
121 nhaye 4099 $collectivite_parameters["sig"]["sig_treatment_mod"] = $conf[$sig_externe]["sig_treatment_mod"];
122 mbroquet 3730 }
123    
124     //// END - SURCHARGE OPENADS
125    
126     // Si on se trouve dans le cas d'utilisation n°1
127     if ($is_get_collectivite_from_user === true) {
128     // Alors on stocke dans l'attribut collectivite le tableau de
129     // paramètres pour utilisation depuis la méthode 'getParameter'.
130     $this->collectivite = $collectivite_parameters;
131     }
132     // On retourne le tableau de paramètres.
133     return $collectivite_parameters;
134     }
135    
136     /**
137     * Retourne l'identifiant de la collectivité multi ou l'identifiant de la
138     * seule collectivité dans le cas d'une installation mono.
139     *
140     * @return integer Identifiant de la collectivité multi.
141     */
142     public function get_idx_collectivite_multi() {
143     // Récupère l'identifiant de la collectivité de niveau 2
144     $sql = "SELECT om_collectivite FROM ".DB_PREFIXE."om_collectivite WHERE niveau = '2'";
145     $idx = $this->db->getOne($sql);
146     $this->addToLog(__METHOD__.": db->getOne(\"".$sql."\");", VERBOSE_MODE);
147     $this->isDatabaseError($idx);
148    
149     // S'il n'y a pas de collectivité de niveau 2
150     if ($idx == null || $idx == '') {
151    
152     // Compte le nombre de collectivité
153     $sql = "SELECT count(om_collectivite) FROM ".DB_PREFIXE."om_collectivite";
154     $count = $this->db->getOne($sql);
155     $this->addToLog(__METHOD__.": db->getOne(\"".$sql."\");", VERBOSE_MODE);
156     $this->isDatabaseError($count);
157    
158     // S'il y qu'une collectivité
159     if ($count == 1) {
160    
161     // Récupère l'identifiant de la seule collectivité
162     $sql = "SELECT om_collectivite FROM ".DB_PREFIXE."om_collectivite WHERE niveau = '1'";
163     $idx = $this->db->getOne($sql);
164     $this->addToLog(__METHOD__.": db->getOne(\"".$sql."\");", VERBOSE_MODE);
165     $this->isDatabaseError($idx);
166     }
167    
168     }
169    
170     // Retourne l'identifiant
171     return $idx;
172     }
173    
174    
175     /**
176     * Retourne l'identifiant de la collectivité de l'element de la table passée
177     * en paramètre.
178     *
179     * @param string $table Table de l'element.
180     * @param mixed $id Identifiant de l'element.
181     *
182     * @return string identifiant de la collectivite ou false si l'element n'existe pas.
183     */
184     public function get_collectivite_of_element($table, $id) {
185     require_once '../obj/'.$table.'.class.php';
186     $instance = new $table($id, $this->db, null);
187     if($instance->getVal($instance->clePrimaire) != '') {
188     return $instance->getVal('om_collectivite');
189     }
190     return false;
191     }
192    
193    
194     /**
195     * Retrouve vrai si collectivité passée en paramètre est de niveau mono
196     */
197     function isCollectiviteMono($id) {
198     $sql = "SELECT niveau FROM ".DB_PREFIXE."om_collectivite WHERE om_collectivite = ".$id;
199     $niveau = $this->db->getOne($sql);
200     $this->addToLog(__METHOD__.": db->getOne(\"".$sql."\");", VERBOSE_MODE);
201     $this->isDatabaseError($niveau);
202     if ($niveau == '1') {
203     return true;
204     }
205     return false;
206     }
207    
208     // }}}
209    
210     // {{{
211    
212     var $om_utilisateur = array();
213     var $user_is_instr = NULL;
214     var $user_is_service = NULL;
215     var $user_is_admin = NULL;
216     var $user_is_service_ext = NULL;
217     var $user_is_qualificateur = NULL;
218     var $user_is_chef = NULL;
219     var $user_is_divisionnaire = NULL;
220     var $user_is_service_int = NULL;
221    
222     /**
223     * Méthode de récupération des informations de l'utilisateur connecté.
224     */
225     function getUserInfos() {
226    
227     // Si l'utilisateur est loggé $_SESSION existe
228     if(isset($_SESSION['login']) AND !empty($_SESSION['login'])) {
229    
230     // Récupération des infos utilisateur
231     $sqlUser = "SELECT om_utilisateur, nom, email, login, om_collectivite, om_profil ".
232     "FROM ".DB_PREFIXE."om_utilisateur WHERE login = '".$_SESSION['login']."'";
233     $resUser=$this->db->query($sqlUser);
234     $this->addToLog("getUserInfos(): db->query(\"".$sqlUser."\");", VERBOSE_MODE);
235     if ( database::isError($resUser)){
236     die();
237     }
238     $this->om_utilisateur=&$resUser->fetchRow(DB_FETCHMODE_ASSOC);
239    
240     // Récupère le profil et test si c'est un
241     $sqlProfil = "SELECT libelle FROM ".DB_PREFIXE."om_profil WHERE om_profil = ".$this->om_utilisateur['om_profil'];
242     $resProfil=$this->db->getOne($sqlProfil);
243     $this->addToLog("getUserInfos(): db->getOne(\"".$sqlProfil."\");", VERBOSE_MODE);
244     if (database::isError($resProfil)){
245     die();
246     }
247     // Sauvegarde le libelle du profil
248     $this->om_utilisateur["libelle_profil"] = $resProfil;
249    
250     // si c'est un administrateur technique
251     // XXX Mauvaise méthode, il faut utiliser isAccredited
252     if ($resProfil == "ADMINISTRATEUR TECHNIQUE"
253     || $resProfil == "ADMINISTRATEUR FONCTIONNEL") {
254     $this->user_is_admin = true;
255     } else {
256     $this->user_is_admin = false;
257     }
258    
259     //si c'est un service externe
260     if ($resProfil == "SERVICE CONSULTÉ") {
261     $this->user_is_service_ext = true;
262     } else {
263     $this->user_is_service_ext = false;
264     }
265    
266     //si c'est un service interne
267     if ($resProfil == "SERVICE CONSULTÉ INTERNE") {
268     $this->user_is_service_int = true;
269     } else {
270     $this->user_is_service_int = false;
271     }
272    
273     // si c'est un qualificateur
274     if ($resProfil == "QUALIFICATEUR") {
275     $this->user_is_qualificateur = true;
276     } else {
277     $this->user_is_qualificateur = false;
278     }
279    
280     // si c'est un chef de service
281     if ($resProfil == "CHEF DE SERVICE") {
282     $this->user_is_chef = true;
283     } else {
284     $this->user_is_chef = false;
285     }
286    
287     // si c'est un divisionnaire
288     if ($resProfil == "DIVISIONNAIRE") {
289     $this->user_is_divisionnaire = true;
290     } else {
291     $this->user_is_divisionnaire = false;
292     }
293    
294     // Récupération des infos instructeur
295     $sqlInstr = "SELECT instructeur.instructeur, instructeur.nom, instructeur.telephone,
296     division.division, division.code, division.libelle ".
297     "FROM ".DB_PREFIXE."instructeur INNER JOIN ".DB_PREFIXE."division ON division.division=instructeur.division ".
298     "WHERE instructeur.om_utilisateur = ".$this->om_utilisateur['om_utilisateur'];
299     $resInstr=$this->db->query($sqlInstr);
300     $this->addToLog("getUserInfos(): db->query(\"".$sqlInstr."\");", VERBOSE_MODE);
301     if ( database::isError($resInstr)){
302     die();
303     }
304     $tempInstr=&$resInstr->fetchRow(DB_FETCHMODE_ASSOC);
305     // Si il y a un resultat c'est un instructeur
306     if(count($tempInstr)>0) {
307     $this->user_is_instr=true;
308     $this->om_utilisateur = array_merge($this->om_utilisateur,$tempInstr);
309     } else {
310     $this->user_is_instr=false;
311     }
312    
313     // Récupération des infos de services consultés
314     $sqlServ = "SELECT service.service, service.abrege, service.libelle ".
315     "FROM ".DB_PREFIXE."service ".
316     "INNER JOIN ".DB_PREFIXE."lien_service_om_utilisateur ON lien_service_om_utilisateur.service=service.service ".
317     "WHERE lien_service_om_utilisateur.om_utilisateur = ".$this->om_utilisateur['om_utilisateur'];
318     $resServ=$this->db->query($sqlServ);
319     $this->addToLog("getUserInfos(): db->query(\"".$sqlServ."\");", VERBOSE_MODE);
320     if ( database::isError($resServ)){
321     die();
322     }
323    
324     while ($tempServ=&$resServ->fetchRow(DB_FETCHMODE_ASSOC)) {
325     $this->om_utilisateur['service'][]=$tempServ;
326     }
327     // Si il y a un resultat c'est un utilisateur de service
328     if(isset($this->om_utilisateur['service'])) {
329     $this->user_is_service=true;
330     } else {
331     $this->user_is_service=false;
332     }
333     }
334     }
335    
336     /**
337     * getter user_is_service
338     */
339     function isUserService() {
340     //
341     if (is_null($this->user_is_service)) {
342     //
343     $this->getUserInfos();
344     }
345     //
346     return $this->user_is_service;
347     }
348    
349     /**
350     * getter user_is_instr
351     */
352     function isUserInstructeur() {
353     //
354     if (is_null($this->user_is_instr)) {
355     //
356     $this->getUserInfos();
357     }
358     //
359     return $this->user_is_instr;
360     }
361    
362     function isUserAdministrateur() {
363     //
364     if (is_null($this->user_is_admin)) {
365     //
366     $this->getUserInfos();
367     }
368     //
369     return $this->user_is_admin;
370     }
371    
372     /**
373     * getter user_is_service_ext
374     */
375     function isUserServiceExt() {
376     //
377     if (is_null($this->user_is_service_ext)) {
378     //
379     $this->getUserInfos();
380     }
381     //
382     return $this->user_is_service_ext;
383     }
384    
385     /**
386     * getter user_is_service_int
387     */
388     function isUserServiceInt() {
389     //
390     if (is_null($this->user_is_service_int)) {
391     //
392     $this->getUserInfos();
393     }
394     //
395     return $this->user_is_service_int;
396     }
397    
398     /**
399     * getter user_is_qualificateur
400     */
401     function isUserQualificateur() {
402     //
403     if (is_null($this->user_is_qualificateur)) {
404     //
405     $this->getUserInfos();
406     }
407     //
408     return $this->user_is_qualificateur;
409     }
410    
411     /**
412     * getter user_is_chef
413     */
414     function isUserChef() {
415     //
416     if (is_null($this->user_is_chef)) {
417     //
418     $this->getUserInfos();
419     }
420     //
421     return $this->user_is_chef;
422     }
423    
424     /**
425     * getter user_is_divisionnaire
426     */
427     function isUserDivisionnaire() {
428     //
429     if (is_null($this->user_is_divisionnaire)) {
430     //
431     $this->getUserInfos();
432     }
433     //
434     return $this->user_is_divisionnaire;
435     }
436    
437     /**
438     * Méthode permettant de définir si l'utilisateur connecté peut ajouter un
439     * événement d'instruction
440     *
441     * @param integer $idx identifiant du dossier
442     * @param string $obj objet
443     *
444     * @return boolean true si il peut false sinon
445     */
446     function isUserCanAddObj($idx, $obj) {
447    
448     // Si il à le droit "bypass" il peut ajouter
449     if($this->isAccredited($obj."_ajouter_bypass") === true) {
450     return true;
451     }
452    
453     if($this->isAccredited(array($obj."_ajouter", $obj), "OR") === false) {
454     return false;
455     }
456    
457     $return = true;
458    
459     // Si il n'est pas dans la même division on défini le retour comme faux
460     // à moins qu'il ai un droit de changement de decision
461     if($this->isUserInstructeur() &&
462     $this->getDivisionFromDossier($idx) != $_SESSION["division"]) {
463    
464     $return = false;
465    
466     if ($obj == "instruction" && $this->isInstrCanChangeDecision($idx) === true) {
467    
468     $return = true;
469     }
470     }
471    
472     return $return;
473     }
474    
475     /**
476     * Permet de définir si un instructeur commune peut editer une instruction
477     *
478     * @param string $idx identifiant du dossier d'instruction
479     *
480     * @return boolean true si il peut
481     */
482     function isInstrCanChangeDecision($idx) {
483 softime 4667 if($this->isAccredited(array("instruction", "instruction_changer_decision"), "OR") === false) {
484 mbroquet 3730 return false;
485     }
486    
487     // Sinon on vérifie l'éligibilité du dossier au changement de décision
488     $sql =
489     "SELECT
490     dossier.dossier
491     FROM
492     ".DB_PREFIXE."dossier
493     JOIN ".DB_PREFIXE."instruction ON instruction.instruction = (
494     SELECT instruction
495     FROM ".DB_PREFIXE."instruction
496     JOIN ".DB_PREFIXE."evenement on instruction.evenement=evenement.evenement
497     WHERE instruction.dossier = dossier.dossier
498     AND evenement.retour IS FALSE
499     ORDER BY date_evenement DESC, instruction DESC
500     LIMIT 1
501     )
502     JOIN ".DB_PREFIXE."evenement ON instruction.evenement=evenement.evenement
503     JOIN ".DB_PREFIXE."instructeur ON dossier.instructeur=instructeur.instructeur
504     JOIN ".DB_PREFIXE."om_utilisateur ON instructeur.om_utilisateur=om_utilisateur.om_utilisateur
505     JOIN ".DB_PREFIXE."om_collectivite ON om_collectivite.om_collectivite=om_utilisateur.om_collectivite
506     JOIN ".DB_PREFIXE."etat ON dossier.etat = etat.etat
507     WHERE
508    
509     (
510     evenement.type = 'arrete' AND
511     (
512     instruction.om_final_instruction IS TRUE
513     OR instruction.created_by_commune IS TRUE
514     ) OR
515     evenement.type = 'changement_decision'
516     )
517     AND evenement.retour IS FALSE
518     AND instruction.date_retour_signature IS NULL
519     AND instruction.date_envoi_rar IS NULL
520     AND instruction.date_retour_rar IS NULL
521     AND instruction.date_envoi_controle_legalite IS NULL
522     AND instruction.date_retour_controle_legalite IS NULL
523     AND etat.statut = 'encours'
524     AND dossier.dossier = '".$idx."'
525     AND om_collectivite.niveau = '2'
526     ";
527    
528    
529     // Si collectivité de l'utilisateur niveau mono alors filtre sur celle-ci
530     if ($this->isCollectiviteMono($_SESSION['collectivite']) === true) {
531     $sql .= " AND dossier.om_collectivite=".$_SESSION['collectivite'];
532     }
533     $res = $this->db->getone($sql);
534     if (database::isError($res)) {
535     die();
536     }
537     // Si le dossier n'est pas sujet au changement de decision
538     if($res == null) {
539     return false;
540     }
541     return true;
542     }
543    
544     // Ajout de variables de session contenant la division pour permettre une
545     // utilisation plus efficace dans les requetes
546     function triggerAfterLogin($utilisateur = NULL) {
547     //
548     $sql = "SELECT instructeur.division, division.code
549     FROM ".DB_PREFIXE."instructeur
550     LEFT JOIN ".DB_PREFIXE."division
551     ON instructeur.division = division.division
552     WHERE instructeur.om_utilisateur='".$utilisateur["om_utilisateur"]."'";
553     $res = $this->db->query($sql);
554     $this->addToLog("triggerAfterLogin(): db->query(\"".$sql."\");", VERBOSE_MODE);
555     if ( database::isError($res)){
556     die();
557     }
558     $row = $res->fetchrow(DB_FETCHMODE_ASSOC);
559     //
560     if (isset($row["division"]) && $row["division"] != NULL) {
561     $_SESSION["division"] = $row["division"];
562     $_SESSION["division_code"] = $row["code"];
563     } else {
564     $_SESSION["division"] = "0";
565     $_SESSION["division_code"] = "";
566     }
567    
568     }
569    
570     // Affichage des actions supplémentaires
571     function displayActionExtras() {
572     // Affichage de la division si l'utilisateur en possède une
573     if ($_SESSION["division"] != 0) {
574     echo "\t\t\t<li class=\"action-division\">";
575     echo "(".$_SESSION['division_code'].")";
576     echo "</li>\n";
577     }
578     }
579    
580     // }}}
581    
582    
583     function getDivisionFromDossier($dossier) {
584     //
585     $sql = "select division from ".DB_PREFIXE."dossier ";
586     $sql .= " where dossier='".$dossier."'";
587     //
588     $division = $this->db->getOne($sql);
589     $this->addToLog("getDivisionFromDossier(): db->getone(\"".$sql."\")", VERBOSE_MODE);
590     database::isError($division);
591     //
592     return $division;
593     }
594    
595     // {{{ GESTION DES FICHIERS
596    
597     /**
598     *
599     */
600     function notExistsError ($explanation = NULL) {
601     // message
602     $message_class = "error";
603     $message = _("Cette page n'existe pas.");
604     $this->addToMessage ($message_class, $message);
605     //
606     $this->setFlag(NULL);
607     $this->display();
608    
609     //
610     die();
611     }
612    
613     // }}}
614     /**
615     * Retourne le statut du dossier d'instruction
616     * @param string $idx Identifiant du dossier d'instruction
617     * @return string Le statut du dossier d'instruction
618     */
619     function getStatutDossier($idx){
620    
621     $statut = '';
622    
623     //Si l'identifiant du dossier d'instruction fourni est correct
624     if ( $idx != '' ){
625    
626     //On récupère le statut de l'état du dossier à partir de l'identifiant du
627     //dossier d'instruction
628     $sql = "SELECT etat.statut
629     FROM ".DB_PREFIXE."dossier
630     LEFT JOIN
631     ".DB_PREFIXE."etat
632     ON
633     dossier.etat = etat.etat
634     WHERE dossier ='".$idx."'";
635     $statut = $this->db->getOne($sql);
636     $this->addToLog("getStatutDossier() : db->getOne(\"".$sql."\")", VERBOSE_MODE);
637     if ( database::isError($statut)){
638     die();
639     }
640     }
641     return $statut;
642     }
643    
644     /**
645     * Formate le champ pour le type Timestamp
646     * @param date $date_str Date
647     * @param boolean $show Format pour l'affichage
648     * @return mixed False si le traitement échoue ou la date formatée
649     */
650     function formatTimestamp ($date_str, $show = true) {
651    
652     // Sépare la date et l'heure
653     $date = explode(" ", $date_str);
654     if (count($date) != 2) {
655     return false;
656     }
657    
658     // Date en BDD
659     $date_db = explode ('-', $date[0]);
660     // Date en affichage
661     $date_show = explode ('/', $date[0]);
662    
663     // Contrôle la composition de la date
664     if (count ($date_db) != 3 and count ($date_show) != 3) {
665     return false;
666     }
667    
668     if (count ($date_db) == 3) {
669     // Vérifie que c'est une date valide
670     if (!checkdate($date_db[1], $date_db[2], $date_db[0])) {
671     return false;
672     }
673     // Si c'est pour l'affichage de la date
674     if ($show == true) {
675     return $date_db [2]."/".$date_db [1]."/".$date_db [0]." ".$date[1];
676     } else {
677     return $date[0];
678     }
679     }
680    
681     //
682     if (count ($date_show) == 3) {
683     // Vérifie que c'est une date valide
684     if (!checkdate($date_show[1], $date_show[0], $date_show[2])) {
685     return false;
686     }
687     // Si c'est pour l'affichage de la date
688     if ($show == true) {
689     return $date[0];
690     } else {
691     return $date_show [2]."-".$date_show [1]."-".$date_show [0]." ".$date[1];
692     }
693    
694     }
695     return false;
696    
697     }
698    
699     /**
700     * Permet de calculer la liste des parcelles à partir de la chaîne passée en paramètre
701     * et la retourner sous forme d'un tableau associatif
702     *
703     * @param string $strParcelles Chaîne de la parcelles.
704     * @param string $collectivite_idx Collectivite de la parcelle.
705     *
706     * @return array (array(prefixe, quartier, section, parcelle), ...)
707     */
708     function parseParcelles($strParcelles, $collectivite_idx = null) {
709    
710     // Séparation des lignes
711     $references = explode(";", $strParcelles);
712     $liste_parcelles = array();
713    
714     // On boucle sur chaque ligne pour ajouter la liste des parcelles de chaque ligne
715     foreach ($references as $parcelles) {
716    
717     // On transforme la chaîne de la ligne de parcelles en tableau
718     $ref = str_split($parcelles);
719     // Les 1er caractères sont numériques
720     $num = true;
721    
722     // Tableau des champs de la ligne de références cadastrales
723     $reference_tab = array();
724     $temp = "";
725     foreach ($ref as $carac) {
726    
727     // Permet de tester si le caractère courant est de même type que le précédent
728     if(is_numeric($carac) === $num) {
729     $temp .= $carac;
730     } else {
731     // Bascule
732     $num = !$num;
733     // On stock le champ
734     $reference_tab[] = $temp;
735     // re-init de la valeur temporaire pour le champ suivant
736     $temp = $carac;
737     }
738     }
739     // Stockage du dernier champ sur lequel il n'y a pas eu de bascule
740     $reference_tab[] = $temp;
741     // Calcul des parcelles
742     $quartier = $reference_tab[0];
743     $sect = $reference_tab[1];
744    
745     $ancien_ref_parc = "";
746     for ($i=2; $i < count($reference_tab); $i+=2) {
747     if($collectivite_idx != null) {
748     // Récupération du code impot de l'arrondissement
749     $collectivite = $this->getCollectivite($collectivite_idx);
750     $parc["prefixe"] = $this->get_arrondissement_code_impot($quartier);
751     }
752     $parc["quartier"] = $quartier;
753     // Met en majuscule si besoin
754     $parc["section"] = strtoupper($sect);
755     if( $ancien_ref_parc == "" OR $reference_tab[$i-1] == "/") {
756     // 1ere parcelle ou parcelle individuelle
757     // Compléte par des "0" le début de la chaîne si besoin
758     $parc["parcelle"] = str_pad($reference_tab[$i], 4, "0", STR_PAD_LEFT);
759     // Ajout d'une parcelle à la liste
760     $liste_parcelles[] = $parc;
761     } elseif ($reference_tab[$i-1] == "A") {
762     // Interval de parcelles
763     for ($j=$ancien_ref_parc+1; $j <= $reference_tab[$i]; $j++) {
764     // Compléte par des "0" le début de la chaîne si besoin
765     $parc["parcelle"] = str_pad($j, 4, "0", STR_PAD_LEFT);
766     // Ajout d'une parcelle à la liste
767     $liste_parcelles[] = $parc;
768     }
769     }
770     //Gestion des erreurs
771     else{
772    
773     echo _("Une erreur de formattage a ete detecte dans la reference cadastrale du dossier ").$this->row['dossier'];
774     }
775     // Sauvegarde de la référence courante de parcelle
776     $ancien_ref_parc = $reference_tab[$i];
777     }
778     }
779    
780     return $liste_parcelles;
781     }
782    
783    
784     /**
785     * Récupère le code impôt par rapport au quartier.
786     *
787     * @param string $quartier Numéro de quartier.
788     * @return string Code impôts.
789     */
790     protected function get_arrondissement_code_impot($quartier) {
791     // Initialisation
792     $code_impots = "";
793     // Si le quartier fournis est correct
794     if ($quartier != "") {
795     // Requête SQL
796     $sql = "SELECT
797     arrondissement.code_impots
798     FROM
799     ".DB_PREFIXE."arrondissement
800     LEFT JOIN
801     ".DB_PREFIXE."quartier
802     ON
803     quartier.arrondissement = arrondissement.arrondissement
804     WHERE
805     quartier.code_impots = '".$quartier."'";
806    
807     }
808     $code_impots = $this->db->getOne($sql);
809     if ($code_impots === null) {
810     $code_impots = "";
811     }
812     $this->isDatabaseError($code_impots);
813     // Retour
814     return $code_impots;
815     }
816    
817    
818     /**
819     * Formate les parcelles en ajoutant le code impôt
820     * @param array $liste_parcelles Tableau des parcelles
821     * @return string Liste des parcelles formatées
822     */
823     function formatParcelleToSend($liste_parcelles) {
824    
825     //
826     $wParcelle = array();
827    
828     //Formatage des références cadastrales pour l'envoi
829     foreach ($liste_parcelles as $value) {
830    
831     // On ajoute les données dans le tableau que si quartier + section + parcelle
832     // a été fourni
833     if ($value["quartier"] !== ""
834     && $value["section"] !== ""
835     && $value["parcelle"] !== ""){
836    
837     //On récupère le code impôt de l'arrondissement
838     $arrondissement = $this->getCodeImpotByQuartier($value["quartier"]);
839    
840     //On ajoute la parcelle, si un arrondissement a été trouvé
841     if ($arrondissement!=="") {
842     //
843     $wParcelle[] = $arrondissement.$value["quartier"].
844     str_pad($value["section"], 2, " ", STR_PAD_LEFT).
845     $value["parcelle"];
846     }
847     }
848     }
849    
850     //
851     return $wParcelle;
852     }
853    
854     /**
855     * Récupère le code impôt par rapport au quartier
856     * @param string $quartier Numéro de quartier
857     * @return string Code impôt
858     */
859     function getCodeImpotByQuartier($quartier) {
860    
861     $arrondissement = "";
862    
863     // Si le quartier fournis est correct
864     if ($quartier != "") {
865    
866     // Requête SQL
867     $sql = "SELECT
868     arrondissement.code_impots
869     FROM
870     ".DB_PREFIXE."arrondissement
871     LEFT JOIN
872     ".DB_PREFIXE."quartier
873     ON
874     quartier.arrondissement = arrondissement.arrondissement
875     WHERE
876     quartier.code_impots = '".$quartier."'";
877     $this->addToLog("getCodeImpotByQuartier() : db->getOne(\"".$sql."\")", VERBOSE_MODE);
878     $arrondissement = $this->db->getOne($sql);
879     $this->isDatabaseError($arrondissement);
880     }
881    
882     // Retour
883     return $arrondissement;
884     }
885    
886    
887     /**
888     * Retourne true si tous les paramètres du SIG externe ont bien été définis
889     * @return bool true/false
890     */
891     public function issetSIGParameter($idx) {
892     $collectivite_idx = $this->get_collectivite_of_element("dossier", $idx);
893     $collectivite = $this->getCollectivite($collectivite_idx);
894     if(isset($collectivite["sig"])) {
895     return true;
896     } else {
897     return false;
898     }
899     }
900    
901     /**
902     * Permet de vérifier que des champs existe dans une table
903     * @param array $list_fields Liste des champs à tester
904     * @param string $table Table où les champs doivent exister
905     * @return mixed Retourne les champs qui n'existent pas
906     * ou true
907     */
908     public function check_field_exist($list_fields, $table) {
909    
910     // Instance de la classe en paramètre
911     require_once "../obj/".$table.".class.php";
912     $object = new $table("]", $this->db, DEBUG);
913    
914     // Récupère les champs de la table
915     foreach ($object->champs as $champ) {
916     $list_column[] = $champ;
917     }
918    
919     // Tableau des champs en erreur
920     $error_fields = array();
921    
922     // Pour chaque champ à tester
923     foreach ($list_fields as $value) {
924    
925     // S'il n'apparaît pas dans la liste des champs possible
926     if (!in_array($value, $list_column)) {
927    
928     // Alors le champ est ajouté au tableau des erreurs
929     $error_fields[] = $value;
930     }
931     }
932    
933     // Si le tableau des erreurs n'est pas vide on le retourne
934     if (count($error_fields) > 0) {
935     return $error_fields;
936     }
937    
938     // Sinon on retourne le booléen true
939     return true;
940    
941     }
942    
943     /*
944     *
945     */
946     /**
947     * Récupère la lettre type lié à un événement
948     * @param integer $evenement L'identifiant de l'événement
949     * @return integer Retourne l'idenfiant de la lettre-type ou true
950     */
951     function getLettreType($evenement){
952    
953     $lettretype = NULL;
954    
955     $sql =
956     "SELECT
957     lettretype
958     FROM
959     ".DB_PREFIXE."evenement
960     WHERE
961     evenement = $evenement";
962    
963     $this->addToLog("getLettreType() : db->query(\"".$sql."\")", VERBOSE_MODE);
964     $res = $this->db->query($sql);
965     if ( database::isError($res)){
966     die();
967     }
968    
969     if ( $res->numrows() > 0 ){
970    
971     $row=& $res->fetchRow(DB_FETCHMODE_ASSOC);
972     $lettretype = $row['lettretype'];
973     }
974    
975     return $lettretype;
976     }
977    
978     /**
979     * Retourne le type de dossier d'autorisation du dossier courant :
980     * @param $idxDossier Le numéro du dossier d'instruction
981     * @return le code du type détaillée de dossier d'autorisation
982     **/
983     function getDATDCode($idxDossier) {
984     $sql = "SELECT dossier_autorisation_type_detaille.code
985     FROM ".DB_PREFIXE."dossier_autorisation_type_detaille
986     INNER JOIN ".DB_PREFIXE."dossier_autorisation
987     ON dossier_autorisation_type_detaille.dossier_autorisation_type_detaille =
988     dossier_autorisation.dossier_autorisation_type_detaille
989     INNER JOIN ".DB_PREFIXE."dossier ON dossier.dossier_autorisation = dossier_autorisation.dossier_autorisation
990     WHERE dossier.dossier = '".$idxDossier."'";
991     $res = $this->db->getOne($sql);
992     $this->addToLog("getDATDCode() : db->getOne(\"".$sql."\")", VERBOSE_MODE);
993     if ( database::isError($res)){
994     die();
995     }
996     return $res;
997     }
998    
999     /**
1000 fmichon 4708 * Retourne le type de dossier d'autorisation du dossier courant :
1001     * @param $idxDossier Le numéro du dossier d'instruction
1002     * @return le code du type de dossier d'autorisation
1003     **/
1004     function getDATCode($idxDossier) {
1005     $sql = "
1006     SELECT
1007     dossier_autorisation_type.code
1008     FROM
1009     ".DB_PREFIXE."dossier_autorisation_type
1010     INNER JOIN ".DB_PREFIXE."dossier_autorisation_type_detaille
1011     ON dossier_autorisation_type.dossier_autorisation_type=dossier_autorisation_type_detaille.dossier_autorisation_type
1012     INNER JOIN ".DB_PREFIXE."dossier_autorisation
1013     ON dossier_autorisation_type_detaille.dossier_autorisation_type_detaille=dossier_autorisation.dossier_autorisation_type_detaille
1014     INNER JOIN ".DB_PREFIXE."dossier
1015     ON dossier.dossier_autorisation=dossier_autorisation.dossier_autorisation
1016     WHERE
1017     dossier.dossier = '".$idxDossier."'
1018     ";
1019     $res = $this->db->getOne($sql);
1020     $this->addToLog(__METHOD__."(): db->getOne(\"".$sql."\")", VERBOSE_MODE);
1021     if ( database::isError($res)){
1022     die();
1023     }
1024     return $res;
1025     }
1026    
1027     /**
1028 mbroquet 3730 * Permet de copier un enregistrement
1029     * @param mixed $idx Identifiant de l'enregistrment
1030     * @param string $obj Objet de l'enregistrment
1031     * @param string $objsf Objets associés
1032     * @return array Tableau des nouveaux id et du message
1033     */
1034     function copier($idx, $obj, $objsf) {
1035    
1036     // Tableau de résultat
1037     $resArray = array();
1038     // Message retourné à l'utilisateur
1039     $message = "";
1040     // Type du message (valid ou error)
1041     $message_type = "valid";
1042    
1043     // Requête SQL permettant de récupérer les informations sur l'objet métier
1044     $sql = "SELECT *
1045     FROM ".DB_PREFIXE.$obj."
1046     WHERE ".$obj." = ".$idx;
1047     $res = $this->db->query($sql);
1048     $this->isDatabaseError($res);
1049    
1050     // Valeurs clonées
1051     $valF = array();
1052     while ($row=& $res->fetchRow(DB_FETCHMODE_ASSOC)) {
1053     // Recupère la valeur
1054     $valF = $row;
1055     }
1056    
1057     // Valeurs non clonées
1058     // Identifiant modifié pour que ça soit un ajout
1059     $valF[$obj] = "]";
1060    
1061     // Inclus la classe de l'objet métier
1062     require_once "../obj/".$obj.".class.php";
1063    
1064     // Instance de l'objet métier
1065     $clone_obj = new $obj("]", $this->db, DEBUG);
1066     // Si dans l'objet métier la fonction "copier" existe
1067     if (method_exists($clone_obj, "update_for_copy")) {
1068     // Traitement sur les valeurs du duplicata
1069     $valF = $clone_obj->update_for_copy($valF, $objsf, DEBUG);
1070     // Recupère les messages retourné par la fonction
1071     $message .= $valF['message'];
1072     // Supprime les messages de la liste des valeurs
1073     unset($valF['message']);
1074     }
1075     // Ajoute le duplicata
1076     $clone_obj->ajouter($valF, $this->db, DEBUG);
1077     // Si aucune erreur se produit dans la classe instanciée
1078     if ($clone_obj->correct === true) {
1079     // Récupère l'identifiant de l'objet créé
1080     $clone_obj_id = $clone_obj->valF[$obj];
1081    
1082     // Message
1083     $message .= sprintf(_("La copie de l'enregistrement %s avec l'identifiant %s s'est effectuee avec succes"), "<span class='bold'>"._($obj)."</span>", "<span class='bold'>".$idx."</span>")."<br />";
1084    
1085     // Ajout de l'identifant au tableau des résultat
1086     $resArray[$obj.'_'.$idx] = $clone_obj_id;
1087    
1088     // S'il y a au moins un objet metier associé
1089     if ($objsf != "") {
1090     // Liste des objet métier associés
1091     $list_objsf = explode(",", $objsf);
1092     // Pour chaque objet associé
1093     foreach ($list_objsf as $key => $objsf) {
1094     // Inclus la classe de l'objet métier associé
1095     require_once "../obj/".$objsf.".class.php";
1096    
1097     // Requête SQL permettant de récupérer les informations sur
1098     // l'objet métier associé
1099     $sql = "SELECT *
1100     FROM ".DB_PREFIXE.$objsf."
1101     WHERE ".$obj." = ".$idx;
1102     $res = $this->db->query($sql);
1103     $this->isDatabaseError($res);
1104    
1105     // Pour chaque élément associé
1106     while ($row=& $res->fetchRow(DB_FETCHMODE_ASSOC)){
1107     // Identifiant de l'objet associé à copier
1108     $idxsf = $row[$objsf];
1109    
1110     // Valeurs clonées
1111     $valF = $row;
1112     // Valeurs non clonées
1113     $valF[$obj] = $clone_obj_id;
1114     // Identifiant modifié pour que ça soit un ajout
1115     $valF[$objsf] = "]";
1116     // Instance de l'objet métier associé
1117     $clone_objsf = new $objsf("]", $this->db, DEBUG);
1118     // Si dans l'objet métier associé
1119     // la fonction "copier" existe
1120     if (method_exists($clone_objsf, "update_for_copy")) {
1121     // Traitement sur les valeurs du duplicata
1122     $valF = $clone_objsf->update_for_copy($valF, $objsf, DEBUG);
1123     // Recupère les messages retourné par la fonction
1124     $message .= $valF['message'];
1125     // Supprime les messages de la liste des valeurs
1126     unset($valF['message']);
1127     }
1128     // Ajoute le duplicata
1129     $clone_objsf->ajouter($valF, $this->db, DEBUG);
1130     // Si aucune erreur se produit dans la classe instanciée
1131     if ($clone_objsf->correct === true) {
1132     // Récupère l'identifiant de l'objet créé
1133     $clone_objsf_id = $clone_objsf->valF[$objsf];
1134    
1135     // Message
1136     $message .= sprintf(_("La copie de l'enregistrement %s avec l'identifiant %s s'est effectuee avec succes"), "<span class='bold'>"._($objsf)."</span>", "<span class='bold'>".$idxsf."</span>")."<br />";
1137    
1138     // Ajout de l'identifant au tableau des résultat
1139     $resArray[$objsf.'_'.$row[$objsf]] = $clone_objsf_id;
1140     } else {
1141    
1142     // Message d'erreur récupéré depuis la classe
1143     $message .= $clone_objsf->msg;
1144     // Type du message
1145     $message_type = "error";
1146     }
1147     }
1148     }
1149     }
1150     //
1151     } else {
1152    
1153     // Message d'erreur récupéré depuis la classe
1154     $message .= $clone_obj->msg;
1155     // Type du message
1156     $message_type = "error";
1157     }
1158    
1159     // Ajout du message au tableau des résultats
1160     $resArray['message'] = $message;
1161     // Ajout du type de message au tableau des résultats
1162     $resArray['message_type'] = $message_type;
1163    
1164     // Retourne le tableau des résultats
1165     return $resArray;
1166     }
1167    
1168     /**
1169     * Cette fonction prend en entrée le ou les paramètres du &contrainte qui sont entre
1170     * parenthèses (un ensemble de paramètres séparés par des points-virgules). Elle
1171     * sépare les paramètres et leurs valeurs puis construit et retourne un tableau
1172     * associatif qui contient pour les groupes et sous-groupes :
1173     * - un tableau de valeurs, avec un nom de groupe ou sous-groupe par ligne
1174     * pour les autres options :
1175     * - la valeur de l'option
1176     *
1177     * @param string $contraintes_param Chaîne contenant tous les paramètres
1178     *
1179     * @return array Tableau associatif avec paramètres et valeurs séparés
1180     */
1181     function explodeConditionContrainte($contraintes_param) {
1182    
1183     // Initialisation des variables
1184     $return = array();
1185     $listGroupes = "";
1186     $listSousgroupes = "";
1187     $service_consulte = "";
1188     $affichage_sans_arborescence = "";
1189    
1190     // Sépare toutes les conditions avec leurs valeurs et les met dans un tableau
1191     $contraintes_params = explode(";", $contraintes_param);
1192    
1193     // Pour chaque paramètre de &contraintes
1194     foreach ($contraintes_params as $value) {
1195     // Récupère le mot-clé "liste_groupe" et les valeurs du paramètre
1196     if (strstr($value, "liste_groupe=")) {
1197     // On enlève le mots-clé "liste_groupe=", on garde les valeurs
1198     $listGroupes = str_replace("liste_groupe=", "", $value);
1199     }
1200     // Récupère le mot-clé "liste_ssgroupe" et les valeurs du paramètre
1201     if (strstr($value, "liste_ssgroupe=")) {
1202     // On enlève le mots-clé "liste_ssgroupe=", on garde les valeurs
1203     $listSousgroupes = str_replace("liste_ssgroupe=", "", $value);
1204     }
1205     // Récupère le mot-clé "service_consulte" et la valeur du paramètre
1206     if (strstr($value, "service_consulte=")) {
1207     // On enlève le mots-clé "service_consulte=", on garde sa valeur
1208     $service_consulte = str_replace("service_consulte=", "", $value);
1209     }
1210     // Récupère le mot-clé "affichage_sans_arborescence" et la valeur du
1211     // paramètre
1212     if (strstr($value, "affichage_sans_arborescence=")) {
1213     // On enlève le mots-clé "affichage_sans_arborescence=", on garde la valeur
1214     $affichage_sans_arborescence = str_replace("affichage_sans_arborescence=", "", $value);
1215     }
1216     }
1217    
1218     // Récupère dans des tableaux la liste des groupes et sous-groupes qui
1219     // doivent être utilisés lors du traitement de la condition
1220     if ($listGroupes != "") {
1221     $listGroupes = array_map('trim', explode(",", $listGroupes));
1222     }
1223     if ($listSousgroupes != "") {
1224     $listSousgroupes = array_map('trim', explode(",", $listSousgroupes));
1225     }
1226    
1227     // Tableau à retourner
1228     $return['groupes'] = $listGroupes;
1229     $return['sousgroupes'] = $listSousgroupes;
1230     $return['service_consulte'] = $service_consulte;
1231     $return['affichage_sans_arborescence'] = $affichage_sans_arborescence;
1232     return $return;
1233     }
1234    
1235     /**
1236     * Méthode qui complète la clause WHERE de la requête SQL de récupération des
1237     * contraintes, selon les paramètres fournis. Elle permet d'ajouter une condition sur
1238     * les groupes, sous-groupes et les services consultés.
1239     *
1240     * @param $string $part Contient tous les paramètres fournis à &contraintes séparés
1241     * par des points-virgules, tel que définis dans l'état.
1242     * array[] $conditions Paramètre optionnel, contient les conditions déjà explosées
1243     * par la fonction explodeConditionContrainte()
1244     *
1245     * @return string Contient les clauses WHERE à ajouter à la requête SQL principale.
1246     */
1247     function traitement_condition_contrainte($part, $conditions = NULL) {
1248    
1249     // Initialisation de la condition
1250     $whereContraintes = "";
1251     // Lorsqu'on a déjà les conditions explosées dans le paramètre $conditions, on
1252     // utilise ces données. Sinon, on appelle la méthode qui explose la chaîne de
1253     // caractères contenant l'ensemble des paramètres.
1254     if (is_array($conditions)){
1255     $explodeConditionContrainte = $conditions;
1256     }
1257     else {
1258     $explodeConditionContrainte = $this->explodeConditionContrainte($part);
1259     }
1260     // Récupère les groupes, sous-groupes et service_consulte pour la condition
1261     $groupes = $explodeConditionContrainte['groupes'];
1262     $sousgroupes = $explodeConditionContrainte['sousgroupes'];
1263     $service_consulte = $explodeConditionContrainte['service_consulte'];
1264    
1265     // Pour chaque groupe
1266     if ($groupes != "") {
1267     foreach ($groupes as $key => $groupe) {
1268     // Si le groupe n'est pas vide
1269     if (!empty($groupe)) {
1270     // Choisit l'opérateur logique
1271     $op_logique = $key > 0 ? 'OR' : 'AND (';
1272     // Ajoute la condition
1273     $whereContraintes .= " ".$op_logique." lower(trim(both E'\n\r\t' from contrainte.groupe)) = lower('"
1274     .pg_escape_string($groupe)."')";
1275     }
1276     }
1277     // S'il y a des valeurs dans groupe
1278     if (count($groupe) > 0) {
1279     // Ferme la parenthèse
1280     $whereContraintes .= " ) ";
1281     }
1282     }
1283    
1284     // Pour chaque sous-groupe
1285     if ($sousgroupes != "") {
1286     foreach ($sousgroupes as $key => $sousgroupe) {
1287     // Si le sous-groupe n'est pas vide
1288     if (!empty($sousgroupe)) {
1289     // Choisit l'opérateur logique
1290     $op_logique = $key > 0 ? 'OR' : 'AND (';
1291     // Ajoute la condition
1292     $whereContraintes .= " ".$op_logique." lower(trim(both E'\n\r\t' from contrainte.sousgroupe)) = lower('"
1293     .pg_escape_string($sousgroupe)."')";
1294     }
1295     }
1296     // S'il y a des valeurs dans sous-groupe
1297     if (count($sousgroupes) > 0) {
1298     // Ferme la parenthèse
1299     $whereContraintes .= " ) ";
1300     }
1301     }
1302    
1303     // Si l'option service_consulte n'est pas vide
1304     if ($service_consulte != "") {
1305     // Ajoute la condition
1306     $whereContraintes .= " AND service_consulte = cast(lower('".$service_consulte."') as boolean) ";
1307     }
1308    
1309     // Condition retournée
1310     return $whereContraintes;
1311     }
1312    
1313     /**
1314     * Calcule une date par l'ajout ou la soustraction de mois ou de jours.
1315     *
1316     * @param date $date Date de base (format dd-mm-yyyy)
1317     * @param integer $delay Délais à ajouter
1318     * @param string $operator Opérateur pour le calcul ("-" ou "+")
1319     * @param string $type Type de calcul (mois ou jour)
1320     *
1321     * @return date Date calculée
1322     */
1323     function mois_date($date, $delay, $operator = "+", $type = "mois") {
1324    
1325     // Si un type n'est pas définit
1326     if ($type != "mois" && $type != "jour") {
1327     //
1328     return null;
1329     }
1330    
1331     // Si aucune date n'a été fournie ou si ce n'est pas une date correctement
1332     // formatée
1333     if ( is_null($date) || $date == "" ||
1334     preg_match('/[0-9]{4}-[0-9]{2}-[0-9]{2}/', $date) == 0 ){
1335     return null;
1336     }
1337    
1338     // Si l'opérateur n'est pas définit
1339     if ($operator != "+" && $operator != "-") {
1340     //
1341     return null;
1342     }
1343    
1344     // Découpage de la date
1345     $temp = explode("-", $date);
1346     $day = (int) $temp[2];
1347     $month = (int) $temp[1];
1348     $year = (int) $temp[0];
1349    
1350     // Si c'est un calcul sur des mois
1351     // Le calcul par mois ne se fait pas comme le calcul par jour car
1352     // les fonctions PHP ne réalisent pas les calculs réglementaires
1353     if ($type == "mois") {
1354    
1355     // Si c'est une addition
1356     if ($operator == '+') {
1357     // Année à ajouter
1358     $year += floor($delay / 12);
1359     // Mois restant
1360     $nb_month = ($delay % 12);
1361     // S'il y a des mois restant
1362     if ($nb_month != 0) {
1363     // Ajout des mois restant
1364     $month += $nb_month;
1365     // Si ça dépasse le mois 12 (décembre)
1366     if ($month > 12) {
1367     // Soustrait 12 au mois
1368     $month -= 12;
1369     // Ajoute 1 à l'année
1370     $year += 1;
1371     }
1372     }
1373     }
1374    
1375     // Si c'est une soustraction
1376     if ($operator == "-") {
1377     // Année à soustraire
1378     $year -= floor($delay / 12);
1379     // Mois restant
1380     $nb_month = ($delay % 12);
1381     // S'il y a des mois restant
1382     if ($nb_month != 0) {
1383     // Soustrait le délais
1384     $month -= $nb_month;
1385     // Si ça dépasse le mois 1 (janvier)
1386     if ($month < 1) {
1387     // Soustrait 12 au mois
1388     $month += 12;
1389     // Ajoute 1 à l'année
1390     $year -= 1;
1391     }
1392     }
1393     }
1394    
1395     // Calcul du nombre de jours dans le mois sélectionné
1396     switch($month) {
1397     // Mois de février
1398     case "2":
1399     if ($year % 4 == 0 && $year % 100 != 0 || $year % 400 == 0) {
1400     $day_max = 29;
1401     } else {
1402     $day_max = 28;
1403     }
1404     break;
1405     // Mois d'avril, juin, septembre et novembre
1406     case "4":
1407     case "6":
1408     case "9":
1409     case "11":
1410     $day_max = 30;
1411     break;
1412     // Mois de janvier, mars, mai, juillet, août, octobre et décembre
1413     default:
1414     $day_max = 31;
1415     }
1416    
1417     // Si le jour est supérieur au jour maximum du mois
1418     if ($day > $day_max) {
1419     // Le jour devient le jour maximum
1420     $day = $day_max;
1421     }
1422    
1423     // Compléte le mois et le jour par un 0 à gauche si c'est un chiffre
1424     $month = str_pad($month, 2, "0", STR_PAD_LEFT);
1425     $day = str_pad($day, 2, "0", STR_PAD_LEFT);
1426    
1427     // Résultat du calcul
1428     $date_result = $year."-".$month."-".$day;
1429     }
1430    
1431     // Si c'est un calcul sur des jours
1432     if ($type == "jour") {
1433     //
1434     $datetime = new DateTime($date);
1435     // Si le délai est un numérique
1436     if (is_numeric($delay)) {
1437     // Modifie la date
1438     $datetime->modify($operator.$delay.' days');
1439     }
1440     // Résultat du calcul
1441     $date_result = $datetime->format('Y-m-d');
1442     }
1443    
1444     // Retourne la date calculée
1445     return $date_result;
1446     }
1447    
1448     /**
1449     * Vérifie la valididité d'une date.
1450     *
1451     * @param string $pDate Date à vérifier
1452     *
1453     * @return boolean
1454     */
1455     function check_date($pDate) {
1456    
1457     // Vérifie si c'est une date valide
1458     if (preg_match("/^([0-9]{4})-([0-9]{2})-([0-9]{2})$/", $pDate, $date)
1459     && checkdate($date[2], $date[3], $date[1])
1460     && $date[1] >= 1900) {
1461     //
1462     return true;
1463     }
1464    
1465     //
1466     return false;
1467     }
1468    
1469     /**
1470     * Permet de tester le bypass
1471     *
1472     * @param string $obj le nom de l'objet
1473     * @param string $permission_suffix
1474     * @return boolean
1475     */
1476     function can_bypass($obj="", $permission_suffix=""){
1477     //On teste le droit bypass
1478     if ($permission_suffix!=""&&$obj!=""&&
1479     $this->isAccredited($obj."_".$permission_suffix."_bypass")){
1480     return true;
1481     }
1482     return false;
1483     }
1484    
1485    
1486     /**
1487     * Vérifie l'option de numérisation.
1488     *
1489     * @return boolean
1490     */
1491     public function is_option_digitalization_folder_enabled() {
1492     //
1493     if ($this->getParameter("option_digitalization_folder") !== true) {
1494     //
1495     return false;
1496     }
1497     //
1498     return true;
1499     }
1500    
1501    
1502     /**
1503     * Vérifie que l'option d'accès au portail citoyen est activée.
1504     *
1505     * @return boolean
1506     */
1507     public function is_option_citizen_access_portal_enabled() {
1508     //
1509     $option = $this->getParameter("option_portail_acces_citoyen");
1510     //
1511     if ($option !== 'true') {
1512     //
1513     return false;
1514     }
1515    
1516     //
1517     return true;
1518     }
1519    
1520 nmeucci 4108 /**
1521 softime 4626 * Vérifie que l'option du SIG est activée.
1522     *
1523     * @return boolean
1524     */
1525     public function is_option_sig_enabled() {
1526     //
1527     $option = $this->getParameter("option_sig");
1528     //
1529 softime 4662 if ($option !== 'sig_externe' && $option !== 'sig_interne') {
1530 softime 4626 //
1531     return false;
1532     }
1533    
1534     //
1535     return true;
1536     }
1537    
1538     /**
1539 nmeucci 4108 * Vérifie le niveau de la collectivité de l'utilisateur connecté
1540     *
1541     * @return boolean
1542     */
1543     function has_collectivite_multi() {
1544     $idx_multi = $this->get_idx_collectivite_multi();
1545     if (intval($_SESSION['collectivite']) === intval($idx_multi)) {
1546     return true;
1547     }
1548     return false;
1549     }
1550 mbroquet 3730
1551 nmeucci 4108
1552 softime 3976 /**
1553     * Pour un path absolu donné, retourne le relatif à la racine de
1554     * l'application.
1555     *
1556     * @param string $absolute Chemin absolu.
1557     *
1558     * @return mixed Faux si échec sinon chemin relatif.
1559     */
1560     public function get_relative_path($absolute) {
1561     if ($this->get_path_app() === false) {
1562     return false;
1563     }
1564     $path_app = $this->get_path_app();
1565     return str_replace($path_app, '', $absolute);
1566     }
1567    
1568    
1569     /**
1570     * Retourne le path absolu de la racine de l'application
1571     *
1572     * @return mixed Faux si échec sinon chemin absolu
1573     */
1574     public function get_path_app() {
1575     $match = array();
1576     preg_match( '/(.*)\/[a-zA-Z0-9]+\/\.\.\/core\/$/', PATH_OPENMAIRIE, $match);
1577     // On vérifie qu'il n'y a pas d'erreur
1578     if (isset($match[1]) === false) {
1579     return false;
1580     }
1581     return $match[1];
1582     }
1583    
1584 nmeucci 3981 /**
1585     * Compose un tableau et retourne son code HTML
1586     *
1587     * @param string $id ID CSS du conteneur
1588     * @param array $headers entêtes de colonnes
1589     * @param array $rows lignes
1590     * @return string code HTML
1591     */
1592 nmeucci 3980 public function compose_generate_table($id, $headers, $rows) {
1593 nmeucci 3981 //
1594     $html = '';
1595 nmeucci 3980 // Début conteneur
1596 nmeucci 3981 $html .= '<div id="'.$id.'">';
1597 nmeucci 3980 // Début tableau
1598 nmeucci 3981 $html .= '<table class="tab-tab">';
1599 nmeucci 3980 // Début entête
1600 nmeucci 3981 $html .= '<thead>';
1601     $html .= '<tr class="ui-tabs-nav ui-accordion ui-state-default tab-title">';
1602 nmeucci 3980 // Colonnes
1603     $nb_colonnes = count($headers);
1604     $index_last_col = $nb_colonnes - 1;
1605     foreach ($headers as $i => $header) {
1606     if ($i === 0) {
1607     $col = ' firstcol';
1608     }
1609     if ($i === $index_last_col) {
1610     $col = ' lastcol';
1611     }
1612 nmeucci 3981 $html .= '<th class="title col-'.$i.$col.'">';
1613     $html .= '<span class="name">';
1614     $html .= $header;
1615     $html .= '</span>';
1616     $html .= '</th>';
1617 nmeucci 3980 }
1618     // Fin entête
1619 nmeucci 3981 $html .= '</tr>';
1620     $html .= '</thead>';
1621 nmeucci 3980 // Début corps
1622 nmeucci 3981 $html .= '<tbody>';
1623 nmeucci 3980 // Lignes
1624     foreach ($rows as $cells) {
1625     // Début ligne
1626 nmeucci 3981 $html .= '<tr class="tab-data">';
1627 nmeucci 3980 // Cellules
1628     foreach ($cells as $j => $cell) {
1629     if ($j === 0) {
1630     $col = ' firstcol';
1631     }
1632     if ($j === $index_last_col) {
1633     $col = ' lastcol';
1634     }
1635 nmeucci 3981 $html .= '<td class="title col-'.$j.$col.'">';
1636     $html .= '<span class="name">';
1637     $html .= $cell;
1638     $html .= '</span>';
1639     $html .= '</td>';
1640 nmeucci 3980 }
1641     // Fin ligne
1642 nmeucci 3981 $html .= "</tr>";
1643 nmeucci 3980 }
1644     // Fin corps
1645 nmeucci 3981 $html .= '</tbody>';
1646 nmeucci 3980 // Fin tableau
1647 nmeucci 3981 $html .= '</table>';
1648 nmeucci 3980 // Fin conteneur
1649 nmeucci 3981 $html .= '</div>';
1650     //
1651     return $html;
1652 nmeucci 3980 }
1653 nmeucci 4156
1654     /**
1655     * Retourne le login de l'utilisateur connecté + entre parenthèses son nom
1656     * s'il en a un.
1657     *
1658     * @return string myLogin OU myLogin (myName)
1659     */
1660     public function get_connected_user_login_name() {
1661     // Requête et stockage des informations de l'user connecté
1662     $this->getUserInfos();
1663     // Si le nom existe et est défini on le récupère
1664     $nom = "";
1665     if (isset($this->om_utilisateur["nom"])
1666     && !empty($this->om_utilisateur["nom"])) {
1667     $nom = trim($this->om_utilisateur["nom"]);
1668     }
1669     // Définition de l'émetteur : obligatoirement son login
1670     $emetteur = $_SESSION['login'];
1671     // Définition de l'émetteur : + éventuellement son nom
1672     if ($nom != "") {
1673     $emetteur .= " (".$nom.")";
1674     }
1675     // Retour
1676     return $emetteur;
1677     }
1678 nhaye 4218
1679     /**
1680 fmichon 4708 * Cette méthode permet d'interfacer le module 'Settings'.
1681     */
1682     function view_module_settings() {
1683     //
1684     require_once "../obj/settings.class.php";
1685     $settings = new settings();
1686     $settings->view_main();
1687     }
1688    
1689     /**
1690     * Interface avec le référentiel ERP.
1691     *
1692     * Est-ce que l'option est activée ?
1693     *
1694     * @return boolean
1695     */
1696     function is_option_referentiel_erp_enabled() {
1697     //
1698     if ($this->getParameter('option_referentiel_erp') !== 'true') {
1699     return false;
1700     }
1701     //
1702     return true;
1703     }
1704    
1705     /**
1706     * Interface avec le référentiel ERP.
1707     */
1708     function send_message_to_referentiel_erp($code, $infos) {
1709     //
1710     require_once "../obj/interface_referentiel_erp.class.php";
1711     $interface_referentiel_erp = new interface_referentiel_erp();
1712     $ret = $interface_referentiel_erp->send_message_to_referentiel_erp($code, $infos);
1713     return $ret;
1714     }
1715    
1716     /**
1717 nhaye 4218 * Récupère la liste des identifiants des collectivités
1718     *
1719     * @param string $return_type 'string' ou 'array' selon que l'on retourne
1720     * respectivement une chaîne ou un tableau
1721     * @param string $separator caractère(s) séparateur(s) employé(s) lorsque
1722     * l'on retourne une chaîne, inutilisé si tableau
1723     * @return mixed possibilité de boolean/string/array :
1724     * false si erreur BDD sinon résultat
1725     */
1726     public function get_list_id_collectivites($return_type = 'string', $separator = ',') {
1727     $sql = "
1728     SELECT
1729     array_to_string(
1730     array_agg(om_collectivite),
1731     '".$separator."'
1732     ) as list_id_collectivites
1733     FROM ".DB_PREFIXE."om_collectivite";
1734     $list = $this->db->getone($sql);
1735     $this->addTolog(
1736     __FILE__." - ".__METHOD__." : db->getone(\"".$sql."\");",
1737     VERBOSE_MODE
1738     );
1739     if ($this->isDatabaseError($list, true)) {
1740     return false;
1741     }
1742     if ($return_type === 'array') {
1743     return explode($separator, $list);
1744     }
1745     return $list;
1746     }
1747 mbroquet 3730 }
1748    
1749     ?>

[email protected]
ViewVC Help
Powered by ViewVC 1.1.26