diff options
Diffstat (limited to 'nexus/SupplicantEvent.cpp')
-rw-r--r-- | nexus/SupplicantEvent.cpp | 95 |
1 files changed, 95 insertions, 0 deletions
diff --git a/nexus/SupplicantEvent.cpp b/nexus/SupplicantEvent.cpp new file mode 100644 index 0000000..5c0944a --- /dev/null +++ b/nexus/SupplicantEvent.cpp @@ -0,0 +1,95 @@ +/* + * Copyright (C) 2008 The Android Open Source Project + * + * Licensed under the Apache License, Version 2.0 (the "License"); + * you may not use this file except in compliance with the License. + * You may obtain a copy of the License at + * + * http://www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an "AS IS" BASIS, + * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the License for the specific language governing permissions and + * limitations under the License. + */ +#include <stdlib.h> + +#define LOG_TAG "SupplicantEvent" +#include <cutils/log.h> + +#include "SupplicantEvent.h" + +#include "libwpa_client/wpa_ctrl.h" + +SupplicantEvent::SupplicantEvent(char *event, size_t len) { + + if (event[0] == '<') { + char *match = strchr(event, '>'); + if (match) { + char tmp[16]; + + strncpy(tmp, &event[1], (match - event)); + mLevel = atoi(tmp); + event += (match - event) + 1; + } else + LOGW("Unclosed level brace in event"); + } else + LOGW("No level specified in event"); + + /* + * <N>CTRL-EVENT-XXX + * ^ + * +---- event + */ + + if (!strncmp(event, WPA_EVENT_CONNECTED, strlen(WPA_EVENT_CONNECTED))) + mType = SupplicantEvent::EVENT_CONNECTED; + else if (!strncmp(event, WPA_EVENT_DISCONNECTED, strlen(WPA_EVENT_DISCONNECTED))) + mType = SupplicantEvent::EVENT_DISCONNECTED; + else if (!strncmp(event, WPA_EVENT_TERMINATING, strlen(WPA_EVENT_TERMINATING))) + mType = SupplicantEvent::EVENT_TERMINATING; + else if (!strncmp(event, WPA_EVENT_PASSWORD_CHANGED, strlen(WPA_EVENT_PASSWORD_CHANGED))) + mType = SupplicantEvent::EVENT_PASSWORD_CHANGED; + else if (!strncmp(event, WPA_EVENT_EAP_NOTIFICATION, strlen(WPA_EVENT_EAP_NOTIFICATION))) + mType = SupplicantEvent::EVENT_EAP_NOTIFICATION; + else if (!strncmp(event, WPA_EVENT_EAP_STARTED, strlen(WPA_EVENT_EAP_STARTED))) + mType = SupplicantEvent::EVENT_EAP_STARTED; + else if (!strncmp(event, WPA_EVENT_EAP_METHOD, strlen(WPA_EVENT_EAP_METHOD))) + mType = SupplicantEvent::EVENT_EAP_METHOD; + else if (!strncmp(event, WPA_EVENT_EAP_SUCCESS, strlen(WPA_EVENT_EAP_SUCCESS))) + mType = SupplicantEvent::EVENT_EAP_SUCCESS; + else if (!strncmp(event, WPA_EVENT_EAP_FAILURE, strlen(WPA_EVENT_EAP_FAILURE))) + mType = SupplicantEvent::EVENT_EAP_FAILURE; + else if (!strncmp(event, WPA_EVENT_SCAN_RESULTS, strlen(WPA_EVENT_SCAN_RESULTS))) + mType = SupplicantEvent::EVENT_SCAN_RESULTS; + else if (!strncmp(event, WPA_EVENT_STATE_CHANGE, strlen(WPA_EVENT_STATE_CHANGE))) + mType = SupplicantEvent::EVENT_STATE_CHANGE; + else if (!strncmp(event, WPA_EVENT_LINK_SPEED, strlen(WPA_EVENT_LINK_SPEED))) + mType = SupplicantEvent::EVENT_LINK_SPEED; + else if (!strncmp(event, WPA_EVENT_DRIVER_STATE, strlen(WPA_EVENT_DRIVER_STATE))) + mType = SupplicantEvent::EVENT_DRIVER_STATE; + else { + LOGW("Unknown supplicant event '%s'", event); + mType = SupplicantEvent::EVENT_UNKNOWN; + } + + for (event; *event != ' '; event++); + event++; + + /* + * <N>CTRL-EVENT-XXX YYYY + * ^ + * +---- event + */ + + for (event; *event == ' '; event++); + + mEvent = strdup(event); + mLen = len; +} + +SupplicantEvent::~SupplicantEvent() { + if (mEvent) + free(mEvent); +} |