| | |
| | | if(is_file($sieve_file)) unlink($sieve_file) or $app->log("Unable to delete file: $sieve_file",LOGLEVEL_WARN); |
| | | |
| | | $app->load('tpl'); |
| | | |
| | | |
| | | //* Select sieve filter file for dovecot version |
| | | exec('dovecot --version',$tmp); |
| | | if(substr($tmp[0],0,3) == '1.0') { |
| | | $filter_file_template = "sieve_filter.master"; |
| | | } elseif(substr($tmp[0],0,3) == '1.2') { |
| | | $filter_file_template = "sieve_filter_1.2.master"; |
| | | } elseif(substr($tmp[0],0,1) == '2') { |
| | | $filter_file_template = "sieve_filter_1.2.master"; |
| | | } else { |
| | | $filter_file_template = "sieve_filter.master"; |
| | | } |
| | | unset($tmp); |
| | | |
| | | //* Create new filter file based on template |
| | | $tpl = new tpl(); |
| | | $tpl->newTemplate("sieve_filter.master"); |
| | | $tpl->newTemplate($filter_file_template); |
| | | |
| | | // cc Field |
| | | $tpl->setVar('cc',$data["new"]["cc"]); |
| | |
| | | |
| | | // Move junk |
| | | $tpl->setVar('move_junk',$data["new"]["move_junk"]); |
| | | |
| | | // Check autoresponder dates |
| | | if($data["new"]["autoresponder_start_date"] == '0000-00-00 00:00:00' && $data["new"]["autoresponder_end_date"] == '0000-00-00 00:00:00') { |
| | | $tpl->setVar('autoresponder_date_limit',0); |
| | | } else { |
| | | $tpl->setVar('autoresponder_date_limit',1); |
| | | } |
| | | |
| | | |
| | | // Set autoresponder start date |
| | | $data["new"]["autoresponder_start_date"] = str_replace (" ", "T", $data["new"]["autoresponder_start_date"]); |
| | |
| | | //* Set alias addresses for autoresponder |
| | | $sql = "SELECT * FROM mail_forwarding WHERE type = 'alias' AND destination = '".$app->db->quote($data["new"]["email"])."'"; |
| | | $records = $app->db->queryAllRecords($sql); |
| | | $addresses = ''; |
| | | |
| | | $addresses = array(); |
| | | $addresses[] = $data["new"]["email"]; |
| | | if(is_array($records) && count($records) > 0) { |
| | | $addresses .= ':addresses ["'.$data["new"]["email"].'",'; |
| | | foreach($records as $rec) { |
| | | $addresses .= '"'.$rec['source'].'",'; |
| | | $addresses[] = $rec['source']; |
| | | } |
| | | $addresses = substr($addresses,0,-1); |
| | | $addresses .= ']'; |
| | | } |
| | | $tpl->setVar('addresses',$addresses); |
| | | |
| | | $app->log("Found " . count($addresses) . " addresses.",LOGLEVEL_DEBUG); |
| | | |
| | | $alias_addresses = array(); |
| | | |
| | | $email_parts = explode('@',$data["new"]["email"]); |
| | | $sql = "SELECT * FROM mail_forwarding WHERE type = 'aliasdomain' AND destination = '@".$app->db->quote($email_parts[1])."'"; |
| | | $records = $app->db->queryAllRecords($sql); |
| | | if(is_array($records) && count($records) > 0) { |
| | | $app->log("Found " . count($records) . " records (aliasdomains).",LOGLEVEL_DEBUG); |
| | | foreach($records as $rec) { |
| | | $aliasdomain = substr($rec['source'],1); |
| | | foreach($addresses as $email) { |
| | | $email_parts = explode('@',$email); |
| | | $alias_addresses[] = $email_parts[0].'@'.$aliasdomain; |
| | | } |
| | | } |
| | | } |
| | | |
| | | $app->log("Found " . count($addresses) . " addresses at all.",LOGLEVEL_DEBUG); |
| | | |
| | | $addresses = array_unique(array_merge($addresses, $alias_addresses)); |
| | | |
| | | $app->log("Found " . count($addresses) . " unique addresses at all.",LOGLEVEL_DEBUG); |
| | | |
| | | $address_str = ''; |
| | | if(is_array($addresses) && count($addresses) > 0) { |
| | | $address_str .= ':addresses ['; |
| | | foreach($addresses as $rec) { |
| | | $address_str .= '"'.$rec.'",'; |
| | | } |
| | | $address_str = substr($address_str,0,-1); |
| | | $address_str .= ']'; |
| | | } |
| | | |
| | | |
| | | $tpl->setVar('addresses',$address_str); |
| | | |
| | | file_put_contents($sieve_file,$tpl->grab()); |
| | | |