Handle hostnames with upper-case letters
[webmin.git] / session_login.cgi
index acfe0ff..f7c2546 100755 (executable)
@@ -2,10 +2,11 @@
 # session_login.cgi
 # Display the login form used in session login mode
 
+BEGIN { push(@INC, ".."); };
+use WebminCore;
+
 $pragma_no_cache = 1;
 #$ENV{'MINISERV_INTERNAL'} || die "Can only be called by miniserv.pl";
-require './web-lib.pl';
-require './ui-lib.pl';
 &init_config();
 &ReadParse();
 if ($gconfig{'loginbanner'} && $ENV{'HTTP_COOKIE'} !~ /banner=1/ &&
@@ -28,8 +29,11 @@ $sidname = $miniserv{'sidname'} || "sid";
 print "Set-Cookie: banner=0; path=/$sec\r\n" if ($gconfig{'loginbanner'});
 print "Set-Cookie: $sidname=x; path=/$sec\r\n" if ($in{'logout'});
 print "Set-Cookie: testing=1; path=/$sec\r\n";
-&ui_print_unbuffered_header(undef, undef, undef, undef, undef, 1, 1, undef,
-                           undef, "onLoad='document.forms[0].pass.value = \"\"; document.forms[0].user.focus()'");
+&ui_print_unbuffered_header(
+       undef, undef, undef, undef, undef, 1, 1, undef,
+       "<title>$text{'session_header'}</title>",
+       "onLoad='document.forms[0].pass.value = \"\"; ".
+       "document.forms[0].user.focus()'");
 
 if ($tconfig{'inframe'}) {
        # Framed themes lose original page
@@ -47,11 +51,13 @@ elsif ($in{'timed_out'}) {
        print "<h3>",&text('session_timed_out', int($in{'timed_out'}/60)),"</h3><p>\n";
        }
 print "$text{'session_prefix'}\n";
-print "<form action=$gconfig{'webprefix'}/session_login.cgi method=post>\n";
-print "<input type=hidden name=page value='".&html_escape($in{'page'})."'>\n";
-print "<table border width=40%>\n";
-print "<tr $tb> <td><b>$text{'session_header'}</b></td> </tr>\n";
-print "<tr $cb> <td align=center><table cellpadding=3>\n";
+
+print &ui_form_start("$gconfig{'webprefix'}/session_login.cgi", "post");
+print &ui_hidden("page", $in{'page'});
+print &ui_table_start($text{'session_header'},
+                     "width=40% class='loginform'", 2);
+
+# Login message
 if ($gconfig{'realname'}) {
        $host = &get_display_hostname();
        }
@@ -60,21 +66,26 @@ else {
        $host =~ s/:\d+//g;
        $host = &html_escape($host);
        }
-print "<tr> <td colspan=2 align=center>",
+print &ui_table_row(undef,
       &text($gconfig{'nohostname'} ? 'session_mesg2' : 'session_mesg',
-           "<tt>$host</tt>"),"</td> </tr>\n";
-print "<tr> <td><b>$text{'session_user'}</b></td>\n";
-print "<td><input name=user size=20 value='".&html_escape($in{'failed'})."'></td> </tr>\n";
-print "<tr> <td><b>$text{'session_pass'}</b></td>\n";
-print "<td><input name=pass size=20 type=password></td> </tr>\n";
-print "<tr> <td colspan=2 align=center><input type=submit value='$text{'session_login'}'>\n";
-print "<input type=reset value='$text{'session_clear'}'><br>\n";
+           "<tt>$host</tt>"), 2, [ "align=center", "align=center" ]);
+
+# Username and password
+print &ui_table_row($text{'session_user'},
+       &ui_textbox("user", $in{'failed'}, 20));
+print &ui_table_row($text{'session_pass'},
+       &ui_password("pass", undef, 20));
 if (!$gconfig{'noremember'}) {
-       print "<input type=checkbox name=save value=1> $text{'session_save'}\n";
+       print &ui_table_row(" ",
+               &ui_checkbox("save", 1, $text{'session_save'}, 0));
        }
-print "</td> </tr>\n";
-print "</table></td></tr></table><p>\n";
-print "</form></center>\n";
+
+print &ui_table_end(),"\n";
+print &ui_submit($text{'session_login'});
+print &ui_reset($text{'session_clear'});
+print &ui_form_end();
+print "</center>\n";
+
 print "$text{'session_postfix'}\n";
 
 # Output frame-detection Javascript, if theme uses frames