diff options
author | Pierre Ossman <ossman@cendio.se> | 2017-09-01 09:24:43 +0200 |
---|---|---|
committer | Pierre Ossman <ossman@cendio.se> | 2017-09-01 09:24:43 +0200 |
commit | 10a48102a4a892daee8ea325f008fccf9663b236 (patch) | |
tree | c1bc06ac25bd2c49eb02595f5af324f12de50939 /vncviewer | |
parent | 82e753d4e1928342c82cc7b82e854aa2666d1145 (diff) | |
download | tigervnc-10a48102a4a892daee8ea325f008fccf9663b236.tar.gz tigervnc-10a48102a4a892daee8ea325f008fccf9663b236.zip |
Merge authentication dialogs
Avoid having two separate code paths for the user/password and
only password dialogs. Makes it easier to extend things in the future.
Diffstat (limited to 'vncviewer')
-rw-r--r-- | vncviewer/UserDialog.cxx | 60 |
1 files changed, 37 insertions, 23 deletions
diff --git a/vncviewer/UserDialog.cxx b/vncviewer/UserDialog.cxx index b57588de..cf6893c8 100644 --- a/vncviewer/UserDialog.cxx +++ b/vncviewer/UserDialog.cxx @@ -82,46 +82,59 @@ void UserDialog::getUserPasswd(char** user, char** password) return; } - if (!user) { - fl_message_title(_("VNC authentication")); - *password = strDup(fl_password(_("Password:"), "")); - if (!*password) - throw rfb::Exception(_("Authentication cancelled")); + Fl_Window *win; + Fl_Input *username; + Fl_Secret_Input *passwd; + Fl_Box *icon; + Fl_Button *button; - return; - } + int y; - // Largely copied from FLTK so that we get the same look and feel - // as the simpler password input. - Fl_Window *win = new Fl_Window(410, 145, _("VNC authentication")); + win = new Fl_Window(410, 145, _("VNC authentication")); win->callback(button_cb,(void *)0); - Fl_Input *username = new Fl_Input(70, 25, 300, 25, _("Username:")); - username->align(FL_ALIGN_TOP_LEFT); + y = 10; - Fl_Secret_Input *passwd = new Fl_Secret_Input(70, 70, 300, 25, _("Password:")); - passwd->align(FL_ALIGN_TOP_LEFT); - - Fl_Box *icon = new Fl_Box(10, 10, 50, 50, "?"); + icon = new Fl_Box(10, 10, 50, 50, "?"); icon->box(FL_UP_BOX); icon->labelfont(FL_TIMES_BOLD); icon->labelsize(34); icon->color(FL_WHITE); icon->labelcolor(FL_BLUE); - Fl_Button *button; + y += 5; + + if (user) { + (new Fl_Box(70, y, win->w()-70-10, 20, _("Username:"))) + ->align(FL_ALIGN_LEFT|FL_ALIGN_INSIDE); + y += 20 + 5; + username = new Fl_Input(70, y, win->w()-70-10, 25); + y += 25 + 5; + } + + (new Fl_Box(70, y, win->w()-70-10, 20, _("Password:"))) + ->align(FL_ALIGN_LEFT|FL_ALIGN_INSIDE); + y += 20 + 5; + passwd = new Fl_Secret_Input(70, y, win->w()-70-10, 25); + y += 25 + 5; + + y += 5; - button = new Fl_Return_Button(310, 110, 90, 25, fl_ok); + button = new Fl_Return_Button(310, y, 90, 25, fl_ok); button->align(FL_ALIGN_INSIDE|FL_ALIGN_WRAP); button->callback(button_cb, (void*)0); - button = new Fl_Button(210, 110, 90, 25, fl_cancel); + button = new Fl_Button(210, y, 90, 25, fl_cancel); button->align(FL_ALIGN_INSIDE|FL_ALIGN_WRAP); button->callback(button_cb, (void*)1); button->shortcut(FL_Escape); + y += 25 + 10; + win->end(); + win->size(win->w(), y); + win->set_modal(); ret_val = -1; @@ -130,14 +143,15 @@ void UserDialog::getUserPasswd(char** user, char** password) while (win->shown()) Fl::wait(); if (ret_val == 0) { - *user = strDup(username->value()); + if (user) + *user = strDup(username->value()); *password = strDup(passwd->value()); - } else { - *user = strDup(""); - *password = strDup(""); } delete win; + + if (ret_val != 0) + throw rfb::Exception(_("Authentication cancelled")); } bool UserDialog::showMsgBox(int flags, const char* title, const char* text) |