\n"; # Setup error handler for down hosts sub add_error { $add_error_msg = join("", @_); } &remote_error_setup(\&add_error); # Make sure each host is set up for firewalling foreach $s (@add) { $add_error_msg = undef; local $host = { 'id' => $s->{'id'} }; local $firewall = &remote_foreign_check($s->{'host'}, $module_name); if ($add_error_msg) { print "$add_error_msg
\n"; next; } if (!$firewall) { print &text('add_echeck', $s->{'host'}),"
\n"; next; } &remote_foreign_require($s->{'host'}, $module_name); local $missing = &remote_foreign_call($s->{'host'}, $module_name, "missing_firewall_commands"); if ($missing) { print &text('add_emissing', $s->{'host'}, "$missing"),"
\n"; next; } @livetables = &remote_foreign_call($s->{'host'}, $module_name, "get_iptables_save", "ip${ipvx}tables-save |"); $rc = 0; foreach $t (@livetables) { $rc += @{$t->{'rules'}}; } print &text('add_ok', $s->{'host'}, $rc),"
\n"; &add_cluster_server($s); } &remote_finished(); if ($in{'add'}) { &webmin_log("add", "host", $add[0]->{'host'}); } else { &webmin_log("add", "group", $in{'group'}); } &ui_print_footer("cluster.cgi?version=${ipvx_arg}", $text{'cluster_return'});