diff options
author | Guido Günther <agx@sigxcpu.org> | 2023-12-05 18:58:20 +0100 |
---|---|---|
committer | Aleksander Morgado <aleksander@aleksander.es> | 2024-12-01 21:41:10 +0000 |
commit | 0e4bc1b6eab7f7d229655f60a1a86fc4aafd081b (patch) | |
tree | b8c9d7758984450f5d869c8279912c07caea502b /libmm-glib/mm-cbm.c | |
parent | 60357247eb3ee93f7505f3913f002d5ab7ad81ce (diff) |
api: Add Cell Broadcast support
Add access to the modem's CellBroadcast interface and to fetch
Cell Broadcast messages.
Closes: https://gitlab.freedesktop.org/mobile-broadband/ModemManager/-/issues/253
Signed-off-by: Guido Günther <agx@sigxcpu.org>
Diffstat (limited to 'libmm-glib/mm-cbm.c')
-rw-r--r-- | libmm-glib/mm-cbm.c | 226 |
1 files changed, 226 insertions, 0 deletions
diff --git a/libmm-glib/mm-cbm.c b/libmm-glib/mm-cbm.c new file mode 100644 index 00000000..5044408f --- /dev/null +++ b/libmm-glib/mm-cbm.c @@ -0,0 +1,226 @@ +/* -*- Mode: C; tab-width: 4; indent-tabs-mode: nil; c-basic-offset: 4 -*- */ +/* + * libmm-glib -- 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) 2024 Guido Günther <agx@sigxcpu.org> + */ + +#include "string.h" + +#include "mm-helpers.h" +#include "mm-cbm.h" +#include "mm-modem.h" + +/** + * SECTION: mm-cbm + * @title: MMCbm + * @short_description: The CBM interface + * + * The #MMCbm is an object providing access to the methods, signals and + * properties of the CBM interface. + * + * When the CBM is exposed and available in the bus, it is ensured that at + * least this interface is also available. + */ + +G_DEFINE_TYPE (MMCbm, mm_cbm, MM_GDBUS_TYPE_CBM_PROXY) + +/*****************************************************************************/ + +/** + * mm_cbm_get_path: + * @self: A #MMCbm. + * + * Gets the DBus path of the #MMCbm object. + * + * Returns: (transfer none): The DBus path of the #MMCbm object. + * + * Since: 1.24 + */ +const gchar * +mm_cbm_get_path (MMCbm *self) +{ + g_return_val_if_fail (MM_IS_CBM (self), NULL); + + RETURN_NON_EMPTY_CONSTANT_STRING ( + g_dbus_proxy_get_object_path (G_DBUS_PROXY (self))); +} + +/** + * mm_cbm_dup_path: + * @self: A #MMCbm. + * + * Gets a copy of the DBus path of the #MMCbm object. + * + * Returns: (transfer full): The DBus path of the #MMCbm object. The returned + * value should be freed with g_free(). + * + * Since: 1.24 + */ +gchar * +mm_cbm_dup_path (MMCbm *self) +{ + gchar *value; + + g_return_val_if_fail (MM_IS_CBM (self), NULL); + + g_object_get (G_OBJECT (self), + "g-object-path", &value, + NULL); + + RETURN_NON_EMPTY_STRING (value); +} + +/*****************************************************************************/ + +/** + * mm_cbm_get_text: + * @self: A #MMCbm. + * + * Gets the message text, in UTF-8. + * + * <warning>The returned value is only valid until the property changes so it is + * only safe to use this function on the thread where @self was constructed. Use + * mm_cbm_dup_text() if on another thread.</warning> + * + * Returns: (transfer none): The message text, or %NULL if it doesn't contain + * any (e.g. contains data instead). + * + * Since: 1.24 + */ +const gchar * +mm_cbm_get_text (MMCbm *self) +{ + g_return_val_if_fail (MM_IS_CBM (self), NULL); + + RETURN_NON_EMPTY_CONSTANT_STRING ( + mm_gdbus_cbm_get_text (MM_GDBUS_CBM (self))); +} + +/** + * mm_cbm_dup_text: + * @self: A #MMCbm. + * + * Gets the message text, in UTF-8. + * + * Returns: (transfer full): The message text, or %NULL if it doesn't contain + * any (e.g. contains data instead). The returned value should be freed with + * g_free(). + * + * Since: 1.24 + */ +gchar * +mm_cbm_dup_text (MMCbm *self) +{ + g_return_val_if_fail (MM_IS_CBM (self), NULL); + + RETURN_NON_EMPTY_STRING ( + mm_gdbus_cbm_dup_text (MM_GDBUS_CBM (self))); +} + +/*****************************************************************************/ + +/** + * mm_cbm_get_state: + * @self: A #MMCbm. + * + * Gets the state of this CBM. + * + * Returns: A #MMCbmState specifying the state. + * + * Since: 1.24 + */ +MMCbmState +mm_cbm_get_state (MMCbm *self) +{ + g_return_val_if_fail (MM_IS_CBM (self), MM_CBM_STATE_UNKNOWN); + + return (MMCbmState)mm_gdbus_cbm_get_state (MM_GDBUS_CBM (self)); +} + +/*****************************************************************************/ + +/** + * mm_cbm_get_channel: + * @self: A #MMCbm. + * + * Gets the channel of this CBM. + * + * Returns: The channel + * + * Since: 1.24 + */ +guint +mm_cbm_get_channel (MMCbm *self) +{ + g_return_val_if_fail (MM_IS_CBM (self), 0); + + return mm_gdbus_cbm_get_channel (MM_GDBUS_CBM (self)); +} + +/*****************************************************************************/ + +/** + * mm_cbm_get_message_code: + * @self: A #MMCbm. + * + * Gets the message code of this CBM. + * + * Returns: The message code + * + * Since: 1.24 + */ +guint +mm_cbm_get_message_code (MMCbm *self) +{ + g_return_val_if_fail (MM_IS_CBM (self), 0); + + return mm_gdbus_cbm_get_message_code (MM_GDBUS_CBM (self)); +} + +/*****************************************************************************/ + +/** + * mm_cbm_get_update: + * @self: A #MMCbm. + * + * Gets the update number of this CBM. + * + * Returns: The update number + * + * Since: 1.24 + */ +guint +mm_cbm_get_update (MMCbm *self) +{ + g_return_val_if_fail (MM_IS_CBM (self), 0); + + return mm_gdbus_cbm_get_update (MM_GDBUS_CBM (self)); +} + +/*****************************************************************************/ + +static void +mm_cbm_init (MMCbm *self) +{ +} + +static void +mm_cbm_class_init (MMCbmClass *cbm_class) +{ +} |