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 &foreign_call($m, "config_save", \%newconfig);
32 # Use config.info to parse config inputs
33 &parse_config(\%newconfig, "$mdir/config.info", $m);
35 &write_file("$config_directory/$m/config", \%newconfig);
36 &unlock_file("$config_directory/$m/config");
38 # Call any post-config save function
39 local $pfn = "${m}::config_post_save";
41 &foreign_call($m, "config_post_save", \%newconfig, \%oldconfig);
44 # Refresh installed modules
45 if (&foreign_check("webmin")) {
46 &foreign_require("webmin", "webmin-lib.pl");
47 &webmin::build_installed_modules(0, $m);
50 &webmin_log("_config_", undef, undef, \%in, $m);