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

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

Parent Directory Parent Directory | Revision Log Revision Log


Revision 3216 - (show annotations)
Wed Dec 17 11:44:45 2014 UTC (10 years, 1 month ago) by vpihour
File size: 52781 byte(s)
L'instruteur a maintenant la possibilité de "marquer comme lu" une consultation sur un dossier d'instruction clôturé.

1 <?php
2 //$Id$
3 //gen openMairie le 10/02/2011 20:32
4 require_once ("../gen/obj/consultation.class.php");
5 require_once("../services/outgoing/messageenqueuer.php");
6
7 class consultation extends consultation_gen {
8
9 var $abstract_type = array(
10 "fichier" => "file",
11 );
12
13 var $metadata = array(
14 "om_fichier_consultation" => array(
15 "dossier" => "getDossier",
16 "dossier_version" => "getDossierVersion",
17 "numDemandeAutor" => "getNumDemandeAutor",
18 "anneemoisDemandeAutor" => "getAnneemoisDemandeAutor",
19 "typeInstruction" => "getTypeInstruction",
20 "statutAutorisation" => "getStatutAutorisation",
21 "typeAutorisation" => "getTypeAutorisation",
22 "dateEvenementDocument" => "getDateEvenementDocument",
23 "groupeInstruction" => 'getGroupeInstruction',
24 "title" => 'getTitle',
25 ),
26 "fichier" => array(
27 "filename" => "getFichierFilename",
28 "dossier" => "getDossier",
29 "dossier_version" => "getDossierVersion",
30 "numDemandeAutor" => "getNumDemandeAutor",
31 "anneemoisDemandeAutor" => "getAnneemoisDemandeAutor",
32 "typeInstruction" => "getTypeInstruction",
33 "statutAutorisation" => "getStatutAutorisation",
34 "typeAutorisation" => "getTypeAutorisation",
35 "dateEvenementDocument" => "getDateEvenementDocument",
36 "groupeInstruction" => 'getGroupeInstruction',
37 "title" => 'getTitle',
38 ),
39 );
40
41 function consultation($id,&$db,$debug) {
42 $this->constructeur($id,$db,$debug);
43 }// fin constructeur
44
45 // {{{ Gestion de la confidentialité des données spécifiques
46
47 /**
48 * Surcharge pour gérer les actions disponibles dans le portlet
49 */
50 function checkAccessibility() {
51 //
52 parent::checkAccessibility();
53 // Si l'utilisateur est un intructeur qui en correspond pas à la
54 // division du dossier
55 if ($this->f->isUserInstructeur()
56 && isset($this->f->om_utilisateur["division"])
57 && $this->f->om_utilisateur["division"] != $this->getDivisionFromDossier()) {
58 //
59 $this->parameters["actions"]["modifier"] = NULL;
60 $this->parameters["actions"]["supprimer"] = NULL;
61 $this->actions_sup["finalisation"] = NULL;
62 $this->actions_sup["definalisation"] = NULL;
63 $this->actions_sup["lu"] = NULL;
64 }
65 // Si une action 'lu' est présente et que le champ lu est à true
66 // on supprime l'action
67 if (isset($this->actions_sup["lu"])
68 && isset($this->val[array_search("lu", $this->champs)])
69 && $this->val[array_search("lu", $this->champs)]== "t") {
70 unset($this->actions_sup["lu"]);
71 }
72
73 //Si le document est déjà finalisé, le lien de l'édition est celui du stockage
74 $om_final_consultation = $this->getVal("om_final_consultation");
75 if ( $om_final_consultation== "t" ){
76
77 //On affiche le bon lien pour l'édition
78 $this->actions_sup["pdfetat"]["lien"] = "../spg/file.php?id=";
79 $this->actions_sup["pdfetat"]["id"] =
80 "&amp;obj=consultation&amp;champ=om_fichier_consultation";
81 //On cache les liens d'action
82 $this->parameters["actions"]["modifier"] = NULL;
83 $this->parameters["actions"]["supprimer"] = NULL;
84 $this->actions_sup["finalisation"] = NULL;
85 }
86 //Si le document n'est pas finalisé, le lien de l'édition est le lien de
87 //génération à la volée
88 if ( $om_final_consultation!= "t" ){
89
90 //On affiche le bon lien pour l'édition
91 $this->actions_sup["pdfetat"]["lien"] = "../app/pdf_consultation.php?idx=";
92 $this->actions_sup["pdfetat"]["id"] = "&obj=consultation";
93 $this->actions_sup["definalisation"] = NULL;
94 if( $this->f->isUserInstructeur() ){
95 $this->parameters["actions"]["modifier"] = NULL;
96 }
97 }
98
99 $idxformulaire = $this->getParameter("idxformulaire");
100 $retourformulaire = $this->getParameter("retourformulaire");
101 //Si le dossier d'instruction auquel est rattachée la consultation est
102 //cloturé, on affiche pas les liens du portlet
103 if ( $idxformulaire != '' &&
104 (
105 $retourformulaire == 'dossier' ||
106 $retourformulaire == 'dossier_instruction' ||
107 $retourformulaire == 'dossier_instruction_mes_encours' ||
108 $retourformulaire == 'dossier_instruction_tous_encours' ||
109 $retourformulaire == 'dossier_instruction_mes_clotures' ||
110 $retourformulaire == 'dossier_instruction_tous_clotures'
111 )){
112
113 //On récuppère le statut du dossier d'instruction
114 $statut = $this->f->getStatutDossier($idxformulaire);
115 if ( $this->f->isUserInstructeur() && $statut == "cloture" ){
116
117 //On cache le lien de modification
118 $this->parameters["actions"]["modifier"] = NULL;
119 $this->parameters["actions"]["supprimer"] = NULL;
120 $this->actions_sup["finalisation"] = NULL;
121 $this->actions_sup["definalisation"] = NULL;
122
123 // On affiche l'action "marquer comme lu" uniquement si la
124 // consultation n'a pas été lue
125 if ($this->getVal("lu")== "t"){
126 $this->actions_sup["lu"] = NULL;
127 }
128 }
129 }
130 }
131
132 /**
133 * Cette methode est à surcharger elle permet de tester dans chaque classe
134 * des droits des droits spécifiques en fonction des données
135 */
136 function canAccess() {
137 // Si l'utilisateur est un utilisateur de service externe
138 // on vérifie qu'il peut accéder à la consultation
139 if ($this->f->isUserService()) {
140 // On compare l'id du service de la consultation
141 // aux id des services de utilisateur connecté
142 foreach($this->f->om_utilisateur['service'] as $service) {
143 if($this->val[array_search("service",$this->champs)]===$service['service']) {
144 return true;
145 }
146 }
147 //
148 $this->f->addToLog("canAccess(): utilisateur de service sur une consultation d'un autre service", EXTRA_VERBOSE_MODE);
149 return false;
150 }
151 // Si l'utilisateur est un intructeur qui ne correspond pas à la
152 // division du dossier
153 if ($this->f->isUserInstructeur()
154 && $this->f->om_utilisateur["division"] != $this->getDivisionFromDossier()
155 && $this->getParameter("maj") != 3) {
156 //
157 $this->f->addToLog("canAccess(): utilisateur instructeur sur un dossier d'une autre division", EXTRA_VERBOSE_MODE);
158 return false;
159 }
160
161 $retourformulaire = $this->getParameter("retourformulaire");
162 // Si l'utilisateur est un instructeur et que le dossier est cloturé
163 if ( $this->f->isUserInstructeur() &&
164 $this->f->getStatutDossier($this->getParameter("idxformulaire")) == "cloture" &&
165 (
166 $retourformulaire == 'dossier' ||
167 $retourformulaire == 'dossier_instruction' ||
168 $retourformulaire == 'dossier_instruction_mes_encours' ||
169 $retourformulaire == 'dossier_instruction_tous_encours' ||
170 $retourformulaire == 'dossier_instruction_mes_clotures' ||
171 $retourformulaire == 'dossier_instruction_tous_clotures'
172 ) &&
173 $this->getParameter("maj") != 3) {
174
175 return false;
176 }
177 //
178 return true;
179 }
180
181 /**
182 * Cette variable permet de stocker le résultat de la méthode
183 * getDivisionFromDossier() afin de ne pas effectuer le recalcul à chacun de
184 * ces appels.
185 * @var string Code de la division du dossier en cours
186 */
187 var $_division_from_dossier = NULL;
188
189 /**
190 * Cette méthode permet de récupérer le code de division correspondant
191 * au dossier sur lequel on se trouve.
192 *
193 * @return string Code de la division du dossier en cours
194 */
195 function getDivisionFromDossier() {
196
197 // Cette méthode peut être appelée plusieurs fois lors d'une requête.
198 // Pour éviter de refaire le traitement de recherche de la division
199 // alors on vérifie si nous ne l'avons pas déjà calculé.
200 if ($this->_division_from_dossier != NULL) {
201 // Logger
202 $this->addToLog("getDivisionFromDossier(): retour de la valeur déjà calculée - '".$this->_division_from_dossier."'", EXTRA_VERBOSE_MODE);
203 // On retourne la valeur déjà calculée
204 return $this->_division_from_dossier;
205 }
206
207 // Par défaut, on définit la valeur du dossier à NULL
208 $dossier = NULL;
209 // Test sur le mode et le contexte du formulaire
210 if ($this->getParameter("maj") == 0
211 && ($this->getParameter("retourformulaire") == "dossier"
212 || $this->getParameter("retourformulaire") == "dossier_instruction"
213 || $this->getParameter("retourformulaire") == "dossier_instruction_mes_encours"
214 || $this->getParameter("retourformulaire") == "dossier_instruction_tous_encours"
215 || $this->getParameter("retourformulaire") == "dossier_instruction_mes_clotures"
216 || $this->getParameter("retourformulaire") == "dossier_instruction_tous_clotures")) {
217 // Si on se trouve en mode AJOUT (seul mode où l'enregistrement
218 // n'existe pas en base de données) ET que nous nous trouvons
219 // dans le contexte d'un dossier d'instruction alors on récupère
220 // le numéro de dossier depuis le paramètre 'idxformulaire'
221 $dossier = $this->getParameter("idxformulaire");
222 } else {
223 // Sinon on récupère le numéro de dossier dans le champs dossier de
224 // l'enregistrement (en base de données)
225 $dossier = $this->getVal("dossier");
226 }
227
228 // On appelle la méthode de la classe utils qui renvoi le code de la
229 // division d'un dossier, on la stocke pour ne pas refaire le calcul au
230 // prochain appel de cette méthode
231 $this->_division_from_dossier = $this->f->getDivisionFromDossier($dossier);
232 // Logger
233 $this->addToLog("getDivisionFromDossier(): retour de la valeur nouvellement calculée - '".$this->_division_from_dossier."'", EXTRA_VERBOSE_MODE);
234 // On retourne la valeur retournée
235 return $this->_division_from_dossier;
236
237 }
238
239 // }}}
240
241 function setValsousformulaire(&$form,$maj,$validation,$idxformulaire,$retourformulaire,$typeformulaire){
242 // ajout du retourformulaire aux attributs de l'objet
243 $this->retourformulaire = $retourformulaire;
244 if ($validation==0) {
245 if ($maj == 0){
246 $form->setVal("dossier", $idxformulaire);
247 $form->setVal("date_envoi",date('d/m/Y'));
248 }
249 if($maj == 1) {
250 if($this->f->isAccredited('consultation_retour_avis_suivi') OR
251 $this->f->isAccredited('consultation_retour_avis_service')) {
252 $form->setVal("date_retour",date('d/m/Y'));
253 }
254 }
255 }
256 }
257
258 function setVal(&$form, $maj, $validation, &$db) {
259 if($maj == 1) {
260 $form->setVal("date_retour",date('d/m/Y'));
261 }
262 }
263
264 function setvalF($val) {
265 //
266 parent::setValF($val);
267 //
268 if ($this->getParameter('maj') == 0) {
269 //
270 if (isset($this->valF["date_envoi"])) {
271 $this->valF["date_reception"] = $this->valF["date_envoi"];
272 }
273 //
274 $this->valF["lu"] = true;
275 }
276
277 // Si un retour d'avis est modifie on passe "lu" a false
278 if($this->getParameter('maj')==1 AND (
279 $this->val[array_search("avis_consultation",$this->champs)] != $val["avis_consultation"] OR
280 $this->val[array_search("date_retour",$this->champs)] != $val["date_retour"] OR
281 $this->val[array_search("motivation",$this->champs)] != $val["motivation"] OR
282 $this->val[array_search("fichier",$this->champs)] != $val["fichier"])
283 ) {
284 $this->valF["lu"]=false;
285 }
286 }
287
288 function setLib(&$form, $maj) {
289 //
290 parent::setLib($form, $maj);
291 //
292 $form->setLib($this->clePrimaire, _("id"));
293 }
294
295 function setType(&$form,$maj) {
296 // Appel du parent
297 parent::setType($form,$maj);
298 $form->setType('dossier', 'hidden');
299 // MODE - AJOUTER
300 if ($maj == 0) {
301 // On cache alors tous les champs que nous ne voulons pas voir
302 // apparaître dans le formulaire d'ajout (principalement les
303 // informations sur le retour d'avis)
304 $form->setType('date_retour', 'hiddendate');
305 $form->setType('date_reception', 'hiddendate');
306 $form->setType('date_limite', 'hiddendate');
307 $form->setType('avis_consultation', 'hidden');
308 $form->setType('motivation', 'hidden');
309 $form->setType('fichier', 'hidden');
310 $form->setType('lu', 'hidden');
311 // On permet la modification de certains champs
312 $form->setType('dossier_libelle', 'hiddenstatic');
313 $form->setType('service', 'select');
314 $form->setType('date_envoi', 'date2');
315 }
316 // MODE - MODIFIER
317 if ($maj == 1) {
318
319 // On affiche en statique les informations qui ne sont plus
320 // modifiables
321 $form->setType('dossier_libelle', 'hiddenstatic');
322 $form->setType('date_envoi', 'hiddenstaticdate');
323 $form->setType('date_limite', 'hiddenstaticdate');
324 $form->setType('service', 'selecthiddenstatic');
325
326 // La date de réception ne peut être modifiée que par un
327 // utilisateur en ayant spécifiquement la permission
328 if($this->f->isAccredited('consultation_modifier_date_reception')) {
329 $form->setType('date_reception', 'date2');
330 } else {
331 $form->setType('date_reception', 'hiddenstaticdate');
332 }
333
334 // Le marqueur lu/non lu ne peut être modifié que par un
335 // utilisateur en ayant spécifiquement la permission
336 if ($this->f->isAccredited('consultation_modifier_lu')) {
337 $form->setType('lu', 'checkbox');
338 } else {
339 $form->setType('lu', 'hidden');
340 }
341
342 // Gestion du type du widget sur le champ fichier
343 if($this->getVal("fichier") == "" OR
344 $this->f->isAccredited('consultation_modifier_fichier')) {
345 // Si il n'y a jamais eu de fichier enregistré ou que
346 // l'utilisateur a spécifiquement les droits pour modifier
347 // un fichier déjà enregistré alors on positionne un type
348 // de widget modifiable
349 if ($this->retourformulaire == "demande_avis_encours"
350 || $this->retourformulaire == "dossier_qualifier"
351 || $this->retourformulaire == "dossier"
352 || $this->retourformulaire == "dossier_instruction"
353 || $this->retourformulaire == "dossier_instruction_mes_encours"
354 || $this->retourformulaire == "dossier_instruction_tous_encours"
355 || $this->retourformulaire == "dossier_instruction_mes_clotures"
356 || $this->retourformulaire == "dossier_instruction_tous_clotures") {
357 $form->setType('fichier', 'upload2');
358 } else {
359 $form->setType('fichier', 'upload');
360 }
361 } else {
362 // Si non on affiche uniquement le nom du fichier
363 $form->setType('fichier', 'file');
364 }
365
366 // Modification layout : écran de retour d'avis permettant
367 // uniquement la saisie des trois champs : avis, motivation et fichier
368 if (!$this->f->isAccredited('consultation_consulter_autre_que_retour_avis')) {
369
370 // On cache alors tous les champs que nous ne voulons pas voir
371 $form->setType('dossier_libelle', 'hidden');
372 $form->setType('service', 'hidden');
373 $form->setType('date_envoi', 'hiddendate');
374 $form->setType('date_retour', 'hiddendate');
375 $form->setType('date_reception', 'hiddendate');
376 $form->setType('date_limite', 'hiddendate');
377 $form->setType('lu', 'hidden');
378
379 }
380
381 }
382 // Mode supprimer
383 if ($maj == 2) {
384 $form->setType('fichier', 'filestatic');
385 }
386 // MODE - CONSULTER
387 if ( $maj == 3 ) {
388 $form->setType('fichier', 'file');
389 }
390 //// On cache la clé primaire
391 //$form->setType('consultation', 'hidden');
392 //
393 if ($this->getParameter("retourformulaire") == "dossier"
394 || $this->getParameter("retourformulaire") == "dossier_instruction"
395 || $this->getParameter("retourformulaire") == "dossier_instruction_mes_encours"
396 || $this->getParameter("retourformulaire") == "dossier_instruction_tous_encours"
397 || $this->getParameter("retourformulaire") == "dossier_instruction_mes_clotures"
398 || $this->getParameter("retourformulaire") == "dossier_instruction_tous_clotures") {
399 //
400 $form->setType('dossier_libelle', 'hidden');
401 }
402
403 $form->setType('code_barres', 'hidden');
404
405 //Cache les champs pour la finalisation
406 $form->setType('om_fichier_consultation', 'hidden');
407 $form->setType('om_final_consultation', 'hidden');
408 }
409
410 // Cette méthode permet de calculer la date limite en fonction de la date
411 // de réception et du délai de consultation du service consulté
412 function calculDateLimite() {
413 // mise a jour instruction avec evenement [return delay]
414 if ($this->valF["date_reception"] != "") {
415 //
416 $sql = " select delai from ".DB_PREFIXE."service ";
417 $sql .= " where service='".$this->valF["service"]."' ";
418 //
419 $delai = $this->db->getOne($sql);
420 $this->addToLog("triggerajouter(): db->getone(\"".$sql."\")", VERBOSE_MODE);
421 //
422 $this->valF["date_limite"] = $this->f->mois_date($this->valF["date_reception"], $delai);
423 //
424 $this->addToMessage(_("delai")." ".
425 _("retour")." ".$delai." "._("mois")." -> ".
426 _("retour")." ".date("d/m/Y", strtotime($this->valF["date_limite"])));
427 }
428 }
429
430 // TRIGGER AVANT MODIFICATION DE DONNEES
431 // trigger before modification data
432 function triggerajouter($id,&$db,$val,$DEBUG) {
433 //
434 $this->calculDateLimite();
435
436 // Identifiant du type de courrier
437 $idTypeCourrier = '12';
438 $idCourrier = str_pad($this->valF["consultation"], 10, "0", STR_PAD_LEFT);
439 // Code barres
440 $this->valF["code_barres"] = $idTypeCourrier . $idCourrier;
441 }
442
443 //
444 function triggermodifier($id,&$db,$val,$DEBUG) {
445 //
446 $this->calculDateLimite();
447 }
448
449 //
450 function triggerajouterapres($id,&$db,$val,$DEBUG) {
451
452 // Verification de la demande de notif par mail
453 $sql= "SELECT abrege, libelle, notification_email, email FROM ".DB_PREFIXE.
454 "service WHERE service ='".$this->valF['service']."'";
455 $res=$db->query($sql);
456 $notif = $res->fetchrow(DB_FETCHMODE_ASSOC);
457 if (database :: isError($sql))die($res->getMessage()."erreur ".$sql);
458 if ($notif['notification_email']=='t') {
459
460 // Recuperation des infos du dossier
461 $sql= "SELECT dossier, terrain_adresse_voie_numero, terrain_adresse_voie, terrain_adresse_code_postal, terrain_adresse_localite
462 FROM ".DB_PREFIXE."dossier WHERE dossier ='".$this->valF['dossier']."'";
463 $res=$db->query($sql);
464 $dossier = $res->fetchrow(DB_FETCHMODE_ASSOC);
465
466 // Definition des parametres d'envoi du mail
467 $title=_("Consultation de services : dossier no")." ".$dossier['dossier'];
468 $corps=_("Votre service est consulte concernant le dossier no")." ".$dossier['dossier']."<br/>".
469 _("Il concerne le terrain situe a l'adresse :")." ".$dossier['terrain_adresse_voie_numero'].
470 " ".$dossier['terrain_adresse_voie']." ".$dossier['terrain_adresse_code_postal']." ".$dossier['terrain_adresse_localite']."<br/>".
471 _("Vous pouvez y acceder et rendre votre avis a l'adresse")." <a href='".$this->f->getParameter('services_consultes_lien_interne').
472 // On ajoute l'idx, s'il y a besoin
473 ((substr($this->f->getParameter('services_consultes_lien_interne'), -5)=="&idx=")?$this->valF['consultation']:"")."'>".
474 _("Lien interne (services VDM)")."</a> "._("ou")." <a href='".$this->f->getParameter('services_consultes_lien_externe').
475 // On ajoute l'idx, s'il y a besoin
476 ((substr($this->f->getParameter('services_consultes_lien_externe'), -5)=="&idx=")?$this->valF['consultation']:"")."'>".
477 _("Lien externe (hors VDM)")."</a>";
478 // Envoi du mail avec message de retour
479 if($this->f->sendMail(iconv("UTF-8", "CP1252", $title), iconv("UTF-8", "CP1252", $corps), iconv("UTF-8", "CP1252", $notif['email']))) {
480 $this->addToMessage(_("Envoi d'un mail de notification au service")." \"(".$notif['abrege'].") ".$notif["libelle"]."\"");
481 } else {
482 $this->addToMessage(_("L'envoi du mail de notification a echoue"));
483 }
484 }
485
486
487 // verification si envoi vers ERP est active
488 if ($this->f->getParameter('option_erp') === 'true') {
489 // s'il s'agit de la consultation ERP Secu, ERP Accessibilite, ou
490 // deenvoie un
491 // message a ERP
492 $dossier_erp = $this->getFromDB("SELECT erp FROM ".DB_PREFIXE.
493 "dossier WHERE dossier = '" .$this->valF['dossier'] . "'");
494 $dossier_nature = $this->getFromDB("SELECT dossier_autorisation_type_detaille.code FROM ".DB_PREFIXE.
495 "dossier
496 INNER JOIN ".DB_PREFIXE."dossier_autorisation
497 ON dossier.dossier_autorisation=dossier_autorisation.dossier_autorisation
498 INNER JOIN ".DB_PREFIXE."dossier_autorisation_type_detaille
499 ON dossier_autorisation.dossier_autorisation_type_detaille
500 = dossier_autorisation_type_detaille.dossier_autorisation_type_detaille
501 WHERE dossier = '" . $this->valF['dossier'] . "'");
502 if ($dossier_erp == 't'
503 && substr($dossier_nature, 0, 2) == $this->f->getParameter('erp_dossier_nature_pc')) {
504 // envoi du message "Demande d'instruction d'un dossier PC pour un ERP"
505 if (($this->valF['service'] == $this->f->getParameter('erp_service_accessibilite')
506 || $this->valF['service'] == $this->f->getParameter('erp_service_securite'))) {
507 $msgenque = new MessageEnqueuer();
508 $msgenque->setDossierInstructionIdentifier($this->valF['dossier']);
509 $msgenque->setConsultationIdentifier($this->valF['consultation']);
510 $return = $msgenque->enqueueMessage($msgenque::$ERP_DEMANDE_INSTRUCTION_PC);
511 //Si une erreur s'est produite on arrête le traitement et on
512 //retourne une erreur
513 if ($return !== 0){
514
515 $this->addToMessage(_("Une erreur s'est produite lors de ".
516 "l'envoi du message au referentiel ERP. Merci de ".
517 "contacter votre administrateur"));
518 //On ne valide pas le formulaire
519 $this->addToMessage("<br/>"._("SAISIE NON ENREGISTREE")."<br/>");
520 $this->correct = false;
521 return false;
522 }
523 else {
524 $this->addToMessage(_("Le message a ete transmis au ".
525 "referentiel ERP."));
526 }
527 }
528
529 // envoi du message "Consultation ERP pour conformite" en cas de creation de la
530 // consultation du service ERP Conformite
531 if ($this->valF['service'] == $this->f->getParameter('erp_service_conformite')) {
532 $msgenque = new MessageEnqueuer();
533 $msgenque->setDossierInstructionIdentifier($this->valF['dossier']);
534 $msgenque->setConsultationIdentifier($this->valF['consultation']);
535 $return = $msgenque->enqueueMessage($msgenque::$ERP_CONSULTATION_CONFORMITE);
536 //Si une erreur s'est produite on arrête le traitement et on
537 //retourne une erreur
538 if ($return !== 0){
539
540 $this->addToMessage(_("Une erreur s'est produite lors de ".
541 "l'envoi du message au referentiel ERP. Merci de ".
542 "contacter votre administrateur"));
543 //On ne valide pas le formulaire
544 $this->addToMessage("<br/>"._("SAISIE NON ENREGISTREE")."<br/>");
545 $this->correct = false;
546 return false;
547 }
548 else {
549 $this->addToMessage(_("Le message a ete transmis au ".
550 "referentiel ERP."));
551 }
552 }
553 }
554 } // fin de if($this->f->getParameter('option_erp') === 'true')
555
556 // Finalisation du document
557 $this->finaliserAjouter();
558 }
559
560 /**
561 * Fait une requette sql pour extraire la valeur d'un champ, et retourne
562 * cette valeur
563 * @param string $sql La requete sql a executer
564 * @return La valeur du champs cherche, sinon NULL. En cas d'erreur de la BD
565 * l'execution s'arrete.
566 */
567 function getFromDB($sql) {
568 //$sql = "SELECT libelle FROM ".DB_PREFIXE."dossier WHERE dossier = '" . $dossier . "'";
569 $res = $this->db->limitquery($sql, 0, 1);
570 $this->f->addToLog("getDossierERPSpecification(): db->limitquery(\"".
571 str_replace(",",", ",$sql)."\", 0, 1);", VERBOSE_MODE);
572 // Si une erreur survient on die
573 if (database::isError($res, true)) {
574 // Appel de la methode de recuperation des erreurs
575 $this->erreur_db($res->getDebugInfo(), $res->getMessage(), 'instruction');
576 }
577 // retourne la nature du dossier
578 while ($row =& $res->fetchRow()) {
579 return $row[0];
580 }
581 // la nature n'etait pas trouve, ce qui ne devrait pas se passer
582 return NULL;
583
584 }
585
586 // =============================================
587 // Ajout du fielset
588 // Add fieldset
589 // =============================================
590 function setLayout(&$form, $maj){
591
592 // Modification layout : écran de retour d'avis permettant
593 // uniquement la saisie des trois champs : avis, motivation et fichier
594 if ($this->f->isAccredited('consultation_consulter_autre_que_retour_avis')) {
595
596 //Champs sur lequel s'ouvre le fieldset
597 $form->setBloc('dossier','D',"");
598 $form->setFieldset('dossier','D',_('Consultation'));
599
600 //Champs sur lequel se ferme le fieldset
601 $form->setFieldset('date_envoi','F','');
602 $form->setBloc('date_envoi','F');
603
604 }
605
606 // MODE - autre que AJOUTER alors on affiche un fieldset retour
607 // d'avis
608 if ($maj != 0) {
609
610 //Champs sur lequel s'ouvre le fieldset
611 $form->setBloc('date_reception','D',"");
612 $form->setFieldset('date_reception','D',_('Retour d\'avis'));
613
614 //Champs sur lequel se ferme le fieldset
615 $form->setFieldset('lu','F','');
616 $form->setBloc('lu','F');
617
618 }
619 }
620
621 /** Surcharge de la methode retour afin de retourner sur la page de saisie de
622 * code barre si besoin
623 **/
624 function retour($premier = 0, $recherche = "", $tricol = "") {
625 $params ="obj=".get_class($this);
626 if($this->getParameter("retour")=="form") {
627 $params .= "&amp;idx=".$this->getParameter("idx");
628 $params .= "&amp;action=3";
629 }
630 $params .= "&amp;premier=".$this->getParameter("premier");
631 $params .= "&amp;tricol=".$this->getParameter("tricol");
632 $params .= "&amp;recherche=".$this->getParameter("recherche");
633 $params .= "&amp;selectioncol=".$this->getParameter("selectioncol");
634 $params .= "&amp;advs_id=".$this->getParameter("advs_id");
635 $params .= "&amp;valide=".$this->getParameter("valide");
636 echo "\n<a class=\"retour\" ";
637 echo "href=\"";
638 //
639
640 if($this->getParameter("retour")=="form" AND !($this->getParameter("validation")>0 AND $this->getParameter("maj")==2 AND $this->correct)) {
641 echo "form.php?".$params;
642 } elseif($this->getParameter("retour")=="suivi_retours_de_consultation") {
643 echo "../app/suivi_retours_de_consultation.php";
644 } else {
645 echo "tab.php?".$params;
646 }
647 //
648 echo "\"";
649 echo ">";
650 //
651 echo _("Retour");
652 //
653 echo "</a>\n";
654 }
655
656 /**
657 * Surcharge du bouton retour pour popup
658 */
659 function retoursousformulaire($idxformulaire, $retourformulaire, $val,
660 $objsf, $premiersf, $tricolsf, $validation,
661 $idx, $maj, $retour) {
662 if($retourformulaire === "demande_avis_encours") {
663 echo "\n<a class=\"retour\" ";
664 echo "href=\"";
665 echo "#";
666 echo "\" ";
667 echo ">";
668 //
669 echo _("Retour");
670 //
671 echo "</a>\n";
672 } else {
673 parent::retoursousformulaire($idxformulaire, $retourformulaire, $val,
674 $objsf, $premiersf, $tricolsf, $validation,
675 $idx, $maj, $retour);
676 }
677 }
678
679 /**
680 * Ajout des contraintes spécifiques pour l'ajout d'un fichier en retour de
681 * consultation
682 */
683 function setSelect(&$form, $maj,&$db,$debug) {
684 if(file_exists ("../sql/".OM_DB_PHPTYPE."/".$this->table.".form.inc.php"))
685 include ("../sql/".OM_DB_PHPTYPE."/".$this->table.".form.inc.php");
686 elseif(file_exists ("../sql/".OM_DB_PHPTYPE."/".$this->table.".form.inc"))
687 include ("../sql/".OM_DB_PHPTYPE."/".$this->table.".form.inc");
688
689 // avis_consultation
690 $this->init_select($form, $db, $maj, $debug, "avis_consultation",
691 $sql_avis_consultation, $sql_avis_consultation_by_id, true);
692
693 // service
694 $this->init_select($form, $db, $maj, $debug, "service",
695 $sql_service, $sql_service_by_id, true);
696
697 //Seulement dans le cas d'un retour d'avis
698 if($this->retourformulaire == "demande_avis_encours") {
699
700 //Tableau des contraintes spécifiques
701 $params = array(
702 "constraint" => array(
703 "size_max" => 2,
704 "extension" => ".pdf"
705 ),
706 );
707
708 $form->setSelect("fichier", $params);
709 }
710 }
711
712 /**
713 * Finalisation du document lors de l'ajout d'une consultation
714 */
715 function finaliserAjouter(){
716
717 //Génération du PDF
718 $_GET['output'] = "string";
719 $_GET['obj'] = "consultation";
720 $_GET['idx'] = $this->valF[$this->clePrimaire];
721 $f = $this->f;
722 include '../app/pdf_consultation.php';
723
724 //Métadonnées du document
725 $metadata = array(
726 'filename' => 'consultation_'.$idx.'.pdf',
727 'mimetype' => 'application/pdf',
728 'size' => strlen($pdf_output)
729 );
730
731 // Récupération des métadonnées calculées après validation
732 $spe_metadata = $this->getMetadata("om_fichier_consultation");
733
734 $metadata = array_merge($metadata, $spe_metadata);
735
736 //On ajoute le document et on récupère son uid
737 $uid = $this->f->storage->create($pdf_output, $metadata);
738
739 //Mise à jour des données
740 if ( $uid != '' && $uid != 'OP_FAILURE' ){
741 // Logger
742 $this->addToLog("finaliserAjouter() - begin", EXTRA_VERBOSE_MODE);
743
744 $valF = array(
745 "om_final_consultation"=> TRUE,
746 "om_fichier_consultation"=>$uid);
747
748 // Execution de la requête de modification des donnees de l'attribut
749 // valF de l'objet dans l'attribut table de l'objet
750 $res = $this->db->autoExecute(DB_PREFIXE.$this->table, $valF,
751 DB_AUTOQUERY_UPDATE, $this->getCle($idx));
752 $this->addToLog("finaliserAjouter() : db->autoExecute(\"".DB_PREFIXE.$this->table."\", ".print_r($valF, true).", DB_AUTOQUERY_UPDATE, \"".$this->getCle($idx)."\")", VERBOSE_MODE);
753 // Si une erreur survient
754 if (database::isError($res)) {
755 // Appel de la methode de recuperation des erreurs
756 $this->erreur_db($res->getDebugInfo(), $res->getMessage(), '');
757 } else {
758 // Log
759 $this->addToLog(_("Requete executee"), VERBOSE_MODE);
760 // Log
761 $message = _("Enregistrement")."&nbsp;".$idx."&nbsp;";
762 $message .= _("de la table")."&nbsp;\"".$this->table."\"&nbsp;";
763 $message .= "[&nbsp;".$this->db->affectedRows()."&nbsp;";
764 $message .= _("enregistrement(s) mis a jour")."&nbsp;]";
765 $this->addToLog($message, VERBOSE_MODE);
766 }
767 }
768 }
769
770 /**
771 * Finalisation des documents.
772 * @param string $champ champ du fichier à finaliser
773 * @param booleen $status permet de définir si on finalise ou définalise
774 * @param string $sousform permet de savoir si se trouve dans un sousformulaire (passé au javascript)
775 */
776 function finaliser($champ = '', $status, $sousform, $retourformulaire) {
777
778 // Recuperation de la valeur de la cle primaire de l'objet
779 if ($this->getVal($this->clePrimaire) != '') {
780 //
781 $id = $this->getVal($this->clePrimaire);
782 }
783 else {
784 //
785 $id=$this->id;
786 }
787
788 // Si on finalise le document
789 if ($status == 1) {
790
791 // Génération du PDF
792 $_GET['output'] = "string";
793 $f = $this->f;
794 include '../app/pdf_consultation.php';
795
796 // Métadonnées du document
797 $metadata = array(
798 'filename' => 'consultation_'.$idx.'.pdf',
799 'mimetype' => 'application/pdf',
800 'size' => strlen($pdf_output)
801 );
802
803 // Récupération des métadonnées calculées après validation
804 $spe_metadata = $this->getMetadata("om_fichier_consultation");
805
806 $metadata = array_merge($metadata, $spe_metadata);
807
808 // Si le document a déjà été finalisé
809 if ( $this->getVal("om_fichier_consultation") != '' ){
810
811 // Met à jour le document mais pas son uid
812 $uid = $this->f->storage->update(
813 $this->getVal("om_fichier_consultation"), $pdf_output, $metadata);
814 }
815 // Sinon, ajoute le document et récupère son uid
816 else {
817
818 // Stockage du PDF
819 $uid = $this->f->storage->create($pdf_output, $metadata);
820 }
821
822 }
823 //
824 else {
825
826 //Récupération de l'uid du document finalisé
827 $uid = $this->getVal("om_fichier_consultation");
828
829 //On dé-finalise avant de finaliser
830 if ( $uid == '' || $uid == 'OP_FAILURE' ){
831 $this->addToLog(
832 _("Finalisation non enregistree")." - ".
833 _("id consultation")." = ".$id." - ".
834 _("uid fichier")." = ".$uid
835 );
836 return -1;
837 }
838 }
839
840
841 //Mise à jour des données
842 if ($uid != '' && $uid != 'OP_FAILURE') {
843
844 // Logger
845 $this->addToLog("finaliser() - begin", EXTRA_VERBOSE_MODE);
846
847 $actions = array();
848
849 // Tableau contenant le lien vers le PDF et lien du portlet pour la
850 // mise à jour de l'interface
851 if ($status == 0) {
852
853 // Lien pour ouvrir le PDF
854 $lien = '../app/pdf_consultation.php?idx='.$id;
855
856 //
857 if ($this->f->isAccredited('consultation') ||
858 $this->f->isAccredited('consultation_modifier')) {
859
860 $actions["modifier"] = ($sousform!='')?
861 '<li><a href="#" onclick="ajaxIt(\'consultation\',
862 \'../scr/sousform.php?obj=consultation&amp;action=1&amp;idx='.
863 $this->getVal($this->clePrimaire).
864 '&amp;premiersf=0&amp;trisf=&amp;retourformulaire='.$retourformulaire.'&amp;idxformulaire='.
865 $this->getVal("dossier").
866 '&amp;retour=form\');">
867 <span class="om-prev-icon om-icon-16 edit-16" title="'.
868 _('Modifier').'">'.
869 _('Modifier').
870 '</span></a></li>':
871 '<li>
872 <a href="form.php?obj=consultation&amp;action=1'.'&amp;idx='.
873 $this->getVal($this->clePrimaire).
874 '&amp;premier=&amp;advs_id=&amp;recherche=&amp;tricol=&amp;selectioncol=&amp;valide=&amp;retour=form">
875 <span class="om-prev-icon om-icon-16 edit-16" title="'.
876 _('Modifier').'">'.
877 _('Modifier').
878 '</span></a></li>';
879 }
880
881 //Si l'utilisateur a le droit de supprimer l'objet
882 if ( $this->f->isAccredited('consultation') ||
883 $this->f->isAccredited('consultation_supprimer') ){
884
885 $actions["supprimer"] = ($sousform!='')?
886 '<li><a href="#" onclick="ajaxIt(\'consultation\',
887 \'../scr/sousform.php?obj=consultation&amp;action=2&amp;idx='.
888 $this->getVal($this->clePrimaire).
889 '&amp;premiersf=0&amp;trisf=&amp;retourformulaire='.$retourformulaire.'&amp;idxformulaire='.
890 $this->getVal("dossier").
891 '&amp;retour=form\');">
892 <span class="om-prev-icon om-icon-16 delete-16" title="'.
893 _('Supprimer').'">'.
894 _('Supprimer').
895 '</span></a></li>':
896 '<li>
897 <a href="form.php?obj=consultation&amp;action=1'.'&amp;idx='.
898 $this->getVal($this->clePrimaire).
899 '&amp;premier=&amp;advs_id=&amp;recherche=&amp;tricol=&amp;selectioncol=&amp;valide=&amp;retour=form">
900 <span class="om-prev-icon om-icon-16 delete-16" title="'.
901 _('Supprimer').'">'.
902 _('Supprimer').
903 '</span></a></li>';
904 }
905 }
906 else {
907
908 // Lien permettant d'afficher le PDF
909 $lien = '../spg/file.php?obj=consultation&'.
910 'champ=om_fichier_consultation&id='.$id;
911 }
912
913 //
914 $retour = array(
915 "portlet"=> "<a href=\"#\" onclick=\"finalizeDocument(".
916 $id.", 'consultation', '".$sousform."', ".(($status==0)?1:0).")\">
917 <span class=\"om-prev-icon om-icon-16 om-icon-fix "
918 .(($status==1)?"de":"")."finalise\" title=\"".
919 (($status==1)?_("Reprendre la redaction du document"):_("Finaliser le document"))."\">".
920 (($status==1)?_("Reprendre la redaction du document"):_("Finaliser le document"))."</span>
921 </a>",
922 "pdf" => $lien,
923 "actions" => $actions
924 );
925
926 foreach ($this->champs as $key => $value) {
927 //
928 $val[$value] = $this->val[$key];
929 }
930
931 $this->setvalF($val);
932
933 // Verification de la validite des donnees
934 $this->verifier($this->val, $this->db, DEBUG);
935 // Verification du verrou
936 $this->testverrou();
937 // Si les verifications precedentes sont correctes, on procede a
938 // la modification, sinon on ne fait rien et on retourne une erreur
939 if ($this->correct) {
940
941 // Execution du trigger 'before' specifique au MODE 'update'
942 $this->triggermodifier( $id, $this->db, $this->val, DEBUG);
943
944 //
945 $valF = '';
946 $valF["om_final_consultation"] = ($status==1)?TRUE:FALSE;
947 $valF["om_fichier_consultation"] = $uid;
948
949 // Execution de la requête de modification des donnees de l'attribut
950 // valF de l'objet dans l'attribut table de l'objet
951 $res = $this->db->autoExecute(DB_PREFIXE.$this->table, $valF,
952 DB_AUTOQUERY_UPDATE, $this->getCle($id));
953 $this->addToLog("finaliser() : db->autoExecute(\"".DB_PREFIXE.$this->table."\", ".print_r($valF, true).", DB_AUTOQUERY_UPDATE, \"".$this->getCle($id)."\")", VERBOSE_MODE);
954
955 // Si une erreur survient
956 if (database::isError($res)) {
957
958 // Appel de la methode de recuperation des erreurs
959 $this->erreur_db($res->getDebugInfo(), $res->getMessage(), '');
960 } else {
961
962 // Log
963 $this->addToLog(_("Requete executee"), VERBOSE_MODE);
964 // Log
965 $message = _("Enregistrement")."&nbsp;".$id."&nbsp;";
966 $message .= _("de la table")."&nbsp;\"".$this->table."\"&nbsp;";
967 $message .= "[&nbsp;".$this->db->affectedRows()."&nbsp;";
968 $message .= _("enregistrement(s) mis a jour")."&nbsp;]";
969 $this->addToLog($message, VERBOSE_MODE);
970 // Mise en place du verrou pour ne pas finaliser plusieurs fois
971 // le meme document
972 $this->verrouille();
973 // Execution du trigger 'after' specifique au MODE 'update'
974 $this->triggermodifierapres($id, $this->db, $this->val, DEBUG);
975
976 return $retour;
977 }
978 //
979 } else {
980
981 // Message d'echec (saut d'une ligne supplementaire avant le
982 // message pour qu'il soit mis en evidence)
983 $this->addToLog(
984 _("Finalisation non enregistree")." - ".
985 _("id consultation")." = ".$id." - ".
986 _("uid fichier")." = ".$uid
987 );
988 return -1;
989 }
990 }
991 // Si le document n'a pas été stocké
992 else{
993 $this->addToLog(
994 _("Finalisation non enregistree")." - ".
995 _("id consultation")." = ".$id." - ".
996 _("uid fichier")." = ".$uid
997 );
998 return -1;
999 }
1000 }
1001
1002 /**
1003 * Création du nom de fichier
1004 * @return string numéro de dossier d'instruction
1005 */
1006 protected function getFichierFilename() {
1007 return "consultation_avis_".$this->valF[$this->clePrimaire].".pdf";
1008 }
1009
1010 /**
1011 * Récupération du numéro de dossier d'instruction à ajouter aux métadonnées
1012 * @return string numéro de dossier d'instruction
1013 */
1014 protected function getDossier() {
1015 if(empty($this->specificMetadata)) {
1016 $this->getSpecificMetadata();
1017 }
1018 return $this->specificMetadata->dossier;
1019 }
1020 /**
1021 * Récupération la version du dossier d'instruction à ajouter aux métadonnées
1022 * @return int Version
1023 */
1024 protected function getDossierVersion() {
1025 if(empty($this->specificMetadata)) {
1026 $this->getSpecificMetadata();
1027 }
1028 return $this->specificMetadata->version;
1029 }
1030 /**
1031 * Récupération du numéro de dossier d'autorisation à ajouter aux métadonnées
1032 * @return string numéro de dossier d'autorisation
1033 */
1034 protected function getNumDemandeAutor() {
1035 if(empty($this->specificMetadata)) {
1036 $this->getSpecificMetadata();
1037 }
1038 return $this->specificMetadata->dossier_autorisation;
1039 }
1040 /**
1041 * Récupération de la date de demande initiale du dossier à ajouter aux métadonnées
1042 * @return date demande initiale
1043 */
1044 protected function getAnneemoisDemandeAutor() {
1045 if(empty($this->specificMetadata)) {
1046 $this->getSpecificMetadata();
1047 }
1048 return $this->specificMetadata->date_demande_initiale;
1049 }
1050 /**
1051 * Récupération du type de dossier d'instruction à ajouter aux métadonnées
1052 * @return string type de dossier d'instruction
1053 */
1054 protected function getTypeInstruction() {
1055 if(empty($this->specificMetadata)) {
1056 $this->getSpecificMetadata();
1057 }
1058 return $this->specificMetadata->dossier_instruction_type;
1059 }
1060 /**
1061 * Récupération du statut du dossier d'autorisation à ajouter aux métadonnées
1062 * @return string avis
1063 */
1064 protected function getStatutAutorisation() {
1065 if(empty($this->specificMetadata)) {
1066 $this->getSpecificMetadata();
1067 }
1068 return $this->specificMetadata->statut;
1069 }
1070 /**
1071 * Récupération du type de dossier d'autorisation à ajouter aux métadonnées
1072 * @return string type d'autorisation
1073 */
1074 protected function getTypeAutorisation() {
1075 if(empty($this->specificMetadata)) {
1076 $this->getSpecificMetadata();
1077 }
1078 return $this->specificMetadata->dossier_autorisation_type;
1079 }
1080 /**
1081 * Récupération de la date d'ajout de document à ajouter aux métadonnées
1082 * @return date de l'évènement
1083 */
1084 protected function getDateEvenementDocument() {
1085 return date("Y-m-d");
1086 }
1087 /**
1088 * Récupération du groupe d'instruction à ajouter aux métadonnées
1089 * @return string Groupe d'instruction
1090 */
1091 protected function getGroupeInstruction() {
1092 if(empty($this->specificMetadata)) {
1093 $this->getSpecificMetadata();
1094 }
1095 return $this->specificMetadata->groupe_instruction;
1096 }
1097 /**
1098 * Récupération du type de document à ajouter aux métadonnées
1099 * @return string Type de document
1100 */
1101 protected function getTitle() {
1102 if ($this->retourformulaire == "demande_avis_encours") {
1103 return 'Retour de consultation';
1104 } else {
1105 return 'Demande de consultation';
1106 }
1107 }
1108
1109 /**
1110 * Cette méthode permet de stocker en attribut toutes les métadonnées
1111 * nécessaire à l'ajout d'un document.
1112 */
1113 public function getSpecificMetadata() {
1114 if (isset($this->valF["dossier"]) AND $this->valF["dossier"] != "") {
1115 $dossier = $this->valF["dossier"];
1116 } else {
1117 $dossier = $this->getVal("dossier");
1118 }
1119 //Requête pour récupérer les informations essentiels sur le dossier d'instruction
1120 $sql = "SELECT dossier.dossier as dossier,
1121 dossier_autorisation.dossier_autorisation as dossier_autorisation,
1122 to_char(dossier.date_demande, 'YYYY/MM') as date_demande_initiale,
1123 dossier_instruction_type.code as dossier_instruction_type,
1124 etat_dossier_autorisation.libelle as statut,
1125 dossier_autorisation_type.code as dossier_autorisation_type,
1126 groupe.code as groupe_instruction
1127 FROM ".DB_PREFIXE."dossier
1128 LEFT JOIN ".DB_PREFIXE."dossier_instruction_type
1129 ON dossier.dossier_instruction_type = dossier_instruction_type.dossier_instruction_type
1130 LEFT JOIN ".DB_PREFIXE."dossier_autorisation
1131 ON dossier.dossier_autorisation = dossier_autorisation.dossier_autorisation
1132 LEFT JOIN ".DB_PREFIXE."etat_dossier_autorisation
1133 ON dossier_autorisation.etat_dossier_autorisation = etat_dossier_autorisation.etat_dossier_autorisation
1134 LEFT JOIN ".DB_PREFIXE."dossier_autorisation_type_detaille
1135 ON dossier_autorisation.dossier_autorisation_type_detaille = dossier_autorisation_type_detaille.dossier_autorisation_type_detaille
1136 LEFT JOIN ".DB_PREFIXE."dossier_autorisation_type
1137 ON dossier_autorisation_type_detaille.dossier_autorisation_type = dossier_autorisation_type.dossier_autorisation_type
1138 LEFT JOIN ".DB_PREFIXE."groupe
1139 ON dossier_autorisation_type.groupe = groupe.groupe
1140 WHERE dossier.dossier = '".$dossier."'";
1141 $res = $this->db->query($sql);
1142 $this->f->addToLog("obj/document_numerise.class.php : db->query(".$sql.")", VERBOSE_MODE);
1143 if ( database::isError($res)){
1144 die();
1145 }
1146
1147 //Le résultat est récupéré dans un objet
1148 $row =& $res->fetchRow(DB_FETCHMODE_OBJECT);
1149
1150 //Si il y a un résultat
1151 if ($row !== null) {
1152
1153 //Génération du numéro de version
1154 $sql = "SELECT
1155 count(*)
1156 FROM
1157 ".DB_PREFIXE."dossier
1158 LEFT JOIN
1159 ".DB_PREFIXE."dossier_autorisation
1160 ON
1161 dossier_autorisation.dossier_autorisation = dossier.dossier_autorisation
1162 LEFT JOIN
1163 ".DB_PREFIXE."dossier_instruction_type
1164 ON
1165 dossier_instruction_type.dossier_instruction_type = dossier.dossier_instruction_type
1166 WHERE
1167 dossier_autorisation.dossier_autorisation = '".$row->dossier_autorisation."'
1168 AND
1169 dossier_instruction_type.code = '".$row->dossier_instruction_type."'";
1170 $row->version = $this->db->getOne($sql);
1171 $this->f->addToLog("getInfosForFoldername(): db->getOne(\"".$sql."\")", VERBOSE_MODE);
1172 if ( database::isError($row->version)){
1173 $this->f->addToError("", $row->version, $row->version);
1174 return false;
1175 }
1176
1177 //Formatage du numéro de version
1178 $row->version = str_pad($row->version, 2, "0", STR_PAD_LEFT);
1179
1180 //Alors on créé l'objet dossier_instruction
1181 $this->specificMetadata = $row;
1182
1183 }
1184 }
1185
1186 }// fin classe
1187 ?>

Properties

Name Value
svn:keywords Id

[email protected]
ViewVC Help
Powered by ViewVC 1.1.26