Compare commits
123 Commits
Author | SHA1 | Date | |
---|---|---|---|
|
a49305fd6b | ||
|
263baa81c0 | ||
|
092890b6ab | ||
|
db7d7ea288 | ||
|
452daf5d5e | ||
|
d373164e13 | ||
|
cd7715fa0e | ||
|
dd6b8c44a4 | ||
|
499273dbb7 | ||
|
6612b892b7 | ||
|
89cea31475 | ||
|
872fa07213 | ||
|
36e4ee7738 | ||
|
a139eb9bce | ||
|
7166696aa2 | ||
|
71db83efce | ||
|
7ae7f25580 | ||
|
5d14baa43a | ||
|
141b397c82 | ||
|
fd853cfc6f | ||
|
63f718178e | ||
|
74baf20feb | ||
|
958112af6b | ||
|
08d0f9448e | ||
|
7bcc8bd3a2 | ||
|
714511b0a8 | ||
|
c9700773f4 | ||
|
2229f87d9b | ||
|
d360503443 | ||
|
838182a8b4 | ||
|
967cfedbb3 | ||
|
a36645a282 | ||
|
3368a70f88 | ||
|
cd1715ba52 | ||
|
0bc2a16093 | ||
|
a21b3cd606 | ||
|
1c479684fc | ||
|
c9dbc7c7b7 | ||
|
c41dc9d8c0 | ||
|
1db5841424 | ||
|
e53b068902 | ||
|
2bd436dfd8 | ||
|
d13be25f45 | ||
|
6efd9dc5f9 | ||
|
1edd4012e4 | ||
|
4390c9855a | ||
|
4d53216c05 | ||
|
040206859f | ||
|
d06119a21d | ||
|
c27ad97287 | ||
|
b1658c0f83 | ||
|
05b8609073 | ||
|
552f09f48a | ||
|
97df5c3b9c | ||
|
8d9102aa08 | ||
|
33e5ad2b5c | ||
|
998cb642a9 | ||
|
07ac195fea | ||
|
f79cac3292 | ||
|
7a20a9941e | ||
|
24cc960379 | ||
|
353df6413f | ||
|
b68eae16e5 | ||
|
9a812edee4 | ||
|
43d2a6e135 | ||
|
5839e22796 | ||
|
ee844c81d2 | ||
|
b6cb3b026c | ||
|
df33ebb2a0 | ||
|
d2a6838958 | ||
|
96b8054e6b | ||
|
dfdd2dadb4 | ||
|
d0528b7883 | ||
|
f40e682800 | ||
|
f4dc01d1ec | ||
|
187ddedf96 | ||
|
5613134fed | ||
|
e454ed4e39 | ||
|
1e2125653e | ||
|
835a726d2a | ||
|
0539cc6d8c | ||
|
549ff7d100 | ||
|
456b528785 | ||
|
003a6342a5 | ||
|
fb10764167 | ||
|
9e1554f5c7 | ||
|
42c82be8f5 | ||
|
76ec0e888b | ||
|
892c99fa23 | ||
|
28da482ef2 | ||
|
936f07336c | ||
|
224a59ab4b | ||
|
6c5ab7800e | ||
|
7e26a2ab98 | ||
|
4e6c398c8c | ||
|
d4e829465b | ||
|
1ade37312e | ||
|
372e381a85 | ||
|
374cc64601 | ||
|
1cf25572a3 | ||
|
ba45f70a30 | ||
|
5e56566de6 | ||
|
a2ccf7ef03 | ||
|
654dbf8198 | ||
|
53a5254897 | ||
|
c433daf024 | ||
|
fd7269d455 | ||
|
b375e6a250 | ||
|
48589d20e2 | ||
|
be9cbcf5ac | ||
|
b04faddac4 | ||
|
e925187dda | ||
|
06f380a17a | ||
|
67882414e1 | ||
|
2b149fb8ea | ||
|
3166bd5df5 | ||
|
e911452d0c | ||
|
deac5ad2fe | ||
|
f097267bcd | ||
|
161130c116 | ||
|
a03b8f28ae | ||
|
bb9ae02ccc | ||
|
a0c09af67e |
7
.github/ISSUE_TEMPLATE/Bug_report.yml
vendored
7
.github/ISSUE_TEMPLATE/Bug_report.yml
vendored
@@ -54,10 +54,11 @@ body:
|
|||||||
| --- | --- |
|
| --- | --- |
|
||||||
| My operating system | I_DO_REPLY_HERE |
|
| My operating system | I_DO_REPLY_HERE |
|
||||||
| Is Apparmor, SELinux or similar active? | I_DO_REPLY_HERE |
|
| Is Apparmor, SELinux or similar active? | I_DO_REPLY_HERE |
|
||||||
| Virtualization technlogy (KVM, VMware, Xen, etc - **LXC and OpenVZ are not supported** | I_DO_REPLY_HERE |
|
| Virtualization technology (KVM, VMware, Xen, etc - **LXC and OpenVZ are not supported** | I_DO_REPLY_HERE |
|
||||||
| Server/VM specifications (Memory, CPU Cores) | I_DO_REPLY_HERE |
|
| Server/VM specifications (Memory, CPU Cores) | I_DO_REPLY_HERE |
|
||||||
| Docker Version (`docker version`) | I_DO_REPLY_HERE |
|
| Docker version (`docker version`) | I_DO_REPLY_HERE |
|
||||||
| Docker-Compose Version (`docker-compose version`) | I_DO_REPLY_HERE |
|
| docker-compose version (`docker-compose version`) | I_DO_REPLY_HERE |
|
||||||
|
| mailcow version (```git describe --tags `git rev-list --tags --max-count=1` ```) | I_DO_REPLY_HERE |
|
||||||
| Reverse proxy (custom solution) | I_DO_REPLY_HERE |
|
| Reverse proxy (custom solution) | I_DO_REPLY_HERE |
|
||||||
|
|
||||||
Output of `git diff origin/master`, any other changes to the code? If so, **please post them**:
|
Output of `git diff origin/master`, any other changes to the code? If so, **please post them**:
|
||||||
|
@@ -1,4 +1,4 @@
|
|||||||
FROM alpine:3.15
|
FROM alpine:3.16
|
||||||
|
|
||||||
LABEL maintainer "Andre Peters <andre.peters@servercow.de>"
|
LABEL maintainer "Andre Peters <andre.peters@servercow.de>"
|
||||||
|
|
||||||
|
@@ -1,76 +1,15 @@
|
|||||||
FROM debian:bullseye-slim
|
FROM clamav/clamav:0.105.0_base
|
||||||
|
|
||||||
LABEL maintainer "André Peters <andre.peters@servercow.de>"
|
LABEL maintainer "André Peters <andre.peters@servercow.de>"
|
||||||
|
|
||||||
ARG CLAMAV=0.104.2
|
RUN apk upgrade --no-cache \
|
||||||
ARG TINI_VERSION=v0.19.0
|
&& apk add --update --no-cache \
|
||||||
|
|
||||||
RUN apt-get update && apt-get install -y --no-install-recommends \
|
|
||||||
ca-certificates \
|
|
||||||
build-essential \
|
|
||||||
pkg-config \
|
|
||||||
python3 \
|
|
||||||
python3-pip \
|
|
||||||
valgrind \
|
|
||||||
check \
|
|
||||||
libbz2-dev \
|
|
||||||
libcurl4-openssl-dev \
|
|
||||||
libjson-c-dev \
|
|
||||||
libmilter-dev \
|
|
||||||
libncurses5-dev \
|
|
||||||
libpcre2-dev \
|
|
||||||
libssl-dev \
|
|
||||||
libxml2-dev \
|
|
||||||
zlib1g-dev \
|
|
||||||
curl \
|
|
||||||
bash \
|
|
||||||
wget \
|
|
||||||
tzdata \
|
|
||||||
dnsutils \
|
|
||||||
rsync \
|
rsync \
|
||||||
dos2unix \
|
bind-tools \
|
||||||
netcat \
|
bash
|
||||||
&& python3 -m pip install cmake \
|
|
||||||
&& rm -rf /var/lib/apt/lists/* \
|
|
||||||
&& wget -O - https://www.clamav.net/downloads/production/clamav-${CLAMAV}.tar.gz | tar xfvz - \
|
|
||||||
&& cd clamav-${CLAMAV} \
|
|
||||||
&& cmake . \
|
|
||||||
-D CMAKE_INSTALL_PREFIX=/usr \
|
|
||||||
-D CMAKE_INSTALL_LIBDIR=/usr/lib \
|
|
||||||
-D APP_CONFIG_DIRECTORY=/etc/clamav \
|
|
||||||
-D CMAKE_INSTALL_MANDIR=/usr/share/man \
|
|
||||||
-D CMAKE_INSTALL_INFODIR=/usr/share/info \
|
|
||||||
-D CLAMAV_USER=clamav \
|
|
||||||
-D CLAMAV_GROUP=clamav \
|
|
||||||
-D DATABASE_DIRECTORY=/var/lib/clamav \
|
|
||||||
-D ENABLE_APP=ON \
|
|
||||||
-D ENABLE_JSON_SHARED=OFF \
|
|
||||||
-D CMAKE_BUILD_TYPE=MinSizeRel \
|
|
||||||
&& cmake --build . -j4 \
|
|
||||||
&& cmake --build . --target install \
|
|
||||||
&& cd .. && rm -rf clamav-${CLAMAV} \
|
|
||||||
&& apt-get -y --auto-remove purge build-essential \
|
|
||||||
&& apt-get -y purge pkg-config \
|
|
||||||
python3 \
|
|
||||||
python3-pip \
|
|
||||||
valgrind \
|
|
||||||
check \
|
|
||||||
libbz2-dev \
|
|
||||||
libcurl4-openssl-dev \
|
|
||||||
libjson-c-dev \
|
|
||||||
libmilter-dev \
|
|
||||||
libncurses5-dev \
|
|
||||||
libpcre2-dev \
|
|
||||||
libssl-dev \
|
|
||||||
libxml2-dev \
|
|
||||||
zlib1g-dev \
|
|
||||||
|
|
||||||
&& addgroup --system --gid 700 clamav \
|
|
||||||
&& adduser --system --no-create-home --home /var/lib/clamav --uid 700 --gid 700 --disabled-login clamav \
|
|
||||||
&& rm -rf /tmp/* /var/tmp/*
|
|
||||||
|
|
||||||
COPY clamd.sh ./
|
COPY clamd.sh ./
|
||||||
ADD https://github.com/krallin/tini/releases/download/${TINI_VERSION}/tini /sbin/tini
|
|
||||||
RUN chmod +x /sbin/tini
|
RUN chmod +x /sbin/tini
|
||||||
|
|
||||||
|
ENTRYPOINT []
|
||||||
CMD ["/sbin/tini", "-g", "--", "/clamd.sh"]
|
CMD ["/sbin/tini", "-g", "--", "/clamd.sh"]
|
@@ -1,4 +1,4 @@
|
|||||||
FROM alpine:3.15
|
FROM alpine:3.16
|
||||||
|
|
||||||
LABEL maintainer "Andre Peters <andre.peters@servercow.de>"
|
LABEL maintainer "Andre Peters <andre.peters@servercow.de>"
|
||||||
|
|
||||||
|
@@ -166,11 +166,17 @@ while ($row = $sth->fetchrow_arrayref()) {
|
|||||||
$success = 1;
|
$success = 1;
|
||||||
}
|
}
|
||||||
|
|
||||||
$update = $dbh->prepare("UPDATE imapsync SET returned_text = ?, success = ?, exit_status = ? WHERE id = ?");
|
$keep_job_active = 1;
|
||||||
|
if (defined $exit_status && $exit_status eq "EXIT_AUTHENTICATION_FAILURE_USER1") {
|
||||||
|
$keep_job_active = 0;
|
||||||
|
}
|
||||||
|
|
||||||
|
$update = $dbh->prepare("UPDATE imapsync SET returned_text = ?, success = ?, exit_status = ?, active = ? WHERE id = ?");
|
||||||
$update->bind_param( 1, ${stdout} );
|
$update->bind_param( 1, ${stdout} );
|
||||||
$update->bind_param( 2, ${success} );
|
$update->bind_param( 2, ${success} );
|
||||||
$update->bind_param( 3, ${exit_status} );
|
$update->bind_param( 3, ${exit_status} );
|
||||||
$update->bind_param( 4, ${id} );
|
$update->bind_param( 4, ${keep_job_active} );
|
||||||
|
$update->bind_param( 5, ${id} );
|
||||||
$update->execute();
|
$update->execute();
|
||||||
} catch {
|
} catch {
|
||||||
$update = $dbh->prepare("UPDATE imapsync SET returned_text = 'Could not start or finish imapsync', success = 0 WHERE id = ?");
|
$update = $dbh->prepare("UPDATE imapsync SET returned_text = 'Could not start or finish imapsync', success = 0 WHERE id = ?");
|
||||||
|
@@ -1,4 +1,4 @@
|
|||||||
FROM alpine:3.15
|
FROM alpine:3.16
|
||||||
LABEL maintainer "Andre Peters <andre.peters@servercow.de>"
|
LABEL maintainer "Andre Peters <andre.peters@servercow.de>"
|
||||||
|
|
||||||
ENV XTABLES_LIBDIR /usr/lib/xtables
|
ENV XTABLES_LIBDIR /usr/lib/xtables
|
||||||
|
@@ -94,7 +94,7 @@ def refreshF2bregex():
|
|||||||
f2bregex = {}
|
f2bregex = {}
|
||||||
f2bregex[1] = 'mailcow UI: Invalid password for .+ by ([0-9a-f\.:]+)'
|
f2bregex[1] = 'mailcow UI: Invalid password for .+ by ([0-9a-f\.:]+)'
|
||||||
f2bregex[2] = 'Rspamd UI: Invalid password by ([0-9a-f\.:]+)'
|
f2bregex[2] = 'Rspamd UI: Invalid password by ([0-9a-f\.:]+)'
|
||||||
f2bregex[3] = 'warning: .*\[([0-9a-f\.:]+)\]: SASL .+ authentication failed'
|
f2bregex[3] = 'warning: .*\[([0-9a-f\.:]+)\]: SASL .+ authentication failed: (?!.*Connection lost to authentication server).+'
|
||||||
f2bregex[4] = 'warning: non-SMTP command from .*\[([0-9a-f\.:]+)]:.+'
|
f2bregex[4] = 'warning: non-SMTP command from .*\[([0-9a-f\.:]+)]:.+'
|
||||||
f2bregex[5] = 'NOQUEUE: reject: RCPT from \[([0-9a-f\.:]+)].+Protocol error.+'
|
f2bregex[5] = 'NOQUEUE: reject: RCPT from \[([0-9a-f\.:]+)].+Protocol error.+'
|
||||||
f2bregex[6] = '-login: Disconnected \(auth failed, .+\): user=.*, method=.+, rip=([0-9a-f\.:]+),'
|
f2bregex[6] = '-login: Disconnected \(auth failed, .+\): user=.*, method=.+, rip=([0-9a-f\.:]+),'
|
||||||
|
@@ -1,4 +1,4 @@
|
|||||||
FROM alpine:3.15
|
FROM alpine:3.16
|
||||||
LABEL maintainer "Andre Peters <andre.peters@servercow.de>"
|
LABEL maintainer "Andre Peters <andre.peters@servercow.de>"
|
||||||
|
|
||||||
WORKDIR /app
|
WORKDIR /app
|
||||||
|
@@ -1,12 +1,12 @@
|
|||||||
FROM php:8.0-fpm-alpine3.14
|
FROM php:8.0-fpm-alpine3.16
|
||||||
LABEL maintainer "Andre Peters <andre.peters@servercow.de>"
|
LABEL maintainer "Andre Peters <andre.peters@servercow.de>"
|
||||||
|
|
||||||
ENV APCU_PECL 5.1.20
|
ENV APCU_PECL 5.1.21
|
||||||
ENV IMAGICK_PECL 3.5.1
|
ENV IMAGICK_PECL 3.7.0
|
||||||
# Mailparse is pulled from master branch
|
# Mailparse is pulled from master branch
|
||||||
#ENV MAILPARSE_PECL 3.0.2
|
#ENV MAILPARSE_PECL 3.0.2
|
||||||
ENV MEMCACHED_PECL 3.1.5
|
ENV MEMCACHED_PECL 3.2.0
|
||||||
ENV REDIS_PECL 5.3.4
|
ENV REDIS_PECL 5.3.7
|
||||||
|
|
||||||
RUN apk add -U --no-cache autoconf \
|
RUN apk add -U --no-cache autoconf \
|
||||||
aspell-dev \
|
aspell-dev \
|
||||||
|
@@ -1,4 +1,4 @@
|
|||||||
FROM debian:buster-slim
|
FROM debian:bullseye-slim
|
||||||
LABEL maintainer "Andre Peters <andre.peters@servercow.de>"
|
LABEL maintainer "Andre Peters <andre.peters@servercow.de>"
|
||||||
|
|
||||||
ARG DEBIAN_FRONTEND=noninteractive
|
ARG DEBIAN_FRONTEND=noninteractive
|
||||||
|
@@ -1,4 +1,4 @@
|
|||||||
@version: 3.19
|
@version: 3.28
|
||||||
@include "scl.conf"
|
@include "scl.conf"
|
||||||
options {
|
options {
|
||||||
chain_hostnames(off);
|
chain_hostnames(off);
|
||||||
|
@@ -1,4 +1,4 @@
|
|||||||
@version: 3.19
|
@version: 3.28
|
||||||
@include "scl.conf"
|
@include "scl.conf"
|
||||||
options {
|
options {
|
||||||
chain_hostnames(off);
|
chain_hostnames(off);
|
||||||
|
@@ -1,4 +1,4 @@
|
|||||||
FROM alpine:3.15
|
FROM alpine:3.16
|
||||||
|
|
||||||
LABEL maintainer "Andre Peters <andre.peters@servercow.de>"
|
LABEL maintainer "Andre Peters <andre.peters@servercow.de>"
|
||||||
|
|
||||||
|
@@ -1,4 +1,4 @@
|
|||||||
FROM alpine:3.15
|
FROM alpine:3.16
|
||||||
LABEL maintainer "André Peters <andre.peters@servercow.de>"
|
LABEL maintainer "André Peters <andre.peters@servercow.de>"
|
||||||
|
|
||||||
# Installation
|
# Installation
|
||||||
|
@@ -65,7 +65,7 @@
|
|||||||
}
|
}
|
||||||
|
|
||||||
location ~ ^/api/v1/(.*)$ {
|
location ~ ^/api/v1/(.*)$ {
|
||||||
try_files $uri $uri/ /json_api.php?query=$1;
|
try_files $uri $uri/ /json_api.php?query=$1&$args;
|
||||||
}
|
}
|
||||||
|
|
||||||
location ^~ /.well-known/acme-challenge/ {
|
location ^~ /.well-known/acme-challenge/ {
|
||||||
@@ -163,7 +163,9 @@
|
|||||||
proxy_connect_timeout 75;
|
proxy_connect_timeout 75;
|
||||||
proxy_send_timeout 3600;
|
proxy_send_timeout 3600;
|
||||||
proxy_read_timeout 3600;
|
proxy_read_timeout 3600;
|
||||||
proxy_buffers 64 256k;
|
proxy_buffer_size 128k;
|
||||||
|
proxy_buffers 64 512k;
|
||||||
|
proxy_busy_buffers_size 512k;
|
||||||
proxy_set_header X-Real-IP $remote_addr;
|
proxy_set_header X-Real-IP $remote_addr;
|
||||||
proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;
|
proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;
|
||||||
proxy_set_header Host $http_host;
|
proxy_set_header Host $http_host;
|
||||||
@@ -197,6 +199,9 @@
|
|||||||
proxy_set_header x-webobjects-server-name $server_name;
|
proxy_set_header x-webobjects-server-name $server_name;
|
||||||
proxy_set_header x-webobjects-server-url $client_req_scheme://$http_host;
|
proxy_set_header x-webobjects-server-url $client_req_scheme://$http_host;
|
||||||
proxy_set_header x-webobjects-server-port $server_port;
|
proxy_set_header x-webobjects-server-port $server_port;
|
||||||
|
proxy_buffer_size 128k;
|
||||||
|
proxy_buffers 64 512k;
|
||||||
|
proxy_busy_buffers_size 512k;
|
||||||
proxy_send_timeout 3600;
|
proxy_send_timeout 3600;
|
||||||
proxy_read_timeout 3600;
|
proxy_read_timeout 3600;
|
||||||
client_body_buffer_size 128k;
|
client_body_buffer_size 128k;
|
||||||
|
@@ -1,53 +1,63 @@
|
|||||||
# Whitelist generated by Postwhite v3.4 on Sun Dec 15 21:16:19 CET 2019
|
# Whitelist generated by Postwhite v3.4 on Mon 21 Mar 2022 06:50:26 PM CET
|
||||||
# https://github.com/stevejenkins/postwhite/
|
# https://github.com/stevejenkins/postwhite/
|
||||||
# 1928 total rules
|
# 1898 total rules
|
||||||
2a00:1450:4000::/36 permit
|
2a00:1450:4000::/36 permit
|
||||||
2a01:111:f400::/48 permit
|
2a01:111:f400::/48 permit
|
||||||
2a01:111:f403::/48 permit
|
2a01:111:f403::/48 permit
|
||||||
|
2a01:4180:4050:0400::/64 permit
|
||||||
|
2a01:4180:4050:0800::/64 permit
|
||||||
|
2a01:4180:4051:0400::/64 permit
|
||||||
|
2a01:4180:4051:0800::/64 permit
|
||||||
2a02:a60:0:5::/64 permit
|
2a02:a60:0:5::/64 permit
|
||||||
2c0f:fb50:4000::/36 permit
|
2c0f:fb50:4000::/36 permit
|
||||||
3.93.157.0/24 permit
|
|
||||||
8.20.114.31 permit
|
8.20.114.31 permit
|
||||||
8.25.194.0/23 permit
|
8.25.194.0/23 permit
|
||||||
8.25.196.0/23 permit
|
8.25.196.0/23 permit
|
||||||
8.39.54.0/23 permit
|
8.39.54.0/23 permit
|
||||||
8.40.222.0/23 permit
|
8.40.222.0/23 permit
|
||||||
8.45.169.0/24 permit
|
|
||||||
12.130.86.238 permit
|
12.130.86.238 permit
|
||||||
|
13.70.32.43 permit
|
||||||
|
13.72.50.45 permit
|
||||||
|
13.74.143.28 permit
|
||||||
13.77.161.179 permit
|
13.77.161.179 permit
|
||||||
|
13.78.233.182 permit
|
||||||
|
13.92.31.129 permit
|
||||||
|
13.110.208.0/21 permit
|
||||||
|
13.110.216.0/22 permit
|
||||||
|
13.110.224.0/20 permit
|
||||||
13.111.0.0/16 permit
|
13.111.0.0/16 permit
|
||||||
13.111.0.0/22 permit
|
|
||||||
13.111.52.0/22 permit
|
|
||||||
13.111.63.0/24 permit
|
|
||||||
13.111.68.0/24 permit
|
|
||||||
13.111.72.0/22 permit
|
|
||||||
13.111.92.0/24 permit
|
|
||||||
13.111.111.0/24 permit
|
|
||||||
17.36.0.0/16 permit
|
|
||||||
17.41.0.0/16 permit
|
17.41.0.0/16 permit
|
||||||
|
17.57.155.0/24 permit
|
||||||
|
17.57.156.0/24 permit
|
||||||
17.58.0.0/16 permit
|
17.58.0.0/16 permit
|
||||||
17.110.0.0/15 permit
|
17.110.0.0/15 permit
|
||||||
17.111.110.0/23 permit
|
|
||||||
17.120.0.0/16 permit
|
|
||||||
17.133.0.0/16 permit
|
|
||||||
17.139.0.0/16 permit
|
|
||||||
17.142.0.0/15 permit
|
17.142.0.0/15 permit
|
||||||
17.151.1.0/24 permit
|
|
||||||
17.158.0.0/15 permit
|
|
||||||
17.162.0.0/15 permit
|
17.162.0.0/15 permit
|
||||||
17.164.0.0/16 permit
|
17.164.0.0/16 permit
|
||||||
17.171.37.0/24 permit
|
17.171.37.0/24 permit
|
||||||
17.172.0.0/16 permit
|
17.172.0.0/16 permit
|
||||||
17.179.168.0/23 permit
|
17.179.168.0/23 permit
|
||||||
18.194.95.56 permit
|
18.194.95.56 permit
|
||||||
18.208.124.128/25 permit
|
18.198.96.88 permit
|
||||||
|
20.47.149.138 permit
|
||||||
|
20.48.0.0/12 permit
|
||||||
|
20.52.52.2 permit
|
||||||
|
20.52.128.133 permit
|
||||||
|
20.63.210.192/28 permit
|
||||||
|
20.64.0.0/10 permit
|
||||||
|
20.94.180.64/28 permit
|
||||||
|
20.185.213.160/27 permit
|
||||||
|
20.185.213.224/27 permit
|
||||||
20.185.214.0/27 permit
|
20.185.214.0/27 permit
|
||||||
20.185.214.2 permit
|
20.185.214.2 permit
|
||||||
20.185.214.32/27 permit
|
20.185.214.32/27 permit
|
||||||
20.185.214.64/27 permit
|
20.185.214.64/27 permit
|
||||||
23.23.237.213 permit
|
20.192.0.0/10 permit
|
||||||
23.103.131.7 permit
|
23.100.85.1 permit
|
||||||
23.103.224.0/19 permit
|
23.103.224.0/19 permit
|
||||||
|
23.249.208.0/20 permit
|
||||||
|
23.251.224.0/19 permit
|
||||||
|
23.253.141.0/24 permit
|
||||||
23.253.182.0/23 permit
|
23.253.182.0/23 permit
|
||||||
23.253.182.103 permit
|
23.253.182.103 permit
|
||||||
23.253.183.145 permit
|
23.253.183.145 permit
|
||||||
@@ -68,11 +78,11 @@
|
|||||||
27.123.206.56/29 permit
|
27.123.206.56/29 permit
|
||||||
27.123.206.76/30 permit
|
27.123.206.76/30 permit
|
||||||
27.123.206.80/28 permit
|
27.123.206.80/28 permit
|
||||||
27.126.146.0/24 permit
|
34.194.25.167 permit
|
||||||
34.200.123.20 permit
|
34.194.144.120 permit
|
||||||
34.212.163.75 permit
|
34.212.163.75 permit
|
||||||
34.213.104.127 permit
|
|
||||||
34.225.212.172 permit
|
34.225.212.172 permit
|
||||||
|
34.247.168.44 permit
|
||||||
35.176.132.251 permit
|
35.176.132.251 permit
|
||||||
35.190.247.0/24 permit
|
35.190.247.0/24 permit
|
||||||
35.191.0.0/16 permit
|
35.191.0.0/16 permit
|
||||||
@@ -80,7 +90,10 @@
|
|||||||
37.218.248.47 permit
|
37.218.248.47 permit
|
||||||
37.218.249.47 permit
|
37.218.249.47 permit
|
||||||
37.218.251.62 permit
|
37.218.251.62 permit
|
||||||
|
39.156.163.64/29 permit
|
||||||
|
40.71.187.0/24 permit
|
||||||
40.76.4.15 permit
|
40.76.4.15 permit
|
||||||
|
40.77.102.222 permit
|
||||||
40.92.0.0/15 permit
|
40.92.0.0/15 permit
|
||||||
40.97.116.82 permit
|
40.97.116.82 permit
|
||||||
40.97.128.194 permit
|
40.97.128.194 permit
|
||||||
@@ -91,18 +104,20 @@
|
|||||||
40.97.161.50 permit
|
40.97.161.50 permit
|
||||||
40.97.164.146 permit
|
40.97.164.146 permit
|
||||||
40.107.0.0/16 permit
|
40.107.0.0/16 permit
|
||||||
|
40.112.65.63 permit
|
||||||
40.112.72.205 permit
|
40.112.72.205 permit
|
||||||
40.113.200.201 permit
|
40.113.200.201 permit
|
||||||
|
40.117.80.0/24 permit
|
||||||
|
40.121.71.46 permit
|
||||||
41.74.192.0/22 permit
|
41.74.192.0/22 permit
|
||||||
41.74.196.0/22 permit
|
41.74.196.0/22 permit
|
||||||
41.74.200.0/23 permit
|
41.74.200.0/23 permit
|
||||||
41.74.201.0/24 permit
|
|
||||||
41.74.204.0/23 permit
|
41.74.204.0/23 permit
|
||||||
41.74.205.0/24 permit
|
41.74.206.0/24 permit
|
||||||
42.159.163.81 permit
|
42.159.163.81 permit
|
||||||
42.159.163.82 permit
|
42.159.163.82 permit
|
||||||
42.159.163.83 permit
|
42.159.163.83 permit
|
||||||
46.19.168.0/23 permit
|
43.228.184.0/22 permit
|
||||||
46.226.48.0/21 permit
|
46.226.48.0/21 permit
|
||||||
46.228.36.37 permit
|
46.228.36.37 permit
|
||||||
46.228.36.38/31 permit
|
46.228.36.38/31 permit
|
||||||
@@ -160,26 +175,19 @@
|
|||||||
50.18.125.97 permit
|
50.18.125.97 permit
|
||||||
50.18.125.237 permit
|
50.18.125.237 permit
|
||||||
50.18.126.162 permit
|
50.18.126.162 permit
|
||||||
50.23.218.192/27 permit
|
|
||||||
50.31.32.0/19 permit
|
50.31.32.0/19 permit
|
||||||
50.31.36.197 permit
|
|
||||||
50.31.36.199 permit
|
|
||||||
50.31.36.205 permit
|
|
||||||
50.31.36.208 permit
|
|
||||||
50.31.36.213 permit
|
|
||||||
50.31.44.111 permit
|
|
||||||
50.31.57.54/31 permit
|
|
||||||
50.31.57.60 permit
|
|
||||||
50.31.57.61 permit
|
|
||||||
50.31.57.62 permit
|
|
||||||
50.31.60.1 permit
|
|
||||||
50.31.156.96/27 permit
|
50.31.156.96/27 permit
|
||||||
50.31.205.0/24 permit
|
50.31.205.0/24 permit
|
||||||
50.207.218.237 permit
|
|
||||||
51.4.71.62 permit
|
51.4.71.62 permit
|
||||||
|
51.4.72.0/24 permit
|
||||||
|
51.4.80.0/27 permit
|
||||||
|
51.5.72.0/24 permit
|
||||||
|
51.5.80.0/27 permit
|
||||||
|
51.137.58.21 permit
|
||||||
|
51.140.75.55 permit
|
||||||
|
51.144.100.179 permit
|
||||||
51.163.158.0/24 permit
|
51.163.158.0/24 permit
|
||||||
51.163.159.0/24 permit
|
51.163.159.21 permit
|
||||||
52.0.20.102 permit
|
|
||||||
52.5.230.59 permit
|
52.5.230.59 permit
|
||||||
52.27.5.72 permit
|
52.27.5.72 permit
|
||||||
52.27.28.47 permit
|
52.27.28.47 permit
|
||||||
@@ -190,10 +198,15 @@
|
|||||||
52.41.64.145 permit
|
52.41.64.145 permit
|
||||||
52.60.41.5 permit
|
52.60.41.5 permit
|
||||||
52.60.115.116 permit
|
52.60.115.116 permit
|
||||||
|
52.82.172.0/22 permit
|
||||||
|
52.94.124.0/28 permit
|
||||||
52.95.48.152/29 permit
|
52.95.48.152/29 permit
|
||||||
52.95.49.88/29 permit
|
52.95.49.88/29 permit
|
||||||
52.100.0.0/14 permit
|
52.100.0.0/14 permit
|
||||||
52.128.40.0/21 permit
|
52.119.213.144/28 permit
|
||||||
|
52.160.39.140 permit
|
||||||
|
52.165.175.144 permit
|
||||||
|
52.185.106.240/28 permit
|
||||||
52.200.59.0/24 permit
|
52.200.59.0/24 permit
|
||||||
52.205.61.79 permit
|
52.205.61.79 permit
|
||||||
52.207.191.216 permit
|
52.207.191.216 permit
|
||||||
@@ -201,26 +214,30 @@
|
|||||||
52.222.73.83 permit
|
52.222.73.83 permit
|
||||||
52.222.73.120 permit
|
52.222.73.120 permit
|
||||||
52.222.75.85 permit
|
52.222.75.85 permit
|
||||||
|
52.234.172.96/28 permit
|
||||||
|
52.236.28.240/28 permit
|
||||||
|
52.237.141.173 permit
|
||||||
|
52.244.206.214 permit
|
||||||
|
52.247.53.144 permit
|
||||||
|
52.250.107.196 permit
|
||||||
|
52.250.126.174 permit
|
||||||
|
52.251.55.143 permit
|
||||||
54.90.148.255 permit
|
54.90.148.255 permit
|
||||||
54.156.255.69 permit
|
54.156.255.69 permit
|
||||||
54.172.97.247 permit
|
54.172.97.247 permit
|
||||||
54.173.229.38 permit
|
|
||||||
54.174.52.0/24 permit
|
|
||||||
54.174.53.128/30 permit
|
|
||||||
54.174.57.0/24 permit
|
|
||||||
54.174.59.0/24 permit
|
|
||||||
54.174.60.0/23 permit
|
|
||||||
54.174.63.0/24 permit
|
|
||||||
54.186.193.102 permit
|
54.186.193.102 permit
|
||||||
|
54.191.223.5 permit
|
||||||
|
54.194.61.95 permit
|
||||||
|
54.195.113.45 permit
|
||||||
54.214.39.184 permit
|
54.214.39.184 permit
|
||||||
|
54.216.77.168 permit
|
||||||
54.240.0.0/18 permit
|
54.240.0.0/18 permit
|
||||||
54.240.40.0/25 permit
|
54.240.64.0/19 permit
|
||||||
54.240.56.128/26 permit
|
54.240.96.0/19 permit
|
||||||
54.240.63.0/25 permit
|
|
||||||
54.241.16.209 permit
|
54.241.16.209 permit
|
||||||
54.243.205.80 permit
|
|
||||||
54.244.54.130 permit
|
54.244.54.130 permit
|
||||||
54.244.242.0/24 permit
|
54.244.242.0/24 permit
|
||||||
|
54.246.232.180 permit
|
||||||
62.13.128.0/24 permit
|
62.13.128.0/24 permit
|
||||||
62.13.129.128/25 permit
|
62.13.129.128/25 permit
|
||||||
62.13.136.0/22 permit
|
62.13.136.0/22 permit
|
||||||
@@ -231,9 +248,9 @@
|
|||||||
62.13.152.0/23 permit
|
62.13.152.0/23 permit
|
||||||
62.17.146.128/26 permit
|
62.17.146.128/26 permit
|
||||||
62.140.7.0/24 permit
|
62.140.7.0/24 permit
|
||||||
62.140.10.0/24 permit
|
62.140.10.21 permit
|
||||||
|
63.32.13.159 permit
|
||||||
63.80.14.0/23 permit
|
63.80.14.0/23 permit
|
||||||
63.111.28.137 permit
|
|
||||||
63.128.21.0/24 permit
|
63.128.21.0/24 permit
|
||||||
63.143.57.128/25 permit
|
63.143.57.128/25 permit
|
||||||
63.143.59.128/25 permit
|
63.143.59.128/25 permit
|
||||||
@@ -241,9 +258,11 @@
|
|||||||
64.20.241.45 permit
|
64.20.241.45 permit
|
||||||
64.34.47.128/27 permit
|
64.34.47.128/27 permit
|
||||||
64.34.57.192/26 permit
|
64.34.57.192/26 permit
|
||||||
|
64.71.149.160/28 permit
|
||||||
64.79.155.0/24 permit
|
64.79.155.0/24 permit
|
||||||
64.79.155.192 permit
|
64.89.44.85 permit
|
||||||
64.89.45.192/30 permit
|
64.89.45.80 permit
|
||||||
|
64.89.45.194 permit
|
||||||
64.89.45.196 permit
|
64.89.45.196 permit
|
||||||
64.95.144.196 permit
|
64.95.144.196 permit
|
||||||
64.127.115.252 permit
|
64.127.115.252 permit
|
||||||
@@ -265,21 +284,21 @@
|
|||||||
64.207.219.7 permit
|
64.207.219.7 permit
|
||||||
64.207.219.8 permit
|
64.207.219.8 permit
|
||||||
64.207.219.9 permit
|
64.207.219.9 permit
|
||||||
64.207.219.10 permit
|
64.207.219.13 permit
|
||||||
64.207.219.11 permit
|
64.207.219.14 permit
|
||||||
64.207.219.12 permit
|
64.207.219.15 permit
|
||||||
64.207.219.71 permit
|
64.207.219.71 permit
|
||||||
64.207.219.72 permit
|
64.207.219.72 permit
|
||||||
64.207.219.73 permit
|
64.207.219.73 permit
|
||||||
64.207.219.74 permit
|
64.207.219.77 permit
|
||||||
64.207.219.75 permit
|
64.207.219.78 permit
|
||||||
64.207.219.76 permit
|
64.207.219.79 permit
|
||||||
64.207.219.135 permit
|
64.207.219.135 permit
|
||||||
64.207.219.136 permit
|
64.207.219.136 permit
|
||||||
64.207.219.137 permit
|
64.207.219.137 permit
|
||||||
64.207.219.138 permit
|
64.207.219.141 permit
|
||||||
64.207.219.139 permit
|
64.207.219.142 permit
|
||||||
64.207.219.140 permit
|
64.207.219.143 permit
|
||||||
64.233.160.0/19 permit
|
64.233.160.0/19 permit
|
||||||
65.38.115.76 permit
|
65.38.115.76 permit
|
||||||
65.38.115.84 permit
|
65.38.115.84 permit
|
||||||
@@ -288,7 +307,6 @@
|
|||||||
65.54.51.64/26 permit
|
65.54.51.64/26 permit
|
||||||
65.54.61.64/26 permit
|
65.54.61.64/26 permit
|
||||||
65.54.121.120/29 permit
|
65.54.121.120/29 permit
|
||||||
65.54.121.124/31 permit
|
|
||||||
65.54.190.0/24 permit
|
65.54.190.0/24 permit
|
||||||
65.54.241.0/24 permit
|
65.54.241.0/24 permit
|
||||||
65.55.29.77 permit
|
65.55.29.77 permit
|
||||||
@@ -298,7 +316,6 @@
|
|||||||
65.55.52.224/27 permit
|
65.55.52.224/27 permit
|
||||||
65.55.78.128/25 permit
|
65.55.78.128/25 permit
|
||||||
65.55.81.48/28 permit
|
65.55.81.48/28 permit
|
||||||
65.55.81.54/31 permit
|
|
||||||
65.55.90.0/24 permit
|
65.55.90.0/24 permit
|
||||||
65.55.94.0/25 permit
|
65.55.94.0/25 permit
|
||||||
65.55.111.0/24 permit
|
65.55.111.0/24 permit
|
||||||
@@ -325,9 +342,6 @@
|
|||||||
66.111.4.225 permit
|
66.111.4.225 permit
|
||||||
66.111.4.229 permit
|
66.111.4.229 permit
|
||||||
66.111.4.230 permit
|
66.111.4.230 permit
|
||||||
66.135.202.0/27 permit
|
|
||||||
66.135.215.0/24 permit
|
|
||||||
66.135.222.1 permit
|
|
||||||
66.162.193.226/31 permit
|
66.162.193.226/31 permit
|
||||||
66.163.184.0/21 permit
|
66.163.184.0/21 permit
|
||||||
66.163.184.0/24 permit
|
66.163.184.0/24 permit
|
||||||
@@ -358,7 +372,8 @@
|
|||||||
66.196.81.232/31 permit
|
66.196.81.232/31 permit
|
||||||
66.196.81.234 permit
|
66.196.81.234 permit
|
||||||
66.211.168.230/31 permit
|
66.211.168.230/31 permit
|
||||||
66.211.184.0/23 permit
|
66.211.170.86/31 permit
|
||||||
|
66.211.170.88/30 permit
|
||||||
66.218.74.64/30 permit
|
66.218.74.64/30 permit
|
||||||
66.218.74.68/31 permit
|
66.218.74.68/31 permit
|
||||||
66.218.75.112/30 permit
|
66.218.75.112/30 permit
|
||||||
@@ -420,9 +435,7 @@
|
|||||||
67.221.168.65 permit
|
67.221.168.65 permit
|
||||||
67.228.2.24/30 permit
|
67.228.2.24/30 permit
|
||||||
67.228.21.184/29 permit
|
67.228.21.184/29 permit
|
||||||
67.228.34.32/27 permit
|
|
||||||
67.228.37.4/30 permit
|
67.228.37.4/30 permit
|
||||||
67.228.50.54/31 permit
|
|
||||||
67.231.145.42 permit
|
67.231.145.42 permit
|
||||||
67.231.153.30 permit
|
67.231.153.30 permit
|
||||||
68.142.230.0/24 permit
|
68.142.230.0/24 permit
|
||||||
@@ -432,17 +445,6 @@
|
|||||||
68.142.230.72/30 permit
|
68.142.230.72/30 permit
|
||||||
68.142.230.76/31 permit
|
68.142.230.76/31 permit
|
||||||
68.142.230.78 permit
|
68.142.230.78 permit
|
||||||
68.232.131.164 permit
|
|
||||||
68.232.131.172 permit
|
|
||||||
68.232.131.183 permit
|
|
||||||
68.232.131.185 permit
|
|
||||||
68.232.143.44 permit
|
|
||||||
68.232.145.216 permit
|
|
||||||
68.232.148.56 permit
|
|
||||||
68.232.148.128 permit
|
|
||||||
68.232.148.138 permit
|
|
||||||
68.232.157.60 permit
|
|
||||||
68.232.157.143 permit
|
|
||||||
68.232.192.0/20 permit
|
68.232.192.0/20 permit
|
||||||
69.63.178.128/25 permit
|
69.63.178.128/25 permit
|
||||||
69.63.181.0/24 permit
|
69.63.181.0/24 permit
|
||||||
@@ -456,9 +458,9 @@
|
|||||||
69.171.232.0/24 permit
|
69.171.232.0/24 permit
|
||||||
69.171.244.0/23 permit
|
69.171.244.0/23 permit
|
||||||
70.37.151.128/25 permit
|
70.37.151.128/25 permit
|
||||||
|
70.42.149.0/24 permit
|
||||||
70.42.149.35 permit
|
70.42.149.35 permit
|
||||||
72.3.185.0/24 permit
|
72.3.185.0/24 permit
|
||||||
72.3.237.64/28 permit
|
|
||||||
72.14.192.0/18 permit
|
72.14.192.0/18 permit
|
||||||
72.21.192.0/19 permit
|
72.21.192.0/19 permit
|
||||||
72.21.217.142 permit
|
72.21.217.142 permit
|
||||||
@@ -523,8 +525,10 @@
|
|||||||
72.32.154.0/24 permit
|
72.32.154.0/24 permit
|
||||||
72.32.217.0/24 permit
|
72.32.217.0/24 permit
|
||||||
72.32.243.0/24 permit
|
72.32.243.0/24 permit
|
||||||
72.34.168.75 permit
|
|
||||||
72.34.168.76 permit
|
72.34.168.76 permit
|
||||||
|
72.34.168.80 permit
|
||||||
|
72.34.168.85 permit
|
||||||
|
72.34.168.86 permit
|
||||||
72.52.72.32/28 permit
|
72.52.72.32/28 permit
|
||||||
72.52.72.36 permit
|
72.52.72.36 permit
|
||||||
74.6.128.0/21 permit
|
74.6.128.0/21 permit
|
||||||
@@ -536,9 +540,6 @@
|
|||||||
74.6.133.0/24 permit
|
74.6.133.0/24 permit
|
||||||
74.6.134.0/24 permit
|
74.6.134.0/24 permit
|
||||||
74.6.135.0/24 permit
|
74.6.135.0/24 permit
|
||||||
74.63.63.115 permit
|
|
||||||
74.63.63.121 permit
|
|
||||||
74.63.194.126 permit
|
|
||||||
74.63.212.0/24 permit
|
74.63.212.0/24 permit
|
||||||
74.63.234.75 permit
|
74.63.234.75 permit
|
||||||
74.63.236.0/24 permit
|
74.63.236.0/24 permit
|
||||||
@@ -557,17 +558,9 @@
|
|||||||
74.112.67.243 permit
|
74.112.67.243 permit
|
||||||
74.125.0.0/16 permit
|
74.125.0.0/16 permit
|
||||||
74.202.227.40 permit
|
74.202.227.40 permit
|
||||||
74.208.4.192/26 permit
|
|
||||||
74.208.5.64/26 permit
|
|
||||||
74.208.122.0/26 permit
|
|
||||||
74.209.250.0/24 permit
|
74.209.250.0/24 permit
|
||||||
74.209.250.12 permit
|
74.209.250.12 permit
|
||||||
75.126.253.48 permit
|
76.223.176.0/20 permit
|
||||||
76.223.176.0/24 permit
|
|
||||||
76.223.180.0/23 permit
|
|
||||||
76.223.188.0/24 permit
|
|
||||||
76.223.189.0/24 permit
|
|
||||||
76.223.190.0/24 permit
|
|
||||||
77.238.176.0/22 permit
|
77.238.176.0/22 permit
|
||||||
77.238.176.0/24 permit
|
77.238.176.0/24 permit
|
||||||
77.238.177.0/24 permit
|
77.238.177.0/24 permit
|
||||||
@@ -590,13 +583,11 @@
|
|||||||
77.238.189.146/31 permit
|
77.238.189.146/31 permit
|
||||||
77.238.189.148/30 permit
|
77.238.189.148/30 permit
|
||||||
81.223.46.0/27 permit
|
81.223.46.0/27 permit
|
||||||
82.165.159.0/24 permit
|
|
||||||
82.165.159.0/26 permit
|
|
||||||
82.165.229.130 permit
|
|
||||||
82.165.230.22 permit
|
|
||||||
84.16.77.1 permit
|
84.16.77.1 permit
|
||||||
85.158.136.0/21 permit
|
85.158.136.0/21 permit
|
||||||
86.61.88.25 permit
|
86.61.88.25 permit
|
||||||
|
87.198.219.130 permit
|
||||||
|
87.198.219.153 permit
|
||||||
87.238.80.0/21 permit
|
87.238.80.0/21 permit
|
||||||
87.248.103.12 permit
|
87.248.103.12 permit
|
||||||
87.248.103.21 permit
|
87.248.103.21 permit
|
||||||
@@ -633,11 +624,9 @@
|
|||||||
87.248.117.201 permit
|
87.248.117.201 permit
|
||||||
87.248.117.202 permit
|
87.248.117.202 permit
|
||||||
87.248.117.205 permit
|
87.248.117.205 permit
|
||||||
|
87.252.219.254 permit
|
||||||
87.253.232.0/21 permit
|
87.253.232.0/21 permit
|
||||||
89.22.108.0/24 permit
|
89.22.108.0/24 permit
|
||||||
91.194.248.0/23 permit
|
|
||||||
91.211.240.0/22 permit
|
|
||||||
91.211.243.0/24 permit
|
|
||||||
91.220.42.0/24 permit
|
91.220.42.0/24 permit
|
||||||
94.236.119.0/26 permit
|
94.236.119.0/26 permit
|
||||||
94.245.112.0/27 permit
|
94.245.112.0/27 permit
|
||||||
@@ -649,7 +638,6 @@
|
|||||||
96.43.148.64/28 permit
|
96.43.148.64/28 permit
|
||||||
96.43.148.64/31 permit
|
96.43.148.64/31 permit
|
||||||
96.43.151.64/28 permit
|
96.43.151.64/28 permit
|
||||||
96.46.150.192/27 permit
|
|
||||||
98.136.44.181 permit
|
98.136.44.181 permit
|
||||||
98.136.44.182/31 permit
|
98.136.44.182/31 permit
|
||||||
98.136.44.184 permit
|
98.136.44.184 permit
|
||||||
@@ -1152,20 +1140,25 @@
|
|||||||
98.139.245.180/31 permit
|
98.139.245.180/31 permit
|
||||||
98.139.245.208/30 permit
|
98.139.245.208/30 permit
|
||||||
98.139.245.212/31 permit
|
98.139.245.212/31 permit
|
||||||
|
99.78.197.208/28 permit
|
||||||
|
103.2.140.0/22 permit
|
||||||
103.9.8.121 permit
|
103.9.8.121 permit
|
||||||
103.9.8.122 permit
|
103.9.8.122 permit
|
||||||
103.9.8.123 permit
|
103.9.8.123 permit
|
||||||
103.9.96.0/22 permit
|
103.9.96.0/22 permit
|
||||||
103.13.69.0/24 permit
|
103.13.69.0/24 permit
|
||||||
103.28.42.0/24 permit
|
103.47.204.0/22 permit
|
||||||
103.96.20.0/24 permit
|
103.96.21.0/24 permit
|
||||||
103.96.22.0/24 permit
|
103.96.23.0/24 permit
|
||||||
|
103.151.192.0/23 permit
|
||||||
103.237.104.0/22 permit
|
103.237.104.0/22 permit
|
||||||
104.43.243.237 permit
|
104.43.243.237 permit
|
||||||
104.47.0.0/17 permit
|
104.47.0.0/17 permit
|
||||||
104.130.96.0/28 permit
|
104.130.96.0/28 permit
|
||||||
104.130.122.0/23 permit
|
104.130.122.0/23 permit
|
||||||
|
104.214.25.77 permit
|
||||||
104.215.148.63 permit
|
104.215.148.63 permit
|
||||||
|
104.215.186.3 permit
|
||||||
104.245.209.192/26 permit
|
104.245.209.192/26 permit
|
||||||
106.10.144.64/27 permit
|
106.10.144.64/27 permit
|
||||||
106.10.144.100/31 permit
|
106.10.144.100/31 permit
|
||||||
@@ -1291,6 +1284,7 @@
|
|||||||
106.10.242.0/24 permit
|
106.10.242.0/24 permit
|
||||||
106.10.243.0/24 permit
|
106.10.243.0/24 permit
|
||||||
106.10.244.0/24 permit
|
106.10.244.0/24 permit
|
||||||
|
106.39.212.64/29 permit
|
||||||
106.50.16.0/28 permit
|
106.50.16.0/28 permit
|
||||||
108.174.0.0/24 permit
|
108.174.0.0/24 permit
|
||||||
108.174.0.215 permit
|
108.174.0.215 permit
|
||||||
@@ -1302,13 +1296,14 @@
|
|||||||
108.175.30.45 permit
|
108.175.30.45 permit
|
||||||
108.177.8.0/21 permit
|
108.177.8.0/21 permit
|
||||||
108.177.96.0/19 permit
|
108.177.96.0/19 permit
|
||||||
108.178.6.0/24 permit
|
|
||||||
109.237.142.0/24 permit
|
109.237.142.0/24 permit
|
||||||
111.221.23.128/25 permit
|
111.221.23.128/25 permit
|
||||||
111.221.26.0/27 permit
|
111.221.26.0/27 permit
|
||||||
111.221.66.0/25 permit
|
111.221.66.0/25 permit
|
||||||
111.221.69.128/25 permit
|
111.221.69.128/25 permit
|
||||||
111.221.112.0/21 permit
|
111.221.112.0/21 permit
|
||||||
|
112.19.199.64/29 permit
|
||||||
|
112.19.242.64/29 permit
|
||||||
116.214.12.0/24 permit
|
116.214.12.0/24 permit
|
||||||
116.214.12.47 permit
|
116.214.12.47 permit
|
||||||
116.214.12.48/31 permit
|
116.214.12.48/31 permit
|
||||||
@@ -1325,6 +1320,7 @@
|
|||||||
117.120.16.0/21 permit
|
117.120.16.0/21 permit
|
||||||
119.42.242.52/31 permit
|
119.42.242.52/31 permit
|
||||||
119.42.242.156 permit
|
119.42.242.156 permit
|
||||||
|
123.126.78.64/29 permit
|
||||||
124.47.150.0/24 permit
|
124.47.150.0/24 permit
|
||||||
124.47.189.0/24 permit
|
124.47.189.0/24 permit
|
||||||
124.108.96.0/24 permit
|
124.108.96.0/24 permit
|
||||||
@@ -1332,11 +1328,19 @@
|
|||||||
124.108.96.28/31 permit
|
124.108.96.28/31 permit
|
||||||
124.108.96.70/31 permit
|
124.108.96.70/31 permit
|
||||||
124.108.96.72/31 permit
|
124.108.96.72/31 permit
|
||||||
|
128.17.0.0/20 permit
|
||||||
|
128.17.64.0/20 permit
|
||||||
|
128.17.128.0/20 permit
|
||||||
|
128.17.192.0/20 permit
|
||||||
128.127.70.0/26 permit
|
128.127.70.0/26 permit
|
||||||
|
128.245.0.0/20 permit
|
||||||
|
128.245.64.0/20 permit
|
||||||
129.41.77.70 permit
|
129.41.77.70 permit
|
||||||
129.41.169.249 permit
|
129.41.169.249 permit
|
||||||
|
129.146.236.58 permit
|
||||||
|
129.153.194.228 permit
|
||||||
|
129.159.87.137 permit
|
||||||
130.61.9.72 permit
|
130.61.9.72 permit
|
||||||
130.61.68.235 permit
|
|
||||||
130.211.0.0/22 permit
|
130.211.0.0/22 permit
|
||||||
130.248.172.0/24 permit
|
130.248.172.0/24 permit
|
||||||
130.248.173.0/24 permit
|
130.248.173.0/24 permit
|
||||||
@@ -1345,8 +1349,10 @@
|
|||||||
131.253.121.0/26 permit
|
131.253.121.0/26 permit
|
||||||
131.253.121.20 permit
|
131.253.121.20 permit
|
||||||
131.253.121.52 permit
|
131.253.121.52 permit
|
||||||
132.145.11.129 permit
|
|
||||||
132.145.13.209 permit
|
132.145.13.209 permit
|
||||||
|
132.226.26.225 permit
|
||||||
|
132.226.49.32 permit
|
||||||
|
132.226.56.24 permit
|
||||||
134.170.27.8 permit
|
134.170.27.8 permit
|
||||||
134.170.113.0/26 permit
|
134.170.113.0/26 permit
|
||||||
134.170.141.64/26 permit
|
134.170.141.64/26 permit
|
||||||
@@ -1356,21 +1362,27 @@
|
|||||||
135.84.82.0/24 permit
|
135.84.82.0/24 permit
|
||||||
135.84.216.0/22 permit
|
135.84.216.0/22 permit
|
||||||
136.143.182.0/23 permit
|
136.143.182.0/23 permit
|
||||||
136.143.188.0/23 permit
|
136.143.184.0/24 permit
|
||||||
|
136.143.188.0/24 permit
|
||||||
136.147.128.0/20 permit
|
136.147.128.0/20 permit
|
||||||
136.147.135.0/24 permit
|
136.147.135.0/24 permit
|
||||||
136.147.176.0/20 permit
|
136.147.176.0/20 permit
|
||||||
136.147.176.0/24 permit
|
136.147.176.0/24 permit
|
||||||
136.147.182.0/24 permit
|
136.147.182.0/24 permit
|
||||||
|
138.91.172.26 permit
|
||||||
139.60.152.0/22 permit
|
139.60.152.0/22 permit
|
||||||
139.178.64.159 permit
|
139.178.64.159 permit
|
||||||
139.178.64.195 permit
|
139.178.64.195 permit
|
||||||
139.180.17.0/24 permit
|
|
||||||
141.193.32.0/23 permit
|
141.193.32.0/23 permit
|
||||||
|
143.55.224.0/21 permit
|
||||||
|
143.55.232.0/22 permit
|
||||||
|
143.55.236.0/22 permit
|
||||||
|
144.178.36.0/24 permit
|
||||||
|
144.178.38.0/24 permit
|
||||||
146.20.112.0/26 permit
|
146.20.112.0/26 permit
|
||||||
146.20.113.0/24 permit
|
146.20.113.0/24 permit
|
||||||
146.20.191.0/24 permit
|
146.20.191.0/24 permit
|
||||||
146.88.28.0/24 permit
|
146.20.215.0/24 permit
|
||||||
146.101.78.0/24 permit
|
146.101.78.0/24 permit
|
||||||
147.75.65.173 permit
|
147.75.65.173 permit
|
||||||
147.75.65.174 permit
|
147.75.65.174 permit
|
||||||
@@ -1384,10 +1396,7 @@
|
|||||||
148.105.0.14 permit
|
148.105.0.14 permit
|
||||||
148.105.8.0/21 permit
|
148.105.8.0/21 permit
|
||||||
149.72.0.0/16 permit
|
149.72.0.0/16 permit
|
||||||
151.101.1.140 permit
|
152.67.105.195 permit
|
||||||
151.101.65.140 permit
|
|
||||||
151.101.129.140 permit
|
|
||||||
151.101.193.140 permit
|
|
||||||
157.55.0.192/26 permit
|
157.55.0.192/26 permit
|
||||||
157.55.1.128/26 permit
|
157.55.1.128/26 permit
|
||||||
157.55.2.0/25 permit
|
157.55.2.0/25 permit
|
||||||
@@ -1397,6 +1406,7 @@
|
|||||||
157.55.61.0/24 permit
|
157.55.61.0/24 permit
|
||||||
157.55.157.128/25 permit
|
157.55.157.128/25 permit
|
||||||
157.55.225.0/25 permit
|
157.55.225.0/25 permit
|
||||||
|
157.55.254.216 permit
|
||||||
157.56.24.0/25 permit
|
157.56.24.0/25 permit
|
||||||
157.56.120.128/26 permit
|
157.56.120.128/26 permit
|
||||||
157.56.232.0/21 permit
|
157.56.232.0/21 permit
|
||||||
@@ -1405,21 +1415,26 @@
|
|||||||
157.58.196.96/29 permit
|
157.58.196.96/29 permit
|
||||||
157.58.249.3 permit
|
157.58.249.3 permit
|
||||||
157.151.208.65 permit
|
157.151.208.65 permit
|
||||||
158.247.16.0/20 permit
|
157.255.1.64/29 permit
|
||||||
|
159.92.157.0/24 permit
|
||||||
|
159.92.158.0/24 permit
|
||||||
|
159.92.159.0/24 permit
|
||||||
|
159.92.160.0/24 permit
|
||||||
|
159.92.161.0/24 permit
|
||||||
|
159.92.162.0/24 permit
|
||||||
|
159.135.132.128/25 permit
|
||||||
|
159.135.140.80/29 permit
|
||||||
159.135.224.0/20 permit
|
159.135.224.0/20 permit
|
||||||
161.38.192.0/22 permit
|
159.183.0.0/16 permit
|
||||||
161.38.196.0/22 permit
|
161.38.192.0/20 permit
|
||||||
161.71.32.0/21 permit
|
161.38.204.0/22 permit
|
||||||
|
161.71.32.0/19 permit
|
||||||
|
161.71.64.0/20 permit
|
||||||
162.208.119.181 permit
|
162.208.119.181 permit
|
||||||
162.247.216.0/22 permit
|
162.247.216.0/22 permit
|
||||||
162.248.184.121 permit
|
163.47.180.0/23 permit
|
||||||
162.248.184.122 permit
|
|
||||||
162.248.185.121 permit
|
|
||||||
162.248.185.122 permit
|
|
||||||
162.248.186.121 permit
|
|
||||||
162.248.186.122 permit
|
|
||||||
163.47.180.0/22 permit
|
|
||||||
163.114.130.16 permit
|
163.114.130.16 permit
|
||||||
|
163.114.132.120 permit
|
||||||
166.78.68.0/22 permit
|
166.78.68.0/22 permit
|
||||||
166.78.68.221 permit
|
166.78.68.221 permit
|
||||||
166.78.69.146 permit
|
166.78.69.146 permit
|
||||||
@@ -1427,16 +1442,7 @@
|
|||||||
166.78.69.170 permit
|
166.78.69.170 permit
|
||||||
166.78.71.131 permit
|
166.78.71.131 permit
|
||||||
167.89.0.0/17 permit
|
167.89.0.0/17 permit
|
||||||
167.89.2.4 permit
|
|
||||||
167.89.22.44 permit
|
|
||||||
167.89.25.84 permit
|
|
||||||
167.89.31.192/29 permit
|
|
||||||
167.89.32.5 permit
|
|
||||||
167.89.32.50 permit
|
|
||||||
167.89.46.159 permit
|
167.89.46.159 permit
|
||||||
167.89.46.185 permit
|
|
||||||
167.89.60.95 permit
|
|
||||||
167.89.62.118 permit
|
|
||||||
167.89.64.9 permit
|
167.89.64.9 permit
|
||||||
167.89.65.0 permit
|
167.89.65.0 permit
|
||||||
167.89.65.53 permit
|
167.89.65.53 permit
|
||||||
@@ -1448,22 +1454,15 @@
|
|||||||
167.89.75.164 permit
|
167.89.75.164 permit
|
||||||
167.89.101.2 permit
|
167.89.101.2 permit
|
||||||
167.89.101.192/28 permit
|
167.89.101.192/28 permit
|
||||||
167.89.107.125 permit
|
|
||||||
167.89.107.127 permit
|
|
||||||
167.89.107.129 permit
|
|
||||||
167.89.107.136 permit
|
|
||||||
167.216.129.170 permit
|
|
||||||
167.216.129.182/31 permit
|
|
||||||
167.216.129.184/29 permit
|
|
||||||
167.216.129.192/29 permit
|
|
||||||
167.216.129.200 permit
|
|
||||||
167.216.129.205 permit
|
|
||||||
167.216.129.206/31 permit
|
|
||||||
167.216.129.208/31 permit
|
|
||||||
167.216.129.210 permit
|
167.216.129.210 permit
|
||||||
|
167.216.131.180 permit
|
||||||
167.220.67.232/29 permit
|
167.220.67.232/29 permit
|
||||||
167.220.67.238 permit
|
167.220.67.238 permit
|
||||||
|
168.138.5.36 permit
|
||||||
168.245.0.0/17 permit
|
168.245.0.0/17 permit
|
||||||
|
170.10.68.0/22 permit
|
||||||
|
170.10.129.0/24 permit
|
||||||
|
170.10.133.0/24 permit
|
||||||
172.217.0.0/19 permit
|
172.217.0.0/19 permit
|
||||||
172.217.32.0/20 permit
|
172.217.32.0/20 permit
|
||||||
172.217.128.0/19 permit
|
172.217.128.0/19 permit
|
||||||
@@ -1473,8 +1472,6 @@
|
|||||||
172.253.112.0/20 permit
|
172.253.112.0/20 permit
|
||||||
173.0.84.224/27 permit
|
173.0.84.224/27 permit
|
||||||
173.0.94.244/30 permit
|
173.0.94.244/30 permit
|
||||||
173.193.132.134/31 permit
|
|
||||||
173.193.210.32/27 permit
|
|
||||||
173.194.0.0/16 permit
|
173.194.0.0/16 permit
|
||||||
173.203.79.182 permit
|
173.203.79.182 permit
|
||||||
173.203.81.39 permit
|
173.203.81.39 permit
|
||||||
@@ -1482,7 +1479,6 @@
|
|||||||
173.224.160.188 permit
|
173.224.160.188 permit
|
||||||
173.224.161.128/25 permit
|
173.224.161.128/25 permit
|
||||||
173.228.155.0/24 permit
|
173.228.155.0/24 permit
|
||||||
173.236.20.0/24 permit
|
|
||||||
174.36.84.8/29 permit
|
174.36.84.8/29 permit
|
||||||
174.36.84.16/29 permit
|
174.36.84.16/29 permit
|
||||||
174.36.84.32/29 permit
|
174.36.84.32/29 permit
|
||||||
@@ -1494,30 +1490,25 @@
|
|||||||
174.36.114.148/30 permit
|
174.36.114.148/30 permit
|
||||||
174.36.114.152/29 permit
|
174.36.114.152/29 permit
|
||||||
174.37.67.28/30 permit
|
174.37.67.28/30 permit
|
||||||
174.37.226.64/27 permit
|
|
||||||
174.129.194.241 permit
|
|
||||||
174.129.203.189 permit
|
174.129.203.189 permit
|
||||||
174.137.46.0/24 permit
|
|
||||||
176.32.105.0/24 permit
|
176.32.105.0/24 permit
|
||||||
176.32.127.0/24 permit
|
176.32.127.0/24 permit
|
||||||
178.236.10.128/26 permit
|
178.236.10.128/26 permit
|
||||||
180.189.28.0/24 permit
|
180.189.28.0/24 permit
|
||||||
182.50.76.0/22 permit
|
182.50.76.0/22 permit
|
||||||
182.50.78.64/28 permit
|
182.50.78.64/28 permit
|
||||||
184.173.105.0/24 permit
|
183.240.219.64/29 permit
|
||||||
184.173.153.0/24 permit
|
|
||||||
185.4.120.0/24 permit
|
|
||||||
185.4.122.0/24 permit
|
|
||||||
185.12.80.0/22 permit
|
185.12.80.0/22 permit
|
||||||
185.28.196.0/22 permit
|
185.28.196.0/22 permit
|
||||||
185.58.84.0/24 permit
|
185.58.84.93 permit
|
||||||
185.58.87.0/24 permit
|
185.58.85.0/24 permit
|
||||||
|
185.58.86.0/24 permit
|
||||||
185.72.128.75 permit
|
185.72.128.75 permit
|
||||||
185.72.128.76 permit
|
185.72.128.76 permit
|
||||||
|
185.72.128.80 permit
|
||||||
185.80.93.204 permit
|
185.80.93.204 permit
|
||||||
185.80.93.227 permit
|
185.80.93.227 permit
|
||||||
185.80.95.31 permit
|
185.80.95.31 permit
|
||||||
185.90.20.0/22 permit
|
|
||||||
185.189.236.0/22 permit
|
185.189.236.0/22 permit
|
||||||
185.211.120.0/22 permit
|
185.211.120.0/22 permit
|
||||||
185.250.236.0/22 permit
|
185.250.236.0/22 permit
|
||||||
@@ -1577,7 +1568,6 @@
|
|||||||
192.64.236.0/24 permit
|
192.64.236.0/24 permit
|
||||||
192.64.237.0/24 permit
|
192.64.237.0/24 permit
|
||||||
192.64.238.0/24 permit
|
192.64.238.0/24 permit
|
||||||
192.92.97.0/24 permit
|
|
||||||
192.161.144.0/20 permit
|
192.161.144.0/20 permit
|
||||||
192.162.87.0/24 permit
|
192.162.87.0/24 permit
|
||||||
192.237.158.0/23 permit
|
192.237.158.0/23 permit
|
||||||
@@ -1589,37 +1579,34 @@
|
|||||||
192.254.113.10 permit
|
192.254.113.10 permit
|
||||||
192.254.113.101 permit
|
192.254.113.101 permit
|
||||||
192.254.114.176 permit
|
192.254.114.176 permit
|
||||||
192.254.115.72 permit
|
|
||||||
192.254.118.63 permit
|
192.254.118.63 permit
|
||||||
192.254.127.96/27 permit
|
193.7.206.0/25 permit
|
||||||
|
193.7.207.0/25 permit
|
||||||
193.109.254.0/23 permit
|
193.109.254.0/23 permit
|
||||||
194.64.234.128/27 permit
|
193.122.128.100 permit
|
||||||
194.64.234.129 permit
|
194.64.234.129 permit
|
||||||
|
194.104.109.0/24 permit
|
||||||
|
194.104.111.0/24 permit
|
||||||
194.106.220.0/23 permit
|
194.106.220.0/23 permit
|
||||||
194.113.24.0/22 permit
|
|
||||||
194.154.193.192/27 permit
|
194.154.193.192/27 permit
|
||||||
195.54.172.0/23 permit
|
|
||||||
195.130.217.0/24 permit
|
195.130.217.0/24 permit
|
||||||
|
195.234.109.226 permit
|
||||||
195.245.230.0/23 permit
|
195.245.230.0/23 permit
|
||||||
198.2.128.0/18 permit
|
198.2.128.0/18 permit
|
||||||
198.2.128.0/24 permit
|
198.2.128.0/24 permit
|
||||||
198.2.132.0/22 permit
|
198.2.132.0/22 permit
|
||||||
198.2.136.0/23 permit
|
198.2.136.0/23 permit
|
||||||
|
198.2.145.0/24 permit
|
||||||
198.2.177.0/24 permit
|
198.2.177.0/24 permit
|
||||||
198.2.178.0/24 permit
|
198.2.178.0/23 permit
|
||||||
198.2.179.0/24 permit
|
|
||||||
198.2.180.0/24 permit
|
198.2.180.0/24 permit
|
||||||
198.2.186.0/23 permit
|
198.2.186.0/23 permit
|
||||||
198.21.0.0/21 permit
|
198.21.0.0/21 permit
|
||||||
198.21.3.166 permit
|
|
||||||
198.21.4.224 permit
|
|
||||||
198.37.144.0/20 permit
|
198.37.144.0/20 permit
|
||||||
198.37.145.250 permit
|
198.37.152.186 permit
|
||||||
198.37.146.118/31 permit
|
|
||||||
198.37.149.128 permit
|
|
||||||
198.37.151.26 permit
|
|
||||||
198.61.254.0/23 permit
|
198.61.254.0/23 permit
|
||||||
198.61.254.231 permit
|
198.61.254.231 permit
|
||||||
|
198.74.56.28 permit
|
||||||
198.178.234.57 permit
|
198.178.234.57 permit
|
||||||
198.245.80.0/20 permit
|
198.245.80.0/20 permit
|
||||||
198.245.81.0/24 permit
|
198.245.81.0/24 permit
|
||||||
@@ -1636,18 +1623,15 @@
|
|||||||
199.122.120.0/21 permit
|
199.122.120.0/21 permit
|
||||||
199.122.123.0/24 permit
|
199.122.123.0/24 permit
|
||||||
199.127.232.0/22 permit
|
199.127.232.0/22 permit
|
||||||
199.201.64.23 permit
|
|
||||||
199.201.65.23 permit
|
|
||||||
199.255.192.0/22 permit
|
199.255.192.0/22 permit
|
||||||
202.129.242.0/23 permit
|
202.129.242.0/23 permit
|
||||||
202.165.102.47 permit
|
202.165.102.47 permit
|
||||||
202.177.148.100 permit
|
202.177.148.100 permit
|
||||||
202.177.148.110 permit
|
202.177.148.110 permit
|
||||||
|
203.31.36.0/22 permit
|
||||||
203.32.4.25 permit
|
203.32.4.25 permit
|
||||||
203.55.21.0/24 permit
|
|
||||||
203.81.17.0/24 permit
|
203.81.17.0/24 permit
|
||||||
203.122.32.250 permit
|
203.122.32.250 permit
|
||||||
203.145.57.160/27 permit
|
|
||||||
203.188.194.32 permit
|
203.188.194.32 permit
|
||||||
203.188.194.151 permit
|
203.188.194.151 permit
|
||||||
203.188.194.203 permit
|
203.188.194.203 permit
|
||||||
@@ -1680,32 +1664,30 @@
|
|||||||
203.188.201.12/30 permit
|
203.188.201.12/30 permit
|
||||||
203.209.230.75 permit
|
203.209.230.75 permit
|
||||||
203.209.230.76/31 permit
|
203.209.230.76/31 permit
|
||||||
204.2.193.0/29 permit
|
|
||||||
204.11.168.0/21 permit
|
204.11.168.0/21 permit
|
||||||
204.13.11.48/29 permit
|
204.13.11.48/29 permit
|
||||||
204.13.11.48/30 permit
|
|
||||||
204.14.232.0/21 permit
|
204.14.232.0/21 permit
|
||||||
204.14.232.64/28 permit
|
204.14.232.64/28 permit
|
||||||
204.14.234.64/28 permit
|
204.14.234.64/28 permit
|
||||||
204.29.186.0/23 permit
|
204.29.186.0/23 permit
|
||||||
204.75.142.0/24 permit
|
|
||||||
204.79.197.212 permit
|
204.79.197.212 permit
|
||||||
204.92.114.187 permit
|
204.92.114.187 permit
|
||||||
204.92.114.203 permit
|
204.92.114.203 permit
|
||||||
204.92.114.204/31 permit
|
204.92.114.204/31 permit
|
||||||
204.141.32.0/23 permit
|
204.141.32.0/23 permit
|
||||||
204.141.42.0/23 permit
|
204.141.42.0/23 permit
|
||||||
204.153.120.0/23 permit
|
204.153.121.0/24 permit
|
||||||
|
204.232.168.0/24 permit
|
||||||
205.139.110.0/24 permit
|
205.139.110.0/24 permit
|
||||||
205.139.111.0/24 permit
|
|
||||||
205.201.128.0/20 permit
|
205.201.128.0/20 permit
|
||||||
205.201.131.128/25 permit
|
205.201.131.128/25 permit
|
||||||
205.201.134.128/25 permit
|
205.201.134.128/25 permit
|
||||||
205.201.136.0/23 permit
|
205.201.136.0/23 permit
|
||||||
205.201.137.229 permit
|
|
||||||
205.201.139.0/24 permit
|
205.201.139.0/24 permit
|
||||||
205.207.104.0/22 permit
|
205.207.104.0/22 permit
|
||||||
205.207.104.108 permit
|
205.207.104.108 permit
|
||||||
|
205.220.167.17 permit
|
||||||
|
205.220.179.17 permit
|
||||||
205.251.233.32 permit
|
205.251.233.32 permit
|
||||||
205.251.233.36 permit
|
205.251.233.36 permit
|
||||||
206.25.247.143 permit
|
206.25.247.143 permit
|
||||||
@@ -1727,6 +1709,8 @@
|
|||||||
207.46.132.128/27 permit
|
207.46.132.128/27 permit
|
||||||
207.46.198.0/25 permit
|
207.46.198.0/25 permit
|
||||||
207.46.200.0/27 permit
|
207.46.200.0/27 permit
|
||||||
|
207.46.225.107 permit
|
||||||
|
207.58.147.64/28 permit
|
||||||
207.67.38.0/24 permit
|
207.67.38.0/24 permit
|
||||||
207.67.98.192/27 permit
|
207.67.98.192/27 permit
|
||||||
207.68.176.0/26 permit
|
207.68.176.0/26 permit
|
||||||
@@ -1734,7 +1718,8 @@
|
|||||||
207.82.80.0/24 permit
|
207.82.80.0/24 permit
|
||||||
207.126.144.0/20 permit
|
207.126.144.0/20 permit
|
||||||
207.171.160.0/19 permit
|
207.171.160.0/19 permit
|
||||||
207.211.30.0/24 permit
|
207.211.30.64/26 permit
|
||||||
|
207.211.30.128/25 permit
|
||||||
207.211.31.0/25 permit
|
207.211.31.0/25 permit
|
||||||
207.211.41.113 permit
|
207.211.41.113 permit
|
||||||
207.218.90.0/24 permit
|
207.218.90.0/24 permit
|
||||||
@@ -1743,7 +1728,7 @@
|
|||||||
208.43.21.28/30 permit
|
208.43.21.28/30 permit
|
||||||
208.43.21.64/29 permit
|
208.43.21.64/29 permit
|
||||||
208.43.21.72/30 permit
|
208.43.21.72/30 permit
|
||||||
208.43.239.136/30 permit
|
208.46.212.80 permit
|
||||||
208.46.212.208/31 permit
|
208.46.212.208/31 permit
|
||||||
208.46.212.210 permit
|
208.46.212.210 permit
|
||||||
208.64.132.0/22 permit
|
208.64.132.0/22 permit
|
||||||
@@ -1773,13 +1758,13 @@
|
|||||||
208.71.42.212/31 permit
|
208.71.42.212/31 permit
|
||||||
208.71.42.214 permit
|
208.71.42.214 permit
|
||||||
208.72.249.240/29 permit
|
208.72.249.240/29 permit
|
||||||
208.74.204.0/22 permit
|
|
||||||
208.74.204.9 permit
|
208.74.204.9 permit
|
||||||
208.75.120.0/22 permit
|
208.75.120.0/22 permit
|
||||||
208.75.122.246 permit
|
208.75.122.246 permit
|
||||||
208.82.236.96/28 permit
|
208.82.237.96/29 permit
|
||||||
208.82.237.96/28 permit
|
208.82.237.104/31 permit
|
||||||
208.82.238.96/28 permit
|
208.82.238.96/29 permit
|
||||||
|
208.82.238.104/31 permit
|
||||||
208.85.50.137 permit
|
208.85.50.137 permit
|
||||||
208.117.48.0/20 permit
|
208.117.48.0/20 permit
|
||||||
208.185.229.45 permit
|
208.185.229.45 permit
|
||||||
@@ -1792,10 +1777,10 @@
|
|||||||
209.67.98.59 permit
|
209.67.98.59 permit
|
||||||
209.85.128.0/17 permit
|
209.85.128.0/17 permit
|
||||||
212.4.136.0/26 permit
|
212.4.136.0/26 permit
|
||||||
212.25.240.75 permit
|
212.25.240.80 permit
|
||||||
212.25.240.76 permit
|
|
||||||
212.25.240.83 permit
|
212.25.240.83 permit
|
||||||
212.25.240.84 permit
|
212.25.240.84/31 permit
|
||||||
|
212.25.240.88 permit
|
||||||
212.82.96.0/24 permit
|
212.82.96.0/24 permit
|
||||||
212.82.96.32/27 permit
|
212.82.96.32/27 permit
|
||||||
212.82.96.64/29 permit
|
212.82.96.64/29 permit
|
||||||
@@ -1836,13 +1821,8 @@
|
|||||||
212.82.111.228/31 permit
|
212.82.111.228/31 permit
|
||||||
212.82.111.230 permit
|
212.82.111.230 permit
|
||||||
212.123.28.40 permit
|
212.123.28.40 permit
|
||||||
212.227.15.0/24 permit
|
213.167.75.0/25 permit
|
||||||
212.227.15.0/25 permit
|
213.167.81.0/25 permit
|
||||||
212.227.17.0/27 permit
|
|
||||||
212.227.126.128/25 permit
|
|
||||||
213.165.64.0/23 permit
|
|
||||||
213.167.75.0/24 permit
|
|
||||||
213.167.81.0/24 permit
|
|
||||||
213.199.128.139 permit
|
213.199.128.139 permit
|
||||||
213.199.128.145 permit
|
213.199.128.145 permit
|
||||||
213.199.138.181 permit
|
213.199.138.181 permit
|
||||||
@@ -1851,6 +1831,7 @@
|
|||||||
213.199.177.0/26 permit
|
213.199.177.0/26 permit
|
||||||
216.17.150.242 permit
|
216.17.150.242 permit
|
||||||
216.17.150.251 permit
|
216.17.150.251 permit
|
||||||
|
216.22.15.224/27 permit
|
||||||
216.24.224.0/20 permit
|
216.24.224.0/20 permit
|
||||||
216.39.60.0/23 permit
|
216.39.60.0/23 permit
|
||||||
216.39.60.154/31 permit
|
216.39.60.154/31 permit
|
||||||
@@ -1877,17 +1858,9 @@
|
|||||||
216.39.62.60/31 permit
|
216.39.62.60/31 permit
|
||||||
216.39.62.136/29 permit
|
216.39.62.136/29 permit
|
||||||
216.39.62.144/31 permit
|
216.39.62.144/31 permit
|
||||||
216.46.168.197 permit
|
216.46.168.0/24 permit
|
||||||
216.46.168.222 permit
|
|
||||||
216.52.185.88/29 permit
|
|
||||||
216.58.192.0/19 permit
|
216.58.192.0/19 permit
|
||||||
216.66.217.240/29 permit
|
216.66.217.240/29 permit
|
||||||
216.71.96.0/22 permit
|
|
||||||
216.71.152.175 permit
|
|
||||||
216.71.152.207 permit
|
|
||||||
216.71.154.29 permit
|
|
||||||
216.71.155.88 permit
|
|
||||||
216.71.155.89 permit
|
|
||||||
216.74.162.13 permit
|
216.74.162.13 permit
|
||||||
216.74.162.14 permit
|
216.74.162.14 permit
|
||||||
216.82.240.0/20 permit
|
216.82.240.0/20 permit
|
||||||
@@ -1897,9 +1870,6 @@
|
|||||||
216.109.114.0/24 permit
|
216.109.114.0/24 permit
|
||||||
216.109.114.32/27 permit
|
216.109.114.32/27 permit
|
||||||
216.109.114.64/29 permit
|
216.109.114.64/29 permit
|
||||||
216.113.160.0/24 permit
|
|
||||||
216.113.172.0/25 permit
|
|
||||||
216.113.175.0/24 permit
|
|
||||||
216.128.126.97 permit
|
216.128.126.97 permit
|
||||||
216.136.162.65 permit
|
216.136.162.65 permit
|
||||||
216.136.162.120/29 permit
|
216.136.162.120/29 permit
|
||||||
@@ -1909,14 +1879,13 @@
|
|||||||
216.203.33.178/31 permit
|
216.203.33.178/31 permit
|
||||||
216.205.24.0/24 permit
|
216.205.24.0/24 permit
|
||||||
216.239.32.0/19 permit
|
216.239.32.0/19 permit
|
||||||
217.72.192.64/26 permit
|
|
||||||
217.72.192.248/29 permit
|
|
||||||
217.72.207.0/27 permit
|
|
||||||
217.77.141.52 permit
|
217.77.141.52 permit
|
||||||
217.77.141.59 permit
|
217.77.141.59 permit
|
||||||
217.175.193.0/24 permit
|
222.73.195.64/29 permit
|
||||||
217.175.194.0/23 permit
|
223.165.113.0/24 permit
|
||||||
217.175.196.0/24 permit
|
223.165.115.0/24 permit
|
||||||
|
223.165.118.0/23 permit
|
||||||
|
223.165.120.0/23 permit
|
||||||
2001:4860:4000::/36 permit
|
2001:4860:4000::/36 permit
|
||||||
2404:6800:4000::/36 permit
|
2404:6800:4000::/36 permit
|
||||||
2607:f8b0:4000::/36 permit
|
2607:f8b0:4000::/36 permit
|
||||||
@@ -1925,6 +1894,7 @@
|
|||||||
2620:109:c006:104::215 permit
|
2620:109:c006:104::215 permit
|
||||||
2620:109:c006:104::/64 permit
|
2620:109:c006:104::/64 permit
|
||||||
2620:109:c00d:104::/64 permit
|
2620:109:c00d:104::/64 permit
|
||||||
|
2620:10d:c090:450::120 permit
|
||||||
2620:10d:c091:450::16 permit
|
2620:10d:c091:450::16 permit
|
||||||
2620:119:50c0:207::215 permit
|
2620:119:50c0:207::215 permit
|
||||||
2620:119:50c0:207::/64 permit
|
2620:119:50c0:207::/64 permit
|
||||||
|
@@ -1,24 +0,0 @@
|
|||||||
rules {
|
|
||||||
"LONG" {
|
|
||||||
train {
|
|
||||||
max_trains = 200;
|
|
||||||
max_usages = 20;
|
|
||||||
max_iterations = 25;
|
|
||||||
learning_rate = 0.01,
|
|
||||||
}
|
|
||||||
symbol_spam = "NEURAL_SPAM_LONG";
|
|
||||||
symbol_ham = "NEURAL_HAM_LONG";
|
|
||||||
ann_expire = 45d;
|
|
||||||
}
|
|
||||||
"SHORT" {
|
|
||||||
train {
|
|
||||||
max_trains = 100;
|
|
||||||
max_usages = 10;
|
|
||||||
max_iterations = 15;
|
|
||||||
learning_rate = 0.01,
|
|
||||||
}
|
|
||||||
symbol_spam = "NEURAL_SPAM_SHORT";
|
|
||||||
symbol_ham = "NEURAL_HAM_SHORT";
|
|
||||||
ann_expire = 7d;
|
|
||||||
}
|
|
||||||
}
|
|
@@ -1,18 +0,0 @@
|
|||||||
symbols = {
|
|
||||||
"NEURAL_SPAM_LONG" {
|
|
||||||
weight = 3.7; # sample weight
|
|
||||||
description = "Neural network spam (long)";
|
|
||||||
}
|
|
||||||
"NEURAL_HAM_LONG" {
|
|
||||||
weight = -4.0; # sample weight
|
|
||||||
description = "Neural network ham (long)";
|
|
||||||
}
|
|
||||||
"NEURAL_SPAM_SHORT" {
|
|
||||||
weight = 2.5; # sample weight
|
|
||||||
description = "Neural network spam (short)";
|
|
||||||
}
|
|
||||||
"NEURAL_HAM_SHORT" {
|
|
||||||
weight = -2.0; # sample weight
|
|
||||||
description = "Neural network ham (short)";
|
|
||||||
}
|
|
||||||
}
|
|
@@ -39,7 +39,7 @@
|
|||||||
window.onload = function() {
|
window.onload = function() {
|
||||||
// Begin Swagger UI call region
|
// Begin Swagger UI call region
|
||||||
const ui = SwaggerUIBundle({
|
const ui = SwaggerUIBundle({
|
||||||
url: "/api/openapi.yaml",
|
urls: [{url: "/api/openapi.yaml", name: "mailcow API"}],
|
||||||
dom_id: '#swagger-ui',
|
dom_id: '#swagger-ui',
|
||||||
deepLinking: true,
|
deepLinking: true,
|
||||||
presets: [
|
presets: [
|
||||||
|
@@ -209,10 +209,17 @@ paths:
|
|||||||
- app_passwd
|
- app_passwd
|
||||||
- add
|
- add
|
||||||
- active: "1"
|
- active: "1"
|
||||||
app_name: emclient
|
username: info@domain.tld
|
||||||
|
app_name: wordpress
|
||||||
app_passwd: keyleudecticidechothistishownsan31
|
app_passwd: keyleudecticidechothistishownsan31
|
||||||
app_passwd2: keyleudecticidechothistishownsan31
|
app_passwd2: keyleudecticidechothistishownsan31
|
||||||
username: hello@mailcow.email
|
protocols:
|
||||||
|
- imap_access
|
||||||
|
- dav_access
|
||||||
|
- smtp_access
|
||||||
|
- eas_access
|
||||||
|
- pop3_access
|
||||||
|
- sieve_access
|
||||||
msg: app_passwd_added
|
msg: app_passwd_added
|
||||||
type: success
|
type: success
|
||||||
schema:
|
schema:
|
||||||
@@ -249,6 +256,13 @@ paths:
|
|||||||
app_name: wordpress
|
app_name: wordpress
|
||||||
app_passwd: keyleudecticidechothistishownsan31
|
app_passwd: keyleudecticidechothistishownsan31
|
||||||
app_passwd2: keyleudecticidechothistishownsan31
|
app_passwd2: keyleudecticidechothistishownsan31
|
||||||
|
protocols:
|
||||||
|
- imap_access
|
||||||
|
- dav_access
|
||||||
|
- smtp_access
|
||||||
|
- eas_access
|
||||||
|
- pop3_access
|
||||||
|
- sieve_access
|
||||||
properties:
|
properties:
|
||||||
active:
|
active:
|
||||||
description: is alias active or not
|
description: is alias active or not
|
||||||
@@ -497,6 +511,7 @@ paths:
|
|||||||
relay_all_recipients: "0"
|
relay_all_recipients: "0"
|
||||||
rl_frame: s
|
rl_frame: s
|
||||||
rl_value: "10"
|
rl_value: "10"
|
||||||
|
tags: ["tag1", "tag2"]
|
||||||
- null
|
- null
|
||||||
msg:
|
msg:
|
||||||
- domain_added
|
- domain_added
|
||||||
@@ -544,6 +559,7 @@ paths:
|
|||||||
rl_frame: s
|
rl_frame: s
|
||||||
rl_value: "10"
|
rl_value: "10"
|
||||||
restart_sogo: "10"
|
restart_sogo: "10"
|
||||||
|
tags: ["tag1", "tag2"]
|
||||||
properties:
|
properties:
|
||||||
active:
|
active:
|
||||||
description: is domain active or not
|
description: is domain active or not
|
||||||
@@ -1010,6 +1026,7 @@ paths:
|
|||||||
force_pw_update: "1"
|
force_pw_update: "1"
|
||||||
tls_enforce_in: "1"
|
tls_enforce_in: "1"
|
||||||
tls_enforce_out: "1"
|
tls_enforce_out: "1"
|
||||||
|
tags: ["tag1", "tag2"]
|
||||||
- null
|
- null
|
||||||
msg:
|
msg:
|
||||||
- mailbox_added
|
- mailbox_added
|
||||||
@@ -1054,6 +1071,7 @@ paths:
|
|||||||
force_pw_update: "1"
|
force_pw_update: "1"
|
||||||
tls_enforce_in: "1"
|
tls_enforce_in: "1"
|
||||||
tls_enforce_out: "1"
|
tls_enforce_out: "1"
|
||||||
|
tags: ["tag1", "tag2"]
|
||||||
properties:
|
properties:
|
||||||
active:
|
active:
|
||||||
description: is mailbox active or not
|
description: is mailbox active or not
|
||||||
@@ -2716,6 +2734,140 @@ paths:
|
|||||||
type: object
|
type: object
|
||||||
type: object
|
type: object
|
||||||
summary: Delete Transport Maps
|
summary: Delete Transport Maps
|
||||||
|
"/api/v1/delete/mailbox/tag/{mailbox}":
|
||||||
|
post:
|
||||||
|
parameters:
|
||||||
|
- description: name of mailbox
|
||||||
|
in: path
|
||||||
|
name: mailbox
|
||||||
|
example: info@domain.tld
|
||||||
|
required: true
|
||||||
|
schema:
|
||||||
|
type: string
|
||||||
|
responses:
|
||||||
|
"401":
|
||||||
|
$ref: "#/components/responses/Unauthorized"
|
||||||
|
"200":
|
||||||
|
content:
|
||||||
|
application/json:
|
||||||
|
examples:
|
||||||
|
response:
|
||||||
|
value:
|
||||||
|
- log:
|
||||||
|
- mailbox
|
||||||
|
- delete
|
||||||
|
- tags_mailbox
|
||||||
|
- tags:
|
||||||
|
- tag1
|
||||||
|
- tag2
|
||||||
|
mailbox: info@domain.tld
|
||||||
|
- null
|
||||||
|
msg:
|
||||||
|
- mailbox_modified
|
||||||
|
- info@domain.tld
|
||||||
|
type: success
|
||||||
|
schema:
|
||||||
|
properties:
|
||||||
|
log:
|
||||||
|
description: contains request object
|
||||||
|
items: {}
|
||||||
|
type: array
|
||||||
|
msg:
|
||||||
|
items: {}
|
||||||
|
type: array
|
||||||
|
type:
|
||||||
|
enum:
|
||||||
|
- success
|
||||||
|
- danger
|
||||||
|
- error
|
||||||
|
type: string
|
||||||
|
type: object
|
||||||
|
description: OK
|
||||||
|
headers: {}
|
||||||
|
tags:
|
||||||
|
- Mailboxes
|
||||||
|
description: You can delete one or more mailbox tags.
|
||||||
|
operationId: Delete mailbox tags
|
||||||
|
requestBody:
|
||||||
|
content:
|
||||||
|
application/json:
|
||||||
|
schema:
|
||||||
|
example:
|
||||||
|
- tag1
|
||||||
|
- tag2
|
||||||
|
properties:
|
||||||
|
items:
|
||||||
|
description: contains list of mailboxes you want to delete
|
||||||
|
type: object
|
||||||
|
type: object
|
||||||
|
summary: Delete mailbox tags
|
||||||
|
"/api/v1/delete/domain/tag/{domain}":
|
||||||
|
post:
|
||||||
|
parameters:
|
||||||
|
- description: name of domain
|
||||||
|
in: path
|
||||||
|
name: domain
|
||||||
|
example: domain.tld
|
||||||
|
required: true
|
||||||
|
schema:
|
||||||
|
type: string
|
||||||
|
responses:
|
||||||
|
"401":
|
||||||
|
$ref: "#/components/responses/Unauthorized"
|
||||||
|
"200":
|
||||||
|
content:
|
||||||
|
application/json:
|
||||||
|
examples:
|
||||||
|
response:
|
||||||
|
value:
|
||||||
|
- log:
|
||||||
|
- mailbox
|
||||||
|
- delete
|
||||||
|
- tags_domain
|
||||||
|
- tags:
|
||||||
|
- tag1
|
||||||
|
- tag2
|
||||||
|
domain: domain.tld
|
||||||
|
- null
|
||||||
|
msg:
|
||||||
|
- domain_modified
|
||||||
|
- domain.tld
|
||||||
|
type: success
|
||||||
|
schema:
|
||||||
|
properties:
|
||||||
|
log:
|
||||||
|
description: contains request object
|
||||||
|
items: {}
|
||||||
|
type: array
|
||||||
|
msg:
|
||||||
|
items: {}
|
||||||
|
type: array
|
||||||
|
type:
|
||||||
|
enum:
|
||||||
|
- success
|
||||||
|
- danger
|
||||||
|
- error
|
||||||
|
type: string
|
||||||
|
type: object
|
||||||
|
description: OK
|
||||||
|
headers: {}
|
||||||
|
tags:
|
||||||
|
- Domains
|
||||||
|
description: You can delete one or more domain tags.
|
||||||
|
operationId: Delete domain tags
|
||||||
|
requestBody:
|
||||||
|
content:
|
||||||
|
application/json:
|
||||||
|
schema:
|
||||||
|
example:
|
||||||
|
- tag1
|
||||||
|
- tag2
|
||||||
|
properties:
|
||||||
|
items:
|
||||||
|
description: contains list of domains you want to delete
|
||||||
|
type: object
|
||||||
|
type: object
|
||||||
|
summary: Delete domain tags
|
||||||
/api/v1/edit/alias:
|
/api/v1/edit/alias:
|
||||||
post:
|
post:
|
||||||
responses:
|
responses:
|
||||||
@@ -2865,6 +3017,7 @@ paths:
|
|||||||
quota: "10240"
|
quota: "10240"
|
||||||
relay_all_recipients: "0"
|
relay_all_recipients: "0"
|
||||||
relayhost: "2"
|
relayhost: "2"
|
||||||
|
tags: ["tag3", "tag4"]
|
||||||
items: domain.tld
|
items: domain.tld
|
||||||
properties:
|
properties:
|
||||||
attr:
|
attr:
|
||||||
@@ -3019,6 +3172,7 @@ paths:
|
|||||||
sogo_access: "1"
|
sogo_access: "1"
|
||||||
username:
|
username:
|
||||||
- info@domain.tld
|
- info@domain.tld
|
||||||
|
tags: ["tag3", "tag4"]
|
||||||
- null
|
- null
|
||||||
msg:
|
msg:
|
||||||
- mailbox_modified
|
- mailbox_modified
|
||||||
@@ -3066,6 +3220,7 @@ paths:
|
|||||||
- domain3.tld
|
- domain3.tld
|
||||||
- "*"
|
- "*"
|
||||||
sogo_access: "1"
|
sogo_access: "1"
|
||||||
|
tags: ["tag3", "tag4"]
|
||||||
items:
|
items:
|
||||||
- info@domain.tld
|
- info@domain.tld
|
||||||
properties:
|
properties:
|
||||||
@@ -3793,6 +3948,11 @@ paths:
|
|||||||
- all
|
- all
|
||||||
- mailcow.tld
|
- mailcow.tld
|
||||||
type: string
|
type: string
|
||||||
|
- description: comma seperated list of tags to filter by
|
||||||
|
example: "tag1,tag2"
|
||||||
|
in: query
|
||||||
|
name: tags
|
||||||
|
required: false
|
||||||
- description: e.g. api-key-string
|
- description: e.g. api-key-string
|
||||||
example: api-key-string
|
example: api-key-string
|
||||||
in: header
|
in: header
|
||||||
@@ -3831,6 +3991,7 @@ paths:
|
|||||||
relay_all_recipients: "0"
|
relay_all_recipients: "0"
|
||||||
relayhost: "0"
|
relayhost: "0"
|
||||||
rl: false
|
rl: false
|
||||||
|
tags: ["tag1", "tag2"]
|
||||||
- active: "1"
|
- active: "1"
|
||||||
aliases_in_domain: 0
|
aliases_in_domain: 0
|
||||||
aliases_left: 400
|
aliases_left: 400
|
||||||
@@ -3853,6 +4014,7 @@ paths:
|
|||||||
relay_all_recipients: "0"
|
relay_all_recipients: "0"
|
||||||
relayhost: "0"
|
relayhost: "0"
|
||||||
rl: false
|
rl: false
|
||||||
|
tags: ["tag3", "tag4"]
|
||||||
description: OK
|
description: OK
|
||||||
headers: {}
|
headers: {}
|
||||||
tags:
|
tags:
|
||||||
@@ -4345,6 +4507,11 @@ paths:
|
|||||||
- all
|
- all
|
||||||
- user@domain.tld
|
- user@domain.tld
|
||||||
type: string
|
type: string
|
||||||
|
- description: comma seperated list of tags to filter by
|
||||||
|
example: "tag1,tag2"
|
||||||
|
in: query
|
||||||
|
name: tags
|
||||||
|
required: false
|
||||||
- description: e.g. api-key-string
|
- description: e.g. api-key-string
|
||||||
example: api-key-string
|
example: api-key-string
|
||||||
in: header
|
in: header
|
||||||
@@ -4382,6 +4549,7 @@ paths:
|
|||||||
rl: false
|
rl: false
|
||||||
spam_aliases: 0
|
spam_aliases: 0
|
||||||
username: info@doman3.tld
|
username: info@doman3.tld
|
||||||
|
tags: ["tag1", "tag2"]
|
||||||
description: OK
|
description: OK
|
||||||
headers: {}
|
headers: {}
|
||||||
tags:
|
tags:
|
||||||
@@ -5072,6 +5240,27 @@ paths:
|
|||||||
of used storage.
|
of used storage.
|
||||||
operationId: Get vmail status
|
operationId: Get vmail status
|
||||||
summary: Get vmail status
|
summary: Get vmail status
|
||||||
|
/api/v1/get/status/version:
|
||||||
|
get:
|
||||||
|
responses:
|
||||||
|
"401":
|
||||||
|
$ref: "#/components/responses/Unauthorized"
|
||||||
|
"200":
|
||||||
|
content:
|
||||||
|
application/json:
|
||||||
|
examples:
|
||||||
|
response:
|
||||||
|
value:
|
||||||
|
version: "2022-04"
|
||||||
|
description: OK
|
||||||
|
headers: {}
|
||||||
|
tags:
|
||||||
|
- Status
|
||||||
|
description: >-
|
||||||
|
Using this endpoint you can get the current running release of this
|
||||||
|
instance.
|
||||||
|
operationId: Get version status
|
||||||
|
summary: Get version status
|
||||||
/api/v1/get/syncjobs/all/no_log:
|
/api/v1/get/syncjobs/all/no_log:
|
||||||
get:
|
get:
|
||||||
responses:
|
responses:
|
||||||
|
@@ -68,7 +68,7 @@ if (empty($_SERVER['PHP_AUTH_USER']) || empty($_SERVER['PHP_AUTH_PW'])) {
|
|||||||
exit(0);
|
exit(0);
|
||||||
}
|
}
|
||||||
|
|
||||||
$login_role = check_login($login_user, $login_pass, true);
|
$login_role = check_login($login_user, $login_pass, array('eas' => TRUE));
|
||||||
|
|
||||||
if ($login_role === "user") {
|
if ($login_role === "user") {
|
||||||
header("Content-Type: application/xml");
|
header("Content-Type: application/xml");
|
||||||
|
@@ -232,6 +232,9 @@ table.footable>tbody>tr.footable-empty>td {
|
|||||||
font-style:italic;
|
font-style:italic;
|
||||||
font-size: 1rem;
|
font-size: 1rem;
|
||||||
}
|
}
|
||||||
|
table>tbody>tr>td>span.footable-toggle {
|
||||||
|
opacity: 0.75;
|
||||||
|
}
|
||||||
.navbar-nav > li {
|
.navbar-nav > li {
|
||||||
font-size: 1rem !important;
|
font-size: 1rem !important;
|
||||||
}
|
}
|
||||||
@@ -256,3 +259,41 @@ code {
|
|||||||
.flag-icon {
|
.flag-icon {
|
||||||
margin-right: 5px;
|
margin-right: 5px;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
.tag-box {
|
||||||
|
display: flex;
|
||||||
|
flex-wrap: wrap;
|
||||||
|
height: auto;
|
||||||
|
}
|
||||||
|
.tag-badge {
|
||||||
|
transition: 200ms linear;
|
||||||
|
margin-top: 5px;
|
||||||
|
margin-bottom: 5px;
|
||||||
|
margin-left: 2px;
|
||||||
|
margin-right: 2px;
|
||||||
|
}
|
||||||
|
.tag-badge.btn-badge {
|
||||||
|
cursor: pointer;
|
||||||
|
}
|
||||||
|
.tag-badge .bi {
|
||||||
|
font-size: 12px;
|
||||||
|
}
|
||||||
|
.tag-badge.btn-badge:hover {
|
||||||
|
filter: brightness(0.9);
|
||||||
|
}
|
||||||
|
.tag-input {
|
||||||
|
margin-left: 10px;
|
||||||
|
border: 0;
|
||||||
|
flex: 1;
|
||||||
|
height: 24px;
|
||||||
|
min-width: 150px;
|
||||||
|
}
|
||||||
|
.tag-input:focus {
|
||||||
|
outline: none;
|
||||||
|
}
|
||||||
|
.tag-add {
|
||||||
|
padding: 0 5px 0 5px;
|
||||||
|
align-items: center;
|
||||||
|
display: inline-flex;
|
||||||
|
}
|
||||||
|
|
||||||
|
@@ -54,6 +54,7 @@ if (isset($_SESSION['mailcow_cc_role'])) {
|
|||||||
'rl' => $rl,
|
'rl' => $rl,
|
||||||
'rlyhosts' => $rlyhosts,
|
'rlyhosts' => $rlyhosts,
|
||||||
'dkim' => dkim('details', $domain),
|
'dkim' => dkim('details', $domain),
|
||||||
|
'domain_details' => $result,
|
||||||
];
|
];
|
||||||
}
|
}
|
||||||
elseif (isset($_GET['oauth2client']) &&
|
elseif (isset($_GET['oauth2client']) &&
|
||||||
@@ -99,6 +100,7 @@ if (isset($_SESSION['mailcow_cc_role'])) {
|
|||||||
'rlyhosts' => $rlyhosts,
|
'rlyhosts' => $rlyhosts,
|
||||||
'sender_acl_handles' => mailbox('get', 'sender_acl_handles', $mailbox),
|
'sender_acl_handles' => mailbox('get', 'sender_acl_handles', $mailbox),
|
||||||
'user_acls' => acl('get', 'user', $mailbox),
|
'user_acls' => acl('get', 'user', $mailbox),
|
||||||
|
'mailbox_details' => $result
|
||||||
];
|
];
|
||||||
}
|
}
|
||||||
elseif (isset($_GET['relayhost']) && is_numeric($_GET["relayhost"]) && !empty($_GET["relayhost"])) {
|
elseif (isset($_GET['relayhost']) && is_numeric($_GET["relayhost"]) && !empty($_GET["relayhost"])) {
|
||||||
|
@@ -197,7 +197,7 @@ function dkim($_action, $_data = null, $privkey = false) {
|
|||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
try {
|
try {
|
||||||
dkim('delete', (array)$domain);
|
dkim('delete', array('domains' => $domain));
|
||||||
$redis->hSet('DKIM_PUB_KEYS', $domain, $pem_public_key);
|
$redis->hSet('DKIM_PUB_KEYS', $domain, $pem_public_key);
|
||||||
$redis->hSet('DKIM_SELECTORS', $domain, $dkim_selector);
|
$redis->hSet('DKIM_SELECTORS', $domain, $dkim_selector);
|
||||||
$redis->hSet('DKIM_PRIV_KEYS', $dkim_selector . '.' . $domain, $private_key_normalized);
|
$redis->hSet('DKIM_PRIV_KEYS', $dkim_selector . '.' . $domain, $private_key_normalized);
|
||||||
|
@@ -336,9 +336,34 @@ function mailbox($_action, $_type, $_data = null, $_extra = null) {
|
|||||||
$mins_interval = $_data['mins_interval'];
|
$mins_interval = $_data['mins_interval'];
|
||||||
$enc1 = $_data['enc1'];
|
$enc1 = $_data['enc1'];
|
||||||
$custom_params = (empty(trim($_data['custom_params']))) ? '' : trim($_data['custom_params']);
|
$custom_params = (empty(trim($_data['custom_params']))) ? '' : trim($_data['custom_params']);
|
||||||
// Workaround, fixme
|
|
||||||
if (strpos($custom_params, 'pipemess')) {
|
// validate custom params
|
||||||
$custom_params = '';
|
foreach (explode(' -', $custom_params) as $param){
|
||||||
|
if (str_contains($param, ' ')) {
|
||||||
|
// bad char
|
||||||
|
$_SESSION['return'][] = array(
|
||||||
|
'type' => 'danger',
|
||||||
|
'log' => array(__FUNCTION__, $_action, $_type, $_data_log, $_attr),
|
||||||
|
'msg' => 'bad character SPACE'
|
||||||
|
);
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
|
||||||
|
// extract option
|
||||||
|
if (str_contains($param, '=')) $param = explode('=', $param)[0];
|
||||||
|
// remove first char if first char is -
|
||||||
|
if ($param[0] == '-') $param = ltrim($param, $param[0]);
|
||||||
|
|
||||||
|
// check if param is whitelisted
|
||||||
|
if (!in_array(strtolower($param), $GLOBALS["IMAPSYNC_OPTIONS"]["whitelist"])){
|
||||||
|
// bad option
|
||||||
|
$_SESSION['return'][] = array(
|
||||||
|
'type' => 'danger',
|
||||||
|
'log' => array(__FUNCTION__, $_action, $_type, $_data_log, $_attr),
|
||||||
|
'msg' => 'bad option '. $param
|
||||||
|
);
|
||||||
|
return false;
|
||||||
|
}
|
||||||
}
|
}
|
||||||
if (empty($subfolder2)) {
|
if (empty($subfolder2)) {
|
||||||
$subfolder2 = "";
|
$subfolder2 = "";
|
||||||
@@ -443,16 +468,15 @@ function mailbox($_action, $_type, $_data = null, $_extra = null) {
|
|||||||
if ($_SESSION['mailcow_cc_role'] != "admin") {
|
if ($_SESSION['mailcow_cc_role'] != "admin") {
|
||||||
$_SESSION['return'][] = array(
|
$_SESSION['return'][] = array(
|
||||||
'type' => 'danger',
|
'type' => 'danger',
|
||||||
'log' => array(__FUNCTION__, $_action, $_type, $_data_log, $_attr),
|
'log' => array(__FUNCTION__, $_action, $_type, $_data_log, $_extra),
|
||||||
'msg' => 'access_denied'
|
'msg' => 'access_denied'
|
||||||
);
|
);
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
$domain = idn_to_ascii(strtolower(trim($_data['domain'])), 0, INTL_IDNA_VARIANT_UTS46);
|
$domain = idn_to_ascii(strtolower(trim($_data['domain'])), 0, INTL_IDNA_VARIANT_UTS46);
|
||||||
$description = $_data['description'];
|
$description = $_data['description'];
|
||||||
if (empty($description)) {
|
if (empty($description)) $description = $domain;
|
||||||
$description = $domain;
|
$tags = (array)$_data['tags'];
|
||||||
}
|
|
||||||
$aliases = (int)$_data['aliases'];
|
$aliases = (int)$_data['aliases'];
|
||||||
$mailboxes = (int)$_data['mailboxes'];
|
$mailboxes = (int)$_data['mailboxes'];
|
||||||
$defquota = (int)$_data['defquota'];
|
$defquota = (int)$_data['defquota'];
|
||||||
@@ -545,10 +569,12 @@ function mailbox($_action, $_type, $_data = null, $_extra = null) {
|
|||||||
);
|
);
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
|
|
||||||
$stmt = $pdo->prepare("DELETE FROM `sender_acl` WHERE `external` = 1 AND `send_as` LIKE :domain");
|
$stmt = $pdo->prepare("DELETE FROM `sender_acl` WHERE `external` = 1 AND `send_as` LIKE :domain");
|
||||||
$stmt->execute(array(
|
$stmt->execute(array(
|
||||||
':domain' => '%@' . $domain
|
':domain' => '%@' . $domain
|
||||||
));
|
));
|
||||||
|
// save domain
|
||||||
$stmt = $pdo->prepare("INSERT INTO `domain` (`domain`, `description`, `aliases`, `mailboxes`, `defquota`, `maxquota`, `quota`, `backupmx`, `gal`, `active`, `relay_unknown_only`, `relay_all_recipients`)
|
$stmt = $pdo->prepare("INSERT INTO `domain` (`domain`, `description`, `aliases`, `mailboxes`, `defquota`, `maxquota`, `quota`, `backupmx`, `gal`, `active`, `relay_unknown_only`, `relay_all_recipients`)
|
||||||
VALUES (:domain, :description, :aliases, :mailboxes, :defquota, :maxquota, :quota, :backupmx, :gal, :active, :relay_unknown_only, :relay_all_recipients)");
|
VALUES (:domain, :description, :aliases, :mailboxes, :defquota, :maxquota, :quota, :backupmx, :gal, :active, :relay_unknown_only, :relay_all_recipients)");
|
||||||
$stmt->execute(array(
|
$stmt->execute(array(
|
||||||
@@ -565,6 +591,24 @@ function mailbox($_action, $_type, $_data = null, $_extra = null) {
|
|||||||
':relay_unknown_only' => $relay_unknown_only,
|
':relay_unknown_only' => $relay_unknown_only,
|
||||||
':relay_all_recipients' => $relay_all_recipients
|
':relay_all_recipients' => $relay_all_recipients
|
||||||
));
|
));
|
||||||
|
// save tags
|
||||||
|
foreach($tags as $index => $tag){
|
||||||
|
if (empty($tag)) continue;
|
||||||
|
if ($index > $GLOBALS['TAGGING_LIMIT']) {
|
||||||
|
$_SESSION['return'][] = array(
|
||||||
|
'type' => 'warning',
|
||||||
|
'log' => array(__FUNCTION__, $_action, $_type, $_data_log, $_attr),
|
||||||
|
'msg' => array('tag_limit_exceeded', 'limit '.$GLOBALS['TAGGING_LIMIT'])
|
||||||
|
);
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
$stmt = $pdo->prepare("INSERT INTO `tags_domain` (`domain`, `tag_name`) VALUES (:domain, :tag_name)");
|
||||||
|
$stmt->execute(array(
|
||||||
|
':domain' => $domain,
|
||||||
|
':tag_name' => $tag,
|
||||||
|
));
|
||||||
|
}
|
||||||
|
|
||||||
try {
|
try {
|
||||||
$redis->hSet('DOMAIN_MAP', $domain, 1);
|
$redis->hSet('DOMAIN_MAP', $domain, 1);
|
||||||
}
|
}
|
||||||
@@ -580,8 +624,17 @@ function mailbox($_action, $_type, $_data = null, $_extra = null) {
|
|||||||
ratelimit('edit', 'domain', array('rl_value' => $_data['rl_value'], 'rl_frame' => $_data['rl_frame'], 'object' => $domain));
|
ratelimit('edit', 'domain', array('rl_value' => $_data['rl_value'], 'rl_frame' => $_data['rl_frame'], 'object' => $domain));
|
||||||
}
|
}
|
||||||
if (!empty($_data['key_size']) && !empty($_data['dkim_selector'])) {
|
if (!empty($_data['key_size']) && !empty($_data['dkim_selector'])) {
|
||||||
|
if (!empty($redis->hGet('DKIM_SELECTORS', $domain))) {
|
||||||
|
$_SESSION['return'][] = array(
|
||||||
|
'type' => 'success',
|
||||||
|
'log' => array(__FUNCTION__, $_action, $_type, $_data_log, $_attr),
|
||||||
|
'msg' => 'domain_add_dkim_available'
|
||||||
|
);
|
||||||
|
}
|
||||||
|
else {
|
||||||
dkim('add', array('key_size' => $_data['key_size'], 'dkim_selector' => $_data['dkim_selector'], 'domains' => $domain));
|
dkim('add', array('key_size' => $_data['key_size'], 'dkim_selector' => $_data['dkim_selector'], 'domains' => $domain));
|
||||||
}
|
}
|
||||||
|
}
|
||||||
if (!empty($restart_sogo)) {
|
if (!empty($restart_sogo)) {
|
||||||
$restart_response = json_decode(docker('post', 'sogo-mailcow', 'restart'), true);
|
$restart_response = json_decode(docker('post', 'sogo-mailcow', 'restart'), true);
|
||||||
if ($restart_response['type'] == "success") {
|
if ($restart_response['type'] == "success") {
|
||||||
@@ -910,8 +963,17 @@ function mailbox($_action, $_type, $_data = null, $_extra = null) {
|
|||||||
ratelimit('edit', 'domain', array('rl_value' => $_data['rl_value'], 'rl_frame' => $_data['rl_frame'], 'object' => $alias_domain));
|
ratelimit('edit', 'domain', array('rl_value' => $_data['rl_value'], 'rl_frame' => $_data['rl_frame'], 'object' => $alias_domain));
|
||||||
}
|
}
|
||||||
if (!empty($_data['key_size']) && !empty($_data['dkim_selector'])) {
|
if (!empty($_data['key_size']) && !empty($_data['dkim_selector'])) {
|
||||||
|
if (!empty($redis->hGet('DKIM_SELECTORS', $alias_domain))) {
|
||||||
|
$_SESSION['return'][] = array(
|
||||||
|
'type' => 'success',
|
||||||
|
'log' => array(__FUNCTION__, $_action, $_type, $_data_log, $_attr),
|
||||||
|
'msg' => 'domain_add_dkim_available'
|
||||||
|
);
|
||||||
|
}
|
||||||
|
else {
|
||||||
dkim('add', array('key_size' => $_data['key_size'], 'dkim_selector' => $_data['dkim_selector'], 'domains' => $alias_domain));
|
dkim('add', array('key_size' => $_data['key_size'], 'dkim_selector' => $_data['dkim_selector'], 'domains' => $alias_domain));
|
||||||
}
|
}
|
||||||
|
}
|
||||||
$_SESSION['return'][] = array(
|
$_SESSION['return'][] = array(
|
||||||
'type' => 'success',
|
'type' => 'success',
|
||||||
'log' => array(__FUNCTION__, $_action, $_type, $_data_log, $_attr),
|
'log' => array(__FUNCTION__, $_action, $_type, $_data_log, $_attr),
|
||||||
@@ -942,6 +1004,7 @@ function mailbox($_action, $_type, $_data = null, $_extra = null) {
|
|||||||
$password = $_data['password'];
|
$password = $_data['password'];
|
||||||
$password2 = $_data['password2'];
|
$password2 = $_data['password2'];
|
||||||
$name = ltrim(rtrim($_data['name'], '>'), '<');
|
$name = ltrim(rtrim($_data['name'], '>'), '<');
|
||||||
|
$tags = $_data['tags'];
|
||||||
$quota_m = intval($_data['quota']);
|
$quota_m = intval($_data['quota']);
|
||||||
if ((!isset($_SESSION['acl']['unlimited_quota']) || $_SESSION['acl']['unlimited_quota'] != "1") && $quota_m === 0) {
|
if ((!isset($_SESSION['acl']['unlimited_quota']) || $_SESSION['acl']['unlimited_quota'] != "1") && $quota_m === 0) {
|
||||||
$_SESSION['return'][] = array(
|
$_SESSION['return'][] = array(
|
||||||
@@ -1103,6 +1166,23 @@ function mailbox($_action, $_type, $_data = null, $_extra = null) {
|
|||||||
$stmt->execute(array(
|
$stmt->execute(array(
|
||||||
':username' => $username
|
':username' => $username
|
||||||
));
|
));
|
||||||
|
// save tags
|
||||||
|
foreach($tags as $index => $tag){
|
||||||
|
if (empty($tag)) continue;
|
||||||
|
if ($index > $GLOBALS['TAGGING_LIMIT']) {
|
||||||
|
$_SESSION['return'][] = array(
|
||||||
|
'type' => 'warning',
|
||||||
|
'log' => array(__FUNCTION__, $_action, $_type, $_data_log, $_attr),
|
||||||
|
'msg' => array('tag_limit_exceeded', 'limit '.$GLOBALS['TAGGING_LIMIT'])
|
||||||
|
);
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
$stmt = $pdo->prepare("INSERT INTO `tags_mailbox` (`username`, `tag_name`) VALUES (:username, :tag_name)");
|
||||||
|
$stmt->execute(array(
|
||||||
|
':username' => $username,
|
||||||
|
':tag_name' => $tag,
|
||||||
|
));
|
||||||
|
}
|
||||||
$stmt = $pdo->prepare("INSERT INTO `quota2` (`username`, `bytes`, `messages`)
|
$stmt = $pdo->prepare("INSERT INTO `quota2` (`username`, `bytes`, `messages`)
|
||||||
VALUES (:username, '0', '0') ON DUPLICATE KEY UPDATE `bytes` = '0', `messages` = '0';");
|
VALUES (:username, '0', '0') ON DUPLICATE KEY UPDATE `bytes` = '0', `messages` = '0';");
|
||||||
$stmt->execute(array(':username' => $username));
|
$stmt->execute(array(':username' => $username));
|
||||||
@@ -1709,8 +1789,34 @@ function mailbox($_action, $_type, $_data = null, $_extra = null) {
|
|||||||
);
|
);
|
||||||
continue;
|
continue;
|
||||||
}
|
}
|
||||||
if (strpos($custom_params, 'pipemess')) {
|
|
||||||
$custom_params = '';
|
// validate custom params
|
||||||
|
foreach (explode(' -', $custom_params) as $param){
|
||||||
|
if (str_contains($param, ' ')) {
|
||||||
|
// bad char
|
||||||
|
$_SESSION['return'][] = array(
|
||||||
|
'type' => 'danger',
|
||||||
|
'log' => array(__FUNCTION__, $_action, $_type, $_data_log, $_attr),
|
||||||
|
'msg' => 'bad character SPACE'
|
||||||
|
);
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
|
||||||
|
// extract option
|
||||||
|
if (str_contains($param, '=')) $param = explode('=', $param)[0];
|
||||||
|
// remove first char if first char is -
|
||||||
|
if ($param[0] == '-') $param = ltrim($param, $param[0]);
|
||||||
|
|
||||||
|
// check if param is whitelisted
|
||||||
|
if (!in_array(strtolower($param), $GLOBALS["IMAPSYNC_OPTIONS"]["whitelist"])){
|
||||||
|
// bad option
|
||||||
|
$_SESSION['return'][] = array(
|
||||||
|
'type' => 'danger',
|
||||||
|
'log' => array(__FUNCTION__, $_action, $_type, $_data_log, $_attr),
|
||||||
|
'msg' => 'bad option '. $param
|
||||||
|
);
|
||||||
|
return false;
|
||||||
|
}
|
||||||
}
|
}
|
||||||
if (empty($subfolder2)) {
|
if (empty($subfolder2)) {
|
||||||
$subfolder2 = "";
|
$subfolder2 = "";
|
||||||
@@ -2146,6 +2252,7 @@ function mailbox($_action, $_type, $_data = null, $_extra = null) {
|
|||||||
$gal = (isset($_data['gal'])) ? intval($_data['gal']) : $is_now['gal'];
|
$gal = (isset($_data['gal'])) ? intval($_data['gal']) : $is_now['gal'];
|
||||||
$description = (!empty($_data['description']) && isset($_SESSION['acl']['domain_desc']) && $_SESSION['acl']['domain_desc'] == "1") ? $_data['description'] : $is_now['description'];
|
$description = (!empty($_data['description']) && isset($_SESSION['acl']['domain_desc']) && $_SESSION['acl']['domain_desc'] == "1") ? $_data['description'] : $is_now['description'];
|
||||||
(int)$relayhost = (isset($_data['relayhost']) && isset($_SESSION['acl']['domain_relayhost']) && $_SESSION['acl']['domain_relayhost'] == "1") ? intval($_data['relayhost']) : intval($is_now['relayhost']);
|
(int)$relayhost = (isset($_data['relayhost']) && isset($_SESSION['acl']['domain_relayhost']) && $_SESSION['acl']['domain_relayhost'] == "1") ? intval($_data['relayhost']) : intval($is_now['relayhost']);
|
||||||
|
$tags = (is_array($_data['tags']) ? $_data['tags'] : array());
|
||||||
}
|
}
|
||||||
else {
|
else {
|
||||||
$_SESSION['return'][] = array(
|
$_SESSION['return'][] = array(
|
||||||
@@ -2155,6 +2262,7 @@ function mailbox($_action, $_type, $_data = null, $_extra = null) {
|
|||||||
);
|
);
|
||||||
continue;
|
continue;
|
||||||
}
|
}
|
||||||
|
|
||||||
$stmt = $pdo->prepare("UPDATE `domain` SET
|
$stmt = $pdo->prepare("UPDATE `domain` SET
|
||||||
`description` = :description,
|
`description` = :description,
|
||||||
`gal` = :gal
|
`gal` = :gal
|
||||||
@@ -2164,6 +2272,24 @@ function mailbox($_action, $_type, $_data = null, $_extra = null) {
|
|||||||
':gal' => $gal,
|
':gal' => $gal,
|
||||||
':domain' => $domain
|
':domain' => $domain
|
||||||
));
|
));
|
||||||
|
// save tags
|
||||||
|
foreach($tags as $index => $tag){
|
||||||
|
if (empty($tag)) continue;
|
||||||
|
if ($index > $GLOBALS['TAGGING_LIMIT']) {
|
||||||
|
$_SESSION['return'][] = array(
|
||||||
|
'type' => 'warning',
|
||||||
|
'log' => array(__FUNCTION__, $_action, $_type, $_data_log, $_attr),
|
||||||
|
'msg' => array('tag_limit_exceeded', 'limit '.$GLOBALS['TAGGING_LIMIT'])
|
||||||
|
);
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
$stmt = $pdo->prepare("INSERT INTO `tags_domain` (`domain`, `tag_name`) VALUES (:domain, :tag_name)");
|
||||||
|
$stmt->execute(array(
|
||||||
|
':domain' => $domain,
|
||||||
|
':tag_name' => $tag,
|
||||||
|
));
|
||||||
|
}
|
||||||
|
|
||||||
$_SESSION['return'][] = array(
|
$_SESSION['return'][] = array(
|
||||||
'type' => 'success',
|
'type' => 'success',
|
||||||
'log' => array(__FUNCTION__, $_action, $_type, $_data_log, $_attr),
|
'log' => array(__FUNCTION__, $_action, $_type, $_data_log, $_attr),
|
||||||
@@ -2185,6 +2311,7 @@ function mailbox($_action, $_type, $_data = null, $_extra = null) {
|
|||||||
$maxquota = (!empty($_data['maxquota'])) ? $_data['maxquota'] : ($is_now['max_quota_for_mbox'] / 1048576);
|
$maxquota = (!empty($_data['maxquota'])) ? $_data['maxquota'] : ($is_now['max_quota_for_mbox'] / 1048576);
|
||||||
$quota = (!empty($_data['quota'])) ? $_data['quota'] : ($is_now['max_quota_for_domain'] / 1048576);
|
$quota = (!empty($_data['quota'])) ? $_data['quota'] : ($is_now['max_quota_for_domain'] / 1048576);
|
||||||
$description = (!empty($_data['description'])) ? $_data['description'] : $is_now['description'];
|
$description = (!empty($_data['description'])) ? $_data['description'] : $is_now['description'];
|
||||||
|
$tags = (is_array($_data['tags']) ? $_data['tags'] : array());
|
||||||
if ($relay_all_recipients == '1') {
|
if ($relay_all_recipients == '1') {
|
||||||
$backupmx = '1';
|
$backupmx = '1';
|
||||||
}
|
}
|
||||||
@@ -2283,6 +2410,7 @@ function mailbox($_action, $_type, $_data = null, $_extra = null) {
|
|||||||
);
|
);
|
||||||
continue;
|
continue;
|
||||||
}
|
}
|
||||||
|
|
||||||
$stmt = $pdo->prepare("UPDATE `domain` SET
|
$stmt = $pdo->prepare("UPDATE `domain` SET
|
||||||
`relay_all_recipients` = :relay_all_recipients,
|
`relay_all_recipients` = :relay_all_recipients,
|
||||||
`relay_unknown_only` = :relay_unknown_only,
|
`relay_unknown_only` = :relay_unknown_only,
|
||||||
@@ -2312,6 +2440,24 @@ function mailbox($_action, $_type, $_data = null, $_extra = null) {
|
|||||||
':description' => $description,
|
':description' => $description,
|
||||||
':domain' => $domain
|
':domain' => $domain
|
||||||
));
|
));
|
||||||
|
// save tags
|
||||||
|
foreach($tags as $index => $tag){
|
||||||
|
if (empty($tag)) continue;
|
||||||
|
if ($index > $GLOBALS['TAGGING_LIMIT']) {
|
||||||
|
$_SESSION['return'][] = array(
|
||||||
|
'type' => 'warning',
|
||||||
|
'log' => array(__FUNCTION__, $_action, $_type, $_data_log, $_attr),
|
||||||
|
'msg' => array('tag_limit_exceeded', 'limit '.$GLOBALS['TAGGING_LIMIT'])
|
||||||
|
);
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
$stmt = $pdo->prepare("INSERT INTO `tags_domain` (`domain`, `tag_name`) VALUES (:domain, :tag_name)");
|
||||||
|
$stmt->execute(array(
|
||||||
|
':domain' => $domain,
|
||||||
|
':tag_name' => $tag,
|
||||||
|
));
|
||||||
|
}
|
||||||
|
|
||||||
$_SESSION['return'][] = array(
|
$_SESSION['return'][] = array(
|
||||||
'type' => 'success',
|
'type' => 'success',
|
||||||
'log' => array(__FUNCTION__, $_action, $_type, $_data_log, $_attr),
|
'log' => array(__FUNCTION__, $_action, $_type, $_data_log, $_attr),
|
||||||
@@ -2360,6 +2506,7 @@ function mailbox($_action, $_type, $_data = null, $_extra = null) {
|
|||||||
$quota_b = $quota_m * 1048576;
|
$quota_b = $quota_m * 1048576;
|
||||||
$password = (!empty($_data['password'])) ? $_data['password'] : null;
|
$password = (!empty($_data['password'])) ? $_data['password'] : null;
|
||||||
$password2 = (!empty($_data['password2'])) ? $_data['password2'] : null;
|
$password2 = (!empty($_data['password2'])) ? $_data['password2'] : null;
|
||||||
|
$tags = (is_array($_data['tags']) ? $_data['tags'] : array());
|
||||||
}
|
}
|
||||||
else {
|
else {
|
||||||
$_SESSION['return'][] = array(
|
$_SESSION['return'][] = array(
|
||||||
@@ -2636,6 +2783,24 @@ function mailbox($_action, $_type, $_data = null, $_extra = null) {
|
|||||||
':relayhost' => $relayhost,
|
':relayhost' => $relayhost,
|
||||||
':username' => $username
|
':username' => $username
|
||||||
));
|
));
|
||||||
|
// save tags
|
||||||
|
foreach($tags as $index => $tag){
|
||||||
|
if (empty($tag)) continue;
|
||||||
|
if ($index > $GLOBALS['TAGGING_LIMIT']) {
|
||||||
|
$_SESSION['return'][] = array(
|
||||||
|
'type' => 'warning',
|
||||||
|
'log' => array(__FUNCTION__, $_action, $_type, $_data_log, $_attr),
|
||||||
|
'msg' => array('tag_limit_exceeded', 'limit '.$GLOBALS['TAGGING_LIMIT'])
|
||||||
|
);
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
$stmt = $pdo->prepare("INSERT INTO `tags_mailbox` (`username`, `tag_name`) VALUES (:username, :tag_name)");
|
||||||
|
$stmt->execute(array(
|
||||||
|
':username' => $username,
|
||||||
|
':tag_name' => $tag,
|
||||||
|
));
|
||||||
|
}
|
||||||
|
|
||||||
$_SESSION['return'][] = array(
|
$_SESSION['return'][] = array(
|
||||||
'type' => 'success',
|
'type' => 'success',
|
||||||
'log' => array(__FUNCTION__, $_action, $_type, $_data_log, $_attr),
|
'log' => array(__FUNCTION__, $_action, $_type, $_data_log, $_attr),
|
||||||
@@ -2851,10 +3016,34 @@ function mailbox($_action, $_type, $_data = null, $_extra = null) {
|
|||||||
break;
|
break;
|
||||||
case 'mailboxes':
|
case 'mailboxes':
|
||||||
$mailboxes = array();
|
$mailboxes = array();
|
||||||
if (isset($_data) && !hasDomainAccess($_SESSION['mailcow_cc_username'], $_SESSION['mailcow_cc_role'], $_data)) {
|
if (isset($_extra) && is_array($_extra) && isset($_data)) {
|
||||||
return false;
|
// get by domain and tags
|
||||||
|
$tags = is_array($_extra) ? $_extra : array();
|
||||||
|
|
||||||
|
$sql = "";
|
||||||
|
foreach ($tags as $key => $tag) {
|
||||||
|
$sql = $sql."SELECT DISTINCT `username` FROM `tags_mailbox` WHERE `username` LIKE ? AND `tag_name` LIKE ?"; // distinct, avoid duplicates
|
||||||
|
if ($key === array_key_last($tags)) break;
|
||||||
|
$sql = $sql.' UNION DISTINCT '; // combine querys with union - distinct, avoid duplicates
|
||||||
|
}
|
||||||
|
|
||||||
|
// prepend domain to array
|
||||||
|
$params = array();
|
||||||
|
foreach ($tags as $key => $val){
|
||||||
|
array_push($params, '%'.$_data.'%');
|
||||||
|
array_push($params, '%'.$val.'%');
|
||||||
|
}
|
||||||
|
$stmt = $pdo->prepare($sql);
|
||||||
|
$stmt->execute($params);
|
||||||
|
|
||||||
|
$rows = $stmt->fetchAll(PDO::FETCH_ASSOC);
|
||||||
|
while($row = array_shift($rows)) {
|
||||||
|
if (hasDomainAccess($_SESSION['mailcow_cc_username'], $_SESSION['mailcow_cc_role'], explode('@', $row['username'])[1]))
|
||||||
|
$mailboxes[] = $row['username'];
|
||||||
|
}
|
||||||
}
|
}
|
||||||
elseif (isset($_data) && hasDomainAccess($_SESSION['mailcow_cc_username'], $_SESSION['mailcow_cc_role'], $_data)) {
|
elseif (isset($_data) && hasDomainAccess($_SESSION['mailcow_cc_username'], $_SESSION['mailcow_cc_role'], $_data)) {
|
||||||
|
// get by domain
|
||||||
$stmt = $pdo->prepare("SELECT `username` FROM `mailbox` WHERE (`kind` = '' OR `kind` = NULL) AND `domain` = :domain");
|
$stmt = $pdo->prepare("SELECT `username` FROM `mailbox` WHERE (`kind` = '' OR `kind` = NULL) AND `domain` = :domain");
|
||||||
$stmt->execute(array(
|
$stmt->execute(array(
|
||||||
':domain' => $_data,
|
':domain' => $_data,
|
||||||
@@ -3348,6 +3537,30 @@ function mailbox($_action, $_type, $_data = null, $_extra = null) {
|
|||||||
if ($_SESSION['mailcow_cc_role'] != "admin" && $_SESSION['mailcow_cc_role'] != "domainadmin") {
|
if ($_SESSION['mailcow_cc_role'] != "admin" && $_SESSION['mailcow_cc_role'] != "domainadmin") {
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
if (isset($_extra) && is_array($_extra)){
|
||||||
|
// get by tags
|
||||||
|
$tags = is_array($_extra) ? $_extra : array();
|
||||||
|
// add % as prefix and suffix to every element for relative searching
|
||||||
|
$tags = array_map(function($x){ return '%'.$x.'%'; }, $tags);
|
||||||
|
$sql = "";
|
||||||
|
foreach ($tags as $key => $tag) {
|
||||||
|
$sql = $sql."SELECT DISTINCT `domain` FROM `tags_domain` WHERE `tag_name` LIKE ?"; // distinct, avoid duplicates
|
||||||
|
if ($key === array_key_last($tags)) break;
|
||||||
|
$sql = $sql.' UNION DISTINCT '; // combine querys with union - distinct, avoid duplicates
|
||||||
|
}
|
||||||
|
$stmt = $pdo->prepare($sql);
|
||||||
|
$stmt->execute($tags);
|
||||||
|
|
||||||
|
$rows = $stmt->fetchAll(PDO::FETCH_ASSOC);
|
||||||
|
while($row = array_shift($rows)) {
|
||||||
|
if ($_SESSION['mailcow_cc_role'] == "admin")
|
||||||
|
$domains[] = $row['domain'];
|
||||||
|
elseif (hasDomainAccess($_SESSION['mailcow_cc_username'], $_SESSION['mailcow_cc_role'], $row['domain']))
|
||||||
|
$domains[] = $row['domain'];
|
||||||
|
}
|
||||||
|
} else {
|
||||||
|
// get all
|
||||||
$stmt = $pdo->prepare("SELECT `domain` FROM `domain`
|
$stmt = $pdo->prepare("SELECT `domain` FROM `domain`
|
||||||
WHERE (`domain` IN (
|
WHERE (`domain` IN (
|
||||||
SELECT `domain` from `domain_admins`
|
SELECT `domain` from `domain_admins`
|
||||||
@@ -3362,6 +3575,8 @@ function mailbox($_action, $_type, $_data = null, $_extra = null) {
|
|||||||
while($row = array_shift($rows)) {
|
while($row = array_shift($rows)) {
|
||||||
$domains[] = $row['domain'];
|
$domains[] = $row['domain'];
|
||||||
}
|
}
|
||||||
|
}
|
||||||
|
|
||||||
return $domains;
|
return $domains;
|
||||||
break;
|
break;
|
||||||
case 'domain_details':
|
case 'domain_details':
|
||||||
@@ -3478,6 +3693,16 @@ function mailbox($_action, $_type, $_data = null, $_extra = null) {
|
|||||||
$domain_admins = $stmt->fetch(PDO::FETCH_ASSOC);
|
$domain_admins = $stmt->fetch(PDO::FETCH_ASSOC);
|
||||||
(isset($domain_admins['domain_admins'])) ? $domaindata['domain_admins'] = $domain_admins['domain_admins'] : $domaindata['domain_admins'] = "-";
|
(isset($domain_admins['domain_admins'])) ? $domaindata['domain_admins'] = $domain_admins['domain_admins'] : $domaindata['domain_admins'] = "-";
|
||||||
}
|
}
|
||||||
|
$stmt = $pdo->prepare("SELECT `tag_name`
|
||||||
|
FROM `tags_domain` WHERE `domain`= :domain");
|
||||||
|
$stmt->execute(array(
|
||||||
|
':domain' => $_data
|
||||||
|
));
|
||||||
|
$tags = $stmt->fetchAll(PDO::FETCH_ASSOC);
|
||||||
|
while ($tag = array_shift($tags)) {
|
||||||
|
$domaindata['tags'][] = $tag['tag_name'];
|
||||||
|
}
|
||||||
|
|
||||||
return $domaindata;
|
return $domaindata;
|
||||||
break;
|
break;
|
||||||
case 'mailbox_details':
|
case 'mailbox_details':
|
||||||
@@ -3613,6 +3838,15 @@ function mailbox($_action, $_type, $_data = null, $_extra = null) {
|
|||||||
}
|
}
|
||||||
$mailboxdata['is_relayed'] = $row['backupmx'];
|
$mailboxdata['is_relayed'] = $row['backupmx'];
|
||||||
}
|
}
|
||||||
|
$stmt = $pdo->prepare("SELECT `tag_name`
|
||||||
|
FROM `tags_mailbox` WHERE `username`= :username");
|
||||||
|
$stmt->execute(array(
|
||||||
|
':username' => $_data
|
||||||
|
));
|
||||||
|
$tags = $stmt->fetchAll(PDO::FETCH_ASSOC);
|
||||||
|
while ($tag = array_shift($tags)) {
|
||||||
|
$mailboxdata['tags'][] = $tag['tag_name'];
|
||||||
|
}
|
||||||
|
|
||||||
return $mailboxdata;
|
return $mailboxdata;
|
||||||
break;
|
break;
|
||||||
@@ -4342,6 +4576,108 @@ function mailbox($_action, $_type, $_data = null, $_extra = null) {
|
|||||||
);
|
);
|
||||||
}
|
}
|
||||||
break;
|
break;
|
||||||
|
case 'tags_domain':
|
||||||
|
if (!is_array($_data['domain'])) {
|
||||||
|
$domains = array();
|
||||||
|
$domains[] = $_data['domain'];
|
||||||
|
}
|
||||||
|
else {
|
||||||
|
$domains = $_data['domain'];
|
||||||
|
}
|
||||||
|
$tags = $_data['tags'];
|
||||||
|
if (!is_array($tags)) $tags = array();
|
||||||
|
|
||||||
|
|
||||||
|
if ($_SESSION['mailcow_cc_role'] != "admin") {
|
||||||
|
$_SESSION['return'][] = array(
|
||||||
|
'type' => 'danger',
|
||||||
|
'log' => array(__FUNCTION__, $_action, $_type, $_data_log, $_attr),
|
||||||
|
'msg' => 'access_denied'
|
||||||
|
);
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
|
||||||
|
$wasModified = false;
|
||||||
|
foreach ($domains as $domain) {
|
||||||
|
if (!is_valid_domain_name($domain)) {
|
||||||
|
$_SESSION['return'][] = array(
|
||||||
|
'type' => 'danger',
|
||||||
|
'log' => array(__FUNCTION__, $_action, $_type, $_data_log, $_attr),
|
||||||
|
'msg' => 'domain_invalid'
|
||||||
|
);
|
||||||
|
continue;
|
||||||
|
}
|
||||||
|
|
||||||
|
foreach($tags as $tag){
|
||||||
|
// delete tag
|
||||||
|
$wasModified = true;
|
||||||
|
$stmt = $pdo->prepare("DELETE FROM `tags_domain` WHERE `domain` = :domain AND `tag_name` = :tag_name");
|
||||||
|
$stmt->execute(array(
|
||||||
|
':domain' => $domain,
|
||||||
|
':tag_name' => $tag,
|
||||||
|
));
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
if (!$wasModified) return false;
|
||||||
|
$_SESSION['return'][] = array(
|
||||||
|
'type' => 'success',
|
||||||
|
'log' => array(__FUNCTION__, $_action, $_type, $_data_log, $_attr),
|
||||||
|
'msg' => array('domain_modified', $domain)
|
||||||
|
);
|
||||||
|
break;
|
||||||
|
case 'tags_mailbox':
|
||||||
|
if (!is_array($_data['username'])) {
|
||||||
|
$usernames = array();
|
||||||
|
$usernames[] = $_data['username'];
|
||||||
|
}
|
||||||
|
else {
|
||||||
|
$usernames = $_data['username'];
|
||||||
|
}
|
||||||
|
$tags = $_data['tags'];
|
||||||
|
if (!is_array($tags)) $tags = array();
|
||||||
|
|
||||||
|
$wasModified = false;
|
||||||
|
foreach ($usernames as $username) {
|
||||||
|
if (!filter_var($username, FILTER_VALIDATE_EMAIL)) {
|
||||||
|
$_SESSION['return'][] = array(
|
||||||
|
'type' => 'danger',
|
||||||
|
'log' => array(__FUNCTION__, $_action, $_type, $_data_log, $_attr),
|
||||||
|
'msg' => 'email invalid'
|
||||||
|
);
|
||||||
|
continue;
|
||||||
|
}
|
||||||
|
|
||||||
|
$is_now = mailbox('get', 'mailbox_details', $username);
|
||||||
|
$domain = $is_now['domain'];
|
||||||
|
if (!hasDomainAccess($_SESSION['mailcow_cc_username'], $_SESSION['mailcow_cc_role'], $domain)) {
|
||||||
|
$_SESSION['return'][] = array(
|
||||||
|
'type' => 'danger',
|
||||||
|
'log' => array(__FUNCTION__, $_action, $_type, $_data_log, $_attr),
|
||||||
|
'msg' => 'access_denied'
|
||||||
|
);
|
||||||
|
continue;
|
||||||
|
}
|
||||||
|
|
||||||
|
// delete tags
|
||||||
|
foreach($tags as $tag){
|
||||||
|
$wasModified = true;
|
||||||
|
|
||||||
|
$stmt = $pdo->prepare("DELETE FROM `tags_mailbox` WHERE `username` = :username AND `tag_name` = :tag_name");
|
||||||
|
$stmt->execute(array(
|
||||||
|
':username' => $username,
|
||||||
|
':tag_name' => $tag,
|
||||||
|
));
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
if (!$wasModified) return false;
|
||||||
|
$_SESSION['return'][] = array(
|
||||||
|
'type' => 'success',
|
||||||
|
'log' => array(__FUNCTION__, $_action, $_type, $_data_log, $_attr),
|
||||||
|
'msg' => array('mailbox_modified', $username)
|
||||||
|
);
|
||||||
|
break;
|
||||||
}
|
}
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
|
@@ -3,7 +3,7 @@ function init_db_schema() {
|
|||||||
try {
|
try {
|
||||||
global $pdo;
|
global $pdo;
|
||||||
|
|
||||||
$db_version = "18012022_1020";
|
$db_version = "18062022_1153";
|
||||||
|
|
||||||
$stmt = $pdo->query("SHOW TABLES LIKE 'versions'");
|
$stmt = $pdo->query("SHOW TABLES LIKE 'versions'");
|
||||||
$num_results = count($stmt->fetchAll(PDO::FETCH_ASSOC));
|
$num_results = count($stmt->fetchAll(PDO::FETCH_ASSOC));
|
||||||
@@ -251,6 +251,26 @@ function init_db_schema() {
|
|||||||
),
|
),
|
||||||
"attr" => "ENGINE=InnoDB DEFAULT CHARSET=utf8mb4 ROW_FORMAT=DYNAMIC"
|
"attr" => "ENGINE=InnoDB DEFAULT CHARSET=utf8mb4 ROW_FORMAT=DYNAMIC"
|
||||||
),
|
),
|
||||||
|
"tags_domain" => array(
|
||||||
|
"cols" => array(
|
||||||
|
"tag_name" => "VARCHAR(255) NOT NULL",
|
||||||
|
"domain" => "VARCHAR(255) NOT NULL"
|
||||||
|
),
|
||||||
|
"keys" => array(
|
||||||
|
"fkey" => array(
|
||||||
|
"fk_tags_domain" => array(
|
||||||
|
"col" => "domain",
|
||||||
|
"ref" => "domain.domain",
|
||||||
|
"delete" => "CASCADE",
|
||||||
|
"update" => "NO ACTION"
|
||||||
|
)
|
||||||
|
),
|
||||||
|
"unique" => array(
|
||||||
|
"tag_name" => array("tag_name", "domain")
|
||||||
|
)
|
||||||
|
),
|
||||||
|
"attr" => "ENGINE=InnoDB DEFAULT CHARSET=utf8mb4 ROW_FORMAT=DYNAMIC"
|
||||||
|
),
|
||||||
"tls_policy_override" => array(
|
"tls_policy_override" => array(
|
||||||
"cols" => array(
|
"cols" => array(
|
||||||
"id" => "INT NOT NULL AUTO_INCREMENT",
|
"id" => "INT NOT NULL AUTO_INCREMENT",
|
||||||
@@ -325,6 +345,26 @@ function init_db_schema() {
|
|||||||
),
|
),
|
||||||
"attr" => "ENGINE=InnoDB DEFAULT CHARSET=utf8mb4 ROW_FORMAT=DYNAMIC"
|
"attr" => "ENGINE=InnoDB DEFAULT CHARSET=utf8mb4 ROW_FORMAT=DYNAMIC"
|
||||||
),
|
),
|
||||||
|
"tags_mailbox" => array(
|
||||||
|
"cols" => array(
|
||||||
|
"tag_name" => "VARCHAR(255) NOT NULL",
|
||||||
|
"username" => "VARCHAR(255) NOT NULL"
|
||||||
|
),
|
||||||
|
"keys" => array(
|
||||||
|
"fkey" => array(
|
||||||
|
"fk_tags_mailbox" => array(
|
||||||
|
"col" => "username",
|
||||||
|
"ref" => "mailbox.username",
|
||||||
|
"delete" => "CASCADE",
|
||||||
|
"update" => "NO ACTION"
|
||||||
|
)
|
||||||
|
),
|
||||||
|
"unique" => array(
|
||||||
|
"tag_name" => array("tag_name", "username")
|
||||||
|
)
|
||||||
|
),
|
||||||
|
"attr" => "ENGINE=InnoDB DEFAULT CHARSET=utf8mb4 ROW_FORMAT=DYNAMIC"
|
||||||
|
),
|
||||||
"sieve_filters" => array(
|
"sieve_filters" => array(
|
||||||
"cols" => array(
|
"cols" => array(
|
||||||
"id" => "INT NOT NULL AUTO_INCREMENT",
|
"id" => "INT NOT NULL AUTO_INCREMENT",
|
||||||
@@ -400,7 +440,7 @@ function init_db_schema() {
|
|||||||
"spam_score" => "TINYINT(1) NOT NULL DEFAULT '1'",
|
"spam_score" => "TINYINT(1) NOT NULL DEFAULT '1'",
|
||||||
"spam_policy" => "TINYINT(1) NOT NULL DEFAULT '1'",
|
"spam_policy" => "TINYINT(1) NOT NULL DEFAULT '1'",
|
||||||
"delimiter_action" => "TINYINT(1) NOT NULL DEFAULT '1'",
|
"delimiter_action" => "TINYINT(1) NOT NULL DEFAULT '1'",
|
||||||
"syncjobs" => "TINYINT(1) NOT NULL DEFAULT '1'",
|
"syncjobs" => "TINYINT(1) NOT NULL DEFAULT '0'",
|
||||||
"eas_reset" => "TINYINT(1) NOT NULL DEFAULT '1'",
|
"eas_reset" => "TINYINT(1) NOT NULL DEFAULT '1'",
|
||||||
"sogo_profile_reset" => "TINYINT(1) NOT NULL DEFAULT '0'",
|
"sogo_profile_reset" => "TINYINT(1) NOT NULL DEFAULT '0'",
|
||||||
"pushover" => "TINYINT(1) NOT NULL DEFAULT '1'",
|
"pushover" => "TINYINT(1) NOT NULL DEFAULT '1'",
|
||||||
@@ -864,7 +904,7 @@ function init_db_schema() {
|
|||||||
"sogo_sessions_folder" => array(
|
"sogo_sessions_folder" => array(
|
||||||
"cols" => array(
|
"cols" => array(
|
||||||
"c_id" => "VARCHAR(255) NOT NULL",
|
"c_id" => "VARCHAR(255) NOT NULL",
|
||||||
"c_value" => "VARCHAR(255) NOT NULL",
|
"c_value" => "VARCHAR(4096) NOT NULL",
|
||||||
"c_creationdate" => "INT(11) NOT NULL",
|
"c_creationdate" => "INT(11) NOT NULL",
|
||||||
"c_lastseen" => "INT(11) NOT NULL"
|
"c_lastseen" => "INT(11) NOT NULL"
|
||||||
),
|
),
|
||||||
@@ -1188,7 +1228,16 @@ function init_db_schema() {
|
|||||||
}
|
}
|
||||||
|
|
||||||
// Mitigate imapsync pipemess issue
|
// Mitigate imapsync pipemess issue
|
||||||
$pdo->query("UPDATE `imapsync` SET `custom_params` = '' WHERE `custom_params` LIKE '%pipemess%';");
|
$pdo->query("UPDATE `imapsync` SET `custom_params` = ''
|
||||||
|
WHERE `custom_params` LIKE '%pipemess%'
|
||||||
|
OR custom_params LIKE '%skipmess%'
|
||||||
|
OR custom_params LIKE '%delete2foldersonly%'
|
||||||
|
OR custom_params LIKE '%delete2foldersbutnot%'
|
||||||
|
OR custom_params LIKE '%regexflag%'
|
||||||
|
OR custom_params LIKE '%pipemess%'
|
||||||
|
OR custom_params LIKE '%regextrans2%'
|
||||||
|
OR custom_params LIKE '%maxlinelengthcmd%';");
|
||||||
|
|
||||||
|
|
||||||
// Migrate webauthn tfa
|
// Migrate webauthn tfa
|
||||||
$stmt = $pdo->query("ALTER TABLE `tfa` MODIFY COLUMN `authmech` ENUM('yubi_otp', 'u2f', 'hotp', 'totp', 'webauthn')");
|
$stmt = $pdo->query("ALTER TABLE `tfa` MODIFY COLUMN `authmech` ENUM('yubi_otp', 'u2f', 'hotp', 'totp', 'webauthn')");
|
||||||
|
@@ -100,6 +100,7 @@ $AVAILABLE_LANGUAGES = array(
|
|||||||
'ru' => 'Pусский (Russian)',
|
'ru' => 'Pусский (Russian)',
|
||||||
'sk' => 'Slovenčina (Slovak)',
|
'sk' => 'Slovenčina (Slovak)',
|
||||||
'sv' => 'Svenska (Swedish)',
|
'sv' => 'Svenska (Swedish)',
|
||||||
|
'uk' => 'Українська (Ukrainian)',
|
||||||
'zh' => '中文 (Chinese)'
|
'zh' => '中文 (Chinese)'
|
||||||
);
|
);
|
||||||
|
|
||||||
@@ -148,6 +149,9 @@ $ACCESS_TOKEN_LIFETIME = 86400;
|
|||||||
// Logout from mailcow after first OAuth2 session profile request
|
// Logout from mailcow after first OAuth2 session profile request
|
||||||
$OAUTH2_FORGET_SESSION_AFTER_LOGIN = false;
|
$OAUTH2_FORGET_SESSION_AFTER_LOGIN = false;
|
||||||
|
|
||||||
|
// Set a limit for mailbox and domain tagging
|
||||||
|
$TAGGING_LIMIT = 25;
|
||||||
|
|
||||||
// MAILBOX_DEFAULT_ATTRIBUTES define default attributes for new mailboxes
|
// MAILBOX_DEFAULT_ATTRIBUTES define default attributes for new mailboxes
|
||||||
// These settings will not change existing mailboxes
|
// These settings will not change existing mailboxes
|
||||||
|
|
||||||
@@ -224,3 +228,135 @@ $RSPAMD_MAPS = array(
|
|||||||
'Monitoring Hosts' => 'monitoring_nolog.map'
|
'Monitoring Hosts' => 'monitoring_nolog.map'
|
||||||
)
|
)
|
||||||
);
|
);
|
||||||
|
|
||||||
|
|
||||||
|
$IMAPSYNC_OPTIONS = array(
|
||||||
|
'whitelist' => array(
|
||||||
|
'log',
|
||||||
|
'showpasswords',
|
||||||
|
'nossl1',
|
||||||
|
'nossl2',
|
||||||
|
'ssl2',
|
||||||
|
'notls1',
|
||||||
|
'notls2',
|
||||||
|
'tls2',
|
||||||
|
'debugssl',
|
||||||
|
'sslargs1',
|
||||||
|
'sslargs2',
|
||||||
|
'authmech1',
|
||||||
|
'authmech2',
|
||||||
|
'authuser1',
|
||||||
|
'authuser2',
|
||||||
|
'proxyauth1',
|
||||||
|
'proxyauth2',
|
||||||
|
'authmd51',
|
||||||
|
'authmd52',
|
||||||
|
'domain1',
|
||||||
|
'domain2',
|
||||||
|
'oauthaccesstoken1',
|
||||||
|
'oauthaccesstoken2',
|
||||||
|
'oauthdirect1',
|
||||||
|
'oauthdirect2',
|
||||||
|
'folder',
|
||||||
|
'folder',
|
||||||
|
'folderrec',
|
||||||
|
'folderrec',
|
||||||
|
'folderfirst',
|
||||||
|
'folderfirst',
|
||||||
|
'folderlast',
|
||||||
|
'folderlast',
|
||||||
|
'nomixfolders',
|
||||||
|
'skipemptyfolders',
|
||||||
|
'include',
|
||||||
|
'include',
|
||||||
|
'subfolder1',
|
||||||
|
'subscribed',
|
||||||
|
'subscribe',
|
||||||
|
'prefix1',
|
||||||
|
'prefix2',
|
||||||
|
'sep1',
|
||||||
|
'sep2',
|
||||||
|
'nofoldersizesatend',
|
||||||
|
'justfoldersizes',
|
||||||
|
'pidfile',
|
||||||
|
'pidfilelocking',
|
||||||
|
'nolog',
|
||||||
|
'logfile',
|
||||||
|
'logdir',
|
||||||
|
'debugcrossduplicates',
|
||||||
|
'disarmreadreceipts',
|
||||||
|
'truncmess',
|
||||||
|
'synclabels',
|
||||||
|
'resynclabels',
|
||||||
|
'resyncflags',
|
||||||
|
'noresyncflags',
|
||||||
|
'filterbuggyflags',
|
||||||
|
'expunge1',
|
||||||
|
'noexpunge1',
|
||||||
|
'delete1emptyfolders',
|
||||||
|
'delete2folders',
|
||||||
|
'noexpunge2',
|
||||||
|
'nouidexpunge2',
|
||||||
|
'syncinternaldates',
|
||||||
|
'idatefromheader',
|
||||||
|
'maxsize',
|
||||||
|
'minsize',
|
||||||
|
'minage',
|
||||||
|
'search',
|
||||||
|
'search1',
|
||||||
|
'search2',
|
||||||
|
'noabletosearch',
|
||||||
|
'noabletosearch1',
|
||||||
|
'noabletosearch2',
|
||||||
|
'maxlinelength',
|
||||||
|
'useheader',
|
||||||
|
'useheader',
|
||||||
|
'syncduplicates',
|
||||||
|
'usecache',
|
||||||
|
'nousecache',
|
||||||
|
'useuid',
|
||||||
|
'syncacls',
|
||||||
|
'nosyncacls',
|
||||||
|
'debug',
|
||||||
|
'debugfolders',
|
||||||
|
'debugcontent',
|
||||||
|
'debugflags',
|
||||||
|
'debugimap1',
|
||||||
|
'debugimap2',
|
||||||
|
'debugimap',
|
||||||
|
'debugmemory',
|
||||||
|
'errorsmax',
|
||||||
|
'tests',
|
||||||
|
'testslive',
|
||||||
|
'testslive6',
|
||||||
|
'gmail1',
|
||||||
|
'gmail2',
|
||||||
|
'office1',
|
||||||
|
'office2',
|
||||||
|
'exchange1',
|
||||||
|
'exchange2',
|
||||||
|
'domino1',
|
||||||
|
'domino2',
|
||||||
|
'keepalive1',
|
||||||
|
'keepalive2',
|
||||||
|
'maxmessagespersecond',
|
||||||
|
'maxbytesafter',
|
||||||
|
'maxsleep',
|
||||||
|
'abort',
|
||||||
|
'exitwhenover',
|
||||||
|
'noid',
|
||||||
|
'justconnect',
|
||||||
|
'justlogin',
|
||||||
|
'justfolders'
|
||||||
|
),
|
||||||
|
'blacklist' => array(
|
||||||
|
'skipmess',
|
||||||
|
'delete2foldersonly',
|
||||||
|
'delete2foldersbutnot',
|
||||||
|
'regexflag',
|
||||||
|
'regexmess',
|
||||||
|
'pipemess',
|
||||||
|
'regextrans2',
|
||||||
|
'maxlinelengthcmd'
|
||||||
|
)
|
||||||
|
);
|
||||||
|
@@ -156,6 +156,12 @@ $(document).ready(function() {
|
|||||||
});
|
});
|
||||||
if (!invalid) {
|
if (!invalid) {
|
||||||
var attr_to_merge = $(this).closest("form").serializeObject();
|
var attr_to_merge = $(this).closest("form").serializeObject();
|
||||||
|
// parse possible JSON Strings
|
||||||
|
for (var [key, value] of Object.entries(attr_to_merge)) {
|
||||||
|
try {
|
||||||
|
attr_to_merge[key] = JSON.parse(attr_to_merge[key]);
|
||||||
|
} catch {}
|
||||||
|
}
|
||||||
var api_attr = $.extend(api_attr, attr_to_merge)
|
var api_attr = $.extend(api_attr, attr_to_merge)
|
||||||
} else {
|
} else {
|
||||||
return false;
|
return false;
|
||||||
@@ -263,6 +269,12 @@ $(document).ready(function() {
|
|||||||
});
|
});
|
||||||
if (!invalid) {
|
if (!invalid) {
|
||||||
var attr_to_merge = $(this).closest("form").serializeObject();
|
var attr_to_merge = $(this).closest("form").serializeObject();
|
||||||
|
// parse possible JSON Strings
|
||||||
|
for (var [key, value] of Object.entries(attr_to_merge)) {
|
||||||
|
try {
|
||||||
|
attr_to_merge[key] = JSON.parse(attr_to_merge[key]);
|
||||||
|
} catch {}
|
||||||
|
}
|
||||||
var api_attr = $.extend(api_attr, attr_to_merge)
|
var api_attr = $.extend(api_attr, attr_to_merge)
|
||||||
} else {
|
} else {
|
||||||
return false;
|
return false;
|
||||||
@@ -329,6 +341,7 @@ $(document).ready(function() {
|
|||||||
multi_data[id].splice($.inArray($(this).data('item'), multi_data[id]), 1);
|
multi_data[id].splice($.inArray($(this).data('item'), multi_data[id]), 1);
|
||||||
multi_data[id].push($(this).data('item'));
|
multi_data[id].push($(this).data('item'));
|
||||||
}
|
}
|
||||||
|
|
||||||
if (typeof $(this).data('text') !== 'undefined') {
|
if (typeof $(this).data('text') !== 'undefined') {
|
||||||
$("#DeleteText").empty();
|
$("#DeleteText").empty();
|
||||||
$("#DeleteText").text($(this).data('text'));
|
$("#DeleteText").text($(this).data('text'));
|
||||||
@@ -340,9 +353,9 @@ $(document).ready(function() {
|
|||||||
$("#ItemsToDelete").empty();
|
$("#ItemsToDelete").empty();
|
||||||
for (var i in data_array) {
|
for (var i in data_array) {
|
||||||
data_array[i] = decodeURIComponent(data_array[i]);
|
data_array[i] = decodeURIComponent(data_array[i]);
|
||||||
$("#ItemsToDelete").append("<li>" + data_array[i] + "</li>");
|
$("#ItemsToDelete").append("<li>" + escapeHtml(data_array[i]) + "</li>");
|
||||||
}
|
}
|
||||||
})
|
});
|
||||||
$('#ConfirmDeleteModal').modal({
|
$('#ConfirmDeleteModal').modal({
|
||||||
backdrop: 'static',
|
backdrop: 'static',
|
||||||
keyboard: false
|
keyboard: false
|
||||||
|
@@ -273,4 +273,51 @@ $(document).ready(function() {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
});
|
});
|
||||||
|
|
||||||
|
// tag boxes
|
||||||
|
$('.tag-box .tag-add').click(function(){
|
||||||
|
addTag(this);
|
||||||
|
});
|
||||||
|
$(".tag-box .tag-input").keydown(function (e) {
|
||||||
|
if (e.which == 13){
|
||||||
|
e.preventDefault();
|
||||||
|
addTag(this);
|
||||||
|
}
|
||||||
|
});
|
||||||
|
function addTag(tagAddElem){
|
||||||
|
var tagboxElem = $(tagAddElem).parent();
|
||||||
|
var tagInputElem = $(tagboxElem).find(".tag-input")[0];
|
||||||
|
var tagValuesElem = $(tagboxElem).find(".tag-values")[0];
|
||||||
|
|
||||||
|
var tag = escapeHtml($(tagInputElem).val());
|
||||||
|
if (!tag) return;
|
||||||
|
var value_tags = [];
|
||||||
|
try {
|
||||||
|
value_tags = JSON.parse($(tagValuesElem).val());
|
||||||
|
} catch {}
|
||||||
|
if (!Array.isArray(value_tags)) value_tags = [];
|
||||||
|
if (value_tags.includes(tag)) return;
|
||||||
|
|
||||||
|
$('<span class="badge badge-primary tag-badge btn-badge"><i class="bi bi-tag-fill"></i> ' + tag + '</span>').insertBefore('.tag-input').click(function(){
|
||||||
|
var del_tag = unescapeHtml($(this).text());
|
||||||
|
var del_tags = [];
|
||||||
|
try {
|
||||||
|
del_tags = JSON.parse($(tagValuesElem).val());
|
||||||
|
} catch {}
|
||||||
|
if (Array.isArray(del_tags)){
|
||||||
|
del_tags.splice(del_tags.indexOf(del_tag), 1);
|
||||||
|
$(tagValuesElem).val(JSON.stringify(del_tags));
|
||||||
|
}
|
||||||
|
$(this).remove();
|
||||||
|
});
|
||||||
|
|
||||||
|
value_tags.push($(tagInputElem).val());
|
||||||
|
$(tagValuesElem).val(JSON.stringify(value_tags));
|
||||||
|
$(tagInputElem).val('');
|
||||||
|
}
|
||||||
});
|
});
|
||||||
|
|
||||||
|
|
||||||
|
// http://stackoverflow.com/questions/24816/escaping-html-strings-with-jquery
|
||||||
|
function escapeHtml(n){var entityMap={"&":"&","<":"<",">":">",'"':""","'":"'","/":"/","`":"`","=":"="}; return String(n).replace(/[&<>"'`=\/]/g,function(n){return entityMap[n]})}
|
||||||
|
function unescapeHtml(t){var n={"&":"&","<":"<",">":">",""":'"',"'":"'","/":"/","`":"`","=":"="};return String(t).replace(/&|<|>|"|'|/|`|=/g,function(t){return n[t]})}
|
||||||
|
@@ -99,37 +99,6 @@ $(document).ready(function() {
|
|||||||
});
|
});
|
||||||
auto_fill_quota($('#addSelectDomain').val());
|
auto_fill_quota($('#addSelectDomain').val());
|
||||||
|
|
||||||
// Read bcc local dests
|
|
||||||
// Using ajax to not be a blocking moo
|
|
||||||
$.get("/api/v1/get/bcc-destination-options", function(data){
|
|
||||||
// Domains
|
|
||||||
var optgroup = "<optgroup label='" + lang.domains + "'>";
|
|
||||||
$.each(data.domains, function(index, domain){
|
|
||||||
optgroup += "<option value='" + domain + "'>" + domain + "</option>"
|
|
||||||
});
|
|
||||||
optgroup += "</optgroup>"
|
|
||||||
$('#bcc-local-dest').append(optgroup);
|
|
||||||
// Alias domains
|
|
||||||
var optgroup = "<optgroup label='" + lang.domain_aliases + "'>";
|
|
||||||
$.each(data.alias_domains, function(index, alias_domain){
|
|
||||||
optgroup += "<option value='" + alias_domain + "'>" + alias_domain + "</option>"
|
|
||||||
});
|
|
||||||
optgroup += "</optgroup>"
|
|
||||||
$('#bcc-local-dest').append(optgroup);
|
|
||||||
// Mailboxes and aliases
|
|
||||||
$.each(data.mailboxes, function(mailbox, aliases){
|
|
||||||
var optgroup = "<optgroup label='" + mailbox + "'>";
|
|
||||||
$.each(aliases, function(index, alias){
|
|
||||||
optgroup += "<option value='" + alias + "'>" + alias + "</option>"
|
|
||||||
});
|
|
||||||
optgroup += "</optgroup>"
|
|
||||||
$('#bcc-local-dest').append(optgroup);
|
|
||||||
});
|
|
||||||
// Finish
|
|
||||||
$('#bcc-local-dest').find('option:selected').remove();
|
|
||||||
$('#bcc-local-dest').selectpicker('refresh');
|
|
||||||
});
|
|
||||||
|
|
||||||
$(".goto_checkbox").click(function( event ) {
|
$(".goto_checkbox").click(function( event ) {
|
||||||
$("form[data-id='add_alias'] .goto_checkbox").not(this).prop('checked', false);
|
$("form[data-id='add_alias'] .goto_checkbox").not(this).prop('checked', false);
|
||||||
if ($("form[data-id='add_alias'] .goto_checkbox:checked").length > 0) {
|
if ($("form[data-id='add_alias'] .goto_checkbox:checked").length > 0) {
|
||||||
@@ -236,9 +205,6 @@ $(document).ready(function() {
|
|||||||
|
|
||||||
});
|
});
|
||||||
jQuery(function($){
|
jQuery(function($){
|
||||||
// http://stackoverflow.com/questions/24816/escaping-html-strings-with-jquery
|
|
||||||
var entityMap={"&":"&","<":"<",">":">",'"':""","'":"'","/":"/","`":"`","=":"="};
|
|
||||||
function escapeHtml(n){return String(n).replace(/[&<>"'`=\/]/g,function(n){return entityMap[n]})}
|
|
||||||
// http://stackoverflow.com/questions/46155/validate-email-address-in-javascript
|
// http://stackoverflow.com/questions/46155/validate-email-address-in-javascript
|
||||||
function humanFileSize(i){if(Math.abs(i)<1024)return i+" B";var B=["KiB","MiB","GiB","TiB","PiB","EiB","ZiB","YiB"],e=-1;do{i/=1024,++e}while(Math.abs(i)>=1024&&e<B.length-1);return i.toFixed(1)+" "+B[e]}
|
function humanFileSize(i){if(Math.abs(i)<1024)return i+" B";var B=["KiB","MiB","GiB","TiB","PiB","EiB","ZiB","YiB"],e=-1;do{i/=1024,++e}while(Math.abs(i)>=1024&&e<B.length-1);return i.toFixed(1)+" "+B[e]}
|
||||||
function unix_time_format(i){return""==i?'<i class="bi bi-x-lg"></i>':new Date(i?1e3*i:0).toLocaleDateString(void 0,{year:"numeric",month:"2-digit",day:"2-digit",hour:"2-digit",minute:"2-digit",second:"2-digit"})}
|
function unix_time_format(i){return""==i?'<i class="bi bi-x-lg"></i>':new Date(i?1e3*i:0).toLocaleDateString(void 0,{year:"numeric",month:"2-digit",day:"2-digit",hour:"2-digit",minute:"2-digit",second:"2-digit"})}
|
||||||
@@ -293,6 +259,7 @@ jQuery(function($){
|
|||||||
{"name":"rl","title":"RL","breakpoints":"xs sm md lg","style":{"min-width":"100px","width":"100px"}},
|
{"name":"rl","title":"RL","breakpoints":"xs sm md lg","style":{"min-width":"100px","width":"100px"}},
|
||||||
{"name":"backupmx","filterable": false,"style":{"min-width":"120px","width":"120px"},"title":lang.backup_mx,"breakpoints":"xs sm md lg","formatter": function(value){return 1==value?'<i class="bi bi-check-lg"></i>':0==value&&'<i class="bi bi-x-lg"></i>';}},
|
{"name":"backupmx","filterable": false,"style":{"min-width":"120px","width":"120px"},"title":lang.backup_mx,"breakpoints":"xs sm md lg","formatter": function(value){return 1==value?'<i class="bi bi-check-lg"></i>':0==value&&'<i class="bi bi-x-lg"></i>';}},
|
||||||
{"name":"domain_admins","title":lang.domain_admins,"style":{"word-break":"break-all","min-width":"200px"},"breakpoints":"xs sm md lg","filterable":(role == "admin"),"visible":(role == "admin")},
|
{"name":"domain_admins","title":lang.domain_admins,"style":{"word-break":"break-all","min-width":"200px"},"breakpoints":"xs sm md lg","filterable":(role == "admin"),"visible":(role == "admin")},
|
||||||
|
{"name":"tags","title":"Tags","style":{},"breakpoints":"xs sm md lg"},
|
||||||
{"name":"active","filterable": false,"style":{"min-width":"80px","width":"80px"},"title":lang.active,"formatter": function(value){return 1==value?'<i class="bi bi-check-lg"></i>':0==value&&'<i class="bi bi-x-lg"></i>';}},
|
{"name":"active","filterable": false,"style":{"min-width":"80px","width":"80px"},"title":lang.active,"formatter": function(value){return 1==value?'<i class="bi bi-check-lg"></i>':0==value&&'<i class="bi bi-x-lg"></i>';}},
|
||||||
{"name":"action","filterable": false,"sortable": false,"style":{"text-align":"right","min-width":"240px","width":"240px"},"type":"html","title":lang.action,"breakpoints":"xs sm md"}
|
{"name":"action","filterable": false,"sortable": false,"style":{"text-align":"right","min-width":"240px","width":"240px"},"type":"html","title":lang.action,"breakpoints":"xs sm md"}
|
||||||
],
|
],
|
||||||
@@ -330,6 +297,13 @@ jQuery(function($){
|
|||||||
'<a href="#dnsInfoModal" class="btn btn-xs btn-xs-half btn-info" data-toggle="modal" data-domain="' + encodeURIComponent(item.domain_name) + '"><i class="bi bi-globe2"></i> DNS</a></div>';
|
'<a href="#dnsInfoModal" class="btn btn-xs btn-xs-half btn-info" data-toggle="modal" data-domain="' + encodeURIComponent(item.domain_name) + '"><i class="bi bi-globe2"></i> DNS</a></div>';
|
||||||
}
|
}
|
||||||
|
|
||||||
|
if (Array.isArray(item.tags)){
|
||||||
|
var tags = '';
|
||||||
|
for (var i = 0; i < item.tags.length; i++)
|
||||||
|
tags += '<span class="badge badge-primary tag-badge"><i class="bi bi-tag-fill"></i> ' + escapeHtml(item.tags[i]) + '</span>';
|
||||||
|
item.tags = tags;
|
||||||
|
}
|
||||||
|
|
||||||
if (item.backupmx == 1) {
|
if (item.backupmx == 1) {
|
||||||
if (item.relay_unknown_only == 1) {
|
if (item.relay_unknown_only == 1) {
|
||||||
item.domain_name = '<div class="label label-info">Relay Non-Local</div> ' + item.domain_name;
|
item.domain_name = '<div class="label label-info">Relay Non-Local</div> ' + item.domain_name;
|
||||||
@@ -418,6 +392,7 @@ jQuery(function($){
|
|||||||
},
|
},
|
||||||
{"name":"messages","filterable": false,"title":lang.msg_num,"breakpoints":"xs sm md"},
|
{"name":"messages","filterable": false,"title":lang.msg_num,"breakpoints":"xs sm md"},
|
||||||
/* {"name":"rl","title":"RL","breakpoints":"all","style":{"width":"125px"}}, */
|
/* {"name":"rl","title":"RL","breakpoints":"all","style":{"width":"125px"}}, */
|
||||||
|
{"name":"tags","title":"Tags","style":{},"breakpoints":"xs sm md lg"},
|
||||||
{"name":"active","filterable": false,"style":{"min-width":"80px","width":"80px"},"title":lang.active,"formatter": function(value){return 1==value?'<i class="bi bi-check-lg"></i>':(0==value?'<i class="bi bi-x-lg"></i>':2==value&&'—');}},
|
{"name":"active","filterable": false,"style":{"min-width":"80px","width":"80px"},"title":lang.active,"formatter": function(value){return 1==value?'<i class="bi bi-check-lg"></i>':(0==value?'<i class="bi bi-x-lg"></i>':2==value&&'—');}},
|
||||||
{"name":"action","filterable": false,"sortable": false,"style":{"min-width":"290px","text-align":"right"},"type":"html","title":lang.action,"breakpoints":"xs sm md"}
|
{"name":"action","filterable": false,"sortable": false,"style":{"min-width":"290px","text-align":"right"},"type":"html","title":lang.action,"breakpoints":"xs sm md"}
|
||||||
],
|
],
|
||||||
@@ -497,6 +472,13 @@ jQuery(function($){
|
|||||||
'<div class="progress-bar-mailbox progress-bar progress-bar-' + item.percent_class + '" role="progressbar" aria-valuenow="' + item.percent_in_use + '" aria-valuemin="0" aria-valuemax="100" ' +
|
'<div class="progress-bar-mailbox progress-bar progress-bar-' + item.percent_class + '" role="progressbar" aria-valuenow="' + item.percent_in_use + '" aria-valuemin="0" aria-valuemax="100" ' +
|
||||||
'style="min-width:2em;width:' + item.percent_in_use + '%">' + item.percent_in_use + '%' + '</div></div>';
|
'style="min-width:2em;width:' + item.percent_in_use + '%">' + item.percent_in_use + '%' + '</div></div>';
|
||||||
item.username = escapeHtml(item.username);
|
item.username = escapeHtml(item.username);
|
||||||
|
|
||||||
|
if (Array.isArray(item.tags)){
|
||||||
|
var tags = '';
|
||||||
|
for (var i = 0; i < item.tags.length; i++)
|
||||||
|
tags += '<span class="badge badge-primary tag-badge"><i class="bi bi-tag-fill"></i> ' + escapeHtml(item.tags[i]) + '</span>';
|
||||||
|
item.tags = tags;
|
||||||
|
}
|
||||||
});
|
});
|
||||||
}
|
}
|
||||||
}),
|
}),
|
||||||
@@ -571,6 +553,7 @@ jQuery(function($){
|
|||||||
'</div>';
|
'</div>';
|
||||||
item.chkbox = '<input type="checkbox" data-id="resource" name="multi_select" value="' + encodeURIComponent(item.name) + '" />';
|
item.chkbox = '<input type="checkbox" data-id="resource" name="multi_select" value="' + encodeURIComponent(item.name) + '" />';
|
||||||
item.name = escapeHtml(item.name);
|
item.name = escapeHtml(item.name);
|
||||||
|
item.description = escapeHtml(item.description);
|
||||||
});
|
});
|
||||||
}
|
}
|
||||||
}),
|
}),
|
||||||
@@ -610,6 +593,37 @@ jQuery(function($){
|
|||||||
});
|
});
|
||||||
}
|
}
|
||||||
function draw_bcc_table() {
|
function draw_bcc_table() {
|
||||||
|
// Read bcc local dests
|
||||||
|
// Using ajax to not be a blocking moo
|
||||||
|
$.get("/api/v1/get/bcc-destination-options", function(data){
|
||||||
|
// Domains
|
||||||
|
var optgroup = "<optgroup label='" + lang.domains + "'>";
|
||||||
|
$.each(data.domains, function(index, domain){
|
||||||
|
optgroup += "<option value='" + domain + "'>" + domain + "</option>"
|
||||||
|
});
|
||||||
|
optgroup += "</optgroup>"
|
||||||
|
$('#bcc-local-dest').append(optgroup);
|
||||||
|
// Alias domains
|
||||||
|
var optgroup = "<optgroup label='" + lang.domain_aliases + "'>";
|
||||||
|
$.each(data.alias_domains, function(index, alias_domain){
|
||||||
|
optgroup += "<option value='" + alias_domain + "'>" + alias_domain + "</option>"
|
||||||
|
});
|
||||||
|
optgroup += "</optgroup>"
|
||||||
|
$('#bcc-local-dest').append(optgroup);
|
||||||
|
// Mailboxes and aliases
|
||||||
|
$.each(data.mailboxes, function(mailbox, aliases){
|
||||||
|
var optgroup = "<optgroup label='" + mailbox + "'>";
|
||||||
|
$.each(aliases, function(index, alias){
|
||||||
|
optgroup += "<option value='" + alias + "'>" + alias + "</option>"
|
||||||
|
});
|
||||||
|
optgroup += "</optgroup>"
|
||||||
|
$('#bcc-local-dest').append(optgroup);
|
||||||
|
});
|
||||||
|
// Finish
|
||||||
|
$('#bcc-local-dest').find('option:selected').remove();
|
||||||
|
$('#bcc-local-dest').selectpicker('refresh');
|
||||||
|
});
|
||||||
|
|
||||||
ft_bcc_table = FooTable.init('#bcc_table', {
|
ft_bcc_table = FooTable.init('#bcc_table', {
|
||||||
"columns": [
|
"columns": [
|
||||||
{"name":"chkbox","title":"","style":{"min-width":"60px","width":"60px"},"filterable": false,"sortable": false,"type":"html"},
|
{"name":"chkbox","title":"","style":{"min-width":"60px","width":"60px"},"filterable": false,"sortable": false,"type":"html"},
|
||||||
@@ -1009,7 +1023,7 @@ jQuery(function($){
|
|||||||
if (!item.exclude > 0) {
|
if (!item.exclude > 0) {
|
||||||
item.exclude = '-';
|
item.exclude = '-';
|
||||||
} else {
|
} else {
|
||||||
item.exclude = '<code>' + item.exclude + '</code>';
|
item.exclude = '<code>' + escapeHtml(item.exclude) + '</code>';
|
||||||
}
|
}
|
||||||
item.server_w_port = escapeHtml(item.user1) + '@' + item.host1 + ':' + item.port1;
|
item.server_w_port = escapeHtml(item.user1) + '@' + item.host1 + ':' + item.port1;
|
||||||
item.action = '<div class="btn-group footable-actions">' +
|
item.action = '<div class="btn-group footable-actions">' +
|
||||||
@@ -1147,15 +1161,33 @@ jQuery(function($){
|
|||||||
event.stopPropagation();
|
event.stopPropagation();
|
||||||
})
|
})
|
||||||
|
|
||||||
draw_domain_table();
|
// detect element visibility changes
|
||||||
draw_mailbox_table();
|
function onVisible(element, callback) {
|
||||||
draw_resource_table();
|
$(element).ready(function() {
|
||||||
draw_alias_table();
|
element_object = document.querySelector(element)
|
||||||
draw_aliasdomain_table();
|
new IntersectionObserver((entries, observer) => {
|
||||||
draw_sync_job_table();
|
entries.forEach(entry => {
|
||||||
draw_filter_table();
|
if(entry.intersectionRatio > 0) {
|
||||||
|
callback(element_object);
|
||||||
|
observer.disconnect();
|
||||||
|
}
|
||||||
|
});
|
||||||
|
}).observe(element_object);
|
||||||
|
});
|
||||||
|
}
|
||||||
|
|
||||||
|
// Load only if the tab is visible
|
||||||
|
onVisible("[id^=tab-domains]", () => draw_domain_table());
|
||||||
|
onVisible("[id^=tab-mailboxes]", () => draw_mailbox_table());
|
||||||
|
onVisible("[id^=tab-resources]", () => draw_resource_table());
|
||||||
|
onVisible("[id^=tab-mbox-aliases]", () => draw_alias_table());
|
||||||
|
onVisible("[id^=tab-domain-aliases]", () => draw_aliasdomain_table());
|
||||||
|
onVisible("[id^=tab-syncjobs]", () => draw_sync_job_table());
|
||||||
|
onVisible("[id^=tab-filters]", () => draw_filter_table());
|
||||||
|
onVisible("[id^=tab-bcc]", () => {
|
||||||
draw_bcc_table();
|
draw_bcc_table();
|
||||||
draw_recipient_map_table();
|
draw_recipient_map_table();
|
||||||
draw_tls_policy_table();
|
});
|
||||||
|
onVisible("[id^=tab-tls-policy]", () => draw_tls_policy_table());
|
||||||
|
|
||||||
});
|
});
|
||||||
|
@@ -14,8 +14,10 @@ function api_log($_data) {
|
|||||||
if ($data == 'csrf_token') {
|
if ($data == 'csrf_token') {
|
||||||
continue;
|
continue;
|
||||||
}
|
}
|
||||||
if ($value = json_decode($value, true)) {
|
|
||||||
unset($value["csrf_token"]);
|
$value = json_decode($value, true);
|
||||||
|
if ($value) {
|
||||||
|
if (is_array($value)) unset($value["csrf_token"]);
|
||||||
foreach ($value as $key => &$val) {
|
foreach ($value as $key => &$val) {
|
||||||
if(preg_match("/pass/i", $key)) {
|
if(preg_match("/pass/i", $key)) {
|
||||||
$val = '*';
|
$val = '*';
|
||||||
@@ -25,6 +27,7 @@ function api_log($_data) {
|
|||||||
}
|
}
|
||||||
$data_var[] = $data . "='" . $value . "'";
|
$data_var[] = $data . "='" . $value . "'";
|
||||||
}
|
}
|
||||||
|
|
||||||
try {
|
try {
|
||||||
$log_line = array(
|
$log_line = array(
|
||||||
'time' => time(),
|
'time' => time(),
|
||||||
@@ -82,10 +85,10 @@ if (isset($_GET['query'])) {
|
|||||||
if ($action == 'delete') {
|
if ($action == 'delete') {
|
||||||
$_POST['items'] = $request;
|
$_POST['items'] = $request;
|
||||||
}
|
}
|
||||||
|
|
||||||
}
|
}
|
||||||
api_log($_POST);
|
api_log($_POST);
|
||||||
|
|
||||||
|
|
||||||
$request_incomplete = json_encode(array(
|
$request_incomplete = json_encode(array(
|
||||||
'type' => 'error',
|
'type' => 'error',
|
||||||
'msg' => 'Cannot find attributes in post data'
|
'msg' => 'Cannot find attributes in post data'
|
||||||
@@ -486,7 +489,12 @@ if (isset($_GET['query'])) {
|
|||||||
case "domain":
|
case "domain":
|
||||||
switch ($object) {
|
switch ($object) {
|
||||||
case "all":
|
case "all":
|
||||||
$domains = mailbox('get', 'domains');
|
$tags = null;
|
||||||
|
if (isset($_GET['tags']) && $_GET['tags'] != '')
|
||||||
|
$tags = explode(',', $_GET['tags']);
|
||||||
|
|
||||||
|
$domains = mailbox('get', 'domains', null, $tags);
|
||||||
|
|
||||||
if (!empty($domains)) {
|
if (!empty($domains)) {
|
||||||
foreach ($domains as $domain) {
|
foreach ($domains as $domain) {
|
||||||
if ($details = mailbox('get', 'domain_details', $domain)) {
|
if ($details = mailbox('get', 'domain_details', $domain)) {
|
||||||
@@ -952,23 +960,20 @@ if (isset($_GET['query'])) {
|
|||||||
switch ($object) {
|
switch ($object) {
|
||||||
case "all":
|
case "all":
|
||||||
case "reduced":
|
case "reduced":
|
||||||
if (empty($extra)) {
|
$tags = null;
|
||||||
$domains = mailbox('get', 'domains');
|
if (isset($_GET['tags']) && $_GET['tags'] != '')
|
||||||
}
|
$tags = explode(',', $_GET['tags']);
|
||||||
else {
|
|
||||||
$domains = explode(',', $extra);
|
if (empty($extra)) $domains = mailbox('get', 'domains');
|
||||||
}
|
else $domains = explode(',', $extra);
|
||||||
|
|
||||||
if (!empty($domains)) {
|
if (!empty($domains)) {
|
||||||
foreach ($domains as $domain) {
|
foreach ($domains as $domain) {
|
||||||
$mailboxes = mailbox('get', 'mailboxes', $domain);
|
$mailboxes = mailbox('get', 'mailboxes', $domain, $tags);
|
||||||
if (!empty($mailboxes)) {
|
if (!empty($mailboxes)) {
|
||||||
foreach ($mailboxes as $mailbox) {
|
foreach ($mailboxes as $mailbox) {
|
||||||
if ($details = mailbox('get', 'mailbox_details', $mailbox, $object)) {
|
if ($details = mailbox('get', 'mailbox_details', $mailbox, $object)) $data[] = $details;
|
||||||
$data[] = $details;
|
else continue;
|
||||||
}
|
|
||||||
else {
|
|
||||||
continue;
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@@ -980,8 +985,23 @@ if (isset($_GET['query'])) {
|
|||||||
break;
|
break;
|
||||||
|
|
||||||
default:
|
default:
|
||||||
|
$tags = null;
|
||||||
|
if (isset($_GET['tags']) && $_GET['tags'] != '')
|
||||||
|
$tags = explode(',', $_GET['tags']);
|
||||||
|
|
||||||
|
if ($tags === null) {
|
||||||
$data = mailbox('get', 'mailbox_details', $object);
|
$data = mailbox('get', 'mailbox_details', $object);
|
||||||
process_get_return($data);
|
process_get_return($data);
|
||||||
|
} else {
|
||||||
|
$mailboxes = mailbox('get', 'mailboxes', $object, $tags);
|
||||||
|
if (is_array($mailboxes)) {
|
||||||
|
foreach ($mailboxes as $mailbox) {
|
||||||
|
if ($details = mailbox('get', 'mailbox_details', $mailbox))
|
||||||
|
$data[] = $details;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
process_get_return($data, false);
|
||||||
|
}
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
break;
|
break;
|
||||||
@@ -1472,6 +1492,11 @@ if (isset($_GET['query'])) {
|
|||||||
'solr_documents' => $solr_documents
|
'solr_documents' => $solr_documents
|
||||||
));
|
));
|
||||||
break;
|
break;
|
||||||
|
case "version":
|
||||||
|
echo json_encode(array(
|
||||||
|
'version' => $GLOBALS['MAILCOW_GIT_VERSION']
|
||||||
|
));
|
||||||
|
break;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
break;
|
break;
|
||||||
@@ -1575,13 +1600,25 @@ if (isset($_GET['query'])) {
|
|||||||
process_delete_return(dkim('delete', array('domains' => $items)));
|
process_delete_return(dkim('delete', array('domains' => $items)));
|
||||||
break;
|
break;
|
||||||
case "domain":
|
case "domain":
|
||||||
|
switch ($object){
|
||||||
|
case "tag":
|
||||||
|
process_delete_return(mailbox('delete', 'tags_domain', array('tags' => $items, 'domain' => $extra)));
|
||||||
|
break;
|
||||||
|
default:
|
||||||
process_delete_return(mailbox('delete', 'domain', array('domain' => $items)));
|
process_delete_return(mailbox('delete', 'domain', array('domain' => $items)));
|
||||||
|
}
|
||||||
break;
|
break;
|
||||||
case "alias-domain":
|
case "alias-domain":
|
||||||
process_delete_return(mailbox('delete', 'alias_domain', array('alias_domain' => $items)));
|
process_delete_return(mailbox('delete', 'alias_domain', array('alias_domain' => $items)));
|
||||||
break;
|
break;
|
||||||
case "mailbox":
|
case "mailbox":
|
||||||
|
switch ($object){
|
||||||
|
case "tag":
|
||||||
|
process_delete_return(mailbox('delete', 'tags_mailbox', array('tags' => $items, 'username' => $extra)));
|
||||||
|
break;
|
||||||
|
default:
|
||||||
process_delete_return(mailbox('delete', 'mailbox', array('username' => $items)));
|
process_delete_return(mailbox('delete', 'mailbox', array('username' => $items)));
|
||||||
|
}
|
||||||
break;
|
break;
|
||||||
case "resource":
|
case "resource":
|
||||||
process_delete_return(mailbox('delete', 'resource', array('name' => $items)));
|
process_delete_return(mailbox('delete', 'resource', array('name' => $items)));
|
||||||
|
@@ -298,7 +298,7 @@
|
|||||||
"rsettings_preset_2": "Postmasteři chtějí dostávat spam",
|
"rsettings_preset_2": "Postmasteři chtějí dostávat spam",
|
||||||
"rsettings_preset_3": "Povolit jen určité odesílatele pro schránku (např. jen interní schránka)",
|
"rsettings_preset_3": "Povolit jen určité odesílatele pro schránku (např. jen interní schránka)",
|
||||||
"rsettings_preset_4": "Deaktivujte Rspamd pro doménu",
|
"rsettings_preset_4": "Deaktivujte Rspamd pro doménu",
|
||||||
"rspamd-com_settings": "<a href=\"https://rspamd.com/doc/configuration/settings.html#settings-structure\" target=\"_blank\">Rspamd dokumentace</a>\r\n - Název nastavení bude automaticky vygenerován, viz níže uvedené předvolby.",
|
"rspamd_com_settings": "<a href=\"https://rspamd.com/doc/configuration/settings.html#settings-structure\" target=\"_blank\">Rspamd dokumentace</a>\r\n - Název nastavení bude automaticky vygenerován, viz níže uvedené předvolby.",
|
||||||
"rspamd_global_filters": "Mapa globálních filtrů",
|
"rspamd_global_filters": "Mapa globálních filtrů",
|
||||||
"rspamd_global_filters_agree": "Budu opatrný!",
|
"rspamd_global_filters_agree": "Budu opatrný!",
|
||||||
"rspamd_global_filters_info": "Mapa globálních filtrů obsahuje jiné globální black- a whitelisty.",
|
"rspamd_global_filters_info": "Mapa globálních filtrů obsahuje jiné globální black- a whitelisty.",
|
||||||
|
@@ -276,7 +276,7 @@
|
|||||||
"rsettings_preset_1": "Deaktiver alt undtagen DKIM og satsgrænse for godkendte brugere",
|
"rsettings_preset_1": "Deaktiver alt undtagen DKIM og satsgrænse for godkendte brugere",
|
||||||
"rsettings_preset_2": "Postmestere ønsker spam",
|
"rsettings_preset_2": "Postmestere ønsker spam",
|
||||||
"rsettings_preset_3": "Tillad kun specifikke afsendere til en postkasse (dvs. kun brug som intern postkasse)",
|
"rsettings_preset_3": "Tillad kun specifikke afsendere til en postkasse (dvs. kun brug som intern postkasse)",
|
||||||
"rspamd-com_settings": "Et indstillingsnavn genereres automatisk, se eksemplet på forudindstillinger nedenfor. For flere detaljer se <a href=\"https://rspamd.com/doc/configuration/settings.html#settings-structure\" target=\"_blank\">Rspamd docs</a>",
|
"rspamd_com_settings": "Et indstillingsnavn genereres automatisk, se eksemplet på forudindstillinger nedenfor. For flere detaljer se <a href=\"https://rspamd.com/doc/configuration/settings.html#settings-structure\" target=\"_blank\">Rspamd docs</a>",
|
||||||
"rspamd_global_filters": "Globale filterkort",
|
"rspamd_global_filters": "Globale filterkort",
|
||||||
"rspamd_global_filters_agree": "Jeg vil være forsigtig!",
|
"rspamd_global_filters_agree": "Jeg vil være forsigtig!",
|
||||||
"rspamd_global_filters_info": "Global filter maps contain different kind of global black and whitelists.",
|
"rspamd_global_filters_info": "Global filter maps contain different kind of global black and whitelists.",
|
||||||
|
@@ -106,7 +106,8 @@
|
|||||||
"timeout2": "Timeout für Verbindung zum lokalen Host",
|
"timeout2": "Timeout für Verbindung zum lokalen Host",
|
||||||
"username": "Benutzername",
|
"username": "Benutzername",
|
||||||
"validate": "Validieren",
|
"validate": "Validieren",
|
||||||
"validation_success": "Erfolgreich validiert"
|
"validation_success": "Erfolgreich validiert",
|
||||||
|
"tags": "Tags"
|
||||||
},
|
},
|
||||||
"admin": {
|
"admin": {
|
||||||
"access": "Zugang",
|
"access": "Zugang",
|
||||||
@@ -295,7 +296,7 @@
|
|||||||
"rsettings_preset_2": "Spam an Postmaster-Adressen nicht blockieren",
|
"rsettings_preset_2": "Spam an Postmaster-Adressen nicht blockieren",
|
||||||
"rsettings_preset_3": "Nur einem oder vielen Absendern erlauben, eine Mailbox anzuschreiben (etwa interne Mailboxen)",
|
"rsettings_preset_3": "Nur einem oder vielen Absendern erlauben, eine Mailbox anzuschreiben (etwa interne Mailboxen)",
|
||||||
"rsettings_preset_4": "Rspamd für eine Domain deaktivieren",
|
"rsettings_preset_4": "Rspamd für eine Domain deaktivieren",
|
||||||
"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_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": "Globale Filter-Maps",
|
||||||
"rspamd_global_filters_agree": "Ich werde vorsichtig sein!",
|
"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_info": "Globale Filter-Maps steuern globales White- und Blacklisting dieses Servers.",
|
||||||
@@ -920,6 +921,7 @@
|
|||||||
"deleted_syncjob": "Sync-Jobs-ID %s gelöscht",
|
"deleted_syncjob": "Sync-Jobs-ID %s gelöscht",
|
||||||
"deleted_syncjobs": "Sync-Jobs gelöscht: %s",
|
"deleted_syncjobs": "Sync-Jobs gelöscht: %s",
|
||||||
"dkim_added": "DKIM-Key %s wurde hinzugefügt",
|
"dkim_added": "DKIM-Key %s wurde hinzugefügt",
|
||||||
|
"domain_add_dkim_available": "Ein DKIM-Key existierte bereits",
|
||||||
"dkim_duplicated": "DKIM-Key der Domain %s wurde auf Domain %s kopiert",
|
"dkim_duplicated": "DKIM-Key der Domain %s wurde auf Domain %s kopiert",
|
||||||
"dkim_removed": "DKIM-Key %s wurde entfernt",
|
"dkim_removed": "DKIM-Key %s wurde entfernt",
|
||||||
"domain_added": "Domain %s wurde angelegt",
|
"domain_added": "Domain %s wurde angelegt",
|
||||||
|
@@ -99,6 +99,7 @@
|
|||||||
"subscribeall": "Subscribe all folders",
|
"subscribeall": "Subscribe all folders",
|
||||||
"syncjob": "Add sync job",
|
"syncjob": "Add sync job",
|
||||||
"syncjob_hint": "Be aware that passwords need to be saved plain-text!",
|
"syncjob_hint": "Be aware that passwords need to be saved plain-text!",
|
||||||
|
"tags": "Tags",
|
||||||
"target_address": "Goto addresses",
|
"target_address": "Goto addresses",
|
||||||
"target_address_info": "<small>Full email address/es (comma-separated).</small>",
|
"target_address_info": "<small>Full email address/es (comma-separated).</small>",
|
||||||
"target_domain": "Target domain",
|
"target_domain": "Target domain",
|
||||||
@@ -299,7 +300,7 @@
|
|||||||
"rsettings_preset_2": "Postmasters want spam",
|
"rsettings_preset_2": "Postmasters want spam",
|
||||||
"rsettings_preset_3": "Only allow specific senders for a mailbox (i.e. usage as internal mailbox only)",
|
"rsettings_preset_3": "Only allow specific senders for a mailbox (i.e. usage as internal mailbox only)",
|
||||||
"rsettings_preset_4": "Disable Rspamd for a domain",
|
"rsettings_preset_4": "Disable Rspamd for a domain",
|
||||||
"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_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": "Global filter maps",
|
||||||
"rspamd_global_filters_agree": "I will be careful!",
|
"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_info": "Global filter maps contain different kind of global black and whitelists.",
|
||||||
@@ -927,6 +928,7 @@
|
|||||||
"deleted_syncjob": "Deleted syncjob ID %s",
|
"deleted_syncjob": "Deleted syncjob ID %s",
|
||||||
"deleted_syncjobs": "Deleted syncjobs: %s",
|
"deleted_syncjobs": "Deleted syncjobs: %s",
|
||||||
"dkim_added": "DKIM key %s has been saved",
|
"dkim_added": "DKIM key %s has been saved",
|
||||||
|
"domain_add_dkim_available": "A DKIM key did already exist",
|
||||||
"dkim_duplicated": "DKIM key for domain %s has been copied to %s",
|
"dkim_duplicated": "DKIM key for domain %s has been copied to %s",
|
||||||
"dkim_removed": "DKIM key %s has been removed",
|
"dkim_removed": "DKIM key %s has been removed",
|
||||||
"domain_added": "Added domain %s",
|
"domain_added": "Added domain %s",
|
||||||
@@ -1133,7 +1135,7 @@
|
|||||||
"spamfilter_table_remove": "remove",
|
"spamfilter_table_remove": "remove",
|
||||||
"spamfilter_table_rule": "Rule",
|
"spamfilter_table_rule": "Rule",
|
||||||
"spamfilter_wl": "Whitelist",
|
"spamfilter_wl": "Whitelist",
|
||||||
"spamfilter_wl_desc": "Whitelisted email addresses 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_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_yellow": "Yellow: this message may be spam, will be tagged as spam and moved to your junk folder",
|
"spamfilter_yellow": "Yellow: this message may be spam, will be tagged as spam and moved to your junk folder",
|
||||||
"status": "Status",
|
"status": "Status",
|
||||||
"sync_jobs": "Sync jobs",
|
"sync_jobs": "Sync jobs",
|
||||||
|
@@ -224,7 +224,7 @@
|
|||||||
"rsettings_insert_preset": "Insertar ejemplo preestablecido \"%s\"",
|
"rsettings_insert_preset": "Insertar ejemplo preestablecido \"%s\"",
|
||||||
"rsettings_preset_1": "Deshabilita todos menos DKIM y el límite de velocidad para usuarios autenticados",
|
"rsettings_preset_1": "Deshabilita todos menos DKIM y el límite de velocidad para usuarios autenticados",
|
||||||
"rsettings_preset_2": "Postmaster quiere correo no deseado",
|
"rsettings_preset_2": "Postmaster quiere correo no deseado",
|
||||||
"rspamd-com_settings": "<a href=\"https://rspamd.com/doc/configuration/settings.html#settings-structure\" target=\"_blank\">Documentación de Rspamd</a>\r\n - Se generará automáticamente un nombre de configuración, consulte los ajustes preestablecidos de ejemplo a continuación:",
|
"rspamd_com_settings": "<a href=\"https://rspamd.com/doc/configuration/settings.html#settings-structure\" target=\"_blank\">Documentación de Rspamd</a>\r\n - Se generará automáticamente un nombre de configuración, consulte los ajustes preestablecidos de ejemplo a continuación:",
|
||||||
"rspamd_settings_map": "Reglas de ajustes de rspamd",
|
"rspamd_settings_map": "Reglas de ajustes de rspamd",
|
||||||
"save": "Guardar cambios",
|
"save": "Guardar cambios",
|
||||||
"search_domain_da": "Buscar dominios",
|
"search_domain_da": "Buscar dominios",
|
||||||
|
@@ -250,7 +250,7 @@
|
|||||||
"rsettings_insert_preset": "Lisää esimerkki esimääritetty \"%s\"",
|
"rsettings_insert_preset": "Lisää esimerkki esimääritetty \"%s\"",
|
||||||
"rsettings_preset_1": "Poista käytöstä kaikki paitsi DKIM-ja Rate Limit-oikeudet todennetuille käyttäjille",
|
"rsettings_preset_1": "Poista käytöstä kaikki paitsi DKIM-ja Rate Limit-oikeudet todennetuille käyttäjille",
|
||||||
"rsettings_preset_2": "Postimaisteri haluaa roska postia",
|
"rsettings_preset_2": "Postimaisteri haluaa roska postia",
|
||||||
"rspamd-com_settings": "<a href=\"https://rspamd.com/doc/configuration/settings.html#settings-structure\" target=\"_blank\">Rspamd docs</a>\r\n - Asetus nimi luodaan automaattisesti, Katso esimerkki esiasetukset alla.",
|
"rspamd_com_settings": "<a href=\"https://rspamd.com/doc/configuration/settings.html#settings-structure\" target=\"_blank\">Rspamd docs</a>\r\n - Asetus nimi luodaan automaattisesti, Katso esimerkki esiasetukset alla.",
|
||||||
"rspamd_settings_map": "Rspamd-asetukset",
|
"rspamd_settings_map": "Rspamd-asetukset",
|
||||||
"save": "Tallenna muutokset",
|
"save": "Tallenna muutokset",
|
||||||
"search_domain_da": "Etsi verkko tunnuksia",
|
"search_domain_da": "Etsi verkko tunnuksia",
|
||||||
|
@@ -136,11 +136,11 @@
|
|||||||
"arrival_time": "Heure d'arrivée (heure du serveur)",
|
"arrival_time": "Heure d'arrivée (heure du serveur)",
|
||||||
"authed_user": "Utilisateur autorisé",
|
"authed_user": "Utilisateur autorisé",
|
||||||
"ays": "Voulez-vous vraiment le faire ?",
|
"ays": "Voulez-vous vraiment le faire ?",
|
||||||
"ban_list_info": "Consultez la liste des adresses IP interdites ci-dessous: <b>réseau (durée d'interdiction restante) - [actions]</b>.<br />Les adresses IP mises en file d'attente pour être interdites seront supprimées de la liste d'interdiction active dans quelques secondes.<br />Les étiquettes rouges indiquent des interdictions permanentes actives par liste noire.",
|
"ban_list_info": "Consultez la liste des adresses IP bannies ci-dessous : <b>réseau (durée de bannissement restante) - [actions]</b>.<br />Les adresses IP mises en file d'attente pour être dé-bannies seront supprimées de la liste de bannissement dans quelques secondes.<br />Les étiquettes rouges indiquent les bannissement permanent par liste noire.",
|
||||||
"change_logo": "Changer de logo",
|
"change_logo": "Changer de logo",
|
||||||
"configuration": "Configuration",
|
"configuration": "Configuration",
|
||||||
"convert_html_to_text": "Convertir le code HTML en texte brut",
|
"convert_html_to_text": "Convertir le code HTML en texte brut",
|
||||||
"credentials_transport_warning": "<b>Attention</b>: L’ajout d’une nouvelle entrée de carte de transport mettra à jour les informations d’identification pour toutes les entrées avec une colonne nexthop correspondante.",
|
"credentials_transport_warning": "<b>Attention</b> : L’ajout d’une nouvelle entrée de carte de transport mettra à jour les informations d’identification pour toutes les entrées avec une colonne nexthop.",
|
||||||
"customer_id": "ID client",
|
"customer_id": "ID client",
|
||||||
"customize": "Personnaliser",
|
"customize": "Personnaliser",
|
||||||
"delete_queue": "Tout supprimer",
|
"delete_queue": "Tout supprimer",
|
||||||
@@ -176,7 +176,7 @@
|
|||||||
"f2b_netban_ipv4": "Taille du sous-réseau IPv4 pour l'application du bannissement (8-32)",
|
"f2b_netban_ipv4": "Taille du sous-réseau IPv4 pour l'application du bannissement (8-32)",
|
||||||
"f2b_netban_ipv6": "Taille du sous-réseau IPv6 pour l'application du bannissement (8-128)",
|
"f2b_netban_ipv6": "Taille du sous-réseau IPv6 pour l'application du bannissement (8-128)",
|
||||||
"f2b_parameters": "Paramètres Fail2ban",
|
"f2b_parameters": "Paramètres Fail2ban",
|
||||||
"f2b_regex_info": "Logs pris en compte: SOGo, Postfix, Dovecot, PHP-FPM.",
|
"f2b_regex_info": "Logs pris en compte : SOGo, Postfix, Dovecot, PHP-FPM.",
|
||||||
"f2b_retry_window": "Fenêtre de nouvel essai pour le nb max. de tentatives",
|
"f2b_retry_window": "Fenêtre de nouvel essai pour le nb max. de tentatives",
|
||||||
"f2b_whitelist": "Réseaux/hôtes en liste blanche",
|
"f2b_whitelist": "Réseaux/hôtes en liste blanche",
|
||||||
"filter_table": "Table de filtrage",
|
"filter_table": "Table de filtrage",
|
||||||
@@ -216,7 +216,7 @@
|
|||||||
"no_record": "Aucun enregistrement",
|
"no_record": "Aucun enregistrement",
|
||||||
"oauth2_client_id": "Client ID",
|
"oauth2_client_id": "Client ID",
|
||||||
"oauth2_client_secret": "Secret client",
|
"oauth2_client_secret": "Secret client",
|
||||||
"oauth2_info": "L'implémentation OAuth2 prend en charge le type d'autorisation \"Authorization Code\" et émet des jetons d'actualisation.<br>\r\nLe serveur émet également automatiquement de nouveaux jetons d'actualisation, après qu'un jeton d'actualisation a été utilisé.<br><br>\r\n→ La portée par défaut est <i>profile</i>. Seuls les utilisateurs de boîte peuvent être authentifiés par rapport à OAuth2. Si le paramètre scope est omis, il revient au <i>profile</i>.<br>\r\n→ Le paramètre <i>state</i> doit être envoyé par le client dans le cadre de la demande d'autorisation.<br><br>\r\nChemins d'accès aux requêtes vers l'API OAuth <br>\r\n<ul>\r\n <li>Point de terminaison d'autorisation: <code>/oauth/authorize</code></li>\r\n <li>Point de terminaison du jeton: <code>/oauth/token</code></li>\r\n <li>Page de ressource: <code>/oauth/profile</code></li>\r\n</ul>\r\nLa régénération du secret client n'expirera pas les codes d'autorisation existants, mais ils ne renouvelleront pas leur jeton.<br><br>\r\nLa révocation des jetons clients entraînera la fin immédiate de toutes les sessions actives.\nTous les clients doivent se ré-authentifier.",
|
"oauth2_info": "L'implémentation OAuth2 prend en charge le type d'autorisation \"Authorization Code\" et émet des jetons d'actualisation.<br>\nLe serveur émet également automatiquement de nouveaux jetons d'actualisation, après qu'un jeton d'actualisation a été utilisé.<br><br>\n→ La portée par défaut est <i>profile</i>. Seuls les utilisateurs d'une boîte peuvent être authentifiés par rapport à OAuth2. Si le paramètre scope est omis, il revient au <i>profile</i>.<br>\n→ Le paramètre <i>state</i> doit être envoyé par le client dans le cadre de la demande d'autorisation.<br><br>\nChemins d'accès aux requêtes vers l'API OAuth <br>\n<ul>\n <li>Point de terminaison d'autorisation : <code>/oauth/authorize</code></li>\n <li>Point de terminaison du jeton : <code>/oauth/token</code></li>\n <li>Page de ressource : <code>/oauth/profile</code></li>\n</ul>\nLa régénération du secret client ne fera pas expirer les codes d'autorisation existants, mais ils ne pourront pas renouveler leur jeton.<br><br>\nLa révocation des jetons clients entraînera la fin immédiate de toutes les sessions actives. Tous les clients doivent se ré-authentifier.",
|
||||||
"oauth2_redirect_uri": "URI de redirection",
|
"oauth2_redirect_uri": "URI de redirection",
|
||||||
"oauth2_renew_secret": "Générer un nouveau secret client",
|
"oauth2_renew_secret": "Générer un nouveau secret client",
|
||||||
"oauth2_revoke_tokens": "Révoquer tous les jetons",
|
"oauth2_revoke_tokens": "Révoquer tous les jetons",
|
||||||
@@ -230,7 +230,7 @@
|
|||||||
"quarantine_exclude_domains": "Exclure les domaines et les alias de domaine",
|
"quarantine_exclude_domains": "Exclure les domaines et les alias de domaine",
|
||||||
"quarantine_max_age": "Âge maximun en jour(s)<br><small>La valeur doit être égale ou supérieure à 1 jour.</small>",
|
"quarantine_max_age": "Âge maximun en jour(s)<br><small>La valeur doit être égale ou supérieure à 1 jour.</small>",
|
||||||
"quarantine_max_size": "Taille maximum en Mo (les éléments plus grands sont mis au rebut):<br><small>0 ne signifie <b>pas</b> illimité.</small>",
|
"quarantine_max_size": "Taille maximum en Mo (les éléments plus grands sont mis au rebut):<br><small>0 ne signifie <b>pas</b> illimité.</small>",
|
||||||
"quarantine_max_score": "Ignorer la notification si le score de spam est au dessus de cette valeur:<br><small>Par défaut: 9999.0</small>",
|
"quarantine_max_score": "Ignorer la notification si le score de spam est au dessus de cette valeur :<br><small>Par défaut : 9999.0</small>",
|
||||||
"quarantine_notification_html": "Modèle de courriel de notification:<br><small>Laisser vide pour restaurer le modèle par défaut.</small>",
|
"quarantine_notification_html": "Modèle de courriel de notification:<br><small>Laisser vide pour restaurer le modèle par défaut.</small>",
|
||||||
"quarantine_notification_sender": "Notification par e-mail de l’expéditeur",
|
"quarantine_notification_sender": "Notification par e-mail de l’expéditeur",
|
||||||
"quarantine_notification_subject": "Objet du courriel de notification",
|
"quarantine_notification_subject": "Objet du courriel de notification",
|
||||||
@@ -262,8 +262,8 @@
|
|||||||
"regex_maps": "Cartes Regex (expression régulière)",
|
"regex_maps": "Cartes Regex (expression régulière)",
|
||||||
"relay_from": "\"De:\" adresse",
|
"relay_from": "\"De:\" adresse",
|
||||||
"relay_run": "Lancer le test",
|
"relay_run": "Lancer le test",
|
||||||
"relayhosts": "Transports de l’expéditeur",
|
"relayhosts": "Transports dépendant de l’expéditeur",
|
||||||
"relayhosts_hint": "Définir les transports dépendant de l’expéditeur pour pouvoir les sélectionner dans un dialogue de configuration de domaines.<br>\r\n Le service de transport est toujours \"SMTP:\" et va donc essayer TLS (lorsqu’il est proposé. Le TLS encapsulé (SMTPS) n’est pas pris en charge. Il est tenu compte de la définition de la politique TLS pour chaque utilisateur sortant.<br>\r\n Affecte les domaines sélectionnés, y compris les domaines alias.",
|
"relayhosts_hint": "Définir les transports dépendant de l’expéditeur pour pouvoir les sélectionner dans un dialogue de configuration de domaines.<br>\n Le service de transport est toujours \"SMTP:\" et va donc essayer TLS lorsqu’il est proposé. Le TLS encapsulé (SMTPS) n’est pas pris en charge. Il est tenu compte de la définition de la politique TLS pour chaque utilisateur sortant.<br>\n Affecte les domaines sélectionnés, y compris les domaines alias.",
|
||||||
"remove": "Supprimer",
|
"remove": "Supprimer",
|
||||||
"remove_row": "Supprimer la ligne",
|
"remove_row": "Supprimer la ligne",
|
||||||
"reset_default": "Réinitialisation à la valeur par défaut",
|
"reset_default": "Réinitialisation à la valeur par défaut",
|
||||||
@@ -278,7 +278,7 @@
|
|||||||
"rsettings_preset_1": "Désactiver tout sauf DKIM et la limite tarifaire pour les utilisateurs authentifiés",
|
"rsettings_preset_1": "Désactiver tout sauf DKIM et la limite tarifaire pour les utilisateurs authentifiés",
|
||||||
"rsettings_preset_2": "Les postmasters veulent du spam",
|
"rsettings_preset_2": "Les postmasters veulent du spam",
|
||||||
"rsettings_preset_3": "Autoriser uniquement des expéditeurs particuliers pour une boîte (c.-à-d. utilisation comme boîte interne seulement)",
|
"rsettings_preset_3": "Autoriser uniquement des expéditeurs particuliers pour une boîte (c.-à-d. utilisation comme boîte interne seulement)",
|
||||||
"rspamd-com_settings": "Un nom de paramètre sera généré automatiquement, voir l’exemple de préréglages ci-dessous. Pour plus de détails voir : <a href=\"https://rspamd.com/doc/configuration/settings.html#settings-structure\" target=\"_blank\">Docs Rspamd</a>",
|
"rspamd_com_settings": "Un nom de paramètre sera généré automatiquement, voir l’exemple de préréglages ci-dessous. Pour plus de détails voir : <a href=\"https://rspamd.com/doc/configuration/settings.html#settings-structure\" target=\"_blank\">Docs Rspamd</a>",
|
||||||
"rspamd_global_filters": "Cartes des filtres globaux",
|
"rspamd_global_filters": "Cartes des filtres globaux",
|
||||||
"rspamd_global_filters_agree": "Je serai prudent !",
|
"rspamd_global_filters_agree": "Je serai prudent !",
|
||||||
"rspamd_global_filters_info": "Les cartes de filtres globales contiennent différents types de listes noires et blanches globales.",
|
"rspamd_global_filters_info": "Les cartes de filtres globales contiennent différents types de listes noires et blanches globales.",
|
||||||
@@ -299,9 +299,9 @@
|
|||||||
"title": "Titre",
|
"title": "Titre",
|
||||||
"title_name": "\"mailcow UI\" titre du site web",
|
"title_name": "\"mailcow UI\" titre du site web",
|
||||||
"to_top": "Retour en haut",
|
"to_top": "Retour en haut",
|
||||||
"transport_dest_format": "Syntaxe: example.org, .example.org, *, box@example.org (les valeurs multiples peuvent être séparées par des virgules)",
|
"transport_dest_format": "Syntaxe : example.org, .example.org, *, box@example.org (les valeurs multiples peuvent être séparées par des virgules)",
|
||||||
"transport_maps": "Plans de transport",
|
"transport_maps": "Plans de transport",
|
||||||
"transports_hint": "→ Une entrée de carte de transport <b>annule</b> une carte de transport dépendante de l’expéditeur</b>.<br>\r\n→ Les paramètres de politique TLS sortants par utilisateur sont ignorés et ne peuvent être appliqués que par les entrées de carte de politique TLS.<br>\r\n→ Le service de transport pour des transports définis est toujours \"smtp:\" et va donc essayer TLS lorsqu’il est offert. Wrapped TLS (SMTPS) n’est pas pris en charge.<br>\r\n→ Les adresses correspondantes \"/localhost$/\" seront toujours transportées via \"local:\", donc une destination \"*\" ne s'applique pas à ces adresses.<br>\r\n→ Pour déterminer les compétences dans l'exemple suivant \"[host]:25\", Postfix demande <b>toujours</b> pour \"host\" avant de chercher \"[host]:25\". Ce comportement rend impossible l’utilisation \"host\" et \"[host]:25\" en même temps.",
|
"transports_hint": "→ Une entrée de carte de transport <b>annule</b> une carte de transport dépendante de l’expéditeur</b>.<br>\n→ Les transports basés sur le MX sont préférables.<br>\n→ Les paramètres de politique TLS sortants par utilisateur sont ignorés et ne peuvent être appliqués que par les entrées de carte de politique TLS.<br>\n→ Pour chaque transports défini, le servie de transports sera \"smtp:\", TLS sera essayé lorsque disponible. Le Wrapped TLS (SMTPS) n’est pas pris en charge.<br>\n→ Les adresses qui correspondent à\"/localhost$/\" seront toujours transportées via \"local:\", donc une destination \"*\" ne s'applique pas à ces adresses.<br>\n→ Pour déterminer les informations d'identification dans l'exemple suivant \"[host]:25\", Postfix va <b>toujours</b> faire une requête pour \"host\" avant de chercher \"[host]:25\". Ce comportement rend impossible l’utilisation \"host\" et \"[host]:25\" en même temps.",
|
||||||
"ui_footer": "Pied de page (HTML autorisé)",
|
"ui_footer": "Pied de page (HTML autorisé)",
|
||||||
"ui_header_announcement": "Annonces",
|
"ui_header_announcement": "Annonces",
|
||||||
"ui_header_announcement_active": "Définir l’annonce active",
|
"ui_header_announcement_active": "Définir l’annonce active",
|
||||||
@@ -319,7 +319,10 @@
|
|||||||
"username": "Nom d'utilisateur",
|
"username": "Nom d'utilisateur",
|
||||||
"validate_license_now": "Valider le GUID par rapport au serveur de licence",
|
"validate_license_now": "Valider le GUID par rapport au serveur de licence",
|
||||||
"verify": "Verifier",
|
"verify": "Verifier",
|
||||||
"yes": "✓"
|
"yes": "✓",
|
||||||
|
"api_read_write": "Accès Lecture-Écriture",
|
||||||
|
"oauth2_add_client": "Ajouter un client OAuth2",
|
||||||
|
"password_policy": "Politique de mots de passe"
|
||||||
},
|
},
|
||||||
"danger": {
|
"danger": {
|
||||||
"access_denied": "Accès refusé ou données de formulaire non valides",
|
"access_denied": "Accès refusé ou données de formulaire non valides",
|
||||||
@@ -327,7 +330,7 @@
|
|||||||
"alias_empty": "L'alias d'adresse ne peut pas être vide",
|
"alias_empty": "L'alias d'adresse ne peut pas être vide",
|
||||||
"alias_goto_identical": "L’alias et l’adresse Goto ne doivent pas être identiques",
|
"alias_goto_identical": "L’alias et l’adresse Goto ne doivent pas être identiques",
|
||||||
"alias_invalid": "L'alias d'adresse %s est non valide",
|
"alias_invalid": "L'alias d'adresse %s est non valide",
|
||||||
"aliasd_targetd_identical": "Le domaine alias ne doit pas être égal au domaine cible: %s",
|
"aliasd_targetd_identical": "Le domaine alias ne doit pas être égal au domaine cible : %s",
|
||||||
"aliases_in_use": "Max. alias doit être supérieur ou égal à %d",
|
"aliases_in_use": "Max. alias doit être supérieur ou égal à %d",
|
||||||
"app_name_empty": "Le nom de l'application ne peut pas être vide",
|
"app_name_empty": "Le nom de l'application ne peut pas être vide",
|
||||||
"app_passwd_id_invalid": "Le mot de passe ID %s de l'application est non valide",
|
"app_passwd_id_invalid": "Le mot de passe ID %s de l'application est non valide",
|
||||||
@@ -338,7 +341,7 @@
|
|||||||
"defquota_empty": "Le quota par défaut par boîte ne doit pas être 0.",
|
"defquota_empty": "Le quota par défaut par boîte ne doit pas être 0.",
|
||||||
"description_invalid": "La description des ressources pour %s est non valide",
|
"description_invalid": "La description des ressources pour %s est non valide",
|
||||||
"dkim_domain_or_sel_exists": "Une clé DKIM pour \"%s\" existe et ne sera pas écrasée",
|
"dkim_domain_or_sel_exists": "Une clé DKIM pour \"%s\" existe et ne sera pas écrasée",
|
||||||
"dkim_domain_or_sel_invalid": "Domaine ou sélection DKIM non valide: %s",
|
"dkim_domain_or_sel_invalid": "Domaine ou sélection DKIM non valide : %s",
|
||||||
"domain_cannot_match_hostname": "Le domaine ne correspond pas au nom d’hôte",
|
"domain_cannot_match_hostname": "Le domaine ne correspond pas au nom d’hôte",
|
||||||
"domain_exists": "Le domaine %s exite déjà",
|
"domain_exists": "Le domaine %s exite déjà",
|
||||||
"domain_invalid": "Le mom de domaine est vide ou non valide",
|
"domain_invalid": "Le mom de domaine est vide ou non valide",
|
||||||
@@ -350,24 +353,24 @@
|
|||||||
"file_open_error": "Le fichier ne peut pas être ouvert pour l'écriture",
|
"file_open_error": "Le fichier ne peut pas être ouvert pour l'écriture",
|
||||||
"filter_type": "Type de fltre erroné",
|
"filter_type": "Type de fltre erroné",
|
||||||
"from_invalid": "Expéditeur ne peut pas être vide",
|
"from_invalid": "Expéditeur ne peut pas être vide",
|
||||||
"global_filter_write_error": "Impossible d’écrire le fichier de filtre: %s",
|
"global_filter_write_error": "Impossible d’écrire le fichier de filtre : %s",
|
||||||
"global_map_invalid": "ID de carte globale %s non valide",
|
"global_map_invalid": "ID de carte globale %s non valide",
|
||||||
"global_map_write_error": "Impossible d’écrire l’ID de la carte globale %s: %s",
|
"global_map_write_error": "Impossible d’écrire l’ID de la carte globale %s : %s",
|
||||||
"goto_empty": "Une adresse alias doit contenir au moins une adresse 'goto'valide",
|
"goto_empty": "Une adresse alias doit contenir au moins une adresse 'goto'valide",
|
||||||
"goto_invalid": "Adresse Goto %s non valide",
|
"goto_invalid": "Adresse Goto %s non valide",
|
||||||
"ham_learn_error": "Erreur d'apprentissage Ham: %s",
|
"ham_learn_error": "Erreur d'apprentissage Ham : %s",
|
||||||
"imagick_exception": "Erreur : Exception Imagick lors de la lecture de l’image",
|
"imagick_exception": "Erreur : Exception Imagick lors de la lecture de l’image",
|
||||||
"img_invalid": "Impossible de valider le fichier image",
|
"img_invalid": "Impossible de valider le fichier image",
|
||||||
"img_tmp_missing": "Impossible de valider le fichier image: Fichier temporaire introuvable",
|
"img_tmp_missing": "Impossible de valider le fichier image : Fichier temporaire introuvable",
|
||||||
"invalid_bcc_map_type": "Type de carte BCC non valide",
|
"invalid_bcc_map_type": "Type de carte BCC non valide",
|
||||||
"invalid_destination": "Le format de la destination \"%s\" est non valide",
|
"invalid_destination": "Le format de la destination \"%s\" est non valide",
|
||||||
"invalid_filter_type": "Type de filtre non valide",
|
"invalid_filter_type": "Type de filtre non valide",
|
||||||
"invalid_host": "Hôte non valide spécifié: %s",
|
"invalid_host": "Hôte non valide spécifié : %s",
|
||||||
"invalid_mime_type": "Type mime non valide",
|
"invalid_mime_type": "Type mime non valide",
|
||||||
"invalid_nexthop": "Le format de saut suivant est non valide",
|
"invalid_nexthop": "Le format de saut suivant est non valide",
|
||||||
"invalid_nexthop_authenticated": "Next hop existe avec différents identifiants, veuillez d’abord mettre à jour les identifiants existants pour ce prochain saut.",
|
"invalid_nexthop_authenticated": "Next hop existe avec différents identifiants, veuillez d’abord mettre à jour les identifiants existants pour ce prochain saut.",
|
||||||
"invalid_recipient_map_new": "Nouveau destinataire précisé non valide: %s",
|
"invalid_recipient_map_new": "Nouveau destinataire spécifié non valide : %s",
|
||||||
"invalid_recipient_map_old": "Destinataire original précisé non valide: %s",
|
"invalid_recipient_map_old": "Destinataire original spécifié non valide : %s",
|
||||||
"ip_list_empty": "La liste des adresses IP autorisées ne peut pas être vide",
|
"ip_list_empty": "La liste des adresses IP autorisées ne peut pas être vide",
|
||||||
"is_alias": "%s est déjà connu comme une adresse alias",
|
"is_alias": "%s est déjà connu comme une adresse alias",
|
||||||
"is_alias_or_mailbox": "%s est déjà connu comme un alias, une boîte ou une adresse alias développée à partir d’un domaine alias.",
|
"is_alias_or_mailbox": "%s est déjà connu comme un alias, une boîte ou une adresse alias développée à partir d’un domaine alias.",
|
||||||
@@ -378,7 +381,7 @@
|
|||||||
"mailbox_invalid": "Le nom de la boîte n'est pas valide",
|
"mailbox_invalid": "Le nom de la boîte n'est pas valide",
|
||||||
"mailbox_quota_exceeded": "Le quota dépasse la limite du domaine (max. %d Mo)",
|
"mailbox_quota_exceeded": "Le quota dépasse la limite du domaine (max. %d Mo)",
|
||||||
"mailbox_quota_exceeds_domain_quota": "Le quota maximum dépasse la limite du quota de domaine",
|
"mailbox_quota_exceeds_domain_quota": "Le quota maximum dépasse la limite du quota de domaine",
|
||||||
"mailbox_quota_left_exceeded": "Espace libre insuffisant (espace libre: %d Mo)",
|
"mailbox_quota_left_exceeded": "Espace libre insuffisant (espace libre : %d Mio)",
|
||||||
"mailboxes_in_use": "Le max. des boîtes doit être supérieur ou égal à %d",
|
"mailboxes_in_use": "Le max. des boîtes doit être supérieur ou égal à %d",
|
||||||
"malformed_username": "Nom d’utilisateur malformé",
|
"malformed_username": "Nom d’utilisateur malformé",
|
||||||
"map_content_empty": "Le contenu de la carte ne peut pas être vide",
|
"map_content_empty": "Le contenu de la carte ne peut pas être vide",
|
||||||
@@ -386,9 +389,9 @@
|
|||||||
"max_mailbox_exceeded": "Le nombre max. de boîte est dépassé (%d of %d)",
|
"max_mailbox_exceeded": "Le nombre max. de boîte est dépassé (%d of %d)",
|
||||||
"max_quota_in_use": "Le quota de la boîte doit être supérieur ou égal à %d Mo",
|
"max_quota_in_use": "Le quota de la boîte doit être supérieur ou égal à %d Mo",
|
||||||
"maxquota_empty": "Le quota maximum par boîte ne doit pas être de 0.",
|
"maxquota_empty": "Le quota maximum par boîte ne doit pas être de 0.",
|
||||||
"mysql_error": "Erreur MySQL: %s",
|
"mysql_error": "Erreur MySQL : %s",
|
||||||
"nginx_reload_failed": "Le rechargement de Nginx a échoué: %s",
|
"nginx_reload_failed": "Le rechargement de Nginx a échoué : %s",
|
||||||
"network_host_invalid": "Réseau ou host non valide: %s",
|
"network_host_invalid": "Réseau ou hôte non valide : %s",
|
||||||
"next_hop_interferes": "%s interfère avec le nexthop %s",
|
"next_hop_interferes": "%s interfère avec le nexthop %s",
|
||||||
"next_hop_interferes_any": "Un saut suivant existant interfère avec %s",
|
"next_hop_interferes_any": "Un saut suivant existant interfère avec %s",
|
||||||
"no_user_defined": "Aucun utilisateur défini",
|
"no_user_defined": "Aucun utilisateur défini",
|
||||||
@@ -399,15 +402,15 @@
|
|||||||
"password_mismatch": "Le mot de passe de confirmation ne correspond pas",
|
"password_mismatch": "Le mot de passe de confirmation ne correspond pas",
|
||||||
"policy_list_from_exists": "Un enregistrement avec ce nom existe déjà",
|
"policy_list_from_exists": "Un enregistrement avec ce nom existe déjà",
|
||||||
"policy_list_from_invalid": "Le format de l’enregistrement est invalide",
|
"policy_list_from_invalid": "Le format de l’enregistrement est invalide",
|
||||||
"private_key_error": "Erreur de clé privée: %s",
|
"private_key_error": "Erreur de clé privée : %s",
|
||||||
"pushover_credentials_missing": "Jeton Pushover ou clé manquante",
|
"pushover_credentials_missing": "Jeton Pushover ou clé manquante",
|
||||||
"pushover_key": "La clé Pushover a un mauvais format",
|
"pushover_key": "La clé Pushover a un mauvais format",
|
||||||
"pushover_token": "Le jeton Pushover a un mauvais format",
|
"pushover_token": "Le jeton Pushover a un mauvais format",
|
||||||
"quota_not_0_not_numeric": "Le quota doit être numerique et >= 0",
|
"quota_not_0_not_numeric": "Le quota doit être numerique et >= 0",
|
||||||
"recipient_map_entry_exists": "Une entrée dans la carte du bénéficiaire \"%s\" existe",
|
"recipient_map_entry_exists": "Une entrée dans la carte du bénéficiaire \"%s\" existe",
|
||||||
"redis_error": "Erreur Redis: %s",
|
"redis_error": "Erreur Redis : %s",
|
||||||
"relayhost_invalid": "La saisie de la carte %s est invalide",
|
"relayhost_invalid": "La saisie de la carte %s est invalide",
|
||||||
"release_send_failed": "Le message n’a pas pu être diffusé: %s",
|
"release_send_failed": "Le message n’a pas pu être diffusé : %s",
|
||||||
"reset_f2b_regex": "Le filtre regex n'a pas pu être réinitialisé à temps, veuillez réessayer ou attendre quelques secondes de plus et recharger le site web.",
|
"reset_f2b_regex": "Le filtre regex n'a pas pu être réinitialisé à temps, veuillez réessayer ou attendre quelques secondes de plus et recharger le site web.",
|
||||||
"resource_invalid": "Le nom de la resource %s n'est pas valide",
|
"resource_invalid": "Le nom de la resource %s n'est pas valide",
|
||||||
"rl_timeframe": "Le délai limite du taux est incorrect",
|
"rl_timeframe": "Le délai limite du taux est incorrect",
|
||||||
@@ -416,8 +419,8 @@
|
|||||||
"sender_acl_invalid": "La valeur ACL de l’expéditeur %s est invalide",
|
"sender_acl_invalid": "La valeur ACL de l’expéditeur %s est invalide",
|
||||||
"set_acl_failed": "Impossible de définir ACL",
|
"set_acl_failed": "Impossible de définir ACL",
|
||||||
"settings_map_invalid": "La carte des paramètres %s est invalide",
|
"settings_map_invalid": "La carte des paramètres %s est invalide",
|
||||||
"sieve_error": "Erreur d’analyseur de tamis: %s",
|
"sieve_error": "Erreur d'analyse syntaxique Sieve : %s",
|
||||||
"spam_learn_error": "Erreur d'apprentissage du spam: %s",
|
"spam_learn_error": "Erreur d'apprentissage du spam : %s",
|
||||||
"subject_empty": "Le sujet ne peut^pas être vide",
|
"subject_empty": "Le sujet ne peut^pas être vide",
|
||||||
"target_domain_invalid": "Le domaine cible %s n'est pas valide",
|
"target_domain_invalid": "Le domaine cible %s n'est pas valide",
|
||||||
"targetd_not_found": "Le domaine cible %s est introuvable",
|
"targetd_not_found": "Le domaine cible %s est introuvable",
|
||||||
@@ -430,15 +433,15 @@
|
|||||||
"tls_policy_map_parameter_invalid": "Le paramètre Policy est invalide",
|
"tls_policy_map_parameter_invalid": "Le paramètre Policy est invalide",
|
||||||
"totp_verification_failed": "Echec de la vérification TOTP",
|
"totp_verification_failed": "Echec de la vérification TOTP",
|
||||||
"transport_dest_exists": "La destination de transport \"%s\" existe",
|
"transport_dest_exists": "La destination de transport \"%s\" existe",
|
||||||
"webauthn_verification_failed": "Echec de la vérification WebAuthn: %s",
|
"webauthn_verification_failed": "Echec de la vérification WebAuthn : %s",
|
||||||
"fido2_verification_failed": "La vérification FIDO2 a échoué: %s",
|
"fido2_verification_failed": "La vérification FIDO2 a échoué : %s",
|
||||||
"unknown": "Une erreur inconnue est survenue",
|
"unknown": "Une erreur inconnue est survenue",
|
||||||
"unknown_tfa_method": "Methode TFA inconnue",
|
"unknown_tfa_method": "Methode TFA inconnue",
|
||||||
"unlimited_quota_acl": "Quota illimité interdit par les ACL",
|
"unlimited_quota_acl": "Quota illimité interdit par les ACL",
|
||||||
"username_invalid": "Le nom d'utilisateur %s ne peut pas être utilisé",
|
"username_invalid": "Le nom d'utilisateur %s ne peut pas être utilisé",
|
||||||
"validity_missing": "Veuillez attribuer une période de validité",
|
"validity_missing": "Veuillez attribuer une période de validité",
|
||||||
"value_missing": "Veuillez fournir toutes les valeurs",
|
"value_missing": "Veuillez fournir toutes les valeurs",
|
||||||
"yotp_verification_failed": "La vérification Yubico OTP a échoué: %s"
|
"yotp_verification_failed": "La vérification Yubico OTP a échoué : %s"
|
||||||
},
|
},
|
||||||
"debug": {
|
"debug": {
|
||||||
"chart_this_server": "Graphique (ce serveur)",
|
"chart_this_server": "Graphique (ce serveur)",
|
||||||
@@ -509,7 +512,7 @@
|
|||||||
"force_pw_update_info": "Cet utilisateur pourra uniquement se connecter à %s.",
|
"force_pw_update_info": "Cet utilisateur pourra uniquement se connecter à %s.",
|
||||||
"full_name": "Nom complet",
|
"full_name": "Nom complet",
|
||||||
"gal": "Liste d'adresses globale (GAL)",
|
"gal": "Liste d'adresses globale (GAL)",
|
||||||
"gal_info": "La liste d'adresses globale (GAL) contient tous les objets d’un domaine et ne peut pas être édité par un utilisateur. Les informations libres/occupées dans SOGo sont manquantes si elles sont désactivées! <b>Redémarrer SOGo pour appliquer les modifications.</b>",
|
"gal_info": "La liste d'adresses globale (GAL) contient tous les objets d’un domaine et ne peut pas être édité par un utilisateur. Les informations libres/occupées dans SOGo sont manquantes si elles sont désactivées ! <b>Redémarrer SOGo pour appliquer les modifications.</b>",
|
||||||
"generate": "générer",
|
"generate": "générer",
|
||||||
"grant_types": "Types 'autorisation",
|
"grant_types": "Types 'autorisation",
|
||||||
"hostname": "Nom d'hôte",
|
"hostname": "Nom d'hôte",
|
||||||
@@ -574,14 +577,16 @@
|
|||||||
"title": "Editer l'objet",
|
"title": "Editer l'objet",
|
||||||
"unchanged_if_empty": "Si non modifié, laisser en blanc",
|
"unchanged_if_empty": "Si non modifié, laisser en blanc",
|
||||||
"username": "Nom d'utilisateur",
|
"username": "Nom d'utilisateur",
|
||||||
"validate_save": "Valider et sauver"
|
"validate_save": "Valider et sauver",
|
||||||
|
"lookup_mx": "La destination est une expression régulière qui doit correspondre avec le nom du MX (<code>.*google\\.com</code> pour acheminer tout le courrier destiné à un MX se terminant par google.com via ce saut).",
|
||||||
|
"mailbox_relayhost_info": "S'applique uniquement à la boîte aux lettres et aux alias directs, remplace le relayhost du domaine."
|
||||||
},
|
},
|
||||||
"footer": {
|
"footer": {
|
||||||
"cancel": "Annuler",
|
"cancel": "Annuler",
|
||||||
"confirm_delete": "Confirmer la suppression",
|
"confirm_delete": "Confirmer la suppression",
|
||||||
"delete_now": "Effacer maintenant",
|
"delete_now": "Effacer maintenant",
|
||||||
"delete_these_items": "Veuillez confirmer les modifications apportées à l’identifiant d’objet suivant",
|
"delete_these_items": "Veuillez confirmer les modifications apportées à l’identifiant d’objet suivant",
|
||||||
"hibp_nok": "Trouvé! Il s’agit d’un mot de passe potentiellement dangereux!",
|
"hibp_nok": "Trouvé ! Il s’agit d’un mot de passe potentiellement dangereux !",
|
||||||
"hibp_ok": "Aucune correspondance trouvée.",
|
"hibp_ok": "Aucune correspondance trouvée.",
|
||||||
"loading": "Veuillez patienter...",
|
"loading": "Veuillez patienter...",
|
||||||
"restart_container": "Redémarrer le conteneur",
|
"restart_container": "Redémarrer le conteneur",
|
||||||
@@ -740,9 +745,9 @@
|
|||||||
"tls_enforce_in": "Appliquer le TLS entrant",
|
"tls_enforce_in": "Appliquer le TLS entrant",
|
||||||
"tls_enforce_out": "Appliquer le TLS sortant",
|
"tls_enforce_out": "Appliquer le TLS sortant",
|
||||||
"tls_map_dest": "Destination",
|
"tls_map_dest": "Destination",
|
||||||
"tls_map_dest_info": "Exemples: example.org, .example.org, [mail.example.org]:25",
|
"tls_map_dest_info": "Exemples : example.org, .example.org, [mail.example.org]:25",
|
||||||
"tls_map_parameters": "Paramètres",
|
"tls_map_parameters": "Paramètres",
|
||||||
"tls_map_parameters_info": "Vide ou paramètres, par exemple: protocols=!SSLv2 ciphers=medium exclude=3DES",
|
"tls_map_parameters_info": "Vide ou paramètres, par exemple : protocols=!SSLv2 ciphers=medium exclude=3DES",
|
||||||
"tls_map_policy": "Politique",
|
"tls_map_policy": "Politique",
|
||||||
"tls_policy_maps": "Cartes des politiques des TLS",
|
"tls_policy_maps": "Cartes des politiques des TLS",
|
||||||
"tls_policy_maps_info": "Cette carte de politique remplace les règles de transport TLS sortantes indépendamment des paramètres de politique TLS des utilisateurs.<br>\r\n Veuillez vérifier <a href=\"http://www.postfix.org/postconf.5.html#smtp_tls_policy_maps\" target=\"_blank\">la doc \"smtp_tls_policy_maps\" </a> pour plus d'informations.",
|
"tls_policy_maps_info": "Cette carte de politique remplace les règles de transport TLS sortantes indépendamment des paramètres de politique TLS des utilisateurs.<br>\r\n Veuillez vérifier <a href=\"http://www.postfix.org/postconf.5.html#smtp_tls_policy_maps\" target=\"_blank\">la doc \"smtp_tls_policy_maps\" </a> pour plus d'informations.",
|
||||||
@@ -756,8 +761,8 @@
|
|||||||
},
|
},
|
||||||
"oauth2": {
|
"oauth2": {
|
||||||
"access_denied": "Veuillez vous connecter en tant que propriétaire de la boîte pour accorder l’accès via Oauth2.",
|
"access_denied": "Veuillez vous connecter en tant que propriétaire de la boîte pour accorder l’accès via Oauth2.",
|
||||||
"authorize_app": "Authorize application",
|
"authorize_app": "Autoriser l'application",
|
||||||
"deny": "Deny",
|
"deny": "Refuser",
|
||||||
"permit": "Autorise l'application",
|
"permit": "Autorise l'application",
|
||||||
"profile": "Profil",
|
"profile": "Profil",
|
||||||
"profile_desc": "Afficher les informations personnelles : nom d’utilisateur, nom complet, créé, modifié, actif",
|
"profile_desc": "Afficher les informations personnelles : nom d’utilisateur, nom complet, créé, modifié, actif",
|
||||||
@@ -772,7 +777,7 @@
|
|||||||
"danger": "Danger",
|
"danger": "Danger",
|
||||||
"deliver_inbox": "Envoyer dans la boîte de reception",
|
"deliver_inbox": "Envoyer dans la boîte de reception",
|
||||||
"disabled_by_config": "La configuration actuelle du système désactive la fonctionnalité de quarantaine. Veuillez définir \"retentions par boîte\" et une \"taille maximum\" pour les éléments en quarantaine.",
|
"disabled_by_config": "La configuration actuelle du système désactive la fonctionnalité de quarantaine. Veuillez définir \"retentions par boîte\" et une \"taille maximum\" pour les éléments en quarantaine.",
|
||||||
"settings_info": "Quantité maximum d'éléments à mettre en quarantaine: %s<br>Taille maximale des e-mails: %s MiB",
|
"settings_info": "Quantité maximum d'éléments à mettre en quarantaine : %s<br>Taille maximale des e-mails : %s MiB",
|
||||||
"download_eml": "Télécharger (.eml)",
|
"download_eml": "Télécharger (.eml)",
|
||||||
"empty": "Pas de résultat",
|
"empty": "Pas de résultat",
|
||||||
"high_danger": "Haut",
|
"high_danger": "Haut",
|
||||||
@@ -819,7 +824,7 @@
|
|||||||
"start": {
|
"start": {
|
||||||
"help": "Afficher/masquer le panneau d’aide",
|
"help": "Afficher/masquer le panneau d’aide",
|
||||||
"imap_smtp_server_auth_info": "Veuillez utiliser votre adresse e-mail complète et le mécanisme d’authentification PLAIN.<br>\r\nVos données de connexion seront cryptées par le cryptage obligatoire côté serveur.",
|
"imap_smtp_server_auth_info": "Veuillez utiliser votre adresse e-mail complète et le mécanisme d’authentification PLAIN.<br>\r\nVos données de connexion seront cryptées par le cryptage obligatoire côté serveur.",
|
||||||
"mailcow_apps_detail": "Utiliser une application Maicow pour accéder à vos messages, calendrier, contacts et plus.",
|
"mailcow_apps_detail": "Utiliser une application mailcow pour accéder à vos messages, calendrier, contacts et plus.",
|
||||||
"mailcow_panel_detail": "<b>Les administrateurs de domaines</b> peuvent créer, modifier or supprimer des boîtes et alias, changer de domaines et lire de plus amples renseignements sur les domaines qui leurs sont attribués.<br>\r\n<b>Les utilisateurs de boîtes</b> sont en mesure de créer des alias limités dans le temps (alias spam), de modifier leurs mots de passe et les paramètres du filtre anti-spam."
|
"mailcow_panel_detail": "<b>Les administrateurs de domaines</b> peuvent créer, modifier or supprimer des boîtes et alias, changer de domaines et lire de plus amples renseignements sur les domaines qui leurs sont attribués.<br>\r\n<b>Les utilisateurs de boîtes</b> sont en mesure de créer des alias limités dans le temps (alias spam), de modifier leurs mots de passe et les paramètres du filtre anti-spam."
|
||||||
},
|
},
|
||||||
"success": {
|
"success": {
|
||||||
@@ -837,14 +842,14 @@
|
|||||||
"app_links": "Modifications enregistrées dans les liens d’application",
|
"app_links": "Modifications enregistrées dans les liens d’application",
|
||||||
"app_passwd_added": "Ajout d’un nouveau mot de passe d’application",
|
"app_passwd_added": "Ajout d’un nouveau mot de passe d’application",
|
||||||
"app_passwd_removed": "Suppression de l’identifiant du mot de passe de l’application %s",
|
"app_passwd_removed": "Suppression de l’identifiant du mot de passe de l’application %s",
|
||||||
"bcc_deleted": "Suppression des entrées de la carte BCC: %s",
|
"bcc_deleted": "Suppression des entrées de la carte BCC : %s",
|
||||||
"bcc_edited": "Entrée de la carte BCC %s modifiée",
|
"bcc_edited": "Entrée de la carte BCC %s modifiée",
|
||||||
"bcc_saved": "Saisie de carte BCC enregistrée",
|
"bcc_saved": "Saisie de carte BCC enregistrée",
|
||||||
"db_init_complete": "Initialisation de la base de données terminée",
|
"db_init_complete": "Initialisation de la base de données terminée",
|
||||||
"delete_filter": "ID des filtres supprimés %s",
|
"delete_filter": "ID des filtres supprimés %s",
|
||||||
"delete_filters": "Filtres supprimés: %s",
|
"delete_filters": "Filtres supprimés : %s",
|
||||||
"deleted_syncjob": "Job de synchronisation supprimé ID %s",
|
"deleted_syncjob": "ID du travail de synchronisation supprimé : %s",
|
||||||
"deleted_syncjobs": "Jobs de synchronisation supprimé: %s",
|
"deleted_syncjobs": "Travail de synchronisation supprimé : %s",
|
||||||
"dkim_added": "La clé DKIM %s a été sauvegardée",
|
"dkim_added": "La clé DKIM %s a été sauvegardée",
|
||||||
"dkim_duplicated": "La clé DKIM pour e domaine %s a été copiée vers %s",
|
"dkim_duplicated": "La clé DKIM pour e domaine %s a été copiée vers %s",
|
||||||
"dkim_removed": "La clé DKIM %s a été supprimée",
|
"dkim_removed": "La clé DKIM %s a été supprimée",
|
||||||
@@ -908,7 +913,7 @@
|
|||||||
"enter_qr_code": "Votre code TOTP si votre appareil ne peut pas scanner les codes QR",
|
"enter_qr_code": "Votre code TOTP si votre appareil ne peut pas scanner les codes QR",
|
||||||
"error_code": "Code d'erreur",
|
"error_code": "Code d'erreur",
|
||||||
"init_webauthn": "Initialisation, veuillez patienter...",
|
"init_webauthn": "Initialisation, veuillez patienter...",
|
||||||
"key_id": "Un identifiant pour votre Yubikey",
|
"key_id": "Un identifiant pour votre Périphérique",
|
||||||
"key_id_totp": "Un identifiant pour votre clé",
|
"key_id_totp": "Un identifiant pour votre clé",
|
||||||
"none": "Désactiver",
|
"none": "Désactiver",
|
||||||
"reload_retry": "- (recharger le navigateur si l’erreur persiste)",
|
"reload_retry": "- (recharger le navigateur si l’erreur persiste)",
|
||||||
@@ -969,7 +974,7 @@
|
|||||||
"direct_aliases": "Adresses alias directes",
|
"direct_aliases": "Adresses alias directes",
|
||||||
"direct_aliases_desc": "Les adresses d’alias directes sont affectées par le filtre anti-spam et les paramètres de politique TLS.",
|
"direct_aliases_desc": "Les adresses d’alias directes sont affectées par le filtre anti-spam et les paramètres de politique TLS.",
|
||||||
"eas_reset": "Réinitialiser le cache de l’appareil Activesync",
|
"eas_reset": "Réinitialiser le cache de l’appareil Activesync",
|
||||||
"eas_reset_help": "Dans de nombreux cas, une réinitialisation du cache de l’appareil aidera à récupérer un profil Activesync cassé.<br><b>Attention:</b> Tous les éléments seront à nouveau chargés!",
|
"eas_reset_help": "Dans de nombreux cas, une réinitialisation du cache de l’appareil aidera à récupérer un profil Activesync cassé.<br><b>Attention :</b> Tous les éléments seront à nouveau téléchargés !",
|
||||||
"eas_reset_now": "Réinitialiser maintenant",
|
"eas_reset_now": "Réinitialiser maintenant",
|
||||||
"edit": "Editer",
|
"edit": "Editer",
|
||||||
"email": "Email",
|
"email": "Email",
|
||||||
@@ -1033,9 +1038,9 @@
|
|||||||
"spamfilter_bl": "Liste noire (BlackList)",
|
"spamfilter_bl": "Liste noire (BlackList)",
|
||||||
"spamfilter_bl_desc": "Les adresses de courriel sur la liste noire de <b>always (toujours)</b> peuvent être classées comme des pourriels et rejetées. Des caractères génériques peuvent être utilisés. Un filtre n’est appliqué qu’aux alias directs (alias avec une seule boîte cible), à l’exclusion des alias tous azimuts et d’une boîte elle-même.",
|
"spamfilter_bl_desc": "Les adresses de courriel sur la liste noire de <b>always (toujours)</b> peuvent être classées comme des pourriels et rejetées. Des caractères génériques peuvent être utilisés. Un filtre n’est appliqué qu’aux alias directs (alias avec une seule boîte cible), à l’exclusion des alias tous azimuts et d’une boîte elle-même.",
|
||||||
"spamfilter_default_score": "Valeurs par défaut",
|
"spamfilter_default_score": "Valeurs par défaut",
|
||||||
"spamfilter_green": "Vert: ce message n'est pas un spam",
|
"spamfilter_green": "Vert : ce message n'est pas un spam",
|
||||||
"spamfilter_hint": "La première valeur indique un \"faible score de spam\", la seconde représente un \"haut score de spam\".",
|
"spamfilter_hint": "La première valeur indique un \"faible score de spam\", la seconde représente un \"haut score de spam\".",
|
||||||
"spamfilter_red": "Rouge: Ce message est un spam et sera rejeté par le serveur",
|
"spamfilter_red": "Rouge : Ce message est un spam et sera rejeté par le serveur",
|
||||||
"spamfilter_table_action": "Action",
|
"spamfilter_table_action": "Action",
|
||||||
"spamfilter_table_add": "Ajouter un élément",
|
"spamfilter_table_add": "Ajouter un élément",
|
||||||
"spamfilter_table_domain_policy": "n/a (politique de domaine)",
|
"spamfilter_table_domain_policy": "n/a (politique de domaine)",
|
||||||
@@ -1043,13 +1048,13 @@
|
|||||||
"spamfilter_table_remove": "supprimer",
|
"spamfilter_table_remove": "supprimer",
|
||||||
"spamfilter_table_rule": "Règle",
|
"spamfilter_table_rule": "Règle",
|
||||||
"spamfilter_wl": "Liste blanche (WhiteList)",
|
"spamfilter_wl": "Liste blanche (WhiteList)",
|
||||||
"spamfilter_wl_desc": "Liste blanche des adresses e-mail à <b> ne jamais</b> classer comme spam. Des caractères génériques peuvent être utilisés. Un filtre n’est appliqué qu’aux alias directs (alias avec une seule boîte cible), à l’exclusion des alias tous azimuts et d’une boîte elle-même.",
|
"spamfilter_wl_desc": "La liste blanche est programmé pour <b> ne jamais</b> classer comme spam les adresses e-mail qu'elle contient. Des caractères génériques peuvent être utilisés. Un filtre n’est appliqué qu’aux alias directs (alias avec une seule boîte cible), à l’exclusion des alias catch-all et d’une boîte mail.",
|
||||||
"spamfilter_yellow": "Jaune: ce message est peut être un spam, il sera étiqueté comme spam et déplacé vers votre dossier Junk",
|
"spamfilter_yellow": "Jaune : ce message est peut être un spam, il sera étiqueté comme spam et déplacé vers votre dossier Pourriel",
|
||||||
"status": "Statut",
|
"status": "Statut",
|
||||||
"sync_jobs": "Jobs de synchronisation",
|
"sync_jobs": "Jobs de synchronisation",
|
||||||
"tag_handling": "Régler la manipulation du courrier étiqueté",
|
"tag_handling": "Régler la manipulation du courrier étiqueté",
|
||||||
"tag_help_example": "Exemple pour une adresse e-mail étiquetée: me<b>+Facebook</b>@example.org",
|
"tag_help_example": "Exemple pour une adresse e-mail étiquetée : me<b>+Facebook</b>@example.org",
|
||||||
"tag_help_explain": "Dans sous-dossier: un nouveau sous-dossier nommé d’après la balise sera créé sous INBOX (\"INBOX/Facebook\").<br>\r\nDans le sujet : le nom des balises sera ajouté au début du sujet du mail, exemple : \"[Facebook] My News\".",
|
"tag_help_explain": "Dans un sous-dossier : un nouveau sous-dossier nommé selon l'étiquette sera créé sous INBOX (\"INBOX/Facebook\").<br>\nDans le sujet : le nom des balises sera ajouté au début du sujet du mail, exemple : \"[Facebook] My News\".",
|
||||||
"tag_in_none": "Ne rien faire",
|
"tag_in_none": "Ne rien faire",
|
||||||
"tag_in_subfolder": "Dans un sous dossier",
|
"tag_in_subfolder": "Dans un sous dossier",
|
||||||
"tag_in_subject": "Dans le sujet",
|
"tag_in_subject": "Dans le sujet",
|
||||||
@@ -1073,10 +1078,10 @@
|
|||||||
"dovecot_restart_failed": "Dovecot n’a pas pu redémarrer, veuillez vérifier les journaux",
|
"dovecot_restart_failed": "Dovecot n’a pas pu redémarrer, veuillez vérifier les journaux",
|
||||||
"fuzzy_learn_error": "Erreur d’apprentissage du hachage flou: %s",
|
"fuzzy_learn_error": "Erreur d’apprentissage du hachage flou: %s",
|
||||||
"hash_not_found": "Hachage non trouvé ou déjà supprimé",
|
"hash_not_found": "Hachage non trouvé ou déjà supprimé",
|
||||||
"ip_invalid": "IP non valide ignorée: %s",
|
"ip_invalid": "IP non valide ignorée : %s",
|
||||||
"no_active_admin": "Impossible de désactiver le dernier administrateur active",
|
"no_active_admin": "Impossible de désactiver le dernier administrateur active",
|
||||||
"quota_exceeded_scope": "Dépassement du quota de domaine: Seules des boîtes illimitées peuvent être créées dans ce domaine.",
|
"quota_exceeded_scope": "Dépassement du quota de domaine : Seules des boîtes illimitées peuvent être créées dans ce domaine.",
|
||||||
"session_token": "Jeton de formulaire invalide: Décalage des jetons",
|
"session_token": "Jeton de formulaire invalide : Jeton différent",
|
||||||
"session_ua": "Jeton de formulaire invalide: erreur de validation User-Agent"
|
"session_ua": "Jeton de formulaire invalide : erreur de validation User-Agent"
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@@ -2,8 +2,8 @@
|
|||||||
"acl": {
|
"acl": {
|
||||||
"alias_domains": "Aggiungi alias di dominio",
|
"alias_domains": "Aggiungi alias di dominio",
|
||||||
"app_passwds": "Gestisci le password delle app",
|
"app_passwds": "Gestisci le password delle app",
|
||||||
"bcc_maps": "BCC maps",
|
"bcc_maps": "Mappe CCN",
|
||||||
"delimiter_action": "Delimiter action",
|
"delimiter_action": "Azione delimitatrice",
|
||||||
"domain_desc": "Modifica la descrizione del dominio",
|
"domain_desc": "Modifica la descrizione del dominio",
|
||||||
"domain_relayhost": "Modifica relayhost per un dominio",
|
"domain_relayhost": "Modifica relayhost per un dominio",
|
||||||
"eas_reset": "Ripristina i dispositivi EAS",
|
"eas_reset": "Ripristina i dispositivi EAS",
|
||||||
@@ -106,7 +106,8 @@
|
|||||||
"validate": "Convalida",
|
"validate": "Convalida",
|
||||||
"validation_success": "Convalidato con successo",
|
"validation_success": "Convalidato con successo",
|
||||||
"bcc_dest_format": "Il destinatario in copia nascosta deve essere un singolo indirizzo email.<br>Se si vuole spedire una copia del messaggio a più destinatari, bisogna creare un alias ed utilizzarlo per questa opzione.",
|
"bcc_dest_format": "Il destinatario in copia nascosta deve essere un singolo indirizzo email.<br>Se si vuole spedire una copia del messaggio a più destinatari, bisogna creare un alias ed utilizzarlo per questa opzione.",
|
||||||
"app_passwd_protocols": "Protocolli consentiti per la password dell'app"
|
"app_passwd_protocols": "Protocolli consentiti per la password dell'app",
|
||||||
|
"tags": "Tag"
|
||||||
},
|
},
|
||||||
"admin": {
|
"admin": {
|
||||||
"access": "Accedi",
|
"access": "Accedi",
|
||||||
@@ -294,7 +295,7 @@
|
|||||||
"rsettings_preset_1": "Disable all but DKIM and rate limit for authenticated users",
|
"rsettings_preset_1": "Disable all but DKIM and rate limit for authenticated users",
|
||||||
"rsettings_preset_2": "I postmaster vogliono lo spam",
|
"rsettings_preset_2": "I postmaster vogliono lo spam",
|
||||||
"rsettings_preset_3": "Consenti solo mittenti specifici per una casella di posta (ad esempio: utilizzo solo come casella di posta interna)",
|
"rsettings_preset_3": "Consenti solo mittenti specifici per una casella di posta (ad esempio: utilizzo solo come casella di posta interna)",
|
||||||
"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_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": "Global filter maps",
|
||||||
"rspamd_global_filters_agree": "Starò attento!",
|
"rspamd_global_filters_agree": "Starò attento!",
|
||||||
"rspamd_global_filters_info": "Global filter maps contain different kind of global black and whitelists.",
|
"rspamd_global_filters_info": "Global filter maps contain different kind of global black and whitelists.",
|
||||||
@@ -983,7 +984,7 @@
|
|||||||
"enter_qr_code": "Il codice TOTP se il tuo dispositivo non è in grado di acquisire i codici QR",
|
"enter_qr_code": "Il codice TOTP se il tuo dispositivo non è in grado di acquisire i codici QR",
|
||||||
"error_code": "Codice di errore",
|
"error_code": "Codice di errore",
|
||||||
"init_webauthn": "Inizializzazione, attendere prego...",
|
"init_webauthn": "Inizializzazione, attendere prego...",
|
||||||
"key_id": "Identificatore per il tuo YubiKey",
|
"key_id": "Identificatore per il tuo dispositivo",
|
||||||
"key_id_totp": "Identificatore per la tua chiave",
|
"key_id_totp": "Identificatore per la tua chiave",
|
||||||
"none": "Disattivato",
|
"none": "Disattivato",
|
||||||
"reload_retry": "- (ricaricare la pagina se l'errore persiste)",
|
"reload_retry": "- (ricaricare la pagina se l'errore persiste)",
|
||||||
@@ -997,7 +998,9 @@
|
|||||||
"waiting_usb_auth": "<i>In attesa del device USB...</i><br /><br />Tocca ora il pulsante sul dispositivo WebAuthn USB.",
|
"waiting_usb_auth": "<i>In attesa del device USB...</i><br /><br />Tocca ora il pulsante sul dispositivo WebAuthn USB.",
|
||||||
"waiting_usb_register": "<i>In attesa del device USB...</i><br /><br />Inserisci la tua password qui sopra e conferma la tua registrazione WebAuthn toccando il pulsante del dispositivo WebAuthn USB.",
|
"waiting_usb_register": "<i>In attesa del device USB...</i><br /><br />Inserisci la tua password qui sopra e conferma la tua registrazione WebAuthn toccando il pulsante del dispositivo WebAuthn USB.",
|
||||||
"yubi_otp": "Autenticazione Yubico OTP",
|
"yubi_otp": "Autenticazione Yubico OTP",
|
||||||
"tfa_token_invalid": "Token TFA non valido"
|
"tfa_token_invalid": "Token TFA non valido",
|
||||||
|
"u2f_deprecated": "Sembra che la tua chiave sia stata registrata utilizzando il metodo U2F deprecato. Disattiveremo Two-Factor-Authenticaiton per te e cancelleremo la tua chiave.",
|
||||||
|
"u2f_deprecated_important": "Registra la tua chiave nel pannello di amministrazione con il nuovo metodo WebAuthn."
|
||||||
},
|
},
|
||||||
"user": {
|
"user": {
|
||||||
"action": "Azione",
|
"action": "Azione",
|
||||||
|
@@ -269,7 +269,7 @@
|
|||||||
"rsettings_preset_1": "인증된 사용자에 대해 DKIM과 속도 제한을 제외한 모든 것을 비활성화",
|
"rsettings_preset_1": "인증된 사용자에 대해 DKIM과 속도 제한을 제외한 모든 것을 비활성화",
|
||||||
"rsettings_preset_2": "포스트 마스터가 스팸을 원함",
|
"rsettings_preset_2": "포스트 마스터가 스팸을 원함",
|
||||||
"rsettings_preset_3": "메일박스에 특정 발신자만 허용 (i.e. 서버 내부 메일함으로만 이용)",
|
"rsettings_preset_3": "메일박스에 특정 발신자만 허용 (i.e. 서버 내부 메일함으로만 이용)",
|
||||||
"rspamd-com_settings": "설정 이름은 자동으로 생성되며 아래 사전 설정 예제를 참고하세요. 자세한 내용은 <a href=\"https://rspamd.com/doc/configuration/settings.html#settings-structure\" target=\"_blank\">Rspamd 문서</a>를 참조하세요.",
|
"rspamd_com_settings": "설정 이름은 자동으로 생성되며 아래 사전 설정 예제를 참고하세요. 자세한 내용은 <a href=\"https://rspamd.com/doc/configuration/settings.html#settings-structure\" target=\"_blank\">Rspamd 문서</a>를 참조하세요.",
|
||||||
"rspamd_global_filters": "글로벌 필터 맵",
|
"rspamd_global_filters": "글로벌 필터 맵",
|
||||||
"rspamd_global_filters_agree": "조심할게!",
|
"rspamd_global_filters_agree": "조심할게!",
|
||||||
"rspamd_global_filters_info": "글로벌 필터 맵은 다른 종류의 글로벌 블랙리스트와 화이트리스트를 포함합니다.",
|
"rspamd_global_filters_info": "글로벌 필터 맵은 다른 종류의 글로벌 블랙리스트와 화이트리스트를 포함합니다.",
|
||||||
|
@@ -277,7 +277,7 @@
|
|||||||
"rsettings_preset_1": "Schakel alles uit voor geauthenticeerde gebruikers, behalve ARC/DKIM en ratelimiting",
|
"rsettings_preset_1": "Schakel alles uit voor geauthenticeerde gebruikers, behalve ARC/DKIM en ratelimiting",
|
||||||
"rsettings_preset_2": "Laat postmasters spam ontvangen",
|
"rsettings_preset_2": "Laat postmasters spam ontvangen",
|
||||||
"rsettings_preset_3": "Sta uitsluitend specifieke afzenders toe voor een mailbox (bijvoorbeeld als interne mailbox)",
|
"rsettings_preset_3": "Sta uitsluitend specifieke afzenders toe voor een mailbox (bijvoorbeeld als interne mailbox)",
|
||||||
"rspamd-com_settings": "Een beschrijving voor deze instelling zal automatisch worden gegenereerd, gebruik de onderstaande presets als voorbeeld. Raadpleeg de <a href=\"https://rspamd.com/doc/configuration/settings.html#settings-structure\" target=\"_blank\">Rspamd-documentatie</a> voor meer informatie.",
|
"rspamd_com_settings": "Een beschrijving voor deze instelling zal automatisch worden gegenereerd, gebruik de onderstaande presets als voorbeeld. Raadpleeg de <a href=\"https://rspamd.com/doc/configuration/settings.html#settings-structure\" target=\"_blank\">Rspamd-documentatie</a> voor meer informatie.",
|
||||||
"rspamd_global_filters": "Globale filters",
|
"rspamd_global_filters": "Globale filters",
|
||||||
"rspamd_global_filters_agree": "Ik ben me ervan bewust dat aanpassingen desastreuze gevolgen kunnen hebben",
|
"rspamd_global_filters_agree": "Ik ben me ervan bewust dat aanpassingen desastreuze gevolgen kunnen hebben",
|
||||||
"rspamd_global_filters_info": "Ieder globaal filter heeft zijn eigen functie, zie de namen.",
|
"rspamd_global_filters_info": "Ieder globaal filter heeft zijn eigen functie, zie de namen.",
|
||||||
|
@@ -299,7 +299,7 @@
|
|||||||
"rsettings_preset_2": "Postmasterii doresc spam",
|
"rsettings_preset_2": "Postmasterii doresc spam",
|
||||||
"rsettings_preset_3": "Permiteți numai expeditori specifici pentru o căsuță poștală (ex: utilizare numai ca adresa de email internă)",
|
"rsettings_preset_3": "Permiteți numai expeditori specifici pentru o căsuță poștală (ex: utilizare numai ca adresa de email internă)",
|
||||||
"rsettings_preset_4": "Dezactivați Rspamd pentru domeniu",
|
"rsettings_preset_4": "Dezactivați Rspamd pentru domeniu",
|
||||||
"rspamd-com_settings": "<a href=\"https://rspamd.com/doc/configuration/settings.html#settings-structure\" target=\"_blank\">Documente Rspamd</a>\n - Un nume de setare va fi generat automat, te rog să consulți presetările exemplu de mai jos.",
|
"rspamd_com_settings": "<a href=\"https://rspamd.com/doc/configuration/settings.html#settings-structure\" target=\"_blank\">Documente Rspamd</a>\n - Un nume de setare va fi generat automat, te rog să consulți presetările exemplu de mai jos.",
|
||||||
"rspamd_global_filters": "Hărți cu filtru global",
|
"rspamd_global_filters": "Hărți cu filtru global",
|
||||||
"rspamd_global_filters_agree": "Voi fi atent!",
|
"rspamd_global_filters_agree": "Voi fi atent!",
|
||||||
"rspamd_global_filters_info": "Hărțile cu filtre globale conțin diferite tipuri de liste negre și albe.",
|
"rspamd_global_filters_info": "Hărțile cu filtre globale conțin diferite tipuri de liste negre și albe.",
|
||||||
|
@@ -105,7 +105,9 @@
|
|||||||
"timeout2": "Тайм-аут для подключения к локальному хосту",
|
"timeout2": "Тайм-аут для подключения к локальному хосту",
|
||||||
"username": "Имя пользователя",
|
"username": "Имя пользователя",
|
||||||
"validate": "Проверить",
|
"validate": "Проверить",
|
||||||
"validation_success": "Проверка прошла успешно"
|
"validation_success": "Проверка прошла успешно",
|
||||||
|
"tags": "Теги",
|
||||||
|
"app_passwd_protocols": "Разрешенные протоколы для пароля приложения"
|
||||||
},
|
},
|
||||||
"admin": {
|
"admin": {
|
||||||
"access": "Настройки доступа",
|
"access": "Настройки доступа",
|
||||||
@@ -190,7 +192,7 @@
|
|||||||
"flush_queue": "Отправить все сообщения",
|
"flush_queue": "Отправить все сообщения",
|
||||||
"forwarding_hosts": "Переадресация хостов",
|
"forwarding_hosts": "Переадресация хостов",
|
||||||
"forwarding_hosts_add_hint": "Можно указывать: IPv4/IPv6 подсети в нотации CIDR, имена хостов (которые будут разрешаться в IP-адреса) или доменные имена (которые будут решаться с IP-адресами путем запроса SPF записей или, в случае их отсутствия - запросом MX записей).",
|
"forwarding_hosts_add_hint": "Можно указывать: IPv4/IPv6 подсети в нотации CIDR, имена хостов (которые будут разрешаться в IP-адреса) или доменные имена (которые будут решаться с IP-адресами путем запроса SPF записей или, в случае их отсутствия - запросом MX записей).",
|
||||||
"forwarding_hosts_hint": "Входящие сообщения безоговорочно принимаются от любых хостов, перечисленных здесь. Эти хосты не проходят проверку DNSBL и graylisting. Спам, полученный от них, никогда не отклоняется, но при желании можно включить спам фильтр и письма с плохим рейтингом будут попадать в Junk. Наиболее распространенное использование - указать почтовые серверы, на которых вы установили правило, которое перенаправляет входящие электронные письма на ваш почтовый сервер.",
|
"forwarding_hosts_hint": "Входящие сообщения безоговорочно принимаются от любых хостов, перечисленных здесь. Эти хосты не проходят проверку DNSBL и graylisting. Спам, полученный от них, никогда не отклоняется, но при желании можно включить спам фильтр и письма с плохим рейтингом будут попадать в Junk. Наиболее распространенное использование - указать почтовые серверы, на которых вы установили правило, которое перенаправляет входящие электронные письма на ваш почтовый сервер mailcow.",
|
||||||
"from": "От",
|
"from": "От",
|
||||||
"generate": "сгенерировать",
|
"generate": "сгенерировать",
|
||||||
"guid": "GUID - уникальный ID",
|
"guid": "GUID - уникальный ID",
|
||||||
@@ -298,7 +300,7 @@
|
|||||||
"rsettings_preset_2": "Не проверять письма на спам Postmaster",
|
"rsettings_preset_2": "Не проверять письма на спам Postmaster",
|
||||||
"rsettings_preset_3": "Разрешить только определённых отправителей для почтового ящика (использование только в качестве внутреннего почтового ящика)",
|
"rsettings_preset_3": "Разрешить только определённых отправителей для почтового ящика (использование только в качестве внутреннего почтового ящика)",
|
||||||
"rsettings_preset_4": "Отключить Rspamd для домена",
|
"rsettings_preset_4": "Отключить Rspamd для домена",
|
||||||
"rspamd-com_settings": "Имена правил будут сгенерированы на основе их ID.<br> Инструкция доступна на сайте <a href=\"https://rspamd.com/doc/configuration/settings.html#settings-structure\" target=\"_blank\">документация Rspamd user settings</a>, заготовленные шаблоны:",
|
"rspamd_com_settings": "Имена правил будут сгенерированы на основе их ID.<br> Инструкция доступна на сайте <a href=\"https://rspamd.com/doc/configuration/settings.html#settings-structure\" target=\"_blank\">документация Rspamd user settings</a>, заготовленные шаблоны:",
|
||||||
"rspamd_global_filters": "Глобальные правила фильтрации",
|
"rspamd_global_filters": "Глобальные правила фильтрации",
|
||||||
"rspamd_global_filters_agree": "Я понимаю, что я делаю, и буду осторожен!",
|
"rspamd_global_filters_agree": "Я понимаю, что я делаю, и буду осторожен!",
|
||||||
"rspamd_global_filters_info": "Глобальные правила фильтрации содержат различные виды глобальных черных и белых списков.",
|
"rspamd_global_filters_info": "Глобальные правила фильтрации содержат различные виды глобальных черных и белых списков.",
|
||||||
@@ -460,7 +462,8 @@
|
|||||||
"unlimited_quota_acl": "Неограниченная квота запрещена политикой доступа",
|
"unlimited_quota_acl": "Неограниченная квота запрещена политикой доступа",
|
||||||
"username_invalid": "Имя пользователя %s нельзя использовать",
|
"username_invalid": "Имя пользователя %s нельзя использовать",
|
||||||
"validity_missing": "Пожалуйста, назначьте срок действия",
|
"validity_missing": "Пожалуйста, назначьте срок действия",
|
||||||
"value_missing": "Пожалуйста заполните все поля"
|
"value_missing": "Пожалуйста заполните все поля",
|
||||||
|
"yotp_verification_failed": "Ошибка валидации Yubico OTP: %s"
|
||||||
},
|
},
|
||||||
"debug": {
|
"debug": {
|
||||||
"chart_this_server": "Диаграмма (текущий сервер)",
|
"chart_this_server": "Диаграмма (текущий сервер)",
|
||||||
|
@@ -299,7 +299,7 @@
|
|||||||
"rsettings_preset_2": "Prijať každý spam",
|
"rsettings_preset_2": "Prijať každý spam",
|
||||||
"rsettings_preset_3": "Povoliť len špecifických odosielateľov (využitie ako interná schránka pre lokálne doručovanie)",
|
"rsettings_preset_3": "Povoliť len špecifických odosielateľov (využitie ako interná schránka pre lokálne doručovanie)",
|
||||||
"rsettings_preset_4": "Deaktivujte Rspamd pre doménu",
|
"rsettings_preset_4": "Deaktivujte Rspamd pre doménu",
|
||||||
"rspamd-com_settings": "Názov nastavenia bude automaticky vygenerovaný, pozrite sa prosím na ukážky uvedené nižšie. Pre viac informácií navštívte <a href=\"https://rspamd.com/doc/configuration/settings.html#settings-structure\" target=\"_blank\">Rspamd dokumentáciu</a>",
|
"rspamd_com_settings": "Názov nastavenia bude automaticky vygenerovaný, pozrite sa prosím na ukážky uvedené nižšie. Pre viac informácií navštívte <a href=\"https://rspamd.com/doc/configuration/settings.html#settings-structure\" target=\"_blank\">Rspamd dokumentáciu</a>",
|
||||||
"rspamd_global_filters": "Mapy globálnych filtrov",
|
"rspamd_global_filters": "Mapy globálnych filtrov",
|
||||||
"rspamd_global_filters_agree": "Budem opatrný!",
|
"rspamd_global_filters_agree": "Budem opatrný!",
|
||||||
"rspamd_global_filters_info": "Mapy globálnych filtrov obsahujú rozličné druhy globálnych blacklistov a whitelistov.",
|
"rspamd_global_filters_info": "Mapy globálnych filtrov obsahujú rozličné druhy globálnych blacklistov a whitelistov.",
|
||||||
|
@@ -288,7 +288,7 @@
|
|||||||
"rsettings_preset_1": "Inaktivera allt förutom DKIM och hastighetsbegränsningar för inloggade användare",
|
"rsettings_preset_1": "Inaktivera allt förutom DKIM och hastighetsbegränsningar för inloggade användare",
|
||||||
"rsettings_preset_2": "Avvisa inte skräppost till postmasteradresser",
|
"rsettings_preset_2": "Avvisa inte skräppost till postmasteradresser",
|
||||||
"rsettings_preset_3": "Tillåt bara en eller flera avsändare att skriva till en brevlåda (t.ex. interna brevlådor)",
|
"rsettings_preset_3": "Tillåt bara en eller flera avsändare att skriva till en brevlåda (t.ex. interna brevlådor)",
|
||||||
"rspamd-com_settings": "Ett inställningsnamn kommer att genereras automatiskt, se exemplet nedan. För mer detaljer se <a href=\"https://rspamd.com/doc/configuration/settings.html#settings-structure\" target=\"_blank\">Rspamd dokumentationen</a>",
|
"rspamd_com_settings": "Ett inställningsnamn kommer att genereras automatiskt, se exemplet nedan. För mer detaljer se <a href=\"https://rspamd.com/doc/configuration/settings.html#settings-structure\" target=\"_blank\">Rspamd dokumentationen</a>",
|
||||||
"rspamd_global_filters": "Globala filterregler",
|
"rspamd_global_filters": "Globala filterregler",
|
||||||
"rspamd_global_filters_agree": "Jag ska vara försiktig!",
|
"rspamd_global_filters_agree": "Jag ska vara försiktig!",
|
||||||
"rspamd_global_filters_info": "En global filterregel kan styra den globala vita- och svartlistan på denna server.",
|
"rspamd_global_filters_info": "En global filterregel kan styra den globala vita- och svartlistan på denna server.",
|
||||||
|
1186
data/web/lang/lang.uk.json
Normal file
1186
data/web/lang/lang.uk.json
Normal file
File diff suppressed because it is too large
Load Diff
@@ -274,7 +274,7 @@
|
|||||||
"rsettings_preset_1": "为已认证用户关闭除DKIM和ratelimit规则外的所有规则",
|
"rsettings_preset_1": "为已认证用户关闭除DKIM和ratelimit规则外的所有规则",
|
||||||
"rsettings_preset_2": "管理员(postmaster)想要垃圾邮件",
|
"rsettings_preset_2": "管理员(postmaster)想要垃圾邮件",
|
||||||
"rsettings_preset_3": "只允许指定的发件人 (如只允许内部邮箱发送)",
|
"rsettings_preset_3": "只允许指定的发件人 (如只允许内部邮箱发送)",
|
||||||
"rspamd-com_settings": "自动生成设置名称,请看下方的示例预设。查看<a href=\"https://rspamd.com/doc/configuration/settings.html#settings-structure\" target=\"_blank\">Rspamd docs</a>以了解更多细节。",
|
"rspamd_com_settings": "自动生成设置名称,请看下方的示例预设。查看<a href=\"https://rspamd.com/doc/configuration/settings.html#settings-structure\" target=\"_blank\">Rspamd docs</a>以了解更多细节。",
|
||||||
"rspamd_global_filters": "全局过滤规则",
|
"rspamd_global_filters": "全局过滤规则",
|
||||||
"rspamd_global_filters_agree": "我会小心谨慎的!",
|
"rspamd_global_filters_agree": "我会小心谨慎的!",
|
||||||
"rspamd_global_filters_info": "全局过滤规则包含了不同类型的全局黑名单和白名单。",
|
"rspamd_global_filters_info": "全局过滤规则包含了不同类型的全局黑名单和白名单。",
|
||||||
|
@@ -1,6 +1,15 @@
|
|||||||
<?php
|
<?php
|
||||||
|
|
||||||
|
if (!isset($_GET['file']) ) {
|
||||||
|
http_response_code(404);
|
||||||
|
exit;
|
||||||
|
}
|
||||||
$pathinfo = pathinfo($_GET['file']);
|
$pathinfo = pathinfo($_GET['file']);
|
||||||
|
|
||||||
|
if (!array_key_exists('extension', $pathinfo)) {
|
||||||
|
http_response_code(404);
|
||||||
|
exit;
|
||||||
|
}
|
||||||
$extension = strtolower($pathinfo['extension']);
|
$extension = strtolower($pathinfo['extension']);
|
||||||
|
|
||||||
$filepath = '/tmp/' . $pathinfo['basename'];
|
$filepath = '/tmp/' . $pathinfo['basename'];
|
||||||
|
@@ -23,6 +23,22 @@
|
|||||||
<input type="text" class="form-control" name="description" value="{{ result.description }}">
|
<input type="text" class="form-control" name="description" value="{{ result.description }}">
|
||||||
</div>
|
</div>
|
||||||
</div>
|
</div>
|
||||||
|
<div class="form-group">
|
||||||
|
<label class="control-label col-sm-2">{{ lang.add.tags }}</label>
|
||||||
|
<div class="col-sm-10">
|
||||||
|
<div class="form-control tag-box">
|
||||||
|
{% for tag in domain_details.tags %}
|
||||||
|
<span data-action='delete_selected' data-item="{{ tag|url_encode }}" data-id="domain_tag_{{ tag }}" data-api-url='delete/domain/tag/{{ domain }}' class="badge badge-primary tag-badge btn-badge">
|
||||||
|
<i class="bi bi-tag-fill"></i>
|
||||||
|
{{ tag }}
|
||||||
|
</span>
|
||||||
|
{% endfor %}
|
||||||
|
<input type="text" class="tag-input">
|
||||||
|
<span class="btn tag-add"><i class="bi bi-plus-lg"></i></span>
|
||||||
|
<input type="hidden" value="" name="tags" class="tag-values" />
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
<div class="form-group">
|
<div class="form-group">
|
||||||
<label class="control-label col-sm-2" for="relayhost">{{ lang.edit.relayhost }}</label>
|
<label class="control-label col-sm-2" for="relayhost">{{ lang.edit.relayhost }}</label>
|
||||||
<div class="col-sm-10">
|
<div class="col-sm-10">
|
||||||
|
@@ -22,6 +22,22 @@
|
|||||||
<input type="text" class="form-control" name="name" value="{{ result.name }}">
|
<input type="text" class="form-control" name="name" value="{{ result.name }}">
|
||||||
</div>
|
</div>
|
||||||
</div>
|
</div>
|
||||||
|
<div class="form-group">
|
||||||
|
<label class="control-label col-sm-2">{{ lang.add.tags }}</label>
|
||||||
|
<div class="col-sm-10">
|
||||||
|
<div class="form-control tag-box">
|
||||||
|
{% for tag in mailbox_details.tags %}
|
||||||
|
<span data-action='delete_selected' data-item="{{ tag }}" data-id="mailbox_tag_{{ tag }}" data-api-url='delete/mailbox/tag/{{ mailbox }}' class="badge badge-primary tag-badge btn-badge">
|
||||||
|
<i class="bi bi-tag-fill"></i>
|
||||||
|
{{ tag }}
|
||||||
|
</span>
|
||||||
|
{% endfor %}
|
||||||
|
<input type="text" class="tag-input">
|
||||||
|
<span class="btn tag-add"><i class="bi bi-plus-lg"></i></span>
|
||||||
|
<input type="hidden" value="" name="tags" class="tag-values" />
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
<div class="form-group">
|
<div class="form-group">
|
||||||
<label class="control-label col-sm-2" for="quota">{{ lang.edit.quota_mb }}
|
<label class="control-label col-sm-2" for="quota">{{ lang.edit.quota_mb }}
|
||||||
<br><span id="quotaBadge" class="badge">max. {{ (result.max_new_quota / 1048576) }} MiB</span>
|
<br><span id="quotaBadge" class="badge">max. {{ (result.max_new_quota / 1048576) }} MiB</span>
|
||||||
@@ -154,12 +170,16 @@
|
|||||||
<div class="col-sm-10">
|
<div class="col-sm-10">
|
||||||
<div class="btn-group" data-acl="{{ acl.tls_policy }}">
|
<div class="btn-group" data-acl="{{ acl.tls_policy }}">
|
||||||
<button type="button" class="btn btn-sm btn-xs-half visible-xs-block visible-sm-inline visible-md-inline visible-lg-inline btn-default{% if get_tls_policy.tls_enforce_in == '1' %} active"{% endif %}"
|
<button type="button" class="btn btn-sm btn-xs-half visible-xs-block visible-sm-inline visible-md-inline visible-lg-inline btn-default{% if get_tls_policy.tls_enforce_in == '1' %} active"{% endif %}"
|
||||||
|
role="switch"
|
||||||
|
aria-checked="{% if get_tls_policy.tls_enforce_in == '1' %}true{% else %}false{% endif %}"
|
||||||
data-action="edit_selected"
|
data-action="edit_selected"
|
||||||
data-item="{{ mailbox }}"
|
data-item="{{ mailbox }}"
|
||||||
data-id="tls_policy"
|
data-id="tls_policy"
|
||||||
data-api-url='edit/tls_policy'
|
data-api-url='edit/tls_policy'
|
||||||
data-api-attr='{"tls_enforce_in": {% if get_tls_policy.tls_enforce_in == '1' %}0{% else %}1{% endif %} }'>{{ lang.user.tls_enforce_in }}</button>
|
data-api-attr='{"tls_enforce_in": {% if get_tls_policy.tls_enforce_in == '1' %}0{% else %}1{% endif %} }'>{{ lang.user.tls_enforce_in }}</button>
|
||||||
<button type="button" class="btn btn-sm btn-xs-half visible-xs-block visible-sm-inline visible-md-inline visible-lg-inline btn-default{% if get_tls_policy.tls_enforce_out == '1' %} active"{% endif %}"
|
<button type="button" class="btn btn-sm btn-xs-half visible-xs-block visible-sm-inline visible-md-inline visible-lg-inline btn-default{% if get_tls_policy.tls_enforce_out == '1' %} active"{% endif %}"
|
||||||
|
role="switch"
|
||||||
|
aria-checked="{% if get_tls_policy.tls_enforce_out == '1' %}true{% else %}false{% endif %}"
|
||||||
data-action="edit_selected"
|
data-action="edit_selected"
|
||||||
data-item="{{ mailbox }}"
|
data-item="{{ mailbox }}"
|
||||||
data-id="tls_policy"
|
data-id="tls_policy"
|
||||||
|
@@ -31,7 +31,7 @@
|
|||||||
<li><a data-action="edit_selected" data-id="filter_item" data-api-url='edit/filter' data-api-attr='{"filter_type":"prefilter"}' href="#">{{ lang.mailbox.set_prefilter }}</a></li>
|
<li><a data-action="edit_selected" data-id="filter_item" data-api-url='edit/filter' data-api-attr='{"filter_type":"prefilter"}' href="#">{{ lang.mailbox.set_prefilter }}</a></li>
|
||||||
<li><a data-action="edit_selected" data-id="filter_item" data-api-url='edit/filter' data-api-attr='{"filter_type":"postfilter"}' href="#">{{ lang.mailbox.set_postfilter }}</a></li>
|
<li><a data-action="edit_selected" data-id="filter_item" data-api-url='edit/filter' data-api-attr='{"filter_type":"postfilter"}' href="#">{{ lang.mailbox.set_postfilter }}</a></li>
|
||||||
<li role="separator" class="divider"></li>
|
<li role="separator" class="divider"></li>
|
||||||
<li><a data-action="delete_selected" data-text="{{ lang.user.eas_reset }}?" data-id="filter_item" data-api-url='delete/filter' href="#">{{ lang.mailbox.remove }}</a></li>
|
<li><a data-action="delete_selected" data-text="{{ lang.edit.delete_ays }}" data-id="filter_item" data-api-url='delete/filter' href="#">{{ lang.mailbox.remove }}</a></li>
|
||||||
</ul>
|
</ul>
|
||||||
<div class="clearfix visible-xs"></div>
|
<div class="clearfix visible-xs"></div>
|
||||||
<a class="btn btn-sm visible-xs-block visible-sm-inline visible-md-inline visible-lg-inline btn-success" href="#" data-toggle="modal" data-target="#addFilterModalAdmin"><i class="bi bi-plus-lg"></i> {{ lang.mailbox.add_filter }}</a>
|
<a class="btn btn-sm visible-xs-block visible-sm-inline visible-md-inline visible-lg-inline btn-success" href="#" data-toggle="modal" data-target="#addFilterModalAdmin"><i class="bi bi-plus-lg"></i> {{ lang.mailbox.add_filter }}</a>
|
||||||
|
@@ -34,7 +34,7 @@
|
|||||||
</div>
|
</div>
|
||||||
</form>
|
</form>
|
||||||
<hr>
|
<hr>
|
||||||
<p>{{ lang.admin.rspamd-com_settings }}</p>
|
<p>{{ lang.admin.rspamd_com_settings | raw }}</p>
|
||||||
<ul id="rspamd_presets"></ul>
|
<ul id="rspamd_presets"></ul>
|
||||||
</div>
|
</div>
|
||||||
</div>
|
</div>
|
||||||
|
@@ -30,6 +30,16 @@
|
|||||||
<input type="text" class="form-control" name="name">
|
<input type="text" class="form-control" name="name">
|
||||||
</div>
|
</div>
|
||||||
</div>
|
</div>
|
||||||
|
<div class="form-group">
|
||||||
|
<label class="control-label col-sm-2">{{ lang.add.tags }}</label>
|
||||||
|
<div class="col-sm-10">
|
||||||
|
<div class="form-control tag-box">
|
||||||
|
<input type="text" class="tag-input">
|
||||||
|
<span class="btn tag-add"><i class="bi bi-plus-lg"></i></span>
|
||||||
|
<input type="hidden" value="" name="tags" class="tag-values" />
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
<div class="form-group">
|
<div class="form-group">
|
||||||
<label class="control-label col-sm-2" for="addInputQuota">{{ lang.add.quota_mb }}
|
<label class="control-label col-sm-2" for="addInputQuota">{{ lang.add.quota_mb }}
|
||||||
<br /><span id="quotaBadge" class="badge">max. - MiB</span>
|
<br /><span id="quotaBadge" class="badge">max. - MiB</span>
|
||||||
@@ -94,6 +104,16 @@
|
|||||||
<input type="text" class="form-control" name="description">
|
<input type="text" class="form-control" name="description">
|
||||||
</div>
|
</div>
|
||||||
</div>
|
</div>
|
||||||
|
<div class="form-group">
|
||||||
|
<label class="control-label col-sm-2">{{ lang.add.tags }}</label>
|
||||||
|
<div class="col-sm-10">
|
||||||
|
<div class="form-control tag-box">
|
||||||
|
<input type="text" class="tag-input">
|
||||||
|
<span class="btn tag-add"><i class="bi bi-plus-lg"></i></span>
|
||||||
|
<input type="hidden" value="" name="tags" class="tag-values" />
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
<div class="form-group">
|
<div class="form-group">
|
||||||
<label class="control-label col-sm-2" for="aliases">{{ lang.add.max_aliases }}</label>
|
<label class="control-label col-sm-2" for="aliases">{{ lang.add.max_aliases }}</label>
|
||||||
<div class="col-sm-10">
|
<div class="col-sm-10">
|
||||||
@@ -188,11 +208,11 @@
|
|||||||
<div class="form-group">
|
<div class="form-group">
|
||||||
<div class="col-sm-offset-2 col-sm-10 btn-group">
|
<div class="col-sm-offset-2 col-sm-10 btn-group">
|
||||||
{% if not skip_sogo %}
|
{% if not skip_sogo %}
|
||||||
<button class="btn btn-xs-lg btn-xs-half visible-xs-block visible-sm-inline visible-md-inline visible-lg-inline btn-default" data-action="add_item" data-id="add_domain" data-api-url='add/domain' data-api-attr='{}' href="#">{{ lang.add.add_domain_only }}</button>
|
<button class="btn btn-xs-lg btn-xs-half visible-xs-block visible-sm-inline visible-md-inline visible-lg-inline btn-default" data-action="add_item" data-id="add_domain" data-api-url='add/domain' data-api-attr='{"tags": []}' href="#">{{ lang.add.add_domain_only }}</button>
|
||||||
<button class="btn btn-xs-lg btn-xs-half visible-xs-block visible-sm-inline visible-md-inline visible-lg-inline btn-default" data-action="add_item" data-id="add_domain" data-api-url='add/domain' data-api-attr='{"restart_sogo":"1"}' href="#">{{ lang.add.add_domain_restart }}</button>
|
<button class="btn btn-xs-lg btn-xs-half visible-xs-block visible-sm-inline visible-md-inline visible-lg-inline btn-default" data-action="add_item" data-id="add_domain" data-api-url='add/domain' data-api-attr='{"restart_sogo":"1", "tags": []}' href="#">{{ lang.add.add_domain_restart }}</button>
|
||||||
<div class="clearfix visible-xs"></div>
|
<div class="clearfix visible-xs"></div>
|
||||||
{% else %}
|
{% else %}
|
||||||
<button class="btn btn-xs-lg visible-xs-block visible-sm-inline visible-md-inline visible-lg-inline btn-success" data-action="add_item" data-id="add_domain" data-api-url='add/domain' data-api-attr='{}' href="#">{{ lang.add.add }}</button>
|
<button class="btn btn-xs-lg visible-xs-block visible-sm-inline visible-md-inline visible-lg-inline btn-success" data-action="add_item" data-id="add_domain" data-api-url='add/domain' data-api-attr='{"tags": []}' href="#">{{ lang.add.add }}</button>
|
||||||
{% endif %}
|
{% endif %}
|
||||||
</div>
|
</div>
|
||||||
</div>
|
</div>
|
||||||
|
@@ -2,11 +2,14 @@
|
|||||||
<div class="panel panel-default">
|
<div class="panel panel-default">
|
||||||
<div class="panel-heading">{{ lang.user.mailbox_general }}</div>
|
<div class="panel-heading">{{ lang.user.mailbox_general }}</div>
|
||||||
<div class="panel-body">
|
<div class="panel-body">
|
||||||
|
{% if mailboxdata.attributes.force_pw_update == '1' %}
|
||||||
|
<div class="alert alert-danger">{{ lang.user.force_pw_update|raw }}</div>
|
||||||
|
{% endif %}
|
||||||
{% if not skip_sogo %}
|
{% if not skip_sogo %}
|
||||||
<div class="row">
|
<div class="row">
|
||||||
<div class="hidden-xs col-md-3 col-xs-5 text-right"></div>
|
<div class="hidden-xs col-md-3 col-xs-5 text-right"></div>
|
||||||
<div class="col-md-3 col-xs-12">
|
<div class="col-md-3 col-xs-12">
|
||||||
{% if dual_login and allow_admin_email_login == 'n' %}
|
{% if dual_login and allow_admin_email_login == 'n' or mailboxdata.attributes.force_pw_update == '1' %}
|
||||||
<button disabled class="btn btn-default btn-block btn-xs-lg">
|
<button disabled class="btn btn-default btn-block btn-xs-lg">
|
||||||
<i class="bi bi-inbox-fill"></i> {{ lang.user.open_webmail_sso }}
|
<i class="bi bi-inbox-fill"></i> {{ lang.user.open_webmail_sso }}
|
||||||
</button>
|
</button>
|
||||||
@@ -115,9 +118,6 @@
|
|||||||
<hr>
|
<hr>
|
||||||
<div class="row">
|
<div class="row">
|
||||||
<div class="col-sm-offset-3 col-sm-9">
|
<div class="col-sm-offset-3 col-sm-9">
|
||||||
{% if mailboxdata.attributes.force_pw_update == '1' %}
|
|
||||||
<div class="alert alert-danger">{{ lang.user.force_pw_update|raw }}</div>
|
|
||||||
{% endif %}
|
|
||||||
<p><a target="_blank" href="https://mailcow.github.io/mailcow-dockerized-docs/client/client/#{{ clientconfigstr }}">[{{ lang.user.client_configuration }}]</a></p>
|
<p><a target="_blank" href="https://mailcow.github.io/mailcow-dockerized-docs/client/client/#{{ clientconfigstr }}">[{{ lang.user.client_configuration }}]</a></p>
|
||||||
<p><a href="#userFilterModal" data-toggle="modal">[{{ lang.user.show_sieve_filters }}]</a></p>
|
<p><a href="#userFilterModal" data-toggle="modal">[{{ lang.user.show_sieve_filters }}]</a></p>
|
||||||
<hr>
|
<hr>
|
||||||
|
@@ -37,12 +37,16 @@
|
|||||||
<div class="col-sm-9 col-xs-12">
|
<div class="col-sm-9 col-xs-12">
|
||||||
<div class="btn-group" data-acl="{{ acl.tls_policy }}">
|
<div class="btn-group" data-acl="{{ acl.tls_policy }}">
|
||||||
<button type="button" class="btn btn-sm btn-xs-half visible-xs-block visible-sm-inline visible-md-inline visible-lg-inline btn-default{% if get_tls_policy.tls_enforce_in == '1' %} active"{% endif %}"
|
<button type="button" class="btn btn-sm btn-xs-half visible-xs-block visible-sm-inline visible-md-inline visible-lg-inline btn-default{% if get_tls_policy.tls_enforce_in == '1' %} active"{% endif %}"
|
||||||
|
role="switch"
|
||||||
|
aria-checked="{% if get_tls_policy.tls_enforce_in == '1' %}true{% else %}false{% endif %}"
|
||||||
data-action="edit_selected"
|
data-action="edit_selected"
|
||||||
data-item="{{ mailcow_cc_username }}"
|
data-item="{{ mailcow_cc_username }}"
|
||||||
data-id="tls_policy"
|
data-id="tls_policy"
|
||||||
data-api-url='edit/tls_policy'
|
data-api-url='edit/tls_policy'
|
||||||
data-api-attr='{"tls_enforce_in": {% if get_tls_policy.tls_enforce_in == '1' %}0{% else %}1{% endif %} }'>{{ lang.user.tls_enforce_in }}</button>
|
data-api-attr='{"tls_enforce_in": {% if get_tls_policy.tls_enforce_in == '1' %}0{% else %}1{% endif %} }'>{{ lang.user.tls_enforce_in }}</button>
|
||||||
<button type="button" class="btn btn-sm btn-xs-half visible-xs-block visible-sm-inline visible-md-inline visible-lg-inline btn-default{% if get_tls_policy.tls_enforce_out == '1' %} active"{% endif %}"
|
<button type="button" class="btn btn-sm btn-xs-half visible-xs-block visible-sm-inline visible-md-inline visible-lg-inline btn-default{% if get_tls_policy.tls_enforce_out == '1' %} active"{% endif %}"
|
||||||
|
role="switch"
|
||||||
|
aria-checked="{% if get_tls_policy.tls_enforce_out == '1' %}true{% else %}false{% endif %}"
|
||||||
data-action="edit_selected"
|
data-action="edit_selected"
|
||||||
data-item="{{ mailcow_cc_username }}"
|
data-item="{{ mailcow_cc_username }}"
|
||||||
data-id="tls_policy"
|
data-id="tls_policy"
|
||||||
|
@@ -2,7 +2,7 @@ version: '2.1'
|
|||||||
services:
|
services:
|
||||||
|
|
||||||
unbound-mailcow:
|
unbound-mailcow:
|
||||||
image: mailcow/unbound:1.15
|
image: mailcow/unbound:1.16
|
||||||
environment:
|
environment:
|
||||||
- TZ=${TZ}
|
- TZ=${TZ}
|
||||||
volumes:
|
volumes:
|
||||||
@@ -22,8 +22,8 @@ services:
|
|||||||
- unbound-mailcow
|
- unbound-mailcow
|
||||||
stop_grace_period: 45s
|
stop_grace_period: 45s
|
||||||
volumes:
|
volumes:
|
||||||
- mysql-vol-1:/var/lib/mysql/:Z
|
- mysql-vol-1:/var/lib/mysql/
|
||||||
- mysql-socket-vol-1:/var/run/mysqld/:z
|
- mysql-socket-vol-1:/var/run/mysqld/
|
||||||
- ./data/conf/mysql/:/etc/mysql/conf.d/:ro,Z
|
- ./data/conf/mysql/:/etc/mysql/conf.d/:ro,Z
|
||||||
environment:
|
environment:
|
||||||
- TZ=${TZ}
|
- TZ=${TZ}
|
||||||
@@ -43,7 +43,7 @@ services:
|
|||||||
redis-mailcow:
|
redis-mailcow:
|
||||||
image: redis:6-alpine
|
image: redis:6-alpine
|
||||||
volumes:
|
volumes:
|
||||||
- redis-vol-1:/data/:Z
|
- redis-vol-1:/data/
|
||||||
restart: always
|
restart: always
|
||||||
ports:
|
ports:
|
||||||
- "${REDIS_PORT:-127.0.0.1:7654}:6379"
|
- "${REDIS_PORT:-127.0.0.1:7654}:6379"
|
||||||
@@ -58,8 +58,10 @@ services:
|
|||||||
- redis
|
- redis
|
||||||
|
|
||||||
clamd-mailcow:
|
clamd-mailcow:
|
||||||
image: mailcow/clamd:1.44
|
image: mailcow/clamd:1.52
|
||||||
restart: always
|
restart: always
|
||||||
|
depends_on:
|
||||||
|
- unbound-mailcow
|
||||||
dns:
|
dns:
|
||||||
- ${IPV4_NETWORK:-172.22.1}.254
|
- ${IPV4_NETWORK:-172.22.1}.254
|
||||||
environment:
|
environment:
|
||||||
@@ -67,13 +69,14 @@ services:
|
|||||||
- SKIP_CLAMD=${SKIP_CLAMD:-n}
|
- SKIP_CLAMD=${SKIP_CLAMD:-n}
|
||||||
volumes:
|
volumes:
|
||||||
- ./data/conf/clamav/:/etc/clamav/:Z
|
- ./data/conf/clamav/:/etc/clamav/:Z
|
||||||
|
- clamd-db-vol-1:/var/lib/clamav
|
||||||
networks:
|
networks:
|
||||||
mailcow-network:
|
mailcow-network:
|
||||||
aliases:
|
aliases:
|
||||||
- clamd
|
- clamd
|
||||||
|
|
||||||
rspamd-mailcow:
|
rspamd-mailcow:
|
||||||
image: mailcow/rspamd:1.80
|
image: mailcow/rspamd:1.90
|
||||||
stop_grace_period: 30s
|
stop_grace_period: 30s
|
||||||
depends_on:
|
depends_on:
|
||||||
- dovecot-mailcow
|
- dovecot-mailcow
|
||||||
@@ -92,7 +95,7 @@ services:
|
|||||||
- ./data/conf/rspamd/lua/:/etc/rspamd/lua/:ro,Z
|
- ./data/conf/rspamd/lua/:/etc/rspamd/lua/:ro,Z
|
||||||
- ./data/conf/rspamd/rspamd.conf.local:/etc/rspamd/rspamd.conf.local:Z
|
- ./data/conf/rspamd/rspamd.conf.local:/etc/rspamd/rspamd.conf.local:Z
|
||||||
- ./data/conf/rspamd/rspamd.conf.override:/etc/rspamd/rspamd.conf.override:Z
|
- ./data/conf/rspamd/rspamd.conf.override:/etc/rspamd/rspamd.conf.override:Z
|
||||||
- rspamd-vol-1:/var/lib/rspamd:z
|
- rspamd-vol-1:/var/lib/rspamd
|
||||||
restart: always
|
restart: always
|
||||||
hostname: rspamd
|
hostname: rspamd
|
||||||
dns:
|
dns:
|
||||||
@@ -103,7 +106,7 @@ services:
|
|||||||
- rspamd
|
- rspamd
|
||||||
|
|
||||||
php-fpm-mailcow:
|
php-fpm-mailcow:
|
||||||
image: mailcow/phpfpm:1.78
|
image: mailcow/phpfpm:1.79
|
||||||
command: "php-fpm -d date.timezone=${TZ} -d expose_php=0"
|
command: "php-fpm -d date.timezone=${TZ} -d expose_php=0"
|
||||||
depends_on:
|
depends_on:
|
||||||
- redis-mailcow
|
- redis-mailcow
|
||||||
@@ -112,8 +115,8 @@ services:
|
|||||||
- ./data/web:/web:z
|
- ./data/web:/web:z
|
||||||
- ./data/conf/rspamd/dynmaps:/dynmaps:ro,z
|
- ./data/conf/rspamd/dynmaps:/dynmaps:ro,z
|
||||||
- ./data/conf/rspamd/custom/:/rspamd_custom_maps:z
|
- ./data/conf/rspamd/custom/:/rspamd_custom_maps:z
|
||||||
- rspamd-vol-1:/var/lib/rspamd:z
|
- rspamd-vol-1:/var/lib/rspamd
|
||||||
- mysql-socket-vol-1:/var/run/mysqld/:z
|
- mysql-socket-vol-1:/var/run/mysqld/
|
||||||
- ./data/conf/sogo/:/etc/sogo/:z
|
- ./data/conf/sogo/:/etc/sogo/:z
|
||||||
- ./data/conf/rspamd/meta_exporter:/meta_exporter:ro,z
|
- ./data/conf/rspamd/meta_exporter:/meta_exporter:ro,z
|
||||||
- ./data/conf/phpfpm/sogo-sso/:/etc/sogo-sso/:z
|
- ./data/conf/phpfpm/sogo-sso/:/etc/sogo-sso/:z
|
||||||
@@ -165,7 +168,7 @@ services:
|
|||||||
- phpfpm
|
- phpfpm
|
||||||
|
|
||||||
sogo-mailcow:
|
sogo-mailcow:
|
||||||
image: mailcow/sogo:1.106
|
image: mailcow/sogo:1.108
|
||||||
environment:
|
environment:
|
||||||
- DBNAME=${DBNAME}
|
- DBNAME=${DBNAME}
|
||||||
- DBUSER=${DBUSER}
|
- DBUSER=${DBUSER}
|
||||||
@@ -191,9 +194,9 @@ services:
|
|||||||
- ./data/conf/sogo/custom-favicon.ico:/usr/lib/GNUstep/SOGo/WebServerResources/img/sogo.ico:z
|
- ./data/conf/sogo/custom-favicon.ico:/usr/lib/GNUstep/SOGo/WebServerResources/img/sogo.ico:z
|
||||||
- ./data/conf/sogo/custom-theme.js:/usr/lib/GNUstep/SOGo/WebServerResources/js/theme.js:z
|
- ./data/conf/sogo/custom-theme.js:/usr/lib/GNUstep/SOGo/WebServerResources/js/theme.js:z
|
||||||
- ./data/conf/sogo/custom-sogo.js:/usr/lib/GNUstep/SOGo/WebServerResources/js/custom-sogo.js:z
|
- ./data/conf/sogo/custom-sogo.js:/usr/lib/GNUstep/SOGo/WebServerResources/js/custom-sogo.js:z
|
||||||
- mysql-socket-vol-1:/var/run/mysqld/:z
|
- mysql-socket-vol-1:/var/run/mysqld/
|
||||||
- sogo-web-vol-1:/sogo_web:z
|
- sogo-web-vol-1:/sogo_web
|
||||||
- sogo-userdata-backup-vol-1:/sogo_backup:Z
|
- sogo-userdata-backup-vol-1:/sogo_backup
|
||||||
labels:
|
labels:
|
||||||
ofelia.enabled: "true"
|
ofelia.enabled: "true"
|
||||||
ofelia.job-exec.sogo_sessions.schedule: "@every 1m"
|
ofelia.job-exec.sogo_sessions.schedule: "@every 1m"
|
||||||
@@ -212,7 +215,7 @@ services:
|
|||||||
- sogo
|
- sogo
|
||||||
|
|
||||||
dovecot-mailcow:
|
dovecot-mailcow:
|
||||||
image: mailcow/dovecot:1.161
|
image: mailcow/dovecot:1.162
|
||||||
depends_on:
|
depends_on:
|
||||||
- mysql-mailcow
|
- mysql-mailcow
|
||||||
dns:
|
dns:
|
||||||
@@ -225,13 +228,13 @@ services:
|
|||||||
- ./data/assets/ssl:/etc/ssl/mail/:ro,z
|
- ./data/assets/ssl:/etc/ssl/mail/:ro,z
|
||||||
- ./data/conf/sogo/:/etc/sogo/:z
|
- ./data/conf/sogo/:/etc/sogo/:z
|
||||||
- ./data/conf/phpfpm/sogo-sso/:/etc/phpfpm/:z
|
- ./data/conf/phpfpm/sogo-sso/:/etc/phpfpm/:z
|
||||||
- vmail-vol-1:/var/vmail:Z
|
- vmail-vol-1:/var/vmail
|
||||||
- vmail-index-vol-1:/var/vmail_index:Z
|
- vmail-index-vol-1:/var/vmail_index
|
||||||
- crypt-vol-1:/mail_crypt/:z
|
- crypt-vol-1:/mail_crypt/
|
||||||
- ./data/conf/rspamd/custom/:/etc/rspamd/custom:z
|
- ./data/conf/rspamd/custom/:/etc/rspamd/custom:z
|
||||||
- ./data/assets/templates:/templates:z
|
- ./data/assets/templates:/templates:z
|
||||||
- rspamd-vol-1:/var/lib/rspamd:z
|
- rspamd-vol-1:/var/lib/rspamd
|
||||||
- mysql-socket-vol-1:/var/run/mysqld/:z
|
- mysql-socket-vol-1:/var/run/mysqld/
|
||||||
environment:
|
environment:
|
||||||
- DOVECOT_MASTER_USER=${DOVECOT_MASTER_USER:-}
|
- DOVECOT_MASTER_USER=${DOVECOT_MASTER_USER:-}
|
||||||
- DOVECOT_MASTER_PASS=${DOVECOT_MASTER_PASS:-}
|
- DOVECOT_MASTER_PASS=${DOVECOT_MASTER_PASS:-}
|
||||||
@@ -292,17 +295,17 @@ services:
|
|||||||
- dovecot
|
- dovecot
|
||||||
|
|
||||||
postfix-mailcow:
|
postfix-mailcow:
|
||||||
image: mailcow/postfix:1.66
|
image: mailcow/postfix:1.67
|
||||||
depends_on:
|
depends_on:
|
||||||
- mysql-mailcow
|
- mysql-mailcow
|
||||||
volumes:
|
volumes:
|
||||||
- ./data/hooks/postfix:/hooks:Z
|
- ./data/hooks/postfix:/hooks:Z
|
||||||
- ./data/conf/postfix:/opt/postfix/conf:z
|
- ./data/conf/postfix:/opt/postfix/conf:z
|
||||||
- ./data/assets/ssl:/etc/ssl/mail/:ro,z
|
- ./data/assets/ssl:/etc/ssl/mail/:ro,z
|
||||||
- postfix-vol-1:/var/spool/postfix:z
|
- postfix-vol-1:/var/spool/postfix
|
||||||
- crypt-vol-1:/var/lib/zeyple:z
|
- crypt-vol-1:/var/lib/zeyple
|
||||||
- rspamd-vol-1:/var/lib/rspamd:z
|
- rspamd-vol-1:/var/lib/rspamd
|
||||||
- mysql-socket-vol-1:/var/run/mysqld/:z
|
- mysql-socket-vol-1:/var/run/mysqld/
|
||||||
environment:
|
environment:
|
||||||
- LOG_LINES=${LOG_LINES:-9999}
|
- LOG_LINES=${LOG_LINES:-9999}
|
||||||
- TZ=${TZ}
|
- TZ=${TZ}
|
||||||
@@ -372,10 +375,10 @@ services:
|
|||||||
- ./data/assets/ssl/:/etc/ssl/mail/:ro,z
|
- ./data/assets/ssl/:/etc/ssl/mail/:ro,z
|
||||||
- ./data/conf/nginx/:/etc/nginx/conf.d/:z
|
- ./data/conf/nginx/:/etc/nginx/conf.d/:z
|
||||||
- ./data/conf/rspamd/meta_exporter:/meta_exporter:ro,z
|
- ./data/conf/rspamd/meta_exporter:/meta_exporter:ro,z
|
||||||
- sogo-web-vol-1:/usr/lib/GNUstep/SOGo/:z
|
- sogo-web-vol-1:/usr/lib/GNUstep/SOGo/
|
||||||
ports:
|
ports:
|
||||||
- "${HTTPS_BIND:-:}:${HTTPS_PORT:-443}:${HTTPS_PORT:-443}"
|
- "${HTTPS_BIND:-}:${HTTPS_PORT:-443}:${HTTPS_PORT:-443}"
|
||||||
- "${HTTP_BIND:-:}:${HTTP_PORT:-80}:${HTTP_PORT:-80}"
|
- "${HTTP_BIND:-}:${HTTP_PORT:-80}:${HTTP_PORT:-80}"
|
||||||
restart: always
|
restart: always
|
||||||
networks:
|
networks:
|
||||||
mailcow-network:
|
mailcow-network:
|
||||||
@@ -385,7 +388,7 @@ services:
|
|||||||
acme-mailcow:
|
acme-mailcow:
|
||||||
depends_on:
|
depends_on:
|
||||||
- nginx-mailcow
|
- nginx-mailcow
|
||||||
image: mailcow/acme:1.81
|
image: mailcow/acme:1.82
|
||||||
dns:
|
dns:
|
||||||
- ${IPV4_NETWORK:-172.22.1}.254
|
- ${IPV4_NETWORK:-172.22.1}.254
|
||||||
environment:
|
environment:
|
||||||
@@ -413,7 +416,7 @@ services:
|
|||||||
- ./data/web/.well-known/acme-challenge:/var/www/acme:z
|
- ./data/web/.well-known/acme-challenge:/var/www/acme:z
|
||||||
- ./data/assets/ssl:/var/lib/acme/:z
|
- ./data/assets/ssl:/var/lib/acme/:z
|
||||||
- ./data/assets/ssl-example:/var/lib/ssl-example/:ro,Z
|
- ./data/assets/ssl-example:/var/lib/ssl-example/:ro,Z
|
||||||
- mysql-socket-vol-1:/var/run/mysqld/:z
|
- mysql-socket-vol-1:/var/run/mysqld/
|
||||||
restart: always
|
restart: always
|
||||||
networks:
|
networks:
|
||||||
mailcow-network:
|
mailcow-network:
|
||||||
@@ -421,7 +424,7 @@ services:
|
|||||||
- acme
|
- acme
|
||||||
|
|
||||||
netfilter-mailcow:
|
netfilter-mailcow:
|
||||||
image: mailcow/netfilter:1.46
|
image: mailcow/netfilter:1.48
|
||||||
stop_grace_period: 30s
|
stop_grace_period: 30s
|
||||||
depends_on:
|
depends_on:
|
||||||
- dovecot-mailcow
|
- dovecot-mailcow
|
||||||
@@ -450,9 +453,9 @@ services:
|
|||||||
tmpfs:
|
tmpfs:
|
||||||
- /tmp
|
- /tmp
|
||||||
volumes:
|
volumes:
|
||||||
- rspamd-vol-1:/var/lib/rspamd:z
|
- rspamd-vol-1:/var/lib/rspamd
|
||||||
- mysql-socket-vol-1:/var/run/mysqld/:z
|
- mysql-socket-vol-1:/var/run/mysqld/
|
||||||
- postfix-vol-1:/var/spool/postfix:z
|
- postfix-vol-1:/var/spool/postfix
|
||||||
- ./data/assets/ssl:/etc/ssl/mail/:ro,z
|
- ./data/assets/ssl:/etc/ssl/mail/:ro,z
|
||||||
restart: always
|
restart: always
|
||||||
environment:
|
environment:
|
||||||
@@ -506,7 +509,7 @@ services:
|
|||||||
- watchdog
|
- watchdog
|
||||||
|
|
||||||
dockerapi-mailcow:
|
dockerapi-mailcow:
|
||||||
image: mailcow/dockerapi:1.41
|
image: mailcow/dockerapi:1.42
|
||||||
security_opt:
|
security_opt:
|
||||||
- label=disable
|
- label=disable
|
||||||
restart: always
|
restart: always
|
||||||
@@ -527,7 +530,7 @@ services:
|
|||||||
image: mailcow/solr:1.8.1
|
image: mailcow/solr:1.8.1
|
||||||
restart: always
|
restart: always
|
||||||
volumes:
|
volumes:
|
||||||
- solr-vol-1:/opt/solr/server/solr/dovecot-fts/data:Z
|
- solr-vol-1:/opt/solr/server/solr/dovecot-fts/data
|
||||||
ports:
|
ports:
|
||||||
- "${SOLR_PORT:-127.0.0.1:18983}:8983"
|
- "${SOLR_PORT:-127.0.0.1:18983}:8983"
|
||||||
environment:
|
environment:
|
||||||
@@ -540,7 +543,7 @@ services:
|
|||||||
- solr
|
- solr
|
||||||
|
|
||||||
olefy-mailcow:
|
olefy-mailcow:
|
||||||
image: mailcow/olefy:1.9
|
image: mailcow/olefy:1.10
|
||||||
restart: always
|
restart: always
|
||||||
environment:
|
environment:
|
||||||
- TZ=${TZ}
|
- TZ=${TZ}
|
||||||
@@ -631,3 +634,4 @@ volumes:
|
|||||||
crypt-vol-1:
|
crypt-vol-1:
|
||||||
sogo-web-vol-1:
|
sogo-web-vol-1:
|
||||||
sogo-userdata-backup-vol-1:
|
sogo-userdata-backup-vol-1:
|
||||||
|
clamd-db-vol-1:
|
||||||
|
@@ -25,7 +25,7 @@ if cp --help 2>&1 | grep -q -i "busybox"; then
|
|||||||
exit 1
|
exit 1
|
||||||
fi
|
fi
|
||||||
|
|
||||||
for bin in openssl curl docker-compose docker git awk sha1sum; do
|
for bin in openssl curl docker docker-compose git awk sha1sum; do
|
||||||
if [[ -z $(which ${bin}) ]]; then echo "Cannot find ${bin}, exiting..."; exit 1; fi
|
if [[ -z $(which ${bin}) ]]; then echo "Cannot find ${bin}, exiting..."; exit 1; fi
|
||||||
done
|
done
|
||||||
|
|
||||||
@@ -144,7 +144,7 @@ DBROOT=$(LC_ALL=C </dev/urandom tr -dc A-Za-z0-9 | head -c 28)
|
|||||||
# Do _not_ use IP:PORT in HTTP(S)_BIND or HTTP(S)_PORT
|
# Do _not_ use IP:PORT in HTTP(S)_BIND or HTTP(S)_PORT
|
||||||
# IMPORTANT: Do not use port 8081, 9081 or 65510!
|
# IMPORTANT: Do not use port 8081, 9081 or 65510!
|
||||||
# Example: HTTP_BIND=1.2.3.4
|
# Example: HTTP_BIND=1.2.3.4
|
||||||
# For IPv4 and IPv6 leave it empty: HTTP_BIND= & HTTPS_PORT=
|
# For IPv4 leave it as it is: HTTP_BIND= & HTTPS_PORT=
|
||||||
# For IPv6 see https://mailcow.github.io/mailcow-dockerized-docs/post_installation/firststeps-ip_bindings/
|
# For IPv6 see https://mailcow.github.io/mailcow-dockerized-docs/post_installation/firststeps-ip_bindings/
|
||||||
|
|
||||||
HTTP_PORT=80
|
HTTP_PORT=80
|
||||||
|
@@ -77,7 +77,7 @@ function preflight_local_checks() {
|
|||||||
exit 1
|
exit 1
|
||||||
fi
|
fi
|
||||||
|
|
||||||
for bin in rsync docker-compose docker grep cut; do
|
for bin in rsync docker docker-compose grep cut; do
|
||||||
if [[ -z $(which ${bin}) ]]; then
|
if [[ -z $(which ${bin}) ]]; then
|
||||||
>&2 echo -e "\e[31mCannot find ${bin} in local PATH, exiting...\e[0m"
|
>&2 echo -e "\e[31mCannot find ${bin} in local PATH, exiting...\e[0m"
|
||||||
exit 1
|
exit 1
|
||||||
@@ -85,7 +85,7 @@ function preflight_local_checks() {
|
|||||||
done
|
done
|
||||||
|
|
||||||
if grep --help 2>&1 | head -n 1 | grep -q -i "busybox"; then
|
if grep --help 2>&1 | head -n 1 | grep -q -i "busybox"; then
|
||||||
>&2 echo -e "\e[31mBusyBox grep detected on local system, please install GNU grep\e[0m"
|
echo -e "\e[31mBusyBox grep detected on local system, please install GNU grep\e[0m"
|
||||||
exit 1
|
exit 1
|
||||||
fi
|
fi
|
||||||
}
|
}
|
||||||
@@ -111,7 +111,7 @@ function preflight_remote_checks() {
|
|||||||
exit 1
|
exit 1
|
||||||
fi
|
fi
|
||||||
|
|
||||||
for bin in rsync docker-compose docker; do
|
for bin in rsync docker docker-compose; do
|
||||||
if ! ssh -o StrictHostKeyChecking=no \
|
if ! ssh -o StrictHostKeyChecking=no \
|
||||||
-i "${REMOTE_SSH_KEY}" \
|
-i "${REMOTE_SSH_KEY}" \
|
||||||
${REMOTE_SSH_HOST} \
|
${REMOTE_SSH_HOST} \
|
||||||
@@ -121,7 +121,6 @@ function preflight_remote_checks() {
|
|||||||
exit 1
|
exit 1
|
||||||
fi
|
fi
|
||||||
done
|
done
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
preflight_local_checks
|
preflight_local_checks
|
||||||
@@ -252,16 +251,18 @@ if ! ssh -o StrictHostKeyChecking=no \
|
|||||||
fi
|
fi
|
||||||
echo "OK"
|
echo "OK"
|
||||||
|
|
||||||
echo -e "\033[1mPulling images on remote...\033[0m"
|
echo -e "\e[33mPulling images on remote...\e[0m"
|
||||||
if ! ssh -o StrictHostKeyChecking=no \
|
echo -e "\e[33mProcess is NOT stuck! Please wait...\e[0m"
|
||||||
|
|
||||||
|
if ! ssh -o StrictHostKeyChecking=no \
|
||||||
-i "${REMOTE_SSH_KEY}" \
|
-i "${REMOTE_SSH_KEY}" \
|
||||||
${REMOTE_SSH_HOST} \
|
${REMOTE_SSH_HOST} \
|
||||||
-p ${REMOTE_SSH_PORT} \
|
-p ${REMOTE_SSH_PORT} \
|
||||||
docker-compose -f "${SCRIPT_DIR}/../docker-compose.yml" pull --no-parallel 2>&1 ; then
|
docker-compose -f "${SCRIPT_DIR}/../docker-compose.yml" pull --no-parallel --quiet 2>&1 ; then
|
||||||
>&2 echo -e "\e[31m[ERR]\e[0m - Could not pull images on remote"
|
>&2 echo -e "\e[31m[ERR]\e[0m - Could not pull images on remote"
|
||||||
fi
|
fi
|
||||||
|
|
||||||
echo -e "\033[1mForcing garbage cleanup on remote...\033[0m"
|
echo -e "\033[1mExecuting update script and forcing garbage cleanup on remote...\033[0m"
|
||||||
if ! ssh -o StrictHostKeyChecking=no \
|
if ! ssh -o StrictHostKeyChecking=no \
|
||||||
-i "${REMOTE_SSH_KEY}" \
|
-i "${REMOTE_SSH_KEY}" \
|
||||||
${REMOTE_SSH_HOST} \
|
${REMOTE_SSH_HOST} \
|
||||||
|
@@ -76,6 +76,19 @@ else
|
|||||||
CMPS_PRJ=$(echo ${COMPOSE_PROJECT_NAME} | tr -cd "[0-9A-Za-z-_]")
|
CMPS_PRJ=$(echo ${COMPOSE_PROJECT_NAME} | tr -cd "[0-9A-Za-z-_]")
|
||||||
fi
|
fi
|
||||||
|
|
||||||
|
for bin in docker docker-compose; do
|
||||||
|
if [[ -z $(which ${bin}) ]]; then
|
||||||
|
>&2 echo -e "\e[31mCannot find ${bin} in local PATH, exiting...\e[0m"
|
||||||
|
exit 1
|
||||||
|
fi
|
||||||
|
done
|
||||||
|
|
||||||
|
if grep --help 2>&1 | head -n 1 | grep -q -i "busybox"; then
|
||||||
|
>&2 echo -e "\e[31mBusyBox grep detected on local system, please install GNU grep\e[0m"
|
||||||
|
exit 1
|
||||||
|
fi
|
||||||
|
|
||||||
|
|
||||||
function backup() {
|
function backup() {
|
||||||
DATE=$(date +"%Y-%m-%d-%H-%M-%S")
|
DATE=$(date +"%Y-%m-%d-%H-%M-%S")
|
||||||
mkdir -p "${BACKUP_LOCATION}/mailcow-${DATE}"
|
mkdir -p "${BACKUP_LOCATION}/mailcow-${DATE}"
|
||||||
|
154
update.sh
154
update.sh
@@ -40,8 +40,20 @@ PATH=$PATH:/opt/bin
|
|||||||
|
|
||||||
umask 0022
|
umask 0022
|
||||||
|
|
||||||
for bin in curl docker-compose docker git awk sha1sum; do
|
for bin in curl docker git awk sha1sum; do
|
||||||
if [[ -z $(which ${bin}) ]]; then echo "Cannot find ${bin}, exiting..."; exit 1; fi
|
if [[ -z $(which ${bin}) ]]; then
|
||||||
|
echo "Cannot find ${bin}, exiting..."
|
||||||
|
exit 1;
|
||||||
|
elif [[ -z $(which docker-compose) ]]; then
|
||||||
|
echo "Cannot find docker-compose Standalone. Installing..."
|
||||||
|
sleep 3
|
||||||
|
if [[ -e /etc/alpine-release ]]; then
|
||||||
|
echo -e "\e[33mNot installing latest docker-compose, because you are using Alpine Linux without glibc support. Install docker-compose via apk!\e[0m"
|
||||||
|
exit 1
|
||||||
|
fi
|
||||||
|
curl -#L https://github.com/docker/compose/releases/download/v$(curl -Ls https://www.servercow.de/docker-compose/latest.php)/docker-compose-$(uname -s)-$(uname -m) > /usr/local/bin/docker-compose
|
||||||
|
chmod +x /usr/local/bin/docker-compose
|
||||||
|
fi
|
||||||
done
|
done
|
||||||
|
|
||||||
export LC_ALL=C
|
export LC_ALL=C
|
||||||
@@ -197,6 +209,70 @@ migrate_docker_nat() {
|
|||||||
fi
|
fi
|
||||||
}
|
}
|
||||||
|
|
||||||
|
remove_obsolete_nginx_ports() {
|
||||||
|
# Removing obsolete docker-compose.override.yml
|
||||||
|
for override in docker-compose.override.yml docker-compose.override.yaml; do
|
||||||
|
if [ -s $override ] ; then
|
||||||
|
if cat $override | grep nginx-mailcow > /dev/null 2>&1; then
|
||||||
|
if cat $override | grep -w [::] > /dev/null 2>&1; then
|
||||||
|
if cat $override | grep -w 80:80 > /dev/null 2>&1 && cat $override | grep -w 443:443 > /dev/null 2>&1 ; then
|
||||||
|
sed -i '/nginx-mailcow:$/,/^$/d' $override
|
||||||
|
echo -e "\e[33mRemoved obsolete NGINX IPv6 Bind from override File.\e[0m"
|
||||||
|
if [[ "$(cat $override | sed '/^\s*$/d' | wc -l)" == "2" ]]; then
|
||||||
|
mv $override ${override}_backup
|
||||||
|
echo -e "\e[31m${override} is empty. Renamed it to ensure mailcow is startable.\e[0m"
|
||||||
|
fi
|
||||||
|
fi
|
||||||
|
fi
|
||||||
|
fi
|
||||||
|
fi
|
||||||
|
done
|
||||||
|
}
|
||||||
|
|
||||||
|
update_compose(){
|
||||||
|
if [[ ${NO_UPDATE_COMPOSE} == "y" ]]; then
|
||||||
|
echo -e "\e[33mNot fetching latest docker-compose, please check for updates manually!\e[0m"
|
||||||
|
return 0
|
||||||
|
elif [[ -e /etc/alpine-release ]]; then
|
||||||
|
echo -e "\e[33mNot fetching latest docker-compose, because you are using Alpine Linux without glibc support. Please update docker-compose via apk!\e[0m"
|
||||||
|
return 0
|
||||||
|
else
|
||||||
|
echo -e "\e[32mFetching new docker-compose version...\e[0m"
|
||||||
|
echo -e "\e[32mTrying to determine GLIBC version...\e[0m"
|
||||||
|
if ldd --version > /dev/null; then
|
||||||
|
GLIBC_V=$(ldd --version | grep -E '(GLIBC|GNU libc)' | rev | cut -d ' ' -f1 | rev | cut -d '.' -f2)
|
||||||
|
if [ ! -z "${GLIBC_V}" ] && [ ${GLIBC_V} -gt 27 ]; then
|
||||||
|
DC_DL_SUFFIX=
|
||||||
|
else
|
||||||
|
DC_DL_SUFFIX=legacy
|
||||||
|
fi
|
||||||
|
else
|
||||||
|
DC_DL_SUFFIX=legacy
|
||||||
|
fi
|
||||||
|
sleep 1
|
||||||
|
if [[ ! -z $(which pip) && $(pip list --local 2>&1 | grep -v DEPRECATION | grep -c docker-compose) == 1 ]]; then
|
||||||
|
true
|
||||||
|
#prevent breaking a working docker-compose installed with pip
|
||||||
|
elif [[ $(curl -sL -w "%{http_code}" https://www.servercow.de/docker-compose/latest.php?vers=${DC_DL_SUFFIX} -o /dev/null) == "200" ]]; then
|
||||||
|
LATEST_COMPOSE=$(curl -#L https://www.servercow.de/docker-compose/latest.php)
|
||||||
|
COMPOSE_VERSION=$(docker-compose version --short)
|
||||||
|
if [[ "$LATEST_COMPOSE" != "$COMPOSE_VERSION" ]]; then
|
||||||
|
COMPOSE_PATH=$(which docker-compose)
|
||||||
|
if [[ -w ${COMPOSE_PATH} ]]; then
|
||||||
|
curl -#L https://github.com/docker/compose/releases/download/v${LATEST_COMPOSE}/docker-compose-$(uname -s)-$(uname -m) > $COMPOSE_PATH
|
||||||
|
chmod +x $COMPOSE_PATH
|
||||||
|
else
|
||||||
|
echo -e "\e[33mWARNING: $COMPOSE_PATH is not writable, but new version $LATEST_COMPOSE is available (installed: $COMPOSE_VERSION)\e[0m"
|
||||||
|
return 1
|
||||||
|
fi
|
||||||
|
fi
|
||||||
|
else
|
||||||
|
echo -e "\e[33mCannot determine latest docker-compose version, skipping...\e[0m"
|
||||||
|
return 1
|
||||||
|
fi
|
||||||
|
fi
|
||||||
|
}
|
||||||
|
|
||||||
while (($#)); do
|
while (($#)); do
|
||||||
case "${1}" in
|
case "${1}" in
|
||||||
--check|-c)
|
--check|-c)
|
||||||
@@ -238,8 +314,11 @@ while (($#)); do
|
|||||||
--no-update-compose)
|
--no-update-compose)
|
||||||
NO_UPDATE_COMPOSE=y
|
NO_UPDATE_COMPOSE=y
|
||||||
;;
|
;;
|
||||||
|
--skip-ping-check)
|
||||||
|
SKIP_PING_CHECK=y
|
||||||
|
;;
|
||||||
--help|-h)
|
--help|-h)
|
||||||
echo './update.sh [-c|--check, --ours, --gc, --no-update-compose, --prefetch, --skip-start, -f|--force, -h|--help]
|
echo './update.sh [-c|--check, --ours, --gc, --no-update-compose, --prefetch, --skip-start, --skip-ping-check, -f|--force, -h|--help]
|
||||||
|
|
||||||
-c|--check - Check for updates and exit (exit codes => 0: update available, 3: no updates)
|
-c|--check - Check for updates and exit (exit codes => 0: update available, 3: no updates)
|
||||||
--ours - Use merge strategy option "ours" to solve conflicts in favor of non-mailcow code (local changes over remote changes), not recommended!
|
--ours - Use merge strategy option "ours" to solve conflicts in favor of non-mailcow code (local changes over remote changes), not recommended!
|
||||||
@@ -247,6 +326,7 @@ while (($#)); do
|
|||||||
--no-update-compose - Do not update docker-compose
|
--no-update-compose - Do not update docker-compose
|
||||||
--prefetch - Only prefetch new images and exit (useful to prepare updates)
|
--prefetch - Only prefetch new images and exit (useful to prepare updates)
|
||||||
--skip-start - Do not start mailcow after update
|
--skip-start - Do not start mailcow after update
|
||||||
|
--skip-ping-check - Skip ICMP Check to public DNS resolvers (Use it only if you´ve blocked any ICMP Connections to your mailcow machine).
|
||||||
-f|--force - Force update, do not ask questions
|
-f|--force - Force update, do not ask questions
|
||||||
'
|
'
|
||||||
exit 1
|
exit 1
|
||||||
@@ -533,18 +613,23 @@ elif [[ ${option} == "WATCHDOG_VERBOSE" ]]; then
|
|||||||
fi
|
fi
|
||||||
done
|
done
|
||||||
|
|
||||||
echo -en "Checking internet connection... "
|
if [[( ${SKIP_PING_CHECK} == "y")]]; then
|
||||||
if ! check_online_status; then
|
echo -e "\e[32mSkipping Ping Check...\e[0m"
|
||||||
|
|
||||||
|
else
|
||||||
|
echo -en "Checking internet connection... "
|
||||||
|
if ! check_online_status; then
|
||||||
echo -e "\e[31mfailed\e[0m"
|
echo -e "\e[31mfailed\e[0m"
|
||||||
exit 1
|
exit 1
|
||||||
else
|
else
|
||||||
echo -e "\e[32mOK\e[0m"
|
echo -e "\e[32mOK\e[0m"
|
||||||
|
fi
|
||||||
fi
|
fi
|
||||||
|
|
||||||
echo -e "\e[32mChecking for newer update script...\e[0m"
|
echo -e "\e[32mChecking for newer update script...\e[0m"
|
||||||
SHA1_1=$(sha1sum update.sh)
|
SHA1_1=$(sha1sum update.sh)
|
||||||
git fetch origin #${BRANCH}
|
git fetch origin #${BRANCH}
|
||||||
git checkout origin/${BRANCH} update.sh
|
git checkout origin/${BRANCH} update.sh docker-compose.yml
|
||||||
SHA1_2=$(sha1sum update.sh)
|
SHA1_2=$(sha1sum update.sh)
|
||||||
if [[ ${SHA1_1} != ${SHA1_2} ]]; then
|
if [[ ${SHA1_1} != ${SHA1_2} ]]; then
|
||||||
echo "update.sh changed, please run this script again, exiting."
|
echo "update.sh changed, please run this script again, exiting."
|
||||||
@@ -568,6 +653,10 @@ if [ ! $FORCE ]; then
|
|||||||
migrate_docker_nat
|
migrate_docker_nat
|
||||||
fi
|
fi
|
||||||
|
|
||||||
|
update_compose
|
||||||
|
|
||||||
|
remove_obsolete_nginx_ports
|
||||||
|
|
||||||
echo -e "\e[32mValidating docker-compose stack configuration...\e[0m"
|
echo -e "\e[32mValidating docker-compose stack configuration...\e[0m"
|
||||||
if ! docker-compose config -q; then
|
if ! docker-compose config -q; then
|
||||||
echo -e "\e[31m\nOh no, something went wrong. Please check the error message above.\e[0m"
|
echo -e "\e[31m\nOh no, something went wrong. Please check the error message above.\e[0m"
|
||||||
@@ -637,44 +726,6 @@ elif [[ ${MERGE_RETURN} != 0 ]]; then
|
|||||||
exit 1
|
exit 1
|
||||||
fi
|
fi
|
||||||
|
|
||||||
if [[ ${NO_UPDATE_COMPOSE} == "y" ]]; then
|
|
||||||
echo -e "\e[33mNot fetching latest docker-compose, please check for updates manually!\e[0m"
|
|
||||||
elif [[ -e /etc/alpine-release ]]; then
|
|
||||||
echo -e "\e[33mNot fetching latest docker-compose, because you are using Alpine Linux without glibc support. Please update docker-compose via apk!\e[0m"
|
|
||||||
else
|
|
||||||
echo -e "\e[32mFetching new docker-compose version...\e[0m"
|
|
||||||
echo -e "\e[32mTrying to determine GLIBC version...\e[0m"
|
|
||||||
if ldd --version > /dev/null; then
|
|
||||||
GLIBC_V=$(ldd --version | grep -E '(GLIBC|GNU libc)' | rev | cut -d ' ' -f1 | rev | cut -d '.' -f2)
|
|
||||||
if [ ! -z "${GLIBC_V}" ] && [ ${GLIBC_V} -gt 27 ]; then
|
|
||||||
DC_DL_SUFFIX=
|
|
||||||
else
|
|
||||||
DC_DL_SUFFIX=legacy
|
|
||||||
fi
|
|
||||||
else
|
|
||||||
DC_DL_SUFFIX=legacy
|
|
||||||
fi
|
|
||||||
sleep 1
|
|
||||||
if [[ ! -z $(which pip) && $(pip list --local 2>&1 | grep -v DEPRECATION | grep -c docker-compose) == 1 ]]; then
|
|
||||||
true
|
|
||||||
#prevent breaking a working docker-compose installed with pip
|
|
||||||
elif [[ $(curl -sL -w "%{http_code}" https://www.servercow.de/docker-compose/latest.php?vers=${DC_DL_SUFFIX} -o /dev/null) == "200" ]]; then
|
|
||||||
LATEST_COMPOSE=$(curl -#L https://www.servercow.de/docker-compose/latest.php)
|
|
||||||
COMPOSE_VERSION=$(docker-compose version --short)
|
|
||||||
if [[ "$LATEST_COMPOSE" != "$COMPOSE_VERSION" ]]; then
|
|
||||||
COMPOSE_PATH=$(which docker-compose)
|
|
||||||
if [[ -w ${COMPOSE_PATH} ]]; then
|
|
||||||
curl -#L https://github.com/docker/compose/releases/download/${LATEST_COMPOSE}/docker-compose-$(uname -s)-$(uname -m) > $COMPOSE_PATH
|
|
||||||
chmod +x $COMPOSE_PATH
|
|
||||||
else
|
|
||||||
echo -e "\e[33mWARNING: $COMPOSE_PATH is not writable, but new version $LATEST_COMPOSE is available (installed: $COMPOSE_VERSION)\e[0m"
|
|
||||||
fi
|
|
||||||
fi
|
|
||||||
else
|
|
||||||
echo -e "\e[33mCannot determine latest docker-compose version, skipping...\e[0m"
|
|
||||||
fi
|
|
||||||
fi
|
|
||||||
|
|
||||||
echo -e "\e[32mFetching new images, if any...\e[0m"
|
echo -e "\e[32mFetching new images, if any...\e[0m"
|
||||||
sleep 2
|
sleep 2
|
||||||
docker-compose pull
|
docker-compose pull
|
||||||
@@ -698,9 +749,6 @@ fi
|
|||||||
|
|
||||||
# Checking for old project name bug
|
# Checking for old project name bug
|
||||||
sed -i --follow-symlinks 's#COMPOSEPROJECT_NAME#COMPOSE_PROJECT_NAME#g' mailcow.conf
|
sed -i --follow-symlinks 's#COMPOSEPROJECT_NAME#COMPOSE_PROJECT_NAME#g' mailcow.conf
|
||||||
# Checking old, wrong bindings
|
|
||||||
sed -i --follow-symlinks 's/HTTP_BIND=0.0.0.0/HTTP_BIND=/g' mailcow.conf
|
|
||||||
sed -i --follow-symlinks 's/HTTPS_BIND=0.0.0.0/HTTPS_BIND=/g' mailcow.conf
|
|
||||||
|
|
||||||
# Fix Rspamd maps
|
# Fix Rspamd maps
|
||||||
if [ -f data/conf/rspamd/custom/global_from_blacklist.map ]; then
|
if [ -f data/conf/rspamd/custom/global_from_blacklist.map ]; then
|
||||||
@@ -750,8 +798,8 @@ if [ -f "${SCRIPT_DIR}/post_update_hook.sh" ]; then
|
|||||||
bash "${SCRIPT_DIR}/post_update_hook.sh"
|
bash "${SCRIPT_DIR}/post_update_hook.sh"
|
||||||
fi
|
fi
|
||||||
|
|
||||||
#echo "In case you encounter any problem, hard-reset to a state before updating mailcow:"
|
# echo "In case you encounter any problem, hard-reset to a state before updating mailcow:"
|
||||||
#echo
|
# echo
|
||||||
#git reflog --color=always | grep "Before update on "
|
# git reflog --color=always | grep "Before update on "
|
||||||
#echo
|
# echo
|
||||||
#echo "Use \"git reset --hard hash-on-the-left\" and run docker-compose up -d afterwards."
|
# echo "Use \"git reset --hard hash-on-the-left\" and run docker-compose up -d afterwards."
|
Reference in New Issue
Block a user