summaryrefslogtreecommitdiffstats
path: root/web_wizard/Apache.pm
diff options
context:
space:
mode:
Diffstat (limited to 'web_wizard/Apache.pm')
-rwxr-xr-xweb_wizard/Apache.pm60
1 files changed, 41 insertions, 19 deletions
diff --git a/web_wizard/Apache.pm b/web_wizard/Apache.pm
index e43af1d6..876c7bb1 100755
--- a/web_wizard/Apache.pm
+++ b/web_wizard/Apache.pm
@@ -31,7 +31,7 @@ use MDK::Wizard::Varspaceval;
my $wiz = new MDK::Wizard::Wizcommon;
-my $file;
+my $file = "/etc/httpd/conf/httpd.conf";
my $root;
my $config;
@@ -44,7 +44,7 @@ my $o = {
user_dir => '',
shared_dir => ''
},
- needed_rpm => [ 'apache-mpm-prefork' ],
+ needed_rpm => [ 'apache-mpm-prefork', 'apache-mod_userdir' ],
defaultimage => "/usr/share/wizards/web_wizard/images/apache.png",
init => sub {
if (-f $file) {
@@ -97,7 +97,12 @@ $o->{pages} = {
},
user_dir => {
name => N("Type the name of the directory users should create in their homes (without ~/) to get it available via http://www.yourserver.com/~user"),
- pre => sub { $o->{var}{user_dir} ||= 'public_html' },
+ pre => sub {
+ $o->{var}{user_dir} = get_user_dir();
+ if ($o->{var}{user_dir} =~ /disabled/) {
+ $o->{var}{user_dir} = 'public_html';
+ }
+ },
data => [
{ label => N("user http sub-directory: ~/"), help => N("Type the name of the directory users should create in their homes (without ~/) to get it available via http://www.yourserver.com/~user"), val => \$o->{var}{user_dir} },
],
@@ -170,11 +175,11 @@ sub chg_docroot {
substInFile {
s|^\s*<Directory\s*$old/?>|<Directory $o->{var}{shared_dir}>|;
- } "/etc/httpd/conf/commonhttpd.conf" if $old;
+ } $file if $old;
substInFile {
s|^\s*<Directory\s*/var/www/html/?>|<Directory $o->{var}{shared_dir}>|;
- } "/etc/httpd/conf/httpd.conf";
+ } $file;
}
sub is_user_mod {
@@ -192,25 +197,44 @@ sub is_last_user_mod {
}
sub get_user_dir {
- my %conf = MDK::Wizard::Varspaceval->get("/etc/httpd/conf/httpd.conf");
+ my %conf = MDK::Wizard::Varspaceval->get($file);
$conf{UserDir};
}
sub chg_user_dir {
- my $root = get_user_dir();
+ # disable by default user_mod
+ if (! any { /<IfModule mod_userdir.c>/ } cat_($file)) {
+ append_to_file($file, <<EOF);
+# add usermod dir support
+<IfModule mod_userdir.c>
+ UserDir disabled
+</IfModule>
+
+<Directory /home/*/>
+ AllowOverride FileInfo AuthConfig Limit
+ Options MultiViews Indexes SymLinksIfOwnerMatch IncludesNoExec
+ <Limit GET POST OPTIONS PROPFIND>
+ Order allow,deny
+ Allow from all
+ </Limit>
+ <LimitExcept GET POST OPTIONS PROPFIND>
+ Order deny,allow
+ Deny from all
+ </LimitExcept>
+</Directory>
+EOF
+ }
+
+ $root = get_user_dir();
if ($o->{var}{user_mod}) {
substInFile {
- s|(/home/\*/)$root(/?)|$1$o->{var}{user_dir}$2|g;
- } "/etc/httpd/conf/httpd.conf";
+ s|(\s*)UserDir.*|$1UserDir $o->{var}{user_dir}|g;
+ s|<Directory\s+/home/\*/.*|<Directory /home/\*/$o->{var}{user_dir}>|g;
+ } $file;
+ } else {
substInFile {
- s|(\s*)UserDir\s*$root(/?)|$1UserDir $o->{var}{user_dir}$2|g;
- s|(/home/\*/)$root(/?)|$1$o->{var}{user_dir}$2|g;
- } "/etc/httpd/conf/httpd.conf";
- }
- else {
- substInFile {
- s|(\s*)UserDir\s*$root(/?)|$1UserDir disabled$2|g;
- } "/etc/httpd/conf/httpd.conf";
+ s|(\s*)UserDir\s*$root|$1UserDir disabled|g;
+ } $file;
}
}
@@ -219,9 +243,7 @@ sub do_it {
my $in = 'interactive'->vnew('su', 'Apache');
my $w = $in->wait_message(N("Apache server"), N("Configuring your system as Apache server ..."));
- my $file = "/etc/httpd/conf/httpd.conf";
my $that = "localhost";
-
if ($o->{var}{web_external} eq "1") {
$that = "all";
}