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

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

Parent Directory Parent Directory | Revision Log Revision Log


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

[email protected]
ViewVC Help
Powered by ViewVC 1.1.26