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

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

Parent Directory Parent Directory | Revision Log Revision Log


Revision 4667 - (hide annotations)
Wed Jun 29 16:50:16 2016 UTC (8 years, 7 months ago) by softime
File size: 59260 byte(s)
* Amélioration - Ajout d'un profil "Administrateur technique et fonctionnel"
  possédant tous les droits.
  Ticket #8400.

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

[email protected]
ViewVC Help
Powered by ViewVC 1.1.26