151 lines
		
	
	
		
			4.9 KiB
		
	
	
	
		
			PHP
		
	
	
	
	
	
			
		
		
	
	
			151 lines
		
	
	
		
			4.9 KiB
		
	
	
	
		
			PHP
		
	
	
	
	
	
| <?php
 | |
| function quota_notification($_action, $_data = null) {
 | |
| 	global $redis;
 | |
| 	$_data_log = $_data;
 | |
|   if ($_SESSION['mailcow_cc_role'] != "admin") {
 | |
|     $_SESSION['return'][] = array(
 | |
|       'type' => 'danger',
 | |
|       'log' => array(__FUNCTION__, $_action, $_data_log),
 | |
|       'msg' => 'access_denied'
 | |
|     );
 | |
|     return false;
 | |
|   }
 | |
|   switch ($_action) {
 | |
|     case 'edit':
 | |
|       $retention_size = $_data['retention_size'];
 | |
|       if ($_data['release_format'] == 'attachment' || $_data['release_format'] == 'raw') {
 | |
|         $release_format = $_data['release_format'];
 | |
|       }
 | |
|       else {
 | |
|         $release_format = 'raw';
 | |
|       }
 | |
|       $subject = $_data['subject'];
 | |
|       $sender = preg_replace('/[\x00-\x1F\x80-\xFF]/', '', $_data['sender']);
 | |
|       if (filter_var($sender, FILTER_VALIDATE_EMAIL) === false) {
 | |
|         $sender = '';
 | |
|       }
 | |
|       $html = $_data['html_tmpl'];
 | |
|       try {
 | |
|         $redis->Set('QW_SENDER', $sender);
 | |
|         $redis->Set('QW_SUBJ', $subject);
 | |
|         $redis->Set('QW_HTML', $html);
 | |
|       }
 | |
|       catch (RedisException $e) {
 | |
|         $_SESSION['return'][] = array(
 | |
|           'type' => 'danger',
 | |
|           'log' => array(__FUNCTION__, $_action, $_data_log),
 | |
|           'msg' => array('redis_error', $e)
 | |
|         );
 | |
|         return false;
 | |
|       }
 | |
|       $_SESSION['return'][] = array(
 | |
|         'type' => 'success',
 | |
|         'log' => array(__FUNCTION__, $_action, $_data_log),
 | |
|         'msg' => 'saved_settings'
 | |
|       );
 | |
|     break;
 | |
|     case 'get':
 | |
|       try {
 | |
|         $settings['subject'] = $redis->Get('QW_SUBJ');
 | |
|         $settings['sender'] = $redis->Get('QW_SENDER');
 | |
|         $settings['html_tmpl'] = htmlspecialchars($redis->Get('QW_HTML'));
 | |
|         if (empty($settings['html_tmpl'])) {
 | |
|           $settings['html_tmpl'] = htmlspecialchars(file_get_contents("/tpls/quota.tpl"));
 | |
|         }
 | |
|       }
 | |
|       catch (RedisException $e) {
 | |
|         $_SESSION['return'][] = array(
 | |
|           'type' => 'danger',
 | |
|           'log' => array(__FUNCTION__, $_action, $_data_log),
 | |
|           'msg' => array('redis_error', $e)
 | |
|         );
 | |
|         return false;
 | |
|       }
 | |
|       return $settings;
 | |
|     break;
 | |
|   }
 | |
| }
 | |
| function quota_notification_bcc($_action, $_data = null) {
 | |
| 	global $redis;
 | |
| 	$_data_log = $_data;
 | |
|   if ($_SESSION['mailcow_cc_role'] != "admin" && $_SESSION['mailcow_cc_role'] != "domainadmin") {
 | |
|     $_SESSION['return'][] = array(
 | |
|       'type' => 'danger',
 | |
|       'log' => array(__FUNCTION__, $_action, $_data_log),
 | |
|       'msg' => 'access_denied'
 | |
|     );
 | |
|     return false;
 | |
|   }
 | |
|   switch ($_action) {
 | |
|     case 'edit':
 | |
|       $domain = $_data['domain'];
 | |
|       if (!hasDomainAccess($_SESSION['mailcow_cc_username'], $_SESSION['mailcow_cc_role'], $domain)) {
 | |
|         $_SESSION['return'][] = array(
 | |
|           'type' => 'danger',
 | |
|           'log' => array(__FUNCTION__, $_action, $_data_log),
 | |
|           'msg' => 'access_denied'
 | |
|         );
 | |
|         return false;
 | |
|       }
 | |
|       $active = intval($_data['active']);
 | |
|       $bcc_rcpts = array_map('trim', preg_split( "/( |,|;|\n)/", $_data['bcc_rcpt']));
 | |
|       foreach ($bcc_rcpts as $i => &$rcpt) {
 | |
|         $rcpt = preg_replace('/[\x00-\x1F\x80-\xFF]/', '', $rcpt);
 | |
|           if (!empty($rcpt) && filter_var($rcpt, FILTER_VALIDATE_EMAIL) === false) {
 | |
|             $_SESSION['return'][] = array(
 | |
|               'type' => 'danger',
 | |
|               'log' => array(__FUNCTION__, $_action, $_data_log),
 | |
|               'msg' => array('goto_invalid', htmlspecialchars($rcpt))
 | |
|             );
 | |
|             unset($bcc_rcpts[$i]);
 | |
|             continue;
 | |
|           }
 | |
|       }
 | |
|       $bcc_rcpts = array_unique($bcc_rcpts);
 | |
|       $bcc_rcpts = array_filter($bcc_rcpts);
 | |
|       if (empty($bcc_rcpts)) {
 | |
|         $active = 0;
 | |
|         
 | |
|       }
 | |
|       try {
 | |
|         $redis->hSet('QW_BCC', $domain, json_encode(array('bcc_rcpts' => $bcc_rcpts, 'active' => $active)));
 | |
|       }
 | |
|       catch (RedisException $e) {
 | |
|         $_SESSION['return'][] = array(
 | |
|           'type' => 'danger',
 | |
|           'log' => array(__FUNCTION__, $_action, $_data_log),
 | |
|           'msg' => array('redis_error', $e)
 | |
|         );
 | |
|         return false;
 | |
|       }
 | |
|       $_SESSION['return'][] = array(
 | |
|         'type' => 'success',
 | |
|         'log' => array(__FUNCTION__, $_action, $_data_log),
 | |
|         'msg' => 'saved_settings'
 | |
|       );
 | |
|     break;
 | |
|     case 'get':
 | |
|       $domain = $_data;
 | |
|       if (!hasDomainAccess($_SESSION['mailcow_cc_username'], $_SESSION['mailcow_cc_role'], $domain)) {
 | |
|         $_SESSION['return'][] = array(
 | |
|           'type' => 'danger',
 | |
|           'log' => array(__FUNCTION__, $_action, $_data_log),
 | |
|           'msg' => 'access_denied'
 | |
|         );
 | |
|         return false;
 | |
|       }
 | |
|       try {
 | |
|         return json_decode($redis->hGet('QW_BCC', $domain), true);
 | |
|       }
 | |
|       catch (RedisException $e) {
 | |
|         $_SESSION['return'][] = array(
 | |
|           'type' => 'danger',
 | |
|           'log' => array(__FUNCTION__, $_action, $_data_log),
 | |
|           'msg' => array('redis_error', $e)
 | |
|         );
 | |
|         return false;
 | |
|       }
 | |
|     break;
 | |
|   }
 | |
| }
 |