| /* -*- Mode: C; tab-width: 4; indent-tabs-mode: nil; c-basic-offset: 4 -*- */ |
| /* |
| * libmm -- Access modem status & information from glib applications |
| * |
| * This library is free software; you can redistribute it and/or |
| * modify it under the terms of the GNU Lesser General Public |
| * License as published by the Free Software Foundation; either |
| * version 2 of the License, or (at your option) any later version. |
| * |
| * This library 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 |
| * Lesser General Public License for more details. |
| * |
| * You should have received a copy of the GNU Lesser General Public |
| * License along with this library; if not, write to the |
| * Free Software Foundation, Inc., 51 Franklin Street, Fifth Floor, |
| * Boston, MA 02110-1301 USA. |
| * |
| * Copyright (C) 2011 Aleksander Morgado <aleksander@gnu.org> |
| */ |
| |
| #include <gio/gio.h> |
| |
| #include "mm-helpers.h" |
| #include "mm-modem-simple.h" |
| |
| /** |
| * mm_modem_simple_get_path: |
| * @self: A #MMModemSimple. |
| * |
| * Gets the DBus path of the #MMObject which implements this interface. |
| * |
| * Returns: (transfer none): The DBus path of the #MMObject object. |
| */ |
| const gchar * |
| mm_modem_simple_get_path (MMModemSimple *self) |
| { |
| g_return_val_if_fail (G_IS_DBUS_PROXY (self), NULL); |
| |
| RETURN_NON_EMPTY_CONSTANT_STRING ( |
| g_dbus_proxy_get_object_path (G_DBUS_PROXY (self))); |
| } |
| |
| /** |
| * mm_modem_simple_dup_path: |
| * @self: A #MMModemSimple. |
| * |
| * Gets a copy of the DBus path of the #MMObject object which implements this interface. |
| * |
| * Returns: (transfer full): The DBus path of the #MMObject. The returned value should be freed with g_free(). |
| */ |
| gchar * |
| mm_modem_simple_dup_path (MMModemSimple *self) |
| { |
| gchar *value; |
| |
| g_return_val_if_fail (G_IS_DBUS_PROXY (self), NULL); |
| |
| g_object_get (G_OBJECT (self), |
| "g-object-path", &value, |
| NULL); |
| RETURN_NON_EMPTY_STRING (value); |
| } |
| |
| typedef struct { |
| GSimpleAsyncResult *result; |
| GCancellable *cancellable; |
| } ConnectContext; |
| |
| static void |
| connect_context_complete_and_free (ConnectContext *ctx) |
| { |
| g_simple_async_result_complete (ctx->result); |
| g_object_unref (ctx->result); |
| if (ctx->cancellable) |
| g_object_unref (ctx->cancellable); |
| g_slice_free (ConnectContext, ctx); |
| } |
| |
| MMBearer * |
| mm_modem_simple_connect_finish (MMModemSimple *self, |
| GAsyncResult *res, |
| GError **error) |
| { |
| g_return_val_if_fail (MM_GDBUS_IS_MODEM_SIMPLE (self), NULL); |
| |
| if (g_simple_async_result_propagate_error (G_SIMPLE_ASYNC_RESULT (res), error)) |
| return NULL; |
| |
| return g_object_ref (g_simple_async_result_get_op_res_gpointer (G_SIMPLE_ASYNC_RESULT (res))); |
| } |
| |
| static void |
| new_bearer_ready (GDBusConnection *connection, |
| GAsyncResult *res, |
| ConnectContext *ctx) |
| { |
| GError *error = NULL; |
| MMBearer *bearer; |
| |
| bearer = mm_gdbus_bearer_proxy_new_finish (res, &error); |
| if (error) |
| g_simple_async_result_take_error (ctx->result, error); |
| else |
| g_simple_async_result_set_op_res_gpointer (ctx->result, |
| bearer, |
| (GDestroyNotify)g_object_unref); |
| |
| connect_context_complete_and_free (ctx); |
| } |
| |
| static void |
| simple_connect_ready (MMModemSimple *self, |
| GAsyncResult *res, |
| ConnectContext *ctx) |
| { |
| GError *error = NULL; |
| gchar *bearer_path = NULL; |
| |
| if (!mm_gdbus_modem_simple_call_connect_finish (self, |
| &bearer_path, |
| res, |
| &error)) { |
| g_simple_async_result_take_error (ctx->result, error); |
| connect_context_complete_and_free (ctx); |
| return; |
| } |
| |
| mm_gdbus_bearer_proxy_new ( |
| g_dbus_proxy_get_connection ( |
| G_DBUS_PROXY (self)), |
| G_DBUS_PROXY_FLAGS_DO_NOT_AUTO_START, |
| MM_DBUS_SERVICE, |
| bearer_path, |
| ctx->cancellable, |
| (GAsyncReadyCallback)new_bearer_ready, |
| ctx); |
| } |
| |
| void |
| mm_modem_simple_connect (MMModemSimple *self, |
| MMSimpleConnectProperties *properties, |
| GCancellable *cancellable, |
| GAsyncReadyCallback callback, |
| gpointer user_data) |
| { |
| ConnectContext *ctx; |
| GVariant *variant; |
| |
| g_return_if_fail (MM_GDBUS_IS_MODEM_SIMPLE (self)); |
| |
| ctx = g_slice_new0 (ConnectContext); |
| ctx->result = g_simple_async_result_new (G_OBJECT (self), |
| callback, |
| user_data, |
| mm_modem_simple_connect); |
| if (cancellable) |
| ctx->cancellable = g_object_ref (cancellable); |
| |
| variant = mm_simple_connect_properties_get_dictionary (properties); |
| mm_gdbus_modem_simple_call_connect ( |
| self, |
| variant, |
| cancellable, |
| (GAsyncReadyCallback)simple_connect_ready, |
| ctx); |
| |
| g_variant_unref (variant); |
| } |
| |
| MMBearer * |
| mm_modem_simple_connect_sync (MMModemSimple *self, |
| MMSimpleConnectProperties *properties, |
| GCancellable *cancellable, |
| GError **error) |
| { |
| MMBearer *bearer = NULL; |
| gchar *bearer_path = NULL; |
| GVariant *variant; |
| |
| g_return_val_if_fail (MM_GDBUS_IS_MODEM_SIMPLE (self), NULL); |
| |
| variant = mm_simple_connect_properties_get_dictionary (properties); |
| mm_gdbus_modem_simple_call_connect_sync (self, |
| variant, |
| &bearer_path, |
| cancellable, |
| error); |
| if (bearer_path) { |
| bearer = mm_gdbus_bearer_proxy_new_sync ( |
| g_dbus_proxy_get_connection ( |
| G_DBUS_PROXY (self)), |
| G_DBUS_PROXY_FLAGS_DO_NOT_AUTO_START, |
| MM_DBUS_SERVICE, |
| bearer_path, |
| cancellable, |
| error); |
| g_free (bearer_path); |
| } |
| |
| g_variant_unref (variant); |
| |
| return bearer; |
| } |
| |
| void |
| mm_modem_simple_disconnect (MMModemSimple *self, |
| const gchar *bearer_path, |
| GCancellable *cancellable, |
| GAsyncReadyCallback callback, |
| gpointer user_data) |
| { |
| g_return_if_fail (MM_GDBUS_IS_MODEM_SIMPLE (self)); |
| |
| mm_gdbus_modem_simple_call_disconnect (self, |
| bearer_path ? bearer_path : "/", |
| cancellable, |
| callback, |
| user_data); |
| } |
| |
| gboolean |
| mm_modem_simple_disconnect_finish (MMModemSimple *self, |
| GAsyncResult *res, |
| GError **error) |
| { |
| g_return_val_if_fail (MM_GDBUS_IS_MODEM_SIMPLE (self), FALSE); |
| |
| return mm_gdbus_modem_simple_call_disconnect_finish (self, res, error); |
| } |
| |
| gboolean |
| mm_modem_simple_disconnect_sync (MMModemSimple *self, |
| const gchar *bearer_path, |
| GCancellable *cancellable, |
| GError **error) |
| { |
| g_return_val_if_fail (MM_GDBUS_IS_MODEM_SIMPLE (self), FALSE); |
| |
| return mm_gdbus_modem_simple_call_disconnect_sync (self, |
| bearer_path ? bearer_path : "/", |
| cancellable, |
| error); |
| } |
| |
| MMSimpleStatus * |
| mm_modem_simple_get_status_finish (MMModemSimple *self, |
| GAsyncResult *res, |
| GError **error) |
| { |
| MMSimpleStatus *status; |
| GVariant *dictionary = NULL; |
| |
| g_return_val_if_fail (MM_GDBUS_IS_MODEM_SIMPLE (self), NULL); |
| |
| if (!mm_gdbus_modem_simple_call_get_status_finish (self, &dictionary, res, error)) |
| return NULL; |
| |
| status = mm_simple_status_new_from_dictionary (dictionary, error); |
| g_variant_unref (dictionary); |
| return status; |
| } |
| |
| void |
| mm_modem_simple_get_status (MMModemSimple *self, |
| GCancellable *cancellable, |
| GAsyncReadyCallback callback, |
| gpointer user_data) |
| { |
| g_return_if_fail (MM_GDBUS_IS_MODEM_SIMPLE (self)); |
| |
| mm_gdbus_modem_simple_call_get_status (self, |
| cancellable, |
| callback, |
| user_data); |
| } |
| |
| MMSimpleStatus * |
| mm_modem_simple_get_status_sync (MMModemSimple *self, |
| GCancellable *cancellable, |
| GError **error) |
| { |
| MMSimpleStatus *status; |
| GVariant *dictionary = NULL; |
| |
| g_return_val_if_fail (MM_GDBUS_IS_MODEM_SIMPLE (self), NULL); |
| |
| if (!mm_gdbus_modem_simple_call_get_status_sync (self, &dictionary, cancellable, error)) |
| return NULL; |
| |
| status = mm_simple_status_new_from_dictionary (dictionary, error); |
| g_variant_unref (dictionary); |
| return status; |
| } |