blob: 0c064884c148c9a2c2784447e4f052ed99834804 [file] [log] [blame]
/*
* Copyright (C) 2017 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.
*/
package com.android.server.wifi;
import com.android.server.wifi.util.XmlUtil;
import org.xmlpull.v1.XmlPullParser;
import org.xmlpull.v1.XmlPullParserException;
import org.xmlpull.v1.XmlSerializer;
import java.io.IOException;
import java.util.HashMap;
import java.util.Map;
import java.util.Set;
/**
* This class performs serialization and parsing of XML data block that contain the list of
* deleted ephemeral SSIDs (XML block data inside <DeletedEphemeralSSIDList> tag).
*/
public class DeletedEphemeralSsidsStoreData implements WifiConfigStore.StoreData {
private static final String XML_TAG_SECTION_HEADER_DELETED_EPHEMERAL_SSID_LIST =
"DeletedEphemeralSSIDList";
private static final String XML_TAG_SSID_LIST = "SSIDList";
private final Clock mClock;
private Map<String, Long> mSsidToTimeMap;
DeletedEphemeralSsidsStoreData(Clock clock) {
mClock = clock;
}
@Override
public void serializeData(XmlSerializer out)
throws XmlPullParserException, IOException {
if (mSsidToTimeMap != null) {
XmlUtil.writeNextValue(out, XML_TAG_SSID_LIST, mSsidToTimeMap);
}
}
@Override
public void deserializeData(XmlPullParser in, int outerTagDepth)
throws XmlPullParserException, IOException {
// Ignore empty reads.
if (in == null) {
return;
}
while (!XmlUtil.isNextSectionEnd(in, outerTagDepth)) {
String[] valueName = new String[1];
Object value = XmlUtil.readCurrentValue(in, valueName);
if (valueName[0] == null) {
throw new XmlPullParserException("Missing value name");
}
switch (valueName[0]) {
case XML_TAG_SSID_LIST:
// Backwards compatibility, this used to be a set.
if (value instanceof Set) {
mSsidToTimeMap = new HashMap<>();
for (String ssid : (Set<String>) value) {
// Mark the deleted time as bootup time for existing entries from
// previous releases.
mSsidToTimeMap.put(ssid, mClock.getWallClockMillis());
}
} else if (value instanceof Map) {
mSsidToTimeMap = (Map<String, Long>) value;
}
break;
default:
throw new XmlPullParserException("Unknown tag under "
+ XML_TAG_SECTION_HEADER_DELETED_EPHEMERAL_SSID_LIST
+ ": " + valueName[0]);
}
}
}
@Override
public void resetData() {
mSsidToTimeMap = null;
}
@Override
public boolean hasNewDataToSerialize() {
// always persist.
return true;
}
@Override
public String getName() {
return XML_TAG_SECTION_HEADER_DELETED_EPHEMERAL_SSID_LIST;
}
@Override
public @WifiConfigStore.StoreFileId int getStoreFileId() {
// Shared general store.
return WifiConfigStore.STORE_FILE_USER_GENERAL;
}
/**
* An empty map will be returned for null SSID list.
*
* @return Map of SSIDs
*/
public Map<String, Long> getSsidToTimeMap() {
if (mSsidToTimeMap == null) {
return new HashMap<String, Long>();
}
return mSsidToTimeMap;
}
public void setSsidToTimeMap(Map<String, Long> ssidMap) {
mSsidToTimeMap = ssidMap;
}
}