2019-10-29 08:39:57 +01:00
|
|
|
<?php
|
|
|
|
function rsettings($_action, $_data = null) {
|
|
|
|
global $pdo;
|
|
|
|
global $lang;
|
|
|
|
$_data_log = $_data;
|
|
|
|
switch ($_action) {
|
|
|
|
case 'add':
|
|
|
|
if ($_SESSION['mailcow_cc_role'] != "admin") {
|
|
|
|
$_SESSION['return'][] = array(
|
|
|
|
'type' => 'danger',
|
|
|
|
'log' => array(__FUNCTION__, $_action, $_data_log),
|
|
|
|
'msg' => 'access_denied'
|
|
|
|
);
|
|
|
|
return false;
|
|
|
|
}
|
|
|
|
$content = $_data['content'];
|
|
|
|
$desc = $_data['desc'];
|
|
|
|
$active = intval($_data['active']);
|
|
|
|
if (empty($content)) {
|
|
|
|
$_SESSION['return'][] = array(
|
|
|
|
'type' => 'danger',
|
|
|
|
'log' => array(__FUNCTION__, $_action, $_data_log),
|
|
|
|
'msg' => 'map_content_empty'
|
|
|
|
);
|
|
|
|
return false;
|
|
|
|
}
|
2020-11-25 16:10:33 +01:00
|
|
|
$stmt = $pdo->prepare("INSERT INTO `settingsmap` (`content`, `desc`, `active`)
|
|
|
|
VALUES (:content, :desc, :active)");
|
|
|
|
$stmt->execute(array(
|
|
|
|
':content' => $content,
|
|
|
|
':desc' => $desc,
|
|
|
|
':active' => $active
|
|
|
|
));
|
2019-10-29 08:39:57 +01:00
|
|
|
$_SESSION['return'][] = array(
|
|
|
|
'type' => 'success',
|
|
|
|
'log' => array(__FUNCTION__, $_action, $_data_log),
|
|
|
|
'msg' => 'settings_map_added'
|
|
|
|
);
|
|
|
|
break;
|
|
|
|
case 'edit':
|
|
|
|
if ($_SESSION['mailcow_cc_role'] != "admin") {
|
|
|
|
$_SESSION['return'][] = array(
|
|
|
|
'type' => 'danger',
|
|
|
|
'log' => array(__FUNCTION__, $_action, $_data_log),
|
|
|
|
'msg' => 'access_denied'
|
|
|
|
);
|
|
|
|
return false;
|
|
|
|
}
|
|
|
|
$ids = (array)$_data['id'];
|
|
|
|
foreach ($ids as $id) {
|
|
|
|
$is_now = rsettings('details', $id);
|
|
|
|
if (!empty($is_now)) {
|
|
|
|
$content = (!empty($_data['content'])) ? $_data['content'] : $is_now['content'];
|
|
|
|
$desc = (!empty($_data['desc'])) ? $_data['desc'] : $is_now['desc'];
|
2020-09-17 19:49:15 +02:00
|
|
|
$active = (isset($_data['active'])) ? intval($_data['active']) : $is_now['active'];
|
2019-10-29 08:39:57 +01:00
|
|
|
}
|
|
|
|
else {
|
|
|
|
$_SESSION['return'][] = array(
|
|
|
|
'type' => 'danger',
|
|
|
|
'log' => array(__FUNCTION__, $_action, $_data_log),
|
|
|
|
'msg' => array('settings_map_invalid', $id)
|
|
|
|
);
|
|
|
|
continue;
|
|
|
|
}
|
|
|
|
$content = trim($content);
|
2020-11-25 16:10:33 +01:00
|
|
|
$stmt = $pdo->prepare("UPDATE `settingsmap` SET
|
|
|
|
`content` = :content,
|
|
|
|
`desc` = :desc,
|
|
|
|
`active` = :active
|
|
|
|
WHERE `id` = :id");
|
|
|
|
$stmt->execute(array(
|
|
|
|
':content' => $content,
|
|
|
|
':desc' => $desc,
|
|
|
|
':active' => $active,
|
|
|
|
':id' => $id
|
|
|
|
));
|
2019-10-29 08:39:57 +01:00
|
|
|
$_SESSION['return'][] = array(
|
|
|
|
'type' => 'success',
|
|
|
|
'log' => array(__FUNCTION__, $_action, $_data_log),
|
2021-09-02 19:30:14 +02:00
|
|
|
'msg' => array('object_modified', htmlspecialchars(implode(',', $ids)))
|
2019-10-29 08:39:57 +01:00
|
|
|
);
|
|
|
|
}
|
|
|
|
break;
|
|
|
|
case 'delete':
|
|
|
|
if ($_SESSION['mailcow_cc_role'] != "admin") {
|
|
|
|
$_SESSION['return'][] = array(
|
|
|
|
'type' => 'danger',
|
|
|
|
'log' => array(__FUNCTION__, $_action, $_data_log),
|
|
|
|
'msg' => 'access_denied'
|
|
|
|
);
|
|
|
|
return false;
|
|
|
|
}
|
|
|
|
$ids = (array)$_data['id'];
|
|
|
|
foreach ($ids as $id) {
|
2020-11-25 16:10:33 +01:00
|
|
|
$stmt = $pdo->prepare("DELETE FROM `settingsmap` WHERE `id`= :id");
|
|
|
|
$stmt->execute(array(':id' => $id));
|
2019-10-29 08:39:57 +01:00
|
|
|
$_SESSION['return'][] = array(
|
|
|
|
'type' => 'success',
|
|
|
|
'log' => array(__FUNCTION__, $_action, $_data_log),
|
|
|
|
'msg' => array('settings_map_removed', htmlspecialchars($id))
|
|
|
|
);
|
|
|
|
}
|
|
|
|
break;
|
|
|
|
case 'get':
|
|
|
|
if ($_SESSION['mailcow_cc_role'] != "admin") {
|
|
|
|
return false;
|
|
|
|
}
|
|
|
|
$settingsmaps = array();
|
|
|
|
$stmt = $pdo->query("SELECT `id`, `desc`, `active` FROM `settingsmap`");
|
|
|
|
$settingsmaps = $stmt->fetchAll(PDO::FETCH_ASSOC);
|
|
|
|
return $settingsmaps;
|
|
|
|
break;
|
|
|
|
case 'details':
|
|
|
|
if ($_SESSION['mailcow_cc_role'] != "admin" || !isset($_data)) {
|
|
|
|
return false;
|
|
|
|
}
|
|
|
|
$settingsmapdata = array();
|
|
|
|
$stmt = $pdo->prepare("SELECT `id`,
|
|
|
|
`desc`,
|
|
|
|
`content`,
|
2020-09-17 19:49:15 +02:00
|
|
|
`active`
|
2019-10-29 08:39:57 +01:00
|
|
|
FROM `settingsmap`
|
|
|
|
WHERE `id` = :id");
|
|
|
|
$stmt->execute(array(':id' => $_data));
|
|
|
|
$settingsmapdata = $stmt->fetch(PDO::FETCH_ASSOC);
|
|
|
|
return $settingsmapdata;
|
|
|
|
break;
|
|
|
|
}
|
|
|
|
}
|
2020-11-25 16:10:33 +01:00
|
|
|
function rspamd_maps($_action, $_data = null) {
|
2019-10-29 08:39:57 +01:00
|
|
|
global $pdo;
|
|
|
|
global $lang;
|
|
|
|
global $RSPAMD_MAPS;
|
|
|
|
$_data_log = $_data;
|
|
|
|
switch ($_action) {
|
|
|
|
case 'edit':
|
|
|
|
if ($_SESSION['mailcow_cc_role'] != "admin") {
|
|
|
|
$_SESSION['return'][] = array(
|
|
|
|
'type' => 'danger',
|
2021-03-08 12:36:23 +01:00
|
|
|
'log' => array(__FUNCTION__, $_action, '-'),
|
2019-10-29 08:39:57 +01:00
|
|
|
'msg' => 'access_denied'
|
|
|
|
);
|
|
|
|
return false;
|
|
|
|
}
|
|
|
|
$maps = (array)$_data['map'];
|
2024-04-03 10:08:18 +02:00
|
|
|
$valid_maps = array();
|
2019-10-29 08:39:57 +01:00
|
|
|
foreach ($maps as $map) {
|
2019-12-27 15:51:23 +01:00
|
|
|
foreach ($RSPAMD_MAPS as $rspamd_map_type) {
|
|
|
|
if (!in_array($map, $rspamd_map_type)) {
|
|
|
|
$_SESSION['return'][] = array(
|
|
|
|
'type' => 'danger',
|
2021-03-08 12:36:23 +01:00
|
|
|
'log' => array(__FUNCTION__, $_action, '-'),
|
2019-12-27 15:51:23 +01:00
|
|
|
'msg' => array('global_map_invalid', $map)
|
|
|
|
);
|
2024-04-03 10:08:18 +02:00
|
|
|
} else {
|
|
|
|
array_push($valid_maps, $map);
|
2019-12-27 15:51:23 +01:00
|
|
|
}
|
2019-10-29 08:39:57 +01:00
|
|
|
}
|
2024-04-03 10:08:18 +02:00
|
|
|
}
|
|
|
|
foreach ($valid_maps as $map) {
|
2019-10-29 08:39:57 +01:00
|
|
|
try {
|
|
|
|
if (file_exists('/rspamd_custom_maps/' . $map)) {
|
|
|
|
$map_content = trim($_data['rspamd_map_data']);
|
|
|
|
$map_handle = fopen('/rspamd_custom_maps/' . $map, 'w');
|
|
|
|
if (!$map_handle) {
|
2020-03-19 12:23:48 +01:00
|
|
|
throw new Exception($lang['danger']['file_open_error']);
|
2019-10-29 08:39:57 +01:00
|
|
|
}
|
|
|
|
fwrite($map_handle, $map_content . PHP_EOL);
|
|
|
|
fclose($map_handle);
|
2019-10-30 20:07:58 +01:00
|
|
|
sleep(1.5);
|
|
|
|
touch('/rspamd_custom_maps/' . $map);
|
2019-10-29 08:39:57 +01:00
|
|
|
}
|
|
|
|
}
|
|
|
|
catch (Exception $e) {
|
|
|
|
$_SESSION['return'][] = array(
|
|
|
|
'type' => 'danger',
|
2021-03-08 12:36:23 +01:00
|
|
|
'log' => array(__FUNCTION__, $_action, '-'),
|
2019-10-29 08:39:57 +01:00
|
|
|
'msg' => array('global_map_write_error', htmlspecialchars($map), htmlspecialchars($e->getMessage()))
|
|
|
|
);
|
|
|
|
continue;
|
|
|
|
}
|
|
|
|
$_SESSION['return'][] = array(
|
|
|
|
'type' => 'success',
|
2021-03-08 12:36:23 +01:00
|
|
|
'log' => array(__FUNCTION__, $_action, '-'),
|
2019-10-29 08:39:57 +01:00
|
|
|
'msg' => array('object_modified', htmlspecialchars($map))
|
|
|
|
);
|
|
|
|
}
|
|
|
|
break;
|
|
|
|
}
|
2020-11-25 16:10:33 +01:00
|
|
|
}
|
|
|
|
function rspamd_actions() {
|
|
|
|
if (isset($_SESSION["mailcow_cc_role"]) && $_SESSION["mailcow_cc_role"] == "admin") {
|
|
|
|
$curl = curl_init();
|
|
|
|
curl_setopt($curl, CURLOPT_UNIX_SOCKET_PATH, '/var/lib/rspamd/rspamd.sock');
|
|
|
|
curl_setopt($curl, CURLOPT_URL,"http://rspamd/stat");
|
|
|
|
curl_setopt($curl, CURLOPT_RETURNTRANSFER, true);
|
|
|
|
$data = curl_exec($curl);
|
|
|
|
if ($data) {
|
|
|
|
$return = array();
|
|
|
|
$stats_array = json_decode($data, true)['actions'];
|
|
|
|
$stats_array['soft reject'] = $stats_array['soft reject'] + $stats_array['greylist'];
|
|
|
|
unset($stats_array['greylist']);
|
|
|
|
foreach ($stats_array as $action => $count) {
|
|
|
|
$return[] = array($action, $count);
|
|
|
|
}
|
|
|
|
return $return;
|
|
|
|
}
|
|
|
|
else {
|
|
|
|
return false;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
else {
|
|
|
|
return false;
|
|
|
|
}
|
|
|
|
}
|