mail-server/resources/config/sieve/from.sieve
2023-10-07 08:53:35 +02:00

158 lines
5.4 KiB
Sieve

let "from_count" "count(header.from[*].raw)";
let "service_accounts" "['www-data', 'anonymous', 'ftp', 'apache', 'nobody', 'guest', 'nginx', 'web', 'www']";
if eval "from_count > 0" {
let "from_raw" "to_lowercase(header.from.raw)";
if eval "from_count > 1" {
let "t.MULTIPLE_FROM" "1";
}
if eval "is_email(from_addr)" {
if eval "contains(service_accounts, from_local)" {
let "t.FROM_SERVICE_ACCT" "1";
}
if eval "starts_with(from_domain, 'www.')" {
let "t.WWW_DOT_DOMAIN" "1";
}
if eval "lookup('spam/free-domains', from_domain_sld)" {
let "t.FREEMAIL_FROM" "1";
} elsif eval "lookup('spam/disposable-domains', from_domain_sld)" {
let "t.DISPOSABLE_FROM" "1";
}
} else {
let "t.FROM_INVALID" "1";
}
if eval "is_empty(from_name)" {
let "t.FROM_NO_DN" "1";
} elsif eval "eq_ignore_case(from_addr, from_name)" {
let "t.FROM_DN_EQ_ADDR" "1";
} else {
if eval "!t.FROM_INVALID" {
let "t.FROM_HAS_DN" "1";
}
if eval "is_email(from_name)" {
let "from_name_sld" "domain_part(email_part(from_name, 'domain'), 'sld')";
if eval "(!t.FROM_INVALID && from_domain_sld != from_name_sld) ||
(!is_empty(envelope.from) && envfrom_domain_sld != from_name_sld) ||
(is_empty(envelope.from) && helo_domain_sld != from_name_sld)" {
let "t.SPOOF_DISPLAY_NAME" "1";
} else {
let "t.FROM_NEQ_DISPLAY_NAME" "1";
}
} else {
if eval "contains(from_name, 'mr. ') || contains(from_name, 'ms. ') || contains(from_name, 'mrs. ') || contains(from_name, 'dr. ')" {
let "t.FROM_NAME_HAS_TITLE" "1";
}
if eval "contains(header.from.name, ' ')" {
let "t.FROM_NAME_EXCESS_SPACE" "1";
}
}
}
if eval "is_empty(envelope.from) &&
(from_local == 'postmaster' ||
from_local == 'mailer-daemon' ||
from_local == 'root')" {
let "t.HFILTER_FROM_BOUNCE" "1";
}
if eval "(!is_empty(envelope.from) &&
eq_ignore_case(from_addr, envelope.from)) ||
(t.HFILTER_FROM_BOUNCE &&
!is_empty(from_domain) &&
from_domain_sld == helo_domain_sld)" {
let "t.FROM_EQ_ENVFROM" "1";
} elsif eval "!t.FROM_INVALID" {
let "t.FORGED_SENDER" "1";
let "t.FROM_NEQ_ENVFROM" "1";
}
if eval "contains(from_local, '+')" {
let "t.TAGGED_FROM" "1";
}
if eval "count(recipients_to) + count(recipients_cc) == 1" {
if eval "eq_ignore_case(recipients_to[0], from_addr)" {
let "t.TO_EQ_FROM" "1";
} elsif eval "eq_ignore_case(email_part(recipients_to[0], 'domain'), from_domain)" {
let "t.TO_DOM_EQ_FROM_DOM" "1";
}
}
if eval "!is_ascii(from_raw)" {
if eval "!env.param.smtputf8 && env.param.body != '8bitmime' && env.param.body != 'binarymime'" {
let "t.FROM_NEEDS_ENCODING" "1";
}
if eval "!is_header_utf8_valid('From')" {
let "t.INVALID_FROM_8BIT" "1";
}
}
if eval "is_ascii(header.from) && contains(from_raw, '=?') && contains(from_raw, '?=')" {
if eval "contains(from_raw, '?q?')" {
# From header is unnecessarily encoded in quoted-printable
let "t.FROM_EXCESS_QP" "1";
} elsif eval "contains(from_raw, '?b?')" {
# From header is unnecessarily encoded in base64
let "t.FROM_EXCESS_BASE64" "1";
}
}
if eval "!is_empty(from_name) && !is_empty(from_addr) && !contains(from_raw, ' <')" {
let "t.R_NO_SPACE_IN_FROM" "1";
}
# Read confirmation address is different to from address
let "crt" "header.X-Confirm-Reading-To.addr";
if eval "!is_empty(crt) && !eq_ignore_case(from_addr, crt)" {
let "t.HEADER_RCONFIRM_MISMATCH" "1";
}
} else {
let "t.MISSING_FROM" "1";
}
if eval "!is_empty(envelope.from)" {
if eval "is_email(envelope.from)" {
if eval "contains(service_accounts, envfrom_local)" {
let "t.ENVFROM_SERVICE_ACCT" "1";
}
} else {
let "t.ENVFROM_INVALID" "1";
}
if eval "!is_empty(envfrom_domain_sld)" {
if eval "lookup('spam/free-domains', envfrom_domain_sld)" {
let "t.FREEMAIL_ENVFROM" "1";
} elsif eval "lookup('spam/disposable-domains', envfrom_domain_sld)" {
let "t.DISPOSABLE_ENVFROM" "1";
}
# Mail from no resolve to A or MX
if eval "!dns_exists(envfrom_domain, 'mx') && !dns_exists(envfrom_domain, 'ip')" {
let "t.HFILTER_FROMHOST_NORES_A_OR_MX" "1";
}
}
# Read confirmation address is different to return path
let "dnt" "header.Disposition-Notification-To.addr";
if eval "!is_empty(dnt) && !eq_ignore_case(envelope.from, dnt)" {
let "t.HEADER_FORGED_MDN" "1";
}
}
if eval "!t.FROM_SERVICE_ACCT &&
(contains_ignore_case(service_accounts, email_part(rto_addr, 'local')) ||
contains_ignore_case(service_accounts, email_part(header.sender.addr, 'local')))" {
let "t.FROM_SERVICE_ACCT" "1";
}
if eval "!t.WWW_DOT_DOMAIN &&
(contains_ignore_case(rto_addr, '@www.') ||
contains_ignore_case(header.sender.addr, '@www.'))" {
let "t.WWW_DOT_DOMAIN" "1";
}