[network-manager-applet/lr/bluetooth: 2/2] editor: Add support for creating Bluetooth connections
- From: Lubomir Rintel <lkundrak src gnome org>
- To: commits-list gnome org
- Cc:
- Subject: [network-manager-applet/lr/bluetooth: 2/2] editor: Add support for creating Bluetooth connections
- Date: Mon, 27 Oct 2014 11:07:34 +0000 (UTC)
commit a7c05664b9ec0c8ba03ab4d087c1bdad41808c8b
Author: Lubomir Rintel <lkundrak v3 sk>
Date: Mon Oct 27 11:54:57 2014 +0100
editor: Add support for creating Bluetooth connections
We need to know if the connection is going to be PAN or DUN.
src/connection-editor/connection-helpers.c | 7 ++
src/connection-editor/page-bluetooth.c | 153 ++++++++++++++++++++++++++++
2 files changed, 160 insertions(+), 0 deletions(-)
---
diff --git a/src/connection-editor/connection-helpers.c b/src/connection-editor/connection-helpers.c
index 1d74867..e1650ec 100644
--- a/src/connection-editor/connection-helpers.c
+++ b/src/connection-editor/connection-helpers.c
@@ -29,6 +29,7 @@
#include "page-wifi.h"
#include "page-mobile.h"
#include "page-wimax.h"
+#include "page-bluetooth.h"
#include "page-dsl.h"
#include "page-infiniband.h"
#include "page-bond.h"
@@ -123,6 +124,12 @@ get_connection_type_list (void)
data.virtual = FALSE;
g_array_append_val (array, data);
+ data.name = _("Bluetooth");
+ data.new_connection_func = bluetooth_connection_new;
+ data.setting_type = NM_TYPE_SETTING_BLUETOOTH;
+ data.virtual = FALSE;
+ g_array_append_val (array, data);
+
data.name = _("DSL");
data.new_connection_func = dsl_connection_new;
data.setting_type = NM_TYPE_SETTING_PPPOE;
diff --git a/src/connection-editor/page-bluetooth.c b/src/connection-editor/page-bluetooth.c
index b1fa0a1..441938e 100644
--- a/src/connection-editor/page-bluetooth.c
+++ b/src/connection-editor/page-bluetooth.c
@@ -32,6 +32,7 @@
#include "page-bluetooth.h"
#include "nm-connection-editor.h"
+#include "nm-mobile-wizard.h"
G_DEFINE_TYPE (CEPageBluetooth, ce_page_bluetooth, CE_TYPE_PAGE)
@@ -175,3 +176,155 @@ ce_page_bluetooth_class_init (CEPageBluetoothClass *bluetooth_class)
/* virtual methods */
parent_class->validate = validate;
}
+
+typedef struct {
+ NMRemoteSettings *settings;
+ PageNewConnectionResultFunc result_func;
+ gpointer user_data;
+ const gchar *type;
+} WizardInfo;
+
+static void
+new_connection_mobile_wizard_done (NMAMobileWizard *wizard,
+ gboolean canceled,
+ NMAMobileWizardAccessMethod *method,
+ gpointer user_data)
+{
+ WizardInfo *info = user_data;
+ NMConnection *connection = NULL;
+ char *detail = NULL;
+ NMSetting *type_setting = NULL;
+
+ if (canceled)
+ goto out;
+
+ if (method) {
+ switch (method->devtype) {
+ case NM_DEVICE_MODEM_CAPABILITY_GSM_UMTS:
+ type_setting = nm_setting_gsm_new ();
+ /* De-facto standard for GSM */
+ g_object_set (type_setting,
+ NM_SETTING_GSM_NUMBER, "*99#",
+ NM_SETTING_GSM_USERNAME, method->username,
+ NM_SETTING_GSM_PASSWORD, method->password,
+ NM_SETTING_GSM_APN, method->gsm_apn,
+ NULL);
+ break;
+ case NM_DEVICE_MODEM_CAPABILITY_CDMA_EVDO:
+ type_setting = nm_setting_cdma_new ();
+ /* De-facto standard for CDMA */
+ g_object_set (type_setting,
+ NM_SETTING_CDMA_NUMBER, "#777",
+ NM_SETTING_GSM_USERNAME, method->username,
+ NM_SETTING_GSM_PASSWORD, method->password,
+ NULL);
+ break;
+ default:
+ g_assert_not_reached ();
+ break;
+ }
+
+ if (method->plan_name)
+ detail = g_strdup_printf ("%s %s %%d", method->provider_name, method->plan_name);
+ else
+ detail = g_strdup_printf ("%s connection %%d", method->provider_name);
+ }
+
+ if (!detail)
+ detail = g_strdup (_("Bluetooth connection %d"));
+ connection = ce_page_new_connection (detail,
+ NM_SETTING_BLUETOOTH_SETTING_NAME,
+ FALSE,
+ info->settings,
+ user_data);
+ g_free (detail);
+ nm_connection_add_setting (connection, nm_setting_bluetooth_new ());
+ g_object_set (nm_connection_get_setting_bluetooth (connection),
+ NM_SETTING_BLUETOOTH_TYPE, info->type, NULL);
+
+ if (type_setting) {
+ nm_connection_add_setting (connection, type_setting);
+ nm_connection_add_setting (connection, nm_setting_ppp_new ());
+ }
+
+out:
+ (*info->result_func) (connection, canceled, NULL, info->user_data);
+
+ if (wizard)
+ nma_mobile_wizard_destroy (wizard);
+
+ g_object_unref (info->settings);
+ g_free (info);
+}
+
+void
+bluetooth_connection_new (GtkWindow *parent,
+ const char *detail,
+ NMRemoteSettings *settings,
+ PageNewConnectionResultFunc result_func,
+ gpointer user_data)
+{
+ gint response;
+ NMAMobileWizard *wizard = NULL;
+ WizardInfo *info;
+ GtkWidget *dialog, *content, *alignment, *vbox, *label, *dun_radio, *panu_radio;
+
+ info = g_malloc0 (sizeof (WizardInfo));
+ info->result_func = result_func;
+ info->settings = g_object_ref (settings);
+ info->user_data = user_data;
+ info->type = NM_SETTING_BLUETOOTH_TYPE_PANU;
+ info->type = NM_SETTING_BLUETOOTH_TYPE_DUN;
+
+
+ dialog = gtk_dialog_new_with_buttons (_("Select Bluetooth Connection Profile"),
+ parent,
+ GTK_DIALOG_MODAL,
+ GTK_STOCK_CANCEL,
+ GTK_RESPONSE_CANCEL,
+ GTK_STOCK_OK,
+ GTK_RESPONSE_OK,
+ NULL);
+
+ content = gtk_dialog_get_content_area (GTK_DIALOG (dialog));
+
+ alignment = gtk_alignment_new (0, 0, 0.5, 0.5);
+ gtk_alignment_set_padding (GTK_ALIGNMENT (alignment), 12, 12, 12, 12);
+ gtk_box_pack_start (GTK_BOX (content), alignment, TRUE, FALSE, 6);
+
+ vbox = gtk_box_new (GTK_ORIENTATION_VERTICAL, 6);
+ gtk_container_add (GTK_CONTAINER (alignment), vbox);
+
+ label = gtk_label_new (_("Select the Bluetooth Profile your device uses."));
+ gtk_misc_set_alignment (GTK_MISC (label), 0, 0.5);
+ gtk_label_set_line_wrap (GTK_LABEL (label), TRUE);
+ gtk_box_pack_start (GTK_BOX (vbox), label, FALSE, FALSE, 12);
+
+ panu_radio = gtk_radio_button_new_with_mnemonic (NULL, _("Personal Area Network"));
+ gtk_toggle_button_set_active (GTK_TOGGLE_BUTTON (panu_radio), TRUE);
+ gtk_box_pack_start (GTK_BOX (vbox), panu_radio, FALSE, FALSE, 6);
+
+ dun_radio = gtk_radio_button_new_with_mnemonic_from_widget (GTK_RADIO_BUTTON (panu_radio),
+ _("Dial-Up Network"));
+ gtk_box_pack_start (GTK_BOX (vbox), dun_radio, FALSE, FALSE, 6);
+
+ gtk_widget_show_all (dialog);
+ response = gtk_dialog_run (GTK_DIALOG (dialog));
+ if (response == GTK_RESPONSE_OK) {
+ if (gtk_toggle_button_get_active (GTK_TOGGLE_BUTTON (dun_radio))) {
+ info->type = NM_SETTING_BLUETOOTH_TYPE_DUN;
+ wizard = nma_mobile_wizard_new (parent, NULL, NM_DEVICE_MODEM_CAPABILITY_NONE, FALSE,
+ new_connection_mobile_wizard_done, info);
+ } else {
+ info->type = NM_SETTING_BLUETOOTH_TYPE_PANU;
+ }
+ }
+ gtk_widget_destroy (dialog);
+
+ if (wizard) {
+ nma_mobile_wizard_present (wizard);
+ return;
+ } else {
+ new_connection_mobile_wizard_done (NULL, (response != GTK_RESPONSE_OK), NULL, info);
+ }
+}
[
Date Prev][
Date Next] [
Thread Prev][
Thread Next]
[
Thread Index]
[
Date Index]
[
Author Index]