#!/usr/bin/perl use strict; use vars qw(%form %CONF $VERSION $DATA_DIR $FONT); print "Content-type: text/html\n\n"; # On affiche l'en-tête HTML indispensable ##### CONFIG ################################### $VERSION='2.0'; # 30/04/2003 $DATA_DIR='pg-recommander-data'; ################################################ ############################################################################## # Ceci est un script CGI en Perl, réalisé par Sébastien Joncheray. # # Vous pouvez l'utiliser gratuitement, à la condition expresse et # # non négociable de ne pas le modifier du tout, ni de le réutiliser/recopier # # en tout ou partie, revendre, louer, redistribuer, etc. # # Un droit d'utilisation gratuite vous est accordé. Tous les autres droits # # sont réservés. Toute contrefacon fait l'objet de poursuites. Nous vous # # fournissons gratuitement ce script de qualité,merci de respecter le travail# # de l'auteur. Pour nous contacter si besoin, voyez sur www.perl-gratuit.com # ############################################################################## # IL EST PAR-DESSUS TOUT INTERDIT DE MODIFIER LES MENTIONS DE L'AUTEUR # # (COPYRIGHT, SITE DE L'AUTEUR,ETC). CELA EST LA CONTREPARTIE DE LA GRATUITé # ############################################################################## # De nombreux autres scripts perl en francais, sont disponibles gratuitement # # sur notre site : http://www.perl-gratuit.com # # # # En cas de difficultés d'installations veuillez consultez les FAQs et autres# # sections d'aide sur www.perl-gratuit.com, avant d'envoyer un E-Mail SVP... # ############################################################################## # Tous droits de modification/distribution/vente strictement réservés # ############################################################################## %form=&receive_getpost; &init; if(($form{'email_dest'} ne '') || ($form{'email_visiteur'} ne '') || ($form{'nom_dest'} ne '') || ($form{'nom_visiteur'} ne '')) { # Si envoi du formulaire ################################## #### Quelques vérifications : #### ################################## if ($form{'nom_visiteur'} eq '') { &print_out("$CONF{thefont}You did not write your name..."); } if ($form{'email_visiteur'} eq '') { &print_out("$CONF{thefont}You did not write your email adress..."); } if ($form{'nom_dest'} eq '') { &print_out("$CONF{thefont}You did not write the recipient name..."); } if ($form{'email_dest'} eq '') { &print_out("$CONF{thefont}You did not write the recipient email adress..."); } ## on vérifie les adresses E-Mail données if (!&verify_email($form{'email_visiteur'})) { &print_out("$CONF{thefont}Your email adress $form{'email_visiteur'} is not correct."); } if (!&verify_email($form{'email_dest'})) { &print_out("$CONF{thefont}The recipient email adress $form{'email_dest'} is not correct."); } ## On vérifie que le message personnalisé n'est pas trop important: if (length($form{'message'}) > 2000) { &print_out("$CONF{thefont}The personnal message you wrote is to long (2000 caract. maximum)."); } $form{'message'}=~ s/\r\n/\n/g; #### Envoi Email au destinataire #### if (length($form{'message'}) > 5) { # si message perso, on l'ajoute $CONF{'MESSAGE_DEST'}.="\n\nMESSAGE ADDED BY [nom_visiteur]:\n".('-' x 30)."\n$form{'message'}\n"; } &send_email($CONF{'EMAIL_WEBMASTER'},$form{'email_dest'},'Recommanded site',&remplir_template($CONF{'MESSAGE_DEST'})); ### Envoi confirmation visiteur si besoin ### if ($CONF{'NOTIFY_VISITEUR'} == 1) { &send_email($CONF{'EMAIL_WEBMASTER'},$form{'email_visiteur'},'Recommanded site',&remplir_template($CONF{'MESSAGE_VISITEUR'})); } ### Envoi notification webmaster si besoin ### if ($CONF{'NOTIFY_WEBMASTER'} == 1) { &send_email($CONF{'EMAIL_WEBMASTER'},$CONF{'EMAIL_WEBMASTER'},'[PG-RECOMMANDER]'," Ceci est un E-Mail automatique de PG-RECOMMANDER pour vous informer que $form{'nom_visiteur'} ($form{'email_visiteur'}) a recommandé votre site à : $form{'nom_dest'} ($form{'email_dest'})\n Adresses sauvegardées sans doublon, stats mises à jour.\n Fin du message."); } #### SAUVEGARDE INFOS VISITEUR #### { my $buf=quotemeta($form{'email_visiteur'}); if (open(COLLVRW,"+<$DATA_DIR/collecte_visiteur.dat")) { flock(COLLVRW,2); seek(COLLVRW,0,0); if ( scalar(grep(/^$buf\|/,)) == 0) { # si email pas encore dans la liste... seek(COLLVRW,0,2); print COLLVRW ($form{'email_visiteur'}.'|'.$form{'nom_visiteur'}."\n"); } close (COLLVRW); } } #### SAUVEGARDE INFOS DESTINATAIRE #### { my $buf=quotemeta($form{'email_dest'}); if (open(COLLDRW,"+<$DATA_DIR/collecte_dest.dat")) { flock(COLLDRW,2); seek(COLLDRW,0,0); if ( scalar(grep(/^$buf\|/,)) == 0) { # si email pas encore dans la liste... seek(COLLDRW,0,2); print COLLDRW ($form{'email_dest'}.'|'.$form{'nom_dest'}."\n"); } close (COLLDRW); } } #### SAUVEGARDE STATS #### $ENV{'HTTP_REFERER'}=~ s/\?.*$//g; if (($ENV{'HTTP_REFERER'} ne '') && (length($ENV{'HTTP_REFERER'}) < 200)) { $ENV{'HTTP_REFERER'}=~ s/\t+//gs; # on enlève les tabulations éventuelles car on utilise \t comme séparateur my %stats=(); if (open(STATRW,"+<$DATA_DIR/stats.dat")) { flock(STATRW,2); ## on lit les données existantes while() { chomp($_); if ($_=~ /^([^\t]+)\t(\d+)$/) { $stats{"$1"}+=$2; } } $stats{$ENV{'HTTP_REFERER'}}+=1; # Sauvegarde seek(STATRW,0,0); while ( ($a,$b)=each %stats) { print STATRW "$a\t$b\n"; } truncate(STATRW,tell(STATRW)); close (STATRW); } } &print_out("

