summaryrefslogtreecommitdiffstats
path: root/src/stkutil.c
diff options
context:
space:
mode:
authorDenis Kenzior <denkenz@gmail.com>2010-03-15 21:01:04 -0500
committerDenis Kenzior <denkenz@gmail.com>2010-03-15 21:02:06 -0500
commite64596f1dc21aa6f25a19c95b83dff8b3a832ac4 (patch)
treeb6fffe840d0b1805872935d36202e2c8b027967b /src/stkutil.c
parenta16f270eb1795cf1d96dc8b9f0d879861214eee8 (diff)
downloadofono-e64596f1dc21aa6f25a19c95b83dff8b3a832ac4.tar.bz2
Add parser for STK send sms proactive commands
Diffstat (limited to 'src/stkutil.c')
-rw-r--r--src/stkutil.c52
1 files changed, 52 insertions, 0 deletions
diff --git a/src/stkutil.c b/src/stkutil.c
index 29643cc2..787f7eb4 100644
--- a/src/stkutil.c
+++ b/src/stkutil.c
@@ -719,6 +719,55 @@ static gboolean parse_get_input(struct stk_command *command,
return TRUE;
}
+static void destroy_send_sms(struct stk_command *command)
+{
+ g_free(command->send_sms.alpha_id);
+ g_free(command->send_sms.address.number);
+}
+
+static gboolean parse_send_sms(struct stk_command *command,
+ struct comprehension_tlv_iter *iter)
+{
+ struct stk_command_send_sms *obj = &command->send_sms;
+ struct gsm_sms_tpdu tpdu;
+ gboolean ret;
+
+ obj->frame_id = 0xFF;
+
+ if (command->src != STK_DEVICE_IDENTITY_TYPE_UICC)
+ return FALSE;
+
+ if (command->dst != STK_DEVICE_IDENTITY_TYPE_NETWORK)
+ return FALSE;
+
+ ret = parse_dataobj(iter, STK_DATA_OBJECT_TYPE_ALPHA_ID, 0,
+ &obj->alpha_id,
+ STK_DATA_OBJECT_TYPE_ADDRESS, 0,
+ &obj->address,
+ STK_DATA_OBJECT_TYPE_GSM_SMS_TPDU, 0,
+ &tpdu,
+ STK_DATA_OBJECT_TYPE_ICON_ID, 0,
+ &obj->icon_id,
+ STK_DATA_OBJECT_TYPE_TEXT_ATTRIBUTE, 0,
+ &obj->text_attribute,
+ STK_DATA_OBJECT_TYPE_FRAME_ID, 0,
+ &obj->frame_id,
+ STK_DATA_OBJECT_TYPE_INVALID);
+
+ if (ret == FALSE)
+ return FALSE;
+
+ command->destructor = destroy_send_sms;
+
+ if (sms_decode(tpdu.tpdu, tpdu.len, TRUE, tpdu.len, &obj->gsm_sms)
+ == FALSE) {
+ command->destructor(command);
+ return FALSE;
+ }
+
+ return TRUE;
+}
+
struct stk_command *stk_command_new_from_pdu(const unsigned char *pdu,
unsigned int len)
{
@@ -789,6 +838,9 @@ struct stk_command *stk_command_new_from_pdu(const unsigned char *pdu,
case STK_COMMAND_TYPE_GET_INPUT:
ok = parse_get_input(command, &iter);
break;
+ case STK_COMMAND_TYPE_SEND_SMS:
+ ok = parse_send_sms(command, &iter);
+ break;
default:
ok = FALSE;
break;