r14402: Generate seperate headers for RPC client functions.
[samba.git] / source4 / gtk / tools / gwsam.c
1 /* 
2    Unix SMB/CIFS implementation.
3    GTK+ SAM frontend
4    
5    Copyright (C) Jelmer Vernooij 2004
6
7    This program is free software; you can redistribute it and/or modify
8    it under the terms of the GNU General Public License as published by
9    the Free Software Foundation; either version 2 of the License, or
10    (at your option) any later version.
11    
12    This program is distributed in the hope that it will be useful,
13    but WITHOUT ANY WARRANTY; without even the implied warranty of
14    MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
15    GNU General Public License for more details.
16    
17    You should have received a copy of the GNU General Public License
18    along with this program; if not, write to the Free Software
19    Foundation, Inc., 675 Mass Ave, Cambridge, MA 02139, USA.
20 */
21
22 #include "includes.h"
23 #include "librpc/gen_ndr/ndr_samr.h"
24 #include "librpc/gen_ndr/ndr_samr_c.h"
25 #include "gtk/common/select.h"
26 #include "gtk/common/gtk-smb.h"
27 #include "auth/credentials/credentials.h"
28
29 struct policy_handle sam_handle;
30 struct dcerpc_pipe *sam_pipe = NULL;
31 static struct policy_handle domain_handle;
32 GtkWidget *mainwin;
33 GtkWidget *seldomain;
34 static GtkWidget *mnu_disconnect;
35
36 static void update_grouplist(void)
37 {
38         if(!sam_pipe) return;
39         //FIXME
40 }
41
42 static void update_userlist(void)
43 {
44         NTSTATUS status;
45         struct samr_EnumDomainUsers r;
46         uint32_t resume_handle=0;
47         int i;
48         TALLOC_CTX *mem_ctx;
49
50         if(!sam_pipe) return;
51
52         mem_ctx = talloc_init("update_userlist");
53         r.in.domain_handle = &domain_handle;
54         r.in.resume_handle = &resume_handle;
55         r.in.acct_flags = 0;
56         r.in.max_size = (uint32_t)-1;
57         r.out.resume_handle = &resume_handle;
58
59         status = dcerpc_samr_EnumDomainUsers(sam_pipe, mem_ctx, &r);
60         if (!NT_STATUS_IS_OK(status)) {
61                 gtk_show_ntstatus(mainwin, "While enumerating domain users", status);
62                 talloc_free(mem_ctx);
63                 return;
64         }
65
66         if (!r.out.sam || r.out.sam->count == 0) {
67                 talloc_free(mem_ctx);
68                 return;
69         }
70
71         for (i=0;i<r.out.sam->count;i++) {
72                 printf("Found: %s\n", r.out.sam->entries[i].name.string);
73                 /* FIXME: Query user info */
74
75                 //              if (!test_OpenUser(sam_pipe, mem_ctx, &sam_handle, r.out.sam->entries[i].idx)) {
76                 //                      ret = False;
77                 //              }
78         }
79         talloc_free(mem_ctx);
80 }
81
82 static void on_new1_activate(GtkMenuItem *menuitem, gpointer user_data)
83 {
84
85 }
86
87 static void on_select_domain_activate(GtkMenuItem *menuitem, gpointer user_data)
88 {
89         GtkSelectDomainDialog *d;
90         gint result;
91         d = GTK_SELECT_DOMAIN_DIALOG(gtk_select_domain_dialog_new(sam_pipe));
92         result = gtk_dialog_run(GTK_DIALOG(d));
93         switch(result) {
94         case GTK_RESPONSE_OK:
95                 break;
96         default:
97                 gtk_widget_destroy(GTK_WIDGET(d));
98                 return;
99         }
100         domain_handle = gtk_select_domain_dialog_get_handle(d);
101
102         update_userlist();
103         update_grouplist();
104
105         gtk_widget_destroy(GTK_WIDGET(d));
106 }
107
108 static void connect_sam(void)
109 {
110         GtkRpcBindingDialog *d;
111         NTSTATUS status;
112         struct samr_Connect r;
113         struct cli_credentials *cred;
114         TALLOC_CTX *mem_ctx;
115         gint result;
116
117         d = GTK_RPC_BINDING_DIALOG(gtk_rpc_binding_dialog_new(NULL));
118         result = gtk_dialog_run(GTK_DIALOG(d));
119         switch(result) {
120         case GTK_RESPONSE_ACCEPT:
121                 break;
122         default:
123                 gtk_widget_destroy(GTK_WIDGET(d));
124                 return;
125         }
126
127         mem_ctx = talloc_init("gwsam_connect");
128         cred = cli_credentials_init(mem_ctx);
129         cli_credentials_guess(cred);
130         cli_credentials_set_gtk_callbacks(cred);
131
132         /* If connected, get list of jobs */
133         status = dcerpc_pipe_connect_b(mem_ctx, &sam_pipe,
134                                        gtk_rpc_binding_dialog_get_binding(d, mem_ctx),
135                                        &dcerpc_table_samr, cred, NULL);
136
137         if(!NT_STATUS_IS_OK(status)) {
138                 gtk_show_ntstatus(mainwin, "While connecting to SAMR interface", status);
139                 sam_pipe = NULL;
140                 gtk_widget_destroy(GTK_WIDGET(d));
141                 talloc_free(mem_ctx);
142                 return;
143         }
144
145         r.in.system_name = 0;
146         r.in.access_mask = SEC_FLAG_MAXIMUM_ALLOWED;
147         r.out.connect_handle = &sam_handle;
148
149         status = dcerpc_samr_Connect(sam_pipe, mem_ctx, &r);
150         if (!NT_STATUS_IS_OK(status)) {
151                 gtk_show_ntstatus(mainwin, "While running connect on SAMR", status);
152                 sam_pipe = NULL;
153                 gtk_widget_destroy(GTK_WIDGET(d));
154                 talloc_free(mem_ctx);
155                 return;
156         }
157
158         gtk_widget_set_sensitive (seldomain, TRUE);
159         gtk_widget_set_sensitive (mnu_disconnect, TRUE);
160         gtk_window_set_title (GTK_WINDOW (mainwin), talloc_asprintf(mem_ctx, "User Manager - Connected to %s", gtk_rpc_binding_dialog_get_host(d)));
161         gtk_widget_destroy(GTK_WIDGET(d));
162
163         sam_pipe = talloc_reference(talloc_autofree_context(), sam_pipe);
164         talloc_free(mem_ctx);
165
166 }
167
168 static void on_connect_activate (GtkMenuItem *menuitem, gpointer user_data)
169 {
170         connect_sam();
171 }
172
173 static void on_disconnect_activate (GtkMenuItem *menuitem, gpointer user_data)
174 {
175         gtk_widget_set_sensitive (mnu_disconnect, FALSE);
176         gtk_window_set_title (GTK_WINDOW (mainwin), "User Manager");
177 }
178
179 static void on_quit_activate (GtkMenuItem *menuitem, gpointer user_data)
180 {
181         talloc_free(sam_pipe);
182
183         gtk_main_quit();
184 }
185
186 static void on_account_activate(GtkMenuItem *menuitem, gpointer user_data)
187 {
188         //FIXME
189 }
190
191
192 static void on_user_rights_activate(GtkMenuItem *menuitem, gpointer user_data)
193 {
194         //FIXME
195 }
196
197
198 static void on_audit_activate(GtkMenuItem *menuitem, gpointer user_data)
199 {
200         //FIXME
201 }
202
203
204 static void on_trust_relations_activate(GtkMenuItem *menuitem, gpointer user_data)
205 {
206         //FIXME
207 }
208
209
210 static void on_refresh_activate(GtkMenuItem *menuitem, gpointer user_data)
211 {
212         update_userlist();
213         update_grouplist();
214 }
215
216
217 static void on_about_activate(GtkMenuItem *menuitem, gpointer user_data)
218 {
219         GtkDialog *aboutwin = GTK_DIALOG(create_gtk_samba_about_dialog("gwsam"));
220         gtk_dialog_run(aboutwin);
221         gtk_widget_destroy(GTK_WIDGET(aboutwin));
222 }
223
224 static GtkWidget* create_mainwindow (void)
225 {
226         GtkWidget *vbox1;
227         GtkWidget *mnu_connect;
228         GtkWidget *menubar;
229         GtkWidget *menuitem1;
230         GtkWidget *menuitem1_menu;
231         GtkWidget *new1;
232         GtkWidget *separatormenuitem1;
233         GtkWidget *quit;
234         GtkWidget *policies;
235         GtkWidget *policies_menu;
236         GtkWidget *account;
237         GtkWidget *user_rights;
238         GtkWidget *audit;
239         GtkWidget *separator1;
240         GtkWidget *trust_relations;
241         GtkWidget *menuitem3;
242         GtkWidget *menuitem3_menu;
243         GtkWidget *refresh;
244         GtkWidget *menuitem4;
245         GtkWidget *menuitem4_menu;
246         GtkWidget *about;
247         GtkWidget *vpaned;
248         GtkWidget *scrolledwindow1;
249         GtkWidget *user_list;
250         GtkWidget *scrolledwindow2;
251         GtkWidget *group_list;
252         GtkWidget *statusbar;
253         GtkAccelGroup *accel_group;
254
255         accel_group = gtk_accel_group_new ();
256
257         mainwin = gtk_window_new (GTK_WINDOW_TOPLEVEL);
258         gtk_window_set_default_size (GTK_WINDOW (mainwin), 642, 562);
259         gtk_window_set_title (GTK_WINDOW (mainwin), "User Manager");
260
261         vbox1 = gtk_vbox_new (FALSE, 0);
262         gtk_container_add (GTK_CONTAINER (mainwin), vbox1);
263
264         menubar = gtk_menu_bar_new ();
265         gtk_box_pack_start (GTK_BOX (vbox1), menubar, FALSE, FALSE, 0);
266
267         menuitem1 = gtk_menu_item_new_with_mnemonic ("_File");
268         gtk_container_add (GTK_CONTAINER (menubar), menuitem1);
269
270         menuitem1_menu = gtk_menu_new ();
271         gtk_menu_item_set_submenu (GTK_MENU_ITEM (menuitem1), menuitem1_menu);
272
273         mnu_connect = gtk_menu_item_new_with_mnemonic ("_Connect");
274         gtk_container_add (GTK_CONTAINER (menuitem1_menu), mnu_connect);
275
276         mnu_disconnect = gtk_menu_item_new_with_mnemonic ("_Disconnect");
277         gtk_widget_set_sensitive (mnu_disconnect, FALSE);
278         gtk_container_add (GTK_CONTAINER (menuitem1_menu), mnu_disconnect);
279
280         seldomain = gtk_menu_item_new_with_mnemonic("_Select Domain");
281         gtk_widget_set_sensitive (seldomain, FALSE);
282         gtk_container_add (GTK_CONTAINER (menuitem1_menu), seldomain);
283
284         separatormenuitem1 = gtk_separator_menu_item_new ();
285         gtk_container_add (GTK_CONTAINER (menuitem1_menu), separatormenuitem1);
286         gtk_widget_set_sensitive (separatormenuitem1, FALSE);
287
288         quit = gtk_image_menu_item_new_from_stock ("gtk-quit", accel_group);
289         gtk_container_add (GTK_CONTAINER (menuitem1_menu), quit);
290
291         menuitem1 = gtk_menu_item_new_with_mnemonic ("_User");
292         gtk_container_add (GTK_CONTAINER (menubar), menuitem1);
293         gtk_widget_set_sensitive (menuitem1, FALSE);
294
295         menuitem1_menu = gtk_menu_new ();
296         gtk_menu_item_set_submenu (GTK_MENU_ITEM (menuitem1), menuitem1_menu);
297
298         new1 = gtk_image_menu_item_new_from_stock ("gtk-new", accel_group);
299         gtk_container_add (GTK_CONTAINER (menuitem1_menu), new1);
300
301
302
303         policies = gtk_menu_item_new_with_mnemonic ("_Policies");
304         gtk_container_add (GTK_CONTAINER (menubar), policies);
305         gtk_widget_set_sensitive (policies, FALSE);
306
307         policies_menu = gtk_menu_new ();
308         gtk_menu_item_set_submenu (GTK_MENU_ITEM (policies), policies_menu);
309
310         account = gtk_menu_item_new_with_mnemonic ("_Account...");
311         gtk_container_add (GTK_CONTAINER (policies_menu), account);
312
313         user_rights = gtk_menu_item_new_with_mnemonic ("_User Rights...");
314         gtk_container_add (GTK_CONTAINER (policies_menu), user_rights);
315
316         audit = gtk_menu_item_new_with_mnemonic ("A_udit...");
317         gtk_container_add (GTK_CONTAINER (policies_menu), audit);
318
319         separator1 = gtk_separator_menu_item_new ();
320         gtk_container_add (GTK_CONTAINER (policies_menu), separator1);
321         gtk_widget_set_sensitive (separator1, FALSE);
322
323         trust_relations = gtk_menu_item_new_with_mnemonic ("_Trust relations");
324         gtk_container_add (GTK_CONTAINER (policies_menu), trust_relations);
325
326         menuitem3 = gtk_menu_item_new_with_mnemonic ("_View");
327         gtk_container_add (GTK_CONTAINER (menubar), menuitem3);
328
329         menuitem3_menu = gtk_menu_new ();
330         gtk_menu_item_set_submenu (GTK_MENU_ITEM (menuitem3), menuitem3_menu);
331
332         refresh = gtk_image_menu_item_new_from_stock ("gtk-refresh", accel_group);
333         gtk_container_add (GTK_CONTAINER (menuitem3_menu), refresh);
334         gtk_widget_set_sensitive (refresh, FALSE);
335
336         menuitem4 = gtk_menu_item_new_with_mnemonic ("_Help");
337         gtk_container_add (GTK_CONTAINER (menubar), menuitem4);
338
339         menuitem4_menu = gtk_menu_new ();
340         gtk_menu_item_set_submenu (GTK_MENU_ITEM (menuitem4), menuitem4_menu);
341
342         about = gtk_menu_item_new_with_mnemonic ("_About");
343         gtk_container_add (GTK_CONTAINER (menuitem4_menu), about);
344
345         vpaned = gtk_vpaned_new ();
346         gtk_box_pack_start (GTK_BOX (vbox1), vpaned, TRUE, TRUE, 0);
347
348         scrolledwindow1 = gtk_scrolled_window_new (NULL, NULL);
349         gtk_paned_pack1 (GTK_PANED (vpaned), scrolledwindow1, FALSE, TRUE);
350
351         user_list = gtk_tree_view_new ();
352         gtk_container_add (GTK_CONTAINER (scrolledwindow1), user_list);
353
354         scrolledwindow2 = gtk_scrolled_window_new (NULL, NULL);
355         gtk_paned_pack2 (GTK_PANED (vpaned), scrolledwindow2, TRUE, TRUE);
356
357         group_list = gtk_tree_view_new ();
358         gtk_container_add (GTK_CONTAINER (scrolledwindow2), group_list);
359
360         statusbar = gtk_statusbar_new ();
361         gtk_box_pack_start (GTK_BOX (vbox1), statusbar, FALSE, FALSE, 0);
362
363         g_signal_connect ((gpointer) new1, "activate",
364                                           G_CALLBACK (on_new1_activate),
365                                           NULL);
366         g_signal_connect ((gpointer) seldomain, "activate",
367                                           G_CALLBACK (on_select_domain_activate),
368                                           NULL);
369         g_signal_connect ((gpointer) mnu_connect, "activate",
370                                           G_CALLBACK (on_connect_activate),
371                                           NULL);
372         g_signal_connect ((gpointer) mnu_disconnect, "activate",
373                                           G_CALLBACK (on_disconnect_activate),
374                                           NULL);
375         g_signal_connect ((gpointer) quit, "activate",
376                                           G_CALLBACK (on_quit_activate),
377                                           NULL);
378         g_signal_connect ((gpointer) account, "activate",
379                                           G_CALLBACK (on_account_activate),
380                                           NULL);
381         g_signal_connect ((gpointer) user_rights, "activate",
382                                           G_CALLBACK (on_user_rights_activate),
383                                           NULL);
384         g_signal_connect ((gpointer) audit, "activate",
385                                           G_CALLBACK (on_audit_activate),
386                                           NULL);
387         g_signal_connect ((gpointer) trust_relations, "activate",
388                                           G_CALLBACK (on_trust_relations_activate),
389                                           NULL);
390         g_signal_connect ((gpointer) refresh, "activate",
391                                           G_CALLBACK (on_refresh_activate),
392                                           NULL);
393         g_signal_connect ((gpointer) about, "activate",
394                                           G_CALLBACK (on_about_activate),
395                                           NULL);
396
397         gtk_window_add_accel_group (GTK_WINDOW (mainwin), accel_group);
398
399         return mainwin;
400 }
401
402 int main(int argc, char **argv)
403 {
404         lp_load();
405         setup_logging(argv[0], DEBUG_STDERR);
406
407         gtk_init(&argc, &argv);
408         mainwin = create_mainwindow();
409         connect_sam();
410         gtk_widget_show_all(mainwin);
411
412         return gtk_event_loop();
413 }