/***************************************************************************\
* SPIP, Systeme de publication pour l'internet *
* *
- * Copyright (c) 2001-2011 *
+ * Copyright (c) 2001-2014 *
* Arnaud Martin, Antoine Pitrou, Philippe Riviere, Emmanuel Saint-James *
* *
* Ce programme est un logiciel libre distribue sous licence GNU/GPL. *
// "127.4 ko" ou "3.1 Mo"
// http://doc.spip.org/@taille_en_octets
function taille_en_octets ($taille) {
+ if ($taille < 1) return '';
if ($taille < 1024) {$taille = _T('taille_octets', array('taille' => $taille));}
else if ($taille < 1024*1024) {
$taille = _T('taille_ko', array('taille' => ((floor($taille / 102.4))/10)));
function vider_url($url, $entites = true) {
# un message pour abs_url
$GLOBALS['mode_abs_url'] = 'url';
-
$url = trim($url);
- if (preg_match(",^(http:?/?/?|mailto:?)$,iS", $url))
- return '';
-
- if ($entites) $url = entites_html($url);
-
- return $url;
+ $r = ",^(?:" . _PROTOCOLES_STD . '):?/?/?$,iS';
+ return preg_match($r, $url) ?'': ($entites ? entites_html($url) : $url);
}
// Extraire une date de n'importe quel champ (a completer...)
return inserer_attribut($balise, $attribut, '', false, true);
}
-
-// Un filtre pour determiner le nom du mode des librement inscrits,
-// a l'aide de la liste globale des statuts (tableau mode => nom du mode)
-// Utile pour le formulaire d'inscription.
-// Si un mode est fourni, verifier que la configuration l'accepte.
-// Si mode inconnu laisser faire, c'est une extension non std
-// mais verifier que la syntaxe est compatible avec SQL
-
// http://doc.spip.org/@tester_config
function tester_config($id, $mode='') {
+ include_spip('inc/autoriser');
+ if ($mode)
+ return autoriser('inscrireauteur', $mode, $id) ? $mode : '';
+ elseif (
+ autoriser('inscrireauteur', $mode = "1comite", $id)
+ OR autoriser('inscrireauteur', $mode = "6forum", $id))
+ return $mode;
- $s = array_search($mode, $GLOBALS['liste_des_statuts']);
- switch ($s) {
-
- case 'info_redacteurs' :
- return (($GLOBALS['meta']['accepter_inscriptions'] == 'oui') ? $mode : '');
-
- case 'info_visiteurs' :
- return (($GLOBALS['meta']['accepter_visiteurs'] == 'oui' OR $GLOBALS['meta']['forums_publics'] == 'abo') ? $mode : '');
-
- default:
- if ($mode AND $mode == addslashes($mode))
- return $mode;
- if ($GLOBALS['meta']["accepter_inscriptions"] == "oui")
- return $GLOBALS['liste_des_statuts']['info_redacteurs'];
- if ($GLOBALS['meta']["accepter_visiteurs"] == "oui")
- return $GLOBALS['liste_des_statuts']['info_visiteurs'];
- return '';
- }
+ return '';
}
//
return ($mod?$nb%$mod:0)+$add;
}
+/**
+ * Vérifie qu'un nom (d'auteur) ne comporte pas d'autres tags que <multi>
+ * et ceux volontairement spécifiés dans la constante
+ *
+ * @param string $nom
+ * Nom (signature) proposé
+ * @return bool
+ * - false si pas conforme,
+ * - true sinon
+**/
+function nom_acceptable($nom) {
+ if (!is_string($nom)) {
+ return false;
+ }
+ if (!defined('_TAGS_NOM_AUTEUR')) define('_TAGS_NOM_AUTEUR','');
+ $tags_acceptes = array_unique(explode(',', 'multi,' . _TAGS_NOM_AUTEUR));
+ foreach($tags_acceptes as $tag) {
+ if (strlen($tag)) {
+ $remp1[] = '<'.trim($tag).'>';
+ $remp1[] = '</'.trim($tag).'>';
+ $remp2[] = '\x60'.trim($tag).'\x61';
+ $remp2[] = '\x60/'.trim($tag).'\x61';
+ }
+ }
+ $v_nom = str_replace($remp2, $remp1, supprimer_tags(str_replace($remp1, $remp2, $nom)));
+ return str_replace('<', '<', $v_nom) == $nom;
+}
// Verifier la conformite d'une ou plusieurs adresses email
// retourne false ou la normalisation de la derniere adresse donnee