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 }