diff options
author | jsorg71 <jsorg71> | 2005-04-02 20:57:14 +0000 |
---|---|---|
committer | jsorg71 <jsorg71> | 2005-04-02 20:57:14 +0000 |
commit | 3a7093caacd542c9902e4c9fd62ca6cd8212296d (patch) | |
tree | 0aadb596881e8aa1c9fc6ac74b5881c8d27748c3 | |
parent | 4c8ffafc9aad2397f6ccf7b5cb18520ce6bd231c (diff) | |
download | xrdp-proprietary-3a7093caacd542c9902e4c9fd62ca6cd8212296d.tar.gz xrdp-proprietary-3a7093caacd542c9902e4c9fd62ca6cd8212296d.zip |
added more login options
-rw-r--r-- | xrdp/constants.h | 2 | ||||
-rw-r--r-- | xrdp/xrdp.ini | 16 | ||||
-rw-r--r-- | xrdp/xrdp_bitmap.c | 34 | ||||
-rw-r--r-- | xrdp/xrdp_login_wnd.c | 453 | ||||
-rw-r--r-- | xrdp/xrdp_types.h | 6 |
5 files changed, 318 insertions, 193 deletions
diff --git a/xrdp/constants.h b/xrdp/constants.h index 2ee617d8..6b15a91f 100644 --- a/xrdp/constants.h +++ b/xrdp/constants.h @@ -429,3 +429,5 @@ #define WM_BUTTON5UP 109 #define WM_BUTTON5DOWN 110 #define WM_INVALIDATE 200 + +#define CB_ITEMCHANGE 300 diff --git a/xrdp/xrdp.ini b/xrdp/xrdp.ini index 9a682181..84f526c0 100644 --- a/xrdp/xrdp.ini +++ b/xrdp/xrdp.ini @@ -6,17 +6,23 @@ bitmap_compression=yes [vnc1] name=sesman lib=../vnc/libvnc.so -auth=local -ip=127.0.0.1 -port=-1 username=ask password=ask +ip=127.0.0.1 +port=-1 [vnc2] name=console lib=../vnc/libvnc.so -auth=local ip=127.0.0.1 port=5900 -username=ask +username=na +password=ask + +[vnc3] +name=vnc-any +lib=../vnc/libvnc.so +ip=ask +port=ask5900 +username=na password=ask diff --git a/xrdp/xrdp_bitmap.c b/xrdp/xrdp_bitmap.c index 3e0262e9..7adf031d 100644 --- a/xrdp/xrdp_bitmap.c +++ b/xrdp/xrdp_bitmap.c @@ -139,6 +139,7 @@ struct xrdp_bitmap* xrdp_bitmap_create_with_data(int width, int height, void xrdp_bitmap_delete(struct xrdp_bitmap* self) { int i; + struct xrdp_mod_data* mod_data; if (self == 0) { @@ -194,8 +195,23 @@ void xrdp_bitmap_delete(struct xrdp_bitmap* self) xrdp_list_remove_item(self->parent->child_list, i); } } - xrdp_list_delete(self->string_list); - xrdp_list_delete(self->data_list); + if (self->string_list != 0) /* for combo */ + { + xrdp_list_delete(self->string_list); + } + if (self->data_list != 0) /* for combo */ + { + for (i = 0; i < self->data_list->count; i++) + { + mod_data = (struct xrdp_mod_data*)xrdp_list_get_item(self->data_list, i); + if (mod_data != 0) + { + xrdp_list_delete(mod_data->names); + xrdp_list_delete(mod_data->values); + } + } + xrdp_list_delete(self->data_list); + } if (!self->do_not_free_data) { g_free(self->data); @@ -1343,6 +1359,10 @@ int xrdp_bitmap_def_proc(struct xrdp_bitmap* self, int msg, { self->item_index--; xrdp_bitmap_invalidate(self, 0); + if (self->parent->notify != 0) + { + self->parent->notify(self->parent, self, CB_ITEMCHANGE, 0, 0); + } } } /* right or down arrow */ @@ -1353,6 +1373,10 @@ int xrdp_bitmap_def_proc(struct xrdp_bitmap* self, int msg, { self->item_index++; xrdp_bitmap_invalidate(self, 0); + if (self->parent->notify != 0) + { + self->parent->notify(self->parent, self, CB_ITEMCHANGE, 0, 0); + } } } } @@ -1379,6 +1403,12 @@ int xrdp_bitmap_def_proc(struct xrdp_bitmap* self, int msg, { self->popped_from->item_index = self->item_index; xrdp_bitmap_invalidate(self->popped_from, 0); + if (self->popped_from->parent->notify != 0) + { + self->popped_from->parent->notify(self->popped_from->parent, + self->popped_from, + CB_ITEMCHANGE, 0, 0); + } } } } diff --git a/xrdp/xrdp_login_wnd.c b/xrdp/xrdp_login_wnd.c index 126b54e6..4893ce60 100644 --- a/xrdp/xrdp_login_wnd.c +++ b/xrdp/xrdp_login_wnd.c @@ -146,150 +146,281 @@ int xrdp_wm_delete_all_childs(struct xrdp_wm* self) } /*****************************************************************************/ -/* all login screen events go here */ -int xrdp_wm_login_notify(struct xrdp_bitmap* wnd, - struct xrdp_bitmap* sender, - int msg, long param1, long param2) +int set_mod_data_item(struct xrdp_mod_data* mod, char* name, char* value) +{ + int index; + + for (index = 0; index < mod->names->count; index++) + { + if (g_strcmp(name, (char*)xrdp_list_get_item(mod->names, index)) == 0) + { + xrdp_list_remove_item(mod->values, index); + xrdp_list_insert_item(mod->values, index, (long)g_strdup(value)); + } + } + return 0; +} + +/*****************************************************************************/ +int xrdp_wm_help_clicked(struct xrdp_bitmap* wnd) { struct xrdp_bitmap* help; struct xrdp_bitmap* but; - struct xrdp_bitmap* b; + + /* create help screen */ + help = xrdp_bitmap_create(300, 300, wnd->wm->screen->bpp, + WND_TYPE_WND, wnd->wm); + xrdp_list_insert_item(wnd->wm->screen->child_list, 0, (long)help); + help->parent = wnd->wm->screen; + help->owner = wnd; + wnd->modal_dialog = help; + help->bg_color = wnd->wm->grey; + help->left = wnd->wm->screen->width / 2 - help->width / 2; + help->top = wnd->wm->screen->height / 2 - help->height / 2; + help->notify = xrdp_wm_login_help_notify; + set_string(&help->caption1, "Login help"); + /* ok button */ + but = xrdp_bitmap_create(60, 25, wnd->wm->screen->bpp, + WND_TYPE_BUTTON, wnd->wm); + xrdp_list_insert_item(help->child_list, 0, (long)but); + but->parent = help; + but->owner = help; + but->left = 120; + but->top = 260; + but->id = 1; + but->tab_stop = 1; + set_string(&but->caption1, "OK"); + /* draw it */ + help->focused_control = but; + help->default_button = but; + help->esc_button = but; + xrdp_bitmap_invalidate(help, 0); + xrdp_wm_set_focused(wnd->wm, help); + return 0; +} + +/*****************************************************************************/ +int xrdp_wm_cancel_clicked(struct xrdp_bitmap* wnd) +{ + if (wnd != 0) + { + if (wnd->wm != 0) + { + if (wnd->wm->pro_layer != 0) + { + wnd->wm->pro_layer->term = 1; + } + } + } + return 0; +} + +/*****************************************************************************/ +int xrdp_wm_ok_clicked(struct xrdp_bitmap* wnd) +{ struct xrdp_bitmap* combo; + struct xrdp_bitmap* label; struct xrdp_bitmap* edit; struct xrdp_wm* wm; - struct xrdp_rect rect; - struct xrdp_mod_data con_mod; - struct xrdp_mod_data* mod; + struct xrdp_list* names; + struct xrdp_list* values; + struct xrdp_mod_data* mod_data; int i; - if (wnd->modal_dialog != 0 && msg != 100) - { - return 0; - } wm = wnd->wm; - if (msg == 1) /* click */ + combo = xrdp_bitmap_get_child_by_id(wnd, 6); + if (combo != 0) { - if (sender->id == 1) /* help button */ - { - /* create help screen */ - help = xrdp_bitmap_create(300, 300, wnd->wm->screen->bpp, - WND_TYPE_WND, wnd->wm); - xrdp_list_insert_item(wnd->wm->screen->child_list, 0, (long)help); - help->parent = wnd->wm->screen; - help->owner = wnd; - wnd->modal_dialog = help; - help->bg_color = wnd->wm->grey; - help->left = wnd->wm->screen->width / 2 - help->width / 2; - help->top = wnd->wm->screen->height / 2 - help->height / 2; - help->notify = xrdp_wm_login_help_notify; - set_string(&help->caption1, "Login help"); - /* ok button */ - but = xrdp_bitmap_create(60, 25, wnd->wm->screen->bpp, - WND_TYPE_BUTTON, wnd->wm); - xrdp_list_insert_item(help->child_list, 0, (long)but); - but->parent = help; - but->owner = help; - but->left = 120; - but->top = 260; - but->id = 1; - but->tab_stop = 1; - set_string(&but->caption1, "OK"); - /* draw it */ - help->focused_control = but; - help->default_button = but; - help->esc_button = but; - xrdp_bitmap_invalidate(help, 0); - xrdp_wm_set_focused(wnd->wm, help); - } - else if (sender->id == 2) /* cancel button */ + mod_data = (struct xrdp_mod_data*) + xrdp_list_get_item(combo->data_list, combo->item_index); + if (mod_data != 0) { - if (wnd != 0) + /* get the user typed values */ + i = 100; + label = xrdp_bitmap_get_child_by_id(wnd, i); + edit = xrdp_bitmap_get_child_by_id(wnd, i + 1); + while (label != 0 && edit != 0) { - if (wnd->wm != 0) + set_mod_data_item(mod_data, label->caption1, edit->caption1); + i += 2; + label = xrdp_bitmap_get_child_by_id(wnd, i); + edit = xrdp_bitmap_get_child_by_id(wnd, i + 1); + } + if (xrdp_wm_setup_mod(wm, mod_data) == 0) + { + /* gota copy these cause dialog gets freed */ + names = xrdp_list_create(); + names->auto_free = 1; + for (i = 0; i < mod_data->names->count; i++) + { + xrdp_list_add_item(names, + (long)g_strdup((char*)xrdp_list_get_item(mod_data->names, i))); + } + values = xrdp_list_create(); + values->auto_free = 1; + for (i = 0; i < mod_data->values->count; i++) + { + xrdp_list_add_item(values, + (long)g_strdup((char*)xrdp_list_get_item(mod_data->values, i))); + } + xrdp_wm_delete_all_childs(wm); + if (!wm->pro_layer->term) { - if (wnd->wm->pro_layer != 0) + if (wm->mod->mod_start(wm->mod, wm->screen->width, + wm->screen->height, wm->screen->bpp) != 0) { - wnd->wm->pro_layer->term = 1; + wm->pro_layer->term = 1; /* kill session */ } } - } - } - else if (sender->id == 3) /* ok button */ - { - combo = xrdp_bitmap_get_child_by_id(wnd, 6); - if (combo != 0) - { - mod = (struct xrdp_mod_data*) - xrdp_list_get_item(combo->data_list, combo->item_index); - if (mod != 0) + if (!wm->pro_layer->term) { - con_mod = *mod; - if (g_strcmp(con_mod.username, "ask") == 0) + for (i = 0; i < names->count; i++) { - edit = xrdp_bitmap_get_child_by_id(wnd, 4); - if (edit != 0) - { - g_strcpy(con_mod.username, edit->caption1); - } + wm->mod->mod_set_param(wm->mod, + (char*)xrdp_list_get_item(names, i), + (char*)xrdp_list_get_item(values, i)); } - if (g_strcmp(con_mod.password, "ask") == 0) + if (wm->mod->mod_connect(wm->mod) != 0) { - edit = xrdp_bitmap_get_child_by_id(wnd, 5); - if (edit != 0) - { - g_strcpy(con_mod.password, edit->caption1); - } + /* totaly free mod */ + wm->mod_exit(wm->mod); + g_free_library(wm->mod_handle); + wm->mod = 0; + wm->mod_handle = 0; + wm->mod_init = 0; + wm->mod_exit = 0; } - if (xrdp_wm_setup_mod(wm, mod) == 0) + else /* close connection log window if connection is ok */ { - xrdp_wm_delete_all_childs(wm); - if (!wm->pro_layer->term) + if (wm->log_wnd != 0) { - if (wm->mod->mod_start(wm->mod, wm->screen->width, - wm->screen->height, wm->screen->bpp) != 0) - { - wm->pro_layer->term = 1; /* kill session */ - } + xrdp_bitmap_delete(wm->log_wnd); } - if (!wm->pro_layer->term) - { - wm->mod->mod_set_param(wm->mod, "ip", con_mod.ip); - wm->mod->mod_set_param(wm->mod, "port", con_mod.port); - wm->mod->mod_set_param(wm->mod, "username", con_mod.username); - wm->mod->mod_set_param(wm->mod, "password", con_mod.password); - if (wm->mod->mod_connect(wm->mod) != 0) - { - /* totaly free mod */ - wm->mod_exit(wm->mod); - g_free_library(wm->mod_handle); - wm->mod = 0; - wm->mod_handle = 0; - wm->mod_init = 0; - wm->mod_exit = 0; - } - else /* close connection log window if connection is ok */ - { - if (wm->log_wnd != 0) - { - xrdp_bitmap_delete(wm->log_wnd); - } - } - } - if (!wm->pro_layer->term) + } + } + if (!wm->pro_layer->term) + { + if (wm->mod != 0) + { + if (wm->mod->sck != 0) { - if (wm->mod != 0) - { - if (wm->mod->sck != 0) - { - wm->pro_layer->app_sck = wm->mod->sck; - } - } + wm->pro_layer->app_sck = wm->mod->sck; } } } + xrdp_list_delete(names); + xrdp_list_delete(values); } } } + return 0; +} + +/******************************************************************************/ +int xrdp_wm_show_edits(struct xrdp_wm* self, struct xrdp_bitmap* combo) +{ + int count; + int index; + int insert_index; + char* name; + char* value; + struct xrdp_mod_data* mod; + struct xrdp_bitmap* b; + + /* free labels and edits, cause we gota create them */ + /* creation or combo changed */ + for (index = 100; index < 200; index++) + { + b = xrdp_bitmap_get_child_by_id(combo->parent, index); + xrdp_bitmap_delete(b); + } + + insert_index = xrdp_list_index_of(self->login_window->child_list, + (long)combo); + insert_index++; + mod = (struct xrdp_mod_data*) + xrdp_list_get_item(combo->data_list, combo->item_index); + if (mod != 0) + { + count = 0; + for (index = 0; index < mod->names->count; index++) + { + value = (char*)xrdp_list_get_item(mod->values, index); + if (g_strncmp("ask", value, 3) == 0) + { + /* label */ + b = xrdp_bitmap_create(60, 20, self->screen->bpp, + WND_TYPE_LABEL, self); + xrdp_list_insert_item(self->login_window->child_list, insert_index, + (long)b); + insert_index++; + b->parent = self->login_window; + b->owner = self->login_window; + b->left = 155; + b->top = 60 + 25 * count; + b->id = 100 + 2 * count; + name = (char*)xrdp_list_get_item(mod->names, index); + set_string(&b->caption1, name); + /* edit */ + b = xrdp_bitmap_create(140, 20, self->screen->bpp, + WND_TYPE_EDIT, self); + xrdp_list_insert_item(self->login_window->child_list, insert_index, + (long)b); + insert_index++; + b->parent = self->login_window; + b->owner = self->login_window; + b->left = 220; + b->top = 60 + 25 * count; + b->id = 100 + 2 * count + 1; + b->pointer = 1; + b->tab_stop = 1; + b->caption1 = (char*)g_malloc(256, 1); + g_strcpy(b->caption1, value + 3); + b->edit_pos = g_strlen(b->caption1); + if (self->login_window->focused_control == 0) + { + self->login_window->focused_control = b; + } + if (g_strcmp(name, "password") == 0) + { + b->password_char = '*'; + } + count++; + } + } + } + return 0; +} + +/*****************************************************************************/ +/* all login screen events go here */ +int xrdp_wm_login_notify(struct xrdp_bitmap* wnd, + struct xrdp_bitmap* sender, + int msg, long param1, long param2) +{ + struct xrdp_bitmap* b; + struct xrdp_rect rect; + int i; + + if (wnd->modal_dialog != 0 && msg != 100) + { + return 0; + } + if (msg == 1) /* click */ + { + if (sender->id == 1) /* help button */ + { + xrdp_wm_help_clicked(wnd); + } + else if (sender->id == 2) /* cancel button */ + { + xrdp_wm_cancel_clicked(wnd); + } + else if (sender->id == 3) /* ok button */ + { + xrdp_wm_ok_clicked(wnd); + } + } else if (msg == 2) /* mouse move */ { } @@ -308,6 +439,11 @@ int xrdp_wm_login_notify(struct xrdp_bitmap* wnd, xrdp_wm_set_focused(wnd->wm, wnd); } } + else if (msg == CB_ITEMCHANGE) /* combo box change */ + { + xrdp_wm_show_edits(wnd->wm, sender); + xrdp_bitmap_invalidate(wnd, 0); /* invalidate the whole dialog for now */ + } return 0; } @@ -344,7 +480,11 @@ int xrdp_wm_login_fill_in_combo(struct xrdp_wm* self, struct xrdp_bitmap* b) { mod_data = (struct xrdp_mod_data*) g_malloc(sizeof(struct xrdp_mod_data), 1); - g_strcpy(mod_data->name, p); + mod_data->names = xrdp_list_create(); + mod_data->names->auto_free = 1; + mod_data->values = xrdp_list_create(); + mod_data->values->auto_free = 1; + g_strcpy(mod_data->name, p); /* set name in square bracket */ for (j = 0; j < section_names->count; j++) { q = (char*)xrdp_list_get_item(section_names, j); @@ -357,21 +497,10 @@ int xrdp_wm_login_fill_in_combo(struct xrdp_wm* self, struct xrdp_bitmap* b) { g_strcpy(mod_data->lib, r); } - else if (g_strcmp("ip", q) == 0) - { - g_strcpy(mod_data->ip, r); - } - else if (g_strcmp("port", q) == 0) + else { - g_strcpy(mod_data->port, r); - } - else if (g_strcmp("username", q) == 0) - { - g_strcpy(mod_data->username, r); - } - else if (g_strcmp("password", q) == 0) - { - g_strcpy(mod_data->password, r); + xrdp_list_add_item(mod_data->names, (long)g_strdup(q)); + xrdp_list_add_item(mod_data->values, (long)g_strdup(r)); } } xrdp_list_add_item(b->string_list, (long)g_strdup(mod_data->name)); @@ -389,6 +518,7 @@ int xrdp_wm_login_fill_in_combo(struct xrdp_wm* self, struct xrdp_bitmap* b) int xrdp_login_wnd_create(struct xrdp_wm* self) { struct xrdp_bitmap* but; + struct xrdp_bitmap* combo; /* draw login window */ self->login_window = xrdp_bitmap_create(400, 200, self->screen->bpp, @@ -428,63 +558,19 @@ int xrdp_login_wnd_create(struct xrdp_wm* self) but->parent = self->login_window; but->owner = self->login_window; but->left = 155; - but->top = 50; - set_string(&but->caption1, "Username"); - - /* edit */ - but = xrdp_bitmap_create(140, 20, self->screen->bpp, WND_TYPE_EDIT, self); - xrdp_list_add_item(self->login_window->child_list, (long)but); - but->parent = self->login_window; - but->owner = self->login_window; - but->left = 220; - but->top = 50; - but->id = 4; - but->pointer = 1; - but->tab_stop = 1; - but->caption1 = (char*)g_malloc(256, 1); - self->login_window->focused_control = but; - - /* label */ - but = xrdp_bitmap_create(60, 20, self->screen->bpp, WND_TYPE_LABEL, self); - xrdp_list_add_item(self->login_window->child_list, (long)but); - but->parent = self->login_window; - but->owner = self->login_window; - but->left = 155; - but->top = 80; - set_string(&but->caption1, "Password"); - - /* edit */ - but = xrdp_bitmap_create(140, 20, self->screen->bpp, WND_TYPE_EDIT, self); - xrdp_list_add_item(self->login_window->child_list, (long)but); - but->parent = self->login_window; - but->owner = self->login_window; - but->left = 220; - but->top = 80; - but->id = 5; - but->pointer = 1; - but->tab_stop = 1; - but->caption1 = (char*)g_malloc(256, 1); - but->password_char = '*'; - - /* label */ - but = xrdp_bitmap_create(60, 20, self->screen->bpp, WND_TYPE_LABEL, self); - xrdp_list_add_item(self->login_window->child_list, (long)but); - but->parent = self->login_window; - but->owner = self->login_window; - but->left = 155; - but->top = 110; + but->top = 35; set_string(&but->caption1, "Module"); /* combo */ - but = xrdp_bitmap_create(140, 20, self->screen->bpp, WND_TYPE_COMBO, self); - xrdp_list_add_item(self->login_window->child_list, (long)but); - but->parent = self->login_window; - but->owner = self->login_window; - but->left = 220; - but->top = 110; - but->id = 6; - but->tab_stop = 1; - xrdp_wm_login_fill_in_combo(self, but); + combo = xrdp_bitmap_create(140, 20, self->screen->bpp, WND_TYPE_COMBO, self); + xrdp_list_add_item(self->login_window->child_list, (long)combo); + combo->parent = self->login_window; + combo->owner = self->login_window; + combo->left = 220; + combo->top = 35; + combo->id = 6; + combo->tab_stop = 1; + xrdp_wm_login_fill_in_combo(self, combo); /* button */ but = xrdp_bitmap_create(60, 25, self->screen->bpp, WND_TYPE_BUTTON, self); @@ -521,5 +607,8 @@ int xrdp_login_wnd_create(struct xrdp_wm* self) set_string(&but->caption1, "Help"); but->tab_stop = 1; + /* labels and edits */ + xrdp_wm_show_edits(self, combo); + return 0; } diff --git a/xrdp/xrdp_types.h b/xrdp/xrdp_types.h index 86fc569a..de687c67 100644 --- a/xrdp/xrdp_types.h +++ b/xrdp/xrdp_types.h @@ -525,8 +525,6 @@ struct xrdp_mod_data { char name[256]; char lib[256]; - char ip[256]; - char port[256]; - char username[256]; - char password[256]; + struct xrdp_list* names; + struct xrdp_list* values; }; |