diff options
author | Aleksander Morgado <aleksander@aleksander.es> | 2021-10-21 11:05:51 +0200 |
---|---|---|
committer | Aleksander Morgado <aleksander@aleksander.es> | 2021-11-02 09:50:17 +0000 |
commit | 3ab765f11c074846cdd7fc81db3f1056ae18f388 (patch) | |
tree | 73ee72de58f8bd8c7eaa362fae07956d8e05734c | |
parent | 49a295474936d7a5523ed7e34397dcd1c97f1c98 (diff) |
api,3gpp: new 'SetPacketServiceState()' method
-rw-r--r-- | cli/mmcli-modem-3gpp.c | 86 | ||||
-rw-r--r-- | docs/reference/libmm-glib/libmm-glib-sections.txt | 7 | ||||
-rw-r--r-- | introspection/org.freedesktop.ModemManager1.Modem.Modem3gpp.xml | 12 | ||||
-rw-r--r-- | libmm-glib/mm-common-helpers.c | 10 | ||||
-rw-r--r-- | libmm-glib/mm-common-helpers.h | 2 | ||||
-rw-r--r-- | libmm-glib/mm-modem-3gpp.c | 87 | ||||
-rw-r--r-- | libmm-glib/mm-modem-3gpp.h | 13 |
7 files changed, 216 insertions, 1 deletions
diff --git a/cli/mmcli-modem-3gpp.c b/cli/mmcli-modem-3gpp.c index f35f1f19..58bdcc83 100644 --- a/cli/mmcli-modem-3gpp.c +++ b/cli/mmcli-modem-3gpp.c @@ -52,6 +52,7 @@ static gchar *register_in_operator_str; static gchar *set_eps_ue_mode_operation_str; static gchar *set_initial_eps_bearer_settings_str; static gchar *disable_facility_lock_str; +static gchar *set_packet_service_state_str; static GOptionEntry entries[] = { { "3gpp-scan", 0, 0, G_OPTION_ARG_NONE, &scan_flag, @@ -78,6 +79,10 @@ static GOptionEntry entries[] = { "Disable facility personalization", "[facility,key]" }, + { "3gpp-set-packet-service-state", 0, 0, G_OPTION_ARG_STRING, &set_packet_service_state_str, + "Set packet service state", + "[attached|detached]" + }, { NULL } }; @@ -110,7 +115,8 @@ mmcli_modem_3gpp_options_enabled (void) !!register_in_operator_str + !!set_eps_ue_mode_operation_str + !!set_initial_eps_bearer_settings_str + - !!disable_facility_lock_str); + !!disable_facility_lock_str + + !!set_packet_service_state_str); if (n_actions > 1) { g_printerr ("error: too many 3GPP actions requested\n"); @@ -341,6 +347,47 @@ disable_facility_lock_ready (MMModem3gpp *modem_3gpp, } static void +set_packet_service_state_process_reply (gboolean result, + const GError *error) +{ + if (!result) { + g_printerr ("error: couldn't set packet service state: '%s'\n", + error ? error->message : "unknown error"); + exit (EXIT_FAILURE); + } + + g_print ("successfully set packet service state\n"); +} + +static void +set_packet_service_state_ready (MMModem3gpp *modem_3gpp, + GAsyncResult *result, + gpointer nothing) +{ + gboolean operation_result; + GError *error = NULL; + + operation_result = mm_modem_3gpp_set_packet_service_state_finish (modem_3gpp, result, &error); + set_packet_service_state_process_reply (operation_result, error); + + mmcli_async_operation_done (); +} + +static gboolean +set_packet_service_state_parse_input (const gchar *str, + MMModem3gppPacketServiceState *out_state) +{ + MMModem3gppPacketServiceState state; + + state = mm_common_get_3gpp_packet_service_state_from_string (str, NULL); + if (state == MM_MODEM_3GPP_PACKET_SERVICE_STATE_UNKNOWN) + return FALSE; + + *out_state = state; + return TRUE; +} + +static void get_modem_ready (GObject *source, GAsyncResult *result) { @@ -435,6 +482,24 @@ get_modem_ready (GObject *source, } + /* Request to set packet service state */ + if (set_packet_service_state_str) { + MMModem3gppPacketServiceState state; + + if (!set_packet_service_state_parse_input (set_packet_service_state_str, &state)) { + g_printerr ("Error parsing packet service state string.\n"); + exit (EXIT_FAILURE); + } + + g_debug ("Asynchronously setting packet service state..."); + mm_modem_3gpp_set_packet_service_state (ctx->modem_3gpp, + state, + ctx->cancellable, + (GAsyncReadyCallback)set_packet_service_state_ready, + NULL); + return; + } + g_warn_if_reached (); } @@ -552,5 +617,24 @@ mmcli_modem_3gpp_run_synchronous (GDBusConnection *connection) return; } + /* Request to set packet service state */ + if (set_packet_service_state_str) { + gboolean result; + MMModem3gppPacketServiceState state; + + if (!set_packet_service_state_parse_input (set_packet_service_state_str, &state)) { + g_printerr ("Error parsing packet service state string.\n"); + exit (EXIT_FAILURE); + } + + g_debug ("Asynchronously setting packet service state..."); + result = mm_modem_3gpp_set_packet_service_state_sync (ctx->modem_3gpp, + state, + NULL, + &error); + set_packet_service_state_process_reply (result, error); + return; + } + g_warn_if_reached (); } diff --git a/docs/reference/libmm-glib/libmm-glib-sections.txt b/docs/reference/libmm-glib/libmm-glib-sections.txt index aaef50b4..f3450893 100644 --- a/docs/reference/libmm-glib/libmm-glib-sections.txt +++ b/docs/reference/libmm-glib/libmm-glib-sections.txt @@ -324,6 +324,9 @@ mm_modem_3gpp_set_initial_eps_bearer_settings_sync mm_modem_3gpp_disable_facility_lock mm_modem_3gpp_disable_facility_lock_finish mm_modem_3gpp_disable_facility_lock_sync +mm_modem_3gpp_set_packet_service_state +mm_modem_3gpp_set_packet_service_state_finish +mm_modem_3gpp_set_packet_service_state_sync <SUBSECTION Standard> MMModem3gppClass MMModem3gppPrivate @@ -2134,12 +2137,16 @@ mm_gdbus_modem3gpp_call_set_initial_eps_bearer_settings_sync mm_gdbus_modem3gpp_call_disable_facility_lock mm_gdbus_modem3gpp_call_disable_facility_lock_finish mm_gdbus_modem3gpp_call_disable_facility_lock_sync +mm_gdbus_modem3gpp_call_set_packet_service_state +mm_gdbus_modem3gpp_call_set_packet_service_state_finish +mm_gdbus_modem3gpp_call_set_packet_service_state_sync <SUBSECTION Private> mm_gdbus_modem3gpp_complete_register mm_gdbus_modem3gpp_complete_scan mm_gdbus_modem3gpp_complete_set_eps_ue_mode_operation mm_gdbus_modem3gpp_complete_set_initial_eps_bearer_settings mm_gdbus_modem3gpp_complete_disable_facility_lock +mm_gdbus_modem3gpp_complete_set_packet_service_state mm_gdbus_modem3gpp_interface_info mm_gdbus_modem3gpp_override_properties mm_gdbus_modem3gpp_set_enabled_facility_locks diff --git a/introspection/org.freedesktop.ModemManager1.Modem.Modem3gpp.xml b/introspection/org.freedesktop.ModemManager1.Modem.Modem3gpp.xml index 05e3c655..0b494010 100644 --- a/introspection/org.freedesktop.ModemManager1.Modem.Modem3gpp.xml +++ b/introspection/org.freedesktop.ModemManager1.Modem.Modem3gpp.xml @@ -214,6 +214,18 @@ </method> <!-- + SetPacketServiceState: + @state: a <link linkend="MMModem3gppPacketServiceState">MMModem3gppPacketServiceState</link>. + + Explicitly attach or detach packet service on the current registered network. + + Since: 1.20 + --> + <method name="SetPacketServiceState"> + <arg name="state" type="u" direction="in" /> + </method> + + <!-- SubscriptionState: A <link linkend="MMModem3gppSubscriptionState">MMModem3gppSubscriptionState</link> diff --git a/libmm-glib/mm-common-helpers.c b/libmm-glib/mm-common-helpers.c index a240eed2..fbb43040 100644 --- a/libmm-glib/mm-common-helpers.c +++ b/libmm-glib/mm-common-helpers.c @@ -669,6 +669,16 @@ mm_common_get_3gpp_facility_from_string (const gchar *str, error); } +MMModem3gppPacketServiceState +mm_common_get_3gpp_packet_service_state_from_string (const gchar *str, + GError **error) +{ + return _enum_from_string (MM_TYPE_MODEM_3GPP_PACKET_SERVICE_STATE, + str, + MM_MODEM_3GPP_PACKET_SERVICE_STATE_UNKNOWN, + error); +} + /******************************************************************************/ /* MMModemPortInfo array management */ diff --git a/libmm-glib/mm-common-helpers.h b/libmm-glib/mm-common-helpers.h index a081a0dd..7ad8c6ad 100644 --- a/libmm-glib/mm-common-helpers.h +++ b/libmm-glib/mm-common-helpers.h @@ -85,6 +85,8 @@ MMBearerApnType mm_common_get_apn_type_from_string GError **error); MMModem3gppFacility mm_common_get_3gpp_facility_from_string (const gchar *str, GError **error); +MMModem3gppPacketServiceState mm_common_get_3gpp_packet_service_state_from_string (const gchar *str, + GError **error); /******************************************************************************/ diff --git a/libmm-glib/mm-modem-3gpp.c b/libmm-glib/mm-modem-3gpp.c index 076e5426..04ddf06a 100644 --- a/libmm-glib/mm-modem-3gpp.c +++ b/libmm-glib/mm-modem-3gpp.c @@ -1281,6 +1281,93 @@ mm_modem_3gpp_disable_facility_lock_sync (MMModem3gpp *self, /*****************************************************************************/ +/** + * mm_modem_3gpp_set_packet_service_state_finish: + * @self: A #MMModem3gpp. + * @res: The #GAsyncResult obtained from the #GAsyncReadyCallback passed to + * mm_modem_3gpp_set_packet_service_state(). + * @error: Return location for error or %NULL. + * + * Finishes an operation started with mm_modem_3gpp_set_packet_service_state(). + * + * Returns: %TRUE if the operation was successful, %FALSE if @error is set. + * + * Since: 1.20 + */ +gboolean +mm_modem_3gpp_set_packet_service_state_finish (MMModem3gpp *self, + GAsyncResult *res, + GError **error) +{ + g_return_val_if_fail (MM_IS_MODEM_3GPP (self), FALSE); + + return mm_gdbus_modem3gpp_call_set_packet_service_state_finish (MM_GDBUS_MODEM3GPP (self), res, error); +} + +/** + * mm_modem_3gpp_set_packet_service_state: + * @self: A #MMModem3gpp. + * @state: A #MMModem3gppPacketServiceState. + * @cancellable: (allow-none): A #GCancellable or %NULL. + * @callback: A #GAsyncReadyCallback to call when the request is satisfied or + * %NULL. + * @user_data: User data to pass to @callback. + * + * Asynchronously tries to attach or detach from the packet domain service. + * + * + * When the operation is finished, @callback will be invoked in the + * <link linkend="g-main-context-push-thread-default">thread-default main loop</link> + * of the thread you are calling this method from. You can then call + * mm_modem_3gpp_set_packet_service_state_finish() to get the result of the operation. + * + * See mm_modem_3gpp_set_packet_service_state_sync() for the synchronous, + * blocking version of this method. + * + * Since: 1.20 + */ +void +mm_modem_3gpp_set_packet_service_state (MMModem3gpp *self, + MMModem3gppPacketServiceState state, + GCancellable *cancellable, + GAsyncReadyCallback callback, + gpointer user_data) +{ + g_return_if_fail (MM_IS_MODEM_3GPP (self)); + + mm_gdbus_modem3gpp_call_set_packet_service_state (MM_GDBUS_MODEM3GPP (self), state, cancellable, callback, user_data); +} + +/** + * mm_modem_3gpp_set_packet_service_state_sync: + * @self: A #MMModem3gpp. + * @state: A #MMModem3gppPacketServiceState. + * @cancellable: (allow-none): A #GCancellable or %NULL. + * @error: Return location for error or %NULL. + * + * Synchronously tries to attach or detach from the packet domain service. + * + * The calling thread is blocked until a reply is received. See + * mm_modem_3gpp_set_packet_service_state() for the asynchronous version of + * this method. + * + * Returns: %TRUE if the operation was successful, %FALSE if @error is set. + * + * Since: 1.20 + */ +gboolean +mm_modem_3gpp_set_packet_service_state_sync (MMModem3gpp *self, + MMModem3gppPacketServiceState state, + GCancellable *cancellable, + GError **error) +{ + g_return_val_if_fail (MM_IS_MODEM_3GPP (self), FALSE); + + return mm_gdbus_modem3gpp_call_set_packet_service_state_sync (MM_GDBUS_MODEM3GPP (self), state, cancellable, error); +} + +/*****************************************************************************/ + static void mm_modem_3gpp_init (MMModem3gpp *self) { diff --git a/libmm-glib/mm-modem-3gpp.h b/libmm-glib/mm-modem-3gpp.h index de7ec27d..6bea3c1d 100644 --- a/libmm-glib/mm-modem-3gpp.h +++ b/libmm-glib/mm-modem-3gpp.h @@ -189,6 +189,19 @@ gboolean mm_modem_3gpp_disable_facility_lock_sync (MMModem3gpp *self, GCancellable *cancellable, GError **error); +void mm_modem_3gpp_set_packet_service_state (MMModem3gpp *self, + MMModem3gppPacketServiceState state, + GCancellable *cancellable, + GAsyncReadyCallback callback, + gpointer user_data); +gboolean mm_modem_3gpp_set_packet_service_state_finish (MMModem3gpp *self, + GAsyncResult *res, + GError **error); +gboolean mm_modem_3gpp_set_packet_service_state_sync (MMModem3gpp *self, + MMModem3gppPacketServiceState state, + GCancellable *cancellable, + GError **error); + G_END_DECLS #endif /* _MM_MODEM_3GPP_H_ */ |