Add parser for STK send sms proactive commands
authorDenis Kenzior <denkenz@gmail.com>
Tue, 16 Mar 2010 02:01:04 +0000 (21:01 -0500)
committerDenis Kenzior <denkenz@gmail.com>
Tue, 16 Mar 2010 02:02:06 +0000 (21:02 -0500)
src/stkutil.c
src/stkutil.h

index 29643cc..787f7eb 100644 (file)
@@ -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;
index 9c09b96..57ba928 100644 (file)
@@ -342,6 +342,15 @@ struct stk_command_get_input {
        unsigned char frame_id; /* Values 0x10 to 0xFF reserved */
 };
 
+struct stk_command_send_sms {
+       char *alpha_id;
+       struct stk_address address;
+       struct sms gsm_sms;
+       struct stk_icon_identifier icon_id;
+       struct stk_text_attribute text_attribute;
+       unsigned char frame_id; /* Values 0x10 to 0xFF reserved */
+};
+
 struct stk_command {
        unsigned char number;
        unsigned char type;
@@ -353,6 +362,7 @@ struct stk_command {
                struct stk_command_display_text display_text;
                struct stk_command_display_text get_inkey;
                struct stk_command_get_input get_input;
+               struct stk_command_send_sms send_sms;
        };
 
        void (*destructor)(struct stk_command *command);