Rev 609 | Go to most recent revision | Blame | Compare with Previous | Last modification | View Log | RSS feed
<?php
/***************************************************************************\
* SPIP, Systeme de publication pour l'internet *
* *
* Copyright (c) 2001-2005 *
* Arnaud Martin, Antoine Pitrou, Philippe Riviere, Emmanuel Saint-James *
* *
* Ce programme est un logiciel libre distribue sous licence GNU/GPL. *
* Pour plus de details voir le fichier COPYING.txt ou l'aide en ligne. *
\***************************************************************************/
//
// Ce fichier ne sera execute qu'une fois
if (defined("_ECRIRE_INC_ACCES")) return;
define("_ECRIRE_INC_ACCES", "1");
function creer_pass_aleatoire($longueur = 8, $sel = "") {
$seed = (double) (microtime() + 1) * time();
mt_srand($seed);
srand($seed);
$s = '';
$pass = '';
for ($i = 0; $i < $longueur; $i++) {
if (!$s) {
$s = mt_rand();
if (!$s) $s = rand();
$s = substr(md5(uniqid($s).$sel), 0, 16);
}
$r = unpack("Cr", pack("H2", $s.$s));
$x = $r['r'] & 63;
if ($x < 10) $x = chr($x + 48);
else if ($x < 36) $x = chr($x + 55);
else if ($x < 62) $x = chr($x + 61);
else if ($x == 63) $x = '/';
else $x = '.';
$pass .= $x;
$s = substr($s, 2);
}
$pass = ereg_replace("[./]", "a", $pass);
$pass = ereg_replace("[I1l]", "L", $pass);
$pass = ereg_replace("[0O]", "o", $pass);
return $pass;
}
//
// low-security : un ensemble de fonctions pour gerer de l'identification
// faible via les URLs (suivi RSS, iCal...)
//
function low_sec($id_auteur) {
// Pas d'id_auteur : low_sec
if (!$id_auteur = intval($id_auteur)) {
if (!$low_sec = lire_meta('low_sec')) {
include_ecrire('inc_meta.php3');
ecrire_meta('low_sec', $low_sec = creer_pass_aleatoire());
ecrire_metas();
}
}
else {
$query = "SELECT * FROM spip_auteurs WHERE id_auteur = $id_auteur";
$result = spip_query($query);
if ($row = spip_fetch_array($result)) {
$low_sec = $row["low_sec"];
if (!$low_sec) {
$low_sec = creer_pass_aleatoire();
spip_query("UPDATE spip_auteurs SET low_sec = '$low_sec' WHERE id_auteur = $id_auteur");
}
}
}
return $low_sec;
}
function afficher_low_sec ($id_auteur, $action='') {
return substr(md5($action.low_sec($id_auteur)),0,8);
}
function verifier_low_sec ($id_auteur, $cle, $action='') {
return ($cle == afficher_low_sec($id_auteur, $action));
}
function effacer_low_sec($id_auteur) {
if (!$id_auteur = intval($id_auteur)) return; // jamais trop prudent ;)
spip_query("UPDATE spip_auteurs SET low_sec = '' WHERE id_auteur = $id_auteur");
}
// Une fonction service qui affiche le statut de l'auteur dans l'espace prive
function afficher_formulaire_statut_auteur ($id_auteur, $statut, $post='') {
global $connect_statut, $connect_toutes_rubriques, $connect_id_auteur;
global $spip_lang_right;
if ($post) {
$url_self = $post;
echo "<p />";
echo "<form action='$post' method='post'>\n";
} else
$url_self = "auteur_infos.php3?id_auteur=$id_auteur";
// S'agit-il d'un admin restreint ?
if ($statut == '0minirezo') {
$query_admin = "SELECT lien.id_rubrique, titre FROM spip_auteurs_rubriques AS lien, spip_rubriques AS rubriques WHERE lien.id_auteur=$id_auteur AND lien.id_rubrique=rubriques.id_rubrique GROUP BY lien.id_rubrique";
$result_admin = spip_query($query_admin);
$admin_restreint = (spip_num_rows($result_admin) > 0);
}
// Seuls les admins voient le menu 'statut' ; les admins restreints
// ne peuvent l'utiliser que pour mettre un auteur a la poubelle
if ($connect_statut == "0minirezo"
AND ($connect_toutes_rubriques OR $statut != "0minirezo")
AND $connect_id_auteur != $id_auteur) {
debut_cadre_relief();
if ($statut == '0minirezo') {
if ($admin_restreint)
echo bouton_block_visible("statut$id_auteur");
else
echo bouton_block_invisible("statut$id_auteur");
}
echo "<b>"._T('info_statut_auteur')." </b> ";
echo "<select name='statut' size=1 class='fondl'>";
if ($connect_statut == "0minirezo" AND $connect_toutes_rubriques)
echo "<OPTION".mySel("0minirezo",$statut).">"._T('item_administrateur_2');
echo "<OPTION".mySel("1comite",$statut).">"._T('intem_redacteur');
if (($statut == '6forum')
OR (lire_meta('accepter_visiteurs') == 'oui')
OR (lire_meta('forums_publics') == 'abo')
OR spip_num_rows(spip_query("SELECT statut
FROM spip_auteurs WHERE statut='6forum'")))
echo "<OPTION".mySel("6forum",$statut).">"._T('item_visiteur');
echo "<OPTION".mySel("5poubelle",$statut).
" style='background:url(" . _DIR_IMG_PACK . "rayures-sup.gif)'>> "._T('texte_statut_poubelle');
echo "</select>\n";
//
// Gestion restreinte des rubriques
//
if ($statut == '0minirezo') {
if (!$admin_restreint) {
echo debut_block_invisible("statut$id_auteur");
echo "<p /><div style='arial2'>\n";
echo _T('info_admin_gere_toutes_rubriques');
} else {
echo debut_block_visible("statut$id_auteur");
echo "<p /><div style='arial2'>\n";
echo _T('info_admin_gere_rubriques')."\n";
echo "<ul style='list-style-image: url(" . _DIR_IMG_PACK . "rubrique-12.gif)'>";
while ($row_admin = spip_fetch_array($result_admin)) {
$id_rubrique = $row_admin["id_rubrique"];
$titre = typo($row_admin["titre"]);
echo "<li>$titre";
if ($connect_toutes_rubriques
AND $connect_id_auteur != $id_auteur) {
echo " <font size=1>"
. "[<a href='$url_self&supp_rub=$id_rubrique'>"
._T('lien_supprimer_rubrique')
."</a>]</font>";
}
$toutes_rubriques .= "$id_rubrique,";
}
echo "</ul>";
$toutes_rubriques = ",$toutes_rubriques";
}
if ($connect_toutes_rubriques
AND $connect_id_auteur != $id_auteur) {
echo "</div><br /><div class='arial1'>";
if (spip_num_rows($result_admin) == 0) {
echo "<b>"._T('info_restreindre_rubrique')."</b><br />";
} else {
echo "<b>"._T('info_ajouter_rubrique')."</b><br />";
}
echo "<INPUT NAME='id_auteur' VALUE='$id_auteur' TYPE='hidden'>";
echo "<SELECT NAME='add_rub' SIZE=1 CLASS='formo'>";
echo "<OPTION VALUE='0'>\n";
afficher_auteur_rubriques("0");
echo "</SELECT>";
}
echo "</div>\n";
echo fin_block();
}
if ($post) {
echo "<div align='$spip_lang_right'><input type='submit'
class='fondo' name='Valider'
value=\""._T('bouton_valider')."\" /></div>";
echo "</form>\n";
}
fin_cadre_relief();
}
}
function modifier_statut_auteur (&$auteur, $statut, $add_rub='', $supp_rub='') {
global $connect_statut, $connect_toutes_rubriques;
// changer le statut ?
if ($connect_statut == '0minirezo' AND $statut) {
if (ereg("^(0minirezo|1comite|5poubelle|6forum)$",$statut)) {
$auteur['statut'] = $statut;
spip_query("UPDATE spip_auteurs SET statut='".$statut."'
WHERE id_auteur=".$auteur['id_auteur']);
}
}
// modif auteur restreint, seulement pour les admins
if ($connect_toutes_rubriques) {
if ($add_rub=intval($add_rub))
spip_query("INSERT INTO spip_auteurs_rubriques
(id_auteur,id_rubrique)
VALUES(".$auteur['id_auteur'].", $add_rub)");
if ($supp_rub=intval($supp_rub))
spip_query("DELETE FROM spip_auteurs_rubriques
WHERE id_auteur=".$auteur['id_auteur']."
AND id_rubrique=$supp_rub");
}
}
function initialiser_sel() {
global $htsalt;
$htsalt = '$1$'.creer_pass_aleatoire();
}
function ecrire_logins($fichier, $tableau_logins) {
reset($tableau_logins);
while(list($login, $htpass) = each($tableau_logins)) {
if ($login && $htpass) {
fputs($fichier, "$login:$htpass\n");
}
}
}
function ecrire_acces() {
$htaccess = _DIR_RESTREINT . _ACCESS_FILE_NAME;
$htpasswd = _DIR_SESSIONS . _AUTH_USER_FILE;
// si .htaccess existe, outrepasser spip_meta
if ((lire_meta('creer_htpasswd') == 'non') AND !@file_exists($htaccess)) {
@unlink($htpasswd);
@unlink($htpasswd."-admin");
return;
}
# remarque : ici on laisse passer les "nouveau" de maniere a leur permettre
# de devenir "1comite" le cas echeant (auth http)... a nettoyer
$query = "SELECT login, htpass FROM spip_auteurs WHERE statut != '5poubelle' AND statut!='6forum'";
$result = spip_query_db($query); // attention, il faut au prealable se connecter a la base (necessaire car utilise par install.php3)
$logins = array();
while($row = spip_fetch_array($result)) $logins[$row['login']] = $row['htpass'];
$fichier = @fopen($htpasswd, "w");
if ($fichier) {
ecrire_logins($fichier, $logins);
fclose($fichier);
} else {
redirige_par_entete("../spip_test_dirs.php3");
}
$query = "SELECT login, htpass FROM spip_auteurs WHERE statut = '0minirezo'";
$result = spip_query_db($query);
$logins = array();
while($row = spip_fetch_array($result)) $logins[$row['login']] = $row['htpass'];
$fichier = fopen("$htpasswd-admin", "w");
ecrire_logins($fichier, $logins);
fclose($fichier);
}
function generer_htpass($pass) {
global $htsalt, $flag_crypt;
if ($flag_crypt) return crypt($pass, $htsalt);
else return '';
}
//
// Verifier la presence des .htaccess
//
function verifier_htaccess($rep) {
$htaccess = "$rep/" . _ACCESS_FILE_NAME;
if ((!@file_exists($htaccess)) AND
!defined('_ECRIRE_INSTALL') AND !defined('_TEST_DIRS')) {
spip_log("demande de creation de $htaccess");
if ($_SERVER['SERVER_ADMIN'] != 'www@nexenservices.com'){
if (!$f = fopen($htaccess, "w"))
echo "<b>" .
"ECHEC DE LA CREATION DE $htaccess" . # ne pas traduire
"</b>";
else
{
fputs($f, "deny from all\n");
fclose($f);
}
} else {
echo "<font color=\"#FF0000\">IMPORTANT : </font>";
echo "Votre hébergeur est Nexen Services.<br />";
echo "La protection du répertoire <i>$rep/</i> doit se faire
par l'intermédiaire de ";
echo "<a href=\"http://www.nexenservices.com/webmestres/htlocal.php\"
target=\"_blank\">l'espace webmestres</a>.";
echo "Veuillez créer manuellement la protection pour
ce répertoire (un couple login/mot de passe est
nécessaire).<br />";
}
}
}
function gerer_htaccess() {
$mode = lire_meta('creer_htaccess');
$r = spip_query("SELECT extension FROM spip_types_documents");
while ($e = spip_fetch_array($r)) {
if (is_dir($dir = _DIR_DOC . $e['extension'])) {
if ($mode == 'oui')
verifier_htaccess($dir);
else @unlink("$dir/" . _ACCESS_FILE_NAME);
}
}
return $mode;
}
// En profiter pour verifier la securite de ecrire/data/
verifier_htaccess(_DIR_SESSIONS);
initialiser_sel();
?>