Fix encoding phone number on sending sms
[project/uqmi.git] / commands-dms.c
index 563321e..a677052 100644 (file)
@@ -1,5 +1,12 @@
 #include "qmi-message.h"
 
+static struct {
+       QmiDmsUimPinId pin_id;
+       char* pin;
+       char* new_pin;
+       char* puk;
+} dms_req_data;
+
 static const char *get_pin_status(int status)
 {
        static const char *pin_status[] = {
@@ -75,17 +82,101 @@ cmd_dms_verify_pin2_prepare(struct qmi_dev *qmi, struct qmi_request *req, struct
        return QMI_CMD_REQUEST;
 }
 
-static struct qmi_dms_uim_unblock_pin_request dms_unlock_pin_req = {
-       QMI_INIT_SEQUENCE(info,
-                       .pin_id = QMI_DMS_UIM_PIN_ID_PIN
-               )
+#define cmd_dms_set_pin_cb no_cb
+static enum qmi_cmd_result
+cmd_dms_set_pin_prepare(struct qmi_dev *qmi, struct qmi_request *req, struct qmi_msg *msg, char *arg)
+{
+       dms_req_data.pin = arg;
+       return QMI_CMD_DONE;
+}
+
+static enum qmi_cmd_result
+cmd_dms_set_pin_protection_prepare(struct qmi_msg *msg, char *arg)
+{
+       if (!dms_req_data.pin) {
+               uqmi_add_error("Missing argument");
+               return QMI_CMD_EXIT;
+       }
+
+       int is_enabled;
+       if (strcasecmp(arg, "disabled") == 0)
+               is_enabled = false;
+       else if (strcasecmp(arg, "enabled") == 0)
+               is_enabled = true;
+       else {
+               uqmi_add_error("Invalid value (valid: disabled, enabled)");
+               return QMI_CMD_EXIT;
+       }
+
+       struct qmi_dms_uim_set_pin_protection_request dms_pin_protection_req = {
+               QMI_INIT_SEQUENCE(info,
+                       .pin_id = dms_req_data.pin_id
+               ),
+               QMI_INIT_PTR(info.pin, dms_req_data.pin),
+               QMI_INIT_PTR(info.protection_enabled, is_enabled)
+       };
+
+       qmi_set_dms_uim_set_pin_protection_request(msg, &dms_pin_protection_req);
+       return QMI_CMD_REQUEST;
+}
+
+#define cmd_dms_set_pin1_protection_cb no_cb
+static enum qmi_cmd_result
+cmd_dms_set_pin1_protection_prepare(struct qmi_dev *qmi, struct qmi_request *req, struct qmi_msg *msg, char *arg)
+{
+       dms_req_data.pin_id = QMI_DMS_UIM_PIN_ID_PIN;
+       return cmd_dms_set_pin_protection_prepare(msg, arg);
+}
+
+#define cmd_dms_set_pin2_protection_cb no_cb
+static enum qmi_cmd_result
+cmd_dms_set_pin2_protection_prepare(struct qmi_dev *qmi, struct qmi_request *req, struct qmi_msg *msg, char *arg)
+{
+       dms_req_data.pin_id = QMI_DMS_UIM_PIN_ID_PIN2;
+       return cmd_dms_set_pin_protection_prepare(msg, arg);
+}
+
+static enum qmi_cmd_result
+cmd_dms_change_pin_prepare(struct qmi_msg *msg, char *arg)
+{
+       if (!dms_req_data.pin || !dms_req_data.new_pin) {
+               uqmi_add_error("Missing argument");
+               return QMI_CMD_EXIT;
+       }
+
+       struct qmi_dms_uim_change_pin_request dms_change_pin_req = {
+               QMI_INIT_SEQUENCE(info,
+                       .pin_id = dms_req_data.pin_id
+               ),
+               QMI_INIT_PTR(info.old_pin, dms_req_data.pin),
+               QMI_INIT_PTR(info.new_pin, dms_req_data.new_pin)
        };
 
+       qmi_set_dms_uim_change_pin_request(msg, &dms_change_pin_req);
+       return QMI_CMD_REQUEST;
+}
+
+#define cmd_dms_change_pin1_cb no_cb
+static enum qmi_cmd_result
+cmd_dms_change_pin1_prepare(struct qmi_dev *qmi, struct qmi_request *req, struct qmi_msg *msg, char *arg)
+{
+       dms_req_data.pin_id = QMI_DMS_UIM_PIN_ID_PIN;
+       return cmd_dms_change_pin_prepare(msg, arg);
+}
+
+#define cmd_dms_change_pin2_cb no_cb
+static enum qmi_cmd_result
+cmd_dms_change_pin2_prepare(struct qmi_dev *qmi, struct qmi_request *req, struct qmi_msg *msg, char *arg)
+{
+       dms_req_data.pin_id = QMI_DMS_UIM_PIN_ID_PIN2;
+       return cmd_dms_change_pin_prepare(msg, arg);
+}
+
 #define cmd_dms_set_new_pin_cb no_cb
 static enum qmi_cmd_result
 cmd_dms_set_new_pin_prepare(struct qmi_dev *qmi, struct qmi_request *req, struct qmi_msg *msg, char *arg)
 {
-       qmi_set_ptr(&dms_unlock_pin_req, info.new_pin, arg);
+       dms_req_data.new_pin = arg;
        return QMI_CMD_DONE;
 }
 
@@ -93,7 +184,7 @@ cmd_dms_set_new_pin_prepare(struct qmi_dev *qmi, struct qmi_request *req, struct
 static enum qmi_cmd_result
 cmd_dms_set_puk_prepare(struct qmi_dev *qmi, struct qmi_request *req, struct qmi_msg *msg, char *arg)
 {
-       qmi_set_ptr(&dms_unlock_pin_req, info.puk, arg);
+       dms_req_data.puk = arg;
        return QMI_CMD_DONE;
 }
 
@@ -101,13 +192,19 @@ cmd_dms_set_puk_prepare(struct qmi_dev *qmi, struct qmi_request *req, struct qmi
 static enum qmi_cmd_result
 cmd_dms_unblock_pin1_prepare(struct qmi_dev *qmi, struct qmi_request *req, struct qmi_msg *msg, char *arg)
 {
-       qmi_set_ptr(&dms_unlock_pin_req, info.pin_id, QMI_DMS_UIM_PIN_ID_PIN);
-
-       if (!dms_unlock_pin_req.data.info.puk || !dms_unlock_pin_req.data.info.new_pin) {
+       if (!dms_req_data.puk || !dms_req_data.new_pin) {
                uqmi_add_error("Missing argument");
                return QMI_CMD_EXIT;
        }
 
+       struct qmi_dms_uim_unblock_pin_request dms_unlock_pin_req = {
+               QMI_INIT_SEQUENCE(info,
+                               .pin_id = QMI_DMS_UIM_PIN_ID_PIN
+                       ),
+               QMI_INIT_PTR(info.puk, dms_req_data.puk),
+               QMI_INIT_PTR(info.new_pin, dms_req_data.new_pin)
+               };
+
        qmi_set_dms_uim_unblock_pin_request(msg, &dms_unlock_pin_req);
        return QMI_CMD_REQUEST;
 }
@@ -116,13 +213,19 @@ cmd_dms_unblock_pin1_prepare(struct qmi_dev *qmi, struct qmi_request *req, struc
 static enum qmi_cmd_result
 cmd_dms_unblock_pin2_prepare(struct qmi_dev *qmi, struct qmi_request *req, struct qmi_msg *msg, char *arg)
 {
-       qmi_set_ptr(&dms_unlock_pin_req, info.pin_id, QMI_DMS_UIM_PIN_ID_PIN2);
-
-       if (!dms_unlock_pin_req.data.info.puk || !dms_unlock_pin_req.data.info.new_pin) {
+       if (!dms_req_data.puk || !dms_req_data.new_pin) {
                uqmi_add_error("Missing argument");
                return QMI_CMD_EXIT;
        }
 
+       struct qmi_dms_uim_unblock_pin_request dms_unlock_pin_req = {
+               QMI_INIT_SEQUENCE(info,
+                       .pin_id = QMI_DMS_UIM_PIN_ID_PIN2
+               ),
+               QMI_INIT_PTR(info.puk, dms_req_data.puk),
+               QMI_INIT_PTR(info.new_pin, dms_req_data.new_pin)
+       };
+
        qmi_set_dms_uim_unblock_pin_request(msg, &dms_unlock_pin_req);
        return QMI_CMD_REQUEST;
 }
@@ -159,6 +262,22 @@ cmd_dms_get_imsi_prepare(struct qmi_dev *qmi, struct qmi_request *req, struct qm
        return QMI_CMD_REQUEST;
 }
 
+static void cmd_dms_get_msisdn_cb(struct qmi_dev *qmi, struct qmi_request *req, struct qmi_msg *msg)
+{
+       struct qmi_dms_get_msisdn_response res;
+
+       qmi_parse_dms_get_msisdn_response(msg, &res);
+       if (res.data.msisdn)
+               blobmsg_add_string(&status, NULL, res.data.msisdn);
+}
+
+static enum qmi_cmd_result
+cmd_dms_get_msisdn_prepare(struct qmi_dev *qmi, struct qmi_request *req, struct qmi_msg *msg, char *arg)
+{
+       qmi_set_dms_get_msisdn_request(msg);
+       return QMI_CMD_REQUEST;
+}
+
 #define cmd_dms_reset_cb no_cb
 static enum qmi_cmd_result
 cmd_dms_reset_prepare(struct qmi_dev *qmi, struct qmi_request *req, struct qmi_msg *msg, char *arg)