Subversion Repositories Applications.referentiel

Rev

Rev 57 | Rev 120 | Go to most recent revision | Details | Compare with Previous | Last modification | View Log | RSS feed

Rev Author Line No. Line
37 jpm 1
<?php
2
// declare(encoding='UTF-8');
3
/**
4
 * Classe Controleur du module Versionnage.
5
 * Permet de publier une nouvelle version d'un référentiel de travail.
6
 *
7
 * @package		Referentiel
8
 * @category	Php5.2
9
 * @author		Jean-Pascal MILCENT <jpm@tela-botanica.org>
10
 * @copyright	2010 Tela-Botanica
11
 * @license		http://www.cecill.info/licences/Licence_CeCILL_V2-fr.txt Licence CECILL
12
 * @license		http://www.gnu.org/licenses/gpl.html Licence GNU-GPL
13
 * @version		SVN: $Id$
14
 */
15
class Versionnage extends AppliControleur {
16
 
39 jpm 17
	const SCRIPT_A_LANCER = 'versionnage';
18
 
48 jpm 19
	private $version = array('titre', 'acronyme', 'version', 'date_prod',
20
		'auteur_principal', 'coordinateur', 'editeur', 'contact',
21
		'contributeur',
49 jpm 22
		'classification', 'dom_tax', 'dom_geo', 'dom_code',
48 jpm 23
		'source', 'copyright', 'licence', 'referencement');
37 jpm 24
	private $referentiel = null;
39 jpm 25
	private $traitementDao = null;
37 jpm 26
 
27
	public function __construct()  {
28
		parent::__construct();
29
 
30
		// Récupération de paramêtres
31
		if (isset($_GET['ref'])) { // code du projet courrant
32
			$this->referentiel = strtolower($_GET['ref']);
33
		}
38 jpm 34
 
39 jpm 35
		// Chargement des DAO nécessaires
36
		$this->traitementDao = new TraitementDao();
37 jpm 37
	}
38
 
39
	//+----------------------------------------------------------------------------------------------------------------+
40
	// Méthodes
41
	/**
42
	 * Fonction d'affichage par défaut
43
	 */
44
	public function executerActionParDefaut() {
38 jpm 45
		return $this->afficherInterface();
46
	}
47
 
48
	/**
49
	 * Affiche le formulaire de demande de versionnage
50
	 */
51
	public function afficherInterface() {
52
		$donnees = array();
45 jpm 53
		$this->definirCommeModulePrincipal(get_class($this));
39 jpm 54
 
38 jpm 55
		// Paramêtres pour l'url du formulaire
56
		$this->url->unsetVariablesRequete(array('module', 'action', 'ref'));
46 jpm 57
		$donnees['url_form'] = $this->obtenirUrlDemandeVersionnage($this->referentiel);
38 jpm 58
		$donnees['url_module'] = 'Versionnage';
59
		$donnees['url_action_rafraichir'] = 'afficherInterface';
60
 
48 jpm 61
		$donnees['version'] = $this->instancierChampsVersionnage();
58 jpm 62
		$donnees['version'] = $this->traiterCasesACocher($donnees['version']);
48 jpm 63
 
38 jpm 64
		// Récupération des paramètres de configuration du manuel des référentiels
65
		$donnees['domaine_geo'] = explode(';', $this->manuel['domaine_geo']);
66
		$donnees['domaine_taxo'] = explode(';', $this->manuel['domaine_taxo']);
67
		$donnees['domaine_code'] = explode(';', $this->manuel['domaine_code']);
68
 
39 jpm 69
		// Traitement de l'info sur le code du référentiel
70
		if (isset($this->referentiel)) {
71
			// Récupération du référentiel courrant
72
			$donnees['ref'] = $this->referentiel;
73
 
74
			// Recherche des traitements en attente
75
			$donnees['traitements_en_attente'] = $this->traitementDao->getTraitementsEnAttente($this->referentiel, self::SCRIPT_A_LANCER);
76
 
77
			// Recherche des traitements en cours d'éxecution
78
			$donnees['traitements_en_cours'] = $this->traitementDao->getTraitementsEnCours($this->referentiel, self::SCRIPT_A_LANCER);
79
 
80
			// Recherche des traitements déjà effectué
81
			$resultat = $this->traitementDao->getTraitementsTermines($this->referentiel, self::SCRIPT_A_LANCER);
82
			if (is_array($resultat)) {
83
				// Ajout de l'url vers la fiche du traitement
84
				foreach ($resultat as &$traitement) {
85
					$traitement['url'] = $this->obtenirUrlFicheTraitement($this->referentiel, $traitement['id_traitement']);
86
				}
87
				$donnees['traitements_termines'] = $resultat;
88
			}
89
		} else {
90
			$this->addMessage("Aucun code de projet de référentiel n'est indiqué (Ex. bdnff).");
91
		}
92
 
46 jpm 93
		$donnees['messages'] = $this->getMessages();
57 jpm 94
		$this->traiterEsperluette($donnees);
38 jpm 95
		$this->setSortie(self::RENDU_CORPS, $this->getVue('form_version', $donnees), false);
37 jpm 96
		$this->construireMenu($this->referentiel);
97
		$this->construireFilAriane($this->referentiel);
38 jpm 98
	}
39 jpm 99
 
48 jpm 100
	public function instancierChampsVersionnage() {
101
		$version = array();
102
		foreach ($this->version as $champ) {
103
			if (isset($_POST[$champ])) {
57 jpm 104
				$version[$champ] = $this->supprimerSlash($_POST[$champ]);
48 jpm 105
			} else {
106
				$version[$champ] = $this->getValeurParDefaut($champ);
107
 
108
			}
109
		}
110
		return $version;
111
	}
112
 
113
	public function getValeurParDefaut($champ) {
114
		$valeur = '';
115
		if ('date_prod' == $champ) {
116
			$valeur = date('Y-m-d');
117
		}
118
		return $valeur;
119
	}
58 jpm 120
 
121
	private function traiterCasesACocher(Array $donnees) {
122
		foreach ($donnees as $cle => $valeur) {
123
			if (is_array($valeur)) {
124
				$this->traiterEsperluette($valeur);
125
				$donnees[$cle] = array_flip($valeur);
126
			}
127
		}
128
		return $donnees;
129
	}
48 jpm 130
 
39 jpm 131
	/**
132
	 * Lance l'ajout d'un traitement
133
	 */
134
	public function demanderTraitement() {
48 jpm 135
		if ($this->verifierMetadonnees()) {
49 jpm 136
			$parametres = $this->instancierChampsVersionnage();
137
			$parametres_serialises = serialize($parametres);
138
			$this->ajouterTraitementParametre($this->referentiel, $parametres_serialises, self::SCRIPT_A_LANCER);
48 jpm 139
		}
39 jpm 140
		$this->afficherInterface();
141
	}
48 jpm 142
 
143
	/**
144
	 * Vérifie les données du formulaire
145
	 */
146
	public function verifierMetadonnees() {
147
		$ok = true;
49 jpm 148
		if (! $this->verifierChampsObligatoires()) {
149
			$ok = false;
150
		}
151
		if (! $this->verifierChampsMajuscule()) {
152
			$ok = false;
153
		}
154
		if (! $this->verifierChampsContact()) {
155
			$ok = false;
156
		}
157
		if (! $this->verifierChampsCourriel()) {
158
			$ok = false;
159
		}
48 jpm 160
		return $ok;
161
	}
162
 
163
	public function verifierChampsObligatoires() {
164
		$ok = true;
165
		$champs_obligatoires = array('titre' => 'Titre',
166
			'acronyme' => 'Acronyme',
167
			'version' => 'Version',
168
			'auteur_principal' => 'Auteur Principal',
169
			'coordinateur' => 'coordinateur',
170
			'contact' => 'Courriel de contact',
49 jpm 171
			'classification' => 'Classification par défaut',
48 jpm 172
			'dom_tax' => 'Domaine taxonomique',
173
			'dom_geo' => 'Domaine géographique',
174
			'dom_code' => 'Codes botaniques utilisés',
175
			'referencement' => 'Comment citer ce référentiel?');
176
		foreach ($champs_obligatoires as $champ_id => $champ_nom) {
177
			if (!isset($_POST[$champ_id]) || empty($_POST[$champ_id])) {
178
				$this->addMessage("Le champ '$champ_nom' doit être obligatoirement rempli.");
179
				$ok = false;
180
			}
181
		}
182
		return $ok;
183
	}
49 jpm 184
 
185
	public function verifierChampsMajuscule() {
186
		$ok = true;
187
		$champs_en_majuscule = array('acronyme' => 'Acronyme');
188
		foreach ($champs_en_majuscule as $champ_id => $champ_nom) {
189
			if (isset($_POST[$champ_id]) && ! $this->verifierMajusculeSansAccent($_POST[$champ_id])) {
190
				$this->addMessage("Le champ '$champ_nom' doit être obligatoirement composé de majuscules non accentuées.");
191
				$ok = false;
192
			}
193
		}
194
		return $ok;
195
	}
196
 
197
	/**
198
	 * Vérifie la mise en majuscule
199
	 */
200
	public function verifierMajusculeSansAccent($txt) {
201
		$ok = (preg_match('/^[A-Z]+$/', $txt)) ? true : false;
202
		return $ok;
203
	}
204
 
205
	public function verifierChampsContact() {
206
		$ok = true;
207
		$champs_contact = array('auteur_principal' => 'Auteur Principal',
208
			'coordinateur' => 'coordinateur',
209
			'contributeur' => 'Auteurs/Contributeurs');
210
		foreach ($champs_contact as $champ_id => $champ_nom) {
211
			if (isset($_POST[$champ_id]) && ! $this->verifierContact($_POST[$champ_id])) {
51 jpm 212
				$this->addMessage("Le champ '$champ_nom' n'est pas au format : Prénom1 NOM1 (Organisation1) [courriel1], Prénom2 NOM2 (Organisation2) [courriel2].");
49 jpm 213
				$ok = false;
214
			}
215
		}
216
		return $ok;
217
	}
218
 
219
	/**
220
	 * Vérifie que le texte est au format :
221
	 * Prénom1 NOM1 (Organisation1) <courriel1>,
222
	 * Prénom2 NOM2 (Organisation2) <courriel2>.
223
	 */
224
	public function verifierContact($txt) {
225
		$ok = true;
226
		if ($txt != '') {
227
			$pp = Pattern::PRENOM;
228
			$pn = Pattern::NOM;
229
			$po = "\([^\)]+\)";// Pattern organisation
230
			$pc = Pattern::COURRIEL;
231
 
232
			$contacts = explode(',', $txt);
233
			foreach ($contacts as $contact) {
234
				$contact = trim($contact);
51 jpm 235
				if (! preg_match("/^$pp $pn $po \[$pc\](?:|.)$/u", $contact)) {
49 jpm 236
					$ok = false;
237
				}
238
			}
239
		}
240
		return $ok;
241
	}
242
 
243
	public function verifierChampsCourriel() {
244
		$ok = true;
245
		$champs_courriel = array('contact' => 'Courriel de contact');
246
		foreach ($champs_courriel as $champ_id => $champ_nom) {
247
			if (isset($_POST[$champ_id]) && ! $this->verifierCourriel($_POST[$champ_id])) {
248
				$this->addMessage("Le champ '$champ_nom' ne comptient pas une adresse de courriel valide.");
249
				$ok = false;
250
			}
251
		}
252
		return $ok;
253
	}
254
 
255
	/**
256
	 * Vérifie que le texte est une adresse de courriel valide.
257
	 */
258
	public function verifierCourriel($txt) {
259
		$pattern_courriel =  Pattern::COURRIEL;
260
		$ok = (preg_match('/^'.$pattern_courriel.'+$/', $txt)) ? true : false;
261
		return $ok;
262
	}
37 jpm 263
}
264
?>