Fixes #351
This commit is contained in:
parent
3b6a6f677d
commit
db01b08926
@ -473,15 +473,8 @@ function mailbox($_action, $_type, $_data = null) {
|
|||||||
break;
|
break;
|
||||||
case 'alias_domain':
|
case 'alias_domain':
|
||||||
$active = intval($_data['active']);
|
$active = intval($_data['active']);
|
||||||
$alias_domain = idn_to_ascii(strtolower(trim($_data['alias_domain'])));
|
$alias_domains = array_map('trim', preg_split( "/( |,|;|\n)/", $_data['alias_domain']));
|
||||||
$target_domain = idn_to_ascii(strtolower(trim($_data['target_domain'])));
|
$target_domain = idn_to_ascii(strtolower(trim($_data['target_domain'])));
|
||||||
if (!is_valid_domain_name($alias_domain)) {
|
|
||||||
$_SESSION['return'] = array(
|
|
||||||
'type' => 'danger',
|
|
||||||
'msg' => sprintf($lang['danger']['alias_domain_invalid'])
|
|
||||||
);
|
|
||||||
return false;
|
|
||||||
}
|
|
||||||
if (!is_valid_domain_name($target_domain)) {
|
if (!is_valid_domain_name($target_domain)) {
|
||||||
$_SESSION['return'] = array(
|
$_SESSION['return'] = array(
|
||||||
'type' => 'danger',
|
'type' => 'danger',
|
||||||
@ -496,66 +489,76 @@ function mailbox($_action, $_type, $_data = null) {
|
|||||||
);
|
);
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
if ($alias_domain == $target_domain) {
|
foreach ($alias_domains as $alias_domain) {
|
||||||
$_SESSION['return'] = array(
|
$alias_domain = idn_to_ascii(strtolower(trim($alias_domain)));
|
||||||
'type' => 'danger',
|
if (!is_valid_domain_name($alias_domain)) {
|
||||||
'msg' => sprintf($lang['danger']['aliasd_targetd_identical'])
|
|
||||||
);
|
|
||||||
return false;
|
|
||||||
}
|
|
||||||
try {
|
|
||||||
$stmt = $pdo->prepare("SELECT `domain` FROM `domain`
|
|
||||||
WHERE `domain`= :target_domain");
|
|
||||||
$stmt->execute(array(':target_domain' => $target_domain));
|
|
||||||
$num_results = count($stmt->fetchAll(PDO::FETCH_ASSOC));
|
|
||||||
if ($num_results == 0) {
|
|
||||||
$_SESSION['return'] = array(
|
$_SESSION['return'] = array(
|
||||||
'type' => 'danger',
|
'type' => 'danger',
|
||||||
'msg' => sprintf($lang['danger']['targetd_not_found'])
|
'msg' => sprintf($lang['danger']['alias_domain_invalid'])
|
||||||
);
|
);
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
$stmt = $pdo->prepare("SELECT `alias_domain` FROM `alias_domain` WHERE `alias_domain`= :alias_domain
|
if ($alias_domain == $target_domain) {
|
||||||
UNION
|
|
||||||
SELECT `alias_domain` FROM `alias_domain` WHERE `alias_domain`= :alias_domain_in_domain");
|
|
||||||
$stmt->execute(array(':alias_domain' => $alias_domain, ':alias_domain_in_domain' => $alias_domain));
|
|
||||||
$num_results = count($stmt->fetchAll(PDO::FETCH_ASSOC));
|
|
||||||
if ($num_results != 0) {
|
|
||||||
$_SESSION['return'] = array(
|
$_SESSION['return'] = array(
|
||||||
'type' => 'danger',
|
'type' => 'danger',
|
||||||
'msg' => sprintf($lang['danger']['aliasd_exists'])
|
'msg' => sprintf($lang['danger']['aliasd_targetd_identical'])
|
||||||
|
);
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
try {
|
||||||
|
$stmt = $pdo->prepare("SELECT `domain` FROM `domain`
|
||||||
|
WHERE `domain`= :target_domain");
|
||||||
|
$stmt->execute(array(':target_domain' => $target_domain));
|
||||||
|
$num_results = count($stmt->fetchAll(PDO::FETCH_ASSOC));
|
||||||
|
if ($num_results == 0) {
|
||||||
|
$_SESSION['return'] = array(
|
||||||
|
'type' => 'danger',
|
||||||
|
'msg' => sprintf($lang['danger']['targetd_not_found'])
|
||||||
|
);
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
$stmt = $pdo->prepare("SELECT `alias_domain` FROM `alias_domain` WHERE `alias_domain`= :alias_domain
|
||||||
|
UNION
|
||||||
|
SELECT `alias_domain` FROM `alias_domain` WHERE `alias_domain`= :alias_domain_in_domain");
|
||||||
|
$stmt->execute(array(':alias_domain' => $alias_domain, ':alias_domain_in_domain' => $alias_domain));
|
||||||
|
$num_results = count($stmt->fetchAll(PDO::FETCH_ASSOC));
|
||||||
|
if ($num_results != 0) {
|
||||||
|
$_SESSION['return'] = array(
|
||||||
|
'type' => 'danger',
|
||||||
|
'msg' => sprintf($lang['danger']['aliasd_exists'])
|
||||||
|
);
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
catch(PDOException $e) {
|
||||||
|
$_SESSION['return'] = array(
|
||||||
|
'type' => 'danger',
|
||||||
|
'msg' => 'MySQL: '.$e
|
||||||
|
);
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
try {
|
||||||
|
$stmt = $pdo->prepare("INSERT INTO `alias_domain` (`alias_domain`, `target_domain`, `active`)
|
||||||
|
VALUES (:alias_domain, :target_domain, :active)");
|
||||||
|
$stmt->execute(array(
|
||||||
|
':alias_domain' => $alias_domain,
|
||||||
|
':target_domain' => $target_domain,
|
||||||
|
':active' => $active
|
||||||
|
));
|
||||||
|
}
|
||||||
|
catch (PDOException $e) {
|
||||||
|
mailbox('delete', 'alias_domain', array('alias_domain' => $alias_domain));
|
||||||
|
$_SESSION['return'] = array(
|
||||||
|
'type' => 'danger',
|
||||||
|
'msg' => 'MySQL: '.$e
|
||||||
);
|
);
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
catch(PDOException $e) {
|
$_SESSION['return'] = array(
|
||||||
$_SESSION['return'] = array(
|
'type' => 'success',
|
||||||
'type' => 'danger',
|
'msg' => sprintf($lang['success']['aliasd_added'], htmlspecialchars(implode(', ', $alias_domains)))
|
||||||
'msg' => 'MySQL: '.$e
|
);
|
||||||
);
|
|
||||||
return false;
|
|
||||||
}
|
|
||||||
try {
|
|
||||||
$stmt = $pdo->prepare("INSERT INTO `alias_domain` (`alias_domain`, `target_domain`, `active`)
|
|
||||||
VALUES (:alias_domain, :target_domain, :active)");
|
|
||||||
$stmt->execute(array(
|
|
||||||
':alias_domain' => $alias_domain,
|
|
||||||
':target_domain' => $target_domain,
|
|
||||||
':active' => $active
|
|
||||||
));
|
|
||||||
$_SESSION['return'] = array(
|
|
||||||
'type' => 'success',
|
|
||||||
'msg' => sprintf($lang['success']['aliasd_added'], htmlspecialchars($alias_domain))
|
|
||||||
);
|
|
||||||
}
|
|
||||||
catch (PDOException $e) {
|
|
||||||
mailbox('delete', 'alias_domain', array('alias_domain' => $alias_domain));
|
|
||||||
$_SESSION['return'] = array(
|
|
||||||
'type' => 'danger',
|
|
||||||
'msg' => 'MySQL: '.$e
|
|
||||||
);
|
|
||||||
return false;
|
|
||||||
}
|
|
||||||
break;
|
break;
|
||||||
case 'mailbox':
|
case 'mailbox':
|
||||||
$local_part = strtolower(trim($_data['local_part']));
|
$local_part = strtolower(trim($_data['local_part']));
|
||||||
|
Loading…
Reference in New Issue
Block a user