diff options
author | Tambet Ingo <tambet@gmail.com> | 2008-12-05 15:57:55 +0200 |
---|---|---|
committer | Tambet Ingo <tambet@gmail.com> | 2008-12-05 15:57:55 +0200 |
commit | a504fb408aa2ba3bb495a08d948ae97bdcb1cdd6 (patch) | |
tree | 1a0f1d466d234002d4047edafb008676e8a4bdfa /src | |
parent | 793044b577c18d3b9028276fdec629981c75f5ed (diff) | |
parent | 1673c6c998ccca73097c7d032b14ff15883d053b (diff) |
Merge branch 'master' of git://gitorious.org/modemmanager/asacs-mbm
Diffstat (limited to 'src')
-rw-r--r-- | src/mm-generic-gsm.c | 30 | ||||
-rw-r--r-- | src/mm-modem-gsm-card.c | 32 | ||||
-rw-r--r-- | src/mm-modem-gsm-card.h | 12 |
3 files changed, 74 insertions, 0 deletions
diff --git a/src/mm-generic-gsm.c b/src/mm-generic-gsm.c index e1769c8d..b08ad3bf 100644 --- a/src/mm-generic-gsm.c +++ b/src/mm-generic-gsm.c @@ -327,6 +327,35 @@ get_card_info (MMModemGsmCard *modem, } static void +send_puk_done (MMSerial *serial, + GString *response, + GError *error, + gpointer user_data) +{ + MMCallbackInfo *info = (MMCallbackInfo *) user_data; + + if (error) + info->error = g_error_copy (error); + mm_callback_info_schedule (info); +} + +static void +send_puk (MMModemGsmCard *modem, + const char *puk, + const char *pin, + MMModemFn callback, + gpointer user_data) +{ + MMCallbackInfo *info; + char *command; + + info = mm_callback_info_new (MM_MODEM (modem), callback, user_data); + command = g_strdup_printf ("+CPIN=\"%s\",\"%s\"", puk, pin); + mm_serial_queue_command (MM_SERIAL (modem), command, 3, send_puk_done, info); + g_free (command); +} + +static void send_pin_done (MMSerial *serial, GString *response, GError *error, @@ -1104,6 +1133,7 @@ modem_gsm_card_init (MMModemGsmCard *class) class->get_imsi = get_imsi; class->get_info = get_card_info; class->send_pin = send_pin; + class->send_puk = send_puk; class->enable_pin = enable_pin; class->change_pin = change_pin; } diff --git a/src/mm-modem-gsm-card.c b/src/mm-modem-gsm-card.c index 1095d968..18f4aba0 100644 --- a/src/mm-modem-gsm-card.c +++ b/src/mm-modem-gsm-card.c @@ -19,6 +19,11 @@ static void impl_gsm_modem_send_pin (MMModemGsmCard *modem, const char *pin, DBusGMethodInvocation *context); +static void impl_gsm_modem_send_puk (MMModemGsmCard *modem, + const char *puk, + const char *pin, + DBusGMethodInvocation *context); + static void impl_gsm_modem_enable_pin (MMModemGsmCard *modem, const char *pin, gboolean enabled, @@ -183,6 +188,24 @@ mm_modem_gsm_card_get_info (MMModemGsmCard *self, } void +mm_modem_gsm_card_send_puk (MMModemGsmCard *self, + const char *puk, + const char *pin, + MMModemFn callback, + gpointer user_data) +{ + g_return_if_fail (MM_IS_MODEM_GSM_CARD (self)); + g_return_if_fail (puk != NULL); + g_return_if_fail (pin != NULL); + g_return_if_fail (callback != NULL); + + if (MM_MODEM_GSM_CARD_GET_INTERFACE (self)->send_puk) + MM_MODEM_GSM_CARD_GET_INTERFACE (self)->send_puk (self, puk, pin, callback, user_data); + else + async_call_not_supported (self, callback, user_data); +} + +void mm_modem_gsm_card_send_pin (MMModemGsmCard *self, const char *pin, MMModemFn callback, @@ -257,6 +280,15 @@ impl_gsm_modem_get_info (MMModemGsmCard *modem, } static void + impl_gsm_modem_send_puk (MMModemGsmCard *modem, + const char *puk, + const char *pin, + DBusGMethodInvocation *context) +{ + mm_modem_gsm_card_send_puk (modem, puk, pin, async_call_done, context); +} + +static void impl_gsm_modem_send_pin (MMModemGsmCard *modem, const char *pin, DBusGMethodInvocation *context) diff --git a/src/mm-modem-gsm-card.h b/src/mm-modem-gsm-card.h index f795e833..50323810 100644 --- a/src/mm-modem-gsm-card.h +++ b/src/mm-modem-gsm-card.h @@ -35,6 +35,12 @@ struct _MMModemGsmCard { MMModemGsmCardInfoFn callback, gpointer user_data); + void (*send_puk) (MMModemGsmCard *self, + const char *puk, + const char *pin, + MMModemFn callback, + gpointer user_data); + void (*send_pin) (MMModemGsmCard *self, const char *pin, MMModemFn callback, @@ -67,6 +73,12 @@ void mm_modem_gsm_card_get_info (MMModemGsmCard *self, MMModemGsmCardInfoFn callback, gpointer user_data); +void mm_modem_gsm_card_send_puk (MMModemGsmCard *self, + const char *puk, + const char *pin, + MMModemFn callback, + gpointer user_data); + void mm_modem_gsm_card_send_pin (MMModemGsmCard *self, const char *pin, MMModemFn callback, |