$CONF{thefont} Thank you $form{'nom_visiteur'} !
 
On your demande, an email has been send to $form{'nom_dest'} ($form{'email_dest'}) on your name to recommand this site.
 
RETURN

"); } else { # Si le CGI a été appelé sans paramètres, on affiche juste le formulaire &print_out($CONF{'theform'}); } 1; ################### FIN ! ###################### ################################################ ################################################ #### ATTENTION, réutilisation/recopie du #### #### code source interdite et illégale #### ################################################ sub receive_getpost { # 2002-09-20 my (%postdata,$data,$pair); $data=''; if ($ENV{'REQUEST_METHOD'} eq 'POST') { my $len=$ENV{'CONTENT_LENGTH'}; if (read(STDIN,$data,$len) != $len) {print ("

error reading post data

"); die("Error reading 'POST' data\n"); } } elsif ($ENV{'REQUEST_METHOD'} eq 'GET') { $data=$ENV{'QUERY_STRING'}; } foreach $pair (split('&',$data)) { my ($name,$value)=split('=',$pair); $name=~ tr/\0//d; $value=~ tr/\0//d; $name =~ tr/+/ /; $name =~ s/%([0-9a-fA-F]{2})/chr hex($1)/ge; $value=~ tr/+/ /; $value=~ s/%([0-9a-fA-F]{2})/chr hex($1)/ge; $postdata{$name}=$value; } return %postdata; } ################################################ #### ATTENTION, réutilisation/recopie du #### #### code source interdite et illégale #### ################################################ sub print_out { my ($msg)=@_; ## ATTENTION, si vous modifiez ou supprimez les lignes ci-dessous, vous ne # ## respectez pas les conditions d'utilisation gratuite de ce programme, et # ## vous vous en servez de manière illégale ! Merci de respecter le travail # ## de l'auteur ! Merci de votre compréhension. # my $out=$CONF{'TEMPLATE_STD'} || (print "Le modèle d'affichage aux visiteurs est absent.
Veuillez vous rendre dans l'administration, section de paramétrage : vérifiez et validez la configuration SVP." and exit(0)); $out=~ s/\[message\]/$msg/gs || (print "Le modèle d'affichage aux visiteurs ne contient pas le tag spécial [message]
Veuillez vous rendre dans l'administration, section de paramétrage : vérifiez et validez la configuration SVP." and exit(0));print "$out

 

