date.chapril.org-framadate/creation_sondage.php

119 lines
5.0 KiB
PHP
Raw Normal View History

2011-05-15 01:32:47 +02:00
<?php
/**
* This software is governed by the CeCILL-B license. If a copy of this license
* is not distributed with this file, you can obtain one at
* http://www.cecill.info/licences/Licence_CeCILL-B_V1-en.txt
*
* Authors of STUdS (initial project): Guilhem BORGHESI (borghesi@unistra.fr) and Raphaël DROZ
* Authors of Framadate/OpenSondate: Framasoft (https://github.com/framasoft)
*
* =============================
*
* Ce logiciel est régi par la licence CeCILL-B. Si une copie de cette licence
* ne se trouve pas avec ce fichier vous pouvez l'obtenir sur
* http://www.cecill.info/licences/Licence_CeCILL-B_V1-fr.txt
*
* Auteurs de STUdS (projet initial) : Guilhem BORGHESI (borghesi@unistra.fr) et Raphaël DROZ
* Auteurs de Framadate/OpenSondage : Framasoft (https://github.com/framasoft)
*/
namespace Framadate;
2011-05-15 01:32:47 +02:00
2014-11-27 00:39:15 +01:00
if (session_id() == '') {
session_start();
2011-05-15 05:50:13 +02:00
}
2011-05-15 01:32:47 +02:00
include_once __DIR__ . '/app/inc/init.php';
2011-05-15 01:32:47 +02:00
//Generer une chaine de caractere unique et aleatoire
2014-11-27 00:39:15 +01:00
function random_string($length)
2011-05-15 03:56:54 +02:00
{
2014-11-27 00:39:15 +01:00
$string = '';
$chaine = 'abcdefghijklmnopqrstuvwxyz123456789';
srand((double)microtime()*1000000);
2014-11-27 00:39:15 +01:00
for($i=0; $i < $length; ++$i) {
$string .= $chaine[rand()%strlen($chaine)];
}
return $string;
2011-05-15 01:32:47 +02:00
}
2014-11-27 00:39:15 +01:00
/**
* @deprecated
*/
function random($car)
{
return random_string($car);
}
2011-05-15 03:56:54 +02:00
function ajouter_sondage()
{
global $connect;
global $config;
2014-11-27 00:39:15 +01:00
$poll = random(16);
$poll_admin = $poll . random(8);
2014-11-27 00:39:15 +01:00
$date_fin = $_SESSION['champdatefin']; // provided by choix_autre.php or choix_date.php
$_SESSION['champdatefin'] = ''; //clean param cause 2 polls created by the same user in the same session can be affected by this param during the 2nd creation.
$sql = 'INSERT INTO sondage
2011-05-22 04:03:44 +02:00
(id_sondage, commentaires, mail_admin, nom_admin, titre, id_sondage_admin, date_fin, format, mailsonde)
VALUES (
'.$connect->Param('id_sondage').',
'.$connect->Param('commentaires').',
'.$connect->Param('mail_admin').',
'.$connect->Param('nom_admin').',
'.$connect->Param('titre').',
'.$connect->Param('id_sondage_admin').',
2014-11-27 00:39:15 +01:00
FROM_UNIXTIME('. $date_fin .'),
2011-05-22 04:03:44 +02:00
'.$connect->Param('format').',
'.$connect->Param('mailsonde').'
)';
$sql = $connect->Prepare($sql);
2014-11-27 00:39:15 +01:00
$res = $connect->Execute($sql, array($poll, $_SESSION['commentaires'], $_SESSION['adresse'], $_SESSION['nom'], $_SESSION['titre'], $poll_admin, $_SESSION['formatsondage'], $_SESSION['mailsonde']));
2014-11-27 00:39:15 +01:00
$sql = 'INSERT INTO sujet_studs VALUES ('.$connect->Param('sondage').', '.$connect->Param('choix').')';
$sql = $connect->Prepare($sql);
2014-11-27 00:39:15 +01:00
$connect->Execute($sql, array($poll, $_SESSION['toutchoix']));
2014-11-27 00:39:15 +01:00
if($config['use_smtp']==true) {
2014-12-03 14:30:25 +01:00
$message = _("This is the message you have to send to the people you want to poll. \nNow, you have to send this message to everyone you want to poll.");
$message .= "\n\n";
2014-11-27 00:39:15 +01:00
$message .= stripslashes(html_entity_decode($_SESSION["nom"],ENT_QUOTES,"UTF-8"))." " . _('hast just created a poll called') . ' : "'.stripslashes(htmlspecialchars_decode($_SESSION['titre'],ENT_QUOTES))."\".\n";
$message .= _('Thanks for filling the poll at the link above') . " :\n\n%s\n\n" . _('Thanks for your confidence.') ."\n". NOMAPPLICATION;
2014-12-03 14:30:25 +01:00
$message_admin = _("This message should NOT be sent to the polled people. It is private for the poll's creator.\n\nYou can now modify it at the link above");
2014-11-27 00:39:15 +01:00
$message_admin .= " :\n\n%s \n\n" . _('Thanks for your confidence.') . "\n". NOMAPPLICATION;
2014-11-27 00:39:15 +01:00
$message = sprintf($message, Utils::getUrlSondage($poll));
$message_admin = sprintf($message_admin, Utils::getUrlSondage($poll_admin, true));
if (Utils::isValidEmail($_SESSION['adresse'])) {
2014-11-27 00:39:15 +01:00
Utils::sendEmail(
"$_SESSION[adresse]",
"[".NOMAPPLICATION."][" . _("Author's message") . "] " . _("Poll") . " : ".stripslashes(htmlspecialchars_decode($_SESSION["titre"], ENT_QUOTES)),
$message_admin,
$_SESSION['adresse']
);
Utils::sendEmail(
"$_SESSION[adresse]",
"[".NOMAPPLICATION."][" . _("For sending to the polled users") . "] " . _("Poll") . " : ".stripslashes(htmlspecialchars_decode($_SESSION["titre"], ENT_QUOTES)),
$message,
$_SESSION['adresse']
);
}
}
2014-11-27 00:39:15 +01:00
error_log(date('H:i:s d/m/Y:') . ' CREATION: '.$poll."\t".$_SESSION[formatsondage]."\t".$_SESSION[nom]."\t".$_SESSION[adresse]."\t \t".$_SESSION[toutchoix]."\n", 3, 'admin/logs_studs.txt');
Utils::cleaning_polls($connect, 'admin/logs_studs.txt');
// Don't keep days, hours and choices in memory (in order to make new polls)
2014-11-27 00:39:15 +01:00
for ($i = 0; $i < count($_SESSION['totalchoixjour']); ++$i) {
unset($_SESSION['horaires'.$i]);
}
2014-11-27 00:39:15 +01:00
unset($_SESSION['totalchoixjour']);
unset($_SESSION['choices']);
2014-11-27 00:39:15 +01:00
header('Location:'. Utils::getUrlSondage($poll_admin, true));
exit();
}