3 # Save inputs from config.cgi
5 BEGIN { push(@INC, ".."); };
7 require './config-lib.pl';
11 &error_setup($text{'config_err'});
12 &foreign_available($m) || &error($text{'config_eaccess'});
13 %access = &get_module_acl(undef, $m);
14 $access{'noconfig'} && &error($text{'config_ecannot'});
16 mkdir("$config_directory/$m", 0700);
17 &lock_file("$config_directory/$m/config");
18 &read_file("$config_directory/$m/config", \%newconfig);
19 %oldconfig = %newconfig;
21 $mdir = &module_root_directory($m);
22 if (-r "$mdir/config_info.pl") {
23 # Module has a custom config editor
24 &foreign_require($m, "config_info.pl");
25 local $fn = "${m}::config_form";
28 $pkg =~ s/[^A-Za-z0-9]/_/g;
29 eval "\%${pkg}::in = \%in";
31 &foreign_call($m, "config_save", \%newconfig);
35 # Use config.info to parse config inputs
36 &parse_config(\%newconfig, "$mdir/config.info", $m);
38 &write_file("$config_directory/$m/config", \%newconfig);
39 &unlock_file("$config_directory/$m/config");
41 # Call any post-config save function
42 local $pfn = "${m}::config_post_save";
44 &foreign_call($m, "config_post_save", \%newconfig, \%oldconfig);
47 # Refresh installed modules
48 if (&foreign_check("webmin")) {
49 &foreign_require("webmin", "webmin-lib.pl");
50 &webmin::build_installed_modules(0, $m);
53 &webmin_log("_config_", undef, undef, \%in, $m);