Server IP : 195.201.23.43 / Your IP : 3.148.109.137 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 =head1 enable-limit.pl Grants access to some feature or edit capability for some virtual servers This command can be used to grant the owner of some or all virtual servers access to some functions in the Virtualmin user interface. The domains that it applies to can be selected with the C<--domain> flag (which can be given multiple times), or with C<--all-domains>. To allow owners of matching domains to enable or disable some feature, use the feature code as a flag, such as C<--ssl> or C<--virtualmin-awstats>. To grant access to some capability, use flags like C<--can-edit-users> or C<--can-edit-dbs>. =cut package virtual_server; if (!$module_name) { $main::no_acl_check++; $ENV{'WEBMIN_CONFIG'} ||= "/etc/webmin"; $ENV{'WEBMIN_VAR'} ||= "/var/webmin"; if ($0 =~ /^(.*)\/[^\/]+$/) { chdir($pwd = $1); } else { chop($pwd = `pwd`); } $0 = "$pwd/enable-limit.pl"; require './virtual-server-lib.pl'; $< == 0 || die "enable-limit.pl must be run as root"; } @OLDARGV = @ARGV; $first_print = \&first_text_print; $second_print = \&second_text_print; $indent_print = \&indent_text_print; $outdent_print = \&outdent_text_print; # Parse command-line args while(@ARGV > 0) { local $a = shift(@ARGV); if ($a eq "--domain") { push(@dnames, shift(@ARGV)); } elsif ($a eq "--all-domains") { $all_doms = 1; } elsif ($a eq "--dbname") { $dbname = 1; } elsif ($a eq "--multiline") { $multiline = 1; } elsif ($a =~ /^--(\S+)$/ && &indexof($1, @features) >= 0) { $config{$1} || &usage("The $a option cannot be used unless the feature is enabled in the module configuration"); $feature{$1}++; } elsif ($a =~ /^--(\S+)$/ && &indexof($1, &list_feature_plugins()) >= 0) { $plugin{$1}++; } elsif ($a =~ /^--can-edit-(\S+)$/ && &indexof($1, @edit_limits) >= 0) { $edit{$1}++; } elsif ($a eq "--help") { &usage(); } else { &usage("Unknown parameter $a"); } } @dnames || $all_doms || usage("No domains specified"); # Get domains to update if ($all_doms) { @doms = &list_domains(); @doms = grep { $_->{'unix'} && !$_->{'alias'} } @doms; } else { foreach $n (@dnames) { $d = &get_domain_by("dom", $n); $d || &usage("Domain $n does not exist"); $d->{'unix'} && !$d->{'alias'} || &usage("Domain $n doesn't have limits"); push(@doms, $d); } } # Do it for all domains foreach $d (@doms) { &$first_print("Updating server $d->{'dom'} .."); &$indent_print(); @dom_features = $d->{'alias'} ? @alias_features : $d->{'parent'} ? ( grep { $_ ne "webmin" } @features ) : @features; # Enable access to a bunch of features foreach $f (@dom_features, &list_feature_plugins()) { if ($feature{$f} || $plugin{$f}) { $d->{"limit_$f"} = 1; } } # Allow choice of DB name if ($dbname) { $d->{'nodbname'} = 0; } # Update edits foreach $ed (@edit_limits) { $d->{'edit_'.$ed} = 1 if ($edit{$ed}); # Update edits dependencies &update_edit_limits($d, $ed, $edit{$ed}); } # Save new domain details &save_domain($d); &refresh_webmin_user($d); &$outdent_print(); &$second_print(".. done"); } &run_post_actions(); &virtualmin_api_log(\@OLDARGV); sub usage { print "$_[0]\n\n" if ($_[0]); print "Enables limits for one or more domains specified on the command line.\n"; print "\n"; print "virtualmin enable-limit --domain name | --all-domains\n"; print " [--dbname]\n"; foreach $f (@features) { print " [--$f]\n" if ($config{$f}); } foreach $f (&list_feature_plugins()) { print " [--$f]\n"; } foreach $f (@edit_limits) { print " [--can-edit-$f]\n"; } exit(1); }Private