mirror of
https://github.com/samba-team/samba.git
synced 2025-11-06 08:23:50 +03:00
306 lines
9.3 KiB
C
306 lines
9.3 KiB
C
/*
|
|
Unix SMB/CIFS implementation.
|
|
SMB-related GTK+ functions
|
|
|
|
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 "librpc/gen_ndr/ndr_samr_c.h"
|
|
#include "gtk/common/select.h"
|
|
#include "gtk/common/gtk-smb.h"
|
|
#include "auth/credentials/credentials.h"
|
|
|
|
/* GtkSelectDomainDialog */
|
|
|
|
const char *gtk_select_domain_dialog_get_domain(GtkSelectDomainDialog *d)
|
|
{
|
|
return gtk_entry_get_text(GTK_ENTRY(d->entry_domain));
|
|
}
|
|
|
|
static void gtk_select_domain_dialog_init (GtkSelectDomainDialog *select_domain_dialog)
|
|
{
|
|
GtkWidget *dialog_vbox1;
|
|
GtkWidget *hbox1;
|
|
GtkWidget *label1;
|
|
GtkWidget *scrolledwindow1;
|
|
GtkWidget *dialog_action_area1;
|
|
GtkWidget *cancelbutton1;
|
|
GtkWidget *okbutton1;
|
|
GtkCellRenderer *renderer;
|
|
GtkTreeViewColumn *curcol;
|
|
|
|
gtk_window_set_title (GTK_WINDOW (select_domain_dialog), "Select Domain");
|
|
|
|
dialog_vbox1 = GTK_DIALOG (select_domain_dialog)->vbox;
|
|
|
|
hbox1 = gtk_hbox_new (FALSE, 0);
|
|
gtk_box_pack_start (GTK_BOX (dialog_vbox1), hbox1, TRUE, TRUE, 0);
|
|
|
|
label1 = gtk_label_new ("Domain:");
|
|
gtk_box_pack_start (GTK_BOX (hbox1), label1, FALSE, FALSE, 0);
|
|
|
|
select_domain_dialog->entry_domain = gtk_entry_new ();
|
|
gtk_box_pack_start (GTK_BOX (hbox1), select_domain_dialog->entry_domain, TRUE, TRUE, 0);
|
|
|
|
scrolledwindow1 = gtk_scrolled_window_new (NULL, NULL);
|
|
gtk_box_pack_start (GTK_BOX (dialog_vbox1), scrolledwindow1, TRUE, TRUE, 0);
|
|
|
|
select_domain_dialog->list_domains = gtk_tree_view_new ();
|
|
gtk_container_add (GTK_CONTAINER (scrolledwindow1), select_domain_dialog->list_domains);
|
|
|
|
curcol = gtk_tree_view_column_new ();
|
|
gtk_tree_view_column_set_title(curcol, "Name");
|
|
renderer = gtk_cell_renderer_text_new();
|
|
gtk_tree_view_column_pack_start(curcol, renderer, True);
|
|
gtk_tree_view_append_column(GTK_TREE_VIEW(select_domain_dialog->list_domains), curcol);
|
|
gtk_tree_view_column_add_attribute(curcol, renderer, "text", 0);
|
|
|
|
select_domain_dialog->store_domains = gtk_list_store_new(1, G_TYPE_STRING);
|
|
gtk_tree_view_set_model(GTK_TREE_VIEW(select_domain_dialog->list_domains), GTK_TREE_MODEL(select_domain_dialog->store_domains));
|
|
g_object_unref(select_domain_dialog->store_domains);
|
|
|
|
dialog_action_area1 = GTK_DIALOG (select_domain_dialog)->action_area;
|
|
gtk_button_box_set_layout (GTK_BUTTON_BOX (dialog_action_area1), GTK_BUTTONBOX_END);
|
|
|
|
cancelbutton1 = gtk_button_new_from_stock ("gtk-cancel");
|
|
gtk_dialog_add_action_widget (GTK_DIALOG (select_domain_dialog), cancelbutton1, GTK_RESPONSE_CANCEL);
|
|
GTK_WIDGET_SET_FLAGS (cancelbutton1, GTK_CAN_DEFAULT);
|
|
|
|
okbutton1 = gtk_button_new_from_stock ("gtk-ok");
|
|
gtk_dialog_add_action_widget (GTK_DIALOG (select_domain_dialog), okbutton1, GTK_RESPONSE_OK);
|
|
gtk_widget_show_all(dialog_vbox1);
|
|
GTK_WIDGET_SET_FLAGS (okbutton1, GTK_CAN_DEFAULT);
|
|
}
|
|
|
|
struct policy_handle gtk_select_domain_dialog_get_handle(GtkSelectDomainDialog *d)
|
|
{
|
|
struct policy_handle h;
|
|
|
|
|
|
/* FIXME */
|
|
return h;
|
|
}
|
|
|
|
GType gtk_select_domain_dialog_get_type (void)
|
|
{
|
|
static GType mytype = 0;
|
|
|
|
if (!mytype)
|
|
{
|
|
static const GTypeInfo myinfo =
|
|
{
|
|
sizeof (GtkSelectDomainDialogClass),
|
|
NULL,
|
|
NULL,
|
|
NULL,
|
|
NULL,
|
|
NULL,
|
|
sizeof(GtkSelectDomainDialog),
|
|
0,
|
|
(GInstanceInitFunc) gtk_select_domain_dialog_init,
|
|
};
|
|
|
|
mytype = g_type_register_static (GTK_TYPE_DIALOG,
|
|
"GtkSelectDomainDialog", &myinfo, 0);
|
|
}
|
|
|
|
return mytype;
|
|
}
|
|
|
|
GtkWidget *gtk_select_domain_dialog_new (struct dcerpc_pipe *sam_pipe)
|
|
{
|
|
GtkSelectDomainDialog *d = g_object_new(gtk_select_domain_dialog_get_type (), NULL);
|
|
NTSTATUS status;
|
|
struct samr_EnumDomains r;
|
|
struct samr_Connect cr;
|
|
struct samr_Close dr;
|
|
struct policy_handle handle;
|
|
uint32_t resume_handle = 0;
|
|
int i;
|
|
TALLOC_CTX *mem_ctx = talloc_init("gtk_select_domain_dialog_new");
|
|
|
|
d->sam_pipe = sam_pipe;
|
|
|
|
cr.in.system_name = 0;
|
|
cr.in.access_mask = SEC_FLAG_MAXIMUM_ALLOWED;
|
|
cr.out.connect_handle = &handle;
|
|
|
|
status = dcerpc_samr_Connect(sam_pipe, mem_ctx, &cr);
|
|
if (!NT_STATUS_IS_OK(status)) {
|
|
gtk_show_ntstatus(NULL, "Running Connect on SAMR", status);
|
|
talloc_free(mem_ctx);
|
|
return GTK_WIDGET(d);
|
|
}
|
|
|
|
r.in.connect_handle = &handle;
|
|
r.in.resume_handle = &resume_handle;
|
|
r.in.buf_size = (uint32_t)-1;
|
|
r.out.resume_handle = &resume_handle;
|
|
|
|
status = dcerpc_samr_EnumDomains(sam_pipe, mem_ctx, &r);
|
|
if (!NT_STATUS_IS_OK(status)) {
|
|
gtk_show_ntstatus(NULL, "Enumerating domains", status);
|
|
} else if (r.out.sam) {
|
|
for (i=0;i<r.out.sam->count;i++) {
|
|
GtkTreeIter iter;
|
|
gtk_list_store_append(d->store_domains, &iter);
|
|
gtk_list_store_set (d->store_domains, &iter, 0, r.out.sam->entries[i].name.string, -1);
|
|
}
|
|
}
|
|
|
|
dr.in.handle = &handle;
|
|
dr.out.handle = &handle;
|
|
|
|
status = dcerpc_samr_Close(sam_pipe, mem_ctx, &dr);
|
|
if (!NT_STATUS_IS_OK(status)) {
|
|
gtk_show_ntstatus(NULL, "Closing SAMR connection", status);
|
|
talloc_free(mem_ctx);
|
|
return GTK_WIDGET ( d );
|
|
}
|
|
|
|
talloc_free(mem_ctx);
|
|
|
|
return GTK_WIDGET ( d );
|
|
}
|
|
|
|
|
|
/* GtkSelectHostDialog */
|
|
const char *gtk_select_host_dialog_get_host (GtkSelectHostDialog *d)
|
|
{
|
|
return gtk_entry_get_text(GTK_ENTRY(d->entry_host));
|
|
}
|
|
|
|
static void gtk_select_host_dialog_init (GtkSelectHostDialog *select_host_dialog)
|
|
{
|
|
GtkWidget *dialog_vbox2;
|
|
GtkWidget *hbox2;
|
|
GtkWidget *label2;
|
|
GtkWidget *scrolledwindow2;
|
|
GtkWidget *dialog_action_area2;
|
|
GtkWidget *cancelbutton2;
|
|
GtkWidget *okbutton2;
|
|
|
|
gtk_window_set_title (GTK_WINDOW (select_host_dialog), "Select Host");
|
|
|
|
dialog_vbox2 = GTK_DIALOG (select_host_dialog)->vbox;
|
|
|
|
hbox2 = gtk_hbox_new (FALSE, 0);
|
|
gtk_box_pack_start (GTK_BOX (dialog_vbox2), hbox2, TRUE, TRUE, 0);
|
|
|
|
label2 = gtk_label_new ("Host");
|
|
gtk_box_pack_start (GTK_BOX (hbox2), label2, FALSE, FALSE, 0);
|
|
|
|
select_host_dialog->entry_host = gtk_entry_new ();
|
|
gtk_box_pack_start (GTK_BOX (hbox2), select_host_dialog->entry_host, TRUE, TRUE, 0);
|
|
|
|
scrolledwindow2 = gtk_scrolled_window_new (NULL, NULL);
|
|
gtk_box_pack_start (GTK_BOX (dialog_vbox2), scrolledwindow2, TRUE, TRUE, 0);
|
|
|
|
select_host_dialog->tree_host = gtk_tree_view_new ();
|
|
gtk_container_add (GTK_CONTAINER (scrolledwindow2), select_host_dialog->tree_host);
|
|
|
|
select_host_dialog->store_host = gtk_tree_store_new(1, G_TYPE_STRING);
|
|
gtk_tree_view_set_model(GTK_TREE_VIEW(select_host_dialog->tree_host), GTK_TREE_MODEL(select_host_dialog->store_host));
|
|
g_object_unref(select_host_dialog->store_host);
|
|
|
|
dialog_action_area2 = GTK_DIALOG (select_host_dialog)->action_area;
|
|
gtk_button_box_set_layout (GTK_BUTTON_BOX (dialog_action_area2), GTK_BUTTONBOX_END);
|
|
|
|
cancelbutton2 = gtk_button_new_from_stock ("gtk-cancel");
|
|
gtk_dialog_add_action_widget (GTK_DIALOG (select_host_dialog), cancelbutton2, GTK_RESPONSE_CANCEL);
|
|
GTK_WIDGET_SET_FLAGS (cancelbutton2, GTK_CAN_DEFAULT);
|
|
|
|
okbutton2 = gtk_button_new_from_stock ("gtk-ok");
|
|
gtk_widget_show_all (dialog_vbox2);
|
|
gtk_dialog_add_action_widget (GTK_DIALOG (select_host_dialog), okbutton2, GTK_RESPONSE_OK);
|
|
GTK_WIDGET_SET_FLAGS (okbutton2, GTK_CAN_DEFAULT);
|
|
}
|
|
|
|
GType gtk_select_host_dialog_get_type (void)
|
|
{
|
|
static GType mytype = 0;
|
|
|
|
if (!mytype)
|
|
{
|
|
static const GTypeInfo myinfo =
|
|
{
|
|
sizeof (GtkSelectHostDialogClass),
|
|
NULL,
|
|
NULL,
|
|
NULL,
|
|
NULL,
|
|
NULL,
|
|
sizeof(GtkSelectHostDialog),
|
|
0,
|
|
(GInstanceInitFunc) gtk_select_host_dialog_init,
|
|
};
|
|
|
|
mytype = g_type_register_static (GTK_TYPE_DIALOG,
|
|
"GtkSelectHostDialog", &myinfo, 0);
|
|
}
|
|
|
|
return mytype;
|
|
}
|
|
|
|
GtkWidget *gtk_select_host_dialog_new (struct dcerpc_pipe *sam_pipe)
|
|
{
|
|
return GTK_WIDGET ( g_object_new (gtk_select_host_dialog_get_type (), NULL ));
|
|
}
|
|
|
|
/**
|
|
* Connect to a specific interface, but ask the user
|
|
* for information not specified
|
|
*/
|
|
struct dcerpc_pipe *gtk_connect_rpc_interface(TALLOC_CTX *mem_ctx, const struct dcerpc_interface_table *table)
|
|
{
|
|
GtkRpcBindingDialog *d;
|
|
NTSTATUS status;
|
|
struct dcerpc_pipe *pipe;
|
|
struct cli_credentials *cred;
|
|
gint result;
|
|
|
|
d = GTK_RPC_BINDING_DIALOG(gtk_rpc_binding_dialog_new(NULL));
|
|
result = gtk_dialog_run(GTK_DIALOG(d));
|
|
|
|
if (result != GTK_RESPONSE_ACCEPT) {
|
|
gtk_widget_destroy(GTK_WIDGET(d));
|
|
return NULL;
|
|
}
|
|
|
|
cred = cli_credentials_init(mem_ctx);
|
|
cli_credentials_guess(cred);
|
|
cli_credentials_set_gtk_callbacks(cred);
|
|
|
|
status = dcerpc_pipe_connect_b(mem_ctx, &pipe,
|
|
gtk_rpc_binding_dialog_get_binding(d, mem_ctx),
|
|
table, cred, NULL);
|
|
|
|
if(!NT_STATUS_IS_OK(status)) {
|
|
gtk_show_ntstatus(NULL, "While connecting to interface", status);
|
|
gtk_widget_destroy(GTK_WIDGET(d));
|
|
talloc_free(cred);
|
|
return NULL;
|
|
}
|
|
|
|
gtk_widget_destroy(GTK_WIDGET(d));
|
|
|
|
talloc_free(cred);
|
|
|
|
return pipe;
|
|
}
|