1
0
This repository has been archived on 2023-11-30. You can view files and clone it, but cannot push or open issues or pull requests.
dtux__serveur-vote-lalis/include/fonctions.inc.php
2022-09-19 12:59:40 +02:00

246 lines
8.8 KiB
PHP

<?php
require_once 'log.php';
require 'PHPMailer/Exception.php';
require 'PHPMailer/PHPMailer.php';
require 'PHPMailer/SMTP.php';
use PHPMailer\PHPMailer\PHPMailer;
use PHPMailer\PHPMailer\SMTP;
use PHPMailer\PHPMailer\Exception;
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
{
return null;
}
}
// 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;
}
function choixVotation($path, $methode = 2, $confirm = true) //2 = toutes les votations 0 = votations en cours 1 = votations cloturées
{
global $base_url, $action;
$db = new db();
$query = "SELECT * FROM liste_votations";
if ($methode != 2)
{
$query .= " where status=" . $methode;
}
$result = $db->query($query);
$votations = $db->result->fetch_all(MYSQLI_ASSOC);
/*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 .= '">';
//echo $redirect;
header( 'Location: ' . $base_url . '/gestionsite/modifVotation.php?id=' . $votations["0"]["id"]) . $redirect;
}*/
print ('<form method="get" action="' . $path . '">');
print "<pre>";
print '<input type="hidden" name="action" value="' . $action . '"/>';
foreach($votations as $key => $value )
{
print '<input type="radio" name="id" value="' . $value["id"] . '"/> ' . $value["titre"] . '&nbsp;:' . $value["libelle"] . '<br>';
}
// TODO confirmation du choix par javascript si $confirm = true
print '</pre><br>
<div>
<input type="submit" value="Envoyer"/>
<input type="submit" formaction="index.php" value="' . _("Annuler") . '"/>
</div>
</form>';
$db->close();
}
function votationForm($path, $titre="", $libelle="", $dateDebut="", $dateFin="", $status=0)
{
//TODO vérification du formulaire en javascript
print('<form method="get" action="' . $path . '">');
print('<input type="hidden" name="status" value="' . $status . '">');
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;
print('<input type="submit" value="' . _("Envoyer") . '"/>') . EOLH;
}
function votesForm($path, $libelle = "", $method = 0)
{
$db = new db();
$query = "SELECT * 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 . '">' . EOL);
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>
<select id="method" name="method" value="'. $method . '">') . EOL;
if ($method == 0)
{
print('<option value ="">' . _("Choisissez une option") . '</option>') . EOL;
}
foreach ($methods as $value)
{
$id = $value["id"];
if ($id == $method)
{
print('<option value ="' . $id . '" selected>' . $value["libelle"] . '</option>' . EOL);
}else
{
print('<option value ="' . $id . '">' . $value["libelle"] . '</option>' . EOL);
}
}
print("</select>"). EOLH;
print('<input type="submit" formaction="index.php" value="' . _("Annuler") . '"/>') . EOL;
print('<input type="submit" value="' . _("Envoyer") . '"/>') . EOL;
print('</form>') . EOL;
$db->close();
}
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;
}
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 );
}
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)
{
$nv = 0;
$text = '';
$db->open();
$query = "SELECT DISTINCT idVotant FROM votes WHERE idVotation=" . $idVotation . ' AND idVote=' . $idVote;
$result = $db->query($query);
while ($idVotants = $db->result->fetch_assoc())
{
$nv++;
$text .= $listeAdherents[$idVotants['idVotant']] . EOLH;
}
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);
$db->close();
}
?>