[! use strict; use PVE::pvecfg; use PVE::I18N; use PVE::ConfigServer; use PVE::HTMLForm; use PVE::HTMLUtils; use PVE::HTMLGrid; !] [- use strict; my $out = ''; my $form = PVE::HTMLForm->new (\%fdat); my $grid = PVE::HTMLGrid->new ('fw1', 'fw2', 'fw3:right', 'fw4'); my $conn = PVE::ConfigClient::connect ($udat{auth_cookie}); my $mailto; if ($form->action eq 'save') { eval { check_write_mode ($udat{AM}); # verify email list $fdat{email} =~ s/[,;]/ /g; my @alist = split (/\s+/, $fdat{email}); foreach my $email (@alist) { PVE::HTMLUtils::check_field (__("Administrator EMail"), $email, 'EMAIL'); } $fdat{email} = join (',', @alist); if ($fdat{newpwd1}) { die __("Passwords does not match") . "\n" if $fdat{newpwd1} ne $fdat{newpwd2}; die __("Password is too short") . "\n" if $fdat{newpwd1} && length ($fdat{newpwd1}) < 5; } $mailto = $conn->get_config_data ('dotforward')->result; if ($mailto ne $fdat{email}) { $conn->set_config_data ('dotforward', $fdat{email}); } if ($fdat{newpwd1}) { $conn->modify_user ('root', undef, $fdat{newpwd1}); } }; $udat{popup_error} = $@ if $@; } # always reread $mailto = $conn->get_config_data ('dotforward')->result; $out .= $form->create_header(); $grid->add_row (__("Administrator EMail") . ':', $form->create_element('email', 'text', $fdat{email} || $mailto)); $grid->add_row (__("Password") . ':', $form->create_element ('newpwd1', 'password', $fdat{newpwd1})); $grid->add_row (__("Confirm Password") . ':', $form->create_element ('newpwd2', 'password', $fdat{newpwd2})); my $html = $grid->html(); $html .= $form->create_cmdbutton ('save'); $out .= PVE::HTMLUtils::create_statusframe (undef, __("Administrator Options"), undef, $html); $out .= $form->create_footer(); print OUT $out; -]