$FONT Script CGI Perl disponible sur Perl-Gratuit.com
";exit(0); ## ATTENTION, si vous modifiez ou supprimez les lignes ci-dessus, vous ne # ## respectez pas les conditions d'utilisation gratuite de ce programme, et # ## vous vous en servez de manière illégale ! Merci de respecter le travail # ## de l'auteur. Merci de votre compréhension. # } ################################################ #### ATTENTION, réutilisation/recopie du #### #### code source interdite et illégale #### ################################################ sub formfield_encode { # 27/01/2002 my ($s)=@_; $s=~ s/&/&/gso; $s=~ s//>/gso; $s=~ s/"/"/gso; $s; } ################################################ #### ATTENTION, réutilisation/recopie du #### #### code source interdite et illégale #### ################################################ sub verify_email { # 29-06-2002 my ($email)=@_; if ($email eq '') { return(0);} if ( ($email =~ /(\s)|(@.*@)|(\.\.)|(@\.)|(^\.)/) || (($email !~ /^[a-zA-Z0-9\-\_\.]+\@localhost$/) && ($email !~ /^[a-zA-Z0-9\-\_\.]+\@(\[?)[a-zA-Z0-9\-\.]+\.([a-zA-Z0-9]+)(\]?)$/)) ) { return(0); } else { return(1); } } ################################################ #### ATTENTION, réutilisation/recopie du #### #### code source interdite et illégale #### ################################################ sub send_email { # Sous-programme pour envoyer un E-Mail my ($from,$to,$subject,$message)=@_; # Récupération des paramètres du mail à envoyer $from=~ s/\s/ /gs; # anti-spam $to=~ s/\s/ /gs; # anti-spam $subject=~ s/\s/ /gs; # anti-spam if ($^O=~ /mswin/i) { print "
$message
Ce script n'est pas fait pour fonctionner sur serveur windows! mail non envoyé!
" and return;} open (MAIL, "|$CONF{'MAILPROG'} -t -oi -oem");# Appel du programme sendmail (PIPE) print MAIL ("To: $to\n"); print MAIL ("From: $from\n"); print MAIL ("Subject: $subject\n\n"); print MAIL ("$message"); close (MAIL); # On referme le canal de communication avec sendmail, et le mail part... } ################################################ #### ATTENTION, réutilisation/recopie du #### #### code source interdite et illégale #### ################################################ sub remplir_template { my ($msg)=@_; ## ATTENTION, si vous modifiez ou supprimez les lignes ci-dessous, vous ne # ## respectez pas les conditions d'utilisation gratuite de ce programme, et # ## vous vous en servez de manière illégale ! Merci de respecter le travail # ## de l'auteur ! Si vous souhaitez modifier ces lignes, il vous faudra # ## aquérir une licence payante. Merci de votre compréhension. # $msg=~ s/\[email_dest\]/$form{email_dest}/gs; $msg=~ s/\[email_visiteur\]/$form{email_visiteur}/gs; $msg=~ s/\[nom_dest\]/$form{nom_dest}/gs; $msg=~ s/\[nom_visiteur\]/$form{nom_visiteur}/gs; $msg.="\n\n\n".'_' x 46 ."\nPG-RECOMMANDER. Script CGI Perl of recommandation\navailable on http://www.perl-gratuit.com \n"; return ($msg); ## ATTENTION, si vous modifiez ou supprimez les lignes ci-dessus, vous ne # ## respectez pas les conditions d'utilisation gratuite de ce programme, et # ## vous vous en servez de manière illégale ! Merci de respecter le travail # ## de l'auteur ! Si vous souhaitez modifier ces lignes, il vous faudra # ## aquérir une licence payante. Merci de votre compréhension. # } ################################################ ################################################ ####### ####### ####### ADMINISTRATION ####### ####### ####### ################################################ sub init { %CONF=(); $CONF{'CGI_NAME'}='PG-Recommander'; # Nom du CGI: NE PAS CHANGER SINON ERREURS...(noms images) $CONF{'CGI_DESC'}="Recommandation de votre site"; # Description du CGI: NE PAS CHANGER SINON ERREURS... $CONF{'IMGCGI_URL'}='http://img-scripts.perl-gratuit.com'; $CONF{'SERVER_NAME'}=($ENV{'SERVER_NAME'} || $ENV{'HTTP_HOST'}); $CONF{'CGI_URL'}=($ENV{'REQUEST_URI'} || $ENV{'SCRIPT_NAME'}); $CONF{'CGI_URL'}=~ s/\?.*//gs; $CONF{'CGI0_URL'}="http://".$CONF{'SERVER_NAME'}.$CONF{'CGI_URL'}; # URL complète, à utiliser pour visiteurs only (valeur par défaut) $FONT=""; ## Vérif que le répertoire des données existe ## if (! -e "$DATA_DIR") { &msg_fin("ERREUR !","Pour faire fonctionner ce CGI, il vous faut créer, dans le répertoire où se trouve ce script, le sous-répertoire $DATA_DIR
N'oubliez pas de lui attribuer CHMOD 777 (tous droits de lecture,écriture,éxécution) si votre serveur est de type Unix.
Pour plus d'informations sur 'CHMOD', voyez sur notre site dans les fiches pratiques/FAQ."); } ## Vérif que le fichier de configuration existe ## if (! -e "$DATA_DIR/config.dat") { open(TESTW,">$DATA_DIR/config.dat") || (&msg_fin("ERREUR !","Impossible de créer le fichier $DATA_DIR/config.dat : $!
Vérifiez le CHMOD 777 du répertoire $DATA_DIR")); close(TESTW); eval{ chmod(0777,"$DATA_DIR/config.dat");}; &msg_fin("Auto-installation",qq|

Bienvenue dans l'auto-installation de "$CONF{'CGI_NAME'}" !

$FONT Vous éxécutez ce script CGI Perl pour la première fois. Afin de faciliter la mise en place de ce script sur votre site, l'installation-configuration est guidée et automatisée par étapes successives. Un fichier de configuration va être créé, un choix de mot de passe administrateur vous sera demandé, puis une page de choix de configuration vous sera présentée. Nous vous conseillons fortement ensuite de consulter la section de documentation inclue.
 
Toute cette procédure vous permet une mise en place aisée, sans besoin d'intervenir manuellement dans les fichiers et répertoires de données de ce script.

$FONTVeuillez maintenant actualiser cette page pour continuer SVP...
(cliquez sur le bouton "Actualiser" de votre navigateur)

|); } ## Vérif que le fichier mot de passe existe ## if (! -e "$DATA_DIR/passwd.dat") { open(TESTW,">$DATA_DIR/passwd.dat") || (&msg_fin("ERREUR !","Impossible de créer le fichier $DATA_DIR/passwd.dat : $!
Vérifiez le CHMOD 777 du répertoire $DATA_DIR")); close(TESTW); eval{ chmod(0777,"$DATA_DIR/passwd.dat");}; &msg_fin("Auto-installation",qq|

Conditions d'utilisation gratuite :

$FONT Au bas des pages générées par ce script vous verrez un copyright et la mention de l'auteur (nom et lien vers notre site).
Un droit d'utilisation gratuite de ce script CGI Perl vous est accordé à la condition expresse de ne pas le modifier du tout (y compris et tout particulièrement ces copyrights et mentions de l'auteur), ni de le réutiliser/recopier en tout ou partie, revendre, louer, redistribuer, etc. Tous les droits autres que l'utilisation gratuite sont réservés (nous contacter au besoin).
 
Tout simplement, merci de respecter le travail de l'auteur afin que nous puissions continuer à vous proposer de tels scripts.

$FONTVeuillez maintenant actualiser cette page pour continuer SVP...
(cliquez sur le bouton "Actualiser" de votre navigateur)

|); } ## Vérif que le répertoire des données est protégé ## if (!-e "$DATA_DIR/.htaccess") { open(HTW,">$DATA_DIR/.htaccess") || (&msg_fin("ERREUR !","Impossible de créer le fichier $DATA_DIR/.htaccess : $!
Vérifiez le CHMOD 777 du répertoire $DATA_DIR")); print HTW "\norder deny,allow\ndeny from all\n\n"; close(HTW); eval{ chmod(0666,"$DATA_DIR/.htaccess");}; &msg_fin("AUTO-PROTECTION DES DONNEES",qq|

