summaryrefslogtreecommitdiff
path: root/source4/gtk/tools
diff options
context:
space:
mode:
Diffstat (limited to 'source4/gtk/tools')
-rw-r--r--source4/gtk/tools/gregedit.c16
-rw-r--r--source4/gtk/tools/gwcrontab.c18
-rw-r--r--source4/gtk/tools/gwsam.c410
-rw-r--r--source4/gtk/tools/gwsam_user.c356
4 files changed, 772 insertions, 28 deletions
diff --git a/source4/gtk/tools/gregedit.c b/source4/gtk/tools/gregedit.c
index 6c13dcaef0..d26f393bb9 100644
--- a/source4/gtk/tools/gregedit.c
+++ b/source4/gtk/tools/gregedit.c
@@ -19,26 +19,14 @@
Foundation, Inc., 675 Mass Ave, Cambridge, MA 02139, USA.
*/
-#ifdef HAVE_CONFIG_H
-# include <config.h>
-#endif
-
-#include <sys/types.h>
-#include <sys/stat.h>
-#include <unistd.h>
-#include <string.h>
-#include <stdio.h>
-
-#include <gdk/gdkkeysyms.h>
-#include <gtk/gtk.h>
#include "includes.h"
+#include "gtk/common/gtk-smb.h"
GtkWidget *openfilewin;
GtkWidget *savefilewin;
GtkTreeStore *store_keys;
GtkListStore *store_vals;
GtkWidget *tree_keys;
-GtkWidget *aboutwin;
GtkWidget *mainwin;
GtkWidget *save;
@@ -265,7 +253,7 @@ static void on_delete_activate (GtkMenuItem *menuitem,
static void on_about_activate (GtkMenuItem *menuitem,
gpointer user_data)
{
- GtkDialog *aboutwin = GTK_DIALOG(create_gtk_samba_about_dialog());
+ GtkDialog *aboutwin = GTK_DIALOG(create_gtk_samba_about_dialog("gregedit"));
gtk_dialog_run(aboutwin);
gtk_widget_destroy(GTK_WIDGET(aboutwin));
}
diff --git a/source4/gtk/tools/gwcrontab.c b/source4/gtk/tools/gwcrontab.c
index 9683570664..aef9c15b52 100644
--- a/source4/gtk/tools/gwcrontab.c
+++ b/source4/gtk/tools/gwcrontab.c
@@ -19,19 +19,8 @@
Foundation, Inc., 675 Mass Ave, Cambridge, MA 02139, USA.
*/
-#ifdef HAVE_CONFIG_H
-# include <config.h>
-#endif
-
-#include <sys/types.h>
-#include <sys/stat.h>
-#include <unistd.h>
-#include <string.h>
-#include <stdio.h>
-
-#include <gdk/gdkkeysyms.h>
-#include <gtk/gtk.h>
#include "includes.h"
+#include "gtk/common/gtk-smb.h"
struct dcerpc_pipe *at_pipe = NULL;
GtkWidget *mainwin;
@@ -211,7 +200,7 @@ void
on_about_activate (GtkMenuItem *menuitem,
gpointer user_data)
{
- GtkDialog *aboutwin = GTK_DIALOG(create_gtk_samba_about_dialog());
+ GtkDialog *aboutwin = GTK_DIALOG(create_gtk_samba_about_dialog("gwcrontab"));
gtk_dialog_run(aboutwin);
gtk_widget_destroy(GTK_WIDGET(aboutwin));
}
@@ -242,6 +231,7 @@ create_mainwindow (void)
accel_group = gtk_accel_group_new ();
mainwindow = gtk_window_new (GTK_WINDOW_TOPLEVEL);
+ gtk_window_set_default_size (GTK_WINDOW (mainwindow), 642, 562);
gtk_window_set_title (GTK_WINDOW (mainwindow), "Task Scheduler");
vbox = gtk_vbox_new (FALSE, 0);
@@ -529,7 +519,7 @@ static GtkWidget*create_new_job_dialog (void)
-int main(int argc, char **argv)
+ int main(int argc, char **argv)
{
gtk_init(&argc, &argv);
mainwin = create_mainwindow();
diff --git a/source4/gtk/tools/gwsam.c b/source4/gtk/tools/gwsam.c
new file mode 100644
index 0000000000..9df9698ba9
--- /dev/null
+++ b/source4/gtk/tools/gwsam.c
@@ -0,0 +1,410 @@
+/*
+ Unix SMB/CIFS implementation.
+ GTK+ SAM frontend
+
+ Copyright (C) Jelmer Vernooij 2004
+
+ This program is free software; you can redistribute it and/or modify
+ it under the terms of the GNU General Public License as published by
+ the Free Software Foundation; either version 2 of the License, or
+ (at your option) any later version.
+
+ This program is distributed in the hope that it will be useful,
+ but WITHOUT ANY WARRANTY; without even the implied warranty of
+ MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
+ GNU General Public License for more details.
+
+ You should have received a copy of the GNU General Public License
+ along with this program; if not, write to the Free Software
+ Foundation, Inc., 675 Mass Ave, Cambridge, MA 02139, USA.
+*/
+
+#include "includes.h"
+#include "gtk/common/gtk-smb.h"
+
+struct policy_handle sam_handle;
+struct dcerpc_pipe *sam_pipe = NULL;
+struct policy_handle domain_handle;
+GtkWidget *mainwin;
+
+void update_grouplist()
+{
+ if(!sam_pipe) return;
+ //FIXME
+}
+
+void update_userlist()
+{
+ NTSTATUS status;
+ struct samr_EnumDomainUsers r;
+ uint32_t resume_handle=0;
+ int i;
+ BOOL ret = True;
+ TALLOC_CTX *mem_ctx;
+
+ if(!sam_pipe) return;
+
+ mem_ctx = talloc_init("update_userlist");
+ r.in.handle = &domain_handle;
+ r.in.resume_handle = &resume_handle;
+ r.in.acct_flags = 0;
+ r.in.max_size = (uint32_t)-1;
+ r.out.resume_handle = &resume_handle;
+
+ status = dcerpc_samr_EnumDomainUsers(sam_pipe, mem_ctx, &r);
+ if (!NT_STATUS_IS_OK(status)) {
+ gtk_show_ntstatus(mainwin, status);
+ talloc_destroy(mem_ctx);
+ return;
+ }
+
+ if (!r.out.sam || r.out.sam->count == 0) {
+ talloc_destroy(mem_ctx);
+ return;
+ }
+
+ for (i=0;i<r.out.sam->count;i++) {
+ printf("Found: %s\n", r.out.sam->entries[i].name.name);
+ /* FIXME: Query user info */
+
+// if (!test_OpenUser(sam_pipe, mem_ctx, &sam_handle, r.out.sam->entries[i].idx)) {
+// ret = False;
+// }
+ }
+ talloc_destroy(mem_ctx);
+}
+
+void
+on_new1_activate (GtkMenuItem *menuitem,
+ gpointer user_data)
+{
+
+}
+
+void
+on_select_domain_activate (GtkMenuItem *menuitem,
+ gpointer user_data)
+{
+ GtkSelectDomainDialog *d;
+ gint result;
+ d = gtk_select_domain_dialog_new(sam_pipe);
+ result = gtk_dialog_run(GTK_DIALOG(d));
+ switch(result) {
+ case GTK_RESPONSE_ACCEPT:
+ break;
+ default:
+ gtk_widget_destroy(GTK_WIDGET(d));
+ return;
+ }
+ domain_handle = gtk_select_domain_dialog_get_handle(d);
+ gtk_widget_destroy(GTK_WIDGET(d));
+}
+
+void on_connect_activate (GtkMenuItem *menuitem, gpointer user_data)
+{
+ GtkRpcBindingDialog *d;
+ NTSTATUS status;
+ struct samr_Connect r;
+ TALLOC_CTX *mem_ctx;
+ gint result;
+
+ d = GTK_RPC_BINDING_DIALOG(gtk_rpc_binding_dialog_new(FALSE));
+ result = gtk_dialog_run(GTK_DIALOG(d));
+ switch(result) {
+ case GTK_RESPONSE_ACCEPT:
+ break;
+ default:
+ gtk_widget_destroy(GTK_WIDGET(d));
+ return;
+ }
+
+ /* If connected, get list of jobs */
+ status = dcerpc_pipe_connect(&sam_pipe, (char *)gtk_rpc_binding_dialog_get_binding(d, DCERPC_SAMR_NAME), DCERPC_SAMR_UUID, DCERPC_SAMR_VERSION, lp_workgroup(), (char *)gtk_rpc_binding_dialog_get_username(d), (char *)gtk_rpc_binding_dialog_get_password(d));
+ if(!NT_STATUS_IS_OK(status)) {
+ gtk_show_ntstatus(mainwin, status);
+ sam_pipe = NULL;
+ gtk_widget_destroy(GTK_WIDGET(d));
+ return;
+ }
+
+ r.in.system_name = 0;
+ r.in.access_mask = SEC_RIGHTS_MAXIMUM_ALLOWED;
+ r.out.handle = &sam_handle;
+
+ mem_ctx = talloc_init("connect");
+ status = dcerpc_samr_Connect(sam_pipe, mem_ctx, &r);
+ talloc_destroy(mem_ctx);
+ if (!NT_STATUS_IS_OK(status)) {
+ gtk_show_ntstatus(mainwin, status);
+ sam_pipe = NULL;
+ gtk_widget_destroy(GTK_WIDGET(d));
+ return;
+ }
+
+ gtk_widget_destroy(GTK_WIDGET(d));
+
+ update_userlist();
+ update_grouplist();
+}
+
+void
+on_quit_activate (GtkMenuItem *menuitem,
+ gpointer user_data)
+{
+ if(sam_pipe)dcerpc_pipe_close(sam_pipe);
+ gtk_main_quit();
+}
+
+
+void
+on_account_activate (GtkMenuItem *menuitem,
+ gpointer user_data)
+{
+ //FIXME
+}
+
+
+void
+on_user_rights_activate (GtkMenuItem *menuitem,
+ gpointer user_data)
+{
+ //FIXME
+}
+
+
+void
+on_audit_activate (GtkMenuItem *menuitem,
+ gpointer user_data)
+{
+ //FIXME
+}
+
+
+void
+on_trust_relations_activate (GtkMenuItem *menuitem,
+ gpointer user_data)
+{
+ //FIXME
+}
+
+
+void
+on_refresh_activate (GtkMenuItem *menuitem,
+ gpointer user_data)
+{
+ update_userlist();
+ update_grouplist();
+}
+
+
+void
+on_about_activate (GtkMenuItem *menuitem,
+ gpointer user_data)
+{
+ GtkDialog *aboutwin = GTK_DIALOG(create_gtk_samba_about_dialog("gwsam"));
+ gtk_dialog_run(aboutwin);
+ gtk_widget_destroy(GTK_WIDGET(aboutwin));
+}
+
+ GtkWidget*
+create_mainwindow (void)
+{
+ GtkWidget *mainwin;
+ GtkWidget *vbox1;
+ GtkWidget *connect;
+ GtkWidget *menubar;
+ GtkWidget *menuitem1;
+ GtkWidget *menuitem1_menu;
+ GtkWidget *new1;
+ GtkWidget *separatormenuitem1;
+ GtkWidget *quit;
+ GtkWidget *menuitem2;
+ GtkWidget *seldomain;
+ GtkWidget *menuitem2_menu;
+ GtkWidget *cut1;
+ GtkWidget *copy1;
+ GtkWidget *paste1;
+ GtkWidget *delete1;
+ GtkWidget *policies;
+ GtkWidget *policies_menu;
+ GtkWidget *account;
+ GtkWidget *user_rights;
+ GtkWidget *audit;
+ GtkWidget *separator1;
+ GtkWidget *trust_relations;
+ GtkWidget *menuitem3;
+ GtkWidget *menuitem3_menu;
+ GtkWidget *refresh;
+ GtkWidget *menuitem4;
+ GtkWidget *menuitem4_menu;
+ GtkWidget *about;
+ GtkWidget *vpaned;
+ GtkWidget *scrolledwindow1;
+ GtkWidget *user_list;
+ GtkWidget *scrolledwindow2;
+ GtkWidget *group_list;
+ GtkWidget *statusbar;
+ GtkAccelGroup *accel_group;
+
+ accel_group = gtk_accel_group_new ();
+
+ mainwin = gtk_window_new (GTK_WINDOW_TOPLEVEL);
+ gtk_window_set_default_size (GTK_WINDOW (mainwin), 642, 562);
+ gtk_window_set_title (GTK_WINDOW (mainwin), "User Manager");
+
+ vbox1 = gtk_vbox_new (FALSE, 0);
+ gtk_widget_show (vbox1);
+ gtk_container_add (GTK_CONTAINER (mainwin), vbox1);
+
+ menubar = gtk_menu_bar_new ();
+ gtk_widget_show (menubar);
+ gtk_box_pack_start (GTK_BOX (vbox1), menubar, FALSE, FALSE, 0);
+
+ menuitem1 = gtk_menu_item_new_with_mnemonic ("_User");
+ gtk_widget_show (menuitem1);
+ gtk_container_add (GTK_CONTAINER (menubar), menuitem1);
+
+ menuitem1_menu = gtk_menu_new ();
+ gtk_menu_item_set_submenu (GTK_MENU_ITEM (menuitem1), menuitem1_menu);
+
+ new1 = gtk_image_menu_item_new_from_stock ("gtk-new", accel_group);
+ gtk_widget_show (new1);
+ gtk_container_add (GTK_CONTAINER (menuitem1_menu), new1);
+
+ connect = gtk_menu_item_new_with_mnemonic ("_Connect");
+ gtk_widget_show (connect);
+ gtk_container_add (GTK_CONTAINER (menuitem1_menu), connect);
+
+ seldomain = gtk_menu_item_new_with_mnemonic("_Select Domain");
+ gtk_widget_show(seldomain);
+ gtk_container_add (GTK_CONTAINER (menuitem1_menu), seldomain);
+
+ separatormenuitem1 = gtk_separator_menu_item_new ();
+ gtk_widget_show (separatormenuitem1);
+ gtk_container_add (GTK_CONTAINER (menuitem1_menu), separatormenuitem1);
+ gtk_widget_set_sensitive (separatormenuitem1, FALSE);
+
+ quit = gtk_image_menu_item_new_from_stock ("gtk-quit", accel_group);
+ gtk_widget_show (quit);
+ gtk_container_add (GTK_CONTAINER (menuitem1_menu), quit);
+
+ policies = gtk_menu_item_new_with_mnemonic ("_Policies");
+ gtk_widget_show (policies);
+ gtk_container_add (GTK_CONTAINER (menubar), policies);
+
+ policies_menu = gtk_menu_new ();
+ gtk_menu_item_set_submenu (GTK_MENU_ITEM (policies), policies_menu);
+
+ account = gtk_menu_item_new_with_mnemonic ("_Account...");
+ gtk_widget_show (account);
+ gtk_container_add (GTK_CONTAINER (policies_menu), account);
+
+ user_rights = gtk_menu_item_new_with_mnemonic ("_User Rights...");
+ gtk_widget_show (user_rights);
+ gtk_container_add (GTK_CONTAINER (policies_menu), user_rights);
+
+ audit = gtk_menu_item_new_with_mnemonic ("A_udit...");
+ gtk_widget_show (audit);
+ gtk_container_add (GTK_CONTAINER (policies_menu), audit);
+
+ separator1 = gtk_separator_menu_item_new ();
+ gtk_widget_show (separator1);
+ gtk_container_add (GTK_CONTAINER (policies_menu), separator1);
+ gtk_widget_set_sensitive (separator1, FALSE);
+
+ trust_relations = gtk_menu_item_new_with_mnemonic ("_Trust relations");
+ gtk_widget_show (trust_relations);
+ gtk_container_add (GTK_CONTAINER (policies_menu), trust_relations);
+
+ menuitem3 = gtk_menu_item_new_with_mnemonic ("_View");
+ gtk_widget_show (menuitem3);
+ gtk_container_add (GTK_CONTAINER (menubar), menuitem3);
+
+ menuitem3_menu = gtk_menu_new ();
+ gtk_menu_item_set_submenu (GTK_MENU_ITEM (menuitem3), menuitem3_menu);
+
+ refresh = gtk_image_menu_item_new_from_stock ("gtk-refresh", accel_group);
+ gtk_widget_show (refresh);
+ gtk_container_add (GTK_CONTAINER (menuitem3_menu), refresh);
+
+ menuitem4 = gtk_menu_item_new_with_mnemonic ("_Help");
+ gtk_widget_show (menuitem4);
+ gtk_container_add (GTK_CONTAINER (menubar), menuitem4);
+
+ menuitem4_menu = gtk_menu_new ();
+ gtk_menu_item_set_submenu (GTK_MENU_ITEM (menuitem4), menuitem4_menu);
+
+ about = gtk_menu_item_new_with_mnemonic ("_About");
+ gtk_widget_show (about);
+ gtk_container_add (GTK_CONTAINER (menuitem4_menu), about);
+
+ vpaned = gtk_vpaned_new ();
+ gtk_widget_show (vpaned);
+ gtk_box_pack_start (GTK_BOX (vbox1), vpaned, TRUE, TRUE, 0);
+
+ scrolledwindow1 = gtk_scrolled_window_new (NULL, NULL);
+ gtk_widget_show (scrolledwindow1);
+ gtk_paned_pack1 (GTK_PANED (vpaned), scrolledwindow1, FALSE, TRUE);
+
+ user_list = gtk_tree_view_new ();
+ gtk_widget_show (user_list);
+ gtk_container_add (GTK_CONTAINER (scrolledwindow1), user_list);
+
+ scrolledwindow2 = gtk_scrolled_window_new (NULL, NULL);
+ gtk_widget_show (scrolledwindow2);
+ gtk_paned_pack2 (GTK_PANED (vpaned), scrolledwindow2, TRUE, TRUE);
+
+ group_list = gtk_tree_view_new ();
+ gtk_widget_show (group_list);
+ gtk_container_add (GTK_CONTAINER (scrolledwindow2), group_list);
+
+ statusbar = gtk_statusbar_new ();
+ gtk_widget_show (statusbar);
+ gtk_box_pack_start (GTK_BOX (vbox1), statusbar, FALSE, FALSE, 0);
+
+ g_signal_connect ((gpointer) new1, "activate",
+ G_CALLBACK (on_new1_activate),
+ NULL);
+ g_signal_connect ((gpointer) seldomain, "activate",
+ G_CALLBACK (on_select_domain_activate),
+ NULL);
+ g_signal_connect ((gpointer) connect, "activate",
+ G_CALLBACK (on_connect_activate),
+ NULL);
+ g_signal_connect ((gpointer) quit, "activate",
+ G_CALLBACK (on_quit_activate),
+ NULL);
+ g_signal_connect ((gpointer) account, "activate",
+ G_CALLBACK (on_account_activate),
+ NULL);
+ g_signal_connect ((gpointer) user_rights, "activate",
+ G_CALLBACK (on_user_rights_activate),
+ NULL);
+ g_signal_connect ((gpointer) audit, "activate",
+ G_CALLBACK (on_audit_activate),
+ NULL);
+ g_signal_connect ((gpointer) trust_relations, "activate",
+ G_CALLBACK (on_trust_relations_activate),
+ NULL);
+ g_signal_connect ((gpointer) refresh, "activate",
+ G_CALLBACK (on_refresh_activate),
+ NULL);
+ g_signal_connect ((gpointer) about, "activate",
+ G_CALLBACK (on_about_activate),
+ NULL);
+
+ gtk_window_add_accel_group (GTK_WINDOW (mainwin), accel_group);
+
+ return mainwin;
+}
+
+
+
+ int main(int argc, char **argv)
+{
+ gtk_init(&argc, &argv);
+ mainwin = create_mainwindow();
+ gtk_widget_show(mainwin);
+ gtk_main();
+}
+
diff --git a/source4/gtk/tools/gwsam_user.c b/source4/gtk/tools/gwsam_user.c
new file mode 100644
index 0000000000..9b764dc1d2
--- /dev/null
+++ b/source4/gtk/tools/gwsam_user.c
@@ -0,0 +1,356 @@
+/*
+ Unix SMB/CIFS implementation.
+ GTK+ SAM frontend
+
+ Copyright (C) Jelmer Vernooij 2004
+
+ This program is free software; you can redistribute it and/or modify
+ it under the terms of the GNU General Public License as published by
+ the Free Software Foundation; either version 2 of the License, or
+ (at your option) any later version.
+
+ This program is distributed in the hope that it will be useful,
+ but WITHOUT ANY WARRANTY; without even the implied warranty of
+ MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
+ GNU General Public License for more details.
+
+ You should have received a copy of the GNU General Public License
+ along with this program; if not, write to the Free Software
+ Foundation, Inc., 675 Mass Ave, Cambridge, MA 02139, USA.
+*/
+
+#include "includes.h"
+#include "gtk/common/gtk-smb.h"
+
+
+GtkWidget*
+create_user_edit_dialog (void)
+{
+ GtkWidget *user_edit_dialog;
+ GtkWidget *dialog_vbox1;
+ GtkWidget *notebook;
+ GtkWidget *table1;
+ GtkWidget *label4;
+ GtkWidget *label5;
+ GtkWidget *label6;
+ GtkWidget *label7;
+ GtkWidget *label8;
+ GtkWidget *chk_mustchange;
+ GtkWidget *entry_fullname;
+ GtkWidget *entry_description;
+ GtkWidget *lbl_username;
+ GtkWidget *entry_password;
+ GtkWidget *entry_confirm_password;
+ GtkWidget *chk_cannotchange;
+ GtkWidget *chk_cannotexpire;
+ GtkWidget *chk_disabled;
+ GtkWidget *chk_lockedout;
+ GtkWidget *label1;
+ GtkWidget *hbox1;
+ GtkWidget *scrolledwindow3;
+ GtkWidget *treeview3;
+ GtkWidget *vbox2;
+ GtkWidget *btn_groupadd;
+ GtkWidget *btn_groupdel;
+ GtkWidget *scrolledwindow4;
+ GtkWidget *treeview4;
+ GtkWidget *label2;
+ GtkWidget *vbox3;
+ GtkWidget *frame1;
+ GtkWidget *table2;
+ GtkWidget *label12;
+ GtkWidget *label13;
+ GtkWidget *entry_profilepath;
+ GtkWidget *entry_scriptname;
+ GtkWidget *label10;
+ GtkWidget *frame2;
+ GtkWidget *table3;
+ GtkWidget *label14;
+ GtkWidget *entry_homedir;
+ GtkWidget *chk_mapdrive;
+ GtkWidget *combo_homedrive;
+ GtkWidget *label11;
+ GtkWidget *label3;
+ GtkWidget *dialog_action_area1;
+ GtkWidget *cancelbutton1;
+ GtkWidget *applybutton1;
+ GtkWidget *okbutton1;
+
+ user_edit_dialog = gtk_dialog_new ();
+ gtk_window_set_title (GTK_WINDOW (user_edit_dialog), "Edit User");
+
+ dialog_vbox1 = GTK_DIALOG (user_edit_dialog)->vbox;
+ gtk_widget_show (dialog_vbox1);
+
+ notebook = gtk_notebook_new ();
+ gtk_widget_show (notebook);
+ gtk_box_pack_start (GTK_BOX (dialog_vbox1), notebook, TRUE, TRUE, 0);
+
+ table1 = gtk_table_new (10, 2, FALSE);
+ gtk_widget_show (table1);
+ gtk_container_add (GTK_CONTAINER (notebook), table1);
+
+ label4 = gtk_label_new ("Username");
+ gtk_widget_show (label4);
+ gtk_table_attach (GTK_TABLE (table1), label4, 0, 1, 0, 1,
+ (GtkAttachOptions) (GTK_FILL),
+ (GtkAttachOptions) (0), 0, 0);
+ gtk_misc_set_alignment (GTK_MISC (label4), 0, 0.5);
+
+ label5 = gtk_label_new ("Full name");
+ gtk_widget_show (label5);
+ gtk_table_attach (GTK_TABLE (table1), label5, 0, 1, 1, 2,
+ (GtkAttachOptions) (GTK_FILL),
+ (GtkAttachOptions) (0), 0, 0);
+ gtk_misc_set_alignment (GTK_MISC (label5), 0, 0.5);
+
+ label6 = gtk_label_new ("Description");
+ gtk_widget_show (label6);
+ gtk_table_attach (GTK_TABLE (table1), label6, 0, 1, 2, 3,
+ (GtkAttachOptions) (GTK_FILL),
+ (GtkAttachOptions) (0), 0, 0);
+ gtk_misc_set_alignment (GTK_MISC (label6), 0, 0.5);
+
+ label7 = gtk_label_new ("Password");
+ gtk_widget_show (label7);
+ gtk_table_attach (GTK_TABLE (table1), label7, 0, 1, 3, 4,
+ (GtkAttachOptions) (GTK_FILL),
+ (GtkAttachOptions) (0), 0, 0);
+ gtk_misc_set_alignment (GTK_MISC (label7), 0, 0.5);
+
+ label8 = gtk_label_new ("Confirm password");
+ gtk_widget_show (label8);
+ gtk_table_attach (GTK_TABLE (table1), label8, 0, 1, 4, 5,
+ (GtkAttachOptions) (GTK_FILL),
+ (GtkAttachOptions) (0), 0, 0);
+ gtk_misc_set_alignment (GTK_MISC (label8), 0, 0.5);
+
+ chk_mustchange = gtk_check_button_new_with_mnemonic ("_User Must Change Password at Next Logon");
+ gtk_widget_show (chk_mustchange);
+ gtk_table_attach (GTK_TABLE (table1), chk_mustchange, 1, 2, 5, 6,
+ (GtkAttachOptions) (GTK_FILL),
+ (GtkAttachOptions) (0), 0, 0);
+
+ entry_fullname = gtk_entry_new ();
+ gtk_widget_show (entry_fullname);
+ gtk_table_attach (GTK_TABLE (table1), entry_fullname, 1, 2, 1, 2,
+ (GtkAttachOptions) (GTK_EXPAND | GTK_FILL),
+ (GtkAttachOptions) (0), 0, 0);
+
+ entry_description = gtk_entry_new ();
+ gtk_widget_show (entry_description);
+ gtk_table_attach (GTK_TABLE (table1), entry_description, 1, 2, 2, 3,
+ (GtkAttachOptions) (GTK_EXPAND | GTK_FILL),
+ (GtkAttachOptions) (0), 0, 0);
+
+ lbl_username = gtk_label_new ("");
+ gtk_widget_show (lbl_username);
+ gtk_table_attach (GTK_TABLE (table1), lbl_username, 1, 2, 0, 1,
+ (GtkAttachOptions) (GTK_FILL),
+ (GtkAttachOptions) (0), 0, 0);
+ gtk_misc_set_alignment (GTK_MISC (lbl_username), 0, 0.5);
+
+ entry_password = gtk_entry_new ();
+ gtk_widget_show (entry_password);
+ gtk_table_attach (GTK_TABLE (table1), entry_password, 1, 2, 3, 4,
+ (GtkAttachOptions) (GTK_EXPAND | GTK_FILL),
+ (GtkAttachOptions) (0), 0, 0);
+
+ entry_confirm_password = gtk_entry_new ();
+ gtk_widget_show (entry_confirm_password);
+ gtk_table_attach (GTK_TABLE (table1), entry_confirm_password, 1, 2, 4, 5,
+ (GtkAttachOptions) (GTK_EXPAND | GTK_FILL),
+ (GtkAttachOptions) (0), 0, 0);
+
+ chk_cannotchange = gtk_check_button_new_with_mnemonic ("User Cannot Change Password");
+ gtk_widget_show (chk_cannotchange);
+ gtk_table_attach (GTK_TABLE (table1), chk_cannotchange, 1, 2, 6, 7,
+ (GtkAttachOptions) (GTK_FILL),
+ (GtkAttachOptions) (0), 0, 0);
+
+ chk_cannotexpire = gtk_check_button_new_with_mnemonic ("Password Never Expires");
+ gtk_widget_show (chk_cannotexpire);
+ gtk_table_attach (GTK_TABLE (table1), chk_cannotexpire, 1, 2, 7, 8,
+ (GtkAttachOptions) (GTK_FILL),
+ (GtkAttachOptions) (0), 0, 0);
+
+ chk_disabled = gtk_check_button_new_with_mnemonic ("Account Disabled");
+ gtk_widget_show (chk_disabled);
+ gtk_table_attach (GTK_TABLE (table1), chk_disabled, 1, 2, 8, 9,
+ (GtkAttachOptions) (GTK_FILL),
+ (GtkAttachOptions) (0), 0, 0);
+
+ chk_lockedout = gtk_check_button_new_with_mnemonic ("Account Locked Out");
+ gtk_widget_show (chk_lockedout);
+ gtk_table_attach (GTK_TABLE (table1), chk_lockedout, 1, 2, 9, 10,
+ (GtkAttachOptions) (GTK_FILL),
+ (GtkAttachOptions) (0), 0, 0);
+
+ label1 = gtk_label_new ("Main");
+ gtk_widget_show (label1);
+ gtk_notebook_set_tab_label (GTK_NOTEBOOK (notebook), gtk_notebook_get_nth_page (GTK_NOTEBOOK (notebook), 0), label1);
+
+ hbox1 = gtk_hbox_new (FALSE, 0);
+ gtk_widget_show (hbox1);
+ gtk_container_add (GTK_CONTAINER (notebook), hbox1);
+
+ scrolledwindow3 = gtk_scrolled_window_new (NULL, NULL);
+ gtk_widget_show (scrolledwindow3);
+ gtk_box_pack_start (GTK_BOX (hbox1), scrolledwindow3, TRUE, TRUE, 0);
+
+ treeview3 = gtk_tree_view_new ();
+ gtk_widget_show (treeview3);
+ gtk_container_add (GTK_CONTAINER (scrolledwindow3), treeview3);
+
+ vbox2 = gtk_vbox_new (TRUE, 0);
+ gtk_widget_show (vbox2);
+ gtk_box_pack_start (GTK_BOX (hbox1), vbox2, TRUE, TRUE, 0);
+
+ btn_groupadd = gtk_button_new_from_stock ("gtk-add");
+ gtk_widget_show (btn_groupadd);
+ gtk_box_pack_start (GTK_BOX (vbox2), btn_groupadd, FALSE, FALSE, 0);
+
+ btn_groupdel = gtk_button_new_from_stock ("gtk-remove");
+ gtk_widget_show (btn_groupdel);
+ gtk_box_pack_start (GTK_BOX (vbox2), btn_groupdel, FALSE, FALSE, 0);
+
+ scrolledwindow4 = gtk_scrolled_window_new (NULL, NULL);
+ gtk_widget_show (scrolledwindow4);
+ gtk_box_pack_start (GTK_BOX (hbox1), scrolledwindow4, TRUE, TRUE, 0);
+
+ treeview4 = gtk_tree_view_new ();
+ gtk_widget_show (treeview4);
+ gtk_container_add (GTK_CONTAINER (scrolledwindow4), treeview4);
+
+ label2 = gtk_label_new ("Groups");
+ gtk_widget_show (label2);
+ gtk_notebook_set_tab_label (GTK_NOTEBOOK (notebook), gtk_notebook_get_nth_page (GTK_NOTEBOOK (notebook), 1), label2);
+
+ vbox3 = gtk_vbox_new (FALSE, 0);
+ gtk_widget_show (vbox3);
+ gtk_container_add (GTK_CONTAINER (notebook), vbox3);
+
+ frame1 = gtk_frame_new (NULL);
+ gtk_widget_show (frame1);
+ gtk_box_pack_start (GTK_BOX (vbox3), frame1, TRUE, TRUE, 0);
+
+ table2 = gtk_table_new (2, 2, FALSE);
+ gtk_widget_show (table2);
+ gtk_container_add (GTK_CONTAINER (frame1), table2);
+
+ label12 = gtk_label_new ("User Profile Path:");
+ gtk_widget_show (label12);
+ gtk_table_attach (GTK_TABLE (table2), label12, 0, 1, 0, 1,
+ (GtkAttachOptions) (GTK_FILL),
+ (GtkAttachOptions) (0), 0, 0);
+ gtk_misc_set_alignment (GTK_MISC (label12), 0, 0.5);
+
+ label13 = gtk_label_new ("Logon Script Name:");
+ gtk_widget_show (label13);
+ gtk_table_attach (GTK_TABLE (table2), label13, 0, 1, 1, 2,
+ (GtkAttachOptions) (GTK_FILL),
+ (GtkAttachOptions) (0), 0, 0);
+ gtk_misc_set_alignment (GTK_MISC (label13), 0, 0.5);
+
+ entry_profilepath = gtk_entry_new ();
+ gtk_widget_show (entry_profilepath);
+ gtk_table_attach (GTK_TABLE (table2), entry_profilepath, 1, 2, 0, 1,
+ (GtkAttachOptions) (GTK_EXPAND | GTK_FILL),
+ (GtkAttachOptions) (0), 0, 0);
+
+ entry_scriptname = gtk_entry_new ();
+ gtk_widget_show (entry_scriptname);
+ gtk_table_attach (GTK_TABLE (table2), entry_scriptname, 1, 2, 1, 2,
+ (GtkAttachOptions) (GTK_EXPAND | GTK_FILL),
+ (GtkAttachOptions) (0), 0, 0);
+
+ label10 = gtk_label_new ("User Profiles");
+ gtk_widget_show (label10);
+ gtk_frame_set_label_widget (GTK_FRAME (frame1), label10);
+
+ frame2 = gtk_frame_new (NULL);
+ gtk_widget_show (frame2);
+ gtk_box_pack_start (GTK_BOX (vbox3), frame2, TRUE, TRUE, 0);
+
+ table3 = gtk_table_new (2, 2, FALSE);
+ gtk_widget_show (table3);
+ gtk_container_add (GTK_CONTAINER (frame2), table3);
+
+ label14 = gtk_label_new ("Path");
+ gtk_widget_show (label14);
+ gtk_table_attach (GTK_TABLE (table3), label14, 0, 1, 0, 1,
+ (GtkAttachOptions) (GTK_FILL),
+ (GtkAttachOptions) (0), 0, 0);
+ gtk_misc_set_alignment (GTK_MISC (label14), 0, 0.5);
+
+ entry_homedir = gtk_entry_new ();
+ gtk_widget_show (entry_homedir);
+ gtk_table_attach (GTK_TABLE (table3), entry_homedir, 1, 2, 0, 1,
+ (GtkAttachOptions) (GTK_EXPAND | GTK_FILL),
+ (GtkAttachOptions) (0), 0, 0);
+
+ chk_mapdrive = gtk_check_button_new_with_mnemonic ("Map homedir to drive");
+ gtk_widget_show (chk_mapdrive);
+ gtk_table_attach (GTK_TABLE (table3), chk_mapdrive, 0, 1, 1, 2,
+ (GtkAttachOptions) (GTK_FILL),
+ (GtkAttachOptions) (0), 0, 0);
+
+ combo_homedrive = gtk_combo_box_entry_new_text ();
+ gtk_widget_show (combo_homedrive);
+ gtk_table_attach (GTK_TABLE (table3), combo_homedrive, 1, 2, 1, 2,
+ (GtkAttachOptions) (GTK_FILL),
+ (GtkAttachOptions) (GTK_FILL), 0, 0);
+ gtk_combo_box_append_text (GTK_COMBO_BOX (combo_homedrive), "C:");
+ gtk_combo_box_append_text (GTK_COMBO_BOX (combo_homedrive), "D:");
+ gtk_combo_box_append_text (GTK_COMBO_BOX (combo_homedrive), "E:");
+ gtk_combo_box_append_text (GTK_COMBO_BOX (combo_homedrive), "F:");
+ gtk_combo_box_append_text (GTK_COMBO_BOX (combo_homedrive), "G:");
+ gtk_combo_box_append_text (GTK_COMBO_BOX (combo_homedrive), "H:");
+ gtk_combo_box_append_text (GTK_COMBO_BOX (combo_homedrive), "I:");
+ gtk_combo_box_append_text (GTK_COMBO_BOX (combo_homedrive), "J:");
+ gtk_combo_box_append_text (GTK_COMBO_BOX (combo_homedrive), "K");
+ gtk_combo_box_append_text (GTK_COMBO_BOX (combo_homedrive), "L:");
+ gtk_combo_box_append_text (GTK_COMBO_BOX (combo_homedrive), "M:");
+ gtk_combo_box_append_text (GTK_COMBO_BOX (combo_homedrive), "N:");
+ gtk_combo_box_append_text (GTK_COMBO_BOX (combo_homedrive), "O:");
+ gtk_combo_box_append_text (GTK_COMBO_BOX (combo_homedrive), "P:");
+ gtk_combo_box_append_text (GTK_COMBO_BOX (combo_homedrive), "Q:");
+ gtk_combo_box_append_text (GTK_COMBO_BOX (combo_homedrive), "R:");
+ gtk_combo_box_append_text (GTK_COMBO_BOX (combo_homedrive), "S:");
+ gtk_combo_box_append_text (GTK_COMBO_BOX (combo_homedrive), "T:");
+ gtk_combo_box_append_text (GTK_COMBO_BOX (combo_homedrive), "U:");
+ gtk_combo_box_append_text (GTK_COMBO_BOX (combo_homedrive), "V:");
+ gtk_combo_box_append_text (GTK_COMBO_BOX (combo_homedrive), "W:");
+ gtk_combo_box_append_text (GTK_COMBO_BOX (combo_homedrive), "X:");
+ gtk_combo_box_append_text (GTK_COMBO_BOX (combo_homedrive), "Y:");
+ gtk_combo_box_append_text (GTK_COMBO_BOX (combo_homedrive), "Z:");
+
+ label11 = gtk_label_new ("Home Directory");
+ gtk_widget_show (label11);
+ gtk_frame_set_label_widget (GTK_FRAME (frame2), label11);
+
+ label3 = gtk_label_new ("Profile");
+ gtk_widget_show (label3);
+ gtk_notebook_set_tab_label (GTK_NOTEBOOK (notebook), gtk_notebook_get_nth_page (GTK_NOTEBOOK (notebook), 2), label3);
+
+ dialog_action_area1 = GTK_DIALOG (user_edit_dialog)->action_area;
+ gtk_widget_show (dialog_action_area1);
+ gtk_button_box_set_layout (GTK_BUTTON_BOX (dialog_action_area1), GTK_BUTTONBOX_END);
+
+ cancelbutton1 = gtk_button_new_from_stock ("gtk-cancel");
+ gtk_widget_show (cancelbutton1);
+ gtk_dialog_add_action_widget (GTK_DIALOG (user_edit_dialog), cancelbutton1, GTK_RESPONSE_CANCEL);
+ GTK_WIDGET_SET_FLAGS (cancelbutton1, GTK_CAN_DEFAULT);
+
+ applybutton1 = gtk_button_new_from_stock ("gtk-apply");
+ gtk_widget_show (applybutton1);
+ gtk_dialog_add_action_widget (GTK_DIALOG (user_edit_dialog), applybutton1, GTK_RESPONSE_APPLY);
+ GTK_WIDGET_SET_FLAGS (applybutton1, GTK_CAN_DEFAULT);
+
+ okbutton1 = gtk_button_new_from_stock ("gtk-ok");
+ gtk_widget_show (okbutton1);
+ gtk_dialog_add_action_widget (GTK_DIALOG (user_edit_dialog), okbutton1, GTK_RESPONSE_OK);
+ GTK_WIDGET_SET_FLAGS (okbutton1, GTK_CAN_DEFAULT);
+
+ return user_edit_dialog;
+}