Add --stop-network
[project/uqmi.git] / commands-wds.c
index 2128bbf..ce7d715 100644 (file)
@@ -1,9 +1,12 @@
+#include <stdlib.h>
+
 #include "qmi-message.h"
 
 static struct qmi_wds_start_network_request wds_sn_req = {
        QMI_INIT(authentication_preference,
                 QMI_WDS_AUTHENTICATION_PAP | QMI_WDS_AUTHENTICATION_CHAP),
 };
+static struct qmi_wds_stop_network_request wds_stn_req;
 
 #define cmd_wds_set_auth_cb no_cb
 static enum qmi_cmd_result
@@ -48,6 +51,15 @@ cmd_wds_set_password_prepare(struct qmi_dev *qmi, struct qmi_request *req, struc
        return QMI_CMD_DONE;
 }
 
+#define cmd_wds_set_autoconnect_cb no_cb
+static enum qmi_cmd_result
+cmd_wds_set_autoconnect_prepare(struct qmi_dev *qmi, struct qmi_request *req, struct qmi_msg *msg, char *arg)
+{
+       qmi_set(&wds_sn_req, enable_autoconnect, true);
+       qmi_set(&wds_stn_req, disable_autoconnect, true);
+       return QMI_CMD_DONE;
+}
+
 static void
 cmd_wds_start_network_cb(struct qmi_dev *qmi, struct qmi_request *req, struct qmi_msg *msg)
 {
@@ -65,3 +77,51 @@ cmd_wds_start_network_prepare(struct qmi_dev *qmi, struct qmi_request *req, stru
        qmi_set_wds_start_network_request(msg, &wds_sn_req);
        return QMI_CMD_REQUEST;
 }
+
+#define cmd_wds_stop_network_cb no_cb
+static enum qmi_cmd_result
+cmd_wds_stop_network_prepare(struct qmi_dev *qmi, struct qmi_request *req, struct qmi_msg *msg, char *arg)
+{
+       uint32_t pdh = strtoul(arg, NULL, 0);
+
+       qmi_set(&wds_stn_req, packet_data_handle, pdh);
+       qmi_set_wds_stop_network_request(msg, &wds_stn_req);
+       return QMI_CMD_REQUEST;
+}
+
+static void
+cmd_wds_get_packet_service_status_cb(struct qmi_dev *qmi, struct qmi_request *req, struct qmi_msg *msg)
+{
+       struct qmi_wds_get_packet_service_status_response res;
+       const char *data_status[] = {
+               [QMI_WDS_CONNECTION_STATUS_UNKNOWN] = "unknown",
+               [QMI_WDS_CONNECTION_STATUS_DISCONNECTED] = "disconnected",
+               [QMI_WDS_CONNECTION_STATUS_CONNECTED] = "connected",
+               [QMI_WDS_CONNECTION_STATUS_SUSPENDED] = "suspended",
+               [QMI_WDS_CONNECTION_STATUS_AUTHENTICATING] = "authenticating",
+       };
+       int s = 0;
+
+       qmi_parse_wds_get_packet_service_status_response(msg, &res);
+       if (res.set.connection_status &&
+           res.data.connection_status >= 0 &&
+           res.data.connection_status < ARRAY_SIZE(data_status))
+               s = res.data.connection_status;
+
+       blobmsg_add_string(&status, NULL, data_status[s]);
+}
+
+static enum qmi_cmd_result
+cmd_wds_get_packet_service_status_prepare(struct qmi_dev *qmi, struct qmi_request *req, struct qmi_msg *msg, char *arg)
+{
+       qmi_set_wds_get_packet_service_status_request(msg);
+       return QMI_CMD_REQUEST;
+}
+
+#define cmd_wds_reset_cb no_cb
+static enum qmi_cmd_result
+cmd_wds_reset_prepare(struct qmi_dev *qmi, struct qmi_request *req, struct qmi_msg *msg, char *arg)
+{
+       qmi_set_wds_reset_request(msg);
+       return QMI_CMD_REQUEST;
+}