/trunk/interfaces/referentiel.php |
---|
16,6 → 16,7 |
// Tableau des chemins à inclure pour trouver une classe relatif à ce fichier |
$chemins = array( |
'..'.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,15 → 127,17 |
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); |