2009-06-16 05:10:44 +08:00
|
|
|
/*
|
|
|
|
* 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>
|
|
|
|
#include <string.h>
|
|
|
|
|
2009-06-17 03:01:50 +08:00
|
|
|
#define LOG_TAG "SupplicantStatus"
|
2009-06-16 05:10:44 +08:00
|
|
|
#include <cutils/log.h>
|
|
|
|
|
|
|
|
#include "SupplicantStatus.h"
|
|
|
|
#include "SupplicantState.h"
|
|
|
|
|
|
|
|
SupplicantStatus::SupplicantStatus() {
|
|
|
|
mWpaState = SupplicantState::UNKNOWN;
|
|
|
|
mId = -1;
|
|
|
|
mBssid = NULL;
|
|
|
|
mSsid = NULL;
|
|
|
|
}
|
|
|
|
|
|
|
|
SupplicantStatus::SupplicantStatus(int state, int id, char *bssid, char *ssid) :
|
|
|
|
mWpaState(state), mId(id), mBssid(bssid), mSsid(ssid) {
|
|
|
|
|
|
|
|
LOGD("state %d, id %d, bssid %p, ssid %p\n", mWpaState, mId, mBssid, mSsid);
|
|
|
|
}
|
|
|
|
|
|
|
|
SupplicantStatus::~SupplicantStatus() {
|
|
|
|
if (mBssid)
|
|
|
|
free(mBssid);
|
|
|
|
if (mSsid)
|
|
|
|
free(mSsid);
|
|
|
|
}
|
|
|
|
|
|
|
|
SupplicantStatus *SupplicantStatus::createStatus(char *data, int len) {
|
|
|
|
char *bssid = NULL;
|
|
|
|
char *ssid = NULL;
|
|
|
|
int id = -1;
|
|
|
|
int state = SupplicantState::UNKNOWN;
|
|
|
|
|
|
|
|
char *next = data;
|
|
|
|
char *line;
|
|
|
|
while((line = strsep(&next, "\n"))) {
|
2009-06-17 03:01:50 +08:00
|
|
|
char *line_next = line;
|
|
|
|
char *token = strsep(&line_next, "=");
|
|
|
|
char *value = strsep(&line_next, "=");
|
2009-06-16 05:10:44 +08:00
|
|
|
if (!strcmp(token, "bssid"))
|
|
|
|
bssid = strdup(value);
|
|
|
|
else if (!strcmp(token, "ssid"))
|
|
|
|
ssid = strdup(value);
|
|
|
|
else if (!strcmp(token, "id"))
|
|
|
|
id = atoi(value);
|
2009-06-17 03:01:50 +08:00
|
|
|
else if (!strcmp(token, "wpa_state")) {
|
|
|
|
if (!strcmp(value, "DISCONNECTED"))
|
|
|
|
state = SupplicantState::DISCONNECTED;
|
|
|
|
else if (!strcmp(value, "INACTIVE"))
|
|
|
|
state = SupplicantState::INACTIVE;
|
|
|
|
else if (!strcmp(value, "SCANNING"))
|
|
|
|
state = SupplicantState::SCANNING;
|
|
|
|
else if (!strcmp(value, "ASSOCIATING"))
|
|
|
|
state = SupplicantState::ASSOCIATING;
|
|
|
|
else if (!strcmp(value, "ASSOCIATED"))
|
|
|
|
state = SupplicantState::ASSOCIATED;
|
|
|
|
else if (!strcmp(value, "FOURWAY_HANDSHAKE"))
|
|
|
|
state = SupplicantState::FOURWAY_HANDSHAKE;
|
|
|
|
else if (!strcmp(value, "GROUP_HANDSHAKE"))
|
|
|
|
state = SupplicantState::GROUP_HANDSHAKE;
|
|
|
|
else if (!strcmp(value, "COMPLETED"))
|
|
|
|
state = SupplicantState::COMPLETED;
|
|
|
|
else if (!strcmp(value, "IDLE"))
|
|
|
|
state = SupplicantState::IDLE;
|
|
|
|
else
|
|
|
|
LOGE("Unknown supplicant state '%s'", value);
|
|
|
|
} else
|
2009-06-16 05:10:44 +08:00
|
|
|
LOGD("Ignoring unsupported status token '%s'", token);
|
|
|
|
}
|
|
|
|
|
|
|
|
return new SupplicantStatus(state, id, bssid, ssid);
|
|
|
|
|
|
|
|
}
|