Sécurité de votre répertoire des données

$FONT Certains serveurs peu ou mal sécurisés permettent l'accès, le listing et la consultation des fichiers à l'intérieur de la section "cgi-bin" des sites hébergés.
 
Afin d'empêcher tout accès par la navigateur dans votre répertoire des données $DATA_DIR un fichier spécial ".htaccess" vient d'être automatiquement créé avec les directives-serveurs adéquates.
 
Selon votre serveur, il se peut que vous ne puissiez pas voir le .htaccess par FTP. Dans ce cas, consultez la page d'informations correspondante dans la section Fiches Pratiques de notre site.

$FONTVeuillez maintenant actualiser cette page pour continuer SVP...
(cliquez sur le bouton "Actualiser" de votre navigateur)

|); } ## Chargement configuration open (CONFR,"$DATA_DIR/config.dat") || &msg_fin("ERREUR !", "Impossible de lire le fichier $DATA_DIR/config.dat: $!"); eval{flock(CONFR,2);}; while () { chomp($_); if ( ($_ ne '') && ($_!~ /^#/) && ($_=~ /^([^\s]+)\s+(.*)/) ) { $CONF{"$1"}="$2"; $CONF{"$1"}=~ s/\|\\n\|/\n/gs; } } close (CONFR); ## Chargement mot de passe: open (PASSR,"$DATA_DIR/passwd.dat") || (&msg_fin("ERREUR !","Impossible de lire le fichier $DATA_DIR/passwd.dat: $!")); $CONF{'CPASSWD'}=; close(PASSR); chomp($CONF{'CPASSWD'}); ## Vérif mot de passe fixé if ($CONF{'CPASSWD'} eq '') { (($form{'ORDadmin_changepass_do'} eq '') && (&admin_changepass) ) || (&admin_changepass_do); } ## OPTIONNAL STUFF : if (! -e "$DATA_DIR/collecte_visiteur.dat") { open(BUF1,">$DATA_DIR/collecte_visiteur.dat") || (&msg_fin("ERREUR !","Impossible de créer le fichier $DATA_DIR/collecte_visiteur.dat : $!
Vérifiez le CHMOD 777 du répertoire $DATA_DIR")); close(BUF1); eval{ chmod(0777,"$DATA_DIR/collecte_visiteur.dat");}; } if (! -e "$DATA_DIR/collecte_dest.dat") { open(BUF2,">$DATA_DIR/collecte_dest.dat") || (&msg_fin("ERREUR !","Impossible de créer le fichier $DATA_DIR/collecte_dest.dat : $!
Vérifiez le CHMOD 777 du répertoire $DATA_DIR")); close(BUF2); eval{ chmod(0777,"$DATA_DIR/collecte_dest.dat");}; } if (! -e "$DATA_DIR/stats.dat") { open(BUF3,">$DATA_DIR/stats.dat") || (&msg_fin("ERREUR !","Impossible de créer le fichier $DATA_DIR/stats.dat : $!
Vérifiez le CHMOD 777 du répertoire $DATA_DIR")); close(BUF3); eval{ chmod(0777,"$DATA_DIR/stats.dat");}; } $CONF{'thefont'}=""; $CONF{'theform'}=qq|
You name
Your email adress
Recipient name
Recipient email adress
Add a personnal message (optional):
|; ## L'administrateur veut entrer ? ## if($ENV{'QUERY_STRING'} eq 'admin') { &msg_fin("ENTREE ADMINISTRATEUR",qq|
Mot de Passe :
 
|); } ## L'administrateur est déjà entré ## if ($form{'PASSWD'}) { # On vérifie le mot de passe s'il y en a un if (crypt($form{'PASSWD'},'aa') ne $CONF{'CPASSWD'}) { sleep(3); &msg_fin ("ACCES ADMINSTRATEUR REFUSE","Le mot de passe n'est pas correct !
Retournez à la page précédente pour retenter...
Si vous ne parvenez pas à vous souvenir de votre mot de passe, une seule chose à faire : par FTP, supprimez le fichier "$DATA_DIR/passwd.dat" puis rendez-vous à l'URL de ce script pour fixer un nouveau mot de passe."); } ## Vérif paramétrage effectué ## if (!$CONF{'config_param'}) { ( ($form{'ORDadmin_param_do'} eq '') && (&admin_param) ) || (&admin_param_do); } &admin; exit(0); } ## sinon retour à l'utilisation publique normale } ################################################ ################################################ sub msg_fin { my ($titre,$tip)=@_; my ($d1,$d2); ## ATTENTION, si vous modifiez ou supprimez les lignes ci-dessous, vous ne # ## respectez pas les conditions d'utilisation gratuite de ce programme, et # ## vous vous en servez de manière illégale ! Merci de respecter le travail # ## de l'auteur ! Merci de votre compréhension. # print qq| $CONF{CGI_NAME} - Administration

 

$CONF{'CGI_NAME'} : $titre

 

$tip

 

Script CGI Perl gratuit disponible sur perl-gratuit.com. v$VERSION ©
|; exit(0); ## ATTENTION, si vous modifiez ou supprimez les lignes ci-dessus, vous ne # ## respectez pas les conditions d'utilisation gratuite de ce programme, et # ## vous vous en servez de manière illégale ! Merci de respecter le travail # ## de l'auteur ! Merci de votre compréhension. # } ################################################ #### ATTENTION, réutilisation/recopie du #### #### code source interdite et illégale #### ################################################ sub admin { if ($form{'ORDadmin_changepass'}) { &admin_changepass; } elsif ($form{'ORDadmin_changepass_do'}) { &admin_changepass_do; } elsif ($form{'ORDadmin_version'}) { &admin_version; } elsif ($form{'ORDadmin_info'}) { &admin_info; } elsif ($form{'ORDadmin_param'}) { &admin_param; } elsif ($form{'ORDadmin_param_do'}) { &admin_param_do; } elsif ($form{'ORDadmin_stats'}) { &admin_stats; # } elsif ($form{'ORDadmin_statsreset'}) { &admin_statsreset; # } elsif ($form{'ORDadmin_export'}) { &admin_export; # } else { &admin_menu; } exit(0); } ################################################ #### ATTENTION, réutilisation/recopie du #### #### code source interdite et illégale #### ################################################ sub admin_menu { my (%tmpl)=(); $tmpl{'EMAIL_WEBMASTER'}=$CONF{'EMAIL_WEBMASTER'}; $tmpl{'NOTIFY_WEBMASTER'}=$CONF{'NOTIFY_WEBMASTER'}==1?'Oui':'Non'; $tmpl{'NOTIFY_VISITEUR'}=$CONF{'NOTIFY_VISITEUR'}==1?'Oui':'Non'; $tmpl{'MAILPROG'}=$CONF{'MAILPROG'}; $tmpl{'FONT_FACE'}=$CONF{'FONT_FACE'}; $tmpl{'FONT_SIZE'}=$CONF{'FONT_SIZE'}; $tmpl{'FONT_COLOR'}=$CONF{'FONT_COLOR'}; ## Nb visiteurs collectées ## $tmpl{'nb_visiteur'}='0'; open(BUF1,"$DATA_DIR/collecte_visiteur.dat") || (&msg_fin('ERREUR',"Impossible de lire le fichier $DATA_DIR/collecte_visiteur.dat: $!")); while () {$tmpl{'nb_visiteur'}++;} close(BUF1); ## Nb destinataires collectés ## $tmpl{'nb_dest'}='0'; open(BUF2,"$DATA_DIR/collecte_dest.dat") || (&msg_fin('ERREUR',"Impossible de lire le fichier $DATA_DIR/collecte_dest.dat: $!")); while () {$tmpl{'nb_dest'}++;} close(BUF2); &msg_fin("Menu Administration",qq|
Vos paramètres :
$FONT E-Mail administrateur : $FONT $tmpl{EMAIL_WEBMASTER}
$FONT Notifications au Webmaster :     $FONT $tmpl{NOTIFY_WEBMASTER}
$FONT Notifications au visiteur : $FONT $tmpl{NOTIFY_VISITEUR}
$FONT Emplacement sendmail : $FONT $tmpl{MAILPROG}
$FONT Police de caractères : $FONT $tmpl{FONT_FACE}, taille:$tmpl{FONT_SIZE}, couleur:$tmpl{FONT_COLOR}
$FONT Adresses collectées : $FONT $tmpl{nb_visiteur} adresses de visiteurs
$tmpl{nb_dest} adresses de destinataires

Menu :
Voir les statistiques d'utilisation.
Exporter la liste des
      au format

Modifier vos paramètres.
Modifier votre mot de passe.
Dernière version disponible.
DOCUMENTATION / INFORMATIONS A LIRE
|); } ################################################ #### ATTENTION, réutilisation/recopie du #### #### code source interdite et illégale #### ################################################ sub admin_changepass { &msg_fin("Modification du mot de passe Administrateur", "

$FONT Choisissez votre nouveau mot de passe Administrateur de ce script (4 à 8 caractères).

$FONT Nouveau mot de passe :
$FONT Nouveau mot de passe (confirmation) :
\n"); } ################################################ #### ATTENTION, réutilisation/recopie du #### #### code source interdite et illégale #### ################################################ sub admin_changepass_do { if (length($form{'new_passwd'}) < 4) { &msg_fin("ERREUR !","Le mot de passe $form{new_passwd} fait moins de 4 caractères, ce qui est dangereux !");} if ($form{'new_passwd'} ne $form{'new_passwdbis'}) { &msg_fin("ERREUR !","Les deux cases de mot de passe ne sont pas identiques");} $CONF{'CPASSWD'}=crypt($form{'new_passwd'},'aa'); open (PASSW,">$DATA_DIR/passwd.dat") || (&msg_fin("ERREUR !","Impossible d'enregistrer dans le fichier $DATA_DIR/passwd.dat ($!), veuillez vérifier le chmod 777 du répertoire $DATA_DIR: $!")); print PASSW "$CONF{'CPASSWD'}"; close (PASSW); eval{ chmod(0666,"$DATA_DIR/passwd.dat");}; $form{'PASSWD'}=$form{'new_passwd'}; &msg_fin("Mot de passe Administrateur modifié", "

$FONT Le mot de passe pour l'accès Administrateur a été modifié et est maintenant $form{'new_passwd'}. Attention, il est sauvegardé de façon cryptée. Vous ne pourrez pas (ce programme non plus) le décrypter. Si vous l'oubliez, lorsque vous tenterez d'accéder ici avec un mauvais mot de passe, un message vous expliquera comment faire.

\n"); } ################################################ #### ATTENTION, réutilisation/recopie du #### #### code source interdite et illégale #### ################################################ sub admin_param { my (%tmpl); if (!$CONF{'config_param'}) { $CONF{'NOTIFY_WEBMASTER'}=1; $CONF{'NOTIFY_VISITEUR'}=1; $CONF{'FONT_FACE'}='Arial'; $CONF{'FONT_SIZE'}=2; $CONF{'FONT_COLOR'}='#000000'; $CONF{'MESSAGE_DEST'}=qq|[nom_dest],\n\n[nom_visiteur] ([email_visiteur]) vous envoie\nce message pour vous recommander d'aller voir le site:\nhttp://www.votre-site-ici.com\n\nVous trouverez sur ce site :\n - des infos sur...\n - des services concernant...\nVous souhaitant bonne visite,\n\nLe webmaster|; $CONF{'MESSAGE_VISITEUR'}=qq|[nom_visiteur],\n\nCeci est un E-Mail automatique pour confirmer que suite\nà votre demande, un E-Mail à été envoyé à [nom_dest]\n([email_dest]) pour recommander le site :\nhttp://www.votre-site-ici.com\n\nEn vous remerciant,\n\nLe Webmaster.\n|; } # default-getback template if ($CONF{'TEMPLATE_STD'} eq '') { $CONF{'TEMPLATE_STD'}=qq|\n\n

 

\n\n
[message]
\n\n|;} $tmpl{'CGI0_URL'} =&formfield_encode($CONF{'CGI0_URL'}); $tmpl{'EMAIL_WEBMASTER'}=&formfield_encode($CONF{'EMAIL_WEBMASTER'}); $tmpl{'MAILPROG'} =&formfield_encode($CONF{'MAILPROG'}); $tmpl{'NOTIFY_WEBMASTER'}= $CONF{'NOTIFY_WEBMASTER'} ? ' checked' : ''; $tmpl{'NOTIFY_VISITEUR'} = $CONF{'NOTIFY_VISITEUR'} ? ' checked' : ''; $tmpl{'TEMPLATE_STD'}=&formfield_encode($CONF{'TEMPLATE_STD'}); $tmpl{'MESSAGE_DEST'}=&formfield_encode($CONF{'MESSAGE_DEST'}); $tmpl{'MESSAGE_VISITEUR'}=&formfield_encode($CONF{'MESSAGE_VISITEUR'}); $tmpl{'FONT_FACE'} =&formfield_encode($CONF{'FONT_FACE'}); $tmpl{'FONT_SIZE'} =&formfield_encode($CONF{'FONT_SIZE'}); $tmpl{'FONT_COLOR'}=&formfield_encode($CONF{'FONT_COLOR'}); ## Recherche des emplacements de sendmail, aux endroits classiques sur Unix/Linux foreach ('/usr/lib/sendmail','/usr/bin/sendmail','/bin/sendmail','/usr/sbin/sendmail','/usr/local/bin/sendmail','/usr/local/lib/sendmail') { if ((-e $_) && (-x $_)) { $tmpl{'guessed_sendmail'}.="$_
"; } } if ($tmpl{'guessed_sendmail'} eq'') { $tmpl{'guessed_sendmail'}='Aucun';} &msg_fin("Configuration",qq|
$FONTURL complète exacte de ce script :
Merci de vérifier que l'URL indiquée ici est correcte. C'est celle-ci qui sera utilisée pour les visiteurs.
$FONTE-Mail Webmaster :
Tapez ici votre adresse E-Mail
$FONTEmplacement de sendmail :
Indiquez ici l'emplacement du programme sendmail sur votre serveur. A noter que ce script tente de le trouver tout seul en cherchant aux endroits habituels, mais il se peut qu'il ne le trouve pas. Si vous ne le connaissez pas demandez à votre hébergeur.

$FONTEmplacement(s) détecté(s):
$tmpl{'guessed_sendmail'}
$FONTNotification webmaster :
Cochez cette case si vous souhaitez être informé par un E-Mail court à chaque fois qu'un visiteur utilise ce script pour recommander votre site à un ami/destinataire.
$FONTNotification visiteur :
Cochez cette case si vous souhaitez que le visiteur recommandant votre site à un ami, reçoive un E-Mail de confirmation/accusé réception.
$FONTPage-modèle d'affichage aux visiteurs :
Vous pouvez modifier ci-dessous la page HTML modèle utilisée pour l'affichage aux visiteurs (template). Pour plus de commodités, copiez/collez ce code HTML dans votre éditeur HTML favori pour personnaliser cette page-modèle puis reportez-le ensuite ici après modifications.
Attention, le tag spécial [message] doit rester présent, il marque l'emplacement auquel le script affichera les différents messages. En cas de doute, laissez tel quel.
 
$FONTE-Mail au destinataire :
Modifiez ci-dessous le message qui sera envoyé par E-Mail au destinataire (ami du visiteur).
Mettez-y principalement l'URL de votre site et une petite description
$FONT Mettez [nom_dest] à l'endroit où le nom du destinataire doit apparaître.
Mettez [email_dest] à l'endroit où l'E-Mail du destinataire doit apparaître.
Mettez [nom_visiteur] à l'endroit où le nom du visiteur doit apparaître.
Mettez [email_visiteur] à l'endroit où l'E-Mail du visiteur doit apparaître.
ATTENTION, lors de l'envoi de l'email, [nom_dest], [email_dest], et les 2 autres TAGS seront remplacés par les noms et adresses E-Mail tapées dans le formulaire. Ne supprimez donc pas ces TAGS, ils servent à personnaliser chaque Mail.

 
$FONTAccusé-réception au visiteur (optionnel) :
Si vous avez coché notification au visiteur ci-dessus, modifiez le message qui sera envoyé par E-Mail au visiteur, en tant qu'accusé-réceptione t remerciement.
$FONT Mettez [nom_dest] à l'endroit où le nom du destinataire doit apparaître.
Mettez [email_dest] à l'endroit où l'E-Mail du destinataire doit apparaître.
Mettez [nom_visiteur] à l'endroit où le nom du visiteur doit apparaître.
Mettez [email_visiteur] à l'endroit où l'E-Mail du visiteur doit apparaître.
ATTENTION, lors de l'envoi de l'email, [nom_dest], [email_dest], et les 2 autres TAGS seront remplacés par les noms et adresses E-Mail tapées dans le formulaire. Ne supprimez donc pas ces TAGS, ils servent à personnaliser chaque Mail.

Format de caractères à utiliser pour l'affichage de messages aux visiteurs:
$FONTPolice : (Recommandé: Arial)
$FONTTaille : (Recommandé: 2)
$FONTCouleur : (Recommandé -noir-: #000000)
|); } ################################################ #### ATTENTION, réutilisation/recopie du #### #### code source interdite et illégale #### ################################################ sub admin_param_do { # CGI0_URL if ($form{'CGI0_URL'} eq '') { &msg_fin("ERREUR !","Vous n'avez pas indiqué l'URL de ce script.");} if ($form{'CGI0_URL'}!~ m|^https*://|) { &msg_fin("ERREUR !","L'URL de ce script doit commencer par http:// ou https://");} $CONF{'CGI0_URL'}=$form{'CGI0_URL'}; # EMAIL_WEBMASTER if (!&verify_email($form{'EMAIL_WEBMASTER'})) { &msg_fin("ERREUR !","Adresse E-Mail webmaster invalide
 
Merci de corriger...");} $CONF{'EMAIL_WEBMASTER'}=$form{'EMAIL_WEBMASTER'}; # MAILPROG if ($form{'MAILPROG'} eq '') { &msg_fin("ERREUR !","Vous n'avez pas indiqué l'emplacement de sendmail. Ceci est indispensable pour les envois d'E-Mails."); } if (!-e "$form{MAILPROG}") { &msg_fin("ERREUR !","Emplacement de sendmail incorrect");} $CONF{'MAILPROG'}=$form{'MAILPROG'}; # NOTIFY_WEBMASTER $CONF{'NOTIFY_WEBMASTER'}=int($form{'NOTIFY_WEBMASTER'}); # NOTIFY_VISITEUR $CONF{'NOTIFY_VISITEUR'}=int($form{'NOTIFY_VISITEUR'}); # TEMPLATE_STD $form{'TEMPLATE_STD'}=~ s/\r\n/\n/gs; if ($form{'TEMPLATE_STD'}!~ /\[message\]/s) { &msg_fin("ERREUR !","La page-modèle d'affichage aux visiteurs ne contient pas le tag spécial [message]
Il doit nécessairement être présent. Merci de retourner page précédente pour vérifier et corriger.");} $CONF{'TEMPLATE_STD'}=$form{'TEMPLATE_STD'}; # MESSAGE_DEST $form{'MESSAGE_DEST'}=~ s/\r\n/\n/gs; $form{'MESSAGE_DEST'}=~ s/\s+$//g; $form{'MESSAGE_DEST'}.="\n"; if ($form{'MESSAGE_DEST'} eq '') { &msg_fin("ERREUR !","Le contenu de l'email au destinataire est vide !. Merci de retourner page précédente pour corriger.");} $CONF{'MESSAGE_DEST'}=$form{'MESSAGE_DEST'}; # MESSAGE_VISITEUR $form{'MESSAGE_VISITEUR'}=~ s/\r\n/\n/gs; $form{'MESSAGE_VISITEUR'}=~ s/\s+$//g; $form{'MESSAGE_VISITEUR'}.="\n"; $CONF{'MESSAGE_VISITEUR'}=$form{'MESSAGE_VISITEUR'}; # FONT : $CONF{'FONT_FACE'}=$form{'FONT_FACE'}; $CONF{'FONT_SIZE'}=$form{'FONT_SIZE'}; $CONF{'FONT_COLOR'}=$form{'FONT_COLOR'}; # SAVE IT'S DONE: $CONF{config_param}=1; ## ENREGISTREMENTS PARAMS ## eval{chmod(0777,"$DATA_DIR/config.dat");}; open (CONFW,">$DATA_DIR/config.dat") || (&msg_fin("ERREUR !","Impossible de réécrire $DATA_DIR/config.dat : $!
Merci de mettre chmod 777 manuellement à ce fichier et au répertoire... ")); foreach ('config_param','CGI0_URL','EMAIL_WEBMASTER','MAILPROG','NOTIFY_WEBMASTER','NOTIFY_VISITEUR','TEMPLATE_STD','MESSAGE_DEST','MESSAGE_VISITEUR','FONT_FACE','FONT_SIZE','FONT_COLOR') { $CONF{$_}=~ s/\n/\|\\n\|/gs; print CONFW ("$_\t$CONF{$_}\n"); } close (CONFW); ## /ENREGISTREMENTS PARAMS ## &msg_fin("Configuration", "

$FONT Paramètres de configuration enregistrés avec succès !

"); } ################################################ #### ATTENTION, réutilisation/recopie du #### #### code source interdite et illégale #### ################################################ sub admin_version { my %tmpl=(); $tmpl{'CGI_NAME_fted'}=lc($CONF{CGI_NAME}); # formatted $tmpl{'CGI_NAME_fted'}=~ s/\s/_/gs; &msg_fin("Dernière version disponible",qq|

Cette page vous indique en temps réel s'il existe une version plus récente de ce script CGI Perl sur notre site perl-gratuit.com. Si vous constatez que c'est le cas, vous pouvez aller y consulter le détail des ajouts ou corrections éventuelles de ce CGI, et télécharger/installer la nouvelle version.

Version utilisée ici : $VERSION
Dernière version disponible :  

$FONT Remarque éventuelle sur la dernière version :

 
Vous trouverez la dernière version disponible sur Perl-Gratuit.com

|); } ################################################ #### ATTENTION, réutilisation/recopie du #### #### code source interdite et illégale #### ################################################ sub admin_info { my (%tmpl)=(); $tmpl{'form'}=&formfield_encode($CONF{'theform'}); &msg_fin("Documentation / Informations à lire",qq|

Informations sur l'utilisation de $CONF{CGI_NAME} :

Accès à l'administration :
Pour accéder à la section d'administration de $CONF{CGI_NAME} rendez-vous à l'URL exacte :
http://$ENV{SERVER_NAME}$CONF{CGI_URL}?admin
Mettez cette URL dans vos favoris pour ne pas l'oublier ! Votre mot de passe sera ensuite demandé.

Intégration dans votre site :
Vous avez deux manières possibles d'intégrer ce CGI à votre site web :
- Soit vous faites un lien direct vers l'URL de ce script CGI Perl, celui-ci affichera alors le formulaire demandant les informations nécessaires.
  URL : $CONF{'CGI0_URL'}
- Soit vous recopiez et intégrez dans une ou plusieurs de vos pages web, le formulaire dont le code HTML est indiqué ci-dessous. Libre à vous d'en personnaliser l'apparence, mais attention à ne pas modifier les champs:

Copyright - Licence d'utilisation :
Un droit d'utilisation gratuite de ce script CGI Perl vous est accordé à la condition expresse de ne pas le modifier du tout, ni de le réutiliser ou recopier en tout ou partie, revendre, louer, redistribuer, etc. Tous les droits autres que l'utilisation gratuite sont réservés (nous contacter au besoin). Toute contrefaçon ou autre violation des droits de propriété intellectuelle fait l'objet de poursuites. IL EST PAR-DESSUS TOUT INTERDIT DE MODIFIER LES MENTIONS DE L'AUTEUR (COPYRIGHT, NOM ET LIEN VERS LE SITE DE L'AUTEUR,ETC). CECI EST LA CONTREPARTIE DE LA GRATUITÉ.
Tout simplement, merci de respecter le travail de l'auteur... afin que nous puissions continuer à vous proposer de tels scripts CGI Perl.

Version PRO disponible :
Ce script CGI existe en version PRO, dédiée à un usage professionnel. Principales caractéristiques :
- aucune mention de l'auteur ni copyright visible par le visiteur.
- personnalisation complète de l'affichage pour une bonne intégration à votre site.
- assistance, support technique privilégié et ultra-prioritaire, documentation complète en ligne.
- installation offerte sur demande.
- nombreuses fontionnalités supplémentaires, etc...
Pour consulter le détail de la version PRO de ce script CGI Perl et en acquérir éventuellement une licence, merci de vous rendre sur notre autre site: Perl-PRO.com

|); } ################################################ ################################################ sub admin_export { my ($line,$nb,$email,$nom); #### Affichage page print (""); if ($form{'export_type'} eq 'visiteur') { print ("Liste des adresses de visiteurs collectées (personnes ayant recommandé votre site):
\n"); } elsif ($form{'export_type'} eq 'dest') { print ("Liste des adresses de destinataires collectées (personnes à qui un E-Mail de recommandation a été envoyé):
\n"); } else { &msg_fin("ERREUR !","Impossible de reconnaître si vous voulez voir les adresses des visiteurs ou des destinataires."); } print "

 

\n"; print "
" if (($form{'export_format'}==4) || ($form{'export_format'}==1));

  ## Liste :
  open (COLLR,"$DATA_DIR/collecte\_$form{'export_type'}.dat") || (&msg_fin("ERREUR !","Impossible de lire $DATA_DIR/collecte\_$form{'export_type'}.dat: $!"));
  while ($line=) {
    chomp($line);
    ($email,$nom)=split(/\|/o,$line);
    if ($form{'export_format'}==1) {            # importation dans PG-MailingList PRO
      print "$line\n";
    } elsif ($form{'export_format'}==2) {       # Outlook/Outlook Express
      print "$nom<$email>; ";
    } elsif ($form{'export_format'}==3) {       # Netscape Mail
      print "$nom<$email>, ";
    } elsif ($form{'export_format'}==4) {       # CSV
      print "$email\t$nom\n",
    }
    $nb++;
  }
  close(COLLR);

  #### Fin de la page
  print "
" if (($form{'export_format'}==4) || ($form{'export_format'}==1)); print ("
 
$nb adresses.\n"); exit(0); } ################################################ ################################################ sub admin_stats { my (%stats,$max,$total)=(); ## Lecture des stats open (STATR,"$DATA_DIR/stats.dat") || (&msg_fin("ERREUR","Impossible de lire le fichier de stats: $!")); while() { chomp($_); if ($_=~ /^([^\t]+)\t(\d+)$/) { $stats{"$1"}+=$2; } } close (STATR); ## valeur maxi, total : $max=0; $total=0; foreach (values(%stats)) { if ($_ > $max) { $max=$_;} $total+=$_; } if ($total<1) { &msg_fin("Statistiques d'utilisation"," Aucune utilisation actuellement."); } &msg_fin("Statistiques d'utilisation","

$FONT Cette section vous indique depuis quelles pages de votre site les visiteurs ont utilisé le formulaire de recommandation.
 
Nombre total d'utilisations de ce CGI: $total

".( join '', map {"\n"} sort{$stats{$b}<=>$stats{$a}} keys %stats )."
$_ $stats{$_} (". int(0.5+($stats{$_}/$total)*100) ." %)


 

"); } ################################################ sub admin_statsreset { open (STATSRAZ,">$DATA_DIR/stats.dat"); close(STATSRAZ); eval{chmod(0666,"$DATA_DIR/stats.dat");}; &msg_fin("Statistiques d'utilisation","

$FONT Les statistiques ont été réinitialisées avec succès !


 

"); } ################################################ ################################################