|
|
|
<?php
|
|
|
|
|
|
|
|
class VacationHandler {
|
|
|
|
protected $username = null;
|
|
|
|
function __construct($username) {
|
|
|
|
$this->username = $username;
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Removes the autoreply alias etc for this user; namely, if they're away we remove their vacation alias and
|
|
|
|
* set the vacation table record to false.
|
|
|
|
* @return boolean true on success.
|
|
|
|
*/
|
|
|
|
function remove() {
|
|
|
|
$ah = new AliasHandler($this->username);
|
|
|
|
$result = $ah->get(true); // fetch all # TODO check $result, error handling
|
|
|
|
$aliases = $ah->result;
|
|
|
|
$new_aliases = array();
|
|
|
|
$table_vacation = table_by_key('vacation');
|
|
|
|
$table_vacation_notification = table_by_key('vacation_notification');
|
|
|
|
|
|
|
|
/* go through the user's aliases and remove any that look like a vacation address */
|
|
|
|
foreach($aliases as $alias) {
|
|
|
|
if(!$ah->is_vacation_address($alias)) {
|
|
|
|
$new_aliases[] = $alias;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
$ah->update($new_aliases, '', false);
|
|
|
|
|
|
|
|
// tidy up vacation table.
|
|
|
|
$active = db_get_boolean(False);
|
|
|
|
$username = escape_string($this->username);
|
|
|
|
$result = db_query("UPDATE $table_vacation SET active = '$active' WHERE email='$username'");
|
|
|
|
$result = db_query("DELETE FROM $table_vacation_notification WHERE on_vacation='$username'");
|
|
|
|
/* crap error handling; oh for exceptions... */
|
|
|
|
return true;
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* @return boolean true indicates this server supports vacation messages, and users are able to change their own.
|
|
|
|
* @global array $CONF
|
|
|
|
*/
|
|
|
|
function vacation_supported() {
|
|
|
|
global $CONF;
|
|
|
|
return $CONF['vacation'] == 'YES' && $CONF['vacation_control'] == 'YES';
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* @return boolean true if on vacation, otherwise false
|
|
|
|
* Why do we bother storing true/false in the vacation table if the alias dictates it anyway?
|
|
|
|
*/
|
|
|
|
function check_vacation() {
|
|
|
|
$ah = new AliasHandler($this->username);
|
|
|
|
$aliases = $ah->get(true); // fetch all.
|
|
|
|
foreach($aliases as $alias) {
|
|
|
|
if($ah->is_vacation_address($alias)) {
|
|
|
|
return true;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
return false;
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Retrieve information on someone who is on vacation
|
|
|
|
* @return struct|boolean stored information on vacation - array(subject - string, message - string, active - boolean, activeFrom - date, activeUntil - date)
|
|
|
|
* will return false if no existing data
|
|
|
|
*/
|
|
|
|
function get_details() {
|
|
|
|
$table_vacation = table_by_key('vacation');
|
|
|
|
$username = escape_string($this->username);
|
|
|
|
|
|
|
|
$sql = "SELECT * FROM $table_vacation WHERE email = '$username'";
|
|
|
|
$result = db_query($sql);
|
|
|
|
if($result['rows'] == 1) {
|
|
|
|
$row = db_array($result['result']);
|
|
|
|
$boolean = ($row['active'] == db_get_boolean(true));
|
|
|
|
return array( 'subject' => $row['subject'],
|
|
|
|
'body' => $row['body'],
|
|
|
|
'active' => $boolean ,
|
|
|
|
'activeFrom' => $row['activefrom'],
|
|
|
|
'activeUntil' => $row['activeuntil']);
|
|
|
|
}
|
|
|
|
return false;
|
|
|
|
}
|
|
|
|
/**
|
|
|
|
* @param string $subject
|
|
|
|
* @param string $body
|
|
|
|
* @param date $activeFrom
|
|
|
|
* @param date $activeUntil
|
|
|
|
*/
|
|
|
|
function set_away($subject, $body, $activeFrom, $activeUntil) {
|
|
|
|
$this->remove(); // clean out any notifications that might already have been sent.
|
|
|
|
// is there an entry in the vacaton table for the user, or do we need to insert?
|
|
|
|
$table_vacation = table_by_key('vacation');
|
|
|
|
$username = escape_string($this->username);
|
|
|
|
$body = escape_string($body);
|
|
|
|
$subject = escape_string($subject);
|
|
|
|
$activeFrom = date ("Y-m-d 00:00:00", strtotime ($activeFrom));
|
|
|
|
$activeUntil = date ("Y-m-d 23:59:59", strtotime ($activeUntil));
|
|
|
|
|
|
|
|
$result = db_query("SELECT * FROM $table_vacation WHERE email = '$username'");
|
|
|
|
$active = db_get_boolean(True);
|
|
|
|
// check if the user has a vacation entry already, if so just update it
|
|
|
|
if($result['rows'] == 1) {
|
|
|
|
$result = db_query("UPDATE $table_vacation SET active = '$active', body = '$body', subject = '$subject', activefrom = '$activeFrom', activeuntil = '$activeUntil', created = NOW() WHERE email = '$username'");
|
|
|
|
}
|
|
|
|
else {
|
|
|
|
$tmp = preg_split ('/@/', $username);
|
|
|
|
$domain = escape_string($tmp[1]);
|
|
|
|
$result = db_query ("INSERT INTO $table_vacation (email,subject,body,domain,created,active,activefrom, activeuntil) VALUES ('$username','$subject','$body','$domain',NOW(),'$active','$activeFrom','$activeUntil')");
|
|
|
|
}
|
|
|
|
|
|
|
|
$ah = new AliasHandler($this->username);
|
|
|
|
$aliases = $ah->get(true);
|
|
|
|
$vacation_address = $this->getVacationAlias();
|
|
|
|
$aliases[] = $vacation_address;
|
|
|
|
return $ah->update($aliases, '', false);
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Returns the vacation alias for this user.
|
|
|
|
* i.e. if this user's username was roger@example.com, and the autoreply domain was set to
|
|
|
|
* autoreply.fish.net in config.inc.php we'd return roger#example.com@autoreply.fish.net
|
|
|
|
* @return string an email alias.
|
|
|
|
*/
|
|
|
|
public function getVacationAlias() {
|
|
|
|
global $CONF;
|
|
|
|
$vacation_domain = $CONF['vacation_domain'];
|
|
|
|
$vacation_goto = preg_replace('/@/', '#', $this->username);
|
|
|
|
$vacation_goto = "{$vacation_goto}@{$vacation_domain}";
|
|
|
|
return $vacation_goto;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
/* vim: set expandtab softtabstop=4 tabstop=4 shiftwidth=4: */
|