123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226 |
- <?php
- /**
- * Postfix Admin
- *
- * LICENSE
- * This source file is subject to the GPL license that is bundled with
- * this package in the file LICENSE.TXT.
- *
- * Further details on the project are available at http://postfixadmin.sf.net
- *
- * @version $Id$
- * @license GNU GPL v2 or later.
- *
- * File: edit-vacation.php
- *
- * Allows users to update their vacation status and
- * admins to update the vacation status for the their users
- *
- * Template File: vacation.tpl
- *
- * Template Variables:
- *
- * tUseremail
- * tActiveFrom
- * tActiveUntil
- * tSubject
- * tBody
- * tInterval_time
- *
- * Form POST \ GET Variables:
- *
- * fUsername
- * fDomain
- * fCancel
- * fChange
- * fBack
- * fActive
- */
-
- require_once('common.php');
-
- // only allow admins to change someone else's 'stuff'
- if (authentication_has_role('admin')) {
- $Admin_role = 1 ;
- $fUsername = safeget('username');
- list(/*NULL*/, $fDomain) = explode('@', $fUsername);
- $Return_url = "list-virtual.php?domain=" . urlencode($fDomain);
-
- # TODO: better check for valid username (check if mailbox exists)
- # TODO: (should be done in VacationHandler)
- if ($fDomain == '' || !check_owner(authentication_get_username(), $fDomain)) {
- die("Invalid username!"); # TODO: better error message
- }
- } else {
- $Admin_role = 0 ;
- $Return_url = "main.php";
- authentication_require_role('user');
- $fUsername = authentication_get_username();
- }
-
- // is vacation support enabled in $CONF ?
- if ($CONF['vacation'] == 'NO') {
- header("Location: $Return_url");
- exit(0);
- }
-
- date_default_timezone_set(@date_default_timezone_get()); # Suppress date.timezone warnings
-
- $error = 0;
-
- $vh = new VacationHandler($fUsername);
-
- $choice_of_reply = Config::read('vacation_choice_of_reply');
- foreach (array_keys($choice_of_reply) as $key) {
- $choice_of_reply[$key] = Config::Lang($choice_of_reply[$key]);
- }
-
- if ($_SERVER['REQUEST_METHOD'] == "GET") {
- $tSubject = '';
- $tBody = '';
- $tActiveFrom = '';
- $tActiveUntil = '';
- $tUseremail = $fUsername;
- $tInterval_Time = '';
-
- $details = $vh->get_details();
- if ($details != false) {
- $tSubject = $details['subject'];
- $tBody = $details['body'];
- $tInterval_Time = $details['interval_time'];
- $tActiveFrom = $details['activeFrom'];
- $tActiveUntil = $details['activeUntil'];
- }
-
- if ($vh->check_vacation()) {
- flash_info(sprintf($PALANG['pUsersVacation_welcome_text'], htmlentities($tUseremail)));
- }
-
- //set a default, reset fields for coming back selection
- if ($tSubject == '') {
- $tSubject = html_entity_decode($PALANG['pUsersVacation_subject_text'], ENT_QUOTES, 'UTF-8');
- }
- if ($tBody == '') {
- $tBody = html_entity_decode($PALANG['pUsersVacation_body_text'], ENT_QUOTES, 'UTF-8');
- }
- }
-
- if ($_SERVER['REQUEST_METHOD'] == "POST") {
- if (safepost('token') != $_SESSION['PFA_token']) {
- die('Invalid token!');
- }
-
- if (isset($_POST['fCancel'])) {
- header("Location: $Return_url");
- exit(0);
- }
-
- $tActiveFrom = date("Y-m-d 00:00:00", strtotime(safepost('fActiveFrom')));
- $tActiveUntil = date("Y-m-d 23:59:59", strtotime(safepost('fActiveUntil')));
-
- $tSubject = safepost('fSubject');
- $fSubject = $tSubject;
- $tBody = safepost('fBody');
- $fBody = $tBody;
-
- $tInterval_Time = safepost('fInterval_Time');
-
- $fChange = escape_string(safepost('fChange'));
- $fBack = escape_string(safepost('fBack'));
-
- $tUseremail = $fUsername;
-
- //set a default, reset fields for coming back selection
- if ($tSubject == '') {
- $tSubject = html_entity_decode($PALANG['pUsersVacation_subject_text'], ENT_QUOTES, 'UTF-8');
- }
- if ($tBody == '') {
- $tBody = html_entity_decode($PALANG['pUsersVacation_body_text'], ENT_QUOTES, 'UTF-8');
- }
-
- if (isset($choice_of_reply[$tInterval_Time])) {
- $fInterval_Time = $tInterval_Time;
- } else {
- $fInterval_Time = 0;
- }
-
- // if they've set themselves change OR back, delete any record of vacation emails.
- // the user is going away - set the goto alias and vacation table as necessary.
-
- //Set the vacation data for $fUsername
-
- if (!empty($fChange)) {
-
- ## check if ActiveUnitl is not back in time,
- ## because vacation.pl will report SMTP recipient $smtp_recipient which resolves to $email does not have an active vacation (rv: $rv, email: $email)"
- ## and will not send message
-
- if (($tActiveUntil >= date("Y-m-d")) and ($tActiveUntil >= $tActiveFrom)) {
- if (!$vh->set_away($fSubject, $fBody, $fInterval_Time, $tActiveFrom, $tActiveUntil)) {
- $error = 1;
- }
- } else {
- if ($tActiveUntil < date("Y-m-d")) {
- flash_error($PALANG['pVacation_until_before_today']);
- } else {
- flash_error($PALANG['pVacation_until_before_from']);
- }
- $error = 1;
- }
- }
-
- //if change, remove old one, then perhaps set new one
- if (!empty($fBack)) {
- if (!$vh->remove()) {
- $error = 1;
- }
- }
- }
-
- // If NO error then diplay flash message and go back to right url where we came from
- if ($error == 0) {
- if (!empty($fBack)) {
- flash_info(sprintf($PALANG['pVacation_result_removed'], htmlentities($tUseremail)));
- header("Location: $Return_url");
- exit;
- }
- if (!empty($fChange)) {
- flash_info(sprintf($PALANG['pVacation_result_added'], htmlentities($tUseremail)));
- header("Location: $Return_url");
- exit;
- }
- } else {
- flash_error(sprintf($PALANG['pVacation_result_error'], htmlentities($fUsername)));
- }
-
- $today = date("Y-m-d");
- if (empty($tActiveFrom)) {
- $tActiveFrom = $today;
- }
- if (empty($tActiveUntil)) {
- $tActiveUntil = $today;
- }
-
- if (! $details['active']) {
- # if vacation is disabled, there's no point in displaying the date of the last vacation ;-)
- # (which also means users would have to scroll in the calendar a lot)
- # so let's be user-friendly and set today's date (but only if the last vacation is in the past)
- if ($tActiveFrom < $today) {
- $tActiveFrom = $today;
- }
- if ($tActiveUntil < $today) {
- $tActiveUntil = $today;
- }
- }
-
- $smarty->assign('tUseremail', $tUseremail);
- $smarty->assign('tSubject', $tSubject);
- $smarty->assign('tBody', $tBody);
- $smarty->assign('tActiveFrom', date("d.m.Y", strtotime($tActiveFrom)));
- $smarty->assign('tActiveUntil', date("d.m.Y", strtotime($tActiveUntil)));
- $smarty->assign('select_options', $choice_of_reply);
- $smarty->assign('tInterval_Time', $tInterval_Time);
- $smarty->assign('smarty_template', 'vacation');
- $smarty->display('index.tpl');
-
- /* vim: set expandtab softtabstop=3 tabstop=3 shiftwidth=3: */
|