Subversion Repositories Applications.referentiel

Compare Revisions

Ignore whitespace Rev 48 → Rev 49

/trunk/interfaces/referentiel.php
15,7 → 15,8
function __autoload($nom_classe) {
// Tableau des chemins à inclure pour trouver une classe relatif à ce fichier
$chemins = array(
'..'.DS.'bibliotheque'.DS.'dao',
'..'.DS.'bibliotheque'.DS.'dao',
'..'.DS.'bibliotheque'.DS.'utilitaires',
'bibliotheque'.DS.'pear',
'composants');
foreach ($chemins as $chemin) {
/trunk/interfaces/squelettes/form_version.tpl.html
85,6 → 85,8
<fieldset id="champs-domaine">
<legend>Domaines couverts par le référentiel</legend>
<p> Vous pouvez choisir plusieurs éléments par liste.</p>
<label for="classification">Classification par défaut <span class="obligatoire">*</span></label>
<p><input id="classification" name="classification" type="text" value="<?=$version['classification']?>"/></p>
<label for="ref-ver-dom-tax">Domaine taxonomique <span class="obligatoire">*</span></label>
<div id="ref-ver-dom-tax" class="case-a-cocher-scroll" />
<ul class="liste-simple">
121,11 → 123,11
</li>
<li>
<label for="copyright">Copyright</label>
<input type="text" id="copyright" name="mention_legale" value="© Tela Botanica - <?=date('Y')?>." readonly="readonly"/>
<input type="text" id="copyright" name="mention_legale" value="Copyright © Tela Botanica (<?=date('Y')?>). Tout droits réservés." readonly="readonly"/>
</li>
<li>
<label for="licence">Licence</label>
<input type="text" id="licence" name="licence" value="" readonly="readonly"/>
<input type="text" id="licence" name="licence" value="http://creativecommons.org/licenses/by-sa/2.0/fr/" readonly="readonly"/>
</li>
<li>
<label for="referencement">Comment citer ce référentiel? <span class="obligatoire">*</span></label>
/trunk/interfaces/controleurs/Versionnage.php
19,7 → 19,7
private $version = array('titre', 'acronyme', 'version', 'date_prod',
'auteur_principal', 'coordinateur', 'editeur', 'contact',
'contributeur',
'dom_tax', 'dom_geo', 'dom_code',
'classification', 'dom_tax', 'dom_geo', 'dom_code',
'source', 'copyright', 'licence', 'referencement');
private $referentiel = null;
private $traitementDao = null;
99,7 → 99,7
$version = array();
foreach ($this->version as $champ) {
if (isset($_POST[$champ])) {
$version[$champ] = strip_tags(stripslashes($_POST[$champ]));
$version[$champ] = stripslashes($_POST[$champ]);
} else {
$version[$champ] = $this->getValeurParDefaut($champ);
121,7 → 121,9
*/
public function demanderTraitement() {
if ($this->verifierMetadonnees()) {
$this->ajouterTraitement($this->referentiel, self::SCRIPT_A_LANCER);
$parametres = $this->instancierChampsVersionnage();
$parametres_serialises = serialize($parametres);
$this->ajouterTraitementParametre($this->referentiel, $parametres_serialises, self::SCRIPT_A_LANCER);
}
$this->afficherInterface();
}
131,7 → 133,18
*/
public function verifierMetadonnees() {
$ok = true;
$ok = ($this->verifierChampsObligatoires()) ? true : false;
if (! $this->verifierChampsObligatoires()) {
$ok = false;
}
if (! $this->verifierChampsMajuscule()) {
$ok = false;
}
if (! $this->verifierChampsContact()) {
$ok = false;
}
if (! $this->verifierChampsCourriel()) {
$ok = false;
}
return $ok;
}
143,6 → 156,7
'auteur_principal' => 'Auteur Principal',
'coordinateur' => 'coordinateur',
'contact' => 'Courriel de contact',
'classification' => 'Classification par défaut',
'dom_tax' => 'Domaine taxonomique',
'dom_geo' => 'Domaine géographique',
'dom_code' => 'Codes botaniques utilisés',
155,5 → 169,84
}
return $ok;
}
public function verifierChampsMajuscule() {
$ok = true;
$champs_en_majuscule = array('acronyme' => 'Acronyme');
foreach ($champs_en_majuscule as $champ_id => $champ_nom) {
if (isset($_POST[$champ_id]) && ! $this->verifierMajusculeSansAccent($_POST[$champ_id])) {
$this->addMessage("Le champ '$champ_nom' doit être obligatoirement composé de majuscules non accentuées.");
$ok = false;
}
}
return $ok;
}
/**
* Vérifie la mise en majuscule
*/
public function verifierMajusculeSansAccent($txt) {
$ok = (preg_match('/^[A-Z]+$/', $txt)) ? true : false;
return $ok;
}
public function verifierChampsContact() {
$ok = true;
$champs_contact = array('auteur_principal' => 'Auteur Principal',
'coordinateur' => 'coordinateur',
'contributeur' => 'Auteurs/Contributeurs');
foreach ($champs_contact as $champ_id => $champ_nom) {
if (isset($_POST[$champ_id]) && ! $this->verifierContact($_POST[$champ_id])) {
$this->addMessage("Le champ '$champ_nom' n'est pas au format : Prénom1 NOM1 (Organisation1) <courriel1>, Prénom2 NOM2 (Organisation2) <courriel2>.");
$ok = false;
}
}
return $ok;
}
/**
* Vérifie que le texte est au format :
* Prénom1 NOM1 (Organisation1) <courriel1>,
* Prénom2 NOM2 (Organisation2) <courriel2>.
*/
public function verifierContact($txt) {
$ok = true;
if ($txt != '') {
$pp = Pattern::PRENOM;
$pn = Pattern::NOM;
$po = "\([^\)]+\)";// Pattern organisation
$pc = Pattern::COURRIEL;
 
$contacts = explode(',', $txt);
foreach ($contacts as $contact) {
$contact = trim($contact);
if (! preg_match("/^$pp $pn $po <$pc>(?:|.)$/u", $contact)) {
$ok = false;
}
}
}
return $ok;
}
public function verifierChampsCourriel() {
$ok = true;
$champs_courriel = array('contact' => 'Courriel de contact');
foreach ($champs_courriel as $champ_id => $champ_nom) {
if (isset($_POST[$champ_id]) && ! $this->verifierCourriel($_POST[$champ_id])) {
$this->addMessage("Le champ '$champ_nom' ne comptient pas une adresse de courriel valide.");
$ok = false;
}
}
return $ok;
}
/**
* Vérifie que le texte est une adresse de courriel valide.
*/
public function verifierCourriel($txt) {
$pattern_courriel = Pattern::COURRIEL;
$ok = (preg_match('/^'.$pattern_courriel.'+$/', $txt)) ? true : false;
return $ok;
}
}
?>
/trunk/services/modules/Traitement.php
273,15 → 273,15
* Retour l'id du nouvel enregistrement ou false!
*/
public function createElement($params_post) {
$params_proteges = $this->traiterParametresPost(array('referentiel_code', 'script'), $params_post);
$meta_date_creation = date ("Y-m-d H:i:s");
$params_proteges = $this->traiterParametresPost(array('referentiel_code', 'script', 'script_parametres'), $params_post);
$meta_date_creation = date ('Y-m-d H:i:s');
$nom = $this->bdd->quote("Traitement {$params_post['referentiel_code']} - $meta_date_creation");
$meta_date_creation = $this->bdd->quote($meta_date_creation);
try {
$requete = "INSERT INTO ref_traitement ".
' (referentiel_code, script, nom, meta_date_creation) '.
" VALUES ({$params_proteges['referentiel_code']}, {$params_proteges['script']}, $nom, $meta_date_creation) ";
' (referentiel_code, script, script_parametres, nom, meta_date_creation) '.
" VALUES ({$params_proteges['referentiel_code']}, {$params_proteges['script_parametres']}, {$params_proteges['script']}, $nom, $meta_date_creation) ";
$resultat = $this->bdd->exec($requete);
if ($resultat === false) {
$id = false;
/trunk/doc/bdd/referentiel.xml
260,8 → 260,8
</SETTINGS>
<METADATA>
<REGIONS>
<REGION ID="28021" RegionName="Exemple BDNT" XPos="743" YPos="25" Width="668" Height="529" RegionColor="1" TablePrefix="0" TableType="0" OverwriteTablePrefix="0" OverwriteTableType="0" Comments="" IsLinkedObject="0" IDLinkedModel="-1" Obj_id_Linked="-1" OrderPos="7" />
<REGION ID="27985" RegionName="Traitements" XPos="28" YPos="24" Width="691" Height="530" RegionColor="0" TablePrefix="0" TableType="0" OverwriteTablePrefix="0" OverwriteTableType="0" Comments="Tables permettant de r\195\169aliser des traitments sur les donn\195\169es des r\195\169f\195\169rentiels." IsLinkedObject="0" IDLinkedModel="-1" Obj_id_Linked="-1" OrderPos="3" />
<REGION ID="28021" RegionName="Exemple BDNT" XPos="743" YPos="25" Width="668" Height="529" RegionColor="1" TablePrefix="0" TableType="0" OverwriteTablePrefix="0" OverwriteTableType="0" Comments="" IsLinkedObject="0" IDLinkedModel="-1" Obj_id_Linked="-1" OrderPos="7" />
</REGIONS>
<TABLES>
<TABLE ID="27977" Tablename="ref_traitement" PrevTableName="Table_01" XPos="87" YPos="74" TableType="0" TablePrefix="0" nmTable="0" Temporary="0" UseStandardInserts="0" StandardInserts="\n" TableOptions="DelayKeyTblUpdates=0\nPackKeys=0\nRowChecksum=0\nRowFormat=0\nUseRaid=0\nRaidType=0\n" Comments="" Collapsed="0" IsLinkedObject="0" IDLinkedModel="-1" Obj_id_Linked="-1" OrderPos="2" >
285,6 → 285,10
<OPTIONSELECT Value="0" />
</OPTIONSELECTED>
</COLUMN>
<COLUMN ID="28051" ColName="script_parametres" PrevColName="" Pos="8" idDatatype="28" DatatypeParams="" Width="-1" Prec="-1" PrimaryKey="0" NotNull="0" AutoInc="0" IsForeignKey="0" DefaultValue="" Comments="Ensemble de param\195\170tres n\195\169cessaire au script dans le format choisis par le d\195\169veloppeur du script (XML, Json, variables serialis\195\169es...).">
<OPTIONSELECTED>
</OPTIONSELECTED>
</COLUMN>
<COLUMN ID="27984" ColName="nom" PrevColName="" Pos="4" idDatatype="20" DatatypeParams="(100)" Width="-1" Prec="-1" PrimaryKey="0" NotNull="0" AutoInc="0" IsForeignKey="0" DefaultValue="" Comments="Nom du traitement">
<OPTIONSELECTED>
<OPTIONSELECT Value="0" />
/trunk/scripts/modules/versionnage/Versionnage.php
22,7 → 22,7
private $projet = null;
private $traitement = null;
private $erreurs = null;
private $messages = null;
private $manuel = null;
private $resultatDao = null;
96,7 → 96,7
$infos[$ordre] = $valeur;
} else {
$e = "Le champ '$champ' n'a pas été pris en compte dans l'attribution de l'ordre des champs.";
$this->ajouterMessageErreur($e);
$this->ajouterMessage($e);
}
}
$donnees['noms'][] = $infos;
103,8 → 103,10
}
$bdtn_tsv = $this->getVue('versionnage/squelettes/bdnt', $donnees, '.tpl.tsv');
if (file_put_contents('/home/jpm/web/referentiel/zip/bdnt.txt', $bdtn_tsv) == false) {
if (file_put_contents(Config::get('chemin_referentiel_zip').'bdnt.txt', $bdtn_tsv) == false) {
Debug::printr("une erreur est survenu lors de l'écriture du fichier");
} else {
}
}
125,14 → 127,16
return $champs_ordre;
}
private function ajouterMessageErreur($message) {
private function ajouterMessage($message) {
$titre = self::SCRIPT_NOM.' #'.$this->traitement['id_traitement'];
$this->erreurs[] = array($titre, $message);
$this->messages[] = array($titre, $message);
}
private function traiterMessagesErreur() {
if (isset($this->erreurs)) {
$this->resultatDao->ajouter($this->traitement['id_traitement'], $this->erreurs);
private function traiterMessages() {
if (isset($this->messages)) {
foreach ($this->messages as $message) {
$this->resultatDao->ajouter($this->traitement['id_traitement'], $message);
}
}
}
}
/trunk/bibliotheque/utilitaires/Pattern.php
New file
0,0 → 1,6
<?php
class Pattern {
const PRENOM = "[\p{L}-]+";// Pattern prénom
const NOM = "[\p{Lu}]+";// Pattern nom
const COURRIEL = "[a-z0-9!#$%&'*+=?^_`{|}~-]+(?:\\.[a-z0-9!#$%&'*+=?^_`{|}~-]+)*@(?:[a-z0-9](?:[a-z0-9-]*[a-z0-9])?\\.)+[a-z0-9](?:[a-z0-9-]*[a-z0-9])?";// Pattern courriel
}
/trunk/bibliotheque/dao/TraitementDao.php
119,9 → 119,23
* @return mixed l'id du traitement ou false en cas d'échec.
*/
public function ajouterTraitement($code_projet, $script) {
return $this->ajouterTraitementParametre($code_projet, null, $script);
}
/**
* Ajoute une demande de traitement pour une référentiel donné
* en passant des paramêtres au script.
*
* @param string le code du référentiel.
* @param string les données serialisées.
* @param string le nom du script à lancer en minuscule.
* @return mixed l'id du traitement ou false en cas d'échec.
*/
public function ajouterTraitementParametre($code_projet, $parametres, $script) {
// Préparation des données à passer par POST
$donnees['referentiel_code'] = $code_projet;
$donnees['script'] = $script;
$donnees['script_parametres'] = (isset($parametres)) ? $parametres : null;
// Envoie des données et récupération du retour
$json = $this->envoyerRequeteAjout($this->url, $donnees);