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

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

Parent Directory Parent Directory | Revision Log Revision Log


Revision 4667 - (show 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 <?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 /**
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 // {{{
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 isset($conf[$sig_externe]["sig_treatment_mod"]) and
86 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 $collectivite_parameters["sig"]["sig_treatment_mod"] = $conf[$sig_externe]["sig_treatment_mod"];
93
94 } elseif($idx_multi != '' and
95 isset($conf[$sig_externe][$idx_multi]) and
96 isset($conf[$sig_externe]["sig_treatment_mod"]) and
97 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 $collectivite_parameters["sig"]["sig_treatment_mod"] = $conf[$sig_externe]["sig_treatment_mod"];
103 }
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 if($this->isAccredited(array("instruction", "instruction_changer_decision"), "OR") === false) {
465 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 /**
1474 * 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 if ($option !== 'sig_externe' && $option !== 'sig_interne') {
1483 //
1484 return false;
1485 }
1486
1487 //
1488 return true;
1489 }
1490
1491 /**
1492 * 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
1504
1505 /**
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 /**
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 public function compose_generate_table($id, $headers, $rows) {
1546 //
1547 $html = '';
1548 // Début conteneur
1549 $html .= '<div id="'.$id.'">';
1550 // Début tableau
1551 $html .= '<table class="tab-tab">';
1552 // Début entête
1553 $html .= '<thead>';
1554 $html .= '<tr class="ui-tabs-nav ui-accordion ui-state-default tab-title">';
1555 // 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 $html .= '<th class="title col-'.$i.$col.'">';
1566 $html .= '<span class="name">';
1567 $html .= $header;
1568 $html .= '</span>';
1569 $html .= '</th>';
1570 }
1571 // Fin entête
1572 $html .= '</tr>';
1573 $html .= '</thead>';
1574 // Début corps
1575 $html .= '<tbody>';
1576 // Lignes
1577 foreach ($rows as $cells) {
1578 // Début ligne
1579 $html .= '<tr class="tab-data">';
1580 // 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 $html .= '<td class="title col-'.$j.$col.'">';
1589 $html .= '<span class="name">';
1590 $html .= $cell;
1591 $html .= '</span>';
1592 $html .= '</td>';
1593 }
1594 // Fin ligne
1595 $html .= "</tr>";
1596 }
1597 // Fin corps
1598 $html .= '</tbody>';
1599 // Fin tableau
1600 $html .= '</table>';
1601 // Fin conteneur
1602 $html .= '</div>';
1603 //
1604 return $html;
1605 }
1606
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
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 }
1664
1665 ?>

[email protected]
ViewVC Help
Powered by ViewVC 1.1.26