From 97416e6b011a3c733d07f83073bf12796c7ecc6b Mon Sep 17 00:00:00 2001 From: Jelmer Vernooij Date: Mon, 12 Feb 2007 12:12:12 +0000 Subject: r21297: Remove the GTK+ tools and library from the main repository. They are now maintained separately in bzr at http://people.samba.org/bzr/jelmer/samba-gtk This also adds some more headers to the list that is installed and a couple of extra #include lines so these headers can be used externally without problems. (This used to be commit 07652f65ce7a5b19130f1a27cbf0e1e5fae13454) --- source4/gtk/common/gtk-smb.c | 316 ------------------------------------------- 1 file changed, 316 deletions(-) delete mode 100644 source4/gtk/common/gtk-smb.c (limited to 'source4/gtk/common/gtk-smb.c') diff --git a/source4/gtk/common/gtk-smb.c b/source4/gtk/common/gtk-smb.c deleted file mode 100644 index cb445d8268..0000000000 --- a/source4/gtk/common/gtk-smb.c +++ /dev/null @@ -1,316 +0,0 @@ -/* - Unix SMB/CIFS implementation. - SMB-related GTK+ functions - - Copyright (C) Jelmer Vernooij 2004-2005 - - 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" -#include "gtk/common/select.h" -#include "version.h" -#include "librpc/rpc/dcerpc.h" -#include "auth/credentials/credentials.h" - -/** - * Dialog error showing a WERROR - */ -void gtk_show_werror(GtkWidget *win, const char *message, WERROR err) -{ - GtkWidget *dialog = gtk_message_dialog_new( GTK_WINDOW(win), - GTK_DIALOG_DESTROY_WITH_PARENT, - GTK_MESSAGE_ERROR, - GTK_BUTTONS_CLOSE, - "%s: %s\n", message?message: "Windows error", - win_errstr(err)); - gtk_dialog_run (GTK_DIALOG (dialog)); - gtk_widget_destroy (dialog); -} - -/** - * GTK+ dialog showing a NTSTATUS error - */ -void gtk_show_ntstatus(GtkWidget *win, const char *message, NTSTATUS status) -{ - GtkWidget *dialog = gtk_message_dialog_new( GTK_WINDOW(win), - GTK_DIALOG_DESTROY_WITH_PARENT, - GTK_MESSAGE_ERROR, - GTK_BUTTONS_CLOSE, - "%s: %s\n", message?message:"Windows error", - nt_errstr(status)); - gtk_dialog_run (GTK_DIALOG (dialog)); - gtk_widget_destroy (dialog); -} - -static void on_browse_activate (GtkButton *button, gpointer user_data) -{ - GtkRpcBindingDialog *rbd = user_data; - GtkWidget *shd = gtk_select_host_dialog_new(rbd->sam_pipe); - if(gtk_dialog_run(GTK_DIALOG(shd)) == GTK_RESPONSE_ACCEPT) { - gtk_entry_set_text(GTK_ENTRY(rbd->entry_host), gtk_select_host_dialog_get_host(GTK_SELECT_HOST_DIALOG(shd))); - } - - gtk_widget_destroy(GTK_WIDGET(shd)); -} - -static void on_ncalrpc_toggled(GtkToggleButton *tb, GtkRpcBindingDialog *d) -{ - gtk_widget_set_sensitive(d->frame_host, !gtk_toggle_button_get_active(tb)); -} - -static void gtk_rpc_binding_dialog_init (GtkRpcBindingDialog *gtk_rpc_binding_dialog) -{ - GtkWidget *dialog_vbox1; - GtkWidget *vbox1; - GtkWidget *vbox6; - GtkWidget *frame_transport; - GtkWidget *label1; - GtkWidget *hbox1; - GtkWidget *lbl_name; - GtkWidget *label2; - GtkWidget *label3; - GtkWidget *frame_security; - GtkWidget *vbox2; - GtkWidget *btn_browse; - GtkWidget *dialog_action_area1; - GtkWidget *btn_cancel; - GtkWidget *btn_connect; - GSList *transport_smb_group = NULL; - - gtk_rpc_binding_dialog->mem_ctx = talloc_init("gtk_rcp_binding_dialog"); - - gtk_window_set_title (GTK_WINDOW (gtk_rpc_binding_dialog), "Connect"); - - dialog_vbox1 = GTK_DIALOG (gtk_rpc_binding_dialog)->vbox; - - vbox1 = gtk_vbox_new (FALSE, 0); - gtk_box_pack_start (GTK_BOX (dialog_vbox1), vbox1, TRUE, TRUE, 0); - - frame_transport = gtk_frame_new (NULL); - gtk_box_pack_start (GTK_BOX (vbox1), frame_transport, TRUE, TRUE, 0); - - vbox6 = gtk_vbox_new (FALSE, 0); - gtk_container_add (GTK_CONTAINER (frame_transport), vbox6); - - gtk_rpc_binding_dialog->transport_ncalrpc = gtk_radio_button_new_with_mnemonic (NULL, "Local Host"); - gtk_box_pack_start (GTK_BOX (vbox6), gtk_rpc_binding_dialog->transport_ncalrpc, FALSE, FALSE, 0); - gtk_radio_button_set_group (GTK_RADIO_BUTTON (gtk_rpc_binding_dialog->transport_ncalrpc), transport_smb_group); - transport_smb_group = gtk_radio_button_get_group (GTK_RADIO_BUTTON (gtk_rpc_binding_dialog->transport_ncalrpc)); - - - gtk_rpc_binding_dialog->transport_smb = gtk_radio_button_new_with_mnemonic (NULL, "RPC over SMB over TCP/IP"); - gtk_box_pack_start (GTK_BOX (vbox6), gtk_rpc_binding_dialog->transport_smb, FALSE, FALSE, 0); - gtk_radio_button_set_group (GTK_RADIO_BUTTON (gtk_rpc_binding_dialog->transport_smb), transport_smb_group); - transport_smb_group = gtk_radio_button_get_group (GTK_RADIO_BUTTON (gtk_rpc_binding_dialog->transport_smb)); - gtk_toggle_button_set_active (GTK_TOGGLE_BUTTON (gtk_rpc_binding_dialog->transport_smb), TRUE); - - gtk_rpc_binding_dialog->transport_tcp_ip = gtk_radio_button_new_with_mnemonic (NULL, "RPC over TCP/IP"); - gtk_box_pack_start (GTK_BOX (vbox6), gtk_rpc_binding_dialog->transport_tcp_ip, FALSE, FALSE, 0); - gtk_radio_button_set_group (GTK_RADIO_BUTTON (gtk_rpc_binding_dialog->transport_tcp_ip), transport_smb_group); - transport_smb_group = gtk_radio_button_get_group (GTK_RADIO_BUTTON (gtk_rpc_binding_dialog->transport_tcp_ip)); - - label1 = gtk_label_new ("Transport"); - gtk_frame_set_label_widget (GTK_FRAME (frame_transport), label1); - - gtk_rpc_binding_dialog->frame_host = gtk_frame_new (NULL); - gtk_box_pack_start (GTK_BOX (vbox1), gtk_rpc_binding_dialog->frame_host, TRUE, TRUE, 0); - - hbox1 = gtk_hbox_new (FALSE, 0); - gtk_container_add (GTK_CONTAINER (gtk_rpc_binding_dialog->frame_host), hbox1); - - lbl_name = gtk_label_new ("Name"); - gtk_box_pack_start (GTK_BOX (hbox1), lbl_name, TRUE, TRUE, 0); - - gtk_rpc_binding_dialog->entry_host = gtk_entry_new (); - gtk_box_pack_start (GTK_BOX (hbox1), gtk_rpc_binding_dialog->entry_host, TRUE, TRUE, 0); - - if(gtk_rpc_binding_dialog->sam_pipe) - { - btn_browse = gtk_button_new_with_label ("Browse"); - gtk_box_pack_start (GTK_BOX (hbox1), btn_browse, TRUE, TRUE, 0); - - g_signal_connect ((gpointer) btn_browse, "pressed", - G_CALLBACK (on_browse_activate), - gtk_rpc_binding_dialog); - } - - label2 = gtk_label_new ("Host"); - gtk_frame_set_label_widget (GTK_FRAME (gtk_rpc_binding_dialog->frame_host), label2); - - frame_security = gtk_frame_new (NULL); - - label3 = gtk_label_new ("Security"); - gtk_frame_set_label_widget (GTK_FRAME (frame_security), label3); - - gtk_box_pack_start (GTK_BOX (vbox1), frame_security, TRUE, TRUE, 0); - - vbox2 = gtk_vbox_new (FALSE, 0); - gtk_container_add (GTK_CONTAINER (frame_security), vbox2); - - gtk_rpc_binding_dialog->chk_sign = gtk_check_button_new_with_mnemonic ("S_ign"); - gtk_box_pack_start (GTK_BOX (vbox2), gtk_rpc_binding_dialog->chk_sign, FALSE, FALSE, 0); - - gtk_rpc_binding_dialog->chk_seal = gtk_check_button_new_with_mnemonic ("_Seal"); - gtk_box_pack_start (GTK_BOX (vbox2), gtk_rpc_binding_dialog->chk_seal, FALSE, FALSE, 0); - - dialog_action_area1 = GTK_DIALOG (gtk_rpc_binding_dialog)->action_area; - gtk_button_box_set_layout (GTK_BUTTON_BOX (dialog_action_area1), GTK_BUTTONBOX_END); - - btn_cancel = gtk_button_new_from_stock ("gtk-cancel"); - gtk_dialog_add_action_widget (GTK_DIALOG (gtk_rpc_binding_dialog), btn_cancel, GTK_RESPONSE_CANCEL); - GTK_WIDGET_SET_FLAGS (btn_cancel, GTK_CAN_DEFAULT); - - btn_connect = gtk_button_new_with_mnemonic ("C_onnect"); - gtk_dialog_add_action_widget (GTK_DIALOG (gtk_rpc_binding_dialog), btn_connect, GTK_RESPONSE_ACCEPT); - gtk_container_set_border_width (GTK_CONTAINER (btn_connect), 1); - GTK_WIDGET_SET_FLAGS (btn_connect, GTK_CAN_DEFAULT); - - g_signal_connect ((gpointer) gtk_rpc_binding_dialog->transport_ncalrpc, "toggled", - G_CALLBACK (on_ncalrpc_toggled), - gtk_rpc_binding_dialog); - - - gtk_toggle_button_set_active (GTK_TOGGLE_BUTTON(gtk_rpc_binding_dialog->transport_ncalrpc), TRUE); - gtk_widget_show_all(dialog_vbox1); - - gtk_widget_grab_focus (btn_connect); - gtk_widget_grab_default (btn_connect); -} - -GType gtk_rpc_binding_dialog_get_type (void) -{ - static GType mytype = 0; - - if (!mytype) - { - static const GTypeInfo myinfo = - { - sizeof (GtkRpcBindingDialogClass), - NULL, - NULL, - NULL, - NULL, - NULL, - sizeof(GtkRpcBindingDialog), - 0, - (GInstanceInitFunc) gtk_rpc_binding_dialog_init, - }; - - mytype = g_type_register_static (GTK_TYPE_DIALOG, - "GtkRpcBindingDialog", &myinfo, 0); - } - - return mytype; -} - -/** - * Create a new GTK+ dialog asking for binding information for - * DCE/RPC - * - * Optionally gets a sam pipe that will be used to look up users - */ -GtkWidget *gtk_rpc_binding_dialog_new (struct dcerpc_pipe *sam_pipe) -{ - GtkRpcBindingDialog *d = GTK_RPC_BINDING_DIALOG ( g_object_new (gtk_rpc_binding_dialog_get_type (), NULL)); - d->sam_pipe = sam_pipe; - return GTK_WIDGET(d); -} - -const char *gtk_rpc_binding_dialog_get_host(GtkRpcBindingDialog *d) -{ - return gtk_entry_get_text(GTK_ENTRY(d->entry_host)); -} - -struct dcerpc_binding *gtk_rpc_binding_dialog_get_binding(GtkRpcBindingDialog *d, TALLOC_CTX *mem_ctx) -{ - struct dcerpc_binding *binding = talloc(mem_ctx, struct dcerpc_binding); - - ZERO_STRUCT(binding->object); - - /* Format: TRANSPORT:host[\pipe\foo,foo,foo] */ - - binding->host = talloc_strdup(mem_ctx, gtk_entry_get_text(GTK_ENTRY(d->entry_host))); - if(gtk_toggle_button_get_active(GTK_TOGGLE_BUTTON(d->transport_tcp_ip))) { - binding->transport = NCACN_IP_TCP; - } else if(gtk_toggle_button_get_active(GTK_TOGGLE_BUTTON(d->transport_ncalrpc))) { - binding->transport = NCALRPC; - binding->host = NULL; - } else { - binding->transport = NCACN_NP; - } - - binding->options = NULL; - binding->flags = 0; - binding->endpoint = NULL; - - if(gtk_toggle_button_get_active(GTK_TOGGLE_BUTTON(d->chk_seal))) { - binding->flags |= DCERPC_SEAL; - } - - if(gtk_toggle_button_get_active(GTK_TOGGLE_BUTTON(d->chk_sign))) { - binding->flags |= DCERPC_SIGN; - } - - return binding; -} - -const char *gtk_rpc_binding_dialog_get_binding_string(GtkRpcBindingDialog *d, TALLOC_CTX *mem_ctx) -{ - return dcerpc_binding_string(mem_ctx, gtk_rpc_binding_dialog_get_binding(d, mem_ctx)); -} - -GtkWidget *create_gtk_samba_about_dialog (const char *appname) -{ - GtkWidget *samba_about_dialog; - GtkWidget *dialog_vbox1; - GtkWidget *label1; - GtkWidget *label2; - GtkWidget *label3; - GtkWidget *label4; - GtkWidget *dialog_action_area1; - GtkWidget *okbutton1; - - samba_about_dialog = gtk_dialog_new (); - gtk_window_set_title (GTK_WINDOW (samba_about_dialog), "About"); - - dialog_vbox1 = GTK_DIALOG (samba_about_dialog)->vbox; - - /* FIXME image1 = create_pixmap (samba_about_dialog, "slmed.png"); - gtk_box_pack_start (GTK_BOX (dialog_vbox1), image1, TRUE, TRUE, 0);*/ - - label1 = gtk_label_new (appname); - gtk_box_pack_start (GTK_BOX (dialog_vbox1), label1, FALSE, FALSE, 0); - - label2 = gtk_label_new (SAMBA_VERSION_STRING); - gtk_box_pack_start (GTK_BOX (dialog_vbox1), label2, FALSE, FALSE, 0); - - label3 = gtk_label_new_with_mnemonic ("Part of Samba "); - gtk_box_pack_start (GTK_BOX (dialog_vbox1), label3, FALSE, FALSE, 0); - - label4 = gtk_label_new ("\302\251 1992-2006 The Samba Team"); - gtk_box_pack_start (GTK_BOX (dialog_vbox1), label4, FALSE, FALSE, 0); - - dialog_action_area1 = GTK_DIALOG (samba_about_dialog)->action_area; - gtk_button_box_set_layout (GTK_BUTTON_BOX (dialog_action_area1), GTK_BUTTONBOX_END); - - okbutton1 = gtk_button_new_from_stock ("gtk-ok"); - gtk_dialog_add_action_widget (GTK_DIALOG (samba_about_dialog), okbutton1, GTK_RESPONSE_OK); - GTK_WIDGET_SET_FLAGS (okbutton1, GTK_CAN_DEFAULT); - gtk_widget_show_all(dialog_vbox1); - - return samba_about_dialog; -} -- cgit