use printf instead of fprintf for pin status verification, remove an unused variable
[project/uqmi.git] / commands-dms.c
1 #include "qmi-message.h"
2
3 static const char *get_pin_status(QmiDmsUimPinStatus status)
4 {
5         static const char *pin_status[] = {
6                 [QMI_DMS_UIM_PIN_STATUS_NOT_INITIALIZED] = "not_initialized",
7                 [QMI_DMS_UIM_PIN_STATUS_ENABLED_NOT_VERIFIED] = "not_verified",
8                 [QMI_DMS_UIM_PIN_STATUS_ENABLED_VERIFIED] = "verified",
9                 [QMI_DMS_UIM_PIN_STATUS_DISABLED] = "disabled",
10                 [QMI_DMS_UIM_PIN_STATUS_BLOCKED] = "blocked",
11                 [QMI_DMS_UIM_PIN_STATUS_PERMANENTLY_BLOCKED] = "permanently_blocked",
12                 [QMI_DMS_UIM_PIN_STATUS_UNBLOCKED] = "unblocked",
13                 [QMI_DMS_UIM_PIN_STATUS_CHANGED] = "changed",
14         };
15         const char *res = "Unknown";
16
17         if (status < ARRAY_SIZE(pin_status) && pin_status[status])
18                 res = pin_status[status];
19
20         return res;
21 }
22
23 static void cmd_dms_get_pin_status_cb(struct qmi_dev *qmi, struct qmi_request *req, struct qmi_msg *msg)
24 {
25         struct qmi_dms_uim_get_pin_status_response res;
26
27         qmi_parse_dms_uim_get_pin_status_response(msg, &res);
28         if (res.set.pin1_status) {
29                 printf("pin1_status=%s\n"
30                            "pin1_verify_tries=%d\n"
31                            "pin1_unblock_tries=%d\n",
32                            get_pin_status(res.data.pin1_status.current_status),
33                            res.data.pin1_status.verify_retries_left,
34                            res.data.pin1_status.unblock_retries_left);
35         }
36         if (res.set.pin2_status) {
37                 printf("pin2_status=%s\n"
38                            "pin2_verify_tries=%d\n"
39                            "pin2_unblock_tries=%d\n",
40                            get_pin_status(res.data.pin2_status.current_status),
41                            res.data.pin2_status.verify_retries_left,
42                            res.data.pin2_status.unblock_retries_left);
43         }
44 }
45
46 static enum qmi_cmd_result
47 cmd_dms_get_pin_status_prepare(struct qmi_dev *qmi, struct qmi_request *req, struct qmi_msg *msg, char *arg)
48 {
49         qmi_set_dms_uim_get_pin_status_request(msg);
50         return QMI_CMD_REQUEST;
51 }
52
53 static void cmd_dms_verify_pin1_cb(struct qmi_dev *qmi, struct qmi_request *req, struct qmi_msg *msg)
54 {
55         if (!msg) {
56                 printf("failed\n");
57                 return;
58         }
59
60         printf("ok\n");
61 }
62
63 static enum qmi_cmd_result
64 cmd_dms_verify_pin1_prepare(struct qmi_dev *qmi, struct qmi_request *req, struct qmi_msg *msg, char *arg)
65 {
66         struct qmi_dms_uim_verify_pin_request data = {
67                 QMI_INIT_SEQUENCE(info,
68                         .pin_id = QMI_DMS_UIM_PIN_ID_PIN,
69                         .pin = arg
70                 )
71         };
72         qmi_set_dms_uim_verify_pin_request(msg, &data);
73         return QMI_CMD_REQUEST;
74 }
75
76 #define cmd_dms_verify_pin2_cb cmd_dms_verify_pin1_cb
77 static enum qmi_cmd_result
78 cmd_dms_verify_pin2_prepare(struct qmi_dev *qmi, struct qmi_request *req, struct qmi_msg *msg, char *arg)
79 {
80         struct qmi_dms_uim_verify_pin_request data = {
81                 QMI_INIT_SEQUENCE(info,
82                         .pin_id = QMI_DMS_UIM_PIN_ID_PIN2,
83                         .pin = arg
84                 )
85         };
86         qmi_set_dms_uim_verify_pin_request(msg, &data);
87         return QMI_CMD_REQUEST;
88 }