Server IP : 195.201.23.43 / Your IP : 13.59.203.127 Web Server : Apache System : Linux webserver2.vercom.be 5.4.0-192-generic #212-Ubuntu SMP Fri Jul 5 09:47:39 UTC 2024 x86_64 User : kdecoratie ( 1041) PHP Version : 7.1.33-63+ubuntu20.04.1+deb.sury.org+1 Disable Function : pcntl_alarm,pcntl_fork,pcntl_waitpid,pcntl_wait,pcntl_wifexited,pcntl_wifstopped,pcntl_wifsignaled,pcntl_wifcontinued,pcntl_wexitstatus,pcntl_wtermsig,pcntl_wstopsig,pcntl_signal,pcntl_signal_get_handler,pcntl_signal_dispatch,pcntl_get_last_error,pcntl_strerror,pcntl_sigprocmask,pcntl_sigwaitinfo,pcntl_sigtimedwait,pcntl_exec,pcntl_getpriority,pcntl_setpriority,pcntl_async_signals, MySQL : OFF | cURL : ON | WGET : ON | Perl : ON | Python : OFF | Sudo : ON | Pkexec : ON Directory : /usr/share/webmin/virtual-server/ |
Upload File : |
#!/usr/bin/perl # Update access control and usage limits for this domain's user require './virtual-server-lib.pl'; &ReadParse(); $d = &get_domain($in{'dom'}); &can_edit_limits($d) || &error($text{'edit_ecannot'}); # Validate and store inputs &error_setup($text{'limits_err'}); $in{'mailboxlimit_def'} || $in{'mailboxlimit'} =~ /^\d+$/ || &error($text{'setup_emailboxlimit'}); $d->{'mailboxlimit'} = $in{'mailboxlimit_def'} ? undef : $in{'mailboxlimit'}; $in{'aliaslimit_def'} || $in{'aliaslimit'} =~ /^\d+$/ || &error($text{'setup_ealiaslimit'}); $d->{'aliaslimit'} = $in{'aliaslimit_def'} ? undef : $in{'aliaslimit'}; $in{'dbslimit_def'} || $in{'dbslimit'} =~ /^\d+$/ || &error($text{'setup_edbslimit'}); $d->{'dbslimit'} = $in{'dbslimit_def'} ? undef : $in{'dbslimit'}; $in{'domslimit_def'} || $in{'domslimit'} =~ /^\d+$/ || &error($text{'limits_edomslimit'}); $d->{'domslimit'} = $in{'domslimit_def'} == 1 ? undef : $in{'domslimit_def'} == 2 ? "*" : $in{'domslimit'}; $in{'aliasdomslimit_def'} || $in{'aliasdomslimit'} =~ /^\d+$/ || &error($text{'limits_ealiasdomslimit'}); $d->{'aliasdomslimit'} = $in{'aliasdomslimit_def'} == 1 ? undef : $in{'aliasdomslimit'}; $in{'realdomslimit_def'} || $in{'realdomslimit'} =~ /^\d+$/ || &error($text{'limits_erealdomslimit'}); $d->{'realdomslimit'} = $in{'realdomslimit_def'} == 1 ? undef : $in{'realdomslimit'}; $d->{'nodbname'} = $in{'nodbname'}; $d->{'norename'} = $in{'norename'}; $d->{'migrate'} = $in{'migrate'}; $d->{'forceunder'} = $in{'forceunder'}; $d->{'safeunder'} = $in{'safeunder'}; $d->{'ipfollow'} = $in{'ipfollow'}; if ($virtualmin_pro) { $in{'mongrels_def'} || $in{'mongrels'} =~ /^[1-9][0-9]*$/ || &error($text{'limits_emongrels'}); $d->{'mongrelslimit'} = $in{'mongrels_def'} ? undef : $in{'mongrels'}; } $d->{'demo'} = $in{'demo'}; %sel_features = map { $_, 1 } split(/\0/, $in{'features'}); foreach $f (@opt_features, "virt", &list_feature_plugins()) { next if (!&can_use_feature($f)); next if ($config{$f} == 3); $d->{"limit_".$f} = $sel_features{$f}; } $d->{'webmin_nocat_modules'} = $in{'nocatwebmin'}; if (&can_webmin_modules()) { $d->{'webmin_modules'} = $in{'modules'}; } # Save edit options %sel_edits = map { $_, 1 } split(/\0/, $in{'edit'}); foreach $ed (@edit_limits) { $d->{"edit_".$ed} = $sel_edits{$ed}; # Update edits dependencies &update_edit_limits($d, $ed, $sel_edits{$ed}); } # Save plugin inputs foreach $f (&list_feature_plugins()) { $err = &plugin_call($f, "feature_limits_parse", $d, \%in); &error($err) if ($err); } # Save allowed scripts if (defined(&list_scripts)) { if ($in{'scripts_def'}) { $d->{'allowedscripts'} = undef; } else { $d->{'allowedscripts'} = join(' ', split(/\r?\n/, $in{'scripts'})); } } # Update files &set_all_null_print(); &save_domain($d); if (defined($in{'shell'})) { # Update shell &change_domain_shell($d, $in{'shell'}); } &refresh_webmin_user($d); # Update jail if (!&check_jailkit_support()) { my $oldjail = &get_domain_jailkit($d); my $jailfeat = $virtualmin_pro; my $jailupd; my $jail_post_clean_enabled; my $jail_post_clean_disabled; my $jail_clean = $jailfeat && $in{'jail_clean'}; $d->{'jail_esects'} = !$jailfeat ? undef : $in{'jail_esects'}; $d->{'jail_ecmds'} = !$jailfeat ? undef : $in{'jail_ecmds'}; # Clear chroot first if ($jail_clean) { # Disable jail if ($oldjail) { $err = &disable_domain_jailkit($d); &error(&text('limits_ejailoff2', $err)) if ($err); $jail_post_clean_disabled = 1; } # Clean all previously copied files my $dom_chdir = &domain_jailkit_dir($d); if (-d $dom_chdir && $dom_chdir =~ /^\/.*?([\d]{6,})$/ && $1 eq $d->{'id'}) { opendir(my $dh, $dom_chdir) || &error(&text('limits_eopenchroot', $dom_chdir, $!)); while (my $dir = readdir($dh)) { next if ($dir eq '.' || $dir eq '..' || $dir eq "home"); # Remove recursively &unlink_file("$dom_chdir/$dir") } closedir($dh); } # Re-enable jail if ($in{'jail'}) { $err = &enable_domain_jailkit($d); &error(&text('limits_ejailon2', $err)) if ($err); $jail_post_clean_enabled = 1; } } if ($in{'jail'}) { # Setup or re-sync jail for this user if (!$jail_post_clean_enabled) { $err = &enable_domain_jailkit($d); &error(&text('limits_ejailon', $err)) if ($err); } if (!$err || $jail_post_clean_enabled) { $d->{'jail'} = 1; $jailupd++ } } elsif ($oldjail && !$in{'jail'}) { # Tear down jail for this user if (!$jail_post_clean_disabled) { $err = &disable_domain_jailkit($d); &error(&text('limits_ejailoff', $err)) if ($err); } if (!$err || $jail_post_clean_disabled) { $d->{'jail'} = 0; $jailupd++; } } &save_domain($d); # Update scripts hostnames, if jail changed if ($jailupd) { &modify_webmin($d, $d); foreach my $dbt ('mysql', 'psql') { &update_all_installed_scripts_database_credentials($d, $d, 'dbhost', undef, $dbt); } } } &run_post_actions(); &clear_links_cache($d, &get_domain_by("parent", $d->{'id'})); &webmin_log("limits", "domain", $d->{'dom'}, $d); &domain_redirect($d);Private