Compare commits

...

3 Commits

Author SHA1 Message Date
Matthew Saunders Brown
ed48b46060 changes to make vhost mapping work properly 2024-08-30 14:01:15 -07:00
Matthew Saunders Brown
f2639ca1ca include password info 2024-08-29 14:20:54 -07:00
Matthew Saunders Brown
8d89ff832d fix ForwardsAdd reroute mapping 2024-08-29 13:53:01 -07:00
9 changed files with 179 additions and 94 deletions

View File

@ -133,6 +133,7 @@ class Login extends \Panel {
/* user authenticated, check if they own requested domain */ /* user authenticated, check if they own requested domain */
if ($domain_array = $f3->call('\Panel::vGet', array("vhost-get.sh -u $username -d $domain -c", FALSE))) { if ($domain_array = $f3->call('\Panel::vGet', array("vhost-get.sh -u $username -d $domain -c", FALSE))) {
$f3->set('SESSION.expiration', time() + $f3->get('TIMEOUT')); $f3->set('SESSION.expiration', time() + $f3->get('TIMEOUT'));
$f3->set('SESSION.vhostusername', $username);
$f3->reroute('/'); $f3->reroute('/');
} else { } else {
/* user does not own domain, check if user is a vpanel admin */ /* user does not own domain, check if user is a vpanel admin */
@ -142,8 +143,7 @@ class Login extends \Panel {
$f3->reroute('/'); $f3->reroute('/');
} else { } else {
/* user does not own domain, and is not a vpanel admin */ /* user does not own domain, and is not a vpanel admin */
$messages[] = "User validated, but does not have admin privileges for $domain."; $messages[] = "Invalid user. Please try another username.";
$messages[] = "Please try another username.";
$f3->set('SESSION.messages', $messages); $f3->set('SESSION.messages', $messages);
echo \Template::instance()->render('login.html'); echo \Template::instance()->render('login.html');
} }

View File

@ -15,7 +15,27 @@ class UsersEdit extends \Panel\Vhost {
parent::beforeRoute($f3); parent::beforeRoute($f3);
$username = $f3->get('PARAMS.username'); $username = $f3->get('PARAMS.username');
if ($user_array = $f3->call('\Panel::vGet', array("vhost-user-get.sh -u $username -c", FALSE))) {
/* exta auth checks if logged in via vhost mapping */
if ($f3->get('NAV.mapping') == 'vhost') {
if ($f3->exists('SESSION.vhostusername')) {
/* vhostusername indicates vhost user login */
$vhostusername = $f3->get('SESSION.vhostusername');
if ($username != $vhostusername) {
/* trying to edit wrong username, redirect back home */
$messages[] = "Unauthorized request.";
$f3->set('SESSION.messages', $messages);
$f3->reroute("/");
}
} else {
/* SESSION.vhostusername not set. Something went wrong, redirect back home */
$messages[] = "Error verifying system user for domain $domain, can not edit.";
$f3->set('SESSION.messages', $messages);
$f3->reroute("/");
}
}
if ($user_array = $f3->call('\Panel::vGet', array("vhost-user-get.sh -u $username -c -v", FALSE))) {
if ($user_array[0]['passwd'] == "") { if ($user_array[0]['passwd'] == "") {
$user_array[0]['passwd'] = '(unavailable)'; $user_array[0]['passwd'] = '(unavailable)';
} }
@ -56,7 +76,7 @@ class UsersEdit extends \Panel\Vhost {
} else { } else {
$password = escapeshellarg($password); $password = escapeshellarg($password);
if ($f3->get('WRITEUSERINFO') == '1') { if ($f3->get('WRITEUSERINFO') == '1') {
exec("/usr/local/bin/vhost-user-mod.sh -u $username -p $password -w", $output, $result_code); exec("/usr/local/bin/vhost-user-mod.sh -u $username -p $password -w 1", $output, $result_code);
} else { } else {
exec("/usr/local/bin/vhost-user-mod.sh -u $username -p $password", $output, $result_code); exec("/usr/local/bin/vhost-user-mod.sh -u $username -p $password", $output, $result_code);
} }
@ -69,7 +89,6 @@ class UsersEdit extends \Panel\Vhost {
} elseif ($action == 'jail') { } elseif ($action == 'jail') {
exec("/usr/local/bin/vhost-user-jail.sh -u $username >/dev/null 2>/dev/null &", $output, $result_code); exec("/usr/local/bin/vhost-user-jail.sh -u $username >/dev/null 2>/dev/null &", $output, $result_code);
$messages[] = "User is being jailed. Note: Setting up the jail environment takes about a minute to complete and is run in the background now."; $messages[] = "User is being jailed. Note: Setting up the jail environment takes about a minute to complete and is run in the background now.";
$f3->reroute("/Users/$username");
} elseif ($action == 'fpmmax') { } elseif ($action == 'fpmmax') {
$fpmmax = $_POST['fpmmax']; $fpmmax = $_POST['fpmmax'];
exec("/usr/local/bin/vhost-user-mod.sh -u $username -x $fpmmax", $output, $result_code); exec("/usr/local/bin/vhost-user-mod.sh -u $username -x $fpmmax", $output, $result_code);
@ -83,8 +102,15 @@ class UsersEdit extends \Panel\Vhost {
} }
$f3->set('SESSION.messages', $messages); $f3->set('SESSION.messages', $messages);
if ($f3->get('NAV.mapping') == 'vhost') {
if (isset($result_code) && $result_code == 0) {
$f3->reroute("/");
} else {
$f3->reroute("/Users/$username/Edit");
}
} else {
$f3->reroute("/Users/$username"); $f3->reroute("/Users/$username");
}
// /* run mod command here */ // /* run mod command here */
// $mbox = $f3->get('PARAMS.mbox'); // $mbox = $f3->get('PARAMS.mbox');

View File

@ -17,8 +17,23 @@ class Vhosts extends \Panel\Vhost {
parent::beforeRoute($f3); parent::beforeRoute($f3);
if ($f3->exists('PARAMS.vhost')) { if ($f3->exists('PARAMS.vhost')) {
/* got here via vpanel link */
$vhost = $f3->get('PARAMS.vhost'); $vhost = $f3->get('PARAMS.vhost');
if ($vhost_array = $f3->call('\Panel::vGet', array("vhost-get.sh -d $vhost -c", FALSE))) { $vhost_get_cmd = "vhost-get.sh -d $vhost -c";
} elseif ($f3->get('NAV.mapping') == 'vhost') {
/* got here via vhost page */
if ($f3->exists('SESSION.domain') && $f3->exists('SESSION.vhostusername')) {
/* SESSION.domain should be set for all vhost logins */
$vhost = $f3->get('SESSION.domain');
$vhostusername = $f3->get('SESSION.vhostusername');
$vhost_get_cmd = "vhost-get.sh -d $vhost -u $vhostusername -c";
} else {
/* should never get here, throw a 500 error to prevent further processing */
$f3->error(500);
}
}
if (isset($vhost_get_cmd)) {
if ($vhost_array = $f3->call('\Panel::vGet', array("$vhost_get_cmd", FALSE))) {
$f3->set('vhost_array', $vhost_array[0]); $f3->set('vhost_array', $vhost_array[0]);
/* get cert info */ /* get cert info */
if ($f3->call('\Panel::verifyCertificateExists', $vhost)) { if ($f3->call('\Panel::verifyCertificateExists', $vhost)) {
@ -82,15 +97,13 @@ class Vhosts extends \Panel\Vhost {
static function get($f3) { static function get($f3) {
if ($f3->exists('PARAMS.vhost')) { if ($f3->exists('PARAMS.vhost')) {
// $vhost_array = $f3->get('vhost_array');
/* convert data for frontend display */
// nothing to convert
// $f3->set('vhost_array', $vhost_array);
$vhost = $f3->get('PARAMS.vhost'); $vhost = $f3->get('PARAMS.vhost');
} elseif ($f3->exists('SESSION.domain')) {
$vhost = $f3->get('SESSION.domain');
}
if (isset($vhost)) {
$f3->set('page_header', "Details for $vhost"); $f3->set('page_header', "Details for $vhost");
echo \Template::instance()->render('vhost/vhosts-vhost.html'); echo \Template::instance()->render('vhost/vhosts-vhost.html');

View File

@ -49,7 +49,8 @@ class ForwardsAdd extends \Panel\Vmail {
if ($result_code == 0) { if ($result_code == 0) {
$messages[] = "Success: Forwarding for email account $mbox@$domain added."; $messages[] = "Success: Forwarding for email account $mbox@$domain added.";
$f3->set('SESSION.messages', $messages); $f3->set('SESSION.messages', $messages);
if ($f3->get('SESSION.access') == 'vmail') { $mapping = $f3->get('NAV.mapping');
if ($mapping == 'vmail') {
$f3->reroute("/Accounts/$mbox/Forwarding"); $f3->reroute("/Accounts/$mbox/Forwarding");
} else { } else {
$f3->reroute("/Email/$domain/Accounts/$mbox/Forwarding"); $f3->reroute("/Email/$domain/Accounts/$mbox/Forwarding");

View File

@ -8,8 +8,4 @@
/ [sync] = Panel\Vhost\Vhosts / [sync] = Panel\Vhost\Vhosts
/Login [sync] = Panel\Login /Login [sync] = Panel\Login
/Logout [sync] = Panel\Logout /Logout [sync] = Panel\Logout
/Websites [sync] = Panel\Vhost\Vhosts /Users/@username/Edit [sync] = Panel\Vhost\UsersEdit
/Websites/Add [sync] = Panel\Vhost\VhostsAdd
/Websites/@vhost [sync] = Panel\Vhost\Vhosts
/Websites/@vhost/Edit [sync] = Panel\Vhost\VhostsEdit
/Websites/@vhost/Delete [sync] = Panel\Vhost\VhostsDelete

View File

@ -26,6 +26,13 @@ if ($f3->get('HOST') == $f3->get('NAV.hostname')) {
if ($f3->exists('SESSION.domain')) { if ($f3->exists('SESSION.domain')) {
$f3->clear('SESSION.domain'); $f3->clear('SESSION.domain');
} }
if ($f3->exists('SESSION.vhostusername')) {
$f3->clear('SESSION.vhostusername');
}
/* load DNS mapping, if enabled */
if ($f3->get('VDNSADMIN') == '1') {
$f3->config("config/maps-vdns.ini");
}
} elseif (preg_match('/^mail\./i', $f3->get('HOST'))) { } elseif (preg_match('/^mail\./i', $f3->get('HOST'))) {
$mapping = 'vmail'; $mapping = 'vmail';
$domain = preg_replace('/^mail\./i', '', $f3->get('HOST')); $domain = preg_replace('/^mail\./i', '', $f3->get('HOST'));
@ -34,15 +41,20 @@ if ($f3->get('HOST') == $f3->get('NAV.hostname')) {
$mapping = 'vhost'; $mapping = 'vhost';
$domain = preg_replace('/^www\./i', '', $f3->get('HOST')); $domain = preg_replace('/^www\./i', '', $f3->get('HOST'));
$f3->set('SESSION.domain', $domain); $f3->set('SESSION.domain', $domain);
/* vhostusername is not set when logging in to vhost admin as vpanel user or via ADMIN IP */
if (!$f3->exists('SESSION.vhostusername')) {
if ($vhost_array = $f3->call('\Panel::vGet', array("vhost-get.sh -d $domain -c", FALSE))) {
$vhostusername = $vhost_array[0]['username'];
$f3->set('SESSION.vhostusername', $vhostusername);
} else {
$messages[] = "System error verifying system user for domain $domain. Please contact support for further assistance.";
$f3->set('SESSION.messages', $messages);
}
}
} }
$f3->set('NAV.mapping', $mapping); $f3->set('NAV.mapping', $mapping);
$f3->config("config/maps-$mapping.ini"); $f3->config("config/maps-$mapping.ini");
/* load DNS mapping, if enabled */
if ($f3->get('VDNSADMIN') == '1') {
$f3->config("config/maps-vdns.ini");
}
/* custom error page */ /* custom error page */
$f3->set('ONERROR',function($f3){ $f3->set('ONERROR',function($f3){
echo \Template::instance()->render('error.html'); echo \Template::instance()->render('error.html');

View File

@ -26,6 +26,8 @@
<header> <header>
<h1><a href="{{@SCHEME}}://{{@HOST}}{{@BASE}}">{{@PACKAGE}}</a></h1> <h1><a href="{{@SCHEME}}://{{@HOST}}{{@BASE}}">{{@PACKAGE}}</a></h1>
<check if="isset(@SESSION.expiration)">
<nav> <nav>
<check if="{{@NAV.mapping=='vpanel'}}"> <check if="{{@NAV.mapping=='vpanel'}}">
<a href="{{@BASE}}/Websites">Websites</a> | <a href="{{@BASE}}/Websites">Websites</a> |
@ -36,7 +38,11 @@
<check if="{{ @VDNSADMIN=='1' }}"><a href="{{@BASE}}/DNS">DNS</a> |</check> <check if="{{ @VDNSADMIN=='1' }}"><a href="{{@BASE}}/DNS">DNS</a> |</check>
<a href="{{@BASE}}/Logout">Logout</a> <a href="{{@BASE}}/Logout">Logout</a>
</check> </check>
<check if="{{ @NAV.mapping=='vhost' }}">
<a href="{{@BASE}}/Logout">Logout</a>
</check>
<check if="{{ @NAV.mapping!='vhost' }}">
<check if="isset(@NAV.subnav)"> <check if="isset(@NAV.subnav)">
<true> <true>
<p style="padding-top: 5px"> <p style="padding-top: 5px">
@ -62,7 +68,10 @@
</check> </check>
</false> </false>
</check> </check>
</check>
</nav> </nav>
</check>
<check if="isset(@page_header)"> <check if="isset(@page_header)">
<h1>{{@page_header}}</h1> <h1>{{@page_header}}</h1>
</check> </check>

View File

@ -26,6 +26,7 @@ Passwords 15 or more characters long do not have any complexity requirements.<br
</form> </form>
</p> </p>
<check if="{{ @NAV.mapping=='vpanel' }}">
<p> <p>
<!-- jail --> <!-- jail -->
<form action="{{@REALM}}" method="POST"> <form action="{{@REALM}}" method="POST">
@ -173,4 +174,21 @@ Passwords 15 or more characters long do not have any complexity requirements.<br
</form> </form>
</p> </p>
</check>
<check if="{{ @NAV.mapping=='vhost' }}">
<!-- show php workers -->
<p>
<form action="{{@REALM}}" method="POST">
<fieldset>
<b>PHP Workers for {{ @user_array.username }}: {{ @user_array.fpmmax }}</b>
<br><br>
PHP Workers is maximum number of PHP processes that this user can have running at one time. Any website(s) installed for this user will be limited by this.
<br><br>
This can not be changed here, contact tech support if you think you need more PHP workers.<br>
</fieldset>
</form>
</p>
</check>
<include href="footer.html" /> <include href="footer.html" />

View File

@ -1,5 +1,7 @@
<include href="header.html" /> <include href="header.html" />
<check if="{{ @NAV.mapping=='vpanel' }}">
<table> <table>
<tr> <tr>
<th>Website</th> <th>Website</th>
@ -21,6 +23,8 @@
<br><br> <br><br>
</check>
<table> <table>
<tr> <tr>
<th>System User</th> <th>System User</th>
@ -30,10 +34,14 @@
<tr> <tr>
<td>{{ @vhost_array.username }}</td> <td>{{ @vhost_array.username }}</td>
<td>{{ @users_array.fpmmax }}</td> <td>{{ @users_array.fpmmax }}</td>
<td><a href="{{@BASE}}/Users/{{ @users_array.username }}/Edit">Edit User</a></td> <check if="{{ @NAV.mapping=='vhost' }}">
<true><td><a href="{{@BASE}}/Users/{{ @users_array.username }}/Edit">Change Password</a></td></true>
<false><td><a href="{{@BASE}}/Users/{{ @users_array.username }}/Edit">Edit User</a></td></false>
</check>
</tr> </tr>
</table> </table>
<check if="isset(@cert_array)"> <check if="isset(@cert_array)">
<true> <true>
<br><br> <br><br>
@ -42,18 +50,19 @@
<th style="white-space: nowrap;">Certificate</th> <th style="white-space: nowrap;">Certificate</th>
<th style="white-space: nowrap;">Expiration</th> <th style="white-space: nowrap;">Expiration</th>
<th style="white-space: nowrap;">Secured Hostnames</th> <th style="white-space: nowrap;">Secured Hostnames</th>
<th>Action</th> <check if="{{ @NAV.mapping=='vpanel' }}"><th>Action</th></check>
</tr> </tr>
<tr> <tr>
<td style="white-space: nowrap;">{{ @cert_array.common }}</td> <td style="white-space: nowrap;">{{ @cert_array.common }}</td>
<td style="white-space: nowrap;">{{ @cert_array.end }}</td> <td style="white-space: nowrap;">{{ @cert_array.end }}</td>
<td style="white-space: nowrap; text-align: right;">{{ @cert_array.alternative | raw }}</td> <td style="white-space: nowrap; text-align: right;">{{ @cert_array.alternative | raw }}</td>
<td style="white-space: nowrap;"><a href="{{@BASE}}/Certs/{{@vhost_array.virtualhost}}/Delete?r={{@PATH}}">Delete</a></td> <check if="{{ @NAV.mapping=='vpanel' }}"><td style="white-space: nowrap;"><a href="{{@BASE}}/Certs/{{@vhost_array.virtualhost}}/Delete?r={{@PATH}}">Delete</a></td></check>
</tr> </tr>
</table> </table>
<br><br> <br><br>
</true> </true>
<false> <false>
<check if="{{ @NAV.mapping=='vpanel' }}">
<hr> <hr>
<check if="{{ @dnsinfo.a.status=='Verified' }}"> <check if="{{ @dnsinfo.a.status=='Verified' }}">
<true> <true>
@ -86,6 +95,7 @@
</false> </false>
</check> </check>
<hr> <hr>
</check>
</false> </false>
</check> </check>