mirror of
https://github.com/mail-in-a-box/mailinabox.git
synced 2025-04-04 00:17:06 +00:00
Manage the local Postgrey whitelist in the admin console
This commit is contained in:
parent
9a9a699be6
commit
0df9de30c9
@ -645,6 +645,33 @@ def privacy_status_set():
|
|||||||
utils.write_settings(config, env)
|
utils.write_settings(config, env)
|
||||||
return "OK"
|
return "OK"
|
||||||
|
|
||||||
|
@app.route('/system/postgrey-whitelist', methods=["GET","POST"])
|
||||||
|
@authorized_personnel_only
|
||||||
|
def postgrey_whitelist_handler():
|
||||||
|
conf_file="/etc/postgrey/whitelist_clients.local"
|
||||||
|
if request.method == "GET":
|
||||||
|
contents = ""
|
||||||
|
try:
|
||||||
|
with open(conf_file) as fp:
|
||||||
|
contents = fp.read()
|
||||||
|
except FileNotFoundError:
|
||||||
|
pass
|
||||||
|
return Response(contents, status=200, mimetype='text/plain')
|
||||||
|
|
||||||
|
elif request.method == "POST":
|
||||||
|
try:
|
||||||
|
contents = request.form["contents"]
|
||||||
|
with open(conf_file, "w") as fp:
|
||||||
|
fp.write(contents)
|
||||||
|
utils.shell("check_call", ["/bin/systemctl", "reload", "postgrey"])
|
||||||
|
except KeyError:
|
||||||
|
return ("Missing required parameter", 400)
|
||||||
|
except subprocess.CalledProcessError as e:
|
||||||
|
app.logger.exception(e)
|
||||||
|
return ("Postgrey reload failed", 500)
|
||||||
|
|
||||||
|
return "OK. Saved and Postgrey reloaded."
|
||||||
|
|
||||||
# MUNIN
|
# MUNIN
|
||||||
|
|
||||||
@app.route('/munin/')
|
@app.route('/munin/')
|
||||||
|
@ -94,6 +94,7 @@
|
|||||||
<li><a href="#custom_dns" onclick="return show_panel(this);">Custom DNS</a></li>
|
<li><a href="#custom_dns" onclick="return show_panel(this);">Custom DNS</a></li>
|
||||||
<li><a href="#external_dns" onclick="return show_panel(this);">External DNS</a></li>
|
<li><a href="#external_dns" onclick="return show_panel(this);">External DNS</a></li>
|
||||||
<li><a href="/admin/munin" target="_blank">Munin Monitoring</a></li>
|
<li><a href="/admin/munin" target="_blank">Munin Monitoring</a></li>
|
||||||
|
<li><a href="#postgrey_whitelist" onclick="return show_panel(this);">Postgrey whitelist</a></li>
|
||||||
</ul>
|
</ul>
|
||||||
</li>
|
</li>
|
||||||
<li class="dropdown">
|
<li class="dropdown">
|
||||||
@ -135,6 +136,10 @@
|
|||||||
{% include "custom-dns.html" %}
|
{% include "custom-dns.html" %}
|
||||||
</div>
|
</div>
|
||||||
|
|
||||||
|
<div id="panel_postgrey_whitelist" class="admin_panel">
|
||||||
|
{% include "postgrey-whitelist.html" %}
|
||||||
|
</div>
|
||||||
|
|
||||||
<div id="panel_mfa" class="admin_panel">
|
<div id="panel_mfa" class="admin_panel">
|
||||||
{% include "mfa.html" %}
|
{% include "mfa.html" %}
|
||||||
</div>
|
</div>
|
||||||
|
53
management/templates/postgrey-whitelist.html
Normal file
53
management/templates/postgrey-whitelist.html
Normal file
@ -0,0 +1,53 @@
|
|||||||
|
<style>
|
||||||
|
</style>
|
||||||
|
|
||||||
|
<h2>Postgrey Whitelist</h2>
|
||||||
|
|
||||||
|
<p>The text box below contains the contents of the system's Postgrey local client whitelist. It's comprised of a list of <em>hosts</em>, one per line, whose incoming email to this server should never be greylisted.</p>
|
||||||
|
|
||||||
|
<p>Entries may be a fully qualified domain name, an IP address, or a regular expression. Regular expressions begin and end with the character "/".</p>
|
||||||
|
|
||||||
|
<p>This file augments the whilelist provided by Postgrey.</p>
|
||||||
|
|
||||||
|
<textarea style="width:100%; height:12em" id="postgrey_whitelist"></textarea>
|
||||||
|
|
||||||
|
<button class="btn-success" onclick="save_postgrey_whitelist()">Save</button>
|
||||||
|
|
||||||
|
<script>
|
||||||
|
|
||||||
|
function show_postgrey_whitelist() {
|
||||||
|
get_postgrey_whitelist();
|
||||||
|
}
|
||||||
|
|
||||||
|
function get_postgrey_whitelist() {
|
||||||
|
api(
|
||||||
|
"/system/postgrey-whitelist",
|
||||||
|
"GET",
|
||||||
|
{ },
|
||||||
|
function(whitelist) {
|
||||||
|
var e = document.getElementById('postgrey_whitelist');
|
||||||
|
e.value = whitelist
|
||||||
|
}
|
||||||
|
);
|
||||||
|
}
|
||||||
|
|
||||||
|
function save_postgrey_whitelist() {
|
||||||
|
var e = document.getElementById('postgrey_whitelist');
|
||||||
|
api(
|
||||||
|
"/system/postgrey-whitelist",
|
||||||
|
"POST",
|
||||||
|
{
|
||||||
|
contents: e.value
|
||||||
|
},
|
||||||
|
function(data) {
|
||||||
|
if (data == "")
|
||||||
|
data = "Nothing changed.";
|
||||||
|
else
|
||||||
|
data = $("<pre/>").text(data);
|
||||||
|
show_modal_error("Postgrey Whitelist Update", data, function() {
|
||||||
|
get_postgrey_whitelist();
|
||||||
|
});
|
||||||
|
});
|
||||||
|
}
|
||||||
|
|
||||||
|
</script>
|
@ -267,6 +267,18 @@ EOF
|
|||||||
chmod +x /etc/cron.daily/mailinabox-postgrey-whitelist
|
chmod +x /etc/cron.daily/mailinabox-postgrey-whitelist
|
||||||
/etc/cron.daily/mailinabox-postgrey-whitelist
|
/etc/cron.daily/mailinabox-postgrey-whitelist
|
||||||
|
|
||||||
|
# keep the postgrey local client whitelist file in STORAGE_ROOT so it
|
||||||
|
# gets backed up
|
||||||
|
mkdir -p "$STORAGE_ROOT/mail/postgrey"
|
||||||
|
if [ ! -L "/etc/postgrey/whitelist_clients.local" ] && [ -f "/etc/postgrey/whitelist_clients.local" ]; then
|
||||||
|
# regular file (non-link) exists - move it to user-data
|
||||||
|
cp -p "/etc/postgrey/whitelist_clients.local" \
|
||||||
|
"$STORAGE_ROOT/mail/postgrey/whitelist_clients.local"
|
||||||
|
fi
|
||||||
|
ln -sf "$STORAGE_ROOT/mail/postgrey/whitelist_clients.local" \
|
||||||
|
"/etc/postgrey/whitelist_clients.local"
|
||||||
|
|
||||||
|
|
||||||
# Increase the message size limit from 10MB to 128MB.
|
# Increase the message size limit from 10MB to 128MB.
|
||||||
# The same limit is specified in nginx.conf for mail submitted via webmail and Z-Push.
|
# The same limit is specified in nginx.conf for mail submitted via webmail and Z-Push.
|
||||||
tools/editconf.py /etc/postfix/main.cf \
|
tools/editconf.py /etc/postfix/main.cf \
|
||||||
|
Loading…
Reference in New Issue
Block a user