diff options
author | Jelmer Vernooij <jelmer@samba.org> | 2006-05-03 20:56:14 +0000 |
---|---|---|
committer | Gerald (Jerry) Carter <jerry@samba.org> | 2007-10-10 14:05:35 -0500 |
commit | 086c9cc5f4a9145ee93060db2eebb3badc325e44 (patch) | |
tree | 2ad27a4a77f0af14168e21c5314de93d26853952 /source4/gtk/common/credentials.c | |
parent | b2f8c9b82d1d96bd49d314a60191b7a62ffc52ca (diff) | |
download | samba-086c9cc5f4a9145ee93060db2eebb3badc325e44.tar.gz samba-086c9cc5f4a9145ee93060db2eebb3badc325e44.tar.bz2 samba-086c9cc5f4a9145ee93060db2eebb3badc325e44.zip |
r15422: Fix issues with functions being called recursively in the credentials
callback code.
(This used to be commit edf0701e877592695bd69124e528338c27f24efd)
Diffstat (limited to 'source4/gtk/common/credentials.c')
-rw-r--r-- | source4/gtk/common/credentials.c | 29 |
1 files changed, 10 insertions, 19 deletions
diff --git a/source4/gtk/common/credentials.c b/source4/gtk/common/credentials.c index 31e2bcf811..78bfca15d5 100644 --- a/source4/gtk/common/credentials.c +++ b/source4/gtk/common/credentials.c @@ -30,11 +30,11 @@ static void gtk_get_credentials(struct cli_credentials *credentials) GtkWidget *table; GtkWidget *entry_username; GtkWidget *entry_password; - GtkWidget *entry_domain; GtkWidget *dialog_action_area1; GtkWidget *cancelbutton1; GtkWidget *okbutton1; GtkWidget *anonymous; + char *username; dialog = gtk_dialog_new (); gtk_window_set_title (GTK_WINDOW (dialog), "Credentials"); @@ -44,19 +44,6 @@ static void gtk_get_credentials(struct cli_credentials *credentials) table = gtk_table_new(4, 2, FALSE); gtk_container_add(GTK_CONTAINER(GTK_DIALOG(dialog)->vbox), table); - label = gtk_label_new ("Domain:"); - - gtk_table_attach(GTK_TABLE(table),label,0,1,0,1,GTK_FILL,0,0,0); - - entry_domain = gtk_entry_new (); - gtk_table_attach(GTK_TABLE(table), entry_domain, 1,2,0,1, GTK_FILL, 0,0,0); - gtk_entry_set_activates_default (GTK_ENTRY (entry_domain), TRUE); - - if (credentials->domain_obtained != CRED_UNINITIALISED && - credentials->domain) { - gtk_entry_set_text(GTK_ENTRY(entry_domain), credentials->domain); - } - label = gtk_label_new ("Username:"); gtk_table_attach(GTK_TABLE(table),label,0,1,1,2,GTK_FILL,0,0,0); @@ -64,8 +51,12 @@ static void gtk_get_credentials(struct cli_credentials *credentials) entry_username = gtk_entry_new (); gtk_table_attach(GTK_TABLE(table),entry_username,1,2,1,2,GTK_FILL,0,0,0); gtk_entry_set_activates_default (GTK_ENTRY (entry_username), TRUE); - if (credentials->username_obtained != CRED_UNINITIALISED) { - gtk_entry_set_text(GTK_ENTRY(entry_username), credentials->username); + + username = cli_credentials_get_unparsed_name(credentials, credentials); + + if (credentials->username_obtained != CRED_UNINITIALISED && + username) { + gtk_entry_set_text(GTK_ENTRY(entry_username), username); } label = gtk_label_new ("Password:"); @@ -77,6 +68,7 @@ static void gtk_get_credentials(struct cli_credentials *credentials) gtk_entry_set_visibility (GTK_ENTRY (entry_password), FALSE); gtk_entry_set_activates_default (GTK_ENTRY (entry_password), TRUE); if (credentials->password_obtained != CRED_UNINITIALISED && + credentials->password_obtained != CRED_CALLBACK && credentials->password) { gtk_entry_set_text(GTK_ENTRY(entry_password), credentials->password); } @@ -99,9 +91,8 @@ static void gtk_get_credentials(struct cli_credentials *credentials) switch (gtk_dialog_run (GTK_DIALOG (dialog))) { case GTK_RESPONSE_OK: - cli_credentials_set_username(credentials, gtk_entry_get_text(GTK_ENTRY(entry_username)), CRED_SPECIFIED); - cli_credentials_set_password(credentials, gtk_entry_get_text(GTK_ENTRY(entry_password)), CRED_SPECIFIED); - cli_credentials_set_domain(credentials, gtk_entry_get_text(GTK_ENTRY(entry_domain)), CRED_SPECIFIED); + cli_credentials_parse_string(credentials, gtk_entry_get_text(GTK_ENTRY(entry_username)), CRED_CALLBACK_RESULT); + cli_credentials_set_password(credentials, gtk_entry_get_text(GTK_ENTRY(entry_password)), CRED_CALLBACK_RESULT); if (gtk_toggle_button_get_active(GTK_TOGGLE_BUTTON(anonymous))) { cli_credentials_set_anonymous(credentials); |