2021-10-14 17:58:21 +02:00
< ? php
2021-10-22 20:12:02 +02:00
2021-10-14 17:58:21 +02:00
require_once 'log.php' ;
2021-10-22 20:12:02 +02:00
require 'PHPMailer/Exception.php' ;
require 'PHPMailer/PHPMailer.php' ;
require 'PHPMailer/SMTP.php' ;
use PHPMailer\PHPMailer\PHPMailer ;
use PHPMailer\PHPMailer\SMTP ;
use PHPMailer\PHPMailer\Exception ;
2021-10-14 17:58:21 +02:00
if ( ! isset ( $site ) )
{
require_once ( " config.inc.php " );
header ( 'Location: ' . $accueil );
}
// $var clef à rechercher dans $_POST, $_GET, et $_SESSION (si $session=true)
// $default valeur retournée si aucune valeur n'est trouvée
// $session: si true, rechercher aussi dans $_SESSION
function getpost ( $var )
{
//echo '$var =>' . $var . "<br />";
if ( isset ( $_GET [ $var ]) )
{
//echo '$_get -> $var =>' . $var . "<br />";
return $_GET [ $var ];
}
elseif ( isset ( $_POST [ $var ]) )
{
//echo '$_POST -> $var =>' . $var . "<br />";
return $_POST [ $var ];
} else
{
2022-09-15 18:34:18 +02:00
return null ;
2021-10-14 17:58:21 +02:00
}
}
// MET LA PREMIÈRE LETTRE D'UN MOT EN MAJUSCULE ( utf8 compliant )
function mb_ucfirst ( $str )
{
$char = mb_substr ( $str , 0 , 1 , " UTF8 " );
$str = mb_substr ( $str , 1 , NULL , " UTF8 " );
$char = mb_strtoupper ( $char , " UTF8 " );
return $char . $str ;
}
2022-09-15 18:34:18 +02:00
function choixVotation ( $path , $methode = 2 , $confirm = true ) //2 = toutes les votations 1 = votations en cours 0 = votations cloturées
2021-10-14 17:58:21 +02:00
{
global $db , $base_url , $action ;
2022-09-15 18:34:18 +02:00
2021-10-14 17:58:21 +02:00
$query = " SELECT * FROM liste_votations " ;
if ( $methode != 2 )
{
$query .= " where status= " . $methode ;
}
$result = $db -> query ( $query );
$votations = $db -> result -> fetch_all ( MYSQLI_ASSOC );
2022-09-14 14:09:04 +02:00
2021-10-14 17:58:21 +02:00
if ( $db -> result -> num_rows == 1 )
{
$redirect = '<META HTTP-EQUIV=Refresh CONTENT="0; URL=' . $base_url . $path . '?id=' . $votations [ " 0 " ][ " id " ];
if ( ! empty ( $action ))
{
$redirect .= '&action=' . $action ;
}
$redirect .= '">' ;
2022-09-15 18:34:18 +02:00
//echo $redirect;
2022-09-14 14:09:04 +02:00
header ( 'Location: ' . $base_url . '/gestionsite/modifVotation.php?id=' . $votations [ " 0 " ][ " id " ]) . $redirect ;
2021-10-14 17:58:21 +02:00
}
2022-09-14 14:09:04 +02:00
print ( '<form method="get" action="' . $path . '">' );
print " <pre> " ;
2022-09-14 14:12:46 +02:00
print '<input type="hidden" name="action" value="' . $action . '">' ;
2021-10-14 17:58:21 +02:00
foreach ( $votations as $key => $value )
{
print '<input type="radio" name="id" value="' . $value [ " id " ] . '"> ' . $value [ " titre " ] . ' :' . $value [ " libelle " ] . '<br>' ;
}
2022-09-15 18:34:18 +02:00
// TODO confirmation du choix par javascript si $confirm = true
2021-10-14 17:58:21 +02:00
print ' </ pre >< br >
< div >
2022-09-14 13:05:25 +02:00
< input type = " submit " value = " Envoyer " >
2021-10-14 17:58:21 +02:00
</ div >
</ form > ' ;
}
2022-09-15 11:44:34 +02:00
function votationForm ( $path , $titre = " " , $libelle = " " , $dateDebut = " " , $DateFin = " " , $status = 0 )
2021-10-14 17:58:21 +02:00
{
2022-09-15 11:44:34 +02:00
//TODO vérification du formulaire en javascript
print ( '<form method="get" action="' . $path . '">' );
print ( '<label for="titre">' . _ ( " Titre " ) . '</label><br><input type="text" id="titre" name="titre" value="' . $titre . '">' ) . EOLH ;
print ( '<label for="libelle">' . _ ( " Description " ) . '</label><br><input type="text" id="libelle" name="libelle" value="' . $libelle . '">' ) . EOLH ;
print ( '<label for="dateDebut">' . _ ( " Date de début de la période de vote " ) . '</label><br><input type="date" id="dateDebut" name="dateDebut" value="' . $dateDebut . '">' ) . EOLH ;
print ( '<label for="dateFin">' . _ ( " Date de fin de la période de vote " ) . '</label><br><input type="date" id="dateFin" name="dateFin" value="' . $dateFin . '">' ) . EOLH ;
print ( '<input type="submit" formaction="index.php" value="' . _ ( " Annuler " ) . '">' ) . EOLH ;
2022-09-15 18:34:18 +02:00
print ( '<input type="submit" value="' . _ ( " Envoyer " ) . '">' ) . EOLH ;
}
function votesForm ( $path , $libelle = " " , $method = 0 )
{
$db = new db ();
$query = " SELECT *m FROM methods " ; // clotûre
$db -> query ( $query );
$methods = $db -> result :: fetch_all ( MYSQLI_ASSOC );
if ( ! ( array_key_exists ( $method , $methods )))
{
print ( _ ( " L'ID de la méthode demandée n'est pas bonne " . __file__ . __LINE__ ));
log_error ( _ ( " L'ID de la méthode demandée n'est pas bonne " . __file__ . __LINE__ ), true , true );
}
//TODO vérification du formulaire en javascript
print ( '<form method="get" action="' . $path . '">' );
print ( '<label for="libelle">' . _ ( " Libellé du vote " ) . '</label><br><input type="text" id="libelle" name="libelle" value="' . $libelle . '">' ) . EOLH ;
print ( '<label for="method">' . _ ( " Méthode de vote " ) . ' </ label >< br >
< input type = " select " id = " method " name = " method " value = " '. $method . ' " > ' ) . EOLH ;
if ( $method == 0 )
{
print ( '<option value ="">' . _ ( " Choisissez une option " ) . '<option>' );
}
foreach ( $methods as $id => $value )
{
if ( $id == $value )
{
print ( '<option value ="' . $id . '" selected>' . $value . '<option>' );
} else
{
print ( '<option value ="' . $id . '">' . $value . '<option>' );
}
}
print ( '<input type="submit" formaction="index.php" value="' . _ ( " Annuler " ) . '">' ) . EOLH ;
2022-09-15 11:44:34 +02:00
print ( '<input type="submit" value="' . _ ( " Envoyer " ) . '">' ) . EOLH ;
}
2021-10-22 20:12:02 +02:00
function envoiMail ( $destinataire , $sujet , $text , $html = false , $cc = '' , $bcc = '' )
{
//require 'vendor/autoload.php';
$mail = new PHPMailer ( true );
try {
if ( $html )
{
// setParameters() takes an associative array
$str = nl2br ( $text );
$text = " <html><head></head> \n <body> " . $str . " </body></html> " ;
log_write ( __FILE__ . EOL . __LINE__ . EOL . wordwrap ( $text , 1000 , " \r \n " ), INFO );
$mail -> isHTML ( true );
$mail -> AltBody = 'Ceci est un messssage HTML' ;
} else
{
//$mail->isHTML(false);
$text = str_replace ( " \n " , " \r \n " , $text );
}
//Server settings
//$mail->SMTPDebug = SMTP::DEBUG_SERVER; //Enable verbose debug output
$mail -> isSMTP (); //Send using SMTP
$mail -> Host = 'mail.gandi.net' ; //Set the SMTP server to send through
$mail -> SMTPAuth = true ; //Enable SMTP authentication
$mail -> Username = 'contact@lalis.fr' ; //SMTP username
$mail -> Password = 'Gu>V$fiM{bQ^!x+FAHF+R.}bl' ; //SMTP password
$mail -> SMTPSecure = PHPMailer :: ENCRYPTION_SMTPS ; //Enable implicit ssl encryption
$mail -> Port = 465 ; //TCP port to connect to; use 587 if you have set `SMTPSecure = PHPMailer::ENCRYPTION_STARTTLS`
$mail -> MessageDate = '' ;
$mail -> SMTPKeepAlive = true ;
//Recipients
$mail -> setFrom ( 'contact@lalis.fr' );
$mail -> addAddress ( $destinataire ); //Add a recipient
//$mail->addReplyTo('info@example.com', 'Information');
$mail -> CharSet = PHPMailer :: CHARSET_UTF8 ;
$mail -> Body = $text ;
//Attachments
//$mail->addAttachment('/var/tmp/file.tar.gz'); //Add attachments
//$mail->addAttachment('/tmp/image.jpg', 'new.jpg'); //Optional name
//Content
//Set email format to HTML
$mail -> Subject = $sujet ;
$mail -> send ();
echo 'Message has been sent' ;
log_write ( __FILE__ . EOL . __LINE__ . EOL . " Le courriel est parti: " . $destinataire . EOL . $sujet . EOL , INFO );
} catch ( Exception $e ) {
echo " Message could not be sent. Mailer Error: { $mail -> ErrorInfo } " ;
log_error ( __FILE__ . EOL . __LINE__ . EOL . " Le courriel n'est pas parti: " . $destinataire . EOL . $sujet . EOL . print_r ( $mail -> ErrorInfo , true ) . EOL . wordwrap ( $text , 1000 , " \r \n " ));
$mail -> getSMTPInstance () -> reset ();
return false ;
}
return true ;
2021-10-14 17:58:21 +02:00
}
function formatteDate ( $locale , $date , $tz )
{
$formatter = new IntlDateFormatter ( $locale , IntlDateFormatter :: LONG , IntlDateFormatter :: NONE , $tz , IntlDateFormatter :: GREGORIAN );
$datetime = new DateTime ();
$datetime -> setTimestamp ( $date );
if ( $formatter == null )
{
log_write ( __FILE__ . EOLH . __LINE__ . EOLH . " Formatter error : locale = " . $locale . " tz = " . $tz . " Formatter = " . print_r ( $formatter , true ) . InvalidConfigException ( intl_get_error_message ()), ERROR );
}
return $formatter -> format ( $datetime );
}
2021-10-22 20:12:02 +02:00
function listeAdherents ()
{
$dolibarr = new dbDolibarr ();
$query = 'SELECT login, firstname, lastname FROM llx_adherent' ;
$dolibarr -> query ( $query );
while ( $adherent = $dolibarr -> result -> fetch_array ())
{
$listeAdherents [ $adherent [ 'login' ]] = $adherent [ 'firstname' ] . ' ' . $adherent [ 'lastname' ];
}
$dolibarr -> close ();
return $listeAdherents ;
}
function listeVotants ( $idVotation , $idVote , $listeAdherents )
{
global $db ;
2021-10-23 01:27:50 +02:00
$nv = 0 ;
$text = '' ;
2021-10-22 20:12:02 +02:00
$query = " SELECT DISTINCT idVotant FROM votes WHERE idVotation= " . $idVotation . ' AND idVote=' . $idVote ;
$result = $db -> query ( $query );
2021-10-23 01:27:50 +02:00
2021-10-22 20:12:02 +02:00
while ( $idVotants = $db -> result -> fetch_assoc ())
{
2021-10-23 01:27:50 +02:00
$nv ++ ;
$text .= $listeAdherents [ $idVotants [ 'idVotant' ]] . EOLH ;
2021-10-22 20:12:02 +02:00
}
2021-10-23 01:27:50 +02:00
print ( 'Nombre de votants : ' . $nv . EOLH . '<div id="listeVotants' . $idVote . '" style="display: none; line-height: 0.8;">' . $text . '</div>' );
print ( '<button id="button' . $idVote . '" onclick="show(\'listeVotants\',\'' . $idVote . '\')">Voir la liste des votants</button>' . EOLH );
2021-10-22 20:12:02 +02:00
}
2021-10-14 17:58:21 +02:00
?>