2010-01-20 16:55:27 +00:00
|
|
|
<?php
|
|
|
|
|
|
|
|
/**
|
2010-01-25 10:06:34 +00:00
|
|
|
* This file is part of the Froxlor project.
|
2010-01-20 16:55:27 +00:00
|
|
|
* Copyright (c) 2003-2009 the SysCP Team (see authors).
|
2010-01-25 10:06:34 +00:00
|
|
|
* Copyright (c) 2010 the Froxlor Team (see authors).
|
2010-01-20 16:55:27 +00:00
|
|
|
*
|
|
|
|
* For the full copyright and license information, please view the COPYING
|
|
|
|
* file that was distributed with this source code. You can also view the
|
2010-01-25 10:06:34 +00:00
|
|
|
* COPYING file online at http://files.froxlor.org/misc/COPYING.txt
|
2010-01-20 16:55:27 +00:00
|
|
|
*
|
|
|
|
* @copyright (c) the authors
|
2010-01-25 10:06:34 +00:00
|
|
|
* @author Florian Lippert <flo@syscp.org> (2003-2009)
|
|
|
|
* @author Froxlor team <team@froxlor.org> (2010-)
|
|
|
|
* @license GPLv2 http://files.froxlor.org/misc/COPYING.txt
|
2010-01-20 16:55:27 +00:00
|
|
|
* @package Panel
|
2011-05-04 09:59:20 +00:00
|
|
|
*
|
2010-01-20 16:55:27 +00:00
|
|
|
*/
|
2022-02-20 17:00:44 +00:00
|
|
|
const AREA = 'customer';
|
|
|
|
require __DIR__ . '/lib/init.php';
|
2010-01-20 16:55:27 +00:00
|
|
|
|
2022-02-20 17:00:44 +00:00
|
|
|
use Froxlor\Api\Commands\Certificates as Certificates;
|
|
|
|
use Froxlor\Api\Commands\SubDomains as SubDomains;
|
2018-12-19 15:57:03 +00:00
|
|
|
use Froxlor\Database\Database;
|
|
|
|
use Froxlor\Settings;
|
2022-02-21 16:42:04 +00:00
|
|
|
use Froxlor\UI\Panel\UI;
|
2022-02-20 17:00:44 +00:00
|
|
|
use Froxlor\UI\Request;
|
2018-12-18 12:45:05 +00:00
|
|
|
|
2016-07-27 11:45:54 +00:00
|
|
|
// redirect if this customer page is hidden via settings
|
2018-12-21 11:24:07 +00:00
|
|
|
if (Settings::IsInList('panel.customer_hide_options', 'domains')) {
|
2018-12-21 10:22:03 +00:00
|
|
|
\Froxlor\UI\Response::redirectTo('customer_index.php');
|
2016-07-27 11:45:54 +00:00
|
|
|
}
|
|
|
|
|
2022-02-20 17:00:44 +00:00
|
|
|
$id = (int) Request::get('id');
|
2010-01-20 16:55:27 +00:00
|
|
|
|
2013-12-15 11:24:32 +00:00
|
|
|
if ($page == 'overview') {
|
2018-12-26 14:51:26 +00:00
|
|
|
$log->logAction(\Froxlor\FroxlorLogger::USR_ACTION, LOG_NOTICE, "viewed customer_domains");
|
2018-12-21 10:22:03 +00:00
|
|
|
eval("echo \"" . \Froxlor\UI\Template::getTemplate("domains/domains") . "\";");
|
2013-12-15 11:24:32 +00:00
|
|
|
} elseif ($page == 'domains') {
|
|
|
|
if ($action == '') {
|
2018-12-26 14:51:26 +00:00
|
|
|
$log->logAction(\Froxlor\FroxlorLogger::USR_ACTION, LOG_NOTICE, "viewed customer_domains::domains");
|
2010-01-20 16:55:27 +00:00
|
|
|
$fields = array(
|
2020-02-29 08:50:29 +00:00
|
|
|
'd.domain_ace' => $lng['domains']['domainname'],
|
2019-11-24 11:52:25 +00:00
|
|
|
'd.aliasdomain' => $lng['domains']['aliasdomain']
|
2010-01-20 16:55:27 +00:00
|
|
|
);
|
2019-11-10 17:35:32 +00:00
|
|
|
try {
|
|
|
|
// get total count
|
|
|
|
$json_result = SubDomains::getLocal($userinfo)->listingCount();
|
|
|
|
$result = json_decode($json_result, true)['data'];
|
|
|
|
// initialize pagination and filtering
|
|
|
|
$paging = new \Froxlor\UI\Pagination($userinfo, $fields, $result);
|
|
|
|
// get list
|
|
|
|
$json_result = SubDomains::getLocal($userinfo, $paging->getApiCommandParams())->listing();
|
|
|
|
} catch (Exception $e) {
|
|
|
|
\Froxlor\UI\Response::dynamic_error($e->getMessage());
|
|
|
|
}
|
|
|
|
$result = json_decode($json_result, true)['data'];
|
|
|
|
|
2010-01-20 16:55:27 +00:00
|
|
|
$sortcode = $paging->getHtmlSortCode($lng);
|
|
|
|
$arrowcode = $paging->getHtmlArrowCode($filename . '?page=' . $page . '&s=' . $s);
|
|
|
|
$searchcode = $paging->getHtmlSearchCode($lng);
|
|
|
|
$pagingcode = $paging->getHtmlPagingCode($filename . '?page=' . $page . '&s=' . $s);
|
|
|
|
$domains = '';
|
|
|
|
$parentdomains_count = 0;
|
2019-11-10 17:35:32 +00:00
|
|
|
$domains_count = $paging->getEntries();
|
2010-01-20 16:55:27 +00:00
|
|
|
$domain_array = array();
|
2018-12-21 11:24:07 +00:00
|
|
|
|
2019-11-10 17:35:32 +00:00
|
|
|
foreach ($result['list'] as $row) {
|
|
|
|
formatDomainEntry($row, $idna_convert);
|
2013-12-15 11:24:32 +00:00
|
|
|
if ($row['parentdomainid'] == '0' && $row['caneditdomain'] == '1') {
|
2022-02-21 16:42:04 +00:00
|
|
|
$parentdomains_count++;
|
2010-01-20 16:55:27 +00:00
|
|
|
}
|
2019-11-20 08:33:28 +00:00
|
|
|
$domain_array[$row['parentdomainname']][] = $row;
|
2019-11-10 17:35:32 +00:00
|
|
|
}
|
2018-12-21 11:24:07 +00:00
|
|
|
|
2019-11-20 08:33:28 +00:00
|
|
|
foreach ($domain_array as $parentdomain => $sdomains) {
|
|
|
|
// PARENTDOMAIN
|
|
|
|
if (Settings::Get('system.awstats_enabled') == '1') {
|
|
|
|
$statsapp = 'awstats';
|
|
|
|
} else {
|
|
|
|
$statsapp = 'webalizer';
|
|
|
|
}
|
|
|
|
$row = [
|
|
|
|
'domain' => $idna_convert->decode($parentdomain)
|
|
|
|
];
|
|
|
|
eval("\$domains.=\"" . \Froxlor\UI\Template::getTemplate("domains/domains_delimiter") . "\";");
|
|
|
|
|
|
|
|
foreach ($sdomains as $domain) {
|
|
|
|
$row = \Froxlor\PhpHelper::htmlentitiesArray($domain);
|
|
|
|
|
2019-11-10 17:35:32 +00:00
|
|
|
// show docroot nicely
|
|
|
|
if (strpos($row['documentroot'], $userinfo['documentroot']) === 0) {
|
|
|
|
$row['documentroot'] = \Froxlor\FileDir::makeCorrectDir(str_replace($userinfo['documentroot'], "/", $row['documentroot']));
|
2015-07-28 06:23:10 +00:00
|
|
|
}
|
2019-11-10 17:35:32 +00:00
|
|
|
// get ssl-ips if activated
|
|
|
|
$show_ssledit = false;
|
|
|
|
if (Settings::Get('system.use_ssl') == '1' && \Froxlor\Domain\Domain::domainHasSslIpPort($row['id']) && $row['caneditdomain'] == '1' && $row['letsencrypt'] == 0) {
|
|
|
|
$show_ssledit = true;
|
2010-01-20 16:55:27 +00:00
|
|
|
}
|
2019-11-10 17:35:32 +00:00
|
|
|
eval("\$domains.=\"" . \Froxlor\UI\Template::getTemplate("domains/domains_domain") . "\";");
|
2010-01-20 16:55:27 +00:00
|
|
|
}
|
|
|
|
}
|
2018-12-21 11:24:07 +00:00
|
|
|
|
2018-12-21 10:22:03 +00:00
|
|
|
eval("echo \"" . \Froxlor\UI\Template::getTemplate("domains/domainlist") . "\";");
|
2013-12-15 11:24:32 +00:00
|
|
|
} elseif ($action == 'delete' && $id != 0) {
|
2018-02-27 09:34:37 +00:00
|
|
|
try {
|
2018-12-22 07:15:31 +00:00
|
|
|
$json_result = SubDomains::getLocal($userinfo, array(
|
2018-02-27 09:34:37 +00:00
|
|
|
'id' => $id
|
|
|
|
))->get();
|
|
|
|
} catch (Exception $e) {
|
2018-12-21 10:22:03 +00:00
|
|
|
\Froxlor\UI\Response::dynamic_error($e->getMessage());
|
2018-02-27 09:34:37 +00:00
|
|
|
}
|
|
|
|
$result = json_decode($json_result, true)['data'];
|
2018-12-21 11:24:07 +00:00
|
|
|
|
2013-10-31 10:51:01 +00:00
|
|
|
$alias_stmt = Database::prepare("SELECT COUNT(`id`) AS `count` FROM `" . TABLE_PANEL_DOMAINS . "` WHERE `aliasdomain` = :aliasdomain");
|
2018-12-21 11:24:07 +00:00
|
|
|
$alias_check = Database::pexecute_first($alias_stmt, array(
|
|
|
|
"aliasdomain" => $id
|
|
|
|
));
|
|
|
|
|
2013-12-15 11:24:32 +00:00
|
|
|
if (isset($result['parentdomainid']) && $result['parentdomainid'] != '0' && $alias_check['count'] == 0) {
|
|
|
|
if (isset($_POST['send']) && $_POST['send'] == 'send') {
|
2018-02-27 09:34:37 +00:00
|
|
|
try {
|
2018-12-22 07:15:31 +00:00
|
|
|
SubDomains::getLocal($userinfo, $_POST)->delete();
|
2018-02-27 09:34:37 +00:00
|
|
|
} catch (Exception $e) {
|
2018-12-21 10:22:03 +00:00
|
|
|
\Froxlor\UI\Response::dynamic_error($e->getMessage());
|
2010-01-20 16:55:27 +00:00
|
|
|
}
|
2018-12-21 11:24:07 +00:00
|
|
|
\Froxlor\UI\Response::redirectTo($filename, array(
|
|
|
|
'page' => $page,
|
|
|
|
's' => $s
|
|
|
|
));
|
2013-10-31 10:51:01 +00:00
|
|
|
} else {
|
2018-12-24 12:50:45 +00:00
|
|
|
\Froxlor\UI\HTML::askYesNo('domains_reallydelete', $filename, array(
|
2018-12-21 11:24:07 +00:00
|
|
|
'id' => $id,
|
|
|
|
'page' => $page,
|
|
|
|
'action' => $action
|
|
|
|
), $idna_convert->decode($result['domain']));
|
2010-01-20 16:55:27 +00:00
|
|
|
}
|
2013-10-31 10:51:01 +00:00
|
|
|
} else {
|
2018-12-21 10:22:03 +00:00
|
|
|
\Froxlor\UI\Response::standard_error('domains_cantdeletemaindomain');
|
2010-01-20 16:55:27 +00:00
|
|
|
}
|
2013-12-15 11:24:32 +00:00
|
|
|
} elseif ($action == 'add') {
|
2018-12-22 07:15:31 +00:00
|
|
|
if ($userinfo['subdomains_used'] < $userinfo['subdomains'] || $userinfo['subdomains'] == '-1') {
|
2013-12-15 11:24:32 +00:00
|
|
|
if (isset($_POST['send']) && $_POST['send'] == 'send') {
|
2018-02-27 14:54:07 +00:00
|
|
|
try {
|
2018-12-22 07:15:31 +00:00
|
|
|
SubDomains::getLocal($userinfo, $_POST)->add();
|
2018-02-27 14:54:07 +00:00
|
|
|
} catch (Exception $e) {
|
2018-12-21 10:22:03 +00:00
|
|
|
\Froxlor\UI\Response::dynamic_error($e->getMessage());
|
2010-01-20 16:55:27 +00:00
|
|
|
}
|
2018-12-21 11:24:07 +00:00
|
|
|
\Froxlor\UI\Response::redirectTo($filename, array(
|
|
|
|
'page' => $page,
|
|
|
|
's' => $s
|
|
|
|
));
|
2013-10-31 10:51:01 +00:00
|
|
|
} else {
|
2016-01-30 12:59:34 +00:00
|
|
|
$stmt = Database::prepare("SELECT `id`, `domain`, `documentroot`, `ssl_redirect`,`isemaildomain`,`letsencrypt` FROM `" . TABLE_PANEL_DOMAINS . "`
|
2013-10-31 10:51:01 +00:00
|
|
|
WHERE `customerid` = :customerid
|
|
|
|
AND `parentdomainid` = '0'
|
|
|
|
AND `email_only` = '0'
|
|
|
|
AND `caneditdomain` = '1'
|
2018-12-21 11:24:07 +00:00
|
|
|
ORDER BY `domain` ASC");
|
|
|
|
Database::pexecute($stmt, array(
|
2018-12-22 07:15:31 +00:00
|
|
|
"customerid" => $userinfo['customerid']
|
2018-12-21 11:24:07 +00:00
|
|
|
));
|
2022-02-21 16:42:04 +00:00
|
|
|
$domains = [];
|
2013-12-15 11:24:32 +00:00
|
|
|
while ($row = $stmt->fetch(PDO::FETCH_ASSOC)) {
|
2022-02-21 16:42:04 +00:00
|
|
|
$domains[$row['domain']] = $idna_convert->decode($row['domain']);
|
2010-01-20 16:55:27 +00:00
|
|
|
}
|
2018-12-21 11:24:07 +00:00
|
|
|
|
2022-02-21 16:42:04 +00:00
|
|
|
$aliasdomains[0] = $lng['domains']['noaliasdomain'];
|
2013-10-31 10:51:01 +00:00
|
|
|
$domains_stmt = Database::prepare("SELECT `d`.`id`, `d`.`domain` FROM `" . TABLE_PANEL_DOMAINS . "` `d`, `" . TABLE_PANEL_CUSTOMERS . "` `c`
|
|
|
|
WHERE `d`.`aliasdomain` IS NULL
|
|
|
|
AND `d`.`id` <> `c`.`standardsubdomain`
|
2014-10-27 09:41:29 +00:00
|
|
|
AND `d`.`parentdomainid` = '0'
|
2013-10-31 10:51:01 +00:00
|
|
|
AND `d`.`customerid`=`c`.`customerid`
|
|
|
|
AND `d`.`email_only`='0'
|
|
|
|
AND `d`.`customerid`= :customerid
|
2018-12-21 11:24:07 +00:00
|
|
|
ORDER BY `d`.`domain` ASC");
|
|
|
|
Database::pexecute($domains_stmt, array(
|
2018-12-22 07:15:31 +00:00
|
|
|
"customerid" => $userinfo['customerid']
|
2018-12-21 11:24:07 +00:00
|
|
|
));
|
|
|
|
|
2013-12-15 11:24:32 +00:00
|
|
|
while ($row_domain = $domains_stmt->fetch(PDO::FETCH_ASSOC)) {
|
2022-02-21 16:42:04 +00:00
|
|
|
$aliasdomains[$row_domain['id']] = $idna_convert->decode($row_domain['domain']);
|
2010-01-20 16:55:27 +00:00
|
|
|
}
|
2018-12-21 11:24:07 +00:00
|
|
|
|
2022-02-21 16:42:04 +00:00
|
|
|
$redirectcode = [];
|
2013-12-15 11:24:32 +00:00
|
|
|
if (Settings::Get('customredirect.enabled') == '1') {
|
2018-12-21 16:41:22 +00:00
|
|
|
$codes = \Froxlor\Domain\Domain::getRedirectCodesArray();
|
2013-12-15 11:24:32 +00:00
|
|
|
foreach ($codes as $rc) {
|
2022-02-21 16:42:04 +00:00
|
|
|
$redirectcode[$rc['id']] = $rc['code'] . ' (' . $lng['redirect_desc'][$rc['desc']] . ')';
|
2010-05-11 08:50:35 +00:00
|
|
|
}
|
|
|
|
}
|
2018-12-21 11:24:07 +00:00
|
|
|
|
2013-03-27 07:34:59 +00:00
|
|
|
// check if we at least have one ssl-ip/port, #1179
|
2022-02-21 16:42:04 +00:00
|
|
|
$ssl_ipsandports = false;
|
2016-11-29 08:34:33 +00:00
|
|
|
$ssl_ip_stmt = Database::prepare("
|
|
|
|
SELECT COUNT(*) as countSSL
|
2018-12-21 11:24:07 +00:00
|
|
|
FROM `" . TABLE_PANEL_IPSANDPORTS . "` pip
|
|
|
|
LEFT JOIN `" . TABLE_DOMAINTOIP . "` dti ON dti.id_ipandports = pip.id
|
2016-11-29 08:34:33 +00:00
|
|
|
WHERE pip.`ssl`='1'
|
|
|
|
");
|
2013-10-31 10:51:01 +00:00
|
|
|
Database::pexecute($ssl_ip_stmt);
|
|
|
|
$resultX = $ssl_ip_stmt->fetch(PDO::FETCH_ASSOC);
|
2018-12-21 11:24:07 +00:00
|
|
|
if (isset($resultX['countSSL']) && (int) $resultX['countSSL'] > 0) {
|
2022-02-21 16:42:04 +00:00
|
|
|
$ssl_ipsandports = true;
|
2013-03-27 07:34:59 +00:00
|
|
|
}
|
2018-12-21 11:24:07 +00:00
|
|
|
|
2022-02-21 16:42:04 +00:00
|
|
|
$openbasedir = [
|
|
|
|
0 => $lng['domain']['docroot'],
|
|
|
|
1 => $lng['domain']['homedir']
|
|
|
|
];
|
2018-12-22 07:15:31 +00:00
|
|
|
$pathSelect = \Froxlor\FileDir::makePathfield($userinfo['documentroot'], $userinfo['guid'], $userinfo['guid']);
|
2018-12-21 11:24:07 +00:00
|
|
|
|
2022-02-21 16:42:04 +00:00
|
|
|
$phpconfigs = [];
|
|
|
|
if (isset($userinfo['allowed_phpconfigs']) && !empty($userinfo['allowed_phpconfigs'])) {
|
2018-12-22 07:15:31 +00:00
|
|
|
$allowed_cfg = json_decode($userinfo['allowed_phpconfigs'], JSON_OBJECT_AS_ARRAY);
|
2018-01-08 12:59:30 +00:00
|
|
|
$phpconfigs_result_stmt = Database::query("
|
|
|
|
SELECT c.*, fc.description as interpreter
|
|
|
|
FROM `" . TABLE_PANEL_PHPCONFIGS . "` c
|
|
|
|
LEFT JOIN `" . TABLE_PANEL_FPMDAEMONS . "` fc ON fc.id = c.fpmsettingid
|
2018-12-21 11:24:07 +00:00
|
|
|
WHERE c.id IN (" . implode(", ", $allowed_cfg) . ")
|
2018-01-08 12:59:30 +00:00
|
|
|
");
|
|
|
|
while ($phpconfigs_row = $phpconfigs_result_stmt->fetch(PDO::FETCH_ASSOC)) {
|
|
|
|
if ((int) Settings::Get('phpfpm.enabled') == 1) {
|
2022-02-21 16:42:04 +00:00
|
|
|
$phpconfigs[$phpconfigs_row['id']] = $phpconfigs_row['description'] . " [" . $phpconfigs_row['interpreter'] . "]";
|
2018-01-08 12:59:30 +00:00
|
|
|
} else {
|
2022-02-21 16:42:04 +00:00
|
|
|
$phpconfigs[$phpconfigs_row['id']] = $phpconfigs_row['description'];
|
2018-01-08 12:59:30 +00:00
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
2018-12-21 11:24:07 +00:00
|
|
|
|
|
|
|
$subdomain_add_data = include_once dirname(__FILE__) . '/lib/formfields/customer/domains/formfield.domains_add.php';
|
|
|
|
|
2022-02-21 16:42:04 +00:00
|
|
|
UI::twigBuffer('user/form.html.twig', [
|
|
|
|
'formaction' => $linker->getLink(array('section' => 'domains')),
|
|
|
|
'formdata' => $subdomain_add_data['domain_add']
|
|
|
|
]);
|
|
|
|
UI::twigOutputBuffer();
|
2010-01-20 16:55:27 +00:00
|
|
|
}
|
|
|
|
}
|
2013-12-15 11:24:32 +00:00
|
|
|
} elseif ($action == 'edit' && $id != 0) {
|
2018-12-21 11:24:07 +00:00
|
|
|
|
2018-03-05 11:13:01 +00:00
|
|
|
try {
|
2018-12-22 07:15:31 +00:00
|
|
|
$json_result = SubDomains::getLocal($userinfo, array(
|
2018-03-05 11:13:01 +00:00
|
|
|
'id' => $id
|
|
|
|
))->get();
|
|
|
|
} catch (Exception $e) {
|
2018-12-21 10:22:03 +00:00
|
|
|
\Froxlor\UI\Response::dynamic_error($e->getMessage());
|
2018-03-05 11:13:01 +00:00
|
|
|
}
|
|
|
|
$result = json_decode($json_result, true)['data'];
|
2018-12-21 11:24:07 +00:00
|
|
|
|
2018-12-22 07:15:31 +00:00
|
|
|
if (isset($result['customerid']) && $result['customerid'] == $userinfo['customerid']) {
|
2013-12-15 11:24:32 +00:00
|
|
|
if (isset($_POST['send']) && $_POST['send'] == 'send') {
|
2018-03-05 11:13:01 +00:00
|
|
|
try {
|
2018-12-22 07:15:31 +00:00
|
|
|
SubDomains::getLocal($userinfo, $_POST)->update();
|
2018-03-05 11:13:01 +00:00
|
|
|
} catch (Exception $e) {
|
2018-12-21 10:22:03 +00:00
|
|
|
\Froxlor\UI\Response::dynamic_error($e->getMessage());
|
2010-01-20 16:55:27 +00:00
|
|
|
}
|
2018-12-21 11:24:07 +00:00
|
|
|
\Froxlor\UI\Response::redirectTo($filename, array(
|
|
|
|
'page' => $page,
|
|
|
|
's' => $s
|
|
|
|
));
|
2013-10-31 10:51:01 +00:00
|
|
|
} else {
|
2010-01-20 16:55:27 +00:00
|
|
|
$result['domain'] = $idna_convert->decode($result['domain']);
|
2018-12-21 11:24:07 +00:00
|
|
|
|
2022-02-21 16:42:04 +00:00
|
|
|
$domains[0] = $lng['domains']['noaliasdomain'];
|
2010-04-29 07:40:55 +00:00
|
|
|
// also check ip/port combination to be the same, #176
|
2018-12-21 11:24:07 +00:00
|
|
|
$domains_stmt = Database::prepare("SELECT `d`.`id`, `d`.`domain` FROM `" . TABLE_PANEL_DOMAINS . "` `d` , `" . TABLE_PANEL_CUSTOMERS . "` `c` , `" . TABLE_DOMAINTOIP . "` `dip`
|
2013-10-31 10:51:01 +00:00
|
|
|
WHERE `d`.`aliasdomain` IS NULL
|
|
|
|
AND `d`.`id` <> :id
|
|
|
|
AND `c`.`standardsubdomain` <> `d`.`id`
|
2014-10-27 09:41:29 +00:00
|
|
|
AND `d`.`parentdomainid` = '0'
|
2013-10-31 10:51:01 +00:00
|
|
|
AND `d`.`customerid` = :customerid
|
|
|
|
AND `c`.`customerid` = `d`.`customerid`
|
|
|
|
AND `d`.`id` = `dip`.`id_domain`
|
|
|
|
AND `dip`.`id_ipandports`
|
2018-12-21 11:24:07 +00:00
|
|
|
IN (SELECT `id_ipandports` FROM `" . TABLE_DOMAINTOIP . "`
|
2013-10-31 10:51:01 +00:00
|
|
|
WHERE `id_domain` = :id)
|
2016-04-30 15:24:11 +00:00
|
|
|
GROUP BY `d`.`id`, `d`.`domain`
|
2018-12-21 11:24:07 +00:00
|
|
|
ORDER BY `d`.`domain` ASC");
|
|
|
|
Database::pexecute($domains_stmt, array(
|
|
|
|
"id" => $result['id'],
|
2018-12-22 07:15:31 +00:00
|
|
|
"customerid" => $userinfo['customerid']
|
2018-12-21 11:24:07 +00:00
|
|
|
));
|
|
|
|
|
2013-12-15 11:24:32 +00:00
|
|
|
while ($row_domain = $domains_stmt->fetch(PDO::FETCH_ASSOC)) {
|
2022-02-21 16:42:04 +00:00
|
|
|
$domains[$row_domain['id']] = $idna_convert->decode($row_domain['domain']);
|
2010-01-20 16:55:27 +00:00
|
|
|
}
|
2018-12-21 11:24:07 +00:00
|
|
|
|
2019-06-05 04:50:06 +00:00
|
|
|
if (preg_match('/^https?\:\/\//', $result['documentroot']) && \Froxlor\Validate\Validate::validateUrl($result['documentroot'])) {
|
2013-12-15 11:24:32 +00:00
|
|
|
if (Settings::Get('panel.pathedit') == 'Dropdown') {
|
2011-03-14 06:58:32 +00:00
|
|
|
$urlvalue = $result['documentroot'];
|
2018-12-22 07:15:31 +00:00
|
|
|
$pathSelect = \Froxlor\FileDir::makePathfield($userinfo['documentroot'], $userinfo['guid'], $userinfo['guid']);
|
2013-10-31 10:51:01 +00:00
|
|
|
} else {
|
2011-03-14 06:58:32 +00:00
|
|
|
$urlvalue = '';
|
2018-12-22 07:15:31 +00:00
|
|
|
$pathSelect = \Froxlor\FileDir::makePathfield($userinfo['documentroot'], $userinfo['guid'], $userinfo['guid'], $result['documentroot'], true);
|
2011-03-14 06:58:32 +00:00
|
|
|
}
|
2013-10-31 10:51:01 +00:00
|
|
|
} else {
|
2010-01-20 16:55:27 +00:00
|
|
|
$urlvalue = '';
|
2018-12-22 07:15:31 +00:00
|
|
|
$pathSelect = \Froxlor\FileDir::makePathfield($userinfo['documentroot'], $userinfo['guid'], $userinfo['guid'], $result['documentroot']);
|
2010-01-20 16:55:27 +00:00
|
|
|
}
|
2018-12-21 11:24:07 +00:00
|
|
|
|
2022-02-21 16:42:04 +00:00
|
|
|
$redirectcode = [];
|
2013-12-15 11:24:32 +00:00
|
|
|
if (Settings::Get('customredirect.enabled') == '1') {
|
2018-12-21 16:41:22 +00:00
|
|
|
$def_code = \Froxlor\Domain\Domain::getDomainRedirectId($id);
|
|
|
|
$codes = \Froxlor\Domain\Domain::getRedirectCodesArray();
|
2013-12-15 11:24:32 +00:00
|
|
|
foreach ($codes as $rc) {
|
2022-02-21 16:42:04 +00:00
|
|
|
$redirectcode[$rc['id']] = $rc['code'] . ' (' . $lng['redirect_desc'][$rc['desc']] . ')';
|
2010-05-11 08:50:35 +00:00
|
|
|
}
|
|
|
|
}
|
2018-12-21 11:24:07 +00:00
|
|
|
|
2013-03-27 07:34:59 +00:00
|
|
|
// check if we at least have one ssl-ip/port, #1179
|
2022-02-21 16:42:04 +00:00
|
|
|
$ssl_ipsandports = false;
|
2016-11-29 08:34:33 +00:00
|
|
|
$ssl_ip_stmt = Database::prepare("
|
|
|
|
SELECT COUNT(*) as countSSL
|
2018-12-21 11:24:07 +00:00
|
|
|
FROM `" . TABLE_PANEL_IPSANDPORTS . "` pip
|
|
|
|
LEFT JOIN `" . TABLE_DOMAINTOIP . "` dti ON dti.id_ipandports = pip.id
|
2016-11-29 08:34:33 +00:00
|
|
|
WHERE `dti`.`id_domain` = :id_domain AND pip.`ssl`='1'
|
|
|
|
");
|
2018-12-21 11:24:07 +00:00
|
|
|
Database::pexecute($ssl_ip_stmt, array(
|
|
|
|
"id_domain" => $result['id']
|
|
|
|
));
|
2013-10-31 10:51:01 +00:00
|
|
|
$resultX = $ssl_ip_stmt->fetch(PDO::FETCH_ASSOC);
|
2018-12-21 11:24:07 +00:00
|
|
|
if (isset($resultX['countSSL']) && (int) $resultX['countSSL'] > 0) {
|
2022-02-21 16:42:04 +00:00
|
|
|
$ssl_ipsandports = true;
|
2013-03-27 07:34:59 +00:00
|
|
|
}
|
2018-12-21 11:24:07 +00:00
|
|
|
|
2016-02-16 13:31:07 +00:00
|
|
|
// Fudge the result for ssl_redirect to hide the Let's Encrypt steps
|
|
|
|
$result['temporary_ssl_redirect'] = $result['ssl_redirect'];
|
|
|
|
$result['ssl_redirect'] = ($result['ssl_redirect'] == 0 ? 0 : 1);
|
2018-12-21 11:24:07 +00:00
|
|
|
|
2022-02-21 16:42:04 +00:00
|
|
|
$openbasedir = [
|
|
|
|
0 => $lng['domain']['docroot'],
|
|
|
|
1 => $lng['domain']['homedir']
|
|
|
|
];
|
2018-12-21 11:24:07 +00:00
|
|
|
|
2013-10-14 08:08:15 +00:00
|
|
|
// create serveralias options
|
2022-02-21 16:42:04 +00:00
|
|
|
$serveraliasoptions = [];
|
|
|
|
$serveraliasoptions_selected = '2';
|
2013-10-14 08:08:15 +00:00
|
|
|
if ($result['iswildcarddomain'] == '1') {
|
2022-02-21 16:42:04 +00:00
|
|
|
$serveraliasoptions_selected = '0';
|
2013-10-14 08:08:15 +00:00
|
|
|
} elseif ($result['wwwserveralias'] == '1') {
|
2022-02-21 16:42:04 +00:00
|
|
|
$serveraliasoptions_selected = '1';
|
2013-10-14 08:08:15 +00:00
|
|
|
}
|
2022-02-21 16:42:04 +00:00
|
|
|
$serveraliasoptions[0] = $lng['domains']['serveraliasoption_wildcard'];
|
|
|
|
$serveraliasoptions[1] = $lng['domains']['serveraliasoption_www'];
|
|
|
|
$serveraliasoptions[2] = $lng['domains']['serveraliasoption_none'];
|
2018-12-21 11:24:07 +00:00
|
|
|
|
|
|
|
$ips_stmt = Database::prepare("SELECT `p`.`ip` AS `ip` FROM `" . TABLE_PANEL_IPSANDPORTS . "` `p`
|
|
|
|
LEFT JOIN `" . TABLE_DOMAINTOIP . "` `dip`
|
2013-10-31 10:51:01 +00:00
|
|
|
ON ( `dip`.`id_ipandports` = `p`.`id` )
|
|
|
|
WHERE `dip`.`id_domain` = :id_domain
|
2018-12-21 11:24:07 +00:00
|
|
|
GROUP BY `p`.`ip`");
|
|
|
|
Database::pexecute($ips_stmt, array(
|
|
|
|
"id_domain" => $result['id']
|
|
|
|
));
|
2022-02-21 16:42:04 +00:00
|
|
|
$domainips = [];
|
2013-10-31 10:51:01 +00:00
|
|
|
while ($rowip = $ips_stmt->fetch(PDO::FETCH_ASSOC)) {
|
2022-02-21 16:42:04 +00:00
|
|
|
$domainips[] = ['item' => $rowip['ip']];
|
2010-01-20 16:55:27 +00:00
|
|
|
}
|
2018-12-21 11:24:07 +00:00
|
|
|
|
2022-02-21 16:42:04 +00:00
|
|
|
$phpconfigs = [];
|
|
|
|
if (isset($userinfo['allowed_phpconfigs']) && !empty($userinfo['allowed_phpconfigs'])) {
|
2018-12-22 07:15:31 +00:00
|
|
|
$allowed_cfg = json_decode($userinfo['allowed_phpconfigs'], JSON_OBJECT_AS_ARRAY);
|
2018-01-08 12:59:30 +00:00
|
|
|
$phpconfigs_result_stmt = Database::query("
|
|
|
|
SELECT c.*, fc.description as interpreter
|
|
|
|
FROM `" . TABLE_PANEL_PHPCONFIGS . "` c
|
|
|
|
LEFT JOIN `" . TABLE_PANEL_FPMDAEMONS . "` fc ON fc.id = c.fpmsettingid
|
2018-12-21 11:24:07 +00:00
|
|
|
WHERE c.id IN (" . implode(", ", $allowed_cfg) . ")
|
2018-01-08 12:59:30 +00:00
|
|
|
");
|
|
|
|
while ($phpconfigs_row = $phpconfigs_result_stmt->fetch(PDO::FETCH_ASSOC)) {
|
|
|
|
if ((int) Settings::Get('phpfpm.enabled') == 1) {
|
2022-02-21 16:42:04 +00:00
|
|
|
$phpconfigs[$phpconfigs_row['id']] = $phpconfigs_row['description'] . " [" . $phpconfigs_row['interpreter'] . "]";
|
2018-01-08 12:59:30 +00:00
|
|
|
} else {
|
2022-02-21 16:42:04 +00:00
|
|
|
$phpconfigs[$phpconfigs_row['id']] = $phpconfigs_row['description'];
|
2018-01-08 12:59:30 +00:00
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
2018-12-21 11:24:07 +00:00
|
|
|
|
2019-01-10 19:12:59 +00:00
|
|
|
$alias_stmt = Database::prepare("SELECT COUNT(`id`) AS count FROM `" . TABLE_PANEL_DOMAINS . "` WHERE `aliasdomain`= :aliasdomain");
|
2019-11-10 17:35:32 +00:00
|
|
|
$alias_check = Database::pexecute_first($alias_stmt, array(
|
|
|
|
"aliasdomain" => $result['id']
|
|
|
|
));
|
2019-01-10 19:12:59 +00:00
|
|
|
$alias_check = $alias_check['count'];
|
|
|
|
|
2018-12-24 12:50:45 +00:00
|
|
|
$result = \Froxlor\PhpHelper::htmlentitiesArray($result);
|
2018-12-21 11:24:07 +00:00
|
|
|
|
|
|
|
$subdomain_edit_data = include_once dirname(__FILE__) . '/lib/formfields/customer/domains/formfield.domains_edit.php';
|
|
|
|
|
2022-02-21 16:42:04 +00:00
|
|
|
UI::twigBuffer('user/form.html.twig', [
|
|
|
|
'formaction' => $linker->getLink(array('section' => 'domains', 'id' => $id)),
|
|
|
|
'formdata' => $subdomain_edit_data['domain_edit']
|
|
|
|
]);
|
|
|
|
UI::twigOutputBuffer();
|
2010-01-20 16:55:27 +00:00
|
|
|
}
|
2013-10-31 10:51:01 +00:00
|
|
|
} else {
|
2018-12-21 10:22:03 +00:00
|
|
|
\Froxlor\UI\Response::standard_error('domains_canteditdomain');
|
2010-01-20 16:55:27 +00:00
|
|
|
}
|
|
|
|
}
|
2013-10-31 10:51:01 +00:00
|
|
|
} elseif ($page == 'domainssleditor') {
|
2018-12-21 11:24:07 +00:00
|
|
|
|
2013-10-31 10:51:01 +00:00
|
|
|
if ($action == '' || $action == 'view') {
|
2019-06-10 09:36:05 +00:00
|
|
|
|
|
|
|
// get domain
|
|
|
|
try {
|
|
|
|
$json_result = SubDomains::getLocal($userinfo, array(
|
|
|
|
'id' => $id
|
|
|
|
))->get();
|
|
|
|
} catch (Exception $e) {
|
|
|
|
\Froxlor\UI\Response::dynamic_error($e->getMessage());
|
|
|
|
}
|
|
|
|
$result_domain = json_decode($json_result, true)['data'];
|
|
|
|
|
2013-10-31 10:51:01 +00:00
|
|
|
if (isset($_POST['send']) && $_POST['send'] == 'send') {
|
2013-05-14 15:26:30 +00:00
|
|
|
$do_insert = isset($_POST['do_insert']) ? (($_POST['do_insert'] == 1) ? true : false) : false;
|
2018-03-05 13:21:36 +00:00
|
|
|
try {
|
|
|
|
if ($do_insert) {
|
2018-12-22 07:15:31 +00:00
|
|
|
Certificates::getLocal($userinfo, $_POST)->add();
|
2013-05-14 15:26:30 +00:00
|
|
|
} else {
|
2018-12-22 07:15:31 +00:00
|
|
|
Certificates::getLocal($userinfo, $_POST)->update();
|
2013-05-14 15:26:30 +00:00
|
|
|
}
|
2018-03-05 13:21:36 +00:00
|
|
|
} catch (Exception $e) {
|
2018-12-21 10:22:03 +00:00
|
|
|
\Froxlor\UI\Response::dynamic_error($e->getMessage());
|
2013-05-14 15:26:30 +00:00
|
|
|
}
|
|
|
|
// back to domain overview
|
2018-12-21 11:24:07 +00:00
|
|
|
\Froxlor\UI\Response::redirectTo($filename, array(
|
|
|
|
'page' => 'domains',
|
|
|
|
's' => $s
|
|
|
|
));
|
2013-05-14 15:26:30 +00:00
|
|
|
}
|
2018-12-21 11:24:07 +00:00
|
|
|
|
|
|
|
$stmt = Database::prepare("SELECT * FROM `" . TABLE_PANEL_DOMAIN_SSL_SETTINGS . "`
|
|
|
|
WHERE `domainid`= :domainid");
|
|
|
|
$result = Database::pexecute_first($stmt, array(
|
|
|
|
"domainid" => $id
|
|
|
|
));
|
|
|
|
|
2013-05-14 15:26:30 +00:00
|
|
|
$do_insert = false;
|
|
|
|
// if no entry can be found, behave like we have empty values
|
2022-02-21 16:42:04 +00:00
|
|
|
if (!is_array($result) || !isset($result['ssl_cert_file'])) {
|
2013-05-14 15:26:30 +00:00
|
|
|
$result = array(
|
|
|
|
'ssl_cert_file' => '',
|
|
|
|
'ssl_key_file' => '',
|
|
|
|
'ssl_ca_file' => '',
|
|
|
|
'ssl_cert_chainfile' => ''
|
|
|
|
);
|
|
|
|
$do_insert = true;
|
|
|
|
}
|
2018-12-21 11:24:07 +00:00
|
|
|
|
2018-12-24 12:50:45 +00:00
|
|
|
$result = \Froxlor\PhpHelper::htmlentitiesArray($result);
|
2018-12-21 11:24:07 +00:00
|
|
|
|
|
|
|
$ssleditor_data = include_once dirname(__FILE__) . '/lib/formfields/customer/domains/formfield.domain_ssleditor.php';
|
2018-12-21 10:22:03 +00:00
|
|
|
$ssleditor_form = \Froxlor\UI\HtmlForm::genHTMLForm($ssleditor_data);
|
2018-12-21 11:24:07 +00:00
|
|
|
|
2013-05-14 15:26:30 +00:00
|
|
|
$title = $ssleditor_data['domain_ssleditor']['title'];
|
|
|
|
$image = $ssleditor_data['domain_ssleditor']['image'];
|
2018-12-21 11:24:07 +00:00
|
|
|
|
2018-12-21 10:22:03 +00:00
|
|
|
eval("echo \"" . \Froxlor\UI\Template::getTemplate("domains/domain_ssleditor") . "\";");
|
2013-05-14 15:26:30 +00:00
|
|
|
}
|
2018-12-22 07:15:31 +00:00
|
|
|
} elseif ($page == 'domaindnseditor' && $userinfo['dnsenabled'] == '1' && Settings::Get('system.dnsenabled') == '1') {
|
2018-12-21 11:24:07 +00:00
|
|
|
|
|
|
|
require_once __DIR__ . '/dns_editor.php';
|
2016-09-26 09:48:36 +00:00
|
|
|
} elseif ($page == 'sslcertificates') {
|
2018-12-21 11:24:07 +00:00
|
|
|
|
|
|
|
require_once __DIR__ . '/ssl_certificates.php';
|
2018-12-01 12:33:08 +00:00
|
|
|
} elseif ($page == 'logfiles') {
|
|
|
|
|
2018-12-21 11:24:07 +00:00
|
|
|
require_once __DIR__ . '/logfiles_viewer.php';
|
2018-12-01 12:33:08 +00:00
|
|
|
}
|
2019-11-10 17:35:32 +00:00
|
|
|
|
|
|
|
function formatDomainEntry(&$row, &$idna_convert)
|
|
|
|
{
|
|
|
|
$row['domain'] = $idna_convert->decode($row['domain']);
|
|
|
|
$row['aliasdomain'] = $idna_convert->decode($row['aliasdomain']);
|
|
|
|
$row['domainalias'] = $idna_convert->decode($row['domainalias']);
|
|
|
|
|
|
|
|
/**
|
|
|
|
* check for set ssl-certs to show different state-icons
|
|
|
|
*/
|
|
|
|
// nothing (ssl_global)
|
|
|
|
$row['domain_hascert'] = 0;
|
|
|
|
$ssl_stmt = Database::prepare("SELECT * FROM `" . TABLE_PANEL_DOMAIN_SSL_SETTINGS . "` WHERE `domainid` = :domainid");
|
|
|
|
Database::pexecute($ssl_stmt, array(
|
|
|
|
"domainid" => $row['id']
|
|
|
|
));
|
|
|
|
$ssl_result = $ssl_stmt->fetch(PDO::FETCH_ASSOC);
|
|
|
|
if (is_array($ssl_result) && isset($ssl_result['ssl_cert_file']) && $ssl_result['ssl_cert_file'] != '') {
|
|
|
|
// own certificate (ssl_customer_green)
|
|
|
|
$row['domain_hascert'] = 1;
|
|
|
|
} else {
|
|
|
|
// check if it's parent has one set (shared)
|
|
|
|
if ($row['parentdomainid'] != 0) {
|
|
|
|
$ssl_stmt = Database::prepare("SELECT * FROM `" . TABLE_PANEL_DOMAIN_SSL_SETTINGS . "` WHERE `domainid` = :domainid");
|
|
|
|
Database::pexecute($ssl_stmt, array(
|
|
|
|
"domainid" => $row['parentdomainid']
|
|
|
|
));
|
|
|
|
$ssl_result = $ssl_stmt->fetch(PDO::FETCH_ASSOC);
|
|
|
|
if (is_array($ssl_result) && isset($ssl_result['ssl_cert_file']) && $ssl_result['ssl_cert_file'] != '') {
|
|
|
|
// parent has a certificate (ssl_shared)
|
|
|
|
$row['domain_hascert'] = 2;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
$row['termination_date'] = str_replace("0000-00-00", "", $row['termination_date']);
|
|
|
|
|
|
|
|
$row['termination_css'] = "";
|
|
|
|
if ($row['termination_date'] != "") {
|
|
|
|
$cdate = strtotime($row['termination_date'] . " 23:59:59");
|
|
|
|
$today = time();
|
|
|
|
|
|
|
|
if ($cdate < $today) {
|
|
|
|
$row['termination_css'] = 'domain-expired';
|
|
|
|
} else {
|
|
|
|
$row['termination_css'] = 'domain-canceled';
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|