3 # Display a form for editing the configuration of a module.
5 BEGIN { push(@INC, ".."); };
7 require './config-lib.pl';
9 $m = $in{'module'} || $ARGV[0];
10 &foreign_available($m) || &error($text{'config_eaccess'});
11 %access = &get_module_acl(undef, $m);
12 $access{'noconfig'} &&
13 &error($text{'config_ecannot'});
14 %module_info = &get_module_info($m);
15 if (-r &help_file($m, "config_intro")) {
16 $help = [ "config_intro", $m ];
21 &ui_print_header(&text('config_dir', $module_info{'desc'}),
22 $text{'config_title'}, "", $help, 0, 1);
24 print &ui_form_start("config_save.cgi", "post");
25 print &ui_hidden("module", $m),"\n";
26 print &ui_table_start(&text('config_header', $module_info{'desc'}),
28 &read_file("$config_directory/$m/config", \%config);
30 $mdir = &module_root_directory($m);
31 if (-r "$mdir/config_info.pl") {
32 # Module has a custom config editor
33 &foreign_require($m, "config_info.pl");
34 local $fn = "${m}::config_form";
37 &foreign_call($m, "config_form", \%config);
41 # Use config.info to create config inputs
42 &generate_config(\%config, "$mdir/config.info", $m);
44 print &ui_table_end();
45 print &ui_form_end([ [ "save", $text{'save'} ] ]);
47 &ui_print_footer("/$m", $text{'index'});