Use new module in top-level CGIs
[webmin.git] / config.cgi
1 #!/usr/local/bin/perl
2 # config.cgi
3 # Display a form for editing the configuration of a module.
4
5 BEGIN { push(@INC, ".."); };
6 use WebminCore;
7 require './config-lib.pl';
8 &init_config();
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 ];
17         }
18 else {
19         $help = undef;
20         }
21 &ui_print_header(&text('config_dir', $module_info{'desc'}),
22                  $text{'config_title'}, "", $help, 0, 1);
23
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'}),
27                       "width=100%", 2);
28 &read_file("$config_directory/$m/config", \%config);
29
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";
35         if (defined(&$fn)) {
36                 $func++;
37                 &foreign_call($m, "config_form", \%config);
38                 }
39         }
40 if (!$func) {
41         # Use config.info to create config inputs
42         &generate_config(\%config, "$mdir/config.info", $m);
43         }
44 print &ui_table_end();
45 print &ui_form_end([ [ "save", $text{'save'} ] ]);
46
47 &ui_print_footer("/$m", $text{'index'});
48