mirror of
https://github.com/mailcow/mailcow-dockerized.git
synced 2025-01-12 04:23:24 +02:00
Merge pull request #536 from mkuron/patch-1
Rspamd user blacklist/whitelist improvements
This commit is contained in:
commit
29acfe85db
@ -47,7 +47,7 @@ function ucl_rcpts($object, $type) {
|
|||||||
$local = parse_email($row['address'])['local'];
|
$local = parse_email($row['address'])['local'];
|
||||||
$domain = parse_email($row['address'])['domain'];
|
$domain = parse_email($row['address'])['domain'];
|
||||||
if (!empty($local) && !empty($domain)) {
|
if (!empty($local) && !empty($domain)) {
|
||||||
$rcpt[] = '/' . $local . '\+.*' . $domain . '/';
|
$rcpt[] = '/' . $local . '\+.*' . $domain . '/i';
|
||||||
}
|
}
|
||||||
$rcpt[] = $row['address'];
|
$rcpt[] = $row['address'];
|
||||||
}
|
}
|
||||||
@ -65,7 +65,7 @@ function ucl_rcpts($object, $type) {
|
|||||||
$local = parse_email($row['alias'])['local'];
|
$local = parse_email($row['alias'])['local'];
|
||||||
$domain = parse_email($row['alias'])['domain'];
|
$domain = parse_email($row['alias'])['domain'];
|
||||||
if (!empty($local) && !empty($domain)) {
|
if (!empty($local) && !empty($domain)) {
|
||||||
$rcpt[] = '/' . $local . '\+.*' . $domain . '/';
|
$rcpt[] = '/' . $local . '\+.*' . $domain . '/i';
|
||||||
}
|
}
|
||||||
$rcpt[] = $row['alias'];
|
$rcpt[] = $row['alias'];
|
||||||
}
|
}
|
||||||
@ -74,20 +74,20 @@ function ucl_rcpts($object, $type) {
|
|||||||
$local = parse_email($row['object'])['local'];
|
$local = parse_email($row['object'])['local'];
|
||||||
$domain = parse_email($row['object'])['domain'];
|
$domain = parse_email($row['object'])['domain'];
|
||||||
if (!empty($local) && !empty($domain)) {
|
if (!empty($local) && !empty($domain)) {
|
||||||
$rcpt[] = '/' . $local . '\+.*' . $domain . '/';
|
$rcpt[] = '/' . $local . '\+.*' . $domain . '/i';
|
||||||
}
|
}
|
||||||
$rcpt[] = $object;
|
$rcpt[] = $object;
|
||||||
}
|
}
|
||||||
elseif ($type == 'domain') {
|
elseif ($type == 'domain') {
|
||||||
// Domain self
|
// Domain self
|
||||||
$rcpt[] = '/.*@' . $object . '/';
|
$rcpt[] = '/.*@' . $object . '/i';
|
||||||
$stmt = $pdo->prepare("SELECT `alias_domain` FROM `alias_domain`
|
$stmt = $pdo->prepare("SELECT `alias_domain` FROM `alias_domain`
|
||||||
WHERE `target_domain` = :object");
|
WHERE `target_domain` = :object");
|
||||||
$stmt->execute(array(':object' => $row['object']));
|
$stmt->execute(array(':object' => $object));
|
||||||
$alias_domains = $stmt->fetchAll(PDO::FETCH_ASSOC);
|
$alias_domains = $stmt->fetchAll(PDO::FETCH_ASSOC);
|
||||||
array_filter($alias_domains);
|
array_filter($alias_domains);
|
||||||
while ($row = array_shift($alias_domains)) {
|
while ($row = array_shift($alias_domains)) {
|
||||||
$rcpt[] = '/.*@' . $row['alias_domain'] . '/';
|
$rcpt[] = '/.*@' . $row['alias_domain'] . '/i';
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
if (!empty($rcpt)) {
|
if (!empty($rcpt)) {
|
||||||
@ -112,7 +112,7 @@ while ($row = array_shift($rows)) {
|
|||||||
score_<?=$username_sane;?> {
|
score_<?=$username_sane;?> {
|
||||||
priority = 4;
|
priority = 4;
|
||||||
<?php
|
<?php
|
||||||
foreach (ucl_rcpts($row['object'], 'mailbox') as $rcpt) {
|
foreach (ucl_rcpts($row['object'], strpos($row['object'], '@') === FALSE ? 'domain' : 'mailbox') as $rcpt) {
|
||||||
?>
|
?>
|
||||||
rcpt = "<?=$rcpt;?>";
|
rcpt = "<?=$rcpt;?>";
|
||||||
<?php
|
<?php
|
||||||
@ -152,13 +152,13 @@ while ($row = array_shift($rows)) {
|
|||||||
$grouped_lists = $stmt->fetchAll(PDO::FETCH_COLUMN);
|
$grouped_lists = $stmt->fetchAll(PDO::FETCH_COLUMN);
|
||||||
$value_sane = preg_replace("/\.\./", ".", (preg_replace("/\*/", ".*", $grouped_lists[0])));
|
$value_sane = preg_replace("/\.\./", ".", (preg_replace("/\*/", ".*", $grouped_lists[0])));
|
||||||
?>
|
?>
|
||||||
from = "/(<?=$value_sane;?>)/";
|
from = "/(<?=$value_sane;?>)/i";
|
||||||
<?php
|
<?php
|
||||||
if (!filter_var(trim($row['object']), FILTER_VALIDATE_EMAIL)) {
|
if (!filter_var(trim($row['object']), FILTER_VALIDATE_EMAIL)) {
|
||||||
?>
|
?>
|
||||||
priority = 5;
|
priority = 5;
|
||||||
<?php
|
<?php
|
||||||
foreach (ucl_rcpts($row['object'], 'mailbox') as $rcpt) {
|
foreach (ucl_rcpts($row['object'], strpos($row['object'], '@') === FALSE ? 'domain' : 'mailbox') as $rcpt) {
|
||||||
?>
|
?>
|
||||||
rcpt = "<?=$rcpt;?>";
|
rcpt = "<?=$rcpt;?>";
|
||||||
<?php
|
<?php
|
||||||
@ -168,7 +168,48 @@ while ($row = array_shift($rows)) {
|
|||||||
?>
|
?>
|
||||||
priority = 6;
|
priority = 6;
|
||||||
<?php
|
<?php
|
||||||
foreach (ucl_rcpts($row['object'], 'mailbox') as $rcpt) {
|
foreach (ucl_rcpts($row['object'], strpos($row['object'], '@') === FALSE ? 'domain' : 'mailbox') as $rcpt) {
|
||||||
|
?>
|
||||||
|
rcpt = "<?=$rcpt;?>";
|
||||||
|
<?php
|
||||||
|
}
|
||||||
|
}
|
||||||
|
?>
|
||||||
|
apply "default" {
|
||||||
|
MAILCOW_WHITE = -999.0;
|
||||||
|
}
|
||||||
|
symbols [
|
||||||
|
"MAILCOW_WHITE"
|
||||||
|
]
|
||||||
|
}
|
||||||
|
whitelist_header_<?=$username_sane;?> {
|
||||||
|
<?php
|
||||||
|
$stmt = $pdo->prepare("SELECT GROUP_CONCAT(REPLACE(`value`, '*', '.*') SEPARATOR '|') AS `value` FROM `filterconf`
|
||||||
|
WHERE `object`= :object
|
||||||
|
AND `option` = 'whitelist_from'");
|
||||||
|
$stmt->execute(array(':object' => $row['object']));
|
||||||
|
$grouped_lists = $stmt->fetchAll(PDO::FETCH_COLUMN);
|
||||||
|
$value_sane = preg_replace("/\.\./", ".", (preg_replace("/\*/", ".*", $grouped_lists[0])));
|
||||||
|
?>
|
||||||
|
request_header = {
|
||||||
|
"From" = "(<?=$value_sane;?>)";
|
||||||
|
}
|
||||||
|
<?php
|
||||||
|
if (!filter_var(trim($row['object']), FILTER_VALIDATE_EMAIL)) {
|
||||||
|
?>
|
||||||
|
priority = 5;
|
||||||
|
<?php
|
||||||
|
foreach (ucl_rcpts($row['object'], strpos($row['object'], '@') === FALSE ? 'domain' : 'mailbox') as $rcpt) {
|
||||||
|
?>
|
||||||
|
rcpt = "<?=$rcpt;?>";
|
||||||
|
<?php
|
||||||
|
}
|
||||||
|
}
|
||||||
|
else {
|
||||||
|
?>
|
||||||
|
priority = 6;
|
||||||
|
<?php
|
||||||
|
foreach (ucl_rcpts($row['object'], strpos($row['object'], '@') === FALSE ? 'domain' : 'mailbox') as $rcpt) {
|
||||||
?>
|
?>
|
||||||
rcpt = "<?=$rcpt;?>";
|
rcpt = "<?=$rcpt;?>";
|
||||||
<?php
|
<?php
|
||||||
@ -203,13 +244,13 @@ while ($row = array_shift($rows)) {
|
|||||||
$grouped_lists = $stmt->fetchAll(PDO::FETCH_COLUMN);
|
$grouped_lists = $stmt->fetchAll(PDO::FETCH_COLUMN);
|
||||||
$value_sane = preg_replace("/\.\./", ".", (preg_replace("/\*/", ".*", $grouped_lists[0])));
|
$value_sane = preg_replace("/\.\./", ".", (preg_replace("/\*/", ".*", $grouped_lists[0])));
|
||||||
?>
|
?>
|
||||||
from = "/(<?=$value_sane;?>)/";
|
from = "/(<?=$value_sane;?>)/i";
|
||||||
<?php
|
<?php
|
||||||
if (!filter_var(trim($row['object']), FILTER_VALIDATE_EMAIL)) {
|
if (!filter_var(trim($row['object']), FILTER_VALIDATE_EMAIL)) {
|
||||||
?>
|
?>
|
||||||
priority = 5;
|
priority = 5;
|
||||||
<?php
|
<?php
|
||||||
foreach (ucl_rcpts($row['object'], 'mailbox') as $rcpt) {
|
foreach (ucl_rcpts($row['object'], strpos($row['object'], '@') === FALSE ? 'domain' : 'mailbox') as $rcpt) {
|
||||||
?>
|
?>
|
||||||
rcpt = "<?=$rcpt;?>";
|
rcpt = "<?=$rcpt;?>";
|
||||||
<?php
|
<?php
|
||||||
@ -219,7 +260,48 @@ while ($row = array_shift($rows)) {
|
|||||||
?>
|
?>
|
||||||
priority = 6;
|
priority = 6;
|
||||||
<?php
|
<?php
|
||||||
foreach (ucl_rcpts($row['object'], 'mailbox') as $rcpt) {
|
foreach (ucl_rcpts($row['object'], strpos($row['object'], '@') === FALSE ? 'domain' : 'mailbox') as $rcpt) {
|
||||||
|
?>
|
||||||
|
rcpt = "<?=$rcpt;?>";
|
||||||
|
<?php
|
||||||
|
}
|
||||||
|
}
|
||||||
|
?>
|
||||||
|
apply "default" {
|
||||||
|
MAILCOW_BLACK = 999.0;
|
||||||
|
}
|
||||||
|
symbols [
|
||||||
|
"MAILCOW_BLACK"
|
||||||
|
]
|
||||||
|
}
|
||||||
|
blacklist_header_<?=$username_sane;?> {
|
||||||
|
<?php
|
||||||
|
$stmt = $pdo->prepare("SELECT GROUP_CONCAT(REPLACE(`value`, '*', '.*') SEPARATOR '|') AS `value` FROM `filterconf`
|
||||||
|
WHERE `object`= :object
|
||||||
|
AND `option` = 'blacklist_from'");
|
||||||
|
$stmt->execute(array(':object' => $row['object']));
|
||||||
|
$grouped_lists = $stmt->fetchAll(PDO::FETCH_COLUMN);
|
||||||
|
$value_sane = preg_replace("/\.\./", ".", (preg_replace("/\*/", ".*", $grouped_lists[0])));
|
||||||
|
?>
|
||||||
|
request_header = {
|
||||||
|
"From" = "(<?=$value_sane;?>)";
|
||||||
|
}
|
||||||
|
<?php
|
||||||
|
if (!filter_var(trim($row['object']), FILTER_VALIDATE_EMAIL)) {
|
||||||
|
?>
|
||||||
|
priority = 5;
|
||||||
|
<?php
|
||||||
|
foreach (ucl_rcpts($row['object'], strpos($row['object'], '@') === FALSE ? 'domain' : 'mailbox') as $rcpt) {
|
||||||
|
?>
|
||||||
|
rcpt = "<?=$rcpt;?>";
|
||||||
|
<?php
|
||||||
|
}
|
||||||
|
}
|
||||||
|
else {
|
||||||
|
?>
|
||||||
|
priority = 6;
|
||||||
|
<?php
|
||||||
|
foreach (ucl_rcpts($row['object'], strpos($row['object'], '@') === FALSE ? 'domain' : 'mailbox') as $rcpt) {
|
||||||
?>
|
?>
|
||||||
rcpt = "<?=$rcpt;?>";
|
rcpt = "<?=$rcpt;?>";
|
||||||
<?php
|
<?php
|
||||||
|
Loading…
Reference in New Issue
Block a user