minExpiryDate(); $max_expiry_time = $pollService->maxExpiryDate(); $form = unserialize($_SESSION['form']); // The poll format is DATE if we are in this file if (!isset($form->format)) { $form->format = 'D'; } // If we come from another format, we need to clear choices if (isset($form->format) && $form->format !== 'D') { $form->format = 'D'; $form->clearChoices(); } if (!isset($form->title) || !isset($form->admin_name) || ($config['use_smtp'] && !isset($form->admin_mail))) { $step = 1; } else if (!empty($_POST['confirmation'])) { $step = 4; } else if (empty($_POST['choixheures']) || isset($form->totalchoixjour)) { $step = 2; } else { $step = 3; } switch ($step) { case 1: // Step 1/4 : error if $_SESSION from info_sondage are not valid $smarty->assign('title', __('Error', 'Error!')); $smarty->assign('error', __('Error', 'You haven\'t filled the first section of the poll creation, or your session has expired.')); $smarty->display('error.tpl'); exit; case 2: // Step 2/4 : Select dates of the poll // Prefill form->choices foreach ($form->getChoices() as $c) { /** @var Choice $c */ $count = 3 - count($c->getSlots()); for ($i = 0; $i < $count; $i++) { $c->addSlot(''); } } $count = 3 - count($form->getChoices()); for ($i = 0; $i < $count; $i++) { $c = new Choice(''); $c->addSlot(''); $c->addSlot(''); $c->addSlot(''); $form->addChoice($c); } $_SESSION['form'] = serialize($form); // Display step 2 $smarty->assign('title', __('Step 2 date', 'Poll dates (2 on 3)')); $smarty->assign('choices', $form->getChoices()); $smarty->assign('error', null); $smarty->display('create_date_poll_step_2.tpl'); exit; case 3: // Step 3/4 : Confirm poll creation // Handle Step2 submission if (!empty($_POST['days'])) { // Remove empty dates $_POST['days'] = array_filter($_POST['days'], function ($d) { return !empty($d); }); // Check if there are at most MAX_SLOTS_PER_POLL slots if (count($_POST['days']) > MAX_SLOTS_PER_POLL) { // Display step 2 $smarty->assign('title', __('Step 2 date', 'Poll dates (2 on 3)')); $smarty->assign('choices', $form->getChoices()); $smarty->assign('error', __f('Error', 'You can\'t select more than %d dates', MAX_SLOTS_PER_POLL)); $smarty->display('create_date_poll_step_2.tpl'); exit; } // Clear previous choices $form->clearChoices(); // Reorder moments to deal with suppressed dates $moments = []; $i = 0; while(count($moments) < count($_POST['days'])) { if (!empty($_POST['horaires' . $i])) { $moments[] = $_POST['horaires' . $i]; } $i++; } for ($i = 0; $i < count($_POST['days']); $i++) { $day = $_POST['days'][$i]; if (!empty($day)) { // Add choice to Form data $date = DateTime::createFromFormat(__('Date', 'datetime_parseformat'), $_POST['days'][$i])->setTime(0, 0, 0); $time = (string) $date->getTimestamp(); $choice = new Choice($time); $form->addChoice($choice); $schedules = $inputService->filterArray($moments[$i], FILTER_DEFAULT); for ($j = 0; $j < count($schedules); $j++) { if (!empty($schedules[$j])) { $choice->addSlot(strip_tags($schedules[$j])); } } } } $form->sortChoices(); } // Display step 3 $summary = ''; $end_date_str = utf8_encode(strftime($date_format['txt_date'], $max_expiry_time)); // textual date $_SESSION['form'] = serialize($form); $smarty->assign('title', __('Step 3', 'Removal date and confirmation (3 on 3)')); $smarty->assign('summary', $summary); $smarty->assign('end_date_str', $end_date_str); $smarty->assign('default_poll_duration', $config['default_poll_duration']); $smarty->assign('use_smtp', $config['use_smtp']); $smarty->display('create_poll_step3.tpl'); exit; case 4: // Step 4 : Data prepare before insert in DB // Define expiration date $enddate = filter_input(INPUT_POST, 'enddate', FILTER_VALIDATE_REGEXP, ['options' => ['regexp' => '#^[0-9]{2}/[0-9]{2}/[0-9]{4}$#']]); if (!empty($enddate)) { $registredate = explode('/', $enddate); if (is_array($registredate) && count($registredate) === 3) { $time = mktime(0, 0, 0, $registredate[1], $registredate[0], $registredate[2]); if ($time < $min_expiry_time) { $form->end_date = $min_expiry_time; } elseif ($max_expiry_time < $time) { $form->end_date = $max_expiry_time; } else { $form->end_date = $time; } } } if (empty($form->end_date)) { // By default, expiration date is 6 months after last day $form->end_date = $max_expiry_time; } // Insert poll in database $ids = $pollService->createPoll($form); $poll_id = $ids[0]; $admin_poll_id = $ids[1]; // Send confirmation by mail if enabled if ($config['use_smtp'] === true) { $message = __('Mail', "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 .= '

'; $message .= Utils::htmlEscape($form->admin_name) . ' ' . __('Mail', 'hast just created a poll called') . ' : "' . Utils::htmlEscape($form->title) . '".
'; $message .= __('Mail', 'Thanks for filling the poll at the link above') . ' :

%1$s'; $message_admin = __('Mail', "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"); $message_admin .= ' :

%1$s'; $message = sprintf($message, Utils::getUrlSondage($poll_id)); $message_admin = sprintf($message_admin, Utils::getUrlSondage($admin_poll_id, true)); if ($mailService->isValidEmail($form->admin_mail)) { $mailService->send($form->admin_mail, '[' . NOMAPPLICATION . '][' . __('Mail', 'Author\'s message') . '] ' . __('Generic', 'Poll') . ': ' . Utils::htmlEscape($form->title), $message_admin); $mailService->send($form->admin_mail, '[' . NOMAPPLICATION . '][' . __('Mail', 'For sending to the polled users') . '] ' . __('Generic', 'Poll') . ': ' . Utils::htmlEscape($form->title), $message); } } // Clean Form data in $_SESSION unset($_SESSION['form']); $purgeService->repeatedCleanings(); // creation message $sessionService->set("Framadate", "messagePollCreated", TRUE); // Redirect to poll administration header('Location:' . Utils::getUrlSondage($admin_poll_id, true)); exit; }