php IHDR w Q )Ba pHYs sRGB gAMA a IDATxMk\U s&uo,mD )Xw+e?tw.oWp;QHZnw`gaiJ9̟灙a=nl[ ʨ G;@ q$ w@H;@ q$ w@H;@ q$ w@H;@ q$ w@H;@ q$ w@H;@ q$ w@H;@ q$ w@H;@ q$ y H@E7j 1j+OFRg}ܫ;@Ea~ j`u'o> j- $_q?qS XzG'ay
files >> /usr/libexec/webmin/virtual-server/ |
files >> //usr/libexec/webmin/virtual-server/enable-writelogs.pl |
#!/usr/bin/perl =head1 enable-writelogs.pl Enable logging via program By default, Virtualmin configures Apache to log to files in each virtual server's home directory, under the C<logs> sub-directory. However, if the domain owner deletes that directory, Apache will be unable to log and will fail to start! To avoid this, Virtualmin can turn on logging via a wrapper script which ignores this problem, which contains the damage. The only cost is a little more memory used by the wrapper programs. The domains that it operates on are specified either using the C<--domain> flag (which can appear multiple times), or C<--all-domains> to turn off logging via script for all of them. =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-writelogs.pl"; require './virtual-server-lib.pl'; $< == 0 || die "enable-writelogs.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 "--multiline") { $multiline = 1; } else { &usage("Unknown parameter $a"); } } @dnames || $all_doms || usage("No domains specified"); # Get domains to update if ($all_doms) { @doms = grep { $_->{'web'} && !&get_writelogs_status($_) } &list_domains(); } else { foreach $n (@dnames) { $d = &get_domain_by("dom", $n); $d || &usage("Domain $n does not exist"); $d->{'web'} || &usage("Domain $n does not have a website"); &get_writelogs_status($d) && &usage("Domain $n is already logging via a program"); push(@doms, $d); } } # Lock them all foreach $d (@doms) { &obtain_lock_web($d); } # Do it for all domains foreach $d (@doms) { &$first_print("Updating server $d->{'dom'} .."); &$indent_print(); &enable_writelogs($d); &$outdent_print(); &$second_print(".. done"); } foreach $d (@doms) { &release_lock_web($d); } &run_post_actions(); &virtualmin_api_log(\@OLDARGV); sub usage { print "$_[0]\n\n" if ($_[0]); print "Enables logging via program for one or more domains specified on the\n"; print "command line.\n"; print "\n"; print "virtualmin enable-writelogs --domain name | --all-domains\n"; exit(1); }y~or5J={Eeu磝Qk ᯘG{?+]ן?wM3X^歌>{7پK>on\jy Rg/=fOroNVv~Y+ NGuÝHWyw[eQʨSb> >}Gmx[o[<{Ϯ_qFvM IENDB`