Pārlūkot izejas kodu

Merge branch 'feat/remove-ip6nat' into nightly

DerLinkman 1 mēnesi atpakaļ
vecāks
revīzija
5aa9498f65

+ 45 - 1
_modules/scripts/core.sh

@@ -17,7 +17,7 @@ caller="${BASH_SOURCE[1]##*/}"
 
 get_installed_tools(){
     for bin in openssl curl docker git awk sha1sum grep cut jq; do
-        if [[ -z $(which ${bin}) ]]; then echo "Cannot find ${bin}, exiting..."; exit 1; fi
+        if [[ -z $(command -v ${bin}) ]]; then echo "Cannot find ${bin}, exiting..."; exit 1; fi
     done
 
     if grep --help 2>&1 | head -n 1 | grep -q -i "busybox"; then echo -e "${LIGHT_RED}BusyBox grep detected, please install gnu grep, \"apk add --no-cache --upgrade grep\"${NC}"; exit 1; fi
@@ -176,4 +176,48 @@ in_array() {
   shift
   for e; do [[ "$e" == "$match" ]] && return 0; done
   return 1
+}
+
+detect_major_update() {
+  if [ ${BRANCH} == "master" ]; then
+    # Array with major versions
+    # Add major versions here
+    MAJOR_VERSIONS=(
+      "2025-02"
+      "2025-03"
+    )
+
+    current_version=""
+    if [[ -f "${SCRIPT_DIR}/data/web/inc/app_info.inc.php" ]]; then
+      current_version=$(grep 'MAILCOW_GIT_VERSION' ${SCRIPT_DIR}/data/web/inc/app_info.inc.php | sed -E 's/.*MAILCOW_GIT_VERSION="([^"]+)".*/\1/')
+    fi
+    if [[ -z "$current_version" ]]; then
+      return 1
+    fi
+    release_url="https://github.com/mailcow/mailcow-dockerized/releases/tag"
+
+    updates_to_apply=()
+
+    for version in "${MAJOR_VERSIONS[@]}"; do
+      if [[ "$current_version" < "$version" ]]; then
+        updates_to_apply+=("$version")
+      fi
+    done
+
+    if [[ ${#updates_to_apply[@]} -gt 0 ]]; then
+      echo -e "\e[33m\nMAJOR UPDATES to be applied:\e[0m"
+      for update in "${updates_to_apply[@]}"; do
+        echo "$update - $release_url/$update"
+      done
+
+      echo -e "\nPlease read the release notes before proceeding."
+      read -p "Do you want to proceed with the update? [y/n] " response
+      if [[ "${response}" =~ ^([yY][eE][sS]|[yY])+$ ]]; then
+        echo "Proceeding with the update..."
+      else
+        echo "Update canceled. Exiting."
+        exit 1
+      fi
+    fi
+  fi
 }

+ 2 - 3
_modules/scripts/ipv6_controller.sh

@@ -18,6 +18,7 @@ get_ipv6_support() {
 # 2) Ensure Docker daemon.json has (or create) the required IPv6 settings
 docker_daemon_edit(){
   DOCKER_DAEMON_CONFIG="/etc/docker/daemon.json"
+  DOCKER_MAJOR=$(docker version --format '{{.Server.Version}}' 2>/dev/null | cut -d. -f1)
   MISSING=()
 
   _has_kv() { grep -Eq "\"$1\"\s*:\s*$2" "$DOCKER_DAEMON_CONFIG" 2>/dev/null; }
@@ -40,7 +41,7 @@ docker_daemon_edit(){
     ! _has_kv ipv6 true       && MISSING+=("ipv6: true")
     ! grep -Eq '"fixed-cidr-v6"\s*:\s*".+"' "$DOCKER_DAEMON_CONFIG" \
                               && MISSING+=('fixed-cidr-v6: "fd00:dead:beef:c0::/80"')
-    if [[ -n "$docker_version" && "$docker_version" -ge 27 ]]; then
+    if [[ -n "$DOCKER_MAJOR" && "$DOCKER_MAJOR" -ge 27 ]]; then
       _has_kv ipv6 true && ! _has_kv ip6tables true && MISSING+=("ip6tables: true")
       ! _has_kv experimental true                 && MISSING+=("experimental: true")
     fi
@@ -87,7 +88,6 @@ docker_daemon_edit(){
     fi
 
     if [[ $ans =~ ^[Yy]$ ]]; then
-      DOCKER_MAJOR=$(docker version --format '{{.Server.Version}}' 2>/dev/null | cut -d. -f1)
       if [[ -n "$DOCKER_MAJOR" && "$DOCKER_MAJOR" -lt 27 ]]; then
         cat > "$DOCKER_DAEMON_CONFIG" <<EOF
 {
@@ -141,7 +141,6 @@ configure_ipv6() {
       echo -e "${RED}Please disable or fix your host/Docker IPv6 support, or set ENABLE_IPV6=false.${NC}"
       exit 1
     else
-      echo "Manual ENABLE_IPV6=$MANUAL_SETTING detected and matches system status—no changes applied."
       return
     fi
   fi

+ 3 - 3
_modules/scripts/new_options.sh

@@ -82,7 +82,7 @@ adapt_new_options() {
             echo "# Switch here between native (compose plugin) and standalone" >> mailcow.conf
             echo "# For more informations take a look at the mailcow docs regarding the configuration options." >> mailcow.conf
             echo "# Normally this should be untouched but if you decided to use either of those you can switch it manually here." >> mailcow.conf
-            echo "# Please be aware that at least one of those variants should be installed on your maschine or mailcow will fail." >> mailcow.conf
+            echo "# Please be aware that at least one of those variants should be installed on your machine or mailcow will fail." >> mailcow.conf
             echo "" >> mailcow.conf
             echo "DOCKER_COMPOSE_VERSION=${DOCKER_COMPOSE_VERSION}" >> mailcow.conf
             ;;
@@ -139,7 +139,7 @@ adapt_new_options() {
         ACL_ANYONE)
             echo '# Set this to "allow" to enable the anyone pseudo user. Disabled by default.' >> mailcow.conf
             echo '# When enabled, ACL can be created, that apply to "All authenticated users"' >> mailcow.conf
-            echo '# This should probably only be activated on mail hosts, that are used exclusivly by one organisation.' >> mailcow.conf
+            echo '# This should probably only be activated on mail hosts, that are used exclusively by one organisation.' >> mailcow.conf
             echo '# Otherwise a user might share data with too many other users.' >> mailcow.conf
             echo 'ACL_ANYONE=disallow' >> mailcow.conf
             ;;
@@ -297,7 +297,7 @@ adapt_new_options() {
             ;;
         
         REDISPASS)
-            echo "REDISPASS=\$(LC_ALL=C </dev/urandom tr -dc A-Za-z0-9 2>/dev/null | head -c 28)" >> mailcow.conf
+            echo "REDISPASS=$(LC_ALL=C </dev/urandom tr -dc A-Za-z0-9 2>/dev/null | head -c 28)" >> mailcow.conf
             ;;
                   
         *)

+ 103 - 62
data/Dockerfiles/netfilter/main.py

@@ -1,5 +1,7 @@
 #!/usr/bin/env python3
 
+DEBUG = False
+
 import re
 import os
 import sys
@@ -20,10 +22,13 @@ from modules.Logger import Logger
 from modules.IPTables import IPTables
 from modules.NFTables import NFTables
 
+def logdebug(msg):
+  if DEBUG:
+    logger.logInfo("DEBUG: %s" % msg)
 
-# globals
+# Globals
 WHITELIST = []
-BLACKLIST= []
+BLACKLIST = []
 bans = {}
 quit_now = False
 exit_code = 0
@@ -33,12 +38,10 @@ r = None
 pubsub = None
 clear_before_quit = False
 
-
 def refreshF2boptions():
   global f2boptions
   global quit_now
   global exit_code
-
   f2boptions = {}
 
   if not r.get('F2B_OPTIONS'):
@@ -52,8 +55,9 @@ def refreshF2boptions():
   else:
     try:
       f2boptions = json.loads(r.get('F2B_OPTIONS'))
-    except ValueError:
-      logger.logCrit('Error loading F2B options: F2B_OPTIONS is not json')
+    except ValueError as e:
+      logger.logCrit(
+        'Error loading F2B options: F2B_OPTIONS is not json. Exception: %s' % e)
       quit_now = True
       exit_code = 2
 
@@ -61,15 +65,15 @@ def refreshF2boptions():
   r.set('F2B_OPTIONS', json.dumps(f2boptions, ensure_ascii=False))
 
 def verifyF2boptions(f2boptions):
-  verifyF2boption(f2boptions,'ban_time', 1800)
-  verifyF2boption(f2boptions,'max_ban_time', 10000)
-  verifyF2boption(f2boptions,'ban_time_increment', True)
-  verifyF2boption(f2boptions,'max_attempts', 10)
-  verifyF2boption(f2boptions,'retry_window', 600)
-  verifyF2boption(f2boptions,'netban_ipv4', 32)
-  verifyF2boption(f2boptions,'netban_ipv6', 128)
-  verifyF2boption(f2boptions,'banlist_id', str(uuid.uuid4()))
-  verifyF2boption(f2boptions,'manage_external', 0)
+  verifyF2boption(f2boptions, 'ban_time', 1800)
+  verifyF2boption(f2boptions, 'max_ban_time', 10000)
+  verifyF2boption(f2boptions, 'ban_time_increment', True)
+  verifyF2boption(f2boptions, 'max_attempts', 10)
+  verifyF2boption(f2boptions, 'retry_window', 600)
+  verifyF2boption(f2boptions, 'netban_ipv4', 32)
+  verifyF2boption(f2boptions, 'netban_ipv6', 128)
+  verifyF2boption(f2boptions, 'banlist_id', str(uuid.uuid4()))
+  verifyF2boption(f2boptions, 'manage_external', 0)
 
 def verifyF2boption(f2boptions, f2boption, f2bdefault):
   f2boptions[f2boption] = f2boptions[f2boption] if f2boption in f2boptions and f2boptions[f2boption] is not None else f2bdefault
@@ -111,7 +115,7 @@ def get_ip(address):
 def ban(address):
   global f2boptions
   global lock
-
+  logdebug("ban() called with address=%s" % address)
   refreshF2boptions()
   MAX_ATTEMPTS = int(f2boptions['max_attempts'])
   RETRY_WINDOW = int(f2boptions['retry_window'])
@@ -119,31 +123,43 @@ def ban(address):
   NETBAN_IPV6 = '/' + str(f2boptions['netban_ipv6'])
 
   ip = get_ip(address)
-  if not ip: return
+  if not ip:
+    logdebug("No valid IP -- skipping ban()")
+    return
   address = str(ip)
   self_network = ipaddress.ip_network(address)
 
   with lock:
     temp_whitelist = set(WHITELIST)
-  if temp_whitelist:
-    for wl_key in temp_whitelist:
-      wl_net = ipaddress.ip_network(wl_key, False)
-      if wl_net.overlaps(self_network):
-        logger.logInfo('Address %s is whitelisted by rule %s' % (self_network, wl_net))
-        return
-
-  net = ipaddress.ip_network((address + (NETBAN_IPV4 if type(ip) is ipaddress.IPv4Address else NETBAN_IPV6)), strict=False)
+    logdebug("Checking if %s overlaps with any WHITELIST entries" % self_network)
+    if temp_whitelist:
+      for wl_key in temp_whitelist:
+        wl_net = ipaddress.ip_network(wl_key, False)
+        logdebug("Checking overlap between %s and %s" % (self_network, wl_net))
+        if wl_net.overlaps(self_network):
+          logger.logInfo(
+            'Address %s is allowlisted by rule %s' % (self_network, wl_net))
+          return
+
+  net = ipaddress.ip_network(
+    (address + (NETBAN_IPV4 if type(ip) is ipaddress.IPv4Address else NETBAN_IPV6)), strict=False)
   net = str(net)
+  logdebug("Ban net: %s" % net)
 
   if not net in bans:
     bans[net] = {'attempts': 0, 'last_attempt': 0, 'ban_counter': 0}
+    logdebug("Initing new ban counter for %s" % net)
 
   current_attempt = time.time()
+  logdebug("Current attempt ts=%s, previous: %s, retry_window: %s" %
+           (current_attempt, bans[net]['last_attempt'], RETRY_WINDOW))
   if current_attempt - bans[net]['last_attempt'] > RETRY_WINDOW:
     bans[net]['attempts'] = 0
+    logdebug("Ban counter for %s reset as window expired" % net)
 
   bans[net]['attempts'] += 1
   bans[net]['last_attempt'] = current_attempt
+  logdebug("%s attempts now %d" % (net, bans[net]['attempts']))
 
   if bans[net]['attempts'] >= MAX_ATTEMPTS:
     cur_time = int(round(time.time()))
@@ -151,34 +167,41 @@ def ban(address):
     logger.logCrit('Banning %s for %d minutes' % (net, NET_BAN_TIME / 60 ))
     if type(ip) is ipaddress.IPv4Address and int(f2boptions['manage_external']) != 1:
       with lock:
+        logdebug("Calling tables.banIPv4(%s)" % net)
         tables.banIPv4(net)
     elif int(f2boptions['manage_external']) != 1:
       with lock:
+        logdebug("Calling tables.banIPv6(%s)" % net)
         tables.banIPv6(net)
 
+    logdebug("Updating F2B_ACTIVE_BANS[%s]=%d" %
+              (net, cur_time + NET_BAN_TIME))
     r.hset('F2B_ACTIVE_BANS', '%s' % net, cur_time + NET_BAN_TIME)
   else:
-    logger.logWarn('%d more attempts in the next %d seconds until %s is banned' % (MAX_ATTEMPTS - bans[net]['attempts'], RETRY_WINDOW, net))
+    logger.logWarn('%d more attempts in the next %d seconds until %s is banned' % (
+      MAX_ATTEMPTS - bans[net]['attempts'], RETRY_WINDOW, net))
 
 def unban(net):
   global lock
-
+  logdebug("Calling unban() with net=%s" % net)
   if not net in bans:
-   logger.logInfo('%s is not banned, skipping unban and deleting from queue (if any)' % net)
-   r.hdel('F2B_QUEUE_UNBAN', '%s' % net)
-   return
-
+    logger.logInfo(
+      '%s is not banned, skipping unban and deleting from queue (if any)' % net)
+    r.hdel('F2B_QUEUE_UNBAN', '%s' % net)
+    return
   logger.logInfo('Unbanning %s' % net)
   if type(ipaddress.ip_network(net)) is ipaddress.IPv4Network:
     with lock:
+      logdebug("Calling tables.unbanIPv4(%s)" % net)
       tables.unbanIPv4(net)
   else:
     with lock:
+      logdebug("Calling tables.unbanIPv6(%s)" % net)
       tables.unbanIPv6(net)
-
   r.hdel('F2B_ACTIVE_BANS', '%s' % net)
   r.hdel('F2B_QUEUE_UNBAN', '%s' % net)
   if net in bans:
+    logdebug("Unban for %s, setting attempts=0, ban_counter+=1" % net)
     bans[net]['attempts'] = 0
     bans[net]['ban_counter'] += 1
 
@@ -204,17 +227,19 @@ def permBan(net, unban=False):
 
   if is_unbanned:
     r.hdel('F2B_PERM_BANS', '%s' % net)
-    logger.logCrit('Removed host/network %s from blacklist' % net)
+    logger.logCrit('Removed host/network %s from denylist' % net)
   elif is_banned:
     r.hset('F2B_PERM_BANS', '%s' % net, int(round(time.time())))
-    logger.logCrit('Added host/network %s to blacklist' % net)
+    logger.logCrit('Added host/network %s to denylist' % net)
 
 def clear():
   global lock
   logger.logInfo('Clearing all bans')
   for net in bans.copy():
+    logdebug("Unbanning net: %s" % net)
     unban(net)
   with lock:
+    logdebug("Clearing IPv4/IPv6 table")
     tables.clearIPv4Table()
     tables.clearIPv6Table()
     try:
@@ -275,21 +300,35 @@ def snat6(snat_target):
 
 def autopurge():
   global f2boptions
-
+  logdebug("autopurge thread started")
   while not quit_now:
+    logdebug("autopurge tick")
     time.sleep(10)
     refreshF2boptions()
     MAX_ATTEMPTS = int(f2boptions['max_attempts'])
     QUEUE_UNBAN = r.hgetall('F2B_QUEUE_UNBAN')
+    logdebug("QUEUE_UNBAN: %s" % QUEUE_UNBAN)
     if QUEUE_UNBAN:
       for net in QUEUE_UNBAN:
+        logdebug("Autopurge: unbanning queued net: %s" % net)
         unban(str(net))
-    for net in bans.copy():
-      if bans[net]['attempts'] >= MAX_ATTEMPTS:
-        NET_BAN_TIME = calcNetBanTime(bans[net]['ban_counter'])
-        TIME_SINCE_LAST_ATTEMPT = time.time() - bans[net]['last_attempt']
-        if TIME_SINCE_LAST_ATTEMPT > NET_BAN_TIME:
-          unban(net)
+    # Only check expiry for actively banned IPs:
+    active_bans = r.hgetall('F2B_ACTIVE_BANS')
+    now = time.time()
+    for net_str, expire_str in active_bans.items():
+      logdebug("Checking ban expiry for (actively banned): %s" % net_str)
+      # Defensive: always process if timer missing or expired
+      try:
+        expire = float(expire_str)
+      except Exception:
+        logdebug("Invalid expire time for %s; unbanning" % net_str)
+        unban(net_str)
+        continue
+      time_left = expire - now
+      logdebug("Time left for %s: %.1f seconds" % (net_str, time_left))
+      if time_left <= 0:
+        logdebug("Ban expired for %s" % net_str)
+        unban(net_str)
 
 def mailcowChainOrder():
   global lock
@@ -359,7 +398,7 @@ def whitelistUpdate():
     with lock:
       if Counter(new_whitelist) != Counter(WHITELIST):
         WHITELIST = new_whitelist
-        logger.logInfo('Whitelist was changed, it has %s entries' % len(WHITELIST))
+        logger.logInfo('Allowlist was changed, it has %s entries' % len(WHITELIST))
     time.sleep(60.0 - ((time.time() - start_time) % 60.0))
 
 def blacklistUpdate():
@@ -375,7 +414,7 @@ def blacklistUpdate():
       addban = set(new_blacklist).difference(BLACKLIST)
       delban = set(BLACKLIST).difference(new_blacklist)
       BLACKLIST = new_blacklist
-      logger.logInfo('Blacklist was changed, it has %s entries' % len(BLACKLIST))
+      logger.logInfo('Denylist was changed, it has %s entries' % len(BLACKLIST))
       if addban:
         for net in addban:
           permBan(net=net)
@@ -386,25 +425,25 @@ def blacklistUpdate():
 
 def sigterm_quit(signum, frame):
   global clear_before_quit
+  logdebug("SIGTERM received, setting clear_before_quit to True and exiting")
   clear_before_quit = True
   sys.exit(exit_code)
 
-def berfore_quit():
+def before_quit():
+  logdebug("before_quit called, clear_before_quit=%s" % clear_before_quit)
   if clear_before_quit:
     clear()
   if pubsub is not None:
     pubsub.unsubscribe()
 
-
 if __name__ == '__main__':
-  atexit.register(berfore_quit)
-  signal.signal(signal.SIGTERM, sigterm_quit)
-
-  # init Logger
   logger = Logger()
+  logdebug("Sys.argv: %s" % sys.argv)
+  atexit.register(before_quit)
+  signal.signal(signal.SIGTERM, sigterm_quit)
 
-  # init backend
   backend = sys.argv[1]
+  logdebug("Backend: %s" % backend)
   if backend == "nftables":
     logger.logInfo('Using NFTables backend')
     tables = NFTables(chain_name, logger)
@@ -412,16 +451,12 @@ if __name__ == '__main__':
     logger.logInfo('Using IPTables backend')
     tables = IPTables(chain_name, logger)
 
-  # In case a previous session was killed without cleanup
   clear()
-
-  # Reinit MAILCOW chain
-  # Is called before threads start, no locking
   logger.logInfo("Initializing mailcow netfilter chain")
   tables.initChainIPv4()
   tables.initChainIPv6()
 
-  if os.getenv("DISABLE_NETFILTER_ISOLATION_RULE").lower() in ("y", "yes"):
+  if os.getenv("DISABLE_NETFILTER_ISOLATION_RULE", "").lower() in ("y", "yes"):
     logger.logInfo(f"Skipping {chain_name} isolation")
   else:
     logger.logInfo(f"Setting {chain_name} isolation")
@@ -432,23 +467,28 @@ if __name__ == '__main__':
     try:
       redis_slaveof_ip = os.getenv('REDIS_SLAVEOF_IP', '')
       redis_slaveof_port = os.getenv('REDIS_SLAVEOF_PORT', '')
+      logdebug(
+        "Connecting redis (SLAVEOF_IP:%s, PORT:%s)" % (redis_slaveof_ip, redis_slaveof_port))
       if "".__eq__(redis_slaveof_ip):
-        r = redis.StrictRedis(host=os.getenv('IPV4_NETWORK', '172.22.1') + '.249', decode_responses=True, port=6379, db=0, password=os.environ['REDISPASS'])
+        r = redis.StrictRedis(
+          host=os.getenv('IPV4_NETWORK', '172.22.1') + '.249', decode_responses=True, port=6379, db=0, password=os.environ['REDISPASS'])
       else:
-        r = redis.StrictRedis(host=redis_slaveof_ip, decode_responses=True, port=redis_slaveof_port, db=0, password=os.environ['REDISPASS'])
+        r = redis.StrictRedis(
+          host=redis_slaveof_ip, decode_responses=True, port=redis_slaveof_port, db=0, password=os.environ['REDISPASS'])
       r.ping()
       pubsub = r.pubsub()
     except Exception as ex:
-      print('%s - trying again in 3 seconds'  % (ex))
+      logdebug(
+        'Redis connection failed: %s - trying again in 3 seconds' % (ex))
       time.sleep(3)
     else:
       break
   logger.set_redis(r)
+  logdebug("Redis connection established, setting up F2B keys")
 
-  # rename fail2ban to netfilter
   if r.exists('F2B_LOG'):
+    logdebug("Renaming F2B_LOG to NETFILTER_LOG")
     r.rename('F2B_LOG', 'NETFILTER_LOG')
-  # clear bans in redis
   r.delete('F2B_ACTIVE_BANS')
   r.delete('F2B_PERM_BANS')
 
@@ -463,7 +503,7 @@ if __name__ == '__main__':
       snat_ip = os.getenv('SNAT_TO_SOURCE')
       snat_ipo = ipaddress.ip_address(snat_ip)
       if type(snat_ipo) is ipaddress.IPv4Address:
-        snat4_thread = Thread(target=snat4,args=(snat_ip,))
+        snat4_thread = Thread(target=snat4, args=(snat_ip,))
         snat4_thread.daemon = True
         snat4_thread.start()
     except ValueError:
@@ -499,4 +539,5 @@ if __name__ == '__main__':
   while not quit_now:
     time.sleep(0.5)
 
-  sys.exit(exit_code)
+  logdebug("Exiting with code %s" % exit_code)
+  sys.exit(exit_code)

+ 2 - 2
data/Dockerfiles/nginx/bootstrap.py

@@ -10,7 +10,7 @@ def includes_conf(env, template_vars):
   server_name_config = f"server_name {template_vars['MAILCOW_HOSTNAME']} autodiscover.* autoconfig.* {' '.join(template_vars['ADDITIONAL_SERVER_NAMES'])};"
   listen_plain_config = f"listen {template_vars['HTTP_PORT']};"
   listen_ssl_config = f"listen {template_vars['HTTPS_PORT']};"
-  if template_vars['ENABLE_IPV6'] == "false":
+  if not template_vars['ENABLE_IPV6']:
     listen_plain_config += f"\nlisten [::]:{template_vars['HTTP_PORT']};"
     listen_ssl_config += f"\nlisten [::]:{template_vars['HTTPS_PORT']} ssl;"
   listen_ssl_config += "\nhttp2 on;"
@@ -58,7 +58,7 @@ def prepare_template_vars():
     'SOGOHOST': os.getenv("SOGOHOST", ipv4_network + ".248"),
     'RSPAMDHOST': os.getenv("RSPAMDHOST", "rspamd-mailcow"),
     'PHPFPMHOST': os.getenv("PHPFPMHOST", "php-fpm-mailcow"),
-    'ENABLE_IPV6': os.getenv("ENABLE_IPV6", "true").lower() in ("false"),
+    'ENABLE_IPV6': os.getenv("ENABLE_IPV6", "true").lower() != "false",
     'HTTP_REDIRECT': os.getenv("HTTP_REDIRECT", "n").lower() in ("y", "yes"),
   }
 

+ 26 - 12
data/conf/postfix/postscreen_access.cidr

@@ -1,6 +1,6 @@
-# Whitelist generated by Postwhite v3.4 on Tue Jul  1 00:22:55 UTC 2025
+# Whitelist generated by Postwhite v3.4 on Fri Aug  1 00:24:14 UTC 2025
 # https://github.com/stevejenkins/postwhite/
-# 2105 total rules
+# 2166 total rules
 2a00:1450:4000::/36	permit
 2a01:111:f400::/48	permit
 2a01:111:f403:8000::/50	permit
@@ -42,7 +42,7 @@
 8.40.222.0/23	permit
 8.40.222.250/31	permit
 12.130.86.238	permit
-13.107.246.51	permit
+13.107.253.40	permit
 13.110.208.0/21	permit
 13.110.209.0/24	permit
 13.110.216.0/22	permit
@@ -120,7 +120,6 @@
 27.123.206.56/29	permit
 27.123.206.76/30	permit
 27.123.206.80/28	permit
-31.25.48.222	permit
 31.47.251.17	permit
 31.186.239.0/24	permit
 34.2.64.0/22	permit
@@ -156,6 +155,7 @@
 34.218.115.239	permit
 34.218.116.3	permit
 34.225.212.172	permit
+34.241.242.183	permit
 35.83.148.184	permit
 35.155.198.111	permit
 35.158.23.94	permit
@@ -256,6 +256,7 @@
 50.112.246.219	permit
 52.1.14.157	permit
 52.5.230.59	permit
+52.6.74.205	permit
 52.12.53.23	permit
 52.13.214.179	permit
 52.26.1.71	permit
@@ -329,7 +330,6 @@
 62.13.144.0/21	permit
 62.13.152.0/21	permit
 62.17.146.128/26	permit
-62.179.121.0/24	permit
 62.201.172.0/27	permit
 62.201.172.32/27	permit
 62.253.227.114	permit
@@ -352,6 +352,7 @@
 64.127.115.252	permit
 64.132.88.0/23	permit
 64.132.92.0/24	permit
+64.181.194.190	permit
 64.207.219.7	permit
 64.207.219.8	permit
 64.207.219.9	permit
@@ -408,7 +409,6 @@
 65.154.166.0/24	permit
 65.212.180.36	permit
 66.102.0.0/20	permit
-66.102.0.0/21	permit
 66.119.150.192/26	permit
 66.163.184.0/24	permit
 66.163.185.0/24	permit
@@ -658,9 +658,6 @@
 82.165.159.45	permit
 82.165.159.130	permit
 82.165.159.131	permit
-84.116.6.0/23	permit
-84.116.36.0/24	permit
-84.116.50.0/23	permit
 85.158.136.0/21	permit
 86.61.88.25	permit
 87.238.80.0/21	permit
@@ -701,12 +698,13 @@
 87.248.117.205	permit
 87.253.232.0/21	permit
 89.22.108.0/24	permit
+91.198.2.0/24	permit
 91.211.240.0/22	permit
-94.169.2.0/23	permit
 94.236.119.0/26	permit
 94.245.112.0/27	permit
 94.245.112.10/31	permit
 95.131.104.0/21	permit
+95.217.114.154	permit
 96.43.144.0/20	permit
 96.43.144.64/28	permit
 96.43.144.64/31	permit
@@ -1344,7 +1342,7 @@
 108.174.6.215	permit
 108.175.18.45	permit
 108.175.30.45	permit
-108.177.8.0/21	permit
+108.177.8.0/22	permit
 108.177.96.0/19	permit
 108.179.144.0/20	permit
 109.237.142.0/24	permit
@@ -1429,6 +1427,8 @@
 132.226.26.225	permit
 132.226.49.32	permit
 132.226.56.24	permit
+134.128.64.0/19	permit
+134.128.96.0/19	permit
 134.170.27.8	permit
 134.170.113.0/26	permit
 134.170.141.64/26	permit
@@ -1618,10 +1618,14 @@
 168.245.127.231	permit
 169.148.129.0/24	permit
 169.148.131.0/24	permit
+169.148.138.0/24	permit
 169.148.142.10	permit
 169.148.144.0/25	permit
 169.148.144.10	permit
 169.148.146.0/23	permit
+169.148.174.33	permit
+169.148.175.3	permit
+169.148.188.0/24	permit
 169.148.188.182	permit
 170.10.128.0/24	permit
 170.10.129.0/24	permit
@@ -1662,6 +1666,8 @@
 182.50.78.64/28	permit
 183.240.219.64/29	permit
 185.4.120.0/22	permit
+185.11.253.128/27	permit
+185.11.255.0/24	permit
 185.12.80.0/22	permit
 185.28.196.0/22	permit
 185.58.84.93	permit
@@ -1672,6 +1678,8 @@
 185.138.56.128/25	permit
 185.189.236.0/22	permit
 185.211.120.0/22	permit
+185.233.188.0/23	permit
+185.233.190.0/23	permit
 185.250.236.0/22	permit
 185.250.239.148	permit
 185.250.239.168	permit
@@ -1746,6 +1754,9 @@
 193.109.254.0/23	permit
 193.122.128.100	permit
 193.123.56.63	permit
+193.142.157.0/24	permit
+193.142.157.191	permit
+193.142.157.198	permit
 194.19.134.0/25	permit
 194.64.234.129	permit
 194.97.196.0/24	permit
@@ -1865,6 +1876,8 @@
 204.92.114.187	permit
 204.92.114.203	permit
 204.92.114.204/31	permit
+204.141.32.0/23	permit
+204.141.42.0/23	permit
 204.216.164.202	permit
 204.220.160.0/21	permit
 204.220.168.0/21	permit
@@ -2039,7 +2052,8 @@
 212.227.126.225	permit
 212.227.126.226	permit
 212.227.126.227	permit
-213.46.255.0/24	permit
+213.95.19.64/27	permit
+213.95.135.4	permit
 213.199.128.139	permit
 213.199.128.145	permit
 213.199.138.181	permit

+ 7 - 6
data/web/inc/vars.inc.php

@@ -83,6 +83,7 @@ $DEFAULT_LANG = 'en-gb';
 // https://en.wikipedia.org/wiki/IETF_language_tag
 $AVAILABLE_LANGUAGES = array(
   // 'ca-es' => 'Català (Catalan)',
+  'bg-bg' => 'Български (Bulgarian)',
   'cs-cz' => 'Čeština (Czech)',
   'da-dk' => 'Danish (Dansk)',
   'de-de' => 'Deutsch (German)',
@@ -237,12 +238,12 @@ $FIDO2_FORMATS = array('apple', 'android-key', 'android-safetynet', 'fido-u2f',
 // Set visible Rspamd maps in mailcow UI, do not change unless you know what you are doing
 $RSPAMD_MAPS = array(
   'regex' => array(
-    'Header-From: Blacklist' => 'global_mime_from_blacklist.map',
-    'Header-From: Whitelist' => 'global_mime_from_whitelist.map',
-    'Envelope Sender Blacklist' => 'global_smtp_from_blacklist.map',
-    'Envelope Sender Whitelist' => 'global_smtp_from_whitelist.map',
-    'Recipient Blacklist' => 'global_rcpt_blacklist.map',
-    'Recipient Whitelist' => 'global_rcpt_whitelist.map',
+    'Header-From: Denylist' => 'global_mime_from_blacklist.map',
+    'Header-From: Allowlist' => 'global_mime_from_whitelist.map',
+    'Envelope Sender Denylist' => 'global_smtp_from_blacklist.map',
+    'Envelope Sender Allowlist' => 'global_smtp_from_whitelist.map',
+    'Recipient Denylist' => 'global_rcpt_blacklist.map',
+    'Recipient Allowlist' => 'global_rcpt_whitelist.map',
     'Fishy TLDS (only fired in combination with bad words)' => 'fishy_tlds.map',
     'Bad Words (only fired in combination with fishy TLDs)' => 'bad_words.map',
     'Bad Words DE (only fired in combination with fishy TLDs)' => 'bad_words_de.map',

+ 1391 - 1
data/web/lang/lang.bg-bg.json

@@ -1 +1,1391 @@
-{}
+{
+    "acl": {
+        "alias_domains": "Добавяне на домейни за псевдоними",
+        "app_passwds": "Управление на пароли за приложения",
+        "bcc_maps": "BCC карти",
+        "delimiter_action": "Действие на разделител",
+        "domain_desc": "Промяна на описанието на домейна",
+        "domain_relayhost": "Промяна на релеен хост за домейн",
+        "eas_reset": "Нулиране на устройствата с ActiveSync",
+        "extend_sender_acl": "Разрешаване на разширяване на ACL на изпращащите от външни адреси",
+        "filters": "Филтри",
+        "login_as": "Вход като потребител на пощенска кутия",
+        "mailbox_relayhost": "Промяна на релеен хост за пощенска кутия",
+        "prohibited": "Забранено от ACL",
+        "protocol_access": "Промяна на достъпа до протоколи",
+        "pushover": "Pushover",
+        "pw_reset": "Разрешаване на нулиране на паролата на потребител на mailcow",
+        "quarantine": "Действия с карантина",
+        "quarantine_attachments": "Прикачени файлове в карантина",
+        "quarantine_category": "Промяна на категорията на уведомленията за карантина",
+        "quarantine_notification": "Промяна на уведомленията за карантина",
+        "ratelimit": "Ограничение на скоростта",
+        "recipient_maps": "Карти на получатели",
+        "smtp_ip_access": "Промяна на разрешените хостове за SMTP",
+        "sogo_access": "Разрешаване на управление на достъпа до SOGo",
+        "sogo_profile_reset": "Нулиране на профила на SOGo",
+        "spam_alias": "Временни псевдоними",
+        "spam_policy": "Черен/Бял списък",
+        "spam_score": "Резултат за спам",
+        "syncjobs": "Синхронизиращи задачи",
+        "tls_policy": "Политика за TLS",
+        "unlimited_quota": "Неограничена квота за пощенски кутии"
+    },
+    "add": {
+        "activate_filter_warn": "Всички други филтри ще бъдат деактивирани, когато активното е отбелязано.",
+        "active": "Активен",
+        "add": "Добавяне",
+        "add_domain_only": "Добавяне само на домейн",
+        "add_domain_restart": "Добавяне на домейн и рестартиране на SOGo",
+        "alias_address": "Адрес/и за псевдоним",
+        "alias_address_info": "<small>Пълни имейл адреси или @example.com, за да хванете всички съобщения за домейн (разделени с запетая). <b>само домейни на mailcow</b>.</small>",
+        "alias_domain": "Домейн за псевдоним",
+        "alias_domain_info": "<small>Валидни имена на домейни (разделени с запетая).</small>",
+        "app_name": "Име на приложението",
+        "app_password": "Добавяне на парола за приложение",
+        "app_passwd_protocols": "Разрешени протоколи за паролата на приложението",
+        "automap": "Опит за автоматично картографиране на папки (\"Изпратени\", \"Изпратени\" => \"Изпратени\" и т.н.)",
+        "backup_mx_options": "Опции за реле",
+        "bcc_dest_format": "BCC дестинацията трябва да бъде един валиден имейл адрес.<br>Ако имате нужда да изпратите копие до множество адреси, създайте псевдоним и го използвайте тук.",
+        "comment_info": "Частен коментар не е видим за потребителя, докато публичен коментар се показва като подсказка при преминаване с мишката върху него в прегледа на потребителя",
+        "custom_params": "Персонализирани параметри",
+        "custom_params_hint": "Дясно: --param=xy, грешно: --param xy",
+        "delete1": "Изтриване от източника след завършване",
+        "delete2": "Изтриване на съобщенията в дестинацията, които не са в източника",
+        "delete2duplicates": "Изтриване на дубликати в дестинацията",
+        "description": "Описание",
+        "destination": "Дестинация",
+        "disable_login": "Забраняване на вход (входящите съобщения все още се приемат)",
+        "domain": "Домейн",
+        "domain_matches_hostname": "Домейнът %s съвпада с името на хоста",
+        "domain_quota_m": "Обща квота на домейна (MiB)",
+        "dry": "Симулиране на синхронизация",
+        "enc_method": "Метод на криптиране",
+        "exclude": "Изключване на обекти (regex)",
+        "full_name": "Пълно име",
+        "gal": "Глобален адресен списък",
+        "gal_info": "Глобалният адресен списък съдържа всички обекти на домейна и не може да бъде редактиран от нито един потребител. Липсва информация за заетост/свободно време в SOGo, ако е деактивирано! <b>Рестартирайте SOGo, за да приложите промените.</b>",
+        "generate": "генериране",
+        "goto_ham": "Учен като <span class=\"text-success\"><b>не е спам</b></span>",
+        "goto_null": "Тихо изхвърляне на имейла",
+        "goto_spam": "Учен като <span class=\"text-danger\"><b>спам</b></span>",
+        "hostname": "Хост",
+        "inactive": "Неактивен",
+        "kind": "Вид",
+        "mailbox_quota_def": "Квота по подразбиране за пощенска кутия",
+        "mailbox_quota_m": "Макс. квота за пощенска кутия (MiB)",
+        "mailbox_username": "Потребителско име (лява част на имейл адрес)",
+        "max_aliases": "Макс. възможни псевдоними",
+        "max_mailboxes": "Макс. възможни пощенски кутии",
+        "mins_interval": "Интервал за проверка (минути)",
+        "multiple_bookings": "Множествени резервации",
+        "nexthop": "Следващ хоп",
+        "password": "Парола",
+        "password_repeat": "Потвърждаване на паролата (повторете)",
+        "port": "Порт",
+        "post_domain_add": "След добавянето на нов домейн, контейнерът на SOGo, \"sogo-mailcow\", трябва да бъде рестартиран!<br><br>Освен това, конфигурацията на DNS на домейна трябва да бъде прегледана. След като конфигурацията на DNS бъде одобрена, рестартирайте \"acme-mailcow\", за да генерирате автоматично сертификати за вашия нов домейн (autoconfig.&lt;domain&gt;, autodiscover.&lt;domain&gt;).<br>Тази стъпка е опционална и ще бъде повторена всеки 24 часа.",
+        "private_comment": "Частен коментар",
+        "public_comment": "Публичен коментар",
+        "quota_mb": "Квота (MiB)",
+        "relay_all": "Реле на всички получатели",
+        "relay_all_info": "↪ Ако изберете да <b>не</b> релеирате всички получатели, ще трябва да добавите (\"скрита\") пощенска кутия за всеки отделен получател, който трябва да бъде релеиран.",
+        "relay_domain": "Реле на този домейн",
+        "relay_transport_info": "<div class=\"badge fs-6 bg-info\">Инфо</div> Можете да дефинирате транспортни карти за персонализирана дестинация за този домейн. Ако не е зададено, ще бъде направен MX lookup.",
+        "relay_unknown_only": "Реле на несъществуващи пощенски кутии. Съществуващите пощенски кутии ще бъдат доставени локално.",
+        "relayhost_wrapped_tls_info": "Моля, <b>не</b> използвайте TLS-wrapped портове (най-често използвани на порт 465).<br>\r\nИзползвайте всеки не-wrapped порт и издайте STARTTLS. Политика за TLS може да бъде създадена в \"TLS политики\", за да се наложи TLS.",
+        "select": "Моля, изберете...",
+        "select_domain": "Моля, изберете първо домейн",
+        "sieve_desc": "Кратко описание",
+        "sieve_type": "Тип на филтър",
+        "skipcrossduplicates": "Пропускане на дублирани съобщения между папки (първи дошъл, първи обслужен)",
+        "subscribeall": "Абониране за всички папки",
+        "syncjob": "Добавяне на синхронизираща задача",
+        "syncjob_hint": "Имайте предвид, че паролите трябва да бъдат запазени като обикновен текст!",
+        "tags": "Тагове",
+        "target_address": "Адреси за пренасочване",
+        "target_address_info": "<small>Пълни имейл адреси (разделени с запетая).</small>",
+        "target_domain": "Целеви домейн",
+        "timeout1": "Таймаут за връзка с отдалечен хост",
+        "timeout2": "Таймаут за връзка с локален хост",
+        "username": "Потребителско име",
+        "validate": "Валидиране",
+        "validation_success": "Успешно валидиране"
+    },
+    "admin": {
+        "access": "Достъп",
+        "action": "Действие",
+        "activate_api": "Активиране на API",
+        "activate_send": "Активиране на бутона за изпращане",
+        "active": "Активен",
+        "active_rspamd_settings_map": "Активна карта с настройки",
+        "add": "Добавяне",
+        "add_admin": "Добавяне на администратор",
+        "add_domain_admin": "Добавяне на администратор на домейн",
+        "add_forwarding_host": "Добавяне на хост за препращане",
+        "add_relayhost": "Добавяне на транспорт, зависим от изпращач",
+        "add_relayhost_hint": "Имайте предвид, че данните за удостоверяване, ако има такива, ще бъдат запазени като обикновен текст.",
+        "add_row": "Добавяне на ред",
+        "add_settings_rule": "Добавяне на правило за настройки",
+        "add_transport": "Добавяне на транспорт",
+        "add_transports_hint": "Имайте предвид, че данните за удостоверяване, ако има такива, ще бъдат запазени като обикновен текст.",
+        "additional_rows": "добавени допълнителни редове",
+        "admin": "Администратор",
+        "admin_details": "Редактиране на детайлите на администратора",
+        "admin_domains": "Назначения на домейни",
+        "admins": "Администратори",
+        "admins_ldap": "LDAP администратори",
+        "advanced_settings": "Разширени настройки",
+        "allowed_methods": "Access-Control-Allow-Methods",
+        "allowed_origins": "Access-Control-Allow-Origin",
+        "api_allow_from": "Разрешаване на API достъп от тези IP адреси/CIDR мрежови нотации",
+        "api_info": "API е в процес на разработка. Документацията може да бъде намерена на <a href=\"/api\">/api</a>",
+        "api_key": "API ключ",
+        "api_read_only": "Достъп само за четене",
+        "api_read_write": "Достъп за четене и писане",
+        "api_skip_ip_check": "Пропускане на IP проверка за API",
+        "app_hide": "Скриване за вход",
+        "app_links": "Връзки към приложения",
+        "app_name": "Име на приложението",
+        "apps_name": "Име на \"mailcow приложенията\"",
+        "arrival_time": "Време на пристигане (време на сървъра)",
+        "authed_user": "Удостоверен потребител",
+        "ays": "Сигурни ли сте, че искате да продължите?",
+        "ban_list_info": "Вижте списък с блокирани IP адреси по-долу: <b>мрежа (оставащо време за блокиране) - [действия]</b>.<br />IP адресите в опашката за разблокиране ще бъдат премахнати от активния списък с блокирани в рамките на няколко секунди.<br />Червените етикети показват активни постоянни блокирания от черния списък.",
+        "change_logo": "Промяна на логото",
+        "logo_normal_label": "Нормално",
+        "logo_dark_label": "Обърнато за тъмен режим",
+        "configuration": "Конфигурация",
+        "convert_html_to_text": "Конвертиране на HTML в обикновен текст",
+        "copy_to_clipboard": "Текстът е копиран в клипборда!",
+        "cors_settings": "Настройки на CORS",
+        "credentials_transport_warning": "<b>Внимание</b>: Добавянето на нов запис в картата на транспорта ще обнови данните за удостоверяване за всички записи с съвпадаща колона за следващ хоп.",
+        "customer_id": "Идентификатор на клиента",
+        "customize": "Персонализиране",
+        "destination": "Дестинация",
+        "dkim_add_key": "Добавяне на ARC/DKIM ключ",
+        "dkim_domains_selector": "Селектор",
+        "dkim_domains_wo_keys": "Избор на домейни без ключове",
+        "dkim_from": "От",
+        "dkim_from_title": "Източник на домейн за копиране на данни",
+        "dkim_key_length": "Дължина на DKIM ключа (битове)",
+        "dkim_key_missing": "Липсващ ключ",
+        "dkim_key_unused": "Неизползван ключ",
+        "dkim_key_valid": "Валиден ключ",
+        "dkim_keys": "ARC/DKIM ключове",
+        "dkim_overwrite_key": "Презаписване на съществуващ DKIM ключ",
+        "dkim_private_key": "Частен ключ",
+        "dkim_to": "До",
+        "dkim_to_title": "Целеви домейн/и - ще бъде презаписан",
+        "domain": "Домейн",
+        "domain_admin": "Администратор на домейн",
+        "domain_admins": "Администратори на домейн",
+        "domain_s": "Домейн/и",
+        "duplicate": "Дублиране",
+        "duplicate_dkim": "Дублиране на DKIM запис",
+        "edit": "Редактиране",
+        "empty": "Няма резултати",
+        "excludes": "Изключване на тези получатели",
+        "f2b_ban_time": "Време за блокиране (с)",
+        "f2b_ban_time_increment": "Времето за блокиране се увеличава с всяко блокиране",
+        "f2b_blacklist": "Черни списъци/хостове",
+        "f2b_filter": "Филтри с регулярни изрази",
+        "f2b_list_info": "Черният списък на хостове или мрежи винаги ще надделява над белия списък. <b>Актуализациите на списъка отнемат няколко секунди, за да бъдат приложени.</b>",
+        "f2b_manage_external": "Управление на Fail2Ban външно",
+        "f2b_manage_external_info": "Fail2ban все още ще поддържа черния списък, но няма да задава правила за блокиране на трафика. Използвайте генерирания черн списък по-долу, за да блокирате трафика външно.",
+        "f2b_max_attempts": "Макс. опити",
+        "f2b_max_ban_time": "Макс. време за блокиране (с)",
+        "f2b_netban_ipv4": "IPv4 размер на подмрежа за прилагане на блокиране (8-32)",
+        "f2b_netban_ipv6": "IPv6 размер на подмрежа за прилагане на блокиране (8-128)",
+        "f2b_parameters": "Параметри на Fail2ban",
+        "f2b_regex_info": "Логовете, които се вземат предвид: SOGo, Postfix, Dovecot, PHP-FPM.",
+        "f2b_retry_window": "Прозорец за повторен опит (с) за макс. опити",
+        "f2b_whitelist": "Бели списъци/хостове",
+        "filter": "Филтър",
+        "filter_table": "Таблица с филтри",
+        "forwarding_hosts": "Хостове за препращане",
+        "forwarding_hosts_add_hint": "Можете да посочите IPv4/IPv6 адреси, мрежи в CIDR нотация, имена на хостове (които ще бъдат разрешени в IP адреси), или имена на домейни (които ще бъдат разрешени в IP адреси чрез заявки към SPF записи или, при липсата им, MX записи).",
+        "forwarding_hosts_hint": "Входящите съобщения се приемат безрезервно от всички хостове, изброени тук. Тези хостове след това не се проверяват срещу DNSBL или подлагат на сиво списък. Спамът, получен от тях, никога не се отхвърля, но опционално може да бъде поставен във файла за нежелана поща. Най-често използваната употреба за това е да се посочат пощенски сървъри, на които сте настроили правило, което препраща входящите имейли към вашия mailcow сървър.",
+        "from": "От",
+        "generate": "генериране",
+        "guid": "GUID - уникален инстанционен идентификатор",
+        "guid_and_license": "GUID & Лиценз",
+        "hash_remove_info": "Премахването на хеш за ограничение на скоростта (ако все още съществува) ще нулира неговия брояч напълно.<br>\r\nВсеки хеш е показан с индивидуален цвят.",
+        "help_text": "Презаписване на помощния текст под маската за вход (разрешен е HTML)",
+        "host": "Хост",
+        "html": "HTML",
+        "iam": "Доставчик на идентичност",
+        "iam_attribute_field": "Поле за атрибут",
+        "iam_authorize_url": "Крайна точка за удостоверяване",
+        "iam_auth_flow": "Поток за удостоверяване",
+        "iam_auth_flow_info": "Освен стандартния поток за удостоверяване (поток с код за удостоверяване в Keycloak), който се използва за единичен вход, mailcow поддържа и поток за удостоверяване с пряки удостоверения. Потокът за удостоверяване с пароли за поща проверява удостоверенията на потребителя, като използва Keycloak Admin REST API. mailcow извлича хешираната парола от атрибута <code>mailcow_password</code>, който е картиран в Keycloak.",
+        "iam_basedn": "Основен DN",
+        "iam_client_id": "Идентификатор на клиента",
+        "iam_client_secret": "Тайна на клиента",
+        "iam_client_scopes": "Обхват на клиента",
+        "iam_default_template": "Шаблон по подразбиране",
+        "iam_default_template_description": "Ако няма зададен шаблон за потребител, шаблонът по подразбиране ще бъде използван за създаване на пощенската кутия, но не и за актуализиране на пощенската кутия.",
+        "iam_description": "Конфигуриране на външен доставчик за удостоверяване<br>Потребителските пощенски кутии ще бъдат създавани автоматично при първия им вход, при условие че е зададено картиране на атрибути.",
+        "iam_extra_permission": "За да работят следните настройки, клиентът на mailcow в Keycloak трябва да има <code>услуга акаунт</code> и разрешението да <code>вижда потребители</code>.",
+        "iam_host": "Хост",
+        "iam_host_info": "Въведете един или повече LDAP хостове, разделени с запетаи.",
+        "iam_import_users": "Импортиране на потребители",
+        "iam_mapping": "Картиране на атрибути",
+        "iam_bindpass": "Парола за свързване",
+        "iam_periodic_full_sync": "Периодичен пълен синхрон",
+        "iam_port": "Порт",
+        "iam_realm": "Реалм",
+        "iam_redirect_url": "URL за пренасочване",
+        "iam_rest_flow": "Поток за пароли за поща",
+        "iam_server_url": "URL на сървъра",
+        "iam_sso": "Единичен вход",
+        "iam_sync_interval": "Интервал за синхронизиране/импортиране (мин)",
+        "iam_test_connection": "Тест на връзката",
+        "iam_token_url": "Крайна точка за токени",
+        "iam_userinfo_url": "Крайна точка за информация за потребителя",
+        "iam_username_field": "Поле за потребителско име",
+        "iam_binddn": "DN за свързване",
+        "iam_use_ssl": "Използване на SSL",
+        "iam_use_ssl_info": "Ако активирате SSL и портът е зададен на 389, той ще бъде автоматично променен на 636.",
+        "iam_use_tls": "Използване на StartTLS",
+        "iam_use_tls_info": "Ако активирате TLS, трябва да използвате стандартния порт за вашия LDAP сървър (389). SSL портовете не могат да бъдат използвани.",
+        "iam_version": "Версия",
+        "ignore_ssl_error": "Игнориране на SSL грешки",
+        "import": "Импортиране",
+        "import_private_key": "Импортиране на частен ключ",
+        "in_use_by": "Използван от",
+        "inactive": "Неактивен",
+        "include_exclude": "Включване/Изключване",
+        "include_exclude_info": "По подразбиране - без избор - <b>всички пощенски кутии</b> се адресират",
+        "includes": "Включване на тези получатели",
+        "ip_check": "Проверка на IP",
+        "ip_check_disabled": "Проверката на IP е деактивирана. Можете да я активирате в <br> <strong>Система > Конфигурация > Опции > Персонализиране</strong>",
+        "ip_check_opt_in": "Оптиране за използване на услугата на трета страна <strong>ipv4.mailcow.email</strong> и <strong>ipv6.mailcow.email</strong>, за да разрешавате външни IP адреси.",
+        "is_mx_based": "MX базиран",
+        "last_applied": "Последно приложено",
+        "license_info": "Лицензът не е задължителен, но помага за по-нататъшното развитие.<br><a href=\"https://www.servercow.de/mailcow?lang=en#sal\" target=\"_blank\" alt=\"SAL поръчка\">Регистрирайте вашия GUID тук</a> или <a href=\"https://www.servercow.de/mailcow?lang=en#support\" target=\"_blank\" alt=\"Поддръжка поръчка\">купете поддръжка за вашата инсталация на mailcow.</a>",
+        "link": "Връзка",
+        "loading": "Моля, изчакайте...",
+        "login_time": "Време за вход",
+        "logo_info": "Вашето изображение ще бъде мащабирано до височина 40 px за горната навигационна лента и макс. ширина 250 px за началната страница. Препоръчва се използването на скалируема графика.",
+        "lookup_mx": "Дестинацията е регулярен израз за съвпадение с MX име (<code>.*\\.google\\.com</code> за пренасочване на всички съобщения, предназначени за MX, завършващ на google.com, през този хоп)",
+        "main_name": "Име на \"mailcow UI\"",
+        "merged_vars_hint": "Редовете в сиво са сляти от <code>vars.(local.)inc.php</code> и не могат да бъдат променени.",
+        "message": "Съобщение",
+        "message_size": "Размер на съобщението",
+        "nexthop": "Следващ хоп",
+        "no": "&#10005;",
+        "no_active_bans": "Няма активни блокирания",
+        "no_new_rows": "Няма допълнителни редове",
+        "no_record": "Няма запис",
+        "oauth2_apps": "OAuth2 приложения",
+        "oauth2_add_client": "Добавяне на OAuth2 клиент",
+        "oauth2_client_id": "Идентификатор на клиента",
+        "oauth2_client_secret": "Тайна на клиента",
+        "oauth2_info": "Реализацията на OAuth2 поддържа типа разрешение \"Код за удостоверяване\" и издава токени за презареждане.<br>\r\nСървърът автоматично издава нови токени за презареждане, след като токен за презареждане е бил използван.<br><br>\r\n&#8226; Обхватът по подразбиране е <i>профил</i>. Само потребителите на пощенски кутии могат да бъдат удостоверени срещу OAuth2. Ако параметърът за обхват е пропуснат, той се връща към <i>профил</i>.<br>\r\n&#8226; Параметърът <i>state</i> трябва да бъде изпратен от клиента като част от заявката за удостоверяване.<br><br>\r\nПътища за заявки към OAuth2 API: <br>\r\n<ul>\r\n  <li>Крайна точка за удостоверяване: <code>/oauth/authorize</code></li>\r\n  <li>Крайна точка за токени: <code>/oauth/token</code></li>\r\n  <li>Страница с ресурси:  <code>/oauth/profile</code></li>\r\n</ul>\r\nГенерирането на нова тайна на клиента няма да анулира съществуващите кодове за удостоверяване, но те няма да могат да подновят своя токен.<br><br>\r\nАнулирането на токените на клиента ще доведе до незабавно прекратяване на всички активни сесии. Всички клиенти ще трябва да се преудостоверят.",
+        "oauth2_redirect_uri": "URI за пренасочване",
+        "oauth2_renew_secret": "Генериране на нова тайна на клиента",
+        "oauth2_revoke_tokens": "Анулиране на всички токени на клиента",
+        "optional": "опционално",
+        "options": "Опции",
+        "password": "Парола",
+        "password_length": "Дължина на паролата",
+        "password_policy": "Политика за пароли",
+        "password_policy_chars": "Трябва да съдържа поне една буквена буква",
+        "password_policy_length": "Минималната дължина на паролата е %d",
+        "password_policy_lowerupper": "Трябва да съдържа малки и главни букви",
+        "password_policy_numbers": "Трябва да съдържа поне една цифра",
+        "password_policy_special_chars": "Трябва да съдържа специални символи",
+        "password_repeat": "Потвърждаване на паролата (повторете)",
+        "password_reset_info": "Ако не е зададен имейл за възстановяване, тази функция не може да бъде използвана.",
+        "password_reset_settings": "Настройки за възстановяване на парола",
+        "password_reset_tmpl_html": "HTML шаблон",
+        "password_reset_tmpl_text": "Текстов шаблон",
+        "password_settings": "Настройки на паролата",
+        "priority": "Приоритет",
+        "private_key": "Частен ключ",
+        "quarantine": "Карантина",
+        "quarantine_bcc": "Изпращане на копие от всички уведомления (BCC) до този получател:<br><small>Оставете празно, за да деактивирате. <b>Неподписано, непроверено имейл. Трябва да бъде доставено само вътрешно.</b></small>",
+        "quarantine_exclude_domains": "Изключване на домейни и домейни на псевдоними",
+        "quarantine_max_age": "Максимална възраст в дни<br><small>Стойността трябва да бъде равна или по-голяма от 1 ден.</small>",
+        "quarantine_max_score": "Изхвърляне на уведомление, ако резултатът за спам на имейла е по-висок от тази стойност:<br><small>По подразбиране е 9999.0</small>",
+        "quarantine_max_size": "Максимален размер в MiB (по-големи елементи се изхвърлят):<br><small>0 не означава неограничен.</small>",
+        "quarantine_notification_html": "Шаблон на имейл за уведомление:<br><small>Оставете празно, за да възстановите шаблона по подразбиране.</small>",
+        "quarantine_notification_sender": "Изпращач на имейл за уведомление",
+        "quarantine_notification_subject": "Тема на имейл за уведомление",
+        "quarantine_redirect": "<b>Пренасочване на всички уведомления</b> към този получател:<br><small>Оставете празно, за да деактивирате. <b>Неподписано, непроверено имейл. Трябва да бъде доставено само вътрешно.</b></small>",
+        "quarantine_release_format": "Формат на освободените елементи",
+        "quarantine_release_format_att": "Като прикачен файл",
+        "quarantine_release_format_raw": "Непроменен оригинал",
+        "quarantine_retention_size": "Задържания за пощенска кутия:<br><small>0 показва <b>неактивен</b>.</small>",
+        "quota_notification_html": "Шаблон на имейл за уведомление:<br><small>Оставете празно, за да възстановите шаблона по подразбиране.</small>",
+        "quota_notification_sender": "Изпращач на имейл за уведомление",
+        "quota_notification_subject": "Тема на имейл за уведомление",
+        "quota_notifications": "Уведомления за квота",
+        "quota_notifications_info": "Уведомленията за квота се изпращат на потребителите веднъж при преминаване на 80% и веднъж при преминаване на 95% използване.",
+        "quota_notifications_vars": "{{percent}} е равно на текущата квота на потребителя<br>{{username}} е името на пощенската кутия",
+        "queue_unban": "разблокиране",
+        "r_active": "Активни ограничения",
+        "r_inactive": "Неактивни ограничения",
+        "r_info": "Елементите в сиво в списъка с активни ограничения не са известни като валидни ограничения за mailcow и не могат да бъдат преместени. Неизвестните ограничения ще бъдат зададени в реда на появяване все пак.<br>Можете да добавяте нови елементи в <code>inc/vars.local.inc.php</code>, за да можете да ги превключвате.",
+        "rate_name": "Име на ограничението",
+        "recipients": "Получатели",
+        "refresh": "Опресняване",
+        "regen_api_key": "Регенериране на API ключ",
+        "regex_maps": "Карти с регулярни изрази",
+        "relay_from": "Адрес \"From:\"",
+        "relay_rcpt": "Адрес \"To:\"",
+        "relay_run": "Изпълнение на тест",
+        "relayhosts": "Транспорти, зависими от изпращач",
+        "relayhosts_hint": "Дефинирайте транспорти, зависими от изпращач, за да можете да ги избирате в диалоговия прозорец за конфигурация на домейн.<br>\r\n  Услугата за транспорт винаги е \"smtp:\" и ще се опита да използва TLS, ако бъде предложена. Wrapped TLS (SMTPS) не се поддържа. Политиката за TLS на потребителя ще бъде взета предвид.<br>\r\n  Засегнатите домейни, включително домейни на псевдоними.",
+        "remove": "Премахване",
+        "remove_row": "Премахване на ред",
+        "reset_default": "Нулиране до подразбиране",
+        "reset_limit": "Премахване на хеш",
+        "reset_password_vars": "<code>{{link}}</code> Генерираната връзка за нулиране на парола<br><code>{{username}}</code> Името на пощенската кутия на потребителя, който е поискал нулиране на парола<br><code>{{username2}}</code> Името на пощенската кутия за възстановяване<br><code>{{date}}</code> Датата на заявката за нулиране на парола<br><code>{{token_lifetime}}</code> Времетраенето на токена в минути<br><code>{{hostname}}</code> Името на хоста на mailcow",
+        "restore_template": "Оставете празно, за да възстановите шаблона по подразбиране.",
+        "routing": "Маршрутизация",
+        "rsetting_add_rule": "Добавяне на правило",
+        "rsetting_content": "Съдържание на правилото",
+        "rsetting_desc": "Кратко описание",
+        "rsetting_no_selection": "Моля, изберете правило",
+        "rsetting_none": "Няма налични правила",
+        "rsettings_insert_preset": "Вмъкване на примерен предефиниран набор \"%s\"",
+        "rsettings_preset_1": "Деактивиране на всичко, освен DKIM и ограничение на скоростта за удостоверени потребители",
+        "rsettings_preset_2": "Пощенските администратори искат спам",
+        "rsettings_preset_3": "Разрешаване само на определени изпращачи за пощенска кутия (напр. използване като вътрешна пощенска кутия)",
+        "rsettings_preset_4": "Деактивиране на Rspamd за домейн",
+        "rspamd_com_settings": "Името на настройката ще бъде автоматично генерирано, моля, вижте примерните предефинирани набори по-долу. За повече детайли вижте <a href=\"https://rspamd.com/doc/configuration/settings.html#settings-structure\" target=\"_blank\">документацията на Rspamd</a>",
+        "rspamd_global_filters": "Глобални карти на филтри",
+        "rspamd_global_filters_agree": "Ще бъда внимателен!",
+        "rspamd_global_filters_info": "Глобалните карти на филтри съдържат различни видове глобални черни и бели списъци.",
+        "rspamd_global_filters_regex": "Имената им обясняват тяхната цел. Всичкото съдържание трябва да съдържа валиден регулярен израз във формат \"/pattern/options\" (напр. <code>/.+@domain\\.tld/i</code>).<br>\r\n  Въпреки че се извършват основни проверки за всеки ред с регулярен израз, функционалността на Rspamd може да бъде нарушена, ако не успява да прочете синтаксиса коректно.<br>\r\n  Rspamd ще се опита да прочете съдържанието на картата при промяна. Ако срещнете проблеми, <a href=\"\" data-toggle=\"modal\" data-container=\"rspamd-mailcow\" data-target=\"#RestartContainer\">рестартирайте Rspamd</a>, за да наложите презареждане на картата.<br>Елементите в черния списък са изключени от карантина.",
+        "rspamd_settings_map": "Карта с настройки на Rspamd",
+        "sal_level": "Ниво на Moo",
+        "save": "Запазване на промените",
+        "search_domain_da": "Търсене на домейни",
+        "send": "Изпращане",
+        "sender": "Изпращач",
+        "service": "Услуга",
+        "service_id": "Идентификатор на услугата",
+        "source": "Източник",
+        "spamfilter": "Филтър за спам",
+        "subject": "Тема",
+        "success": "Успех",
+        "sys_mails": "Системни имейли",
+        "task": "Задача",
+        "text": "Текст",
+        "time": "Време",
+        "title": "Заглавие",
+        "title_name": "Име на уеб страницата на \"mailcow UI\"",
+        "to_top": "Обратно нагоре",
+        "transport_dest_format": "Регулярен израз или синтаксис: example.org, .example.org, *, box@example.org (няколко стойности могат да бъдат разделени с запетая)",
+        "transport_maps": "Карти за транспорт",
+        "transport_test_rcpt_info": "&#8226; Използвайте null@hosted.mailcow.de, за да тествате препращането към чуждестранна дестинация.",
+        "transports_hint": "&#8226; Записът в картата на транспорта <b>пренарежда</b> запис в картата на транспорт, зависим от изпращач</b>.<br>\r\n&#8226; Транспортите, базирани на MX, се използват предимно.<br>\r\n&#8226; Настройките за политика на TLS на потребителя се игнорират и могат да бъдат приложени само чрез записи в картите на политиката на TLS.<br>\r\n&#8226; Услугата за транспорт за дефинираните транспорти винаги е \"smtp:\" и ще се опита да използва TLS, ако бъде предложена. Wrapped TLS (SMTPS) не се поддържа.<br>\r\n&#8226; Адресите, съвпадащи с \"/localhost$/\", винаги ще бъдат транспортирани през \"local:\", следователно записът \"*\" няма да се приложи към тези адреси.<br>\r\n&#8226; За да определите удостоверения за следващ хоп \"[host]:25\", Postfix <b>винаги</b> заявява за \"host\", преди да търси за \"[host]:25\". Това поведение прави невъзможно да се използват \"host\" и \"[host]:25\" едновременно.",
+        "ui_footer": "Подвал (разрешен е HTML)",
+        "ui_header_announcement": "Обяви",
+        "ui_header_announcement_active": "Задаване на активна обява",
+        "ui_header_announcement_content": "Текст (разрешен е HTML)",
+        "ui_header_announcement_help": "Обявата е видима за всички влезли потребители и на екрана за вход на UI.",
+        "ui_header_announcement_select": "Избор на тип обява",
+        "ui_header_announcement_type": "Тип",
+        "ui_header_announcement_type_danger": "Много важно",
+        "ui_header_announcement_type_info": "Информация",
+        "ui_header_announcement_type_warning": "Важно",
+        "ui_texts": "Етикети и текстове на UI",
+        "unban_pending": "разблокиране в опашката",
+        "unchanged_if_empty": "Ако не е променено, оставете празно",
+        "upload": "Качване",
+        "username": "Потребителско име",
+        "user_link": "Връзка към потребител",
+        "validate_license_now": "Валидиране на GUID срещу лицензен сървър",
+        "verify": "Проверка",
+        "yes": "&#10003;"
+    },
+    "danger": {
+        "access_denied": "Достъпът е отказан или данните от формуляра са невалидни",
+        "alias_domain_invalid": "Домейнът на псевдонима %s е невалиден",
+        "alias_empty": "Адресът на псевдонима не трябва да е празен",
+        "alias_goto_identical": "Адресът на псевдонима и адресът за пренасочване не трябва да са идентични",
+        "alias_invalid": "Адресът на псевдонима %s е невалиден",
+        "aliasd_targetd_identical": "Домейнът на псевдонима не трябва да е равен на целевия домейн: %s",
+        "aliases_in_use": "Макс. псевдоними трябва да бъдат по-големи или равни на %d",
+        "app_name_empty": "Името на приложението не може да бъде празно",
+        "app_passwd_id_invalid": "Идентификаторът на паролата за приложението %s е невалиден",
+        "authsource_in_use": "Доставчикът на идентичност не може да бъде променен или изтрит, тъй като се използва в момента от един или повече потребители.",
+        "bcc_empty": "BCC дестинацията не може да бъде празна",
+        "bcc_exists": "Картата BCC %s съществува за тип %s",
+        "bcc_must_be_email": "BCC дестинацията %s не е валиден имейл адрес",
+        "comment_too_long": "Коментарът е твърде дълъг, разрешени са макс. 160 символа",
+        "cors_invalid_method": "Зададен е невалиден метод за разрешаване",
+        "cors_invalid_origin": "Зададен е невалиден източник за разрешаване",
+        "defquota_empty": "Квотата по подразбиране за пощенска кутия не трябва да бъде 0.",
+        "demo_mode_enabled": "Режимът на демонстрация е активиран",
+        "description_invalid": "Описанието на ресурса за %s е невалидно",
+        "dkim_domain_or_sel_exists": "Съществува DKIM ключ за \"%s\", който няма да бъде презаписан",
+        "dkim_domain_or_sel_invalid": "DKIM домейн или селектор е невалиден: %s",
+        "domain_cannot_match_hostname": "Домейнът не може да съвпада с името на хоста",
+        "domain_exists": "Домейнът %s вече съществува",
+        "domain_invalid": "Името на домейна е празно или невалидно",
+        "domain_not_empty": "Не може да бъде премахнат непразен домейн %s",
+        "domain_not_found": "Домейнът %s не е намерен",
+        "domain_quota_m_in_use": "Квотата на домейна трябва да бъде по-голяма или равна на %s MiB",
+        "extended_sender_acl_denied": "липсва ACL за задаване на външни адреси на изпращач",
+        "extra_acl_invalid": "Външният адрес на изпращач \"%s\" е невалиден",
+        "extra_acl_invalid_domain": "Външният изпращач \"%s\" използва невалиден домейн",
+        "fido2_verification_failed": "Проверката на FIDO2 е неуспешна: %s",
+        "file_open_error": "Файлът не може да бъде отворен за писане",
+        "filter_type": "Грешен тип на филтър",
+        "from_invalid": "Изпращачът не трябва да бъде празен",
+        "generic_server_error": "Възникна неочаквана грешка на сървъра. Моля, свържете се с вашия администратор.",
+        "global_filter_write_error": "Файлът с филтър не може да бъде записан: %s",
+        "global_map_invalid": "Идентификаторът на глобалната карта %s е невалиден",
+        "global_map_write_error": "Глобалният идентификатор на картата %s не може да бъде записан: %s",
+        "goto_empty": "Адресът на псевдоним трябва да съдържа поне един валиден адрес за пренасочване",
+        "goto_invalid": "Адресът за пренасочване %s е невалиден",
+        "ham_learn_error": "Грешка при обучение за не-спам: %s",
+        "iam_test_connection": "Връзката е неуспешна",
+        "imagick_exception": "Грешка: Грешка при четене на изображение с Imagick",
+        "img_dimensions_exceeded": "Изображението надхвърля максималния размер",
+        "img_invalid": "Не може да се валидира файл с изображение",
+        "img_size_exceeded": "Изображението надхвърля максималния размер на файла",
+        "img_tmp_missing": "Не може да се валидира файл с изображение: Липсва временен файл",
+        "invalid_bcc_map_type": "Невалиден тип на картата BCC",
+        "invalid_destination": "Форматът на дестинацията \"%s\" е невалиден",
+        "invalid_filter_type": "Невалиден тип на филтър",
+        "invalid_host": "Зададен е невалиден хост: %s",
+        "invalid_mime_type": "Невалиден MIME тип",
+        "invalid_nexthop": "Форматът на следващия хоп е невалиден",
+        "invalid_nexthop_authenticated": "Следващият хоп съществува с различни удостоверения, моля, актуализирайте съществуващите удостоверения за този следващ хоп първо.",
+        "invalid_recipient_map_new": "Зададен е невалиден нов получател: %s",
+        "invalid_recipient_map_old": "Зададен е невалиден оригинален получател: %s",
+        "invalid_reset_token": "Невалиден токен за нулиране",
+        "ip_list_empty": "Списъкът с разрешени IP адреси не може да бъде празен",
+        "is_alias": "%s вече е известен като адрес на псевдоним",
+        "is_alias_or_mailbox": "%s вече е известен като адрес на псевдоним, пощенска кутия или адрес на псевдоним, разширен от домейн на псевдоним.",
+        "is_spam_alias": "%s вече е известен като временен адрес на псевдоним (спам адрес на псевдоним)",
+        "last_key": "Последното ключове не може да бъде изтрито, моля, деактивирайте TFA вместо това.",
+        "login_failed": "Неуспешен вход",
+        "mailbox_defquota_exceeds_mailbox_maxquota": "Квотата по подразбиране надхвърля лимита на макс. квота",
+        "mailbox_invalid": "Името на пощенската кутия е невалидно",
+        "mailbox_quota_exceeded": "Квотата надхвърля лимита на домейна (макс. %d MiB)",
+        "mailbox_quota_exceeds_domain_quota": "Макс. квотата надхвърля лимита на квотата на домейна",
+        "mailbox_quota_left_exceeded": "Няма достатъчно място (оставащо място: %d MiB)",
+        "mailboxes_in_use": "Макс. пощенски кутии трябва да бъдат по-големи или равни на %d",
+        "malformed_username": "Неправилно формирано потребителско име",
+        "map_content_empty": "Съдържанието на картата не може да бъде празно",
+        "max_alias_exceeded": "Макс. псевдоними са надхвърлени",
+        "max_mailbox_exceeded": "Макс. пощенски кутии са надхвърлени (%d от %d)",
+        "max_quota_in_use": "Квотата на пощенската кутия трябва да бъде по-голяма или равна на %d MiB",
+        "maxquota_empty": "Макс. квотата за пощенска кутия не трябва да бъде 0.",
+        "mysql_error": "Грешка на MySQL: %s",
+        "network_host_invalid": "Невалидна мрежа или хост: %s",
+        "next_hop_interferes": "%s се намесва с nexthop %s",
+        "next_hop_interferes_any": "Съществуващ следващ хоп се намесва с %s",
+        "nginx_reload_failed": "Презареждането на Nginx е неуспешно: %s",
+        "no_user_defined": "Няма зададен потребител",
+        "object_exists": "Обектът %s вече съществува",
+        "object_is_not_numeric": "Стойността %s не е числова",
+        "password_complexity": "Паролата не отговаря на изискванията",
+        "password_empty": "Паролата не трябва да бъде празна",
+        "password_mismatch": "Паролата за потвърждение не съвпада",
+        "password_reset_invalid_user": "Пощенската кутия не е намерена или не е зададен имейл за възстановяване",
+        "password_reset_na": "Възстановяването на парола в момента е недостъпно. Моля, свържете се с вашия администратор.",
+        "policy_list_from_exists": "Съществува запис с даденото име",
+        "policy_list_from_invalid": "Записът има невалиден формат",
+        "private_key_error": "Грешка с частен ключ: %s",
+        "pushover_credentials_missing": "Липсва токен или ключ на Pushover",
+        "pushover_key": "Ключът на Pushover има грешен формат",
+        "pushover_token": "Токенът на Pushover има грешен формат",
+        "quota_not_0_not_numeric": "Квотата трябва да бъде числова и >= 0",
+        "recipient_map_entry_exists": "Съществува запис в картата на получатели \"%s\"",
+        "recovery_email_failed": "Не може да бъде изпратен имейл за възстановяване. Моля, свържете се с вашия администратор.",
+        "redis_error": "Грешка на Redis: %s",
+        "relayhost_invalid": "Записът в картата %s е невалиден",
+        "release_send_failed": "Съобщението не може да бъде освободено: %s",
+        "required_data_missing": "Липсват необходими данни %s",
+        "reset_f2b_regex": "Регулярният филтър не може да бъде нулиран навреме, моля, опитайте отново или изчакайте още няколко секунди и презаредете уеб сайта.",
+        "reset_token_limit_exceeded": "Лимитът на токена за нулиране е надхвърлен. Моля, опитайте по-късно.",
+        "resource_invalid": "Името на ресурса %s е невалидно",
+        "rl_timeframe": "Временният интервал за ограничение на скоростта е некоректен",
+        "rspamd_ui_pw_length": "Паролата на UI на Rspamd трябва да бъде поне 6 символа",
+        "script_empty": "Скриптът не може да бъде празен",
+        "sender_acl_invalid": "Стойността на ACL на изпращач %s е невалидна",
+        "set_acl_failed": "Неуспешно задаване на ACL",
+        "settings_map_invalid": "Идентификаторът на картата с настройки %s е невалиден",
+        "sieve_error": "Грешка при синтаксиса на Sieve: %s",
+        "spam_learn_error": "Грешка при обучение за спам: %s",
+        "subject_empty": "Темата не трябва да бъде празна",
+        "target_domain_invalid": "Целевият домейн %s е невалиден",
+        "targetd_not_found": "Целевият домейн %s не е намерен",
+        "targetd_relay_domain": "Целевият домейн %s е домейн за реле",
+        "template_exists": "Шаблонът %s вече съществува",
+        "template_id_invalid": "Идентификаторът на шаблона %s е невалиден",
+        "template_name_invalid": "Името на шаблона е невалидно",
+        "temp_error": "Временна грешка",
+        "text_empty": "Текстът не трябва да бъде празен",
+        "tfa_token_invalid": "Токенът за TFA е невалиден",
+        "tls_policy_map_dest_invalid": "Дестинацията на политиката е невалидна",
+        "tls_policy_map_entry_exists": "Съществува запис в картата на политиката на TLS \"%s\"",
+        "tls_policy_map_parameter_invalid": "Параметърът на политиката е невалиден",
+        "to_invalid": "Получателят не трябва да бъде празен",
+        "totp_verification_failed": "Проверката на TOTP е неуспешна",
+        "transport_dest_exists": "Дестинацията на транспорта \"%s\" съществува",
+        "webauthn_verification_failed": "Проверката на WebAuthn е неуспешна: %s",
+        "webauthn_authenticator_failed": "Избраният аутентикатор не е намерен",
+        "webauthn_publickey_failed": "Не е запазен публичен ключ за избрания аутентикатор",
+        "webauthn_username_failed": "Избраният аутентикатор принадлежи на друга сметка",
+        "unknown": "Възникна неизвестна грешка",
+        "unknown_tfa_method": "Неизвестен метод за TFA",
+        "unlimited_quota_acl": "Неограничената квота е забранена от ACL",
+        "username_invalid": "Потребителското име %s не може да бъде използвано",
+        "validity_missing": "Моля, задайте период на валидност",
+        "value_missing": "Моля, предоставете всички стойности",
+        "yotp_verification_failed": "Проверката на Yubico OTP е неуспешна: %s"
+    },
+    "datatables": {
+        "collapse_all": "Свиване на всичко",
+        "decimal": ".",
+        "emptyTable": "Няма данни в таблицата",
+        "expand_all": "Разширяване на всичко",
+        "info": "Показване на _START_ до _END_ от _TOTAL_ записа",
+        "infoEmpty": "Показване на 0 до 0 от 0 записа",
+        "infoFiltered": "(филтрирани от общо _MAX_ записа)",
+        "infoPostFix": "",
+        "thousands": ",",
+        "lengthMenu": "Показване на _MENU_ записа",
+        "loadingRecords": "Зареждане...",
+        "processing": "Моля, изчакайте...",
+        "search": "Търсене:",
+        "zeroRecords": "Няма съвпадащи записи",
+        "paginate": {
+            "first": "Първи",
+            "last": "Последен",
+            "next": "Следващ",
+            "previous": "Предишен"
+        },
+        "aria": {
+            "sortAscending": ": активиране за сортиране на колоната във възходящ ред",
+            "sortDescending": ": активиране за сортиране на колоната в низходящ ред"
+        }
+    },
+    "debug": {
+        "architecture": "Архитектура",
+        "chart_this_server": "Графика (този сървър)",
+        "containers_info": "Информация за контейнерите",
+        "container_running": "Изпълнява се",
+        "container_disabled": "Контейнерът е спрян или деактивиран",
+        "container_stopped": "Спрян",
+        "cores": "Ядра",
+        "current_time": "Системно време",
+        "disk_usage": "Използване на диска",
+        "docs": "Документи",
+        "error_show_ip": "Не може да се разреши публичния IP адрес",
+        "external_logs": "Външни логове",
+        "history_all_servers": "История (всички сървъри)",
+        "in_memory_logs": "Логове в паметта",
+        "last_modified": "Последно модифициране",
+        "log_info": "<p>Логовете на mailcow <b>в паметта</b> се събират в списъци на Redis и се подрязват до LOG_LINES (%d) на всяка минута, за да се намали натоварването.<br>Логовете в паметта не са предназначени да бъдат постоянни. Всички приложения, които записват в паметта, също записват в демона на Docker и следователно в основния драйвер за логсване.<br>Логовете в паметта трябва да се използват за отстраняване на леки проблеми с контейнери.</p>\r\n  <p><b>Външните логове</b> се събират чрез API на даденото приложение.</p>\r\n  <p><b>Статичните логове</b> са най-вече логове на активност, които не се записват в демона на Docker, но все още трябва да бъдат постоянни (с изключение на логовете на API).</p>",
+        "login_time": "Време",
+        "logs": "Логове",
+        "memory": "Памет",
+        "online_users": "Потребители онлайн",
+        "restart_container": "Рестартиране",
+        "service": "Услуга",
+        "show_ip": "Показване на публичен IP",
+        "size": "Размер",
+        "started_at": "Стартирано в",
+        "started_on": "Стартирано на",
+        "static_logs": "Статични логове",
+        "success": "Успех",
+        "system_containers": "Система & Контейнери",
+        "timezone": "Часова зона",
+        "uptime": "Време на работа",
+        "update_available": "Има налична актуализация",
+        "no_update_available": "Системата е на последното издание",
+        "update_failed": "Не може да се провери за актуализация",
+        "username": "Потребителско име",
+        "wip": "В момента се работи"
+    },
+    "diagnostics": {
+        "cname_from_a": "Стойността е извлечена от A/AAAA запис. Това се поддържа, докато записът сочи към правилния ресурс.",
+        "dns_records": "DNS записи",
+        "dns_records_24hours": "Моля, имайте предвид, че промените в DNS може да отнемат до 24 часа, за да имат актуалното си състояние правилно отразено на тази страница. Тя е предназначена да ви позволи лесно да видите как да конфигурирате вашите DNS записи и да проверите дали всичките ви записи са правилно запазени в DNS.",
+        "dns_records_data": "Правилни данни",
+        "dns_records_docs": "Моля, вижте и <a target=\"_blank\" href=\"https://docs.mailcow.email/getstarted/prerequisite-dns\">документацията</a>.",
+        "dns_records_name": "Име",
+        "dns_records_status": "Текущо състояние",
+        "dns_records_type": "Тип",
+        "optional": "Този запис е опционален."
+    },
+    "edit": {
+        "acl": "ACL (Разрешение)",
+        "active": "Активен",
+        "admin": "Редактиране на администратор",
+        "advanced_settings": "Разширени настройки",
+        "alias": "Редактиране на псевдоним",
+        "allow_from_smtp": "Разрешаване само на тези IP адреси да използват <b>SMTP</b>",
+        "allow_from_smtp_info": "Оставете празно, за да разрешите всички изпращачи.<br>IPv4/IPv6 адреси и мрежи.",
+        "allowed_protocols": "Разрешени протоколи за пряк потребителски достъп (не засяга протоколите за пароли на приложения)",
+        "app_name": "Име на приложението",
+        "app_passwd": "Парола за приложение",
+        "app_passwd_protocols": "Разрешени протоколи за паролата на приложението",
+        "automap": "Опит за автоматично картографиране на папки (\"Изпратени\", \"Изпратени\" => \"Изпратени\" и т.н.)",
+        "backup_mx_options": "Опции за реле",
+        "bcc_dest_format": "BCC дестинацията трябва да бъде един валиден имейл адрес.<br>Ако имате нужда да изпратите копие до множество адреси, създайте псевдоним и го използвайте тук.",
+        "client_id": "Идентификатор на клиента",
+        "client_secret": "Тайна на клиента",
+        "comment_info": "Частен коментар не е видим за потребителя, докато публичен коментар се показва като подсказка при преминаване с мишката върху него в прегледа на потребителя",
+        "created_on": "Създаден на",
+        "custom_attributes": "Персонализирани атрибути",
+        "delete1": "Изтриване от източника след завършване",
+        "delete2": "Изтриване на съобщенията в дестинацията, които не са в източника",
+        "delete2duplicates": "Изтриване на дубликати в дестинацията",
+        "delete_ays": "Моля, потвърдете процеса на изтриване.",
+        "description": "Описание",
+        "disable_login": "Забраняване на вход (входящите съобщения все още се приемат)",
+        "domain": "Редактиране на домейн",
+        "domain_admin": "Редактиране на администратор на домейн",
+        "domain_footer": "Подвал за домейн",
+        "domain_footer_html": "HTML подвал",
+        "domain_footer_info": "Подвалите за домейн се добавят към всички изходящи имейли, свързани с адрес в този домейн. Следните променливи могат да бъдат използвани за подвала:",
+        "domain_footer_info_vars": {
+            "auth_user": "{= auth_user =}   - Удостоверен потребител, посочен от MTA",
+            "from_user": "{= from_user =}   - Потребителска част на обвивката, напр. за \"moo@mailcow.tld\" връща \"moo\"",
+            "from_name": "{= from_name =}   - Име на обвивката, напр. за \"Mailcow &lt;moo@mailcow.tld&gt;\" връща \"Mailcow\"",
+            "from_addr": "{= from_addr =}   - Адресна част на обвивката",
+            "from_domain": "{= from_domain =} - Домейна част на обвивката",
+            "custom": "{= foo =}         - Ако пощенската кутия има персонализиран атрибут \"foo\" със стойност \"bar\", ще върне \"bar\""
+        },
+        "domain_footer_plain": "PLAIN подвал",
+        "domain_footer_skip_replies": "Игнориране на подвал в отговорни имейли",
+        "domain_quota": "Квота на домейна",
+        "domains": "Домейни",
+        "dont_check_sender_acl": "Деактивиране на проверката на изпращач за домейн %s (+ домейни на псевдоними)",
+        "edit_alias_domain": "Редактиране на домейн на псевдоним",
+        "encryption": "Криптиране",
+        "exclude": "Изключване на обекти (regex)",
+        "extended_sender_acl": "Външни адреси на изпращач",
+        "extended_sender_acl_info": "Трябва да бъде импортиран DKIM домейн ключ, ако е наличен.<br>\r\n  Помнете да добавите този сървър към съответния SPF TXT запис.<br>\r\n  Когато домейн или домейн на псевдоним бъде добавен към този сървър, който се припокрива с външен адрес, външният адрес ще бъде премахнат.<br>\r\n  Използвайте @domain.tld, за да разрешите изпращане като *@domain.tld.",
+        "footer_exclude": "Изключване от подвал",
+        "force_pw_update": "Принудително обновяване на парола при следващия вход",
+        "force_pw_update_info": "Този потребител ще може да влезе само в %s. Паролите за приложения остават използваеми.",
+        "full_name": "Пълно име",
+        "gal": "Глобален адресен списък",
+        "gal_info": "Глобалният адресен списък съдържа всички обекти на домейна и не може да бъде редактиран от нито един потребител. Липсва информация за заетост/свободно време в SOGo, ако е деактивирано! <b>Рестартирайте SOGo, за да приложите промените.</b>",
+        "generate": "генериране",
+        "grant_types": "Типове разрешения",
+        "hostname": "Име на хост",
+        "inactive": "Неактивен",
+        "kind": "Вид",
+        "last_modified": "Последно модифициране",
+        "lookup_mx": "Дестинацията е регулярен израз за съвпадение с MX име (<code>.*\\.google\\.com</code> за пренасочване на всички съобщения, предназначени за MX, завършващ на google.com, през този хоп)",
+        "mailbox": "Редактиране на пощенска кутия",
+        "mailbox_quota_def": "Квота по подразбиране за пощенска кутия",
+        "mailbox_relayhost_info": "Прилага се за пощенската кутия и директните псевдоними само, пренарежда запис в картата на транспорта за домейн.",
+        "mailbox_rename": "Преименуване на пощенска кутия",
+        "mailbox_rename_agree": "Създадох резервно копие.",
+        "mailbox_rename_alias": "Автоматично създаване на псевдоним",
+        "mailbox_rename_title": "Ново локално име на пощенска кутия",
+        "mailbox_rename_warning": "ВНИМАНИЕ! Създайте резервно копие преди преименуване на пощенската кутия.",
+        "max_aliases": "Макс. псевдоними",
+        "max_mailboxes": "Макс. възможни пощенски кутии",
+        "max_quota": "Макс. квота за пощенска кутия (MiB)",
+        "maxage": "Максимална възраст на съобщенията в дни, които ще бъдат проверени от отдалечен<br><small>(0 = игнорирай възраст)</small>",
+        "maxbytespersecond": "Макс. байтове за секунда <br><small>(0 = неограничен)</small>",
+        "mbox_rl_info": "Това ограничение на скоростта се прилага върху SASL името за вход, то съвпада с всеки \"от\" адрес, използван от влезлия потребител. Ограничението на скоростта на пощенска кутия пренарежда ограничението на скоростта за домейн.",
+        "mins_interval": "Интервал (мин)",
+        "multiple_bookings": "Множествени резервации",
+        "nexthop": "Следващ хоп",
+        "none_inherit": "Без / Наследяване",
+        "password": "Парола",
+        "password_recovery_email": "Имейл за възстановяване на парола",
+        "password_repeat": "Потвърждаване на паролата (повторете)",
+        "previous": "Предишна страница",
+        "private_comment": "Частен коментар",
+        "public_comment": "Публичен коментар",
+        "pushover": "Pushover",
+        "pushover_evaluate_x_prio": "Ескалиране на високоприоритетни съобщения [<code>X-Priority: 1</code>]",
+        "pushover_info": "Настройките за известия на Pushover ще се прилагат за всички чисти (не-спам) съобщения, доставени до <b>%s</b>, включително псевдоними (споделени, несподелени, таговани).",
+        "pushover_only_x_prio": "Разглеждане само на високоприоритетни съобщения [<code>X-Priority: 1</code>]",
+        "pushover_sender_array": "Разглеждане само на следните адреси на изпращач <small>(разделени с запетая)</small>",
+        "pushover_sender_regex": "Разглеждане на следния regex на изпращач",
+        "pushover_sound": "Звук",
+        "pushover_text": "Текст на известието",
+        "pushover_title": "Заглавие на известието",
+        "pushover_vars": "Когато не е зададен филтър на изпращач, всички съобщения ще бъдат разглеждани.<br>Филтрите с регулярен израз, както и точните проверки на изпращач, могат да бъдат дефинирани индивидуално и ще бъдат разглеждани последователно. Те не зависят един от друг.<br>Използвайте следните променливи за текст и заглавие (моля, вземете предвид политиките за поверителност на данните)",
+        "pushover_verify": "Проверка на удостоверения",
+        "quota_mb": "Квота (MiB)",
+        "quota_warning_bcc": "Предупреждения за квота ще бъдат изпращани като отделни копия до следните получатели:",
+        "quota_warning_bcc_info": "Съобщенията ще бъдат изпратени с тема, допълнена с името на потребителя в скоби, например: <code>Предупреждение за квота (user@example.com)</code>.",
+        "ratelimit": "Ограничение на скоростта",
+        "redirect_uri": "URI за пренасочване/обратно извикване",
+        "relay_all": "Реле на всички получатели",
+        "relay_all_info": "↪ Ако изберете да <b>не</b> релеирате всички получатели, ще трябва да добавите (\"скрита\") пощенска кутия за всеки отделен получател, който трябва да бъде релеиран.",
+        "relay_domain": "Реле на този домейн",
+        "relay_transport_info": "<div class=\"badge fs-6 bg-info\">Инфо</div> Можете да дефинирате транспортни карти за персонализирана дестинация за този домейн. Ако не е зададено, ще бъде направен MX lookup.",
+        "relay_unknown_only": "Реле на несъществуващи пощенски кутии. Съществуващите пощенски кутии ще бъдат доставени локално.",
+        "relayhost": "Транспорти, зависими от изпращач",
+        "remove": "Премахване",
+        "resource": "Ресурс",
+        "save": "Запазване на промените",
+        "scope": "Обхват",
+        "sender_acl": "Разрешаване на изпращане като",
+        "sender_acl_disabled": "<span class=\"badge fs-6 bg-danger\">Проверката на изпращач е деактивирана</span>",
+        "sender_acl_info": "Ако потребителят на пощенска кутия A е разрешен да изпраща като потребителя на пощенска кутия B, адресът на изпращач не се показва автоматично като избираем \"от\" поле в SOGo.<br>\r\n  Потребителят на пощенска кутия B трябва да създаде делегация в SOGo, за да разреши на потребителя на пощенска кутия A да избира техния адрес като изпращач. За да делегирате пощенска кутия в SOGo, използвайте менюто (три точки) вдясно от името на пощенската кутия в горния ляв ъгъл, докато сте в режим на поща. Това поведение не се прилага за адреси на псевдоними.",
+        "sieve_desc": "Кратко описание",
+        "sieve_type": "Тип на филтър",
+        "skipcrossduplicates": "Пропускане на дублирани съобщения между папки (първи дошъл, първи обслужен)",
+        "sogo_access": "Директно препращане към SOGo",
+        "sogo_access_info": "След влизане, потребителят се пренасочва автоматично към SOGo.",
+        "sogo_visible": "Псевдонимът е видим в SOGo",
+        "sogo_visible_info": "Тази опция засяга само обекти, които могат да бъдат показани в SOGo (споделени или несподелени адреси на псевдоними, сочещи поне една локална пощенска кутия). Ако е скрит, псевдонимът няма да се появи като избираем адрес на изпращач в SOGo.",
+        "spam_alias": "Създаване или промяна на временни псевдоними",
+        "spam_filter": "Филтър за спам",
+        "spam_policy": "Добавяне или премахване на елементи към черния/бял списък",
+        "spam_score": "Задаване на персонализиран резултат за спам",
+        "subfolder2": "Синхронизиране в подпапка в дестинацията<br><small>(празно = не използвай подпапка)</small>",
+        "syncjob": "Редактиране на синхронизираща задача",
+        "target_address": "Адрес/и за пренасочване <small>(разделени с запетая)</small>",
+        "target_domain": "Целеви домейн",
+        "timeout1": "Таймаут за връзка с отдалечен хост",
+        "timeout2": "Таймаут за връзка с локален хост",
+        "title": "Редактиране на обект",
+        "unchanged_if_empty": "Ако не е променено, оставете празно",
+        "username": "Потребителско име",
+        "validate_save": "Валидиране и запазване"
+    },
+    "fido2": {
+        "confirm": "Потвърждаване",
+        "fido2_auth": "Вход с FIDO2",
+        "fido2_success": "Устройството е регистрирано успешно",
+        "fido2_validation_failed": "Проверката е неуспешна",
+        "fn": "Приятелско име",
+        "known_ids": "Известни идентификатори",
+        "none": "Деактивирано",
+        "register_status": "Състояние на регистрация",
+        "rename": "Преименуване",
+        "set_fido2": "Регистриране на FIDO2 устройство",
+        "set_fido2_touchid": "Регистриране на Touch ID на Apple M1",
+        "set_fn": "Задаване на приятелско име",
+        "start_fido2_validation": "Стартиране на проверка на FIDO2"
+    },
+    "footer": {
+        "cancel": "Отказ",
+        "confirm_delete": "Потвърждаване на изтриването",
+        "delete_now": "Изтриване сега",
+        "delete_these_items": "Моля, потвърдете промените за следния идентификатор на обект",
+        "hibp_check": "Проверка срещу haveibeenpwned.com",
+        "hibp_nok": "Съвпадение! Това е потенциално опасна парола!",
+        "hibp_ok": "Няма съвпадение.",
+        "loading": "Моля, изчакайте...",
+        "nothing_selected": "Няма избрани елементи",
+        "restart_container": "Рестартиране на контейнер",
+        "restart_container_info": "<b>Важно:</b> Грациозното рестартиране може да отнеме известно време за завършване, моля, изчакайте да приключи.",
+        "restart_now": "Рестартиране сега",
+        "restarting_container": "Рестартиране на контейнера, това може да отнеме известно време"
+    },
+    "header": {
+        "administration": "Конфигурация & Детайли",
+        "apps": "Приложения",
+        "debug": "Информация",
+        "email": "Имейл",
+        "mailcow_system": "Система",
+        "mailcow_config": "Конфигурация",
+        "quarantine": "Карантина",
+        "restart_netfilter": "Рестартиране на netfilter",
+        "restart_sogo": "Рестартиране на SOGo",
+        "user_settings": "Настройки на потребителя"
+    },
+    "info": {
+        "awaiting_tfa_confirmation": "Изчакване на потвърждение за TFA",
+        "no_action": "Няма приложимо действие",
+        "session_expires": "Вашата сесия ще изтече след около 15 секунди"
+    },
+    "login": {
+        "back_to_mailcow": "Обратно към mailcow",
+        "delayed": "Входът е забавен с %s секунди.",
+        "fido2_webauthn": "Вход с FIDO2/WebAuthn",
+        "forgot_password": "> Забравена парола?",
+        "invalid_pass_reset_token": "Токенът за нулиране на парола е невалиден или е изтекъл.<br>Моля, заявете нов линк за нулиране на парола.",
+        "login": "Вход",
+        "login_admin": "Вход на администратор",
+        "login_dadmin": "Вход на администратор на домейн",
+        "login_user": "Потребителски вход",
+        "mobileconfig_info": "Моля, влезте като потребител на пощенска кутия, за да изтеглите поискания Apple профил за връзка.",
+        "new_password": "Нова парола",
+        "new_password_confirm": "Потвърждаване на новата парола",
+        "other_logins": "или вход с",
+        "password": "Парола",
+        "request_reset_password": "Заявка за промяна на парола",
+        "reset_password": "Нулиране на парола",
+        "username": "Потребителско име"
+    },
+    "mailbox": {
+        "action": "Действие",
+        "activate": "Активиране",
+        "active": "Активен",
+        "add": "Добавяне",
+        "add_alias": "Добавяне на псевдоним",
+        "add_alias_expand": "Разширяване на псевдоним над домейни на псевдоними",
+        "add_bcc_entry": "Добавяне на запис в картата BCC",
+        "add_domain": "Добавяне на домейн",
+        "add_domain_alias": "Добавяне на псевдоним на домейн",
+        "add_domain_record_first": "Моля, добавете първо домейн",
+        "add_filter": "Добавяне на филтър",
+        "add_mailbox": "Добавяне на пощенска кутия",
+        "add_recipient_map_entry": "Добавяне на запис в картата на получатели",
+        "add_resource": "Добавяне на ресурс",
+        "add_template": "Добавяне на шаблон",
+        "add_tls_policy_map": "Добавяне на карта на политиката на TLS",
+        "address_rewriting": "Презаписване на адрес",
+        "alias": "Псевдоним",
+        "alias_domain_alias_hint": "Псевдонимите <b>не</b> се прилагат автоматично към домейни на псевдоними. Псевдонимът <code>my-alias@domain</code> <b>не</b> покрива адреса <code>my-alias@alias-domain</code> (където \"alias-domain\" е имагинерен псевдоним на домейн).<br>Моля, използвайте филтър на Sieve, за да пренасочите имейл към външна пощенска кутия (вижте раздела \"Филтри\" или SOGo -> Пренасочвач). Използвайте \"Разширяване на псевдоним над домейни на псевдоними\", за да добавите автоматично липсващи псевдоними.",
+        "alias_domain_backupmx": "Псевдонимът на домейн е неактивен за домейн за реле",
+        "aliases": "Псевдоними",
+        "all_domains": "Всички домейни",
+        "allow_from_smtp": "Разрешаване само на тези IP адреси да използват <b>SMTP</b>",
+        "allow_from_smtp_info": "Оставете празно, за да разрешите всички изпращачи.<br>IPv4/IPv6 адреси и мрежи.",
+        "allowed_protocols": "Разрешени протоколи",
+        "backup_mx": "Домейн за реле",
+        "bcc": "BCC",
+        "bcc_destination": "BCC дестинация",
+        "bcc_destinations": "BCC дестинации",
+        "bcc_info": "Картите BCC се използват, за да препращат тихо копия от всички съобщения до друг адрес. Записът от тип получател на карта се използва, когато локалната дестинация действа като получател на имейл. Записът от тип изпращач на карта се използва, когато локалната дестинация действа като изпращач на имейл. Локалната дестинация няма да бъде информирана за неуспешна доставка.",
+        "bcc_local_dest": "Локална дестинация",
+        "bcc_map": "Карта BCC",
+        "bcc_map_type": "Тип BCC",
+        "bcc_maps": "Карти BCC",
+        "bcc_rcpt_map": "Карта на получател",
+        "bcc_sender_map": "Карта на изпращач",
+        "bcc_to_rcpt": "Превключване към карта на получател",
+        "bcc_to_sender": "Превключване към карта на изпращач",
+        "bcc_type": "Тип BCC",
+        "booking_null": "Винаги показване като свободен",
+        "booking_0_short": "Винаги свободен",
+        "booking_custom": "Твърдо ограничение до определен брой резервации",
+        "booking_custom_short": "Твърдо ограничение",
+        "booking_ltnull": "Неограничено, но показване като заето, когато е резервирано",
+        "booking_lt0_short": "Меко ограничение",
+        "catch_all": "Catch-All",
+        "created_on": "Създаден на",
+        "daily": "Ежедневно",
+        "deactivate": "Деактивиране",
+        "description": "Описание",
+        "disable_login": "Забраняване на вход (входящите съобщения все още се приемат)",
+        "disable_x": "Деактивиране",
+        "dkim_domains_selector": "Селектор",
+        "dkim_key_length": "Дължина на DKIM ключа (битове)",
+        "domain": "Домейн",
+        "domain_admins": "Администратори на домейн",
+        "domain_aliases": "Псевдоними на домейн",
+        "domain_templates": "Шаблони за домейн",
+        "domain_quota": "Квота",
+        "domain_quota_total": "Обща квота на домейна",
+        "domains": "Домейни",
+        "edit": "Редактиране",
+        "empty": "Няма резултати",
+        "enable_x": "Активиране",
+        "excludes": "Изключване",
+        "filter_table": "Таблица с филтри",
+        "filters": "Филтри",
+        "fname": "Пълно име",
+        "force_pw_update": "Принудително обновяване на парола при следващия вход",
+        "gal": "Глобален адресен списък",
+        "goto_ham": "Учен като <span class=\"text-success\"><b>не е спам</b></span>",
+        "goto_spam": "Учен като <span class=\"text-danger\"><b>спам</b></span>",
+        "hourly": "Часово",
+        "iam": "Доставчик на идентичност",
+        "in_use": "В употреба (%)",
+        "inactive": "Неактивен",
+        "insert_preset": "Вмъкване на примерен предефиниран набор \"%s\"",
+        "kind": "Вид",
+        "last_mail_login": "Последен вход в пощата",
+        "last_modified": "Последно модифициране",
+        "last_pw_change": "Последна промяна на парола",
+        "last_run": "Последно изпълнение",
+        "last_run_reset": "Задаване на следващо",
+        "mailbox": "Пощенска кутия",
+        "mailbox_defaults": "Настройки по подразбиране",
+        "mailbox_defaults_info": "Дефинирайте настройки по подразбиране за нови пощенски кутии.",
+        "mailbox_defquota": "Размер по подразбиране на пощенска кутия",
+        "mailbox_templates": "Шаблони за пощенска кутия",
+        "mailbox_quota": "Макс. размер на пощенска кутия",
+        "mailboxes": "Пощенски кутии",
+        "max_aliases": "Макс. псевдоними",
+        "max_mailboxes": "Макс. възможни пощенски кутии",
+        "max_quota": "Макс. квота за пощенска кутия",
+        "mins_interval": "Интервал (мин)",
+        "msg_num": "Съобщение №",
+        "multiple_bookings": "Множествени резервации",
+        "never": "Никога",
+        "no": "&#10005;",
+        "no_record": "Няма запис за обект %s",
+        "no_record_single": "Няма запис",
+        "open_logs": "Отваряне на логове",
+        "owner": "Собственик",
+        "private_comment": "Частен коментар",
+        "public_comment": "Публичен коментар",
+        "q_add_header": "при преместване в папката за нежелана поща",
+        "q_all": " при преместване в папката за нежелана поща и при отхвърляне",
+        "q_reject": "при отхвърляне",
+        "quarantine_category": "Категория на уведомленията за карантина",
+        "quarantine_notification": "Уведомления за карантина",
+        "quick_actions": "Действия",
+        "recipient": "Получател",
+        "recipient_map": "Карта на получател",
+        "recipient_map_info": "Картите на получател се използват, за да се замени адресът на дестинация на съобщението, преди да бъде доставено.",
+        "recipient_map_new": "Нов получател",
+        "recipient_map_new_info": "Дестинацията на картата на получател трябва да бъде валиден имейл адрес или име на домейн.",
+        "recipient_map_old": "Оригинален получател",
+        "recipient_map_old_info": "Оригиналната дестинация на картата на получател трябва да бъде валиден имейл адрес или име на домейн.",
+        "recipient_maps": "Карти на получател",
+        "relay_all": "Реле на всички получатели",
+        "relay_unknown": "Реле на несъществуващи пощенски кутии",
+        "remove": "Премахване",
+        "resources": "Ресурси",
+        "running": "Изпълнява се",
+        "sender": "Изпращач",
+        "set_postfilter": "Маркиране като постфилтър",
+        "set_prefilter": "Маркиране като префилтър",
+        "sieve_info": "Можете да запазите множество филтри за всеки потребител, но само един префилтър и един постфилтър могат да бъдат активни едновременно.<br>\r\nВсеки филтър ще бъде обработен в описания ред. Нито един неуспешен скрипт, нито издадена команда \"keep;\" няма да спре обработката на следващите скриптове. Промените в глобалните филтри на sieve ще предизвикат рестартиране на Dovecot.<br><br>Глобален префилтър на sieve &#8226; Префилтър &#8226; Потребителски скриптове &#8226; Постфилтър &#8226; Глобален постфилтър на sieve",
+        "sieve_preset_1": "Изтриване на съобщения с потенциално опасни типове файлове",
+        "sieve_preset_2": "Винаги маркиране на имейла на определен изпращач като прочетен",
+        "sieve_preset_3": "Тихо изтриване, спиране на всякаква допълнителна обработка на sieve филтри",
+        "sieve_preset_4": "Архивиране на съобщението във ВХОДНА, пропускане на допълнителна обработка от sieve филтри",
+        "sieve_preset_5": "Автоотговор (ваканция)",
+        "sieve_preset_6": "Отхвърляне на съобщение с отговор",
+        "sieve_preset_7": "Пренасочване и запазване/изтриване",
+        "sieve_preset_8": "Пренасочване на имейл от определен изпращач, маркиране като прочетен и сортиране в подпапка",
+        "sieve_preset_header": "Моля, вижте примерните предефинирани набори по-долу. За повече детайли вижте <a href=\"https://en.wikipedia.org/wiki/Sieve_(mail_filtering_language)\" target=\"_blank\">Wikipedia</a>.",
+        "sogo_visible": "Псевдонимът е видим в SOGo",
+        "sogo_visible_n": "Скриване на псевдоним в SOGo",
+        "sogo_visible_y": "Показване на псевдоним в SOGo",
+        "spam_aliases": "Времеви псевдоними",
+        "stats": "Статистика",
+        "status": "Статус",
+        "sync_jobs": "Синхронизиращи задачи",
+        "syncjob_check_log": "Проверка на лога",
+        "syncjob_last_run_result": "Резултат от последното изпълнение",
+        "syncjob_EX_OK": "Успех",
+        "syncjob_EXIT_CONNECTION_FAILURE": "Проблем с връзката",
+        "syncjob_EXIT_TLS_FAILURE": "Проблем с криптираната връзка",
+        "syncjob_EXIT_AUTHENTICATION_FAILURE": "Проблем с удостоверяването",
+        "syncjob_EXIT_OVERQUOTA": "Целевата пощенска кутия е над квотата",
+        "syncjob_EXIT_CONNECTION_FAILURE_HOST1": "Не може да се свърже с отдалечен сървър",
+        "syncjob_EXIT_AUTHENTICATION_FAILURE_USER1": "Грешно потребителско име или парола",
+        "table_size": "Размер на таблицата",
+        "table_size_show_n": "Показване на %s елемента",
+        "target_address": "Адрес за пренасочване",
+        "target_domain": "Целеви домейн",
+        "templates": "Шаблони",
+        "template": "Шаблон",
+        "tls_enforce_in": "Принудително използване на TLS за входящи",
+        "tls_enforce_out": "Принудително използване на TLS за изходящи",
+        "tls_map_dest": "Дестинация",
+        "tls_map_dest_info": "Примери: example.org, .example.org, [mail.example.org]:25",
+        "tls_map_parameters": "Параметри",
+        "tls_map_parameters_info": "Празно или параметри, например: protocols=!SSLv2 ciphers=medium exclude=3DES",
+        "tls_map_policy": "Политика",
+        "tls_policy_maps": "Пренареждания на политиката на TLS",
+        "tls_policy_maps_enforced_tls": "Тези политики ще пренареждат и поведението за потребители на пощенски кутии, които принудително използват изходящи TLS връзки. Ако няма политика, съществуваща по-долу, тези потребители ще приложат стойностите по подразбиране, зададени като <code>smtp_tls_mandatory_protocols</code> и <code>smtp_tls_mandatory_ciphers</code>.",
+        "tls_policy_maps_info": "Тази политика за пренареждане на TLS транспортни правила е независима от настройките за политика на TLS на потребителя.<br>\r\n  Моля, вижте <a href=\"http://www.postfix.org/postconf.5.html#smtp_tls_policy_maps\" target=\"_blank\">документацията за \"smtp_tls_policy_maps\"</a> за повече информация.",
+        "tls_policy_maps_long": "Пренареждания на политиката на TLS за изходящи",
+        "toggle_all": "Превключване на всички",
+        "username": "Потребителско име",
+        "waiting": "Изчакване",
+        "weekly": "Седмично",
+        "yes": "&#10003;"
+    },
+    "oauth2": {
+        "access_denied": "Моля, влезте като собственик на пощенска кутия, за да удостоверите чрез OAuth2.",
+        "authorize_app": "Удостоверяване на приложение",
+        "deny": "Отказ",
+        "permit": "Удостоверяване на приложение",
+        "profile": "Профил",
+        "profile_desc": "Преглед на лични данни: потребителско име, пълно име, създадено, модифицирано, активно",
+        "scope_ask_permission": "Приложението заявява следните разрешения"
+    },
+    "quarantine": {
+        "action": "Действие",
+        "atts": "Прикачени файлове",
+        "check_hash": "Търсене на файлов хеш в VirusTotal",
+        "confirm": "Потвърждаване",
+        "confirm_delete": "Потвърждаване на изтриването на този елемент.",
+        "danger": "Опасност",
+        "deliver_inbox": "Доставяне в пощенската кутия",
+        "disabled_by_config": "Текущата системна конфигурация деактивира функционалността на карантината. Моля, задайте \"задържания за пощенска кутия\" и \"максимален размер\" за елементите на карантината.",
+        "download_eml": "Изтегляне (.eml)",
+        "empty": "Няма резултати",
+        "high_danger": "Висока",
+        "info": "Информация",
+        "junk_folder": "Папка за нежелана поща",
+        "learn_spam_delete": "Учен като спам и изтриване",
+        "low_danger": "Ниска",
+        "medium_danger": "Средна",
+        "neutral_danger": "Неутрална",
+        "notified": "Уведомен",
+        "qhandler_success": "Заявката е изпратена успешно до системата. Можете да затворите прозореца сега.",
+        "qid": "QID на Rspamd",
+        "qinfo": "Системата за карантина ще запази отхвърлените съобщения в базата данни (изпращачът няма да бъде информиран за доставеното съобщение) както и съобщенията, доставени като копие в папката за нежелана поща на пощенска кутия.<br> <br>\"Учен като спам и изтриване\" ще научи съобщението като спам чрез теоремата на Бейс и също ще изчисли размити хешове, за да отхвърли подобни съобщения в бъдеще.<br> <br>Моля, имайте предвид, че обучаването на множество съобщения може да бъде - в зависимост от вашата система - времеемко.<br>Елементите в черния списък са изключени от карантината.",
+        "qitem": "Елемент в карантина",
+        "quarantine": "Карантина",
+        "quick_actions": "Действия",
+        "quick_delete_link": "Отваряне на бърз линк за изтриване",
+        "quick_info_link": "Отваряне на бърз информационен линк",
+        "quick_release_link": "Отваряне на бърз линк за освобождане",
+        "rcpt": "Получател",
+        "received": "Получено",
+        "recipients": "Получатели",
+        "refresh": "Опресняване",
+        "rejected": "Отхвърлено",
+        "release": "Освобождане",
+        "release_body": "Прикаченото съобщение е добавено към това съобщение.",
+        "release_subject": "Потенциално вреден елемент в карантина %s",
+        "remove": "Премахване",
+        "rewrite_subject": "Презаписване на темата",
+        "rspamd_result": "Резултат от Rspamd",
+        "sender": "Изпращач (SMTP)",
+        "sender_header": "Изпращач (\"From\" заглавие)",
+        "settings_info": "Максимален брой елементи за карантиниране: %s<br>Максимален размер на имейл: %s MiB",
+        "show_item": "Показване на елемент",
+        "spam": "Спам",
+        "spam_score": "Резултат",
+        "subj": "Тема",
+        "table_size": "Размер на таблицата",
+        "table_size_show_n": "Показване на %s елемента",
+        "text_from_html_content": "Съдържание (конвертиран HTML)",
+        "text_plain_content": "Съдържание (обикновен текст)",
+        "toggle_all": "Превключване на всички",
+        "type": "Тип"
+    },
+    "queue": {
+        "delete": "Изтриване на всички",
+        "flush": "Изчистване на опашката",
+        "info": "Опашката на имейлите съдържа всички имейли, които чакат за доставка. Ако имейлът е засечен в опашката за дълго време, той автоматично се изтрива от системата.<br>Съобщението за грешка на съответния имейл дава информация защо имейлът не може да бъде доставен.",
+        "legend": "Функции на действията в опашката на имейлите:",
+        "ays": "Моля, потвърдете, че искате да изтриете всички елементи от текущата опашка.",
+        "deliver_mail": "Доставяне",
+        "deliver_mail_legend": "Опит за повторно доставяне на избраните съобщения.",
+        "hold_mail": "Задържане",
+        "hold_mail_legend": "Задържа избраните съобщения. (Предотвратява допълнителни опити за доставяне)",
+        "queue_manager": "Мениджър на опашката",
+        "show_message": "Показване на съобщение",
+        "unban": "разблокиране на опашката",
+        "unhold_mail": "Освобождаване",
+        "unhold_mail_legend": "Освобождава избраните съобщения за доставка. (Изисква предварително задържане)"
+    },
+    "ratelimit": {
+        "disabled": "Деактивирано",
+        "second": "съобщения/секунда",
+        "minute": "съобщения/минута",
+        "hour": "съобщения/час",
+        "day": "съобщения/ден"
+    },
+    "start": {
+        "help": "Показване/Скриване на панела за помощ",
+        "imap_smtp_server_auth_info": "Моля, използвайте пълния си имейл адрес и механизма за удостоверяване PLAIN.<br>\r\nВашите данни за вход ще бъдат криптирани от сървърната страна чрез задължително сървърно криптиране."
+    },
+    "success": {
+        "acl_saved": "ACL за обект %s е запазен",
+        "admin_added": "Администраторът %s е добавен",
+        "admin_api_modified": "Промените в API са запазени",
+        "admin_modified": "Промените в администратора са запазени",
+        "admin_removed": "Администраторът %s е премахнат",
+        "alias_added": "Адресът на псевдонима %s (%d) е добавен",
+        "alias_domain_removed": "Домейнът на псевдонима %s е премахнат",
+        "alias_modified": "Промените в адреса на псевдонима %s са запазени",
+        "alias_removed": "Псевдонимът %s е премахнат",
+        "aliasd_added": "Добавен домейн на псевдоним %s",
+        "aliasd_modified": "Промените в домейна на псевдоним %s са запазени",
+        "app_links": "Запазени промени в линковете на приложенията",
+        "app_passwd_added": "Добавена нова парола за приложение",
+        "app_passwd_removed": "Премахната парола за приложение с ID %s",
+        "bcc_deleted": "Записи в картата BCC са изтрити: %s",
+        "bcc_edited": "Записът в картата BCC %s е редактиран",
+        "bcc_saved": "Записът в картата BCC е запазен",
+        "cors_headers_edited": "Настройките на CORS са запазени",
+        "db_init_complete": "Инициализацията на базата данни е завършена",
+        "delete_filter": "Изтрити филтри с ID %s",
+        "delete_filters": "Изтрити филтри: %s",
+        "deleted_syncjob": "Изтрита синхронизираща задача с ID %s",
+        "deleted_syncjobs": "Изтрити синхронизиращи задачи: %s",
+        "dkim_added": "Добавен DKIM ключ %s",
+        "dkim_duplicated": "DKIM ключът за домейн %s е копиран в %s",
+        "dkim_removed": "DKIM ключът %s е премахнат",
+        "domain_add_dkim_available": "DKIM ключът вече съществува",
+        "domain_added": "Добавен домейн %s",
+        "domain_admin_added": "Добавен администратор на домейн %s",
+        "domain_admin_modified": "Промените в администратора на домейн %s са запазени",
+        "domain_admin_removed": "Администраторът на домейн %s е премахнат",
+        "domain_footer_modified": "Промените в подвала на домейн %s са запазени",
+        "domain_modified": "Промените в домейн %s са запазени",
+        "domain_removed": "Домейнът %s е премахнат",
+        "dovecot_restart_success": "Dovecot е рестартиран успешно",
+        "eas_reset": "Устройствата с ActiveSync за потребителя %s са нулирани",
+        "f2b_banlist_refreshed": "Списъкът с ID на блокираните е актуализиран успешно.",
+        "f2b_modified": "Промените в параметрите на Fail2ban са запазени",
+        "forwarding_host_added": "Добавен хост за препращане %s",
+        "forwarding_host_removed": "Премахнат хост за препращане %s",
+        "global_filter_written": "Филтърът е записан успешно във файл",
+        "hash_deleted": "Хешът е изтрит",
+        "iam_test_connection": "Връзката е успешна",
+        "ip_check_opt_in_modified": "Проверката на IP беше успешно запазена",
+        "item_deleted": "Елементът %s е изтрит успешно",
+        "item_released": "Елементът %s е освободен",
+        "items_deleted": "Елементът %s е изтрит успешно",
+        "items_released": "Избраните елементи са освободени",
+        "learned_ham": "Успешно научен ID %s като не е спам",
+        "license_modified": "Промените в лиценза са запазени",
+        "logged_in_as": "Вписан като %s",
+        "mailbox_added": "Пощенската кутия %s е добавена",
+        "mailbox_modified": "Промените в пощенската кутия %s са запазени",
+        "mailbox_removed": "Пощенската кутия %s е премахната",
+        "mailbox_renamed": "Пощенската кутия е преименувана от %s на %s",
+        "nginx_reloaded": "Nginx е презареден",
+        "object_modified": "Промените в обект %s са запазени",
+        "password_changed_success": "Паролата е променена успешно",
+        "password_policy_saved": "Политиката за парола е запазена успешно",
+        "pushover_settings_edited": "Настройките на Pushover са запазени успешно, моля, проверете удостоверенията.",
+        "qlearn_spam": "Съобщението с ID %s е научено като спам и изтрито",
+        "queue_command_success": "Командата на опашката е завършена успешно",
+        "recipient_map_entry_deleted": "Записът в картата на получател с ID %s е изтрит",
+        "recipient_map_entry_saved": "Записът в картата на получател \"%s\" е запазен",
+        "recovery_email_sent": "Изпратен имейл за възстановяване до %s",
+        "relayhost_added": "Записът в картата %s е добавен",
+        "relayhost_removed": "Записът в картата %s е премахнат",
+        "reset_main_logo": "Нулиране на логото по подразбиране",
+        "resource_added": "Ресурсът %s е добавен",
+        "resource_modified": "Промените в пощенската кутия %s са запазени",
+        "resource_removed": "Ресурсът %s е премахнат",
+        "rl_saved": "Ограничението на скоростта за обект %s е запазено",
+        "rspamd_ui_pw_set": "Паролата на UI на Rspamd е зададена успешно",
+        "saved_settings": "Запазени настройки",
+        "settings_map_added": "Добавен запис в картата с настройки",
+        "settings_map_removed": "Премахнат запис в картата с настройки с ID %s",
+        "sogo_profile_reset": "Профилът на SOGo за потребителя %s е нулиран",
+        "template_added": "Добавен шаблон %s",
+        "template_modified": "Промените в шаблон %s са запазени",
+        "template_removed": "Шаблонът с ID %s е премахнат",
+        "tls_policy_map_entry_deleted": "Записът в картата на политиката на TLS с ID %s е изтрит",
+        "tls_policy_map_entry_saved": "Записът в картата на политиката на TLS \"%s\" е запазен",
+        "ui_texts": "Запазени промени в текстовете на UI",
+        "upload_success": "Файлът е качен успешно",
+        "verified_fido2_login": "Потвърдено вход с FIDO2",
+        "verified_totp_login": "Потвърдено вход с TOTP",
+        "verified_webauthn_login": "Потвърдено вход с WebAuthn",
+        "verified_yotp_login": "Потвърдено вход с Yubico OTP"
+    },
+    "tfa": {
+        "authenticators": "Аутентикатори",
+        "api_register": "%s използва облачното API на Yubico. Моля, вземете API ключ за вашия ключ <a href=\"https://upgrade.yubico.com/getapikey/\" target=\"_blank\">тук</a>",
+        "confirm": "Потвърждаване",
+        "confirm_totp_token": "Моля, потвърдете промените, като въведете генерирания токен",
+        "delete_tfa": "Деактивиране на TFA",
+        "disable_tfa": "Деактивиране на TFA до следващия успешен вход",
+        "enter_qr_code": "Вашият TOTP код, ако вашето устройство не може да сканира QR кодове",
+        "error_code": "Код на грешка",
+        "init_webauthn": "Инициализиране, моля, изчакайте...",
+        "key_id": "Идентификатор за вашето устройство",
+        "key_id_totp": "Идентификатор за вашия ключ",
+        "none": "Деактивиране",
+        "reload_retry": "- (презаредете браузъра, ако грешката продължи)",
+        "scan_qr_code": "Моля, сканирайте следния код с вашето приложение за аутентикация или въведете кода ръчно.",
+        "select": "Моля, изберете",
+        "set_tfa": "Задаване на метод за двуфакторно удостоверяване",
+        "start_webauthn_validation": "Стартиране на проверка",
+        "tfa": "Двуфакторно удостоверяване",
+        "tfa_token_invalid": "Невалиден токен за TFA",
+        "totp": "Временен OTP (Google Authenticator, Authy и др.)",
+        "u2f_deprecated": "Изглежда, че вашият ключ е регистриран с депрекирания метод U2F. Ще деактивираме двуфакторното удостоверяване за вас и ще изтрием вашия ключ.",
+        "u2f_deprecated_important": "Моля, регистрирайте вашия ключ в административния панел с новия метод WebAuthn.",
+        "webauthn": "Удостоверяване с WebAuthn",
+        "waiting_usb_auth": "<i>Изчакване на USB устройство...</i><br><br>Моля, докоснете бутона на вашето USB устройство сега.",
+        "waiting_usb_register": "<i>Изчакване на USB устройство...</i><br><br>Моля, въведете паролата си по-горе и потвърдете регистрацията си, като докоснете бутона на вашето USB устройство.",
+        "yubi_otp": "Удостоверяване с Yubico OTP"
+    },
+    "user": {
+        "action": "Действие",
+        "active": "Активен",
+        "active_sieve": "Активен филтър",
+        "advanced_settings": "Разширени настройки",
+        "alias": "Псевдоним",
+        "alias_create_random": "Генериране на случаен псевдоним",
+        "alias_extend_all": "Удължаване на всички псевдоними с 1 час",
+        "alias_full_date": "d.m.Y, H:i:s T",
+        "alias_remove_all": "Премахване на всички псевдоними",
+        "alias_select_validity": "Период на валидност",
+        "alias_time_left": "Оставащо време",
+        "alias_valid_until": "Валиден до",
+        "aliases_also_send_as": "Разрешено да изпраща и като потребител",
+        "aliases_send_as_all": "Не проверявай достъпа на изпращач за следните домейни и техните псевдоними",
+        "allowed_protocols": "Разрешени протоколи",
+        "app_hint": "Паролите за приложения са алтернативни пароли за вашия IMAP, SMTP, CalDAV, CardDAV и EAS вход. Потребителското име остава непроменено. SOGo уеб пощата не е достъпна чрез пароли за приложения.",
+        "app_name": "Име на приложението",
+        "app_passwds": "Пароли за приложения",
+        "apple_connection_profile": "Профил за връзка на Apple",
+        "apple_connection_profile_complete": "Този профил за връзка включва настройки за IMAP и SMTP, както и пътища за CalDAV (календари) и CardDAV (контакти) за устройство на Apple.",
+        "apple_connection_profile_mailonly": "Този профил за връзка включва настройки за IMAP и SMTP за устройство на Apple.",
+        "apple_connection_profile_with_app_password": "Генерирана е нова парола за приложение и е добавена към профила, така че не е необходимо да се въвежда парола при настройката на вашето устройство. Моля, не споделяйте файла, тъй като той предоставя пълен достъп до вашата пощенска кутия.",
+        "attribute": "Атрибут",
+        "authentication": "Удостоверяване",
+        "change_password": "Промяна на парола",
+        "change_password_hint_app_passwords": "Вашият акаунт има %d пароли за приложения, които няма да бъдат променени. За управление на тях, отидете в раздела \"Пароли за приложения\".",
+        "clear_recent_successful_connections": "Изчистване на видимите успешни връзки",
+        "client_configuration": "Показване на ръководства за настройка на пощенски клиенти и смартфони",
+        "create_app_passwd": "Създаване на парола за приложение",
+        "create_syncjob": "Създаване на нова синхронизираща задача",
+        "created_on": "Създаден на",
+        "daily": "Ежедневно",
+        "day": "ден",
+        "delete_ays": "Моля, потвърдете процеса на изтриване.",
+        "description": "Описание",
+        "direct_aliases": "Директни адреси на псевдоними",
+        "direct_aliases_desc": "Директните адреси на псевдоними се засягат от настройките за филтър за спам и политика за TLS.",
+        "direct_protocol_access": "Този потребител на пощенска кутия има <b>директен, външен достъп</b> до следните протоколи и приложения. Тази настройка се контролира от вашия администратор. Паролите за приложения могат да бъдат създадени, за да се предостави достъп до отделни протоколи и приложения.<br>Бутонът \"Уеб поща\" предоставя еднократно удостоверяване към SOGo и винаги е достъпен.",
+        "eas_reset": "Нулиране на кеша на устройствата с ActiveSync",
+        "eas_reset_help": "В много случаи нулирането на кеша на устройството ще помогне за възстановяването на повреден профил на ActiveSync.<br><b>Внимание:</b> Всички елементи ще бъдат презаредени!",
+        "eas_reset_now": "Нулиране сега",
+        "edit": "Редактиране",
+        "email": "Имейл",
+        "email_and_dav": "Имейл, календари и контакти",
+        "empty": "Няма резултати",
+        "encryption": "Криптиране",
+        "excludes": "Изключване",
+        "expire_in": "Изтича след",
+        "fido2_webauthn": "FIDO2/WebAuthn",
+        "force_pw_update": "Трябва да зададете нова парола, за да имате достъп до груповите услуги.",
+        "from": "от",
+        "generate": "генериране",
+        "hour": "час",
+        "hourly": "Часово",
+        "hours": "часа",
+        "in_use": "В употреба",
+        "interval": "Интервал",
+        "is_catch_all": "Catch-all за домейн/и",
+        "last_mail_login": "Последен вход в пощата",
+        "last_pw_change": "Последна промяна на парола",
+        "last_run": "Последно изпълнение",
+        "last_ui_login": "Последен вход в UI",
+        "loading": "Зареждане...",
+        "login_history": "История на входовете",
+        "mailbox": "Пощенска кутия",
+        "mailbox_details": "Детайли",
+        "mailbox_general": "Общи",
+        "mailbox_settings": "Настройки",
+        "messages": "съобщения",
+        "month": "месец",
+        "months": "месеца",
+        "never": "Никога",
+        "new_password": "Нова парола",
+        "new_password_repeat": "Потвърждаване на новата парола",
+        "no_active_filter": "Няма активен филтър",
+        "no_last_login": "Няма информация за последен вход в UI",
+        "no_record": "Няма запис",
+        "open_logs": "Отваряне на логове",
+        "open_webmail_sso": "Уеб поща",
+        "overview": "Преглед",
+        "password": "Парола",
+        "password_now": "Текуща парола (потвърждаване на промените)",
+        "password_repeat": "Парола (повторете)",
+        "password_reset_info": "Ако не е зададен имейл за възстановяване на парола, тази функция не може да бъде използвана.",
+        "protocols": "Протоколи",
+        "pushover_evaluate_x_prio": "Ескалиране на високоприоритетни съобщения [<code>X-Priority: 1</code>]",
+        "pushover_info": "Настройките за известия на Pushover ще се прилагат за всички чисти (не-спам) съобщения, доставени до <b>%s</b>, включително псевдоними (споделени, несподелени, таговани).",
+        "pushover_only_x_prio": "Разглеждане само на високоприоритетни съобщения [<code>X-Priority: 1</code>]",
+        "pushover_sender_array": "Разглеждане на следните адреси на изпращач <small>(разделени с запетая)</small>",
+        "pushover_sender_regex": "Съвпадение на изпращач с следния regex",
+        "pushover_sound": "Звук",
+        "pushover_text": "Текст на известието",
+        "pushover_title": "Заглавие на известието",
+        "pushover_vars": "Когато не е зададен филтър на изпращач, всички съобщения ще бъдат разглеждани.<br>Филтрите с регулярен израз, както и точните проверки на изпращач, могат да бъдат дефинирани индивидуално и ще бъдат разглеждани последователно. Те не зависят един от друг.<br>Използвайте следните променливи за текст и заглавие (моля, вземете предвид политиките за поверителност на данните)",
+        "pushover_verify": "Проверка на удостоверения",
+        "pw_recovery_email": "Имейл за възстановяване на парола",
+        "q_add_header": "Папка за нежелана поща",
+        "q_all": "Всички категории",
+        "q_reject": "Отхвърлени",
+        "quarantine_category": "Категория на уведомленията за карантина",
+        "quarantine_category_info": "Категорията \"Отхвърлени\" включва съобщения, които са били отхвърлени, докато категорията \"Папка за нежелана поща\" ще уведоми потребителя за съобщения, които са били поставени в папката за нежелана поща.",
+        "quarantine_notification": "Уведомления за карантина",
+        "quarantine_notification_info": "След като уведомлението е изпратено, елементите ще бъдат маркирани като \"уведомени\" и няма да бъдат изпращани допълнителни уведомления за този конкретен елемент.",
+        "recent_successful_connections": "Видими успешни връзки",
+        "remove": "Премахване",
+        "running": "Изпълнява се",
+        "save": "Запазване на промените",
+        "save_changes": "Запазване на промените",
+        "sender_acl_disabled": "<span class=\"badge fs-6 bg-danger\">Проверката на изпращач е деактивирана</span>",
+        "shared_aliases": "Споделени адреси на псевдоними",
+        "shared_aliases_desc": "Споделените псевдоними не се засягат от настройките за филтър за спам и политика за TLS на потребителя. Съответните настройки за спам филтър могат да бъдат направени само от администратор като настройка за домейн.",
+        "show_sieve_filters": "Показване на активния потребителски филтър на sieve",
+        "sogo_profile_reset": "Нулиране на профила на SOGo",
+        "sogo_profile_reset_help": "Това ще унищожи профила на SOGo и <b>ще изтрие всички данни за контакти и календар безвъзвратно</b>.",
+        "sogo_profile_reset_now": "Нулиране сега",
+        "spam_aliases": "Временни адреси на псевдоними",
+        "spam_score_reset": "Нулиране до настройките на сървъра по подразбиране",
+        "spamfilter": "Филтър за спам",
+        "spamfilter_behavior": "Рейтинг",
+        "spamfilter_bl": "Черен списък",
+        "spamfilter_bl_desc": "Адресите в черния списък <b>винаги</b> ще бъдат класифицирани като спам и отхвърлени. Отхвърлените съобщения <b>не</b> ще бъдат копирани в карантина. Поддържат се уайлдкардове.<br>Отхвърлените съобщения няма да бъдат доставени до папката за нежелана поща.",
+        "spamfilter_default_score": "Стойности по подразбиране",
+        "spamfilter_green": "Зелено: това съобщение не е спам",
+        "spamfilter_hint": "Първата стойност описва \"нисък резултат за спам\", втората представлява \"висок резултат за спам\".",
+        "spamfilter_red": "Червено: това съобщение е спам и ще бъде отхвърлено от сървъра",
+        "spamfilter_table_action": "Действие",
+        "spamfilter_table_add": "Добавяне на елемент",
+        "spamfilter_table_domain_policy": "политика на домейна",
+        "spamfilter_table_empty": "Няма данни за показване",
+        "spamfilter_table_remove": "премахване",
+        "spamfilter_table_rule": "Правило",
+        "spamfilter_wl": "Бял списък",
+        "spamfilter_wl_desc": "Адресите в белия списък <b>никога</b> ще бъдат класифицирани като спам. Поддържат се уайлдкардове.<br>Съобщенията, които не са класифицирани като спам, ще бъдат доставени в папката за нежелана поща, ако резултатът за спам е над стойността за висок резултат за спам.",
+        "spamfilter_yellow": "Жълто: това съобщение може да е спам, ще бъде маркирано като спам и преместено в папката за нежелана поща",
+        "status": "Статус",
+        "sync_jobs": "Синхронизиращи задачи",
+        "syncjob_EXIT_AUTHENTICATION_FAILURE": "Проблем с удостоверяването",
+        "syncjob_EXIT_AUTHENTICATION_FAILURE_USER1": "Грешно потребителско име или парола",
+        "syncjob_EXIT_CONNECTION_FAILURE": "Проблем с връзката",
+        "syncjob_EXIT_CONNECTION_FAILURE_HOST1": "Не може да се свърже с отдалечен сървър",
+        "syncjob_EXIT_OVERQUOTA": "Целевата пощенска кутия е над квотата",
+        "syncjob_EXIT_TLS_FAILURE": "Проблем с криптираната връзка",
+        "syncjob_EX_OK": "Успех",
+        "syncjob_check_log": "Проверка на лога",
+        "syncjob_last_run_result": "Резултат от последното изпълнение",
+        "tag_handling": "Настройка за тагове",
+        "tag_help_example": "Пример за тагован имейл адрес: me<b>+Facebook</b>@example.org",
+        "tag_help_explain": "В подпапка: ще бъде създадена нова подпапка под INBOX (\"INBOX/Facebook\").<br>\r\nВ тема: първото име на тага ще бъде добавено към темата на съобщението, например: \"[Facebook] Моите новини\".",
+        "tag_in_none": "Не прави нищо",
+        "tag_in_subfolder": "В подпапка",
+        "tag_in_subject": "В тема",
+        "text": "Текст",
+        "tfa_info": "Двуфакторното удостоверяване помага за защита на вашия акаунт. Ако го активирате, ще ви трябват пароли за приложения, за да влезете в приложения или услуги, които не поддържат двуфакторно удостоверяване (напр. пощенски клиенти).",
+        "title": "Заглавие",
+        "tls_enforce_in": "Принудително използване на TLS за входящи",
+        "tls_enforce_out": "Принудително използване на TLS за изходящи",
+        "tls_policy": "Политика за криптиране",
+        "tls_policy_warning": "<strong>Внимание:</strong> Ако решите да принудите преноса на криптирани съобщения, може да загубите съобщения.<br>Съобщенията, които не удовлетворяват политиката, ще бъдат върнати с твърдо отхвърляне от системата за поща.<br>Тази опция засяга вашия основен адрес на пощенска кутия (логин име), всички адреси, произтичащи от домейни на псевдоними, както и адреси на псевдоними, <b>с единствена целева пощенска кутия</b>.",
+        "user_settings": "Настройки на потребителя",
+        "username": "Потребителско име",
+        "value": "Стойност",
+        "verify": "Проверка",
+        "waiting": "Изчакване",
+        "week": "седмица",
+        "weekly": "Weekly",
+        "weeks": "седмици",
+        "with_app_password": "с парола за приложение",
+        "year": "година",
+        "years": "години"
+    },
+    "warning": {
+        "cannot_delete_self": "Не може да изтриете влезлия потребител",
+        "domain_added_sogo_failed": "Добавен домейн, но неуспешно рестартиране на SOGo, моля, проверете системните логове.",
+        "dovecot_restart_failed": "Dovecot не успя да рестартира, моля, проверете логовете",
+        "fuzzy_learn_error": "Грешка при обучение на размит хеш: %s",
+        "hash_not_found": "Хешът не е намерен или вече е изтрит",
+        "ip_invalid": "Пропуснат невалиден IP: %s",
+        "is_not_primary_alias": "Пропуснат неосновен псевдоним %s",
+        "no_active_admin": "Не може да деактивирате последния активен администратор",
+        "quota_exceeded_scope": "Квотата на домейна е надвишена: Само неограничени пощенски кутии могат да бъдат създадени в този домейн.",
+        "session_token": "Невалиден формулярен токен: Несъответствие на токена.",
+        "session_ua": "Невалиден формулярен токен: Грешка при проверка на User-Agent."
+    }
+}

+ 1 - 1
data/web/lang/lang.ca-es.json

@@ -557,4 +557,4 @@
         "week": "Setmana",
         "weeks": "Setmanes"
     }
-}
+}

+ 19 - 17
data/web/lang/lang.de-de.json

@@ -25,7 +25,7 @@
         "sogo_access": "Verwalten des SOGo-Zugriffsrechts erlauben",
         "sogo_profile_reset": "SOGo-Profil zurücksetzen",
         "spam_alias": "Temporäre E-Mail-Aliasse",
-        "spam_policy": "Blacklist/Whitelist",
+        "spam_policy": "Deny/Allowlist",
         "spam_score": "Spam-Bewertung",
         "syncjobs": "Sync Jobs",
         "tls_policy": "Verschlüsselungsrichtlinie",
@@ -147,7 +147,7 @@
         "arrival_time": "Ankunftszeit (Serverzeit)",
         "authed_user": "Auth. Benutzer",
         "ays": "Soll der Vorgang wirklich ausgeführt werden?",
-        "ban_list_info": "Übersicht ausgesperrter Netzwerke: <b>Netzwerk (verbleibende Bannzeit) - [Aktionen]</b>.<br />IPs, die zum Entsperren eingereiht werden, verlassen die Liste aktiver Banns nach wenigen Sekunden.<br />Rote Labels sind Indikatoren für aktive Blacklist-Einträge.",
+        "ban_list_info": "Übersicht ausgesperrter Netzwerke: <b>Netzwerk (verbleibende Bannzeit) - [Aktionen]</b>.<br />IPs, die zum Entsperren eingereiht werden, verlassen die Liste aktiver Banns nach wenigen Sekunden.<br />Rote Labels sind Indikatoren für aktive Allowlist-Einträge.",
         "change_logo": "Logo ändern",
         "configuration": "Konfiguration",
         "convert_html_to_text": "Konvertiere HTML zu reinem Text",
@@ -184,9 +184,9 @@
         "excludes": "Diese Empfänger ausschließen",
         "f2b_ban_time": "Bannzeit in Sekunden",
         "f2b_ban_time_increment": "Bannzeit erhöht sich mit jedem Bann",
-        "f2b_blacklist": "Blacklist für Netzwerke und Hosts",
+        "f2b_blacklist": "Denyliste für Netzwerke und Hosts",
         "f2b_filter": "Regex-Filter",
-        "f2b_list_info": "Ein Host oder Netzwerk auf der Blacklist wird immer eine Whitelist-Einheit überwiegen. <b>Die Aktualisierung der Liste dauert einige Sekunden.</b>",
+        "f2b_list_info": "Ein Host oder Netzwerk auf der Denyliste wird immer eine Allowlist-Einheit überwiegen. <b>Die Aktualisierung der Liste dauert einige Sekunden.</b>",
         "f2b_manage_external": "Fail2Ban extern verwalten",
         "f2b_manage_external_info": "Fail2ban wird die Banlist weiterhin pflegen, jedoch werden keine aktiven Regeln zum blockieren gesetzt. Die unten generierte Banlist, kann verwendet werden, um den Datenverkehr extern zu blockieren.",
         "f2b_max_attempts": "Max. Versuche",
@@ -196,10 +196,10 @@
         "f2b_parameters": "Fail2ban-Parameter",
         "f2b_regex_info": "Berücksichtigte Logs: SOGo, Postfix, Dovecot, PHP-FPM.",
         "f2b_retry_window": "Wiederholungen im Zeitraum von (s)",
-        "f2b_whitelist": "Whitelist für Netzwerke und Hosts",
+        "f2b_whitelist": "Allowliste für Netzwerke und Hosts",
         "filter_table": "Tabelle filtern",
-        "force_sso_text": "Wenn ein externer OIDC-Provider konfiguriert ist, blendet diese Option die mailcow Loginform aus und zeigt nur den Single Sign-On-Button an.",
-        "force_sso": "mailcow Login deaktivieren und nur Single Sign-On anzeigen",
+        "force_sso_text": "Wenn ein externer OIDC-Provider konfiguriert ist, blendet diese Option die mailcow-Loginform aus und zeigt nur den Single-Sign-On-Button an.",
+        "force_sso": "mailcow-Login deaktivieren und nur Single Sign-On anzeigen",
         "forwarding_hosts": "Weiterleitungs-Hosts",
         "forwarding_hosts_add_hint": "Sie können entweder IPv4-/IPv6-Adressen, Netzwerke in CIDR-Notation, Hostnamen (die zu IP-Adressen aufgelöst werden), oder Domainnamen (die zu IP-Adressen aufgelöst werden, indem ihr SPF-Record abgefragt wird oder, in dessen Abwesenheit, ihre MX-Records) angeben.",
         "forwarding_hosts_hint": "Eingehende Nachrichten werden von den hier gelisteten Hosts bedingungslos akzeptiert. Diese Hosts werden dann nicht mit DNSBLs abgeglichen oder Greylisting unterworfen. Von ihnen empfangener Spam wird nie abgelehnt, optional kann er aber in den Spam-Ordner einsortiert werden. Die übliche Verwendung für diese Funktion ist, um Mailserver anzugeben, auf denen eine Weiterleitung zu Ihrem mailcow-Server eingerichtet wurde.",
@@ -272,6 +272,7 @@
         "message": "Nachricht",
         "message_size": "Nachrichtengröße",
         "nexthop": "Next Hop",
+        "needs_restart": "benötigt Neustart",
         "no": "&#10005;",
         "no_active_bans": "Keine aktiven Banns",
         "no_new_rows": "Keine weiteren Zeilen vorhanden",
@@ -354,8 +355,8 @@
         "rspamd_com_settings": "Ein Name wird automatisch generiert. Beispielinhalte zur Einsicht stehen nachstehend bereit. Siehe auch <a href=\"https://rspamd.com/doc/configuration/settings.html#settings-structure\" target=\"_blank\">Rspamd docs</a>",
         "rspamd_global_filters": "Globale Filter-Maps",
         "rspamd_global_filters_agree": "Ich werde vorsichtig sein!",
-        "rspamd_global_filters_info": "Globale Filter-Maps steuern globales White- und Blacklisting dieses Servers.",
-        "rspamd_global_filters_regex": "Die akzeptierte Form für Einträge sind <b>ausschließlich</b> Regular Expressions.\r\n  Trotz rudimentärer Überprüfung der Map, kann es zu fehlerhaften Einträgen kommen, die Rspamd im schlechtesten Fall mit unvorhersehbarer Funktionalität bestraft.<br>\r\n  Das korrekte Format lautet \"/pattern/options\" (Beispiel: <code>/.+@domain\\.tld/i</code>).<br>\r\n  Der Name der Map beschreibt die jeweilige Funktion.<br>\r\n  Rspamd versucht die Maps umgehend aufzulösen. Bei Problemen sollte <a href=\"\" data-toggle=\"modal\" data-container=\"rspamd-mailcow\" data-target=\"#RestartContainer\">Rspamd manuell neugestartet werden</a>.<br>Elemente auf Blacklists sind von der Quarantäne ausgeschlossen.",
+        "rspamd_global_filters_info": "Globale Filter-Maps steuern globales Allow- und Denylisting dieses Servers.",
+        "rspamd_global_filters_regex": "Die akzeptierte Form für Einträge sind <b>ausschließlich</b> Regular Expressions.\r\n  Trotz rudimentärer Überprüfung der Map, kann es zu fehlerhaften Einträgen kommen, die Rspamd im schlechtesten Fall mit unvorhersehbarer Funktionalität bestraft.<br>\r\n  Das korrekte Format lautet \"/pattern/options\" (Beispiel: <code>/.+@domain\\.tld/i</code>).<br>\r\n  Der Name der Map beschreibt die jeweilige Funktion.<br>\r\n  Rspamd versucht die Maps umgehend aufzulösen. Bei Problemen sollte <a href=\"\" data-toggle=\"modal\" data-container=\"rspamd-mailcow\" data-target=\"#RestartContainer\">Rspamd manuell neugestartet werden</a>.<br>Elemente auf Denylisten sind von der Quarantäne ausgeschlossen.",
         "rspamd_settings_map": "Rspamd-Settings-Map",
         "sal_level": "Moo-Level",
         "save": "Änderungen speichern",
@@ -547,7 +548,8 @@
         "yotp_verification_failed": "Yubico OTP-Verifizierung fehlgeschlagen: %s",
         "template_exists": "Vorlage %s existiert bereits",
         "template_id_invalid": "Vorlagen-ID %s ungültig",
-        "template_name_invalid": "Name der Vorlage ungültig"
+        "template_name_invalid": "Name der Vorlage ungültig",
+        "required_data_missing": "Die benötigten Daten: %s fehlen"
     },
     "datatables": {
         "collapse_all": "Alle Einklappen",
@@ -747,7 +749,7 @@
         "sogo_visible_info": "Diese Option hat lediglich Einfluss auf Objekte, die in SOGo darstellbar sind (geteilte oder nicht-geteilte Alias-Adressen mit dem Ziel mindestens einer lokalen Mailbox).",
         "spam_alias": "Anpassen temporärer Alias-Adressen",
         "spam_filter": "Spamfilter",
-        "spam_policy": "Hinzufügen und Entfernen von Einträgen in White- und Blacklists",
+        "spam_policy": "Hinzufügen und Entfernen von Einträgen in Allow- und Denylisten",
         "spam_score": "Einen benutzerdefiniterten Spam-Score festlegen",
         "subfolder2": "Ziel-Ordner<br><small>(leer = kein Unterordner)</small>",
         "syncjob": "Sync-Job bearbeiten",
@@ -941,7 +943,7 @@
         "recipient_map_new": "Neuer Empfänger",
         "recipient_map_new_info": "Der neue Empfänger muss eine E-Mail-Adresse oder ein Domainname sein.",
         "recipient_map_old": "Original-Empfänger",
-        "recipient_map_old_info": "Der originale Empfänger muss eine E-Mail-Adresse oder ein Domainname sein.",
+        "recipient_map_old_info": "Der originäre Empfänger muss eine E-Mail-Adresse oder ein Domainname sein.",
         "recipient_maps": "Empfängerumschreibungen",
         "relay_all": "Alle Empfänger-Adressen relayen",
         "relay_unknown": "Unbekannte Mailboxen relayen",
@@ -1037,7 +1039,7 @@
         "notified": "Benachrichtigt",
         "qhandler_success": "Aktion wurde an das System übergeben. Sie dürfen dieses Fenster nun schließen.",
         "qid": "Rspamd QID",
-        "qinfo": "Das Quarantänesystem speichert abgelehnte Nachrichten in der Datenbank (dem Sender wird <em>nicht</em> signalisiert, dass seine E-Mail zugestellt wurde) als auch diese, die als Kopie in den Junk-Ordner der jeweiligen Mailbox zugestellt wurden.\r\n  <br>\"Als Spam lernen und löschen\" lernt Nachrichten nach bayesscher Statistik als Spam und erstellt Fuzzy Hashes ausgehend von der jeweiligen Nachricht, um ähnliche Inhalte zukünftig zu unterbinden.\r\n  <br>Der Prozess des Lernens kann abhängig vom System zeitintensiv sein.<br>Auf Blacklists vorkommende Elemente sind von der Quarantäne ausgeschlossen.",
+        "qinfo": "Das Quarantänesystem speichert abgelehnte Nachrichten in der Datenbank (dem Sender wird <em>nicht</em> signalisiert, dass seine E-Mail zugestellt wurde) als auch diese, die als Kopie in den Junk-Ordner der jeweiligen Mailbox zugestellt wurden.\r\n  <br>\"Als Spam lernen und löschen\" lernt Nachrichten nach bayesscher Statistik als Spam und erstellt Fuzzy Hashes ausgehend von der jeweiligen Nachricht, um ähnliche Inhalte zukünftig zu unterbinden.\r\n  <br>Der Prozess des Lernens kann abhängig vom System zeitintensiv sein.<br>Auf Denylisten vorkommende Elemente sind von der Quarantäne ausgeschlossen.",
         "qitem": "Quarantäneeintrag",
         "quarantine": "Quarantäne",
         "quick_actions": "Aktionen",
@@ -1326,8 +1328,8 @@
         "spam_score_reset": "Auf Server-Standard zurücksetzen",
         "spamfilter": "Spamfilter",
         "spamfilter_behavior": "Bewertung",
-        "spamfilter_bl": "Blacklist",
-        "spamfilter_bl_desc": "Für E-Mail-Adressen, die vom Spamfilter <b>immer</b> als Spam erfasst und abgelehnt werden. Die Quarantäne-Funktion ist für diese Nachrichten deaktiviert. Die Verwendung von Wildcards ist gestattet. Ein Filter funktioniert lediglich für direkte nicht-\"Catch All\" Alias-Adressen (Alias-Adressen mit lediglich einer Mailbox als Ziel-Adresse) sowie die Mailbox-Adresse selbst.",
+        "spamfilter_bl": "Denyliste",
+        "spamfilter_bl_desc": "Für E-Mail-Adressen, die vom Spamfilter <b>immer</b> als Spam erfasst und abgelehnt werden. Die Quarantäne-Funktion ist für diese Nachrichten <b>deaktiviert</b>. Die Verwendung von Wildcards ist gestattet. Ein Filter funktioniert lediglich für direkte Nicht-„Catch-All“-Alias-Adressen (Alias-Adressen mit lediglich einer Mailbox als Ziel-Adresse) sowie die Mailbox-Adresse selbst.",
         "spamfilter_default_score": "Standardwert",
         "spamfilter_green": "Grün: Die Nachricht ist kein Spam",
         "spamfilter_hint": "Der erste Wert beschreibt den \"low spam score\", der zweite Wert den \"high spam score\".",
@@ -1338,8 +1340,8 @@
         "spamfilter_table_empty": "Keine Einträge vorhanden",
         "spamfilter_table_remove": "Entfernen",
         "spamfilter_table_rule": "Regel",
-        "spamfilter_wl": "Whitelist",
-        "spamfilter_wl_desc": "Für E-Mail-Adressen, die vom Spamfilter <b>nicht</b> erfasst werden sollen. Die Verwendung von Wildcards ist gestattet. Ein Filter funktioniert lediglich für direkte nicht-\"Catch All\" Alias-Adressen (Alias-Adressen mit lediglich einer Mailbox als Ziel-Adresse) sowie die Mailbox-Adresse selbst.",
+        "spamfilter_wl": "Allowliste",
+        "spamfilter_wl_desc": "Für E-Mail-Adressen, die vom Spamfilter <b>nicht</b> erfasst werden sollen. Die Verwendung von Wildcards ist gestattet. Ein Filter funktioniert lediglich für direkte Nicht-„Catch-All“-Alias-Adressen (Alias-Adressen mit lediglich einer Mailbox als Ziel-Adresse) sowie die Mailbox-Adresse selbst.",
         "spamfilter_yellow": "Gelb: Die Nachricht ist vielleicht Spam, wird als Spam markiert und in den Junk-Ordner verschoben",
         "status": "Status",
         "sync_jobs": "Sync Jobs",

+ 14 - 13
data/web/lang/lang.en-gb.json

@@ -25,7 +25,7 @@
         "sogo_access": "Allow management of SOGo access",
         "sogo_profile_reset": "Reset SOGo profile",
         "spam_alias": "Temporary aliases",
-        "spam_policy": "Blacklist/Whitelist",
+        "spam_policy": "Denylist/Allowlist",
         "spam_score": "Spam score",
         "syncjobs": "Sync jobs",
         "tls_policy": "TLS policy",
@@ -151,7 +151,7 @@
         "arrival_time": "Arrival time (server time)",
         "authed_user": "Auth. user",
         "ays": "Are you sure you want to proceed?",
-        "ban_list_info": "See a list of banned IPs below: <b>network (remaining ban time) - [actions]</b>.<br />IPs queued to be unbanned will be removed from the active ban list within a few seconds.<br />Red labels indicate active permanent bans by blacklisting.",
+        "ban_list_info": "See a list of banned IPs below: <b>network (remaining ban time) - [actions]</b>.<br />IPs queued to be unbanned will be removed from the active ban list within a few seconds.<br />Red labels indicate active permanent bans by denylisting.",
         "change_logo": "Change logo",
         "logo_normal_label": "Normal",
         "logo_dark_label": "Inverted for dark mode",
@@ -190,9 +190,9 @@
         "excludes": "Excludes these recipients",
         "f2b_ban_time": "Ban time (s)",
         "f2b_ban_time_increment": "Ban time is incremented with each ban",
-        "f2b_blacklist": "Blacklisted networks/hosts",
+        "f2b_blacklist": "Denylisted networks/hosts",
         "f2b_filter": "Regex filters",
-        "f2b_list_info": "A blacklisted host or network will always outweigh a whitelist entity. <b>List updates will take a few seconds to be applied.</b>",
+        "f2b_list_info": "A denylisted host or network will always outweigh a allowlist entity. <b>List updates will take a few seconds to be applied.</b>",
         "f2b_manage_external": "Manage Fail2Ban externally",
         "f2b_manage_external_info": "Fail2ban will still maintain the banlist, but it will not actively set rules to block traffic. Use the generated banlist below to externally block the traffic.",
         "f2b_max_attempts": "Max. attempts",
@@ -202,7 +202,7 @@
         "f2b_parameters": "Fail2ban parameters",
         "f2b_regex_info": "Logs taken into consideration: SOGo, Postfix, Dovecot, PHP-FPM.",
         "f2b_retry_window": "Retry window (s) for max. attempts",
-        "f2b_whitelist": "Whitelisted networks/hosts",
+        "f2b_whitelist": "Allowlisted networks/hosts",
         "filter": "Filter",
         "filter_table": "Filter table",
         "force_sso_text": "If an external OIDC provider is configured, this option hides the default mailcow login forms and only shows the Single Sign-On button",
@@ -279,6 +279,7 @@
         "message": "Message",
         "message_size": "Message size",
         "nexthop": "Next hop",
+        "needs_restart": "needs restart",
         "no": "&#10005;",
         "no_active_bans": "No active bans",
         "no_new_rows": "No further rows available",
@@ -364,8 +365,8 @@
         "rspamd_com_settings": "A setting name will be auto-generated, please see the example presets below. For more details see <a href=\"https://rspamd.com/doc/configuration/settings.html#settings-structure\" target=\"_blank\">Rspamd docs</a>",
         "rspamd_global_filters": "Global filter maps",
         "rspamd_global_filters_agree": "I will be careful!",
-        "rspamd_global_filters_info": "Global filter maps contain different kind of global black and whitelists.",
-        "rspamd_global_filters_regex": "Their names explain their purpose. All content must contain valid regular expression in the format of \"/pattern/options\" (e.g. <code>/.+@domain\\.tld/i</code>).<br>\r\n  Although rudimentary checks are being executed on each line of regex, Rspamds functionality can be broken, if it fails to read the syntax correctly.<br>\r\n  Rspamd will try to read the map content when changed. If you experience problems, <a href=\"\" data-toggle=\"modal\" data-container=\"rspamd-mailcow\" data-target=\"#RestartContainer\">restart Rspamd</a> to enforce a map reload.<br>Blacklisted elements are excluded from quarantine.",
+        "rspamd_global_filters_info": "Global filter maps contain different kind of global deny and allowlists.",
+        "rspamd_global_filters_regex": "Their names explain their purpose. All content must contain valid regular expression in the format of \"/pattern/options\" (e.g. <code>/.+@domain\\.tld/i</code>).<br>\r\n  Although rudimentary checks are being executed on each line of regex, Rspamds functionality can be broken, if it fails to read the syntax correctly.<br>\r\n  Rspamd will try to read the map content when changed. If you experience problems, <a href=\"\" data-toggle=\"modal\" data-container=\"rspamd-mailcow\" data-target=\"#RestartContainer\">restart Rspamd</a> to enforce a map reload.<br>Denylisted elements are excluded from quarantine.",
         "rspamd_settings_map": "Rspamd settings map",
         "sal_level": "Moo level",
         "save": "Save changes",
@@ -750,7 +751,7 @@
         "sogo_visible_info": "This option only affects objects, that can be displayed in SOGo (shared or non-shared alias addresses pointing to at least one local mailbox). If hidden, an alias will not appear as selectable sender in SOGo.",
         "spam_alias": "Create or change time limited alias addresses",
         "spam_filter": "Spam filter",
-        "spam_policy": "Add or remove items to white-/blacklist",
+        "spam_policy": "Add or remove items to allow-/denylist",
         "spam_score": "Set a custom spam score",
         "subfolder2": "Sync into subfolder on destination<br><small>(empty = do not use subfolder)</small>",
         "syncjob": "Edit sync job",
@@ -1039,7 +1040,7 @@
         "notified": "Notified",
         "qhandler_success": "Request successfully sent to the system. You can now close the window.",
         "qid": "Rspamd QID",
-        "qinfo": "The quarantine system will save rejected mail to the database (the sender will <em>not</em> be given the impression of a delivered mail) as well as mail, that is delivered as copy into the Junk folder of a mailbox.\r\n  <br>\"Learn as spam and delete\" will learn a message as spam via Bayesian theorem and also calculate fuzzy hashes to deny similar messages in the future.\r\n  <br>Please be aware that learning multiple messages can be - depending on your system - time consuming.<br>Blacklisted elements are excluded from the quarantine.",
+        "qinfo": "The quarantine system will save rejected mail to the database (the sender will <em>not</em> be given the impression of a delivered mail) as well as mail, that is delivered as copy into the Junk folder of a mailbox.\r\n  <br>\"Learn as spam and delete\" will learn a message as spam via Bayesian theorem and also calculate fuzzy hashes to deny similar messages in the future.\r\n  <br>Please be aware that learning multiple messages can be - depending on your system - time consuming.<br>Denylisted elements are excluded from the quarantine.",
         "qitem": "Quarantine item",
         "quarantine": "Quarantine",
         "quick_actions": "Actions",
@@ -1337,8 +1338,8 @@
         "spam_score_reset": "Reset to server default",
         "spamfilter": "Spam filter",
         "spamfilter_behavior": "Rating",
-        "spamfilter_bl": "Blacklist",
-        "spamfilter_bl_desc": "Blacklisted email addresses to <b>always</b> classify as spam and reject. Rejected mail will <b>not</b> be copied to quarantine. Wildcards may be used. A filter is only applied to direct aliases (aliases with a single target mailbox) excluding catch-all aliases and a mailbox itself.",
+        "spamfilter_bl": "Denylist",
+        "spamfilter_bl_desc": "Denylisted email addresses to <b>always</b> classify as spam and reject. Rejected mail will <b>not</b> be copied to quarantine. Wildcards may be used. A filter is only applied to direct aliases (aliases with a single target mailbox) excluding catch-all aliases and a mailbox itself.",
         "spamfilter_default_score": "Default values",
         "spamfilter_green": "Green: this message is not spam",
         "spamfilter_hint": "The first value describes the \"low spam score\", the second represents the \"high spam score\".",
@@ -1349,8 +1350,8 @@
         "spamfilter_table_empty": "No data to display",
         "spamfilter_table_remove": "remove",
         "spamfilter_table_rule": "Rule",
-        "spamfilter_wl": "Whitelist",
-        "spamfilter_wl_desc": "Whitelisted email addresses are programmed to <b>never</b> classify as spam. Wildcards may be used. A filter is only applied to direct aliases (aliases with a single target mailbox) excluding catch-all aliases and a mailbox itself.",
+        "spamfilter_wl": "Allowlist",
+        "spamfilter_wl_desc": "Allowlisted email addresses are programmed to <b>never</b> classify as spam. Wildcards may be used. A filter is only applied to direct aliases (aliases with a single target mailbox) excluding catch-all aliases and a mailbox itself.",
         "spamfilter_yellow": "Yellow: this message may be spam, will be tagged as spam and moved to your junk folder",
         "status": "Status",
         "sync_jobs": "Sync jobs",

+ 456 - 36
data/web/lang/lang.es-es.json

@@ -10,11 +10,11 @@
         "quarantine": "Acciones de cuarentena",
         "quarantine_attachments": "Archivos ajuntos en cuarentena",
         "quarantine_notification": "Notificaciones de cuarentena",
-        "ratelimit": "Rate limit",
+        "ratelimit": "Límite de peticiones",
         "recipient_maps": "Rutas del destinatario",
         "sogo_profile_reset": "Resetear perfil SOGo",
         "spam_alias": "Aliases temporales",
-        "spam_policy": "Lista blanca/negra",
+        "spam_policy": "Lista de bloqueo/desbloqueo",
         "spam_score": "Puntuación de spam",
         "syncjobs": "Trabajos de sincronización",
         "tls_policy": "Póliza de TLS",
@@ -25,8 +25,10 @@
         "quarantine_category": "Cambiar categoría de las notificaciones de cuarentena",
         "domain_relayhost": "Cambiar relayhost por un dominio",
         "extend_sender_acl": "Permitir extender la ACL del remitente por direcciones externas",
-        "pw_reset": "Permitir el reset  de la contraseña del usario mailcow",
-        "sogo_access": "Permitir la gestión del acceso a SOGo"
+        "pw_reset": "Permitir el restablecimiento de la contraseña del usuario mailcow",
+        "sogo_access": "Permitir la gestión del acceso a SOGo",
+        "mailbox_relayhost": "Cambiar el host de reenvío para un buzón",
+        "smtp_ip_access": "Cambiar hosts permitidos para SMTP"
     },
     "add": {
         "activate_filter_warn": "Todos los demás filtros se desactivarán cuando este filtro se active.",
@@ -34,7 +36,7 @@
         "add": "Agregar",
         "add_domain_only": "Agregar dominio solamente",
         "add_domain_restart": "Agregar dominio y reiniciar SOGo",
-        "alias_address": "Dirección(es) alias:",
+        "alias_address": "Dirección(es) alias",
         "alias_address_info": "<small>Dirección(es) de correo completa(s) ó @dominio.com, para atrapar todos los mensajes para un dominio (separado por coma). <b>Dominios que existan en mailcow solamente</b>.</small>",
         "alias_domain": "Dominio alias",
         "alias_domain_info": "<small>Nombres de dominio válidos solamente (separado por coma).</small>",
@@ -45,13 +47,13 @@
         "delete1": "Eliminar de la fuente cuando se complete",
         "delete2": "Eliminar mensajes en el destino que no están en la fuente",
         "delete2duplicates": "Eliminar duplicados en el destino",
-        "description": "Descripción:",
+        "description": "Descripción",
         "destination": "Destino",
         "domain": "Dominio",
-        "domain_quota_m": "Cuota total del dominio (MiB):",
+        "domain_quota_m": "Cuota total del dominio (MiB)",
         "enc_method": "Método de cifrado",
         "exclude": "Excluir objectos (regex)",
-        "full_name": "Nombre completo:",
+        "full_name": "Nombre completo",
         "gal": "Lista global de direcciones (GAL)",
         "gal_info": "El GAL contiene todos los objetos de un dominio y no puede ser editado por ningún usuario. Falta información de disponibilidad en SOGo, si está desactivada. <b>Reinicia SOGo para aplicar los cambios.</b>",
         "generate": "Generar",
@@ -61,20 +63,20 @@
         "hostname": "Host",
         "kind": "Tipo",
         "mailbox_quota_def": "Cuota de buzón predeterminada",
-        "mailbox_quota_m": "Máx. cuota por buzón (MiB):",
-        "mailbox_username": "Nombre de usuario (parte izquierda de una dirección de correo):",
-        "max_aliases": "Máx. alias posibles:",
-        "max_mailboxes": "Máx. buzones posibles:",
+        "mailbox_quota_m": "Máx. cuota por buzón (MiB)",
+        "mailbox_username": "Nombre de usuario (parte izquierda de una dirección de correo)",
+        "max_aliases": "Máx. alias posibles",
+        "max_mailboxes": "Máx. buzones posibles",
         "mins_interval": "Intervalo de sondeo (minutos)",
         "multiple_bookings": "Múltiples reservas",
         "nexthop": "Siguiente destino",
-        "password": "Constraseña:",
-        "password_repeat": "Confirmación de contraseña (repetir):",
+        "password": "Contraseña",
+        "password_repeat": "Confirmación de contraseña (repetir)",
         "port": "Puerto",
-        "post_domain_add": "<b>Nota:</b> Necesitarás reiniciar el contenedor del servicio SOGo despues de agregar un nuevo dominio",
-        "quota_mb": "Cuota (MiB):",
+        "post_domain_add": "Es necesario reiniciar el contenedor del servicio SOGo, \"sogo-mailcow\", tras agregar un nuevo dominio.<br><br>Además, la configuración DNS de los dominios debería ser comprobada. En cuanto la configuración DNS se apruebe, reinicie \"acme-mailcow\" para generar automáticamente certificados para su nuevo dominio (autoconfig.&lt;dominio&gt;, autodiscover.&lt;dominio&gt;).<br>Este paso es opcional y se reintentará cada 24 horas.",
+        "quota_mb": "Cuota (MiB)",
         "relay_all": "Retransmitir todos los destinatarios",
-        "relay_all_info": "<small>Si eliges <b>no</b> retransmitir a todos los destinatarios, necesitas agregar un buzón \"ciego\" por cada destinatario que debe ser retransmitido.</small>",
+        "relay_all_info": "↪ Si se elige <b>no</b> retransmitir todos los destinatarios, será necesario agregar un buzón \"ciego\" por cada destinatario que deba ser retransmitido.",
         "relay_domain": "Retransmitir este dominio",
         "select": "Por favor selecciona...",
         "select_domain": "Por favor elige un dominio primero",
@@ -83,7 +85,7 @@
         "skipcrossduplicates": "Omitir mensajes duplicados en carpetas (orden de llegada)",
         "subscribeall": "Suscribirse a todas las carpetas",
         "syncjob": "Añadir trabajo de sincronización",
-        "syncjob_hint": "Ten en cuenta que las contraseñas deben guardarse en texto sin cifrado",
+        "syncjob_hint": "Tenga en cuenta que las contraseñas deben guardarse en texto plano sin cifrar",
         "target_address": "Direcciones destino:",
         "target_address_info": "<small>Dirección(es) de correo completa(s) (separado por coma).</small>",
         "target_domain": "Dominio destino:",
@@ -100,7 +102,13 @@
         "comment_info": "Los comentarios privados no son visibles al usuario, mientras que los comentarios públicos aparecerán sobre la información general del usuario",
         "dry": "Simular la sincronización",
         "private_comment": "Comentario privado",
-        "app_passwd_protocols": "Protocolos autorizados para la contraseña de la aplicación"
+        "app_passwd_protocols": "Protocolos autorizados para la contraseña de la aplicación",
+        "relay_transport_info": "<div class=\"label label-info\">Información</div> Puede definir mapas de transporte para un destino personalizado para este dominio. En caso de no definirlo, se realizará una búsqueda MX.",
+        "bcc_dest_format": "El destino del CCO debe ser una única dirección de correo electrónico válida.<br>Si necesita enviar una copia a varias direcciones, cree un alias y utilícelo aquí.",
+        "domain_matches_hostname": "El dominio %s coincide con el nombre de host",
+        "relay_unknown_only": "Reenviar sólo los buzones no existentes. Los buzones existentes se entregarán localmente.",
+        "relayhost_wrapped_tls_info": "Por favor, no utilice puertos con TLS (habitualmente, el puerto 465). <br>Utilice cualquier puerto no cifrado y emita STARTTLS. Se puede crear una política para imponer TLS en \"TLS policy maps\".",
+        "tags": "Etiquetas"
     },
     "admin": {
         "access": "Acceso",
@@ -129,7 +137,7 @@
         "app_name": "Nombre de la app",
         "apps_name": "Nombre \"mailcow Apps\"",
         "arrival_time": "Tiempo de llegada (hora del servidor)",
-        "ban_list_info": "Lista de IPs bloqueadas: <b>red (tiempo de prohibición restante) - [acciones]</b>.<br />Las IPs en cola para ser desbloqueadas se eliminarán de la lista de bloqueos en unos pocos segundos.<br />Las etiquetas rojas indican bloqueos permanentes mediante la inclusión en la lista negra.",
+        "ban_list_info": "Lista de direcciones IP bloqueadas: <b>red (tiempo de prohibición restante) - [acciones]</b>.<br />Las direcciones IP en cola para ser desbloqueadas se eliminarán de la lista de bloqueos en unos segundos.<br />Las etiquetas rojas indican bloqueos permanentes por inclusión en la lista de bloqueo.",
         "change_logo": "Cambiar logo",
         "configuration": "Configuración",
         "credentials_transport_warning": "<b>Advertencia</b>: al agregar una nueva entrada de ruta de transporte se actualizarán las credenciales para todas las entradas con una columna de \"siguiente destino\" coincidente.",
@@ -157,15 +165,15 @@
         "excludes": "Excluye a estos destinatarios",
         "f2b_ban_time": "Tiempo de restricción (s)",
         "f2b_ban_time_increment": "Tiempo de restricción se incrementa con cada restricción",
-        "f2b_blacklist": "Redes y hosts en lista negra",
-        "f2b_list_info": "Un host o red en lista negra siempre superará a una entidad de la lista blanca. <b>Las actualizaciones de la lista tardarán unos segundos en aplicarse.</b>",
+        "f2b_blacklist": "Redes y hosts en lista de bloqueo",
+        "f2b_list_info": "Un host o red en lista de bloqueo siempre tendrá prioridad sobre una entidad de la lista de desbloqueo. <b>Las actualizaciones de la lista tardarán unos segundos en aplicarse.</b>",
         "f2b_max_attempts": "Max num. de intentos",
         "f2b_max_ban_time": "Max tiempo de restricción (s)",
         "f2b_netban_ipv4": "Tamaño de subred IPv4 para aplicar la restricción (8-32)",
         "f2b_netban_ipv6": "Tamaño de subred IPv6 para aplicar la restricción (8-128)",
         "f2b_parameters": "Parametros Fail2ban",
         "f2b_retry_window": "Ventana de tiempo entre reintentos",
-        "f2b_whitelist": "Redes y hosts en lista blanca",
+        "f2b_whitelist": "Redes y hosts en lista de desbloqueo",
         "filter_table": "Filtrar tabla",
         "forwarding_hosts": "Hosts de reenvío",
         "forwarding_hosts_add_hint": "Se puede especificar direcciones IPv4 / IPv6, redes en notación CIDR, nombres de host (que se resolverán en direcciones IP) o dominios (que se resolverán en direcciones IP consultando registros SPF o, en su defecto, registros MX)",
@@ -253,7 +261,146 @@
         "unban_pending": "Desbloqueo pendiente",
         "unchanged_if_empty": "Si no hay cambios déjalo en blanco",
         "upload": "Cargar",
-        "username": "Nombre de usuario"
+        "username": "Nombre de usuario",
+        "force_sso_text": "Si se configura un proveedor OIDC externo, esta opción oculta los formularios por defecto de inicio de sesión y muestra solamente el botón de inicio de sesión único",
+        "admin_quicklink": "Ocultar enlace rápido a página de inicio de sesión para administradores",
+        "iam_default_template_description": "Si no se asigna una plantilla a un usuario, se utilizará la plantilla por defecto para crear el buzón, pero no para actualizarlo.",
+        "reset_password_vars": "<code>{{link}}</code> El enlace generado para el restablecimiento de contraseña<br><code>{{username}}</code> El buzón del usuario que ha solicitado el restablecimiento de contraseña<br><code>{{username2}}</code> La dirección del buzón de recuperación de contraseña<br><code>{{date}}</code> La fecha en que se realizó la solicitud de restablecimiento de contraseña<br><code>{{token_lifetime}}</code> El periodo de vigencia del token en minutos<br><code>{{hostname}}</code> El servidor Mailcow",
+        "api_info": "La API es un trabajo en curso. La documentación se puede encontrar en <a href=\"/api\">/api</a>",
+        "iam_description": "Configurar un proveedor de autenticación externo<br>Los buzones de usuario se crearán automáticamente la primera vez que se inicie sesión, siempre que se hayan configurado las equivalencias de atributos",
+        "ui_header_announcement_help": "El anuncio será visible para todos los usuarios conectados y también en la pantalla de inicio de sesión.",
+        "html": "HTML",
+        "oauth2_redirect_uri": "URI de redirección",
+        "quarantine_bcc": "Remitir una copia de todas las notificaciones (CCO) a este destinatario: <br><small>Dejar en blanco para desactivar. <b>Correo sin firmar y sin comprobar. Debe entregarse solo internamente.</b></small>",
+        "quarantine_redirect": "<b>Redirigir todas las notificaciones</b> a este destinatario:<br><small>Dejar en blanco para desactivar. <b>Correo sin firmar y sin comprobar. Debe entregarse sólo internamente.</b></small>",
+        "iam_authorize_url": "Endpoint de autorización",
+        "sal_level": "Nivel de Moo",
+        "ui_footer": "Pie de página (se permite HTML)",
+        "is_mx_based": "Basado en MX",
+        "password_reset_tmpl_text": "Plantilla de texto",
+        "password_length": "Longitud de la contraseña",
+        "quicklink_text": "Mostrar u ocultar enlaces rápidos a otras páginas de inicio bajo el formulario de inicio de sesión",
+        "password_policy_lowerupper": "Debe contener caracteres en minúsculas y mayúsculas",
+        "rspamd_global_filters_regex": "Sus nombres indican su propósito. Todo el contenido debe constar de expresiones regulares válidas con el formato \"/patrón/opciones\" (por ejemplo, <code>/.+@domain\\.tld/i</code>).<br>\n  Si bien se llevan a cabo comprobaciones básicas de cada expresión regular, la funcionalidad de Rspamd puede verse inutilizada, si no consigue interpretar correctamente la sintaxis utilizada.<br>\n  Rspamd intentará leer el contenido del mapa cuando éste se modifique. En caso de de problemas, <a href=\"\" data-toggle=\"modal\" data-container=\"rspamd-mailcow\" data-target=\"#RestartContainer\">reinicie Rspamd</a> para forzar una recarga del mapa.<br>Los elementos incluidos en listas de bloqueo se excluyen de la cuarentena.",
+        "iam_use_ssl_info": "Si se habilita SSL y el puerto se establece en el 389, se cambiará automáticamente al 636.",
+        "iam_login_provisioning": "Crear usuarios automáticamente al iniciar sesión",
+        "iam_periodic_full_sync": "Sincronización completa periódica",
+        "iam_port": "Puerto",
+        "iam_realm": "Ámbito",
+        "iam_redirect_url": "URL de redirección",
+        "iam_server_url": "URL del servidor",
+        "iam_sso": "Inicio de sesión único (SSO)",
+        "iam_sync_interval": "Intervalo de sincronización/importación (minutos)",
+        "iam_test_connection": "Comprobar conexión",
+        "iam_token_url": "Endpoint del token",
+        "iam_username_field": "Campo de nombre de usuario",
+        "iam_use_ssl": "Utilizar SSL",
+        "iam_use_tls": "Utilizar STARTTLS",
+        "iam_userinfo_url": "Endopint de información de usuario",
+        "iam_use_tls_info": "Si se habilita TLS, se debe utilizar el puerto por defecto del servidor LDAP (389). No se permiten puertos SSL.",
+        "iam_version": "Versión",
+        "ignore_ssl_error": "Ignorar errores de SSL",
+        "ip_check": "Comprobación IP",
+        "ip_check_disabled": "La comprobación de IP está desactivada. Puede activarla en<br> <strong>Sistema > Configuración > Opciones > Personalizar</strong>.",
+        "ip_check_opt_in": "Aceptar utilizar el servicio de terceros <strong>ipv4.mailcow.email</strong> y <strong>ipv6.mailcow.email</strong> para resolver direcciones IP externas.",
+        "last_applied": "Aplicado por última vez",
+        "license_info": "No es obligatorio contar con una licencia, pero ayuda a continuar el desarrollo.<br><a href=\"https://www.servercow.de/mailcow?lang=en#sal\" target=\"_blank\" alt=\"SAL order\">Indique aquí su GUID</a> o <a href=\"https://www.servercow.de/mailcow?lang=en#support\" target=\"_blank\" alt=\"Support order\">adquiera servicios de soporte para su instalación de Mailcow.</a>",
+        "login_time": "Hora de inicio de sesión",
+        "lookup_mx": "Destino es una expresión regular con la que contrastar el nombre MX (<code>.*\\.google\\.com</code> para dirigir todo el tráfico dirigido a un MX que termina en google.com a través de este salto)",
+        "message": "Mensaje",
+        "no": "&#10005;",
+        "optional": "opcional",
+        "app_hide": "Ocultar para inicio de sesión",
+        "convert_html_to_text": "Convertir HTML a texto plano",
+        "cors_settings": "Configuración de CORS",
+        "customer_id": "ID de cliente",
+        "dkim_overwrite_key": "Sobrescribir la clave DKIM existente",
+        "domain_admin": "Administrador de dominio",
+        "f2b_manage_external": "Gestionar Fail2Ban de manera externa",
+        "f2b_manage_external_info": "Fail2Ban conservará la lista de bloqueo, pero no establecerá activamente reglas para bloquear el tráfico. Utilizar la lista de bloqueo siguiente para bloquear externamente el tráfico.",
+        "filter": "Filtrar",
+        "admins": "Administradores",
+        "admins_ldap": "Administradores de LDAP",
+        "advanced_settings": "Configuración avanzada",
+        "allowed_methods": "Access-Control-Allow-Methods",
+        "allowed_origins": "Access-Control-Allow-Origin",
+        "api_read_only": "Acceso de sólo lectura",
+        "api_read_write": "Acceso de lectura y escritura",
+        "api_skip_ip_check": "Omitir la comprobación de la IP para la API",
+        "authed_user": "Usuario autentificado",
+        "ays": "¿Está seguro de querer continuar?",
+        "logo_normal_label": "Normal",
+        "logo_dark_label": "Invertido para modo oscuro",
+        "copy_to_clipboard": "¡Texto copiado al portapapeles!",
+        "login_page": "Inicio de sesión",
+        "domainadmin_quicklink": "Ocultar enlace rápido a página de inicio de sesión para administradores de dominios",
+        "domain_s": "Dominio(s)",
+        "f2b_filter": "Filtros regex",
+        "f2b_regex_info": "Registros tomados en consideración: SOGo, Postfix, Dovecot, PHP-FPM.",
+        "force_sso": "Deshabilitar el inicio de sesión de Mailcow y mostrar solamente el inicio de sesión único",
+        "guid": "GUID - ID de instancia único",
+        "guid_and_license": "GUID y licencia",
+        "hash_remove_info": "Al eliminar un hash de límite de velocidad (si todavía existe) se reiniciará su contador por completo.<br> Cada hash se indica con un color individual.",
+        "iam": "Proveedor de identidad",
+        "iam_attribute_field": "Campo de atributo",
+        "iam_auth_flow": "Flujo de autenticación",
+        "iam_basedn": "DN de base",
+        "iam_client_id": "ID de cliente",
+        "iam_client_secret": "Secreto de cliente",
+        "iam_client_scopes": "Ámbitos de cliente",
+        "iam_default_template": "Plantilla por defecto",
+        "iam_host": "Host",
+        "iam_host_info": "Introduzca uno o más hosts de LDAP, separados por comas.",
+        "iam_import_users": "Importar usuarios",
+        "iam_mapping": "Equivalencias de atributos",
+        "needs_restart": "necesita reinicio",
+        "oauth2_apps": "Aplicaciones OAuth2",
+        "oauth2_add_client": "Añadir cliente OAuth2",
+        "oauth2_renew_secret": "Generar nuevo secreto de cliente",
+        "oauth2_revoke_tokens": "Revocar todos los tokens de cliente",
+        "options": "Opciones",
+        "password_policy": "Política de contraseñas",
+        "password_policy_chars": "Debe contener al menos un caracter alfabético",
+        "password_policy_length": "La longitud mínima de la contraseña es %d",
+        "password_policy_numbers": "Debe contener al menos un número",
+        "password_policy_special_chars": "Debe contener caracteres especiales",
+        "password_reset_info": "Si no se indica una dirección para la recuperación de contraseñas, esta función no puede utilizarse.",
+        "password_reset_settings": "Configuración de recuperación de contraseña",
+        "password_reset_tmpl_html": "Plantilla HTML",
+        "password_settings": "Configuración de contraseña",
+        "priority": "Prioridad",
+        "quarantine_max_score": "Descartar notificación si la puntuación de spam de un mensaje de correo es mayor que este valor:<br><small>Por defecto 9999.0</small>",
+        "queue_unban": "desbloquear",
+        "regex_maps": "Mapas regex",
+        "relay_rcpt": "Dirección \"Para:\"",
+        "reset_limit": "Eliminar hash",
+        "restore_template": "Dejar en blanco para restablecer la plantilla por defecto",
+        "rsetting_no_selection": "Seleccione una regla",
+        "rsettings_preset_3": "Permitir solamente remitentes específicos para un buzón (utilizar únicamente como buzón interno)",
+        "rsettings_preset_4": "Deshabilitar Rspamd para un dominio",
+        "rspamd_global_filters": "Mapas de filtrado globales",
+        "rspamd_global_filters_agree": "¡Tendré cuidado!",
+        "rspamd_global_filters_info": "Los mapas de filtrado globales contienen distintos tipos de listos de bloqueo y desbloqueo.",
+        "service": "Servicio",
+        "service_id": "ID de servicio",
+        "success": "Éxito",
+        "task": "Tarea",
+        "time": "Tiempo",
+        "title": "Título",
+        "transport_dest_format": "Regex o sintaxis: ejemplo.org, .ejemplo.org, *, buzon@ejemplo.org (se pueden introducir varios valores separados por comas)",
+        "transport_test_rcpt_info": "&#8226; Utilizar null@hosted.mailcow.de para comprobar la retransmisión a un destino externo.",
+        "ui_header_announcement": "Anuncios",
+        "ui_header_announcement_content": "Texto (se permite HTML)",
+        "ui_header_announcement_select": "Seleccionar tipo de anuncio",
+        "ui_header_announcement_type": "Tipo",
+        "ui_header_announcement_type_danger": "Muy importante",
+        "ui_header_announcement_type_info": "Información",
+        "ui_header_announcement_type_warning": "Importante",
+        "user_link": "Enlace de usuario",
+        "user_quicklink": "Ocultar enlace rápido a página de inicio de sesión de usuario",
+        "validate_license_now": "Validar el GUID contra el servidor de licencias",
+        "verify": "Verificar",
+        "yes": "&#10003;"
     },
     "danger": {
         "access_denied": "Acceso denegado o datos del formulario inválidos",
@@ -341,7 +488,60 @@
         "username_invalid": "Nombre de usuario no se puede utilizar",
         "validity_missing": "Por favor asigna un periodo de validez",
         "value_missing": "Por favor proporcione todos los valores",
-        "yotp_verification_failed": "Verificación Yubico OTP fallida: %s"
+        "yotp_verification_failed": "Verificación Yubico OTP fallida: %s",
+        "last_key": "La última clave no se puede eliminar, en su lugar desactive la autenticación de doble factor.",
+        "img_dimensions_exceeded": "La imagen excede el tamaño máximo permitido",
+        "authsource_in_use": "El proveedor de identidades no se puede cambiar al estar en uso por uno o más usuario(s).",
+        "app_name_empty": "El nombre de la aplicación no puede quedar vacío",
+        "recovery_email_failed": "No se ha podido enviar un correo de recuperación. Contacte con su administrador.",
+        "tls_policy_map_dest_invalid": "Destino de política no válido",
+        "cors_invalid_method": "Allow-Method especificado no válido",
+        "dkim_domain_or_sel_exists": "Ya existe una clave DKIM para \"%s\" y no será sobrescrita",
+        "webauthn_publickey_failed": "No se ha almacenado ninguna clave pública para el autenticador seleccionado",
+        "invalid_reset_token": "Token de restablecimiento no válido",
+        "password_reset_na": "El restablecimiento de contraseña no está disponible en estos momentos. Contacte con su administrador.",
+        "generic_server_error": "Se ha producido un error inesperado en el servidor. Contacte con su administrador.",
+        "reset_f2b_regex": "El filtro Regex no se ha podido restablecer a tiempo, inténtelo de nuevo o espere unos segundos y vuelva a cargar la página web.",
+        "extra_acl_invalid": "Dirección de remitente externo \"%s\" no válida",
+        "extra_acl_invalid_domain": "El remitente externo \"%s\" utiliza un dominio no válido",
+        "max_alias_exceeded": "Se ha excedido el número máximo de alias",
+        "app_passwd_id_invalid": "Contraseña de aplicación con ID %s no válida",
+        "comment_too_long": "Comentario demasiado largo, máximo de 160 caracteres permitidos",
+        "cors_invalid_origin": "Allow-Origin especificado no válido",
+        "demo_mode_enabled": "Modo demo activado",
+        "description_invalid": "Descripción de recurso para %s no válida",
+        "extended_sender_acl_denied": "no se encuentra ACL para establecer direcciones de remitente externo",
+        "fido2_verification_failed": "Verificación FIDO2 fallida: %s",
+        "file_open_error": "El archivo no se puede abrir para escritura",
+        "global_filter_write_error": "No se ha podido escribir el archivo de filtro: %s",
+        "global_map_invalid": "Mapa global con ID %s no válido",
+        "global_map_write_error": "No se ha podido guardar el mapa global con ID %s: %s",
+        "ham_learn_error": "Error de aprendizaje de correo deseado: %s",
+        "iam_test_connection": "Conexión fallida",
+        "imagick_exception": "Error: Excepción en Imagick al leer la imagen",
+        "img_invalid": "No se ha podido validar el archivo de imagen",
+        "img_size_exceeded": "La imagen excede el tamaño máximo de archivo",
+        "img_tmp_missing": "No se ha podido validar el archivo de imagen: archivo temporal no encontrado",
+        "invalid_filter_type": "Tipo de filtro no válido",
+        "invalid_mime_type": "Tipo MIME no válido",
+        "maxquota_empty": "La cuota máxima por buzón no debe ser cero.",
+        "nginx_reload_failed": "Recarga de Nginx fallida: %s",
+        "password_reset_invalid_user": "Buzón no encontrado o dirección de correo para recuperación no establecida",
+        "pushover_credentials_missing": "Falta el token y/o la clave de Pushover",
+        "pushover_key": "La clave de Pushover tiene un formato incorrecto",
+        "pushover_token": "El token de Pushover tiene un formato incorrecto",
+        "required_data_missing": "Datos necesarios %s no proporcionados",
+        "reset_token_limit_exceeded": "Se ha superado el límite de tokens de restablecimiento. Inténtelo más tarde.",
+        "resource_invalid": "Nombre de recurso %s no válido",
+        "targetd_relay_domain": "El dominio de destino %s es un dominio de retransmisión",
+        "template_exists": "La plantilla %s ya existe",
+        "template_id_invalid": "Plantilla con ID %s no válida",
+        "template_name_invalid": "Nombre de plantilla no válido",
+        "temp_error": "Error transitorio",
+        "tfa_token_invalid": "Token de autenticación de doble factor no válido",
+        "to_invalid": "El destinatario no puede quedar en blanco",
+        "webauthn_authenticator_failed": "No se ha localizado el autenticador seleccionado",
+        "webauthn_username_failed": "El autenticador seleccionado pertenece a otra cuenta"
     },
     "debug": {
         "containers_info": "Información de los contenedores",
@@ -357,7 +557,29 @@
         "started_at": "Iniciado el",
         "uptime": "Uptime",
         "static_logs": "Logs estáticos",
-        "system_containers": "Sistema y Contenedores"
+        "system_containers": "Sistema y Contenedores",
+        "show_ip": "Mostrar IP pública",
+        "wip": "Actualmente incompleto",
+        "current_time": "Hora del sistema",
+        "service": "Servicio",
+        "timezone": "Huso horario",
+        "update_available": "Hay una actualización disponible",
+        "update_failed": "No se han podido comprobar las actualizaciones",
+        "architecture": "Arquitectura",
+        "chart_this_server": "Gráfico (este servidor)",
+        "container_running": "En ejecución",
+        "container_disabled": "Contenedor detenido o desactivado",
+        "container_stopped": "Detenido",
+        "cores": "Núcleos",
+        "error_show_ip": "No se han podido resolver las direcciones IP públicas",
+        "history_all_servers": "Historial (todos los servidores)",
+        "login_time": "Tiempo",
+        "memory": "Memoria",
+        "online_users": "Usuarios conectados",
+        "started_on": "Iniciado",
+        "success": "Éxito",
+        "no_update_available": "El sistema está actualizado",
+        "username": "Nombre de usuario"
     },
     "diagnostics": {
         "cname_from_a": "Valor derivado del registro A / AAAA. Esto es permitido siempre que el registro apunte al recurso correcto.",
@@ -367,7 +589,8 @@
         "dns_records_name": "Nombre",
         "dns_records_status": "Información actual",
         "dns_records_type": "Tipo",
-        "optional": "Este récord es opcional."
+        "optional": "Este récord es opcional.",
+        "dns_records_docs": "Consulte también <a target=\"_blank\" href=\"https://docs.mailcow.email/getstarted/prerequisite-dns\">la documentación</a>."
     },
     "edit": {
         "active": "Activo",
@@ -435,13 +658,79 @@
         "title": "Editar objeto",
         "unchanged_if_empty": "Si no hay cambios dejalo en blanco",
         "username": "Nombre de usuario",
-        "validate_save": "Validar y guardar"
+        "validate_save": "Validar y guardar",
+        "app_passwd_protocols": "Protocolos permitidos con contraseña de aplicación",
+        "domain_footer_info": "Los pies de página de dominio se añaden a todos los mensajes salientes remitidos por una dirección de dicho dominio.<br> Están disponibles las siguientes variables para el pie de página:",
+        "sender_acl_info": "Si el usuario del buzón A tiene permitido enviar como el buzón B, la dirección de remitente no se mostrará automáticamente como seleccionable en el campo \"De\" en SOGo.<br>\n  El usuario del buzón B necesitará crear una delegación en SOGo para permitir al usuario A seleccionar su dirección como remitente. Para delegar un buzón en SOGo, utilice el menú (tres puntos) a la derecha del nombre del buzón en la esquina superior izquierda, en la vista de correo. Este comportamiento no se aplica a direcciones alias.",
+        "sogo_access_info": "Tras iniciar sesión, el usuario será redirigido automáticamente a SOGo.",
+        "comment_info": "Un comentario privado no es visible para el usuario, mientras que un comentario público se muestra como descripción emergente al pasar el ratón en la vista general del usuario",
+        "quota_warning_bcc_info": "Los avisos se enviarán como copias separadas a los siguientes destinatarios. Se indicará en el asunto el usuario afectado entre paréntesis, como por ejemplo: <code>Aviso de cuota (usuario@ejemplo.com)</code>.",
+        "sogo_access": "Redirección directa a SOGo",
+        "sogo_visible_info": "Esta opción solamente afecta a objetos que puedan ser visualizados en SOGo (alias compartidos o no compartidos que apunten al menos a un buzón interno). Si se oculta, el alias no aparecerá como seleccionable en SOGo.",
+        "extended_sender_acl_info": "Se aconseja importar una clave de dominio DKIM, si está disponible.<br>\n  Recuerde añadir este servidor al registro SPF correspondiente.<br>\n  Siempre que se añada un dominio o alias a este servidor, que se superponga con una dirección externa, se eliminará la dirección externa.<br>\n  Utilice @dominio.tld para permitir enviar como *@dominio.tld.",
+        "pushover_info": "La configuración de notificaciones push se aplicará a todos los mensajes limpios (no spam) entregados a <b>%s</b> incluyendo alias (compartidos, no compartidos, etiquetados).",
+        "mbox_rl_info": "Este límite de peticiones se aplica al nombre de inicio de sesión SASL, coincide con cualquier dirección \"de\" que utilice el usuario conectado. Un límite de buzón tiene precedencia sobre un límite del dominio.",
+        "admin": "Editar administrador",
+        "none_inherit": "Ninguno / heredar",
+        "sender_acl_disabled": "<span class=\"badge fs-6 bg-danger\">Comprobación de remitente desactivada</span>",
+        "footer_exclude": "Excluir del pie de página",
+        "acl": "ACL (permisos)",
+        "advanced_settings": "Configuración avanzada",
+        "allow_from_smtp": "Permitir únicamente a las siguientes direcciones IP utilizar <b>SMTP</b>",
+        "allow_from_smtp_info": "Dejar en blanco para permitir cualquier remitente.<br>Direcciones y redes IPv4/IPv6.",
+        "allowed_protocols": "Protocolos permitidos para acceso directo del usuario (no afecta a protocolos con contraseña de aplicación)",
+        "app_name": "Nombre de aplicación",
+        "app_passwd": "Contraseña de aplicación",
+        "created_on": "Creado",
+        "custom_attributes": "Atributos personalizados",
+        "delete_ays": "Por favor, confirme el proceso de eliminación.",
+        "disable_login": "Deshabilitar inicio de sesión (se aceptará el correo entrante)",
+        "domain_footer": "Pie de página para todos los usuarios del dominio",
+        "domain_footer_html": "Pie de página HTML",
+        "domain_footer_skip_replies": "Descartar pie de página en correos de respuesta",
+        "extended_sender_acl": "Direcciones de remisión externas",
+        "generate": "generar",
+        "lookup_mx": "El destino es una expresión regular con la que contrastar el nombre MX (<code>.*\\.google\\.com</code> para dirigir todo el correo enviado a un MX que termine en google.com a través de este salto)",
+        "mailbox_relayhost_info": "Aplicable únicamente al buzón y sus alias directos, anula el host de retransmisión para el dominio",
+        "mailbox_rename": "Renombrar buzón",
+        "mailbox_rename_agree": "He creado una copia de seguridad.",
+        "mailbox_rename_warning": "¡IMPORTANTE! Realice una copia de seguridad antes de renombrar el buzón.",
+        "mailbox_rename_alias": "Crear alias automáticamente",
+        "mailbox_rename_title": "Nuevo nombre de buzón local",
+        "password_recovery_email": "Dirección de correo para recuperación de contraseña",
+        "private_comment": "Comentario privado",
+        "public_comment": "Comentario público",
+        "pushover": "Pushover",
+        "pushover_evaluate_x_prio": "Escalar correo de alta prioridad [<code>X-Priority: 1</code>]",
+        "pushover_sender_array": "Tener en cuenta únicamente las siguientes direcciones de correo de remitente <small>(separados por comas)</small>",
+        "pushover_text": "Texto de notificación",
+        "pushover_title": "Título de notificación",
+        "pushover_sound": "Sonido",
+        "pushover_verify": "Verificar credenciales",
+        "quota_warning_bcc": "CCO de aviso de cuota",
+        "ratelimit": "Límite de peticiones",
+        "relay_transport_info": "<div class=\"badge fs-6 bg-info\">Información</div> Puede definir mapas de transporte para destinatarios personalizados para este dominio. Si no se establece, se realizará una búsqueda MX.",
+        "relay_unknown_only": "Reenviar solamente los buzones no existentes. Los buzones existentes se entregarán localmente.",
+        "sogo_visible": "Alias visible en SOGo.",
+        "spam_alias": "Crear o modificar alias temporales (con caducidad)",
+        "spam_filter": "Filtro de spam",
+        "spam_policy": "Añadir o eliminar elementos de la lista de bloqueo/desbloqueo",
+        "spam_score": "Establecer una puntuación de spam personalizada"
     },
     "footer": {
         "hibp_nok": "¡Se encontró coincidencia - esta es una contraseña <b>no segura</b>, selecciona otra!",
         "hibp_ok": "No se encontraron coincidencias",
         "loading": "Espera por favor...",
-        "restart_now": "Reiniciar ahora"
+        "restart_now": "Reiniciar ahora",
+        "restart_container": "Reiniciar contenedor",
+        "restart_container_info": "<b>Importante:</b> Un reinicio limpio puede llevar un tiempo. Por favor, espere a que finalice.",
+        "cancel": "Cancelar",
+        "confirm_delete": "Confirmar eliminación",
+        "delete_now": "Eliminar ahora",
+        "delete_these_items": "Confirme sus cambios para el siguiente ID de objeto",
+        "hibp_check": "Comprobar en haveibeenpwned.com",
+        "nothing_selected": "Nada seleccionado",
+        "restarting_container": "Reiniciando contenedor, puede llevar un tiempo"
     },
     "header": {
         "administration": "Administración",
@@ -450,17 +739,38 @@
         "mailcow_config": "Configuración",
         "quarantine": "Cuarentena",
         "restart_sogo": "Reiniciar SOGo",
-        "user_settings": "Configuraciones de usuario"
+        "user_settings": "Configuraciones de usuario",
+        "mailcow_system": "Sistema",
+        "apps": "Aplicaciones",
+        "restart_netfilter": "Reiniciar netfilter"
     },
     "info": {
         "awaiting_tfa_confirmation": "En espera de confirmación de TFA",
-        "no_action": "No hay acción aplicable"
+        "no_action": "No hay acción aplicable",
+        "session_expires": "Su sesión expirará en unos 15 segundos"
     },
     "login": {
         "delayed": "El inicio de sesión ha sido retrasado %s segundos.",
         "login": "Inicio de sesión",
         "password": "Contraseña",
-        "username": "Nombre de usuario"
+        "username": "Nombre de usuario",
+        "login_admin": "Inicio de sesión de administrador",
+        "invalid_pass_reset_token": "El token de restablecimiento de contraseña no es válido o ha caducado.<br>Solicite un nuevo enlace de restablecimiento de contraseña.",
+        "fido2_webauthn": "Inicio de sesión FIDO2/WebAuthn",
+        "forgot_password": "> ¿Contraseña olvidada?",
+        "mobileconfig_info": "Inicie sesión como usuario de buzón para descargar el perfil de conexión solicitado para dispositivos Apple.",
+        "new_password": "Nueva contraseña",
+        "back_to_mailcow": "Volver a mailcow",
+        "login_linkstext": "¿Sesión incorrecta?",
+        "login_usertext": "Iniciar sesión como usuario",
+        "login_domainadmintext": "Iniciar sesión como administrador de dominio",
+        "login_admintext": "Iniciar sesión como administrador",
+        "login_user": "Inicio de sesión de usuario",
+        "login_dadmin": "Inicio de sesión de administrador de dominio",
+        "new_password_confirm": "Confirmar nueva contraseña",
+        "other_logins": "o iniciar sesión con",
+        "reset_password": "Restablecer contraseña",
+        "request_reset_password": "Solicitar cambio de contraseña"
     },
     "mailbox": {
         "action": "Acción",
@@ -572,7 +882,67 @@
         "toggle_all": "Selecionar todo",
         "username": "Nombre de usuario",
         "waiting": "Esperando",
-        "weekly": "Cada semana"
+        "weekly": "Cada semana",
+        "sieve_preset_4": "Colocar en bandeja de entrada, omitir procesamiento posterior en filtros de sieve",
+        "goto_spam": "Aprender como <b>correo no deseado</b>",
+        "sieve_preset_header": "Vea los preajustes de ejemplo más abajo. Para más detalles, consulte <a href=\"https://en.wikipedia.org/wiki/Sieve_(mail_filtering_language)\" target=\"_blank\">Wikipedia</a>.",
+        "syncjob_EXIT_AUTHENTICATION_FAILURE_USER1": "Nombre de usuario o contraseña incorrectos",
+        "tls_policy_maps_enforced_tls": "Estas políticas tendrán precedencia también para aquellos usuarios de buzones en los que sea obligatoria una conexión TLS. Si no se indica ninguna política a continuación, dichos usuarios aplicarán los valores predeterminados que se especifiquen en <code>smtp_tls_mandatory_protocols</code> y <code>smtp_tls_mandatory_ciphers</code>.",
+        "alias_domain_alias_hint": "Los alias <b>no</b> se aplican a dominios de alias automáticamente. Una dirección alias <code>mi-alias@dominio</code> <b>no cubre</b> la dirección <code>mi-alias@dominio-alias</code> (donde \"dominio-alias\" es un hipotético alias para el dominio \"dominio\").<br>Utilice un filtro sieve para redirigir el correo a un buzón externo (ver la pestaña \"Filtros\" o utilice SOGo -> Desvío). Utilice \"expandir alias a dominio de alias\" para agregar automáticamente los alias que falten.",
+        "domain_templates": "Plantillas de dominio",
+        "sieve_preset_1": "Desechar correo con tipos de archivo probablemente peligrosos",
+        "created_on": "Creado",
+        "disable_login": "No permitir iniciar sesión (se seguirá aceptando el correo entrante)",
+        "mailbox": "Buzón",
+        "mailbox_defaults": "Ajustes por defecto",
+        "sogo_visible_y": "Mostrar alias en SOGo",
+        "spam_aliases": "Alias temporal",
+        "add_template": "Añadir plantilla",
+        "all_domains": "Todos los dominios",
+        "allow_from_smtp": "Permitir únicamente a estas direcciones IP utilizar <b>SMTP</b>",
+        "allow_from_smtp_info": "Dejar vacío para permitir cualquier remitente.<br>Direcciones y redes IPv4/IPv6.",
+        "allowed_protocols": "Protocolos permitidos",
+        "goto_ham": "Aprender como <b>correo deseado</b>",
+        "iam": "Proveedor de identidad",
+        "insert_preset": "Insertar valor predeterminado de ejemplo \"%s\"",
+        "last_mail_login": "Último acceso al correo",
+        "last_pw_change": "Último cambio de contraseña",
+        "mailbox_defaults_info": "Definir configuración por defecto para nuevos buzones.",
+        "mailbox_templates": "Plantillas de buzón",
+        "no": "&#10005;",
+        "open_logs": "Abrir registros",
+        "owner": "Propietario",
+        "private_comment": "Comentario privado",
+        "public_comment": "Comentario público",
+        "q_add_header": "al mover a carpeta de Spam",
+        "q_all": " al mover a carpeta de Spam y al rechazar",
+        "q_reject": "al rechazar",
+        "quarantine_category": "Categoría de notificación de cuarentena",
+        "recipient": "Destinatario",
+        "relay_unknown": "Retransmitir buzones desconocidos",
+        "sender": "Remitente",
+        "sieve_preset_2": "Marcar siempre el correo de un remitente específico como leído",
+        "sieve_preset_3": "Descartar silenciosamente, detener procesado de sieve",
+        "sieve_preset_5": "Respuesta automática (vacaciones)",
+        "sieve_preset_6": "Rechazar correo con respuesta",
+        "sieve_preset_7": "Redireccionar y guardar/descartar",
+        "sieve_preset_8": "Redirigir correo de un remitente específico, marcarlo como leído y clasificarlo en subcarpeta",
+        "sogo_visible": "Alias visible en SOGo",
+        "sogo_visible_n": "Ocultar alias en SOGo",
+        "stats": "Estadísticas",
+        "syncjob_check_log": "Comprobar registros",
+        "syncjob_last_run_result": "Resultado de la última ejecución",
+        "syncjob_EX_OK": "Éxito",
+        "syncjob_EXIT_CONNECTION_FAILURE": "Problema de conexión",
+        "syncjob_EXIT_TLS_FAILURE": "Problema con la conexión cifrada",
+        "syncjob_EXIT_AUTHENTICATION_FAILURE": "Problema de autenticación",
+        "syncjob_EXIT_OVERQUOTA": "El buzón de destino ha superado la cuota",
+        "syncjob_EXIT_CONNECTION_FAILURE_HOST1": "No es posible conectar con el servidor remoto",
+        "table_size": "Tamaño de la tabla",
+        "table_size_show_n": "Mostrar %s elementos",
+        "templates": "Plantillas",
+        "template": "Plantilla",
+        "yes": "&#10003;"
     },
     "oauth2": {
         "access_denied": "Inicie sesión como propietario del buzón para otorgar acceso a través de OAuth2.",
@@ -614,7 +984,13 @@
         "subj": "Asunto",
         "text_from_html_content": "Contenido (html convertido)",
         "text_plain_content": "Contenido (text/plain)",
-        "toggle_all": "Seleccionar todos"
+        "toggle_all": "Seleccionar todos",
+        "confirm": "Confirmar",
+        "deliver_inbox": "Entregar en bandeja de entrada",
+        "download_eml": "Descargar (.eml)",
+        "info": "Información",
+        "junk_folder": "Carpeta de correo no deseado",
+        "notified": "Notificado"
     },
     "queue": {
         "queue_manager": "Administrador de cola"
@@ -773,11 +1149,55 @@
         "waiting": "Esperando",
         "week": "Semana",
         "weekly": "Cada semana",
-        "weeks": "Semanas"
+        "weeks": "Semanas",
+        "with_app_password": "con contraseña de aplicación",
+        "year": "año",
+        "years": "años"
     },
     "warning": {
         "domain_added_sogo_failed": "Se agregó el dominio pero no se pudo reiniciar SOGo, revisa los logs del servidor.",
         "fuzzy_learn_error": "Error aprendiendo hash: %s",
-        "ip_invalid": "IP inválida omitida: %s"
+        "ip_invalid": "IP inválida omitida: %s",
+        "cannot_delete_self": "No se puede eliminar el usuario conectado"
+    },
+    "datatables": {
+        "collapse_all": "Contraer todo",
+        "aria": {
+            "sortAscending": ": activar para ordenar ascendentemente según la columna",
+            "sortDescending": ": activar para ordenar descendentemente según la columna"
+        },
+        "infoEmpty": "Mostrando 0 a 0 de 0 apuntes",
+        "paginate": {
+            "last": "Última",
+            "next": "Siguiente",
+            "previous": "Anterior",
+            "first": "Primero"
+        },
+        "processing": "Espere, por favor...",
+        "decimal": ".",
+        "emptyTable": "Sin datos disponibles en la tabla",
+        "expand_all": "Ampliar todo",
+        "info": "Mostrando apuntes _START_ a _END_ de _TOTAL_",
+        "infoFiltered": "(filtrado a partir de _MAX_ entradas totales)",
+        "thousands": ",",
+        "lengthMenu": "Mostrar entradas de _MENU_",
+        "loadingRecords": "Cargando...",
+        "search": "Buscar:",
+        "zeroRecords": "No se han encontrado registros coincidentes"
+    },
+    "fido2": {
+        "set_fido2": "Registrar dispositivo FIDO2",
+        "set_fido2_touchid": "Registrar Touch ID en Apple M1",
+        "set_fn": "Establecer nombre amistoso (fácil de recordar)",
+        "confirm": "Confirmar",
+        "fido2_auth": "Iniciar sesión con FIDO2",
+        "fido2_success": "Dispositivo registrado con éxito",
+        "fido2_validation_failed": "Validación fallida",
+        "fn": "Nombre amistoso (fácil de recordar)",
+        "known_ids": "ID conocidas",
+        "none": "Deshabilitado",
+        "register_status": "Estado de registro",
+        "rename": "Renombrar",
+        "start_fido2_validation": "Iniciar validación FIDO2"
     }
 }

+ 7 - 2
data/web/lang/lang.pt-br.json

@@ -359,7 +359,12 @@
         "username": "Nome de usuário",
         "validate_license_now": "Valide o GUID em relação ao servidor de licenças",
         "verify": "Verificar",
-        "yes": "✓"
+        "yes": "✓",
+        "iam_client_id": "ID de cliente",
+        "iam_client_secret": "Senha de cliente",
+        "iam_auth_flow": "Fluxo de autenticação",
+        "iam_client_scopes": "Escopo do cliente",
+        "iam_default_template": "Template Padrão"
     },
     "danger": {
         "access_denied": "Acesso negado ou dados de formulário inválidos",
@@ -508,7 +513,7 @@
         "infoFiltered": "(filtrado do total de entradas _MAX_)",
         "infoPostFix": "",
         "thousands": ",",
-        "lengthMenu": "Mostrar _ MENU_ entradas",
+        "lengthMenu": "Mostrar _MENU_ entradas",
         "loadingRecords": "Carregando...",
         "processing": "Por favor, aguarde...",
         "search": "Pesquisa:",

+ 7 - 6
data/web/lang/lang.ru-ru.json

@@ -184,7 +184,7 @@
         "excludes": "Исключает этих получателей",
         "f2b_ban_time": "Время бана (в секундах)",
         "f2b_ban_time_increment": "Время бана увеличивается с каждым баном",
-        "f2b_blacklist": "Черный список подсетей/хостов",
+        "f2b_blacklist": "Черный список сетей/хостов",
         "f2b_filter": "Правила фильтрации с помощью регулярных выражений",
         "f2b_list_info": "Хосты или подсети, занесенные в черный список, всегда будут перевешивать объекты из белого списка. <b>Обновление списка займет несколько секунд.</b>",
         "f2b_manage_external": "Внешнее управление Fail2Ban",
@@ -196,7 +196,7 @@
         "f2b_parameters": "Настройки Fail2ban",
         "f2b_regex_info": "Журналы которые принимаются во внимание: SOGo, Postfix, Dovecot, PHP-FPM.",
         "f2b_retry_window": "Промежуток времени для следующего бана (в секундах)",
-        "f2b_whitelist": "Белый список подсетей/хостов",
+        "f2b_whitelist": "Белый список сетей/хостов",
         "filter_table": "Поиск",
         "forwarding_hosts": "Переадресация хостов",
         "forwarding_hosts_add_hint": "Можно указывать: IPv4/IPv6 подсети в нотации CIDR, имена хостов (которые будут разрешаться в IP-адреса) или доменные имена (которые будут решаться с IP-адресами путем запроса SPF записей или, в случае их отсутствия - запросом MX записей).",
@@ -319,7 +319,7 @@
         "rspamd_global_filters": "Глобальные правила фильтрации",
         "rspamd_global_filters_agree": "Я понимаю, что я делаю, и буду осторожен!",
         "rspamd_global_filters_info": "Глобальные правила фильтрации содержат различные виды глобальных черных и белых списков.",
-        "rspamd_global_filters_regex": "Названия фильтров отражают их предназначение. Все правила должены состоять из регулярных выражений в формате \"/pattern/options\" (например: <code>/.+@domain\\.tld/i</code>).<br>\r\nНесмотря на то, что перед сохранением правил выполняется проверка регулярных выражений, функциональность Rspamds может быть нарушена, если будет использован<br>\r\n некорректный синтаксис. Будьте внимательны при написании правил.<br>Электронные письма от адресов электронной почты, проходящие по регулярным выражениям черных списков, будут отклонены без сохранения в карантин.<br>\r\n Rspamd попытается прочитать содержимое правил при их изменении. Но, если что, вы можете <a href=\"\" data-toggle=\"modal\" data-container=\"rspamd-mailcow\" data-target=\"#RestartContainer\">перезапустить Rspamd</a>, чтобы принять последние изменения принудительно.",
+        "rspamd_global_filters_regex": "Названия фильтров отражают их предназначение. Все правила должны состоять из регулярных выражений в формате \"/pattern/options\" (например: <code>/.+@domain\\.tld/i</code>).<br>\nНесмотря на то, что перед сохранением правил выполняется проверка регулярных выражений, функциональность Rspamds может быть нарушена, если будет использован<br>\n некорректный синтаксис. Будьте внимательны при написании правил.<br>Электронные письма от адресов электронной почты, проходящие по регулярным выражениям черных списков, будут отклонены без сохранения в карантин.<br>\n Rspamd попытается прочитать содержимое правил при их изменении. Но, если что, вы можете <a href=\"\" data-toggle=\"modal\" data-container=\"rspamd-mailcow\" data-target=\"#RestartContainer\">перезапустить Rspamd</a>, чтобы принять последние изменения принудительно.",
         "rspamd_settings_map": "Правила Rspamd",
         "sal_level": "Уровень Муу",
         "save": "Сохранить изменения",
@@ -408,7 +408,8 @@
         "iam_host": "Хост",
         "iam_host_info": "Укажите один или несколько LDAP-хостов через запятую.",
         "iam_import_users": "Импорт пользователей",
-        "admin_quicklink": "Скрыть ссылку на вход для администраторов"
+        "admin_quicklink": "Скрыть ссылку на вход для администраторов",
+        "needs_restart": "необходим перезапуск"
     },
     "danger": {
         "access_denied": "Доступ запрещён, или указаны неверные данные",
@@ -750,7 +751,7 @@
         "sogo_visible_info": "Влияет только на объекты, которые могут отображаться в SOGo (персональные или общие псевдонимы, указывающие как минимум на один локальный почтовый аккаунт). Учтите, что если функция отключена, у пользователей не будет возможности выбрать адрес псевдонима в качестве отправителя в SOGo.",
         "spam_alias": "Создать или изменить временные (спам) псевдонимы",
         "spam_filter": "Спам фильтр",
-        "spam_policy": "Добавление или удаление элементов в белом/черном списке",
+        "spam_policy": "Добавить или удалить элементы белого/черного списка",
         "spam_score": "Задать индивидуальное определение спама",
         "subfolder2": "Синхронизировать в подпапку<br><small>(пусто = в корень)</small>",
         "syncjob": "Изменить задание синхронизации",
@@ -1039,7 +1040,7 @@
         "notified": "Увед.",
         "qhandler_success": "Запрос успешно отправлен в систему. Теперь вы можете закрыть окно.",
         "qid": "Rspamd QID",
-        "qinfo": "Карантин сохраняет входящие сообщения, классифицированные как нежелательные, в базу данных.\r\n  <br>Отправители писем, которые помечены как отвергнутые, будут уверены что их письма <b>не</b> были доставлены вам.\r\n  <br>\"Освободить из карантина\" изучит сообщение как полезную почту; по теореме Байеса и доставит его вам в Inbox.\r\n  <br>\"Запомнить как спам и удалить\" изучит сообщение как спам по теореме Байеса, а также вычислит нечёткие хэши, чтобы лучше блокировать подобные сообщения в дальнейшем.\r\n  <br>Учтите, что в зависимости от технических характеристик вашей системы, изучение большого количества сообщений может занять много времени.",
+        "qinfo": "Карантин сохраняет входящие сообщения, классифицированные как нежелательные, в базу данных.\n  <br>Отправители писем, которые помечены как отвергнутые, будут уверены что их письма <b>не</b> были доставлены вам.\n  <br>\"Освободить из карантина\" изучит сообщение как полезную почту; по теореме Байеса и доставит его вам в Inbox.\n  <br>\"Запомнить как спам и удалить\" изучит сообщение как спам по теореме Байеса, а также вычислит нечёткие хэши, чтобы лучше блокировать подобные сообщения в дальнейшем.\n  <br>Учтите, что в зависимости от технических характеристик вашей системы, изучение большого количества сообщений может занять много времени.",
         "qitem": "Обьект карантина",
         "quarantine": "Карантин",
         "quick_actions": "Действия",

+ 15 - 14
data/web/lang/lang.si-si.json

@@ -20,7 +20,7 @@
         "sogo_access": "Dovoli upravljanje SOGo dostopa",
         "sogo_profile_reset": "Ponastavi SOGo profil",
         "spam_alias": "Začasni vzdevki",
-        "spam_policy": "Črna lista/Bela lista",
+        "spam_policy": "Seznam zavrnjenih/dovoljenih",
         "spam_score": "Ocena neželene pošte",
         "tls_policy": "Politika TLS",
         "unlimited_quota": "Neomejena kvota za poštne predale",
@@ -172,7 +172,7 @@
         "excludes": "Izključuje te prejemnike",
         "f2b_ban_time": "Čas blokade (s)",
         "f2b_ban_time_increment": "Čas blokade se poveča z vsako blokado",
-        "f2b_blacklist": "Mreže/gostitelji na blacklisti",
+        "f2b_blacklist": "Omrežja/gostitelji na seznamu zavrnjenih",
         "f2b_filter": "Regex filtri",
         "f2b_max_attempts": "Največ poskusov",
         "f2b_max_ban_time": "Maksimalno trajanje blokade (s)",
@@ -181,7 +181,7 @@
         "f2b_parameters": "Fail2ban parametri",
         "f2b_regex_info": "Upoštevajo se dnevniki SOGo, Postfix, Dovecot, PHP-FPM.",
         "f2b_retry_window": "Upoštevan čas (s) za največ poskusov",
-        "f2b_whitelist": "Mreže/gostitelji na whitelisti",
+        "f2b_whitelist": "Omrežja/gostitelji na seznamu dovoljenih",
         "filter_table": "Filtriraj tabelo",
         "from": "Od",
         "generate": "ustvari",
@@ -281,16 +281,16 @@
         "rspamd_com_settings": "Ime nastavitve bo samodejno generirano. Prosim oglejte si primere nastavitev spodaj. Za več informacij si oglejte <a href=\"https://rspamd.com/doc/configuration/settings.html#settings-structure\" target=\"_blank\">dokumentacijo Rspamd</a>",
         "rspamd_global_filters": "Globalne preslikave filtrov",
         "rspamd_global_filters_agree": "Previden bom!",
-        "rspamd_global_filters_info": "Globalne preslikave filtrov vsebujejo različne vrste globalnih blacklist in whitelist.",
+        "rspamd_global_filters_info": "Globalni filtri vsebujejo različne vrste globalnih seznamov zavrnjenih in dovoljenih vsebin.",
         "add_admin": "Dodaj skrbnika",
         "add_relayhost_hint": "Prosimo zavedajte se, da se podatki za avtentikacijo, če obstajajo, shranijo v golo besedilo.",
         "admin": "Skrbnik",
         "api_allow_from": "Dovoli API dostop s teh IP naslovov / CIDR mrežnih zapisov",
         "apps_name": "Ime aplikacije v mailcow",
-        "ban_list_info": "Oglejte si seznam blokiranih IP naslovov spodaj: <b>network (remaining ban time) - [actions]</b>.<br />. IPji v vrsti za odstranitev blokade bodo odstranjeni iz aktivnega seznama blokad v nekaj sekundah.<br />Rdeče oznake prikazujejo trajne blokade z blacklisto.",
+        "ban_list_info": "Spodaj si oglejte seznam prepovedanih IP-jev: <b>omrežje (preostali čas prepovedi) - [dejanja]</b>.<br />IP-ji, ki so v čakalni vrsti za odpravo prepovedi, bodo v nekaj sekundah odstranjeni s seznama aktivnih prepovedi.<br />Rdeče oznake označujejo aktivne trajne prepovedi s seznama zavrnjenih.",
         "dkim_key_length": "Dolžina DKIM ključa (v bitih)",
         "dkim_to_title": "Ciljne domene bodo prepisane",
-        "f2b_list_info": "Gostitelj ali omrežje na blacklisti bo vedno prevladal zapis na whitelisti. <b>Apliciranje sprememb seznama traja nekaj sekund.</b>",
+        "f2b_list_info": "Gostitelj ali omrežje na seznamu zavrnjenih bo vedno imelo prednost pred entiteto na seznamu dovoljenih. <b>Posodobitve seznama bodo trajale nekaj sekund, da se uporabijo.</b>",
         "forwarding_hosts": "Gostitelji za posredovanje",
         "forwarding_hosts_add_hint": "Lahko vpišete IPv4/IPv6 naslove, mreže v CIDR obliki, imena gostiteljev (kateri se prevedejo v IP naslove) ali imena domen (katera se prevedejo v IP naslove glede na poizvedbo po SPF zapisih, v primeru manjkajočih zapisov pa MX zapisih).",
         "forwarding_hosts_hint": "Dohodna sporočila so brezpogojno sprejeta od katerih koli gostiteljev v tem seznamu. Ti gostitelji se ne bodo preverjali po DNSBL seznamih in ne bodo dodani v greyliste. Prejeti spam s teh gostiteljev ni nikoli zavrnjen, opcijsko pa se lahko premakne v mapo neželene pošte. Najpogostejša uporaba za to je navedba poštnih strežnikov, iz katerih ste nastavili pravilo za posredovanje pošte na vaš mailcow strežnik.",
@@ -306,7 +306,7 @@
         "relayhosts_hint": "Določite transporte glede na pošiljatelja, da jih lahko izberete v konfiguraciji domene.<br>\nTransportni servis je vedno \"smtp:\" in bo poskušal s TLS ko bo na voljo. Wrapped TLS (SMTPS) ni podprto. Upošteva se uporabnikova politika odhodnega TLS.<br>\nVpliva na izbrane domene vključno z alias domenami.",
         "transport_dest_format": "Regex ali sintaksa: example.org, .example.org, *, box@example.org (več vrednosti ločite z vejico)",
         "transport_test_rcpt_info": "&#8226; Uporabite null@hosted.mailcow.de za testiranje relaya na drugo destinacijo.",
-        "rspamd_global_filters_regex": "Njihovi nazivi pojasnijo njihov namen. Vsa vsebina mora imeti veljaven regular expression v obliki \"/pattern/options\" (npr. <code>/.+@domain\\.tld/i</code>).<br>\nČeprav se v vsaki vrstici regexa izvedejo osnovni pregledi, je lahko funkcionalnost programa Rspamd motena, če sintaksa ni pravilna.<br>\nRspamd bo poskušal prebrati vsebino preslikave, ko bo spremenjena. Če imate težave, <a href=\"\" data-toggle=\"modal\" data-container=\"rspamd-mailcow\" data-target=\"#RestartContainer\">ponovno zaženite Rspamd</a>, da prisilite ponovno nalaganje preslikav.<br> Elementi z Blackliste so izključeni iz karantene.",
+        "rspamd_global_filters_regex": "Njihovi nazivi pojasnijo njihov namen. Vsa vsebina mora imeti veljaven regular expression v obliki \"/pattern/options\" (npr. <code>/.+@domain\\.tld/i</code>).<br>\nČeprav se v vsaki vrstici regexa izvedejo osnovni pregledi, je lahko funkcionalnost programa Rspamd motena, če sintaksa ni pravilna.<br>\nRspamd bo poskušal prebrati vsebino preslikave, ko bo spremenjena. Če imate težave, <a href=\"\" data-toggle=\"modal\" data-container=\"rspamd-mailcow\" data-target=\"#RestartContainer\">ponovno zaženite Rspamd</a>, da prisilite ponovno nalaganje preslikav.<br> Elementi na seznamu zavrnjenih so izključeni iz karantene.",
         "rspamd_settings_map": "Preslikava nastavitev Rspamd",
         "sal_level": "Moo stopnja",
         "save": "Shrani spremembe",
@@ -408,7 +408,8 @@
         "restore_template": "Za obnovitev privzete predloge pustite polje prazno.",
         "task": "Naloga",
         "user_link": "Uporabniška povezava",
-        "iam_realm": "Realm"
+        "iam_realm": "Realm",
+        "needs_restart": "potreben je ponovni zagon"
     },
     "danger": {
         "alias_goto_identical": "Alias in goto naslov morata biti identična",
@@ -745,7 +746,7 @@
         "sogo_visible_info": "Ta možnost vpliva samo na objekte, ki jih je mogoče prikazati v SOGo (naslovi aliasov v skupni rabi ali brez nje, ki kažejo na vsaj en lokalni poštni predal). Če je skrita, vzdevek ne bo prikazan kot izbirni pošiljatelj v SOGo.",
         "spam_alias": "Ustvarjanje ali spreminjanje časovno omejenih vzdevkovnih naslovov",
         "spam_filter": "Filter neželene pošte",
-        "spam_policy": "Dodajanje ali odstranjevanje elementov na beli/črni seznam",
+        "spam_policy": "Dodajanje ali odstranjevanje elementov na seznam dovoljenih/zavrnjenih",
         "spam_score": "Nastavite oceno neželene pošte po meri",
         "subfolder2": "Sinhroniziraj v podmapo na cilju<br><small>(prazno = ne uporabi podmape)</small>",
         "syncjob": "Urejanje sinhronizacijskega opravila",
@@ -1013,7 +1014,7 @@
         "medium_danger": "Srednje",
         "notified": "Obveščen",
         "low_danger": "Nizko",
-        "qinfo": "Sistem karantene bo zavrnjeno pošto shranil v zbirko podatkov (pošiljatelj ne bo imel vtisa, da je bila pošta dostavljena), prav tako pa bo pošto, ki bo dostavljena kot kopija, shranil v mapo »Neželena pošta« v nabiralniku.\n<br>»Uči kot neželeno pošto in izbriši« bo sporočilo prepoznal kot neželeno pošto prek Bayesovega izreka in izračunal tudi mehke zgoščene vrednosti, da bi v prihodnje zavrnil podobna sporočila.\n<br>Upoštevajte, da je učenje več sporočil lahko – odvisno od vašega sistema – zamudno.<br>Elementi na črnem seznamu so izključeni iz karantene.",
+        "qinfo": "Sistem karantene bo zavrnjeno pošto shranil v zbirko podatkov (pošiljatelj ne bo imel vtisa, da je bila pošta dostavljena), prav tako pa bo pošto, ki bo dostavljena kot kopija, shranil v mapo »Neželena pošta« v nabiralniku.\n<br>»Uči kot neželeno pošto in izbriši« bo sporočilo prepoznal kot neželeno pošto prek Bayesovega izreka in izračunal tudi mehke zgoščene vrednosti, da bi v prihodnje zavrnil podobna sporočila.\n<br>Upoštevajte, da je učenje več sporočil lahko – odvisno od vašega sistema – zamudno.<br>Elementi na seznamu zavrnjenih so izključeni iz karantene.",
         "junk_folder": "Mapa z neželeno pošto",
         "action": "Dejanje",
         "atts": "Priloge",
@@ -1232,8 +1233,8 @@
         "pushover_vars": "Če filter pošiljatelja ni definiran, bodo upoštevana vsa e-poštna sporočila.<br>Filtre regularnih izrazov in natančna preverjanja pošiljateljev je mogoče definirati posamično in bodo obravnavana zaporedno. Niso odvisna drug od drugega.<br>Uporabne spremenljivke za besedilo in naslov (upoštevajte pravilnike o varstvu podatkov)",
         "quarantine_notification_info": "Ko je obvestilo poslano, bodo elementi označeni kot »obveščeni« in za ta določen element ne bodo poslana nobena nadaljnja obvestila.",
         "verify": "Preveri",
-        "spamfilter_bl_desc": "E-poštni naslovi na črnem seznamu, ki jih <b>vedno</b> razvrstite kot neželeno pošto in zavrnete. Zavrnjena pošta <b>ne</b> bo kopirana v karanteno. Uporabite lahko nadomestne znake. Filter se uporabi samo za neposredne vzdevke (vzdevke z enim samim ciljnim nabiralnikom), izključujoč vseobsegajoče vzdevke in sam nabiralnik.",
-        "spamfilter_wl_desc": "E-poštni naslovi na belem seznamu so programirani tako, da se <b>nikoli</b> ne razvrstijo kot neželena pošta. Uporabijo se lahko nadomestni znaki. Filter se uporabi samo za neposredne vzdevke (vzdevke z enim samim ciljnim poštnim predalom), izključujoč vseobsegajoče vzdevke in sam poštni predal.",
+        "spamfilter_bl_desc": "E-poštni naslovi na seznamu zavrnjenih, ki bodo <b>vedno</b> razvrščeni kot neželena pošta in zavrnjeni. Zavrnjena pošta <b>ne</b> bo kopirana v karanteno. Uporabite lahko nadomestne znake. Filter se uporabi samo za neposredne vzdevke (vzdevke z enim samim ciljnim nabiralnikom), izključujoč vseobsegajoče vzdevke in sam nabiralnik.",
+        "spamfilter_wl_desc": "E-poštni naslovi na seznamu dovoljenih so programirani tako, da se <b>nikoli</b> ne razvrstijo kot neželena pošta. Uporabijo se lahko nadomestni znaki. Filter se uporabi samo za neposredne vzdevke (vzdevke z enim samim ciljnim poštnim predalom), izključujoč vseobsegajoče vzdevke in sam poštni predal.",
         "tls_policy_warning": "<strong>Opozorilo:</strong> Če se odločite za uveljavitev šifriranega prenosa pošte, lahko izgubite e-pošto.<br>Sporočila, ki ne ustrezajo pravilniku, bo poštni sistem zavrnil s popolno napako.<br>Ta možnost velja za vaš primarni e-poštni naslov (prijavno ime), vse naslove, izpeljane iz vzdevkov domen, in vzdevke, <b>ki imajo samo ta en poštni predal</b> kot cilj.",
         "allowed_protocols": "Dovoljeni protokoli",
         "title": "Naslov",
@@ -1341,7 +1342,7 @@
         "spam_score_reset": "Ponastavi na privzete nastavitve strežnika",
         "spamfilter": "Filter neželene pošte",
         "spamfilter_behavior": "Ocena",
-        "spamfilter_bl": "Črna lista",
+        "spamfilter_bl": "Seznam zavrnjenih",
         "spamfilter_default_score": "Privzete vrednosti",
         "spamfilter_green": "Zelena: to sporočilo ni neželena pošta",
         "spamfilter_hint": "Prva vrednost opisuje »nizko oceno neželene pošte«, druga pa »visoko oceno neželene pošte«.",
@@ -1352,7 +1353,7 @@
         "spamfilter_table_empty": "Ni podatkov za prikaz",
         "spamfilter_table_remove": "odstrani",
         "spamfilter_table_rule": "Pravilo",
-        "spamfilter_wl": "Bela lista",
+        "spamfilter_wl": "Seznam dovoljenih",
         "spamfilter_yellow": "Rumena: to sporočilo je morda neželena pošta, označeno bo kot neželena pošta in premaknjeno v mapo z neželeno pošto",
         "status": "Stanje",
         "sync_jobs": "Sinhronizacija opravil",

+ 1 - 1
data/web/lang/lang.zh-tw.json

@@ -1324,4 +1324,4 @@
         "hold_mail": "保留",
         "unhold_mail": "取消保留"
     }
-}
+}

+ 2 - 2
data/web/templates/admin/tab-config-f2b.twig

@@ -118,8 +118,8 @@
           <span class="d-none d-sm-inline"> - </span>
             {% if active_ban.queued_for_unban == 0 %}
             <a data-action="edit_selected" data-item="{{ active_ban.network }}" data-id="f2b-quick" data-api-url='edit/fail2ban' data-api-attr='{"action":"unban"}' href="#">[{{ lang.admin.queue_unban }}]</a>
-            <a data-action="edit_selected" data-item="{{ active_ban.network }}" data-id="f2b-quick" data-api-url='edit/fail2ban' data-api-attr='{"action":"whitelist"}' href="#">[whitelist]</a>
-            <a data-action="edit_selected" data-item="{{ active_ban.network }}" data-id="f2b-quick" data-api-url='edit/fail2ban' data-api-attr='{"action":"blacklist"}' href="#">[blacklist (<b>needs restart</b>)]</a>
+            <a data-action="edit_selected" data-item="{{ active_ban.network }}" data-id="f2b-quick" data-api-url='edit/fail2ban' data-api-attr='{"action":"whitelist"}' href="#">[allowlist]</a>
+            <a data-action="edit_selected" data-item="{{ active_ban.network }}" data-id="f2b-quick" data-api-url='edit/fail2ban' data-api-attr='{"action":"blacklist"}' href="#">[denylist (<b>{{ lang.admin.needs_restart }}</b>)]</a>
             {% else %}
             <i>{{ lang.admin.unban_pending }}</i>
             {% endif %}

+ 2 - 2
docker-compose.yml

@@ -200,7 +200,7 @@ services:
             - phpfpm
 
     sogo-mailcow:
-      image: ghcr.io/mailcow/sogo:1.133
+      image: ghcr.io/mailcow/sogo:1.134
       environment:
         - DBNAME=${DBNAME}
         - DBUSER=${DBUSER}
@@ -477,7 +477,7 @@ services:
             - acme
 
     netfilter-mailcow:
-      image: ghcr.io/mailcow/netfilter:1.61
+      image: ghcr.io/mailcow/netfilter:1.62
       stop_grace_period: 30s
       restart: always
       privileged: true

+ 0 - 65
update.sh

@@ -19,71 +19,6 @@ source _modules/scripts/ipv6_controller.sh
 source _modules/scripts/new_options.sh
 source _modules/scripts/migrate_options.sh
 
-detect_major_update() {
-  if [ ${BRANCH} == "master" ]; then
-    # Array with major versions
-    # Add major versions here
-    MAJOR_VERSIONS=(
-      "2025-02"
-      "2025-03"
-    )
-
-    current_version=""
-    if [[ -f "${SCRIPT_DIR}/data/web/inc/app_info.inc.php" ]]; then
-      current_version=$(grep 'MAILCOW_GIT_VERSION' ${SCRIPT_DIR}/data/web/inc/app_info.inc.php | sed -E 's/.*MAILCOW_GIT_VERSION="([^"]+)".*/\1/')
-    fi
-    if [[ -z "$current_version" ]]; then
-      return 1
-    fi
-    release_url="https://github.com/mailcow/mailcow-dockerized/releases/tag"
-
-    updates_to_apply=()
-
-    for version in "${MAJOR_VERSIONS[@]}"; do
-      if [[ "$current_version" < "$version" ]]; then
-        updates_to_apply+=("$version")
-      fi
-    done
-
-    if [[ ${#updates_to_apply[@]} -gt 0 ]]; then
-      echo -e "\e[33m\nMAJOR UPDATES to be applied:\e[0m"
-      for update in "${updates_to_apply[@]}"; do
-        echo "$update - $release_url/$update"
-      done
-
-      echo -e "\nPlease read the release notes before proceeding."
-      read -p "Do you want to proceed with the update? [y/n] " response
-      if [[ "${response}" =~ ^([yY][eE][sS]|[yY])+$ ]]; then
-        echo "Proceeding with the update..."
-      else
-        echo "Update canceled. Exiting."
-        exit 1
-      fi
-    fi
-  fi
-}
-
-remove_obsolete_options() {
-  OBSOLETE_OPTIONS=(
-    "ACME_CONTACT"
-  )
-
-  for option in "${OBSOLETE_OPTIONS[@]}"; do
-    if [[ "$option" == "ACME_CONTACT" ]]; then
-      sed -i '/^# Lets Encrypt registration contact information/d' mailcow.conf
-      sed -i "/^# Let's Encrypt registration contact information/d" mailcow.conf
-      sed -i '/^# Optional: Leave empty for none/d' mailcow.conf
-      sed -i '/^# This value is only used on first order!/d' mailcow.conf
-      sed -i '/^# Setting it at a later point will require the following steps:/d' mailcow.conf
-      sed -i '/^# https:\/\/docs.mailcow.email\/troubleshooting\/debug-reset_tls\//d' mailcow.conf
-      sed -i '/^ACME_CONTACT=.*/d' mailcow.conf
-      sed -i '/^#ACME_CONTACT=.*/d' mailcow.conf
-    else
-      sed -i "/^${option}=.*/d" mailcow.conf
-      sed -i "/^#${option}=.*/d" mailcow.conf
-    fi
-  done
-}
 ############## End Function Section ##############
 
 # Check permissions