diff options
author | Aleksander Morgado <aleksander@lanedo.com> | 2011-11-20 20:55:07 +0100 |
---|---|---|
committer | Aleksander Morgado <aleksander@lanedo.com> | 2012-03-15 14:14:26 +0100 |
commit | 1257ecd13613d6f60d317a3ee3f34332188d0cfc (patch) | |
tree | 9b790e3a162e155cc0ef2fb2b55f351606aa909f /cli/mmcli-common.c | |
parent | 9ae68b3fee0a8f58e308f1a20cccf433a414fc8b (diff) |
cli: start to port Modem actions to use the new libmm-glib
Diffstat (limited to 'cli/mmcli-common.c')
-rw-r--r-- | cli/mmcli-common.c | 237 |
1 files changed, 237 insertions, 0 deletions
diff --git a/cli/mmcli-common.c b/cli/mmcli-common.c new file mode 100644 index 00000000..0e5b746e --- /dev/null +++ b/cli/mmcli-common.c @@ -0,0 +1,237 @@ +/* -*- Mode: C; tab-width: 4; indent-tabs-mode: nil; c-basic-offset: 4 -*- */ +/* + * mmcli -- Control modem status & access information from the command line + * + * 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 3 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, see <http://www.gnu.org/licenses/>. + * + * Copyright (C) 2011 Aleksander Morgado <aleksander@gnu.org> + */ + +#include <stdlib.h> + +#include "mmcli-common.h" + +static void +manager_new_ready (GDBusConnection *connection, + GAsyncResult *res, + GSimpleAsyncResult *simple) +{ + MMManager *manager; + gchar *name_owner; + GError *error = NULL; + + manager = mm_manager_new_finish (res, &error); + if (!manager) { + g_printerr ("error: couldn't create manager: %s\n", + error ? error->message : "unknown error"); + exit (EXIT_FAILURE); + } + + name_owner = g_dbus_object_manager_client_get_name_owner (G_DBUS_OBJECT_MANAGER_CLIENT (manager)); + if (!name_owner) { + g_printerr ("error: couldn't find the ModemManager process in the bus\n"); + exit (EXIT_FAILURE); + } + + g_debug ("ModemManager process found at '%s'", name_owner); + g_free (name_owner); + + g_simple_async_result_set_op_res_gpointer (simple, manager, NULL); + g_simple_async_result_complete (simple); + g_object_unref (simple); +} + +MMManager * +mmcli_get_manager_finish (GAsyncResult *res) +{ + return g_simple_async_result_get_op_res_gpointer (G_SIMPLE_ASYNC_RESULT (res)); +} + +void +mmcli_get_manager (GDBusConnection *connection, + GCancellable *cancellable, + GAsyncReadyCallback callback, + gpointer user_data) +{ + GSimpleAsyncResult *result; + + result = g_simple_async_result_new (G_OBJECT (connection), + callback, + user_data, + mmcli_get_manager); + mm_manager_new (connection, + G_DBUS_OBJECT_MANAGER_CLIENT_FLAGS_NONE, + cancellable, + (GAsyncReadyCallback)manager_new_ready, + result); +} + +MMManager * +mmcli_get_manager_sync (GDBusConnection *connection) +{ + MMManager *manager; + gchar *name_owner; + GError *error = NULL; + + manager = mm_manager_new_sync (connection, + G_DBUS_OBJECT_MANAGER_CLIENT_FLAGS_NONE, + NULL, + &error); + if (!manager) { + g_printerr ("error: couldn't create manager: %s\n", + error ? error->message : "unknown error"); + exit (EXIT_FAILURE); + } + + name_owner = g_dbus_object_manager_client_get_name_owner (G_DBUS_OBJECT_MANAGER_CLIENT (manager)); + if (!name_owner) { + g_printerr ("error: couldn't find the ModemManager process in the bus\n"); + exit (EXIT_FAILURE); + } + + g_debug ("ModemManager process found at '%s'", name_owner); + g_free (name_owner); + + return manager; +} + +#define MODEM_PATH_TAG "modem-path-tag" + +static MMModem * +find_modem (MMManager *manager, + const gchar *modem_path) +{ + GList *modems; + GList *l; + MMModem *found = NULL; + + modems = g_dbus_object_manager_get_objects (G_DBUS_OBJECT_MANAGER (manager)); + for (l = modems; l; l = g_list_next (l)) { + MMModem *modem = MM_MODEM (l->data); + + if (g_str_equal (mm_modem_get_path (modem), + modem_path)) { + found = g_object_ref (modem); + break; + } + } + g_list_foreach (modems, (GFunc)g_object_unref, NULL); + g_list_free (modems); + + if (!found) { + g_printerr ("error: couldn't find the Modem at '%s'\n", modem_path); + exit (EXIT_FAILURE); + } + + g_debug ("Modem found at '%s'", modem_path); + + return found; +} + +static gchar * +get_modem_path (const gchar *modem_str) +{ + gchar *modem_path; + + /* We must have a given modem specified */ + if (!modem_str) { + g_printerr ("error: no modem was specified\n"); + exit (EXIT_FAILURE); + } + + /* Modem path may come in two ways: full DBus path or just modem index. + * If it is a modem index, we'll need to generate the DBus path ourselves */ + if (modem_str[0] == '/') + modem_path = g_strdup (modem_str); + else { + if (g_ascii_isdigit (modem_str[0])) + modem_path = g_strdup_printf (MM_DBUS_PATH "/Modems/%s", modem_str); + else { + g_printerr ("error: invalid modem string specified: '%s'\n", + modem_str); + exit (EXIT_FAILURE); + } + } + + return modem_path; +} + +static void +get_manager_ready (GDBusConnection *connection, + GAsyncResult *res, + GSimpleAsyncResult *simple) +{ + MMManager *manager; + MMModem *found; + const gchar *modem_path; + + manager = mmcli_get_manager_finish (res); + modem_path = g_object_get_data (G_OBJECT (simple), MODEM_PATH_TAG); + found = find_modem (manager, modem_path); + g_object_unref (manager); + + g_simple_async_result_set_op_res_gpointer (simple, found, NULL); + g_simple_async_result_complete (simple); + g_object_unref (simple); +} + +MMModem * +mmcli_get_modem_finish (GAsyncResult *res) +{ + return g_simple_async_result_get_op_res_gpointer (G_SIMPLE_ASYNC_RESULT (res)); +} + +void +mmcli_get_modem (GDBusConnection *connection, + const gchar *modem_str, + GCancellable *cancellable, + GAsyncReadyCallback callback, + gpointer user_data) +{ + GSimpleAsyncResult *result; + gchar *modem_path; + + modem_path = get_modem_path (modem_str); + result = g_simple_async_result_new (G_OBJECT (connection), + callback, + user_data, + mmcli_get_modem); + g_object_set_data_full (G_OBJECT (result), + MODEM_PATH_TAG, + modem_path, + g_free); + + mmcli_get_manager (connection, + cancellable, + (GAsyncReadyCallback)get_manager_ready, + result); +} + +MMModem * +mmcli_get_modem_sync (GDBusConnection *connection, + const gchar *modem_str) +{ + MMManager *manager; + MMModem *found; + gchar *modem_path; + + manager = mmcli_get_manager_sync (connection); + modem_path = get_modem_path (modem_str); + + found = find_modem (manager, modem_path); + g_object_unref (manager); + g_free (modem_path); + + return found; +} |