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

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

Parent Directory Parent Directory | Revision Log Revision Log


Revision 6929 - (hide annotations)
Thu Jun 15 16:57:15 2017 UTC (7 years, 7 months ago) by softime
File size: 65757 byte(s)
* Merge de la 4.2.0

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

Properties

Name Value
svn:keywords "Id"

[email protected]
ViewVC Help
Powered by ViewVC 1.1.26