remove passpoint - DO NOT MERGE
This CL is dependent on I3d2a230b0362520b9f1b2bc3792260116971e106 Change-Id: I1a0d655877d9368d833d62e231797af4b2560862
This commit is contained in:
committed by
Pierre Vandwalle
parent
1a95b1a6f3
commit
808079bd27
@@ -376,7 +376,6 @@ LOCAL_SRC_FILES += \
|
||||
telephony/java/com/android/internal/telephony/ISub.aidl \
|
||||
telephony/java/com/android/internal/telephony/IMms.aidl \
|
||||
wifi/java/android/net/wifi/IWifiManager.aidl \
|
||||
wifi/java/android/net/wifi/passpoint/IWifiPasspointManager.aidl \
|
||||
wifi/java/android/net/wifi/p2p/IWifiP2pManager.aidl \
|
||||
wifi/java/android/net/wifi/IWifiScanner.aidl \
|
||||
wifi/java/android/net/wifi/IRttManager.aidl \
|
||||
|
||||
180
api/current.txt
180
api/current.txt
@@ -17993,7 +17993,6 @@ package android.net.wifi {
|
||||
field public java.lang.String capabilities;
|
||||
field public int frequency;
|
||||
field public int level;
|
||||
field public android.net.wifi.passpoint.WifiPasspointInfo passpoint;
|
||||
field public long timestamp;
|
||||
}
|
||||
|
||||
@@ -18472,185 +18471,6 @@ package android.net.wifi.p2p.nsd {
|
||||
|
||||
}
|
||||
|
||||
package android.net.wifi.passpoint {
|
||||
|
||||
public abstract interface IWifiPasspointManager implements android.os.IInterface {
|
||||
method public abstract android.os.Messenger getMessenger() throws android.os.RemoteException;
|
||||
method public abstract int getPasspointState() throws android.os.RemoteException;
|
||||
}
|
||||
|
||||
public class WifiPasspointInfo implements android.os.Parcelable {
|
||||
ctor public WifiPasspointInfo();
|
||||
method public int describeContents();
|
||||
method public void writeToParcel(android.os.Parcel, int);
|
||||
field public static final int ANQP_CAPABILITY = 1; // 0x1
|
||||
field public static final int CELLULAR_NETWORK = 64; // 0x40
|
||||
field public static final int CONNECTION_CAPABILITY = 2048; // 0x800
|
||||
field public static final int DOMAIN_NAME = 128; // 0x80
|
||||
field public static final int HOTSPOT_CAPABILITY = 256; // 0x100
|
||||
field public static final int IP_ADDR_TYPE_AVAILABILITY = 16; // 0x10
|
||||
field public static final int NAI_REALM = 32; // 0x20
|
||||
field public static final int NETWORK_AUTH_TYPE = 4; // 0x4
|
||||
field public static final int OPERATOR_FRIENDLY_NAME = 512; // 0x200
|
||||
field public static final int OSU_PROVIDER = 4096; // 0x1000
|
||||
field public static final int PRESET_ALL = 8191; // 0x1fff
|
||||
field public static final int PRESET_CRED_MATCH = 481; // 0x1e1
|
||||
field public static final int ROAMING_CONSORTIUM = 8; // 0x8
|
||||
field public static final int VENUE_NAME = 2; // 0x2
|
||||
field public static final int WAN_METRICS = 1024; // 0x400
|
||||
field public java.lang.String bssid;
|
||||
field public java.util.List cellularNetworkList;
|
||||
field public java.util.List connectionCapabilityList;
|
||||
field public java.util.List domainNameList;
|
||||
field public android.net.wifi.passpoint.WifiPasspointInfo.IpAddressType ipAddrTypeAvailability;
|
||||
field public java.util.List naiRealmList;
|
||||
field public java.util.List networkAuthTypeList;
|
||||
field public java.lang.String operatorFriendlyName;
|
||||
field public java.util.List osuProviderList;
|
||||
field public java.util.List roamingConsortiumList;
|
||||
field public java.lang.String venueName;
|
||||
field public android.net.wifi.passpoint.WifiPasspointInfo.WanMetrics wanMetrics;
|
||||
}
|
||||
|
||||
public static class WifiPasspointInfo.CellularNetwork {
|
||||
ctor public WifiPasspointInfo.CellularNetwork();
|
||||
field public java.lang.String mcc;
|
||||
field public java.lang.String mnc;
|
||||
}
|
||||
|
||||
public static class WifiPasspointInfo.IpAddressType {
|
||||
ctor public WifiPasspointInfo.IpAddressType();
|
||||
method public int getIpv4Availability();
|
||||
method public int getIpv6Availability();
|
||||
field public static final int IPV4_DOUBLE_NAT = 4; // 0x4
|
||||
field public static final int IPV4_NOT_AVAILABLE = 0; // 0x0
|
||||
field public static final int IPV4_PORT_RESTRICTED = 2; // 0x2
|
||||
field public static final int IPV4_PORT_RESTRICTED_DOUBLE_NAT = 6; // 0x6
|
||||
field public static final int IPV4_PORT_RESTRICTED_SINGLE_NAT = 5; // 0x5
|
||||
field public static final int IPV4_PORT_UNKNOWN = 7; // 0x7
|
||||
field public static final int IPV4_PUBLIC = 1; // 0x1
|
||||
field public static final int IPV4_SINGLE_NAT = 3; // 0x3
|
||||
field public static final int IPV6_AVAILABLE = 1; // 0x1
|
||||
field public static final int IPV6_NOT_AVAILABLE = 0; // 0x0
|
||||
field public static final int IPV6_UNKNOWN = 2; // 0x2
|
||||
field public int availability;
|
||||
}
|
||||
|
||||
public static class WifiPasspointInfo.IpProtoPort {
|
||||
ctor public WifiPasspointInfo.IpProtoPort();
|
||||
field public static final int STATUS_CLOSED = 0; // 0x0
|
||||
field public static final int STATUS_OPEN = 1; // 0x1
|
||||
field public static final int STATUS_UNKNOWN = 2; // 0x2
|
||||
field public int port;
|
||||
field public int proto;
|
||||
field public int status;
|
||||
}
|
||||
|
||||
public static class WifiPasspointInfo.NaiRealm {
|
||||
ctor public WifiPasspointInfo.NaiRealm();
|
||||
field public static final int ENCODING_RFC4282 = 0; // 0x0
|
||||
field public static final int ENCODING_UTF8 = 1; // 0x1
|
||||
field public int encoding;
|
||||
field public java.lang.String realm;
|
||||
}
|
||||
|
||||
public static class WifiPasspointInfo.NetworkAuthType {
|
||||
ctor public WifiPasspointInfo.NetworkAuthType();
|
||||
field public static final int TYPE_DNS_REDIRECTION = 3; // 0x3
|
||||
field public static final int TYPE_HTTP_REDIRECTION = 2; // 0x2
|
||||
field public static final int TYPE_ONLINE_ENROLLMENT = 1; // 0x1
|
||||
field public static final int TYPE_TERMS_AND_CONDITION = 0; // 0x0
|
||||
field public java.lang.String redirectUrl;
|
||||
field public int type;
|
||||
}
|
||||
|
||||
public static class WifiPasspointInfo.WanMetrics {
|
||||
ctor public WifiPasspointInfo.WanMetrics();
|
||||
method public boolean getAtCapacity();
|
||||
method public int getLinkStatus();
|
||||
method public boolean getSymmetricLink();
|
||||
field public static final int STATUS_DOWN = 2; // 0x2
|
||||
field public static final int STATUS_RESERVED = 0; // 0x0
|
||||
field public static final int STATUS_TEST = 3; // 0x3
|
||||
field public static final int STATUS_UP = 1; // 0x1
|
||||
field public int downlinkLoad;
|
||||
field public long downlinkSpeed;
|
||||
field public int lmd;
|
||||
field public int uplinkLoad;
|
||||
field public long uplinkSpeed;
|
||||
field public int wanInfo;
|
||||
}
|
||||
|
||||
public class WifiPasspointManager {
|
||||
ctor public WifiPasspointManager(android.content.Context, android.net.wifi.passpoint.IWifiPasspointManager);
|
||||
method public android.os.Messenger getMessenger();
|
||||
method public android.net.wifi.passpoint.WifiPasspointManager.Channel initialize(android.content.Context, android.os.Looper, android.net.wifi.passpoint.WifiPasspointManager.ChannelListener);
|
||||
method public void requestAnqpInfo(android.net.wifi.passpoint.WifiPasspointManager.Channel, java.util.List<android.net.wifi.ScanResult>, int, android.net.wifi.passpoint.WifiPasspointManager.ActionListener);
|
||||
field public static final java.lang.String PASSPOINT_CRED_CHANGED_ACTION = "android.net.wifi.passpoint.CRED_CHANGE";
|
||||
field public static final java.lang.String PASSPOINT_OSU_AVAILABLE_ACTION = "android.net.wifi.passpoint.OSU_AVAILABLE";
|
||||
field public static final int PASSPOINT_STATE_ACCESS = 3; // 0x3
|
||||
field public static final java.lang.String PASSPOINT_STATE_CHANGED_ACTION = "android.net.wifi.passpoint.STATE_CHANGE";
|
||||
field public static final int PASSPOINT_STATE_DISABLED = 1; // 0x1
|
||||
field public static final int PASSPOINT_STATE_DISCOVERY = 2; // 0x2
|
||||
field public static final int PASSPOINT_STATE_PROVISION = 4; // 0x4
|
||||
field public static final int PASSPOINT_STATE_UNKNOWN = 0; // 0x0
|
||||
field public static final java.lang.String PASSPOINT_USER_REM_REQ_ACTION = "android.net.wifi.passpoint.USER_REM_REQ";
|
||||
field public static final java.lang.String PROTOCOL_DM = "OMA-DM-ClientInitiated";
|
||||
field public static final java.lang.String PROTOCOL_SOAP = "SPP-ClientInitiated";
|
||||
field public static final int REASON_BUSY = 2; // 0x2
|
||||
field public static final int REASON_ERROR = 0; // 0x0
|
||||
field public static final int REASON_INVALID_PARAMETER = 3; // 0x3
|
||||
field public static final int REASON_NOT_TRUSTED = 4; // 0x4
|
||||
field public static final int REASON_WIFI_DISABLED = 1; // 0x1
|
||||
field public static final int REQUEST_ANQP_INFO = 163841; // 0x28001
|
||||
field public static final int REQUEST_ANQP_INFO_FAILED = 163842; // 0x28002
|
||||
field public static final int REQUEST_ANQP_INFO_SUCCEEDED = 163843; // 0x28003
|
||||
field public static final int REQUEST_OSU_ICON = 163844; // 0x28004
|
||||
field public static final int REQUEST_OSU_ICON_FAILED = 163845; // 0x28005
|
||||
field public static final int REQUEST_OSU_ICON_SUCCEEDED = 163846; // 0x28006
|
||||
field public static final int START_OSU = 163847; // 0x28007
|
||||
field public static final int START_OSU_BROWSER = 163848; // 0x28008
|
||||
field public static final int START_OSU_FAILED = 163849; // 0x28009
|
||||
field public static final int START_OSU_SUCCEEDED = 163850; // 0x2800a
|
||||
}
|
||||
|
||||
public static abstract interface WifiPasspointManager.ActionListener {
|
||||
method public abstract void onFailure(int);
|
||||
method public abstract void onSuccess();
|
||||
}
|
||||
|
||||
public static class WifiPasspointManager.Channel {
|
||||
}
|
||||
|
||||
public static abstract interface WifiPasspointManager.ChannelListener {
|
||||
method public abstract void onChannelDisconnected();
|
||||
}
|
||||
|
||||
public static class WifiPasspointManager.ParcelableString implements android.os.Parcelable {
|
||||
ctor public WifiPasspointManager.ParcelableString();
|
||||
method public int describeContents();
|
||||
method public void writeToParcel(android.os.Parcel, int);
|
||||
field public static final android.os.Parcelable.Creator CREATOR;
|
||||
field public java.lang.String string;
|
||||
}
|
||||
|
||||
public class WifiPasspointOsuProvider implements android.os.Parcelable {
|
||||
method public int describeContents();
|
||||
method public void writeToParcel(android.os.Parcel, int);
|
||||
field public static final android.os.Parcelable.Creator CREATOR;
|
||||
field public java.lang.String friendlyName;
|
||||
field public java.lang.Object icon;
|
||||
field public java.lang.String iconFileName;
|
||||
field public int iconHeight;
|
||||
field public java.lang.String iconType;
|
||||
field public int iconWidth;
|
||||
field public java.lang.String osuNai;
|
||||
field public java.lang.String osuService;
|
||||
field public java.lang.String ssid;
|
||||
}
|
||||
|
||||
}
|
||||
|
||||
package android.nfc {
|
||||
|
||||
public class FormatException extends java.lang.Exception {
|
||||
|
||||
@@ -92,8 +92,6 @@ import android.net.nsd.INsdManager;
|
||||
import android.net.nsd.NsdManager;
|
||||
import android.net.wifi.IWifiManager;
|
||||
import android.net.wifi.WifiManager;
|
||||
import android.net.wifi.passpoint.IWifiPasspointManager;
|
||||
import android.net.wifi.passpoint.WifiPasspointManager;
|
||||
import android.net.wifi.p2p.IWifiP2pManager;
|
||||
import android.net.wifi.p2p.WifiP2pManager;
|
||||
import android.net.wifi.IWifiScanner;
|
||||
@@ -606,13 +604,6 @@ class ContextImpl extends Context {
|
||||
return new WifiManager(ctx.getOuterContext(), service);
|
||||
}});
|
||||
|
||||
registerService(WIFI_PASSPOINT_SERVICE, new ServiceFetcher() {
|
||||
public Object createService(ContextImpl ctx) {
|
||||
IBinder b = ServiceManager.getService(WIFI_PASSPOINT_SERVICE);
|
||||
IWifiPasspointManager service = IWifiPasspointManager.Stub.asInterface(b);
|
||||
return new WifiPasspointManager(ctx.getOuterContext(), service);
|
||||
}});
|
||||
|
||||
registerService(WIFI_P2P_SERVICE, new ServiceFetcher() {
|
||||
public Object createService(ContextImpl ctx) {
|
||||
IBinder b = ServiceManager.getService(WIFI_P2P_SERVICE);
|
||||
|
||||
@@ -16,8 +16,6 @@
|
||||
|
||||
package android.net.wifi;
|
||||
|
||||
import android.net.wifi.passpoint.WifiPasspointInfo;
|
||||
import android.net.wifi.passpoint.WifiPasspointManager;
|
||||
import android.os.Parcel;
|
||||
import android.os.Parcelable;
|
||||
|
||||
@@ -158,12 +156,6 @@ public class ScanResult implements Parcelable {
|
||||
*/
|
||||
public int distanceSdCm;
|
||||
|
||||
/**
|
||||
* Passpoint ANQP information. This is not fetched automatically.
|
||||
* Use {@link WifiPasspointManager#requestAnqpInfo} to request ANQP info.
|
||||
*/
|
||||
public WifiPasspointInfo passpoint;
|
||||
|
||||
/**
|
||||
* {@hide}
|
||||
*/
|
||||
@@ -260,7 +252,6 @@ public class ScanResult implements Parcelable {
|
||||
distanceCm = source.distanceCm;
|
||||
distanceSdCm = source.distanceSdCm;
|
||||
seen = source.seen;
|
||||
passpoint = source.passpoint;
|
||||
autoJoinStatus = source.autoJoinStatus;
|
||||
untrusted = source.untrusted;
|
||||
numConnection = source.numConnection;
|
||||
@@ -298,7 +289,6 @@ public class ScanResult implements Parcelable {
|
||||
sb.append(", distanceSd: ").append((distanceSdCm != UNSPECIFIED ? distanceSdCm : "?")).
|
||||
append("(cm)");
|
||||
|
||||
sb.append(", passpoint: ").append(passpoint != null ? "yes" : "no");
|
||||
if (autoJoinStatus != 0) {
|
||||
sb.append(", status: ").append(autoJoinStatus);
|
||||
}
|
||||
@@ -330,12 +320,6 @@ public class ScanResult implements Parcelable {
|
||||
dest.writeInt(untrusted ? 1 : 0);
|
||||
dest.writeInt(numConnection);
|
||||
dest.writeInt(numUsage);
|
||||
if (passpoint != null) {
|
||||
dest.writeInt(1);
|
||||
passpoint.writeToParcel(dest, flags);
|
||||
} else {
|
||||
dest.writeInt(0);
|
||||
}
|
||||
if (informationElements != null) {
|
||||
dest.writeInt(informationElements.length);
|
||||
for (int i = 0; i < informationElements.length; i++) {
|
||||
@@ -370,10 +354,6 @@ public class ScanResult implements Parcelable {
|
||||
sr.autoJoinStatus = in.readInt();
|
||||
sr.untrusted = in.readInt() != 0;
|
||||
sr.numConnection = in.readInt();
|
||||
sr.numUsage = in.readInt();
|
||||
if (in.readInt() == 1) {
|
||||
sr.passpoint = WifiPasspointInfo.CREATOR.createFromParcel(in);
|
||||
}
|
||||
int n = in.readInt();
|
||||
if (n != 0) {
|
||||
sr.informationElements = new InformationElement[n];
|
||||
|
||||
@@ -1,35 +0,0 @@
|
||||
/**
|
||||
* Copyright (c) 2014, 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 android.net.wifi.passpoint;
|
||||
|
||||
import android.net.wifi.ScanResult;
|
||||
import android.net.wifi.passpoint.WifiPasspointPolicy;
|
||||
import android.net.wifi.passpoint.WifiPasspointCredential;
|
||||
import android.os.Messenger;
|
||||
|
||||
/**
|
||||
* Interface that allows controlling and querying Wifi Passpoint connectivity.
|
||||
*
|
||||
* {@hide}
|
||||
*/
|
||||
interface IWifiPasspointManager
|
||||
{
|
||||
Messenger getMessenger();
|
||||
|
||||
int getPasspointState();
|
||||
}
|
||||
|
||||
@@ -1,19 +0,0 @@
|
||||
/**
|
||||
* Copyright (c) 2014, 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 android.net.wifi.passpoint;
|
||||
|
||||
parcelable WifiPasspointCredential;
|
||||
@@ -1,667 +0,0 @@
|
||||
/*
|
||||
* Copyright (C) 2014 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 android.net.wifi.passpoint;
|
||||
|
||||
import android.net.wifi.WifiEnterpriseConfig;
|
||||
import android.os.Parcelable;
|
||||
import android.os.Parcel;
|
||||
|
||||
import java.util.ArrayList;
|
||||
import java.util.Collection;
|
||||
import java.util.List;
|
||||
import java.util.Iterator;
|
||||
import java.util.Map;
|
||||
import java.util.Set;
|
||||
|
||||
|
||||
/**
|
||||
* A class representing a Wi-Fi Passpoint credential.
|
||||
* @hide
|
||||
*/
|
||||
public class WifiPasspointCredential implements Parcelable {
|
||||
|
||||
private final static String TAG = "PasspointCredential";
|
||||
private final static boolean DBG = true;
|
||||
|
||||
/** Wi-Fi nodes**/
|
||||
private String mWifiSpFqdn;
|
||||
|
||||
/** PerProviderSubscription nodes **/
|
||||
private String mCredentialName;
|
||||
|
||||
/** SubscriptionUpdate nodes **/
|
||||
private String mSubscriptionUpdateInterval;
|
||||
private String mSubscriptionUpdateMethod;
|
||||
private String mSubscriptionUpdateRestriction;
|
||||
private String mSubscriptionUpdateURI;
|
||||
private String mSubscriptionUpdateUsername;
|
||||
private String mSubscriptionUpdatePassword;
|
||||
|
||||
/** HomeSP nodes **/
|
||||
private String mHomeSpFqdn;
|
||||
private String mFriendlyName;
|
||||
private Collection<WifiPasspointDmTree.HomeOIList> mHomeOIList;
|
||||
private Collection<WifiPasspointDmTree.OtherHomePartners> mOtherHomePartnerList;
|
||||
|
||||
/** SubscriptionParameters nodes**/
|
||||
private String mCreationDate;
|
||||
private String mExpirationDate;
|
||||
|
||||
/** Credential nodes **/
|
||||
private String mType;
|
||||
private String mInnerMethod;
|
||||
private String mCertType;
|
||||
private String mCertSha256Fingerprint;
|
||||
private String mUpdateIdentifier;
|
||||
private String mUsername;
|
||||
private String mPasswd;
|
||||
private String mRealm;
|
||||
private String mImsi;
|
||||
private String mMcc;
|
||||
private String mMnc;
|
||||
private String mCaRootCert;
|
||||
private String mClientCert;
|
||||
private boolean mCheckAaaServerCertStatus;
|
||||
|
||||
/** Policy nodes **/
|
||||
private String mPolicyUpdateUri;
|
||||
private String mPolicyUpdateInterval;
|
||||
private String mPolicyUpdateUsername;
|
||||
private String mPolicyUpdatePassword;
|
||||
private String mPolicyUpdateRestriction;
|
||||
private String mPolicyUpdateMethod;
|
||||
private Collection<WifiPasspointDmTree.PreferredRoamingPartnerList> mPreferredRoamingPartnerList;
|
||||
private Collection<WifiPasspointDmTree.MinBackhaulThresholdNetwork> mMinBackhaulThresholdNetwork;
|
||||
private Collection<WifiPasspointDmTree.SPExclusionList> mSpExclusionList;
|
||||
private Collection<WifiPasspointDmTree.RequiredProtoPortTuple> mRequiredProtoPortTuple;
|
||||
private String mMaxBssLoad;
|
||||
|
||||
/** CrednetialPriority node **/
|
||||
private int mCrednetialPriority;
|
||||
|
||||
/** AAAServerTrustRoot nodes **/
|
||||
private String mAaaCertUrl;
|
||||
private String mAaaSha256Fingerprint;
|
||||
|
||||
/** Others **/
|
||||
private boolean mIsMachineRemediation;
|
||||
private boolean mUserPreferred = false;
|
||||
private String mWifiTreePath;
|
||||
private WifiEnterpriseConfig mEnterpriseConfig;
|
||||
|
||||
/** @hide */
|
||||
public WifiPasspointCredential() {}
|
||||
|
||||
/**
|
||||
* Constructor
|
||||
* @param realm Realm of the passpoint credential
|
||||
* @param fqdn Fully qualified domain name (FQDN) of the credential
|
||||
* @param config Enterprise config, must be either EAP-TLS or EAP-TTLS
|
||||
* @see WifiEnterpriseConfig
|
||||
*/
|
||||
public WifiPasspointCredential(String realm, String fqdn, WifiEnterpriseConfig config) {
|
||||
mRealm = realm;
|
||||
switch (config.getEapMethod()) {
|
||||
case WifiEnterpriseConfig.Eap.TLS:
|
||||
case WifiEnterpriseConfig.Eap.TTLS:
|
||||
mEnterpriseConfig = new WifiEnterpriseConfig(config);
|
||||
break;
|
||||
default:
|
||||
// ignore
|
||||
}
|
||||
}
|
||||
|
||||
/** @hide */
|
||||
public WifiPasspointCredential(String type,
|
||||
String caroot,
|
||||
String clientcert,
|
||||
String mcc,
|
||||
String mnc,
|
||||
WifiPasspointDmTree.SpFqdn sp,
|
||||
WifiPasspointDmTree.CredentialInfo credinfo) {
|
||||
|
||||
if (credinfo == null) {
|
||||
return;
|
||||
}
|
||||
|
||||
mType = type;
|
||||
mCaRootCert = caroot;
|
||||
mClientCert = clientcert;
|
||||
|
||||
mWifiSpFqdn = sp.nodeName;
|
||||
mUpdateIdentifier = sp.perProviderSubscription.UpdateIdentifier;
|
||||
|
||||
mCredentialName = credinfo.nodeName;
|
||||
mOtherHomePartnerList = credinfo.homeSP.otherHomePartners.values();
|
||||
|
||||
Set set = credinfo.aAAServerTrustRoot.entrySet();
|
||||
Iterator i = set.iterator();
|
||||
if (i.hasNext()) {
|
||||
Map.Entry entry3 = (Map.Entry) i.next();
|
||||
WifiPasspointDmTree.AAAServerTrustRoot aaa = (WifiPasspointDmTree.AAAServerTrustRoot) entry3.getValue();
|
||||
mAaaCertUrl = aaa.CertURL;
|
||||
mAaaSha256Fingerprint = aaa.CertSHA256Fingerprint;
|
||||
}
|
||||
|
||||
mCertType = credinfo.credential.digitalCertificate.CertificateType;
|
||||
mCertSha256Fingerprint = credinfo.credential.digitalCertificate.CertSHA256Fingerprint;
|
||||
mUsername = credinfo.credential.usernamePassword.Username;
|
||||
mPasswd = credinfo.credential.usernamePassword.Password;
|
||||
mIsMachineRemediation = credinfo.credential.usernamePassword.MachineManaged;
|
||||
mInnerMethod = credinfo.credential.usernamePassword.eAPMethod.InnerMethod;
|
||||
mImsi = credinfo.credential.sim.IMSI;
|
||||
mMcc = mcc;
|
||||
mMnc = mnc;
|
||||
mCreationDate = credinfo.credential.CreationDate;
|
||||
mExpirationDate = credinfo.credential.ExpirationDate;
|
||||
mRealm = credinfo.credential.Realm;
|
||||
|
||||
if (credinfo.credentialPriority == null) {
|
||||
mCrednetialPriority = 128;
|
||||
} else {
|
||||
mCrednetialPriority = Integer.parseInt(credinfo.credentialPriority);
|
||||
}
|
||||
|
||||
mHomeSpFqdn = credinfo.homeSP.FQDN;
|
||||
|
||||
mSubscriptionUpdateInterval = credinfo.subscriptionUpdate.UpdateInterval;
|
||||
mSubscriptionUpdateMethod = credinfo.subscriptionUpdate.UpdateMethod;
|
||||
mSubscriptionUpdateRestriction = credinfo.subscriptionUpdate.Restriction;
|
||||
mSubscriptionUpdateURI = credinfo.subscriptionUpdate.URI;
|
||||
mSubscriptionUpdateUsername = credinfo.subscriptionUpdate.usernamePassword.Username;
|
||||
mSubscriptionUpdatePassword = credinfo.subscriptionUpdate.usernamePassword.Password;
|
||||
|
||||
mPolicyUpdateUri = credinfo.policy.policyUpdate.URI;
|
||||
mPolicyUpdateInterval = credinfo.policy.policyUpdate.UpdateInterval;
|
||||
mPolicyUpdateUsername = credinfo.policy.policyUpdate.usernamePassword.Username;
|
||||
mPolicyUpdatePassword = credinfo.policy.policyUpdate.usernamePassword.Password;
|
||||
mPolicyUpdateRestriction = credinfo.policy.policyUpdate.Restriction;
|
||||
mPolicyUpdateMethod = credinfo.policy.policyUpdate.UpdateMethod;
|
||||
mPreferredRoamingPartnerList = credinfo.policy.preferredRoamingPartnerList.values();
|
||||
mMinBackhaulThresholdNetwork = credinfo.policy.minBackhaulThreshold.values();
|
||||
mRequiredProtoPortTuple = credinfo.policy.requiredProtoPortTuple.values();
|
||||
mMaxBssLoad = credinfo.policy.maximumBSSLoadValue;
|
||||
mSpExclusionList = credinfo.policy.sPExclusionList.values();
|
||||
|
||||
mHomeOIList = credinfo.homeSP.homeOIList.values();
|
||||
mFriendlyName = credinfo.homeSP.FriendlyName;
|
||||
mCheckAaaServerCertStatus = credinfo.credential.CheckAAAServerCertStatus;
|
||||
}
|
||||
|
||||
/** @hide */
|
||||
public String getUpdateIdentifier() {
|
||||
return mUpdateIdentifier;
|
||||
}
|
||||
|
||||
/** @hide */
|
||||
public String getUpdateMethod() {
|
||||
return mSubscriptionUpdateMethod;
|
||||
}
|
||||
|
||||
/** @hide */
|
||||
public void setUpdateMethod(String method) {
|
||||
mSubscriptionUpdateMethod = method;
|
||||
}
|
||||
|
||||
/** @hide */
|
||||
public String getWifiSpFqdn() {
|
||||
return mWifiSpFqdn;
|
||||
}
|
||||
|
||||
/** @hide */
|
||||
public String getCredName() {
|
||||
return mCredentialName;
|
||||
}
|
||||
|
||||
/** @hide */
|
||||
public String getType() {
|
||||
return mType;
|
||||
}
|
||||
|
||||
/**
|
||||
* Get enterprise config of this Passpoint credential.
|
||||
* @return Enterprise config
|
||||
* @see WifiEnterpriseConfig
|
||||
*/
|
||||
public WifiEnterpriseConfig getEnterpriseConfig() {
|
||||
return new WifiEnterpriseConfig(mEnterpriseConfig);
|
||||
}
|
||||
|
||||
/**
|
||||
* Set enterprise config of this Passpoint credential.
|
||||
* @param config Enterprise config, must be either EAP-TLS or EAP-TTLS
|
||||
* @see WifiEnterpriseConfig
|
||||
*/
|
||||
public void setEnterpriseConfig(WifiEnterpriseConfig config) {
|
||||
// TODO
|
||||
}
|
||||
|
||||
/** @hide */
|
||||
public String getCertType() {
|
||||
return mCertType;
|
||||
}
|
||||
|
||||
/** @hide */
|
||||
public String getCertSha256Fingerprint() {
|
||||
return mCertSha256Fingerprint;
|
||||
}
|
||||
|
||||
/** @hide */
|
||||
public String getUserName() {
|
||||
return mUsername;
|
||||
}
|
||||
|
||||
/** @hide */
|
||||
public String getPassword() {
|
||||
// TODO: guarded by connectivity internal
|
||||
return mPasswd;
|
||||
}
|
||||
|
||||
/** @hide */
|
||||
public String getImsi() {
|
||||
return mImsi;
|
||||
}
|
||||
|
||||
/** @hide */
|
||||
public String getMcc() {
|
||||
return mMcc;
|
||||
}
|
||||
|
||||
/** @hide */
|
||||
public String getMnc() {
|
||||
return mMnc;
|
||||
}
|
||||
|
||||
/** @hide */
|
||||
public String getCaRootCertPath() {
|
||||
return mCaRootCert;
|
||||
}
|
||||
|
||||
/** @hide */
|
||||
public String getClientCertPath() {
|
||||
return mClientCert;
|
||||
}
|
||||
|
||||
/**
|
||||
* Get the realm of this Passpoint credential.
|
||||
* @return Realm
|
||||
*/
|
||||
public String getRealm() {
|
||||
return mRealm;
|
||||
}
|
||||
|
||||
/**
|
||||
* Set the ream of this Passpoint credential.
|
||||
* @param realm Realm
|
||||
*/
|
||||
public void setRealm(String realm) {
|
||||
mRealm = realm;
|
||||
}
|
||||
|
||||
/** @hide */
|
||||
public int getPriority() {
|
||||
if (mUserPreferred) {
|
||||
return 0;
|
||||
}
|
||||
|
||||
return mCrednetialPriority;
|
||||
}
|
||||
|
||||
/**
|
||||
* Get the fully qualified domain name (FQDN) of this Passpoint credential.
|
||||
* @return FQDN
|
||||
*/
|
||||
public String getHomeSpFqdn() {
|
||||
return mHomeSpFqdn;
|
||||
}
|
||||
|
||||
/**
|
||||
* Set the fully qualified domain name (FQDN) of this Passpoint credential.
|
||||
* @param fqdn FQDN
|
||||
*/
|
||||
public void setHomeFqdn(String fqdn) {
|
||||
mHomeSpFqdn = fqdn;
|
||||
}
|
||||
|
||||
|
||||
/** @hide */
|
||||
public Collection<WifiPasspointDmTree.OtherHomePartners> getOtherHomePartnerList() {
|
||||
return mOtherHomePartnerList;
|
||||
}
|
||||
|
||||
/** @hide */
|
||||
public String getSubscriptionUpdateUsername() {
|
||||
return mSubscriptionUpdateUsername;
|
||||
}
|
||||
|
||||
/** @hide */
|
||||
public String getSubscriptionUpdatePassword() {
|
||||
return mSubscriptionUpdatePassword;
|
||||
}
|
||||
|
||||
/** @hide */
|
||||
public String getPolicyUpdateUri() {
|
||||
return mPolicyUpdateUri;
|
||||
}
|
||||
|
||||
/** @hide */
|
||||
public String getPolicyUpdateInterval() {
|
||||
return mPolicyUpdateInterval;
|
||||
}
|
||||
|
||||
/** @hide */
|
||||
public String getPolicyUpdateUsername() {
|
||||
return mPolicyUpdateUsername;
|
||||
}
|
||||
|
||||
/** @hide */
|
||||
public String getPolicyUpdatePassword() {
|
||||
return mPolicyUpdatePassword;
|
||||
}
|
||||
|
||||
/** @hide */
|
||||
public String getPolicyUpdateRestriction() {
|
||||
return mPolicyUpdateRestriction;
|
||||
}
|
||||
|
||||
/** @hide */
|
||||
public String getPolicyUpdateMethod() {
|
||||
return mPolicyUpdateMethod;
|
||||
}
|
||||
|
||||
/** @hide */
|
||||
public String getCreationDate() {
|
||||
return mCreationDate;
|
||||
}
|
||||
|
||||
/** @hide */
|
||||
public String getExpirationDate() {
|
||||
return mExpirationDate;
|
||||
}
|
||||
|
||||
/** @hide */
|
||||
public void setExpirationDate(String expirationdate) {
|
||||
mExpirationDate = expirationdate;
|
||||
}
|
||||
|
||||
/** @hide */
|
||||
public Collection<WifiPasspointDmTree.PreferredRoamingPartnerList> getPreferredRoamingPartnerList() {
|
||||
return mPreferredRoamingPartnerList;
|
||||
}
|
||||
|
||||
/** @hide */
|
||||
public Collection<WifiPasspointDmTree.HomeOIList> getHomeOiList() {
|
||||
return mHomeOIList;
|
||||
}
|
||||
|
||||
/** @hide */
|
||||
public Collection<WifiPasspointDmTree.MinBackhaulThresholdNetwork> getBackhaulThresholdList() {
|
||||
return mMinBackhaulThresholdNetwork;
|
||||
}
|
||||
|
||||
/** @hide */
|
||||
public Collection<WifiPasspointDmTree.RequiredProtoPortTuple> getRequiredProtoPortList() {
|
||||
return mRequiredProtoPortTuple;
|
||||
}
|
||||
|
||||
/** @hide */
|
||||
public Collection<WifiPasspointDmTree.SPExclusionList> getSPExclusionList() {
|
||||
return mSpExclusionList;
|
||||
}
|
||||
|
||||
/** @hide */
|
||||
public boolean getIsMachineRemediation() {
|
||||
return mIsMachineRemediation;
|
||||
}
|
||||
|
||||
/** @hide */
|
||||
public String getAaaCertUrl() {
|
||||
return mAaaCertUrl;
|
||||
}
|
||||
|
||||
/** @hide */
|
||||
public String getAaaSha256Fingerprint() {
|
||||
return mAaaSha256Fingerprint;
|
||||
}
|
||||
|
||||
/** @hide */
|
||||
public String getSubscriptionUpdateRestriction() {
|
||||
return mSubscriptionUpdateRestriction;
|
||||
}
|
||||
|
||||
/** @hide */
|
||||
public String getSubscriptionUpdateURI() {
|
||||
return mSubscriptionUpdateURI;
|
||||
}
|
||||
|
||||
/** @hide */
|
||||
public String getSubscriptionUpdateInterval() {
|
||||
return mSubscriptionUpdateInterval;
|
||||
}
|
||||
|
||||
/** @hide */
|
||||
public String getFriendlyName() {
|
||||
return mFriendlyName;
|
||||
}
|
||||
|
||||
/** @hide */
|
||||
public String getMaxBssLoad() {
|
||||
return mMaxBssLoad;
|
||||
}
|
||||
|
||||
/** @hide */
|
||||
public boolean getUserPreference() {
|
||||
return mUserPreferred;
|
||||
}
|
||||
|
||||
/** @hide */
|
||||
public boolean getCheckAaaServerCertStatus() {
|
||||
return mCheckAaaServerCertStatus;
|
||||
}
|
||||
|
||||
/** @hide */
|
||||
public void setUserPreference(boolean value) {
|
||||
mUserPreferred = value;
|
||||
}
|
||||
|
||||
@Override
|
||||
/** @hide */
|
||||
public boolean equals(Object obj) {
|
||||
boolean result = false;
|
||||
if (obj instanceof WifiPasspointCredential) {
|
||||
final WifiPasspointCredential other = (WifiPasspointCredential) obj;
|
||||
if (this.mType.equals(other.mType)) {
|
||||
if (this.mType.equals("TTLS")) {
|
||||
result = this.mUsername.equals(other.mUsername) &&
|
||||
this.mPasswd.equals(other.mPasswd) &&
|
||||
this.mRealm.equals(other.mRealm) &&
|
||||
this.mHomeSpFqdn.equals(other.mHomeSpFqdn);
|
||||
}
|
||||
if (this.mType.equals("TLS")) {
|
||||
result = this.mRealm.equals(other.mRealm) &&
|
||||
this.mHomeSpFqdn.equals(other.mHomeSpFqdn) &&
|
||||
this.mClientCert.equals(other.mClientCert);
|
||||
}
|
||||
if (this.mType.equals("SIM")) {
|
||||
result = this.mMcc.equals(other.mMcc) &&
|
||||
this.mMnc.equals(other.mMnc) &&
|
||||
this.mImsi.equals(other.mImsi) &&
|
||||
this.mHomeSpFqdn.equals(other.mHomeSpFqdn);
|
||||
}
|
||||
}
|
||||
}
|
||||
return result;
|
||||
}
|
||||
|
||||
@Override
|
||||
/** @hide */
|
||||
public String toString() {
|
||||
StringBuffer sb = new StringBuffer();
|
||||
String none = "<none>";
|
||||
|
||||
if (!DBG) {
|
||||
sb.append(none);
|
||||
} else {
|
||||
sb.append(", UpdateIdentifier: ")
|
||||
.append(mUpdateIdentifier == null ? none : mUpdateIdentifier)
|
||||
.append(", SubscriptionUpdateMethod: ")
|
||||
.append(mSubscriptionUpdateMethod == null ? none : mSubscriptionUpdateMethod)
|
||||
.append(", Type: ").append(mType == null ? none : mType)
|
||||
.append(", Username: ").append(mUsername == null ? none : mUsername)
|
||||
.append(", Passwd: ").append(mPasswd == null ? none : mPasswd)
|
||||
.append(", SubDMAccUsername: ")
|
||||
.append(mSubscriptionUpdateUsername == null ? none : mSubscriptionUpdateUsername)
|
||||
.append(", SubDMAccPassword: ")
|
||||
.append(mSubscriptionUpdatePassword == null ? none : mSubscriptionUpdatePassword)
|
||||
.append(", PolDMAccUsername: ")
|
||||
.append(mPolicyUpdateUsername == null ? none : mPolicyUpdateUsername)
|
||||
.append(", PolDMAccPassword: ")
|
||||
.append(mPolicyUpdatePassword == null ? none : mPolicyUpdatePassword)
|
||||
.append(", Imsi: ").append(mImsi == null ? none : mImsi)
|
||||
.append(", Mcc: ").append(mMcc == null ? none : mMcc)
|
||||
.append(", Mnc: ").append(mMnc == null ? none : mMnc)
|
||||
.append(", CaRootCert: ").append(mCaRootCert == null ? none : mCaRootCert)
|
||||
.append(", Realm: ").append(mRealm == null ? none : mRealm)
|
||||
.append(", Priority: ").append(mCrednetialPriority)
|
||||
.append(", Fqdn: ").append(mHomeSpFqdn == null ? none : mHomeSpFqdn)
|
||||
.append(", Otherhomepartners: ")
|
||||
.append(mOtherHomePartnerList == null ? none : mOtherHomePartnerList)
|
||||
.append(", ExpirationDate: ")
|
||||
.append(mExpirationDate == null ? none : mExpirationDate)
|
||||
.append(", MaxBssLoad: ").append(mMaxBssLoad == null ? none : mMaxBssLoad)
|
||||
.append(", SPExclusionList: ").append(mSpExclusionList);
|
||||
|
||||
if (mPreferredRoamingPartnerList != null) {
|
||||
sb.append("PreferredRoamingPartnerList:");
|
||||
for (WifiPasspointDmTree.PreferredRoamingPartnerList prpListItem : mPreferredRoamingPartnerList) {
|
||||
sb.append("[fqdnmatch:").append(prpListItem.FQDN_Match).
|
||||
append(", priority:").append(prpListItem.Priority).
|
||||
append(", country:").append(prpListItem.Country).append("]");
|
||||
}
|
||||
}
|
||||
|
||||
if (mHomeOIList != null) {
|
||||
sb.append("HomeOIList:");
|
||||
for (WifiPasspointDmTree.HomeOIList HomeOIListItem : mHomeOIList) {
|
||||
sb.append("[HomeOI:").append(HomeOIListItem.HomeOI).
|
||||
append(", HomeOIRequired:").append(HomeOIListItem.HomeOIRequired).
|
||||
append("]");
|
||||
}
|
||||
}
|
||||
|
||||
if (mMinBackhaulThresholdNetwork != null) {
|
||||
sb.append("BackHaulThreshold:");
|
||||
for (WifiPasspointDmTree.MinBackhaulThresholdNetwork BhtListItem : mMinBackhaulThresholdNetwork) {
|
||||
sb.append("[networkType:").append(BhtListItem.NetworkType).
|
||||
append(", dlBandwidth:").append(BhtListItem.DLBandwidth).
|
||||
append(", ulBandwidth:").append(BhtListItem.ULBandwidth).
|
||||
append("]");
|
||||
}
|
||||
}
|
||||
|
||||
if (mRequiredProtoPortTuple != null) {
|
||||
sb.append("WifiMORequiredProtoPortTupleList:");
|
||||
for (WifiPasspointDmTree.RequiredProtoPortTuple RpptListItem : mRequiredProtoPortTuple) {
|
||||
sb.append("[IPProtocol:").append(RpptListItem.IPProtocol).
|
||||
append(", PortNumber:").append(RpptListItem.PortNumber).
|
||||
append("]");
|
||||
}
|
||||
}
|
||||
}
|
||||
return sb.toString();
|
||||
}
|
||||
|
||||
/** Implement the Parcelable interface {@hide} */
|
||||
public int describeContents() {
|
||||
return 0;
|
||||
}
|
||||
|
||||
/** Implement the Parcelable interface {@hide} */
|
||||
public void writeToParcel(Parcel dest, int flags) {
|
||||
dest.writeString(mWifiSpFqdn);
|
||||
dest.writeString(mCredentialName);
|
||||
dest.writeString(mType);
|
||||
dest.writeInt(mCrednetialPriority);
|
||||
dest.writeString(mHomeSpFqdn);
|
||||
dest.writeString(mRealm);
|
||||
}
|
||||
|
||||
/** Implement the Parcelable interface {@hide} */
|
||||
public void readFromParcel(Parcel in) {
|
||||
mWifiSpFqdn = in.readString();
|
||||
mCredentialName = in.readString();
|
||||
mType = in.readString();
|
||||
mCrednetialPriority = in.readInt();
|
||||
mHomeSpFqdn = in.readString();
|
||||
mRealm = in.readString();
|
||||
}
|
||||
|
||||
/** Implement the Parcelable interface {@hide} */
|
||||
public static final Creator<WifiPasspointCredential> CREATOR =
|
||||
new Creator<WifiPasspointCredential>() {
|
||||
public WifiPasspointCredential createFromParcel(Parcel in) {
|
||||
WifiPasspointCredential pc = new WifiPasspointCredential();
|
||||
pc.mWifiSpFqdn = in.readString();
|
||||
pc.mCredentialName = in.readString();
|
||||
pc.mType = in.readString();
|
||||
pc.mCrednetialPriority = in.readInt();
|
||||
pc.mHomeSpFqdn = in.readString();
|
||||
pc.mRealm = in.readString();
|
||||
return pc;
|
||||
}
|
||||
|
||||
public WifiPasspointCredential[] newArray(int size) {
|
||||
return new WifiPasspointCredential[size];
|
||||
}
|
||||
};
|
||||
|
||||
/** @hide */
|
||||
public int compareTo(WifiPasspointCredential another) {
|
||||
|
||||
//The smaller the higher
|
||||
if (mCrednetialPriority < another.mCrednetialPriority) {
|
||||
return -1;
|
||||
} else if (mCrednetialPriority == another.mCrednetialPriority) {
|
||||
return this.mType.compareTo(another.mType);
|
||||
} else {
|
||||
return 1;
|
||||
}
|
||||
}
|
||||
|
||||
@Override
|
||||
/** @hide */
|
||||
public int hashCode() {
|
||||
int hash = 208;
|
||||
if (mType != null) {
|
||||
hash += mType.hashCode();
|
||||
}
|
||||
if (mRealm != null) {
|
||||
hash += mRealm.hashCode();
|
||||
}
|
||||
if (mHomeSpFqdn != null) {
|
||||
hash += mHomeSpFqdn.hashCode();
|
||||
}
|
||||
if (mUsername != null) {
|
||||
hash += mUsername.hashCode();
|
||||
}
|
||||
if (mPasswd != null) {
|
||||
hash += mPasswd.hashCode();
|
||||
}
|
||||
|
||||
return hash;
|
||||
}
|
||||
}
|
||||
@@ -1,19 +0,0 @@
|
||||
/**
|
||||
* Copyright (c) 2014, 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 android.net.wifi.passpoint;
|
||||
|
||||
parcelable WifiPasspointDmTree;
|
||||
File diff suppressed because it is too large
Load Diff
@@ -1,19 +0,0 @@
|
||||
/**
|
||||
* Copyright (c) 2014, 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 android.net.wifi.passpoint;
|
||||
|
||||
parcelable WifiPasspointInfo;
|
||||
@@ -1,558 +0,0 @@
|
||||
/*
|
||||
* Copyright (C) 2014 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 android.net.wifi.passpoint;
|
||||
|
||||
import android.os.Parcel;
|
||||
import android.os.Parcelable;
|
||||
|
||||
import java.util.ArrayList;
|
||||
import java.util.List;
|
||||
|
||||
public class WifiPasspointInfo implements Parcelable {
|
||||
|
||||
/** TODO doc */
|
||||
public static final int ANQP_CAPABILITY = 1 << 0;
|
||||
|
||||
/** TODO doc */
|
||||
public static final int VENUE_NAME = 1 << 1;
|
||||
|
||||
/** TODO doc */
|
||||
public static final int NETWORK_AUTH_TYPE = 1 << 2;
|
||||
|
||||
/** TODO doc */
|
||||
public static final int ROAMING_CONSORTIUM = 1 << 3;
|
||||
|
||||
/** TODO doc */
|
||||
public static final int IP_ADDR_TYPE_AVAILABILITY = 1 << 4;
|
||||
|
||||
/** TODO doc */
|
||||
public static final int NAI_REALM = 1 << 5;
|
||||
|
||||
/** TODO doc */
|
||||
public static final int CELLULAR_NETWORK = 1 << 6;
|
||||
|
||||
/** TODO doc */
|
||||
public static final int DOMAIN_NAME = 1 << 7;
|
||||
|
||||
/** TODO doc */
|
||||
public static final int HOTSPOT_CAPABILITY = 1 << 8;
|
||||
|
||||
/** TODO doc */
|
||||
public static final int OPERATOR_FRIENDLY_NAME = 1 << 9;
|
||||
|
||||
/** TODO doc */
|
||||
public static final int WAN_METRICS = 1 << 10;
|
||||
|
||||
/** TODO doc */
|
||||
public static final int CONNECTION_CAPABILITY = 1 << 11;
|
||||
|
||||
/** TODO doc */
|
||||
public static final int OSU_PROVIDER = 1 << 12;
|
||||
|
||||
/** TODO doc */
|
||||
public static final int PRESET_CRED_MATCH =
|
||||
ANQP_CAPABILITY |
|
||||
HOTSPOT_CAPABILITY |
|
||||
NAI_REALM |
|
||||
CELLULAR_NETWORK |
|
||||
DOMAIN_NAME;
|
||||
|
||||
/** TODO doc */
|
||||
public static final int PRESET_ALL =
|
||||
ANQP_CAPABILITY |
|
||||
VENUE_NAME |
|
||||
NETWORK_AUTH_TYPE |
|
||||
ROAMING_CONSORTIUM |
|
||||
IP_ADDR_TYPE_AVAILABILITY |
|
||||
NAI_REALM |
|
||||
CELLULAR_NETWORK |
|
||||
DOMAIN_NAME |
|
||||
HOTSPOT_CAPABILITY |
|
||||
OPERATOR_FRIENDLY_NAME |
|
||||
WAN_METRICS |
|
||||
CONNECTION_CAPABILITY |
|
||||
OSU_PROVIDER;
|
||||
|
||||
|
||||
public static class WanMetrics {
|
||||
public static final int STATUS_RESERVED = 0;
|
||||
public static final int STATUS_UP = 1;
|
||||
public static final int STATUS_DOWN = 2;
|
||||
public static final int STATUS_TEST = 3;
|
||||
|
||||
public int wanInfo;
|
||||
public long downlinkSpeed;
|
||||
public long uplinkSpeed;
|
||||
public int downlinkLoad;
|
||||
public int uplinkLoad;
|
||||
public int lmd;
|
||||
|
||||
public int getLinkStatus() {
|
||||
return wanInfo & 0x3;
|
||||
}
|
||||
|
||||
public boolean getSymmetricLink() {
|
||||
return (wanInfo & (1 << 2)) != 0;
|
||||
}
|
||||
|
||||
public boolean getAtCapacity() {
|
||||
return (wanInfo & (1 << 3)) != 0;
|
||||
}
|
||||
|
||||
@Override
|
||||
public String toString() {
|
||||
return wanInfo + "," + downlinkSpeed + "," + uplinkSpeed + "," +
|
||||
downlinkLoad + "," + uplinkLoad + "," + lmd;
|
||||
}
|
||||
}
|
||||
|
||||
public static class IpProtoPort {
|
||||
public static final int STATUS_CLOSED = 0;
|
||||
public static final int STATUS_OPEN = 1;
|
||||
public static final int STATUS_UNKNOWN = 2;
|
||||
|
||||
public int proto;
|
||||
public int port;
|
||||
public int status;
|
||||
|
||||
@Override
|
||||
public String toString() {
|
||||
return proto + "," + port + "," + status;
|
||||
}
|
||||
}
|
||||
|
||||
public static class NetworkAuthType {
|
||||
public static final int TYPE_TERMS_AND_CONDITION = 0;
|
||||
public static final int TYPE_ONLINE_ENROLLMENT = 1;
|
||||
public static final int TYPE_HTTP_REDIRECTION = 2;
|
||||
public static final int TYPE_DNS_REDIRECTION = 3;
|
||||
|
||||
public int type;
|
||||
public String redirectUrl;
|
||||
|
||||
@Override
|
||||
public String toString() {
|
||||
return type + "," + redirectUrl;
|
||||
}
|
||||
}
|
||||
|
||||
public static class IpAddressType {
|
||||
public static final int IPV6_NOT_AVAILABLE = 0;
|
||||
public static final int IPV6_AVAILABLE = 1;
|
||||
public static final int IPV6_UNKNOWN = 2;
|
||||
|
||||
public static final int IPV4_NOT_AVAILABLE = 0;
|
||||
public static final int IPV4_PUBLIC = 1;
|
||||
public static final int IPV4_PORT_RESTRICTED = 2;
|
||||
public static final int IPV4_SINGLE_NAT = 3;
|
||||
public static final int IPV4_DOUBLE_NAT = 4;
|
||||
public static final int IPV4_PORT_RESTRICTED_SINGLE_NAT = 5;
|
||||
public static final int IPV4_PORT_RESTRICTED_DOUBLE_NAT = 6;
|
||||
public static final int IPV4_PORT_UNKNOWN = 7;
|
||||
|
||||
private static final int NULL_VALUE = -1;
|
||||
|
||||
public int availability;
|
||||
|
||||
public int getIpv6Availability() {
|
||||
return availability & 0x3;
|
||||
}
|
||||
|
||||
public int getIpv4Availability() {
|
||||
return (availability & 0xFF) >> 2;
|
||||
}
|
||||
|
||||
@Override
|
||||
public String toString() {
|
||||
return getIpv6Availability() + "," + getIpv4Availability();
|
||||
}
|
||||
}
|
||||
|
||||
public static class NaiRealm {
|
||||
public static final int ENCODING_RFC4282 = 0;
|
||||
public static final int ENCODING_UTF8 = 1;
|
||||
|
||||
public int encoding;
|
||||
public String realm;
|
||||
|
||||
@Override
|
||||
public String toString() {
|
||||
return encoding + "," + realm;
|
||||
}
|
||||
}
|
||||
|
||||
public static class CellularNetwork {
|
||||
public String mcc;
|
||||
public String mnc;
|
||||
|
||||
@Override
|
||||
public String toString() {
|
||||
return mcc + "," + mnc;
|
||||
}
|
||||
}
|
||||
|
||||
/** BSSID */
|
||||
public String bssid;
|
||||
|
||||
/** venue name */
|
||||
public String venueName;
|
||||
|
||||
/** list of network authentication types */
|
||||
public List<NetworkAuthType> networkAuthTypeList;
|
||||
|
||||
/** list of roaming consortium OIs */
|
||||
public List<String> roamingConsortiumList;
|
||||
|
||||
/** IP address availability */
|
||||
public IpAddressType ipAddrTypeAvailability;
|
||||
|
||||
/** list of NAI realm */
|
||||
public List<NaiRealm> naiRealmList;
|
||||
|
||||
/** list of 3GPP cellular network */
|
||||
public List<CellularNetwork> cellularNetworkList;
|
||||
|
||||
/** list of fully qualified domain name (FQDN) */
|
||||
public List<String> domainNameList;
|
||||
|
||||
/** HS 2.0 operator friendly name */
|
||||
public String operatorFriendlyName;
|
||||
|
||||
/** HS 2.0 wan metrics */
|
||||
public WanMetrics wanMetrics;
|
||||
|
||||
/** list of HS 2.0 IP proto port */
|
||||
public List<IpProtoPort> connectionCapabilityList;
|
||||
|
||||
/** list of HS 2.0 OSU providers */
|
||||
public List<WifiPasspointOsuProvider> osuProviderList;
|
||||
|
||||
/**
|
||||
* Convert mask to ANQP subtypes, for supplicant command use.
|
||||
*
|
||||
* @param mask The ANQP subtypes mask.
|
||||
* @return String of ANQP subtypes, good for supplicant command use
|
||||
* @hide
|
||||
*/
|
||||
public static String toAnqpSubtypes(int mask) {
|
||||
StringBuilder sb = new StringBuilder();
|
||||
if ((mask & ANQP_CAPABILITY) != 0)
|
||||
sb.append("257,");
|
||||
if ((mask & VENUE_NAME) != 0)
|
||||
sb.append("258,");
|
||||
if ((mask & NETWORK_AUTH_TYPE) != 0)
|
||||
sb.append("260,");
|
||||
if ((mask & ROAMING_CONSORTIUM) != 0)
|
||||
sb.append("261,");
|
||||
if ((mask & IP_ADDR_TYPE_AVAILABILITY) != 0)
|
||||
sb.append("262,");
|
||||
if ((mask & NAI_REALM) != 0)
|
||||
sb.append("263,");
|
||||
if ((mask & CELLULAR_NETWORK) != 0)
|
||||
sb.append("264,");
|
||||
if ((mask & DOMAIN_NAME) != 0)
|
||||
sb.append("268,");
|
||||
if ((mask & HOTSPOT_CAPABILITY) != 0)
|
||||
sb.append("hs20:2,");
|
||||
if ((mask & OPERATOR_FRIENDLY_NAME) != 0)
|
||||
sb.append("hs20:3,");
|
||||
if ((mask & WAN_METRICS) != 0)
|
||||
sb.append("hs20:4,");
|
||||
if ((mask & CONNECTION_CAPABILITY) != 0)
|
||||
sb.append("hs20:5,");
|
||||
if ((mask & OSU_PROVIDER) != 0)
|
||||
sb.append("hs20:8,");
|
||||
if (sb.length() > 0)
|
||||
sb.deleteCharAt(sb.length() - 1);
|
||||
return sb.toString();
|
||||
}
|
||||
|
||||
@Override
|
||||
public String toString() {
|
||||
StringBuffer sb = new StringBuffer();
|
||||
|
||||
sb.append("BSSID: ").append("(").append(bssid).append(")");
|
||||
|
||||
if (venueName != null)
|
||||
sb.append(" venueName: ").append("(")
|
||||
.append(venueName.replace("\n", "\\n")).append(")");
|
||||
|
||||
if (networkAuthTypeList != null) {
|
||||
sb.append(" networkAuthType: ");
|
||||
for (NetworkAuthType auth : networkAuthTypeList)
|
||||
sb.append("(").append(auth.toString()).append(")");
|
||||
}
|
||||
|
||||
if (roamingConsortiumList != null) {
|
||||
sb.append(" roamingConsortium: ");
|
||||
for (String oi : roamingConsortiumList)
|
||||
sb.append("(").append(oi).append(")");
|
||||
}
|
||||
|
||||
if (ipAddrTypeAvailability != null) {
|
||||
sb.append(" ipAddrTypeAvaibility: ").append("(")
|
||||
.append(ipAddrTypeAvailability.toString()).append(")");
|
||||
}
|
||||
|
||||
if (naiRealmList != null) {
|
||||
sb.append(" naiRealm: ");
|
||||
for (NaiRealm realm : naiRealmList)
|
||||
sb.append("(").append(realm.toString()).append(")");
|
||||
}
|
||||
|
||||
if (cellularNetworkList != null) {
|
||||
sb.append(" cellularNetwork: ");
|
||||
for (CellularNetwork plmn : cellularNetworkList)
|
||||
sb.append("(").append(plmn.toString()).append(")");
|
||||
}
|
||||
|
||||
if (domainNameList != null) {
|
||||
sb.append(" domainName: ");
|
||||
for (String fqdn : domainNameList)
|
||||
sb.append("(").append(fqdn).append(")");
|
||||
}
|
||||
|
||||
if (operatorFriendlyName != null)
|
||||
sb.append(" operatorFriendlyName: ").append("(")
|
||||
.append(operatorFriendlyName).append(")");
|
||||
|
||||
if (wanMetrics != null)
|
||||
sb.append(" wanMetrics: ").append("(")
|
||||
.append(wanMetrics.toString()).append(")");
|
||||
|
||||
if (connectionCapabilityList != null) {
|
||||
sb.append(" connectionCapability: ");
|
||||
for (IpProtoPort ip : connectionCapabilityList)
|
||||
sb.append("(").append(ip.toString()).append(")");
|
||||
}
|
||||
|
||||
if (osuProviderList != null) {
|
||||
sb.append(" osuProviderList: ");
|
||||
for (WifiPasspointOsuProvider osu : osuProviderList)
|
||||
sb.append("(").append(osu.toString()).append(")");
|
||||
}
|
||||
|
||||
return sb.toString();
|
||||
}
|
||||
|
||||
/** Implement the Parcelable interface {@hide} */
|
||||
@Override
|
||||
public void writeToParcel(Parcel out, int flags) {
|
||||
out.writeString(bssid);
|
||||
out.writeString(venueName);
|
||||
|
||||
if (networkAuthTypeList == null) {
|
||||
out.writeInt(0);
|
||||
} else {
|
||||
out.writeInt(networkAuthTypeList.size());
|
||||
for (NetworkAuthType auth : networkAuthTypeList) {
|
||||
out.writeInt(auth.type);
|
||||
out.writeString(auth.redirectUrl);
|
||||
}
|
||||
}
|
||||
|
||||
if (roamingConsortiumList == null) {
|
||||
out.writeInt(0);
|
||||
} else {
|
||||
out.writeInt(roamingConsortiumList.size());
|
||||
for (String oi : roamingConsortiumList)
|
||||
out.writeString(oi);
|
||||
}
|
||||
|
||||
if (ipAddrTypeAvailability == null) {
|
||||
out.writeInt(IpAddressType.NULL_VALUE);
|
||||
} else {
|
||||
out.writeInt(ipAddrTypeAvailability.availability);
|
||||
}
|
||||
|
||||
if (naiRealmList == null) {
|
||||
out.writeInt(0);
|
||||
} else {
|
||||
out.writeInt(naiRealmList.size());
|
||||
for (NaiRealm realm : naiRealmList) {
|
||||
out.writeInt(realm.encoding);
|
||||
out.writeString(realm.realm);
|
||||
}
|
||||
}
|
||||
|
||||
if (cellularNetworkList == null) {
|
||||
out.writeInt(0);
|
||||
} else {
|
||||
out.writeInt(cellularNetworkList.size());
|
||||
for (CellularNetwork plmn : cellularNetworkList) {
|
||||
out.writeString(plmn.mcc);
|
||||
out.writeString(plmn.mnc);
|
||||
}
|
||||
}
|
||||
|
||||
|
||||
if (domainNameList == null) {
|
||||
out.writeInt(0);
|
||||
} else {
|
||||
out.writeInt(domainNameList.size());
|
||||
for (String fqdn : domainNameList)
|
||||
out.writeString(fqdn);
|
||||
}
|
||||
|
||||
out.writeString(operatorFriendlyName);
|
||||
|
||||
if (wanMetrics == null) {
|
||||
out.writeInt(0);
|
||||
} else {
|
||||
out.writeInt(1);
|
||||
out.writeInt(wanMetrics.wanInfo);
|
||||
out.writeLong(wanMetrics.downlinkSpeed);
|
||||
out.writeLong(wanMetrics.uplinkSpeed);
|
||||
out.writeInt(wanMetrics.downlinkLoad);
|
||||
out.writeInt(wanMetrics.uplinkLoad);
|
||||
out.writeInt(wanMetrics.lmd);
|
||||
}
|
||||
|
||||
if (connectionCapabilityList == null) {
|
||||
out.writeInt(0);
|
||||
} else {
|
||||
out.writeInt(connectionCapabilityList.size());
|
||||
for (IpProtoPort ip : connectionCapabilityList) {
|
||||
out.writeInt(ip.proto);
|
||||
out.writeInt(ip.port);
|
||||
out.writeInt(ip.status);
|
||||
}
|
||||
}
|
||||
|
||||
if (osuProviderList == null) {
|
||||
out.writeInt(0);
|
||||
} else {
|
||||
out.writeInt(osuProviderList.size());
|
||||
for (WifiPasspointOsuProvider osu : osuProviderList)
|
||||
osu.writeToParcel(out, flags);
|
||||
}
|
||||
}
|
||||
|
||||
/** Implement the Parcelable interface {@hide} */
|
||||
@Override
|
||||
public int describeContents() {
|
||||
return 0;
|
||||
}
|
||||
|
||||
/** Implement the Parcelable interface {@hide} */
|
||||
public static final Parcelable.Creator<WifiPasspointInfo> CREATOR =
|
||||
new Parcelable.Creator<WifiPasspointInfo>() {
|
||||
@Override
|
||||
public WifiPasspointInfo createFromParcel(Parcel in) {
|
||||
WifiPasspointInfo p = new WifiPasspointInfo();
|
||||
int n;
|
||||
|
||||
p.bssid = in.readString();
|
||||
p.venueName = in.readString();
|
||||
|
||||
n = in.readInt();
|
||||
if (n > 0) {
|
||||
p.networkAuthTypeList = new ArrayList<NetworkAuthType>();
|
||||
for (int i = 0; i < n; i++) {
|
||||
NetworkAuthType auth = new NetworkAuthType();
|
||||
auth.type = in.readInt();
|
||||
auth.redirectUrl = in.readString();
|
||||
p.networkAuthTypeList.add(auth);
|
||||
}
|
||||
}
|
||||
|
||||
n = in.readInt();
|
||||
if (n > 0) {
|
||||
p.roamingConsortiumList = new ArrayList<String>();
|
||||
for (int i = 0; i < n; i++)
|
||||
p.roamingConsortiumList.add(in.readString());
|
||||
}
|
||||
|
||||
n = in.readInt();
|
||||
if (n != IpAddressType.NULL_VALUE) {
|
||||
p.ipAddrTypeAvailability = new IpAddressType();
|
||||
p.ipAddrTypeAvailability.availability = n;
|
||||
}
|
||||
|
||||
n = in.readInt();
|
||||
if (n > 0) {
|
||||
p.naiRealmList = new ArrayList<NaiRealm>();
|
||||
for (int i = 0; i < n; i++) {
|
||||
NaiRealm realm = new NaiRealm();
|
||||
realm.encoding = in.readInt();
|
||||
realm.realm = in.readString();
|
||||
p.naiRealmList.add(realm);
|
||||
}
|
||||
}
|
||||
|
||||
n = in.readInt();
|
||||
if (n > 0) {
|
||||
p.cellularNetworkList = new ArrayList<CellularNetwork>();
|
||||
for (int i = 0; i < n; i++) {
|
||||
CellularNetwork plmn = new CellularNetwork();
|
||||
plmn.mcc = in.readString();
|
||||
plmn.mnc = in.readString();
|
||||
p.cellularNetworkList.add(plmn);
|
||||
}
|
||||
}
|
||||
|
||||
n = in.readInt();
|
||||
if (n > 0) {
|
||||
p.domainNameList = new ArrayList<String>();
|
||||
for (int i = 0; i < n; i++)
|
||||
p.domainNameList.add(in.readString());
|
||||
}
|
||||
|
||||
p.operatorFriendlyName = in.readString();
|
||||
|
||||
n = in.readInt();
|
||||
if (n > 0) {
|
||||
p.wanMetrics = new WanMetrics();
|
||||
p.wanMetrics.wanInfo = in.readInt();
|
||||
p.wanMetrics.downlinkSpeed = in.readLong();
|
||||
p.wanMetrics.uplinkSpeed = in.readLong();
|
||||
p.wanMetrics.downlinkLoad = in.readInt();
|
||||
p.wanMetrics.uplinkLoad = in.readInt();
|
||||
p.wanMetrics.lmd = in.readInt();
|
||||
}
|
||||
|
||||
n = in.readInt();
|
||||
if (n > 0) {
|
||||
p.connectionCapabilityList = new ArrayList<IpProtoPort>();
|
||||
for (int i = 0; i < n; i++) {
|
||||
IpProtoPort ip = new IpProtoPort();
|
||||
ip.proto = in.readInt();
|
||||
ip.port = in.readInt();
|
||||
ip.status = in.readInt();
|
||||
p.connectionCapabilityList.add(ip);
|
||||
}
|
||||
}
|
||||
|
||||
n = in.readInt();
|
||||
if (n > 0) {
|
||||
p.osuProviderList = new ArrayList<WifiPasspointOsuProvider>();
|
||||
for (int i = 0; i < n; i++) {
|
||||
WifiPasspointOsuProvider osu = WifiPasspointOsuProvider.CREATOR
|
||||
.createFromParcel(in);
|
||||
p.osuProviderList.add(osu);
|
||||
}
|
||||
}
|
||||
|
||||
return p;
|
||||
}
|
||||
|
||||
@Override
|
||||
public WifiPasspointInfo[] newArray(int size) {
|
||||
return new WifiPasspointInfo[size];
|
||||
}
|
||||
};
|
||||
}
|
||||
@@ -1,420 +0,0 @@
|
||||
/*
|
||||
* Copyright (C) 2014 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 android.net.wifi.passpoint;
|
||||
|
||||
import android.content.Context;
|
||||
import android.net.wifi.ScanResult;
|
||||
import android.os.Handler;
|
||||
import android.os.Looper;
|
||||
import android.os.Message;
|
||||
import android.os.Messenger;
|
||||
import android.os.Parcel;
|
||||
import android.os.Parcelable;
|
||||
import android.os.RemoteException;
|
||||
import android.util.Log;
|
||||
|
||||
import com.android.internal.util.AsyncChannel;
|
||||
import com.android.internal.util.Protocol;
|
||||
|
||||
import java.util.ArrayList;
|
||||
import java.util.HashMap;
|
||||
import java.util.LinkedList;
|
||||
import java.util.List;
|
||||
|
||||
/**
|
||||
* Provides APIs for managing Wifi Passpoint credentials.
|
||||
*/
|
||||
public class WifiPasspointManager {
|
||||
|
||||
private static final String TAG = "PasspointManager";
|
||||
|
||||
private static final boolean DBG = true;
|
||||
|
||||
/* Passpoint states values */
|
||||
|
||||
/** Passpoint is in an unknown state. This should only occur in boot time */
|
||||
public static final int PASSPOINT_STATE_UNKNOWN = 0;
|
||||
|
||||
/** Passpoint is disabled. This occurs when wifi is disabled */
|
||||
public static final int PASSPOINT_STATE_DISABLED = 1;
|
||||
|
||||
/** Passpoint is enabled and in discovery state */
|
||||
public static final int PASSPOINT_STATE_DISCOVERY = 2;
|
||||
|
||||
/** Passpoint is enabled and in access state */
|
||||
public static final int PASSPOINT_STATE_ACCESS = 3;
|
||||
|
||||
/** Passpoint is enabled and in provisioning state */
|
||||
public static final int PASSPOINT_STATE_PROVISION = 4;
|
||||
|
||||
/* Passpoint callback error codes */
|
||||
|
||||
/** Indicates that the operation failed due to an internal error */
|
||||
public static final int REASON_ERROR = 0;
|
||||
|
||||
/** Indicates that the operation failed because wifi is disabled */
|
||||
public static final int REASON_WIFI_DISABLED = 1;
|
||||
|
||||
/** Indicates that the operation failed because the framework is busy */
|
||||
public static final int REASON_BUSY = 2;
|
||||
|
||||
/** Indicates that the operation failed because parameter is invalid */
|
||||
public static final int REASON_INVALID_PARAMETER = 3;
|
||||
|
||||
/** Indicates that the operation failed because the server is not trusted */
|
||||
public static final int REASON_NOT_TRUSTED = 4;
|
||||
|
||||
/**
|
||||
* protocol supported for Passpoint
|
||||
*/
|
||||
public static final String PROTOCOL_DM = "OMA-DM-ClientInitiated";
|
||||
|
||||
/**
|
||||
* protocol supported for Passpoint
|
||||
*/
|
||||
public static final String PROTOCOL_SOAP = "SPP-ClientInitiated";
|
||||
|
||||
/* Passpoint broadcasts */
|
||||
|
||||
/**
|
||||
* Broadcast intent action indicating that the state of Passpoint
|
||||
* connectivity has changed
|
||||
*/
|
||||
public static final String PASSPOINT_STATE_CHANGED_ACTION =
|
||||
"android.net.wifi.passpoint.STATE_CHANGE";
|
||||
|
||||
/**
|
||||
* Broadcast intent action indicating that the saved Passpoint credential
|
||||
* list has changed
|
||||
*/
|
||||
public static final String PASSPOINT_CRED_CHANGED_ACTION =
|
||||
"android.net.wifi.passpoint.CRED_CHANGE";
|
||||
|
||||
/**
|
||||
* Broadcast intent action indicating that Passpoint online sign up is
|
||||
* avaiable.
|
||||
*/
|
||||
public static final String PASSPOINT_OSU_AVAILABLE_ACTION =
|
||||
"android.net.wifi.passpoint.OSU_AVAILABLE";
|
||||
|
||||
/**
|
||||
* Broadcast intent action indicating that user remediation is required
|
||||
*/
|
||||
public static final String PASSPOINT_USER_REM_REQ_ACTION =
|
||||
"android.net.wifi.passpoint.USER_REM_REQ";
|
||||
|
||||
/**
|
||||
* Interface for callback invocation when framework channel is lost
|
||||
*/
|
||||
public interface ChannelListener {
|
||||
/**
|
||||
* The channel to the framework has been disconnected. Application could
|
||||
* try re-initializing using {@link #initialize}
|
||||
*/
|
||||
public void onChannelDisconnected();
|
||||
}
|
||||
|
||||
/**
|
||||
* Interface for callback invocation on an application action
|
||||
*/
|
||||
public interface ActionListener {
|
||||
/** The operation succeeded */
|
||||
public void onSuccess();
|
||||
|
||||
/**
|
||||
* The operation failed
|
||||
*
|
||||
* @param reason The reason for failure could be one of
|
||||
* {@link #REASON_WIFI_DISABLED}, {@link #REASON_ERROR} or {@link #REASON_BUSY}
|
||||
*/
|
||||
public void onFailure(int reason);
|
||||
}
|
||||
|
||||
/**
|
||||
* A channel that connects the application to the wifi passpoint framework.
|
||||
* Most passpoint operations require a Channel as an argument.
|
||||
* An instance of Channel is obtained by doing a call on {@link #initialize}
|
||||
*/
|
||||
public static class Channel {
|
||||
private final static int INVALID_LISTENER_KEY = 0;
|
||||
|
||||
private ChannelListener mChannelListener;
|
||||
|
||||
private HashMap<Integer, Object> mListenerMap = new HashMap<Integer, Object>();
|
||||
private HashMap<Integer, Integer> mListenerMapCount = new HashMap<Integer, Integer>();
|
||||
private Object mListenerMapLock = new Object();
|
||||
private int mListenerKey = 0;
|
||||
|
||||
private List<ScanResult> mAnqpRequest = new LinkedList<ScanResult>();
|
||||
private Object mAnqpRequestLock = new Object();
|
||||
|
||||
private AsyncChannel mAsyncChannel;
|
||||
private PasspointHandler mHandler;
|
||||
Context mContext;
|
||||
|
||||
Channel(Context context, Looper looper, ChannelListener l) {
|
||||
mAsyncChannel = new AsyncChannel();
|
||||
mHandler = new PasspointHandler(looper);
|
||||
mChannelListener = l;
|
||||
mContext = context;
|
||||
}
|
||||
|
||||
private int putListener(Object listener) {
|
||||
return putListener(listener, 1);
|
||||
}
|
||||
|
||||
private int putListener(Object listener, int count) {
|
||||
if (listener == null || count <= 0)
|
||||
return INVALID_LISTENER_KEY;
|
||||
int key;
|
||||
synchronized (mListenerMapLock) {
|
||||
do {
|
||||
key = mListenerKey++;
|
||||
} while (key == INVALID_LISTENER_KEY);
|
||||
mListenerMap.put(key, listener);
|
||||
mListenerMapCount.put(key, count);
|
||||
}
|
||||
return key;
|
||||
}
|
||||
|
||||
private Object peekListener(int key) {
|
||||
Log.d(TAG, "peekListener() key=" + key);
|
||||
if (key == INVALID_LISTENER_KEY)
|
||||
return null;
|
||||
synchronized (mListenerMapLock) {
|
||||
return mListenerMap.get(key);
|
||||
}
|
||||
}
|
||||
|
||||
|
||||
private Object getListener(int key, boolean forceRemove) {
|
||||
Log.d(TAG, "getListener() key=" + key + " force=" + forceRemove);
|
||||
if (key == INVALID_LISTENER_KEY)
|
||||
return null;
|
||||
synchronized (mListenerMapLock) {
|
||||
if (!forceRemove) {
|
||||
int count = mListenerMapCount.get(key);
|
||||
Log.d(TAG, "count=" + count);
|
||||
mListenerMapCount.put(key, --count);
|
||||
if (count > 0)
|
||||
return null;
|
||||
}
|
||||
Log.d(TAG, "remove key");
|
||||
mListenerMapCount.remove(key);
|
||||
return mListenerMap.remove(key);
|
||||
}
|
||||
}
|
||||
|
||||
private void anqpRequestStart(ScanResult sr) {
|
||||
Log.d(TAG, "anqpRequestStart sr.bssid=" + sr.BSSID);
|
||||
synchronized (mAnqpRequestLock) {
|
||||
mAnqpRequest.add(sr);
|
||||
}
|
||||
}
|
||||
|
||||
private void anqpRequestFinish(WifiPasspointInfo result) {
|
||||
Log.d(TAG, "anqpRequestFinish pi.bssid=" + result.bssid);
|
||||
synchronized (mAnqpRequestLock) {
|
||||
for (ScanResult sr : mAnqpRequest)
|
||||
if (sr.BSSID.equals(result.bssid)) {
|
||||
Log.d(TAG, "find hit " + result.bssid);
|
||||
sr.passpoint = result;
|
||||
mAnqpRequest.remove(sr);
|
||||
Log.d(TAG, "mAnqpRequest.len=" + mAnqpRequest.size());
|
||||
break;
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
private void anqpRequestFinish(ScanResult sr) {
|
||||
Log.d(TAG, "anqpRequestFinish sr.bssid=" + sr.BSSID);
|
||||
synchronized (mAnqpRequestLock) {
|
||||
for (ScanResult sr1 : mAnqpRequest)
|
||||
if (sr1.BSSID.equals(sr.BSSID)) {
|
||||
mAnqpRequest.remove(sr1);
|
||||
break;
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
class PasspointHandler extends Handler {
|
||||
PasspointHandler(Looper looper) {
|
||||
super(looper);
|
||||
}
|
||||
|
||||
@Override
|
||||
public void handleMessage(Message message) {
|
||||
Object listener = null;
|
||||
|
||||
switch (message.what) {
|
||||
case AsyncChannel.CMD_CHANNEL_DISCONNECTED:
|
||||
if (mChannelListener != null) {
|
||||
mChannelListener.onChannelDisconnected();
|
||||
mChannelListener = null;
|
||||
}
|
||||
break;
|
||||
|
||||
case REQUEST_ANQP_INFO_SUCCEEDED:
|
||||
WifiPasspointInfo result = (WifiPasspointInfo) message.obj;
|
||||
anqpRequestFinish(result);
|
||||
listener = getListener(message.arg2, false);
|
||||
if (listener != null) {
|
||||
((ActionListener) listener).onSuccess();
|
||||
}
|
||||
break;
|
||||
|
||||
case REQUEST_ANQP_INFO_FAILED:
|
||||
anqpRequestFinish((ScanResult) message.obj);
|
||||
listener = getListener(message.arg2, false);
|
||||
if (listener == null)
|
||||
getListener(message.arg2, true);
|
||||
if (listener != null) {
|
||||
((ActionListener) listener).onFailure(message.arg1);
|
||||
}
|
||||
break;
|
||||
|
||||
default:
|
||||
Log.d(TAG, "Ignored " + message);
|
||||
break;
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
}
|
||||
|
||||
public static class ParcelableString implements Parcelable {
|
||||
public String string;
|
||||
|
||||
@Override
|
||||
public int describeContents() {
|
||||
return 0;
|
||||
}
|
||||
|
||||
@Override
|
||||
public void writeToParcel(Parcel out, int flags) {
|
||||
out.writeString(string);
|
||||
}
|
||||
|
||||
public static final Parcelable.Creator<ParcelableString> CREATOR =
|
||||
new Parcelable.Creator<ParcelableString>() {
|
||||
@Override
|
||||
public ParcelableString createFromParcel(Parcel in) {
|
||||
ParcelableString ret = new ParcelableString();
|
||||
ret.string = in.readString();
|
||||
return ret;
|
||||
}
|
||||
@Override
|
||||
public ParcelableString[] newArray(int size) {
|
||||
return new ParcelableString[size];
|
||||
}
|
||||
};
|
||||
}
|
||||
|
||||
private static final int BASE = Protocol.BASE_WIFI_PASSPOINT_MANAGER;
|
||||
|
||||
public static final int REQUEST_ANQP_INFO = BASE + 1;
|
||||
public static final int REQUEST_ANQP_INFO_FAILED = BASE + 2;
|
||||
public static final int REQUEST_ANQP_INFO_SUCCEEDED = BASE + 3;
|
||||
public static final int REQUEST_OSU_ICON = BASE + 4;
|
||||
public static final int REQUEST_OSU_ICON_FAILED = BASE + 5;
|
||||
public static final int REQUEST_OSU_ICON_SUCCEEDED = BASE + 6;
|
||||
public static final int START_OSU = BASE + 7;
|
||||
public static final int START_OSU_BROWSER = BASE + 8;
|
||||
public static final int START_OSU_FAILED = BASE + 9;
|
||||
public static final int START_OSU_SUCCEEDED = BASE + 10;
|
||||
|
||||
private Context mContext;
|
||||
IWifiPasspointManager mService;
|
||||
|
||||
/**
|
||||
* TODO: doc
|
||||
* @param context
|
||||
* @param service
|
||||
*/
|
||||
public WifiPasspointManager(Context context, IWifiPasspointManager service) {
|
||||
mContext = context;
|
||||
mService = service;
|
||||
}
|
||||
|
||||
/**
|
||||
* Registers the application with the framework. This function must be the
|
||||
* first to be called before any async passpoint operations are performed.
|
||||
*
|
||||
* @param srcContext is the context of the source
|
||||
* @param srcLooper is the Looper on which the callbacks are receivied
|
||||
* @param listener for callback at loss of framework communication. Can be
|
||||
* null.
|
||||
* @return Channel instance that is necessary for performing any further
|
||||
* passpoint operations
|
||||
*
|
||||
*/
|
||||
public Channel initialize(Context srcContext, Looper srcLooper, ChannelListener listener) {
|
||||
Messenger messenger = getMessenger();
|
||||
if (messenger == null)
|
||||
return null;
|
||||
|
||||
Channel c = new Channel(srcContext, srcLooper, listener);
|
||||
if (c.mAsyncChannel.connectSync(srcContext, c.mHandler, messenger)
|
||||
== AsyncChannel.STATUS_SUCCESSFUL) {
|
||||
return c;
|
||||
} else {
|
||||
return null;
|
||||
}
|
||||
}
|
||||
|
||||
/**
|
||||
* STOPSHIP: temp solution, should use supplicant manager instead, check
|
||||
* with b/13931972
|
||||
*/
|
||||
public Messenger getMessenger() {
|
||||
try {
|
||||
return mService.getMessenger();
|
||||
} catch (RemoteException e) {
|
||||
return null;
|
||||
}
|
||||
}
|
||||
|
||||
public void requestAnqpInfo(Channel c, List<ScanResult> requested, int mask,
|
||||
ActionListener listener) {
|
||||
Log.d(TAG, "requestAnqpInfo start");
|
||||
Log.d(TAG, "requested.size=" + requested.size());
|
||||
checkChannel(c);
|
||||
List<ScanResult> list = new ArrayList<ScanResult>();
|
||||
for (ScanResult sr : requested)
|
||||
if (sr.capabilities.contains("[HS20]")) {
|
||||
list.add(sr);
|
||||
c.anqpRequestStart(sr);
|
||||
Log.d(TAG, "adding " + sr.BSSID);
|
||||
}
|
||||
int count = list.size();
|
||||
Log.d(TAG, "after filter, count=" + count);
|
||||
if (count == 0) {
|
||||
if (DBG)
|
||||
Log.d(TAG, "ANQP info request contains no HS20 APs, skipped");
|
||||
listener.onSuccess();
|
||||
return;
|
||||
}
|
||||
int key = c.putListener(listener, count);
|
||||
for (ScanResult sr : list)
|
||||
c.mAsyncChannel.sendMessage(REQUEST_ANQP_INFO, mask, key, sr);
|
||||
Log.d(TAG, "requestAnqpInfo end");
|
||||
}
|
||||
|
||||
private static void checkChannel(Channel c) {
|
||||
if (c == null) throw new IllegalArgumentException("Channel needs to be initialized");
|
||||
}
|
||||
}
|
||||
@@ -1,19 +0,0 @@
|
||||
/**
|
||||
* Copyright (c) 2014, 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 android.net.wifi.passpoint;
|
||||
|
||||
parcelable WifiPasspointOsuProvider;
|
||||
@@ -1,152 +0,0 @@
|
||||
/*
|
||||
* Copyright (C) 2014 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 android.net.wifi.passpoint;
|
||||
|
||||
import android.os.Parcel;
|
||||
import android.os.Parcelable;
|
||||
|
||||
/** @hide */
|
||||
public class WifiPasspointOsuProvider implements Parcelable {
|
||||
|
||||
/** TODO: doc
|
||||
* @hide
|
||||
*/
|
||||
public static final int OSU_METHOD_UNKNOWN = -1;
|
||||
|
||||
/** TODO: doc
|
||||
* @hide
|
||||
*/
|
||||
public static final int OSU_METHOD_OMADM = 0;
|
||||
|
||||
/** TODO: doc
|
||||
* @hide
|
||||
*/
|
||||
public static final int OSU_METHOD_SOAP = 1;
|
||||
|
||||
/** TODO: doc */
|
||||
public String ssid;
|
||||
|
||||
/** TODO: doc */
|
||||
public String friendlyName;
|
||||
|
||||
/** TODO: doc
|
||||
* @hide
|
||||
*/
|
||||
public String serverUri;
|
||||
|
||||
/** TODO: doc
|
||||
* @hide
|
||||
*/
|
||||
public int osuMethod = OSU_METHOD_UNKNOWN;
|
||||
|
||||
/** TODO: doc */
|
||||
public int iconWidth;
|
||||
|
||||
/** TODO: doc */
|
||||
public int iconHeight;
|
||||
|
||||
/** TODO: doc */
|
||||
public String iconType;
|
||||
|
||||
/** TODO: doc */
|
||||
public String iconFileName;
|
||||
|
||||
/** TODO: doc */
|
||||
public Object icon; // TODO: should change to image format
|
||||
|
||||
/** TODO: doc */
|
||||
public String osuNai;
|
||||
|
||||
/** TODO: doc */
|
||||
public String osuService;
|
||||
|
||||
/** default constructor @hide */
|
||||
public WifiPasspointOsuProvider() {
|
||||
// TODO
|
||||
}
|
||||
|
||||
/** copy constructor @hide */
|
||||
public WifiPasspointOsuProvider(WifiPasspointOsuProvider source) {
|
||||
// TODO
|
||||
}
|
||||
|
||||
@Override
|
||||
public String toString() {
|
||||
StringBuffer sb = new StringBuffer();
|
||||
sb.append("SSID: ").append("<").append(ssid).append(">");
|
||||
if (friendlyName != null)
|
||||
sb.append(" friendlyName: ").append("<").append(friendlyName).append(">");
|
||||
if (serverUri != null)
|
||||
sb.append(" serverUri: ").append("<").append(serverUri).append(">");
|
||||
sb.append(" osuMethod: ").append("<").append(osuMethod).append(">");
|
||||
if (iconFileName != null) {
|
||||
sb.append(" icon: <").append(iconWidth).append("x")
|
||||
.append(iconHeight).append(" ")
|
||||
.append(iconType).append(" ")
|
||||
.append(iconFileName).append(">");
|
||||
}
|
||||
if (osuNai != null)
|
||||
sb.append(" osuNai: ").append("<").append(osuNai).append(">");
|
||||
if (osuService != null)
|
||||
sb.append(" osuService: ").append("<").append(osuService).append(">");
|
||||
return sb.toString();
|
||||
}
|
||||
|
||||
@Override
|
||||
public int describeContents() {
|
||||
return 0;
|
||||
}
|
||||
|
||||
@Override
|
||||
public void writeToParcel(Parcel out, int flags) {
|
||||
out.writeString(ssid);
|
||||
out.writeString(friendlyName);
|
||||
out.writeString(serverUri);
|
||||
out.writeInt(osuMethod);
|
||||
out.writeInt(iconWidth);
|
||||
out.writeInt(iconHeight);
|
||||
out.writeString(iconType);
|
||||
out.writeString(iconFileName);
|
||||
out.writeString(osuNai);
|
||||
out.writeString(osuService);
|
||||
// TODO: icon image?
|
||||
}
|
||||
|
||||
public static final Parcelable.Creator<WifiPasspointOsuProvider> CREATOR =
|
||||
new Parcelable.Creator<WifiPasspointOsuProvider>() {
|
||||
@Override
|
||||
public WifiPasspointOsuProvider createFromParcel(Parcel in) {
|
||||
WifiPasspointOsuProvider osu = new WifiPasspointOsuProvider();
|
||||
osu.ssid = in.readString();
|
||||
osu.friendlyName = in.readString();
|
||||
osu.serverUri = in.readString();
|
||||
osu.osuMethod = in.readInt();
|
||||
osu.iconWidth = in.readInt();
|
||||
osu.iconHeight = in.readInt();
|
||||
osu.iconType = in.readString();
|
||||
osu.iconFileName = in.readString();
|
||||
osu.osuNai = in.readString();
|
||||
osu.osuService = in.readString();
|
||||
return osu;
|
||||
}
|
||||
|
||||
@Override
|
||||
public WifiPasspointOsuProvider[] newArray(int size) {
|
||||
return new WifiPasspointOsuProvider[size];
|
||||
}
|
||||
};
|
||||
}
|
||||
@@ -1,19 +0,0 @@
|
||||
/**
|
||||
* Copyright (c) 2014, 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 android.net.wifi.passpoint;
|
||||
|
||||
parcelable WifiPasspointPolicy;
|
||||
@@ -1,386 +0,0 @@
|
||||
/*
|
||||
* Copyright (C) 2014 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 android.net.wifi.passpoint;
|
||||
|
||||
import android.net.wifi.WifiConfiguration;
|
||||
import android.net.wifi.ScanResult;
|
||||
import android.os.Parcelable;
|
||||
import android.os.Parcel;
|
||||
import android.security.Credentials;
|
||||
import android.util.Log;
|
||||
|
||||
import java.lang.reflect.Field;
|
||||
import java.lang.reflect.Method;
|
||||
import java.util.List;
|
||||
|
||||
|
||||
/** @hide */
|
||||
public class WifiPasspointPolicy implements Parcelable {
|
||||
|
||||
private final static String TAG = "PasspointPolicy";
|
||||
|
||||
/** @hide */
|
||||
public static final int HOME_SP = 0;
|
||||
|
||||
/** @hide */
|
||||
public static final int ROAMING_PARTNER = 1;
|
||||
|
||||
/** @hide */
|
||||
public static final int UNRESTRICTED = 2;
|
||||
|
||||
private String mName;
|
||||
private int mCredentialPriority;
|
||||
private int mRoamingPriority;
|
||||
private String mBssid;
|
||||
private String mSsid;
|
||||
private WifiPasspointCredential mCredential;
|
||||
private int mRestriction;// Permitted values are "HomeSP", "RoamingPartner", or "Unrestricted"
|
||||
private boolean mIsHomeSp;
|
||||
|
||||
private final String INT_PRIVATE_KEY = "private_key";
|
||||
private final String INT_PHASE2 = "phase2";
|
||||
private final String INT_PASSWORD = "password";
|
||||
private final String INT_IDENTITY = "identity";
|
||||
private final String INT_EAP = "eap";
|
||||
private final String INT_CLIENT_CERT = "client_cert";
|
||||
private final String INT_CA_CERT = "ca_cert";
|
||||
private final String INT_ANONYMOUS_IDENTITY = "anonymous_identity";
|
||||
private final String INT_SIM_SLOT = "sim_slot";
|
||||
private final String INT_ENTERPRISEFIELD_NAME ="android.net.wifi.WifiConfiguration$EnterpriseField";
|
||||
private final String ISO8601DATEFORMAT = "yyyy-MM-dd'T'HH:mm:ss'Z'";
|
||||
private final String ENTERPRISE_PHASE2_MSCHAPV2 = "auth=MSCHAPV2";
|
||||
private final String ENTERPRISE_PHASE2_MSCHAP = "auth=MSCHAP";
|
||||
|
||||
/** @hide */
|
||||
public WifiPasspointPolicy(String name, String ssid,
|
||||
String bssid, WifiPasspointCredential pc,
|
||||
int restriction, boolean ishomesp) {
|
||||
mName = name;
|
||||
if (pc != null) {
|
||||
mCredentialPriority = pc.getPriority();
|
||||
}
|
||||
//PerProviderSubscription/<X+>/Policy/PreferredRoamingPartnerList/<X+>/Priority
|
||||
mRoamingPriority = 128; //default priority value of 128
|
||||
mSsid = ssid;
|
||||
mCredential = pc;
|
||||
mBssid = bssid;
|
||||
mRestriction = restriction;
|
||||
mIsHomeSp = ishomesp;
|
||||
}
|
||||
|
||||
public String getSsid() {
|
||||
return mSsid;
|
||||
}
|
||||
|
||||
/** @hide */
|
||||
public void setBssid(String bssid) {
|
||||
mBssid = bssid;
|
||||
}
|
||||
|
||||
public String getBssid() {
|
||||
return mBssid;
|
||||
}
|
||||
|
||||
/** @hide */
|
||||
public void setRestriction(int r) {
|
||||
mRestriction = r;
|
||||
}
|
||||
|
||||
/** @hide */
|
||||
public int getRestriction() {
|
||||
return mRestriction;
|
||||
}
|
||||
|
||||
/** @hide */
|
||||
public void setHomeSp(boolean b) {
|
||||
mIsHomeSp = b;
|
||||
}
|
||||
|
||||
/** @hide */
|
||||
public boolean isHomeSp() {
|
||||
return mIsHomeSp;
|
||||
}
|
||||
|
||||
/** @hide */
|
||||
public void setCredential(WifiPasspointCredential newCredential) {
|
||||
mCredential = newCredential;
|
||||
}
|
||||
|
||||
public WifiPasspointCredential getCredential() {
|
||||
// TODO: return a copy
|
||||
return mCredential;
|
||||
}
|
||||
|
||||
/** @hide */
|
||||
public void setCredentialPriority(int priority) {
|
||||
mCredentialPriority = priority;
|
||||
}
|
||||
|
||||
/** @hide */
|
||||
public void setRoamingPriority(int priority) {
|
||||
mRoamingPriority = priority;
|
||||
}
|
||||
|
||||
public int getCredentialPriority() {
|
||||
return mCredentialPriority;
|
||||
}
|
||||
|
||||
public int getRoamingPriority() {
|
||||
return mRoamingPriority;
|
||||
}
|
||||
|
||||
public WifiConfiguration createWifiConfiguration() {
|
||||
WifiConfiguration wfg = new WifiConfiguration();
|
||||
if (mBssid != null) {
|
||||
Log.d(TAG, "create bssid:" + mBssid);
|
||||
wfg.BSSID = mBssid;
|
||||
}
|
||||
|
||||
if (mSsid != null) {
|
||||
Log.d(TAG, "create ssid:" + mSsid);
|
||||
wfg.SSID = mSsid;
|
||||
}
|
||||
//TODO: 1. add pmf configuration
|
||||
// 2. add ocsp configuration
|
||||
// 3. add eap-sim configuration
|
||||
/*Key management*/
|
||||
wfg.status = WifiConfiguration.Status.ENABLED;
|
||||
wfg.allowedKeyManagement.clear();
|
||||
wfg.allowedKeyManagement.set(WifiConfiguration.KeyMgmt.WPA_EAP);
|
||||
wfg.allowedKeyManagement.set(WifiConfiguration.KeyMgmt.IEEE8021X);
|
||||
|
||||
/*Group Ciphers*/
|
||||
wfg.allowedGroupCiphers.clear();
|
||||
wfg.allowedPairwiseCiphers.set(WifiConfiguration.PairwiseCipher.CCMP);
|
||||
wfg.allowedPairwiseCiphers.set(WifiConfiguration.PairwiseCipher.TKIP);
|
||||
|
||||
/*Protocols*/
|
||||
wfg.allowedProtocols.clear();
|
||||
wfg.allowedProtocols.set(WifiConfiguration.Protocol.RSN);
|
||||
wfg.allowedProtocols.set(WifiConfiguration.Protocol.WPA);
|
||||
|
||||
Class[] enterpriseFieldArray = WifiConfiguration.class.getClasses();
|
||||
Class<?> enterpriseFieldClass = null;
|
||||
|
||||
|
||||
for(Class<?> myClass : enterpriseFieldArray) {
|
||||
if(myClass.getName().equals(INT_ENTERPRISEFIELD_NAME)) {
|
||||
enterpriseFieldClass = myClass;
|
||||
break;
|
||||
}
|
||||
}
|
||||
Log.d(TAG, "class chosen " + enterpriseFieldClass.getName() );
|
||||
|
||||
|
||||
Field anonymousId = null, caCert = null, clientCert = null,
|
||||
eap = null, identity = null, password = null,
|
||||
phase2 = null, privateKey = null;
|
||||
|
||||
Field[] fields = WifiConfiguration.class.getFields();
|
||||
|
||||
|
||||
for (Field tempField : fields) {
|
||||
if (tempField.getName().trim().equals(INT_ANONYMOUS_IDENTITY)) {
|
||||
anonymousId = tempField;
|
||||
Log.d(TAG, "field " + anonymousId.getName() );
|
||||
} else if (tempField.getName().trim().equals(INT_CA_CERT)) {
|
||||
caCert = tempField;
|
||||
} else if (tempField.getName().trim().equals(INT_CLIENT_CERT)) {
|
||||
clientCert = tempField;
|
||||
Log.d(TAG, "field " + clientCert.getName() );
|
||||
} else if (tempField.getName().trim().equals(INT_EAP)) {
|
||||
eap = tempField;
|
||||
Log.d(TAG, "field " + eap.getName() );
|
||||
} else if (tempField.getName().trim().equals(INT_IDENTITY)) {
|
||||
identity = tempField;
|
||||
Log.d(TAG, "field " + identity.getName() );
|
||||
} else if (tempField.getName().trim().equals(INT_PASSWORD)) {
|
||||
password = tempField;
|
||||
Log.d(TAG, "field " + password.getName() );
|
||||
} else if (tempField.getName().trim().equals(INT_PHASE2)) {
|
||||
phase2 = tempField;
|
||||
Log.d(TAG, "field " + phase2.getName() );
|
||||
|
||||
} else if (tempField.getName().trim().equals(INT_PRIVATE_KEY)) {
|
||||
privateKey = tempField;
|
||||
}
|
||||
}
|
||||
|
||||
|
||||
Method setValue = null;
|
||||
|
||||
for(Method m: enterpriseFieldClass.getMethods()) {
|
||||
if(m.getName().trim().equals("setValue")) {
|
||||
Log.d(TAG, "method " + m.getName() );
|
||||
setValue = m;
|
||||
break;
|
||||
}
|
||||
}
|
||||
|
||||
try {
|
||||
// EAP
|
||||
String eapmethod = mCredential.getType();
|
||||
Log.d(TAG, "eapmethod:" + eapmethod);
|
||||
setValue.invoke(eap.get(wfg), eapmethod);
|
||||
|
||||
// Username, password, EAP Phase 2
|
||||
if ("TTLS".equals(eapmethod)) {
|
||||
setValue.invoke(phase2.get(wfg), ENTERPRISE_PHASE2_MSCHAPV2);
|
||||
setValue.invoke(identity.get(wfg), mCredential.getUserName());
|
||||
setValue.invoke(password.get(wfg), mCredential.getPassword());
|
||||
setValue.invoke(anonymousId.get(wfg), "anonymous@" + mCredential.getRealm());
|
||||
}
|
||||
|
||||
// EAP CA Certificate
|
||||
String cacertificate = null;
|
||||
String rootCA = mCredential.getCaRootCertPath();
|
||||
if (rootCA == null){
|
||||
cacertificate = null;
|
||||
} else {
|
||||
cacertificate = "keystore://" + Credentials.WIFI + "HS20" + Credentials.CA_CERTIFICATE + rootCA;
|
||||
}
|
||||
Log.d(TAG, "cacertificate:" + cacertificate);
|
||||
setValue.invoke(caCert.get(wfg), cacertificate);
|
||||
|
||||
//User certificate
|
||||
if ("TLS".equals(eapmethod)) {
|
||||
String usercertificate = null;
|
||||
String privatekey = null;
|
||||
String clientCertPath = mCredential.getClientCertPath();
|
||||
if (clientCertPath != null){
|
||||
privatekey = "keystore://" + Credentials.WIFI + "HS20" + Credentials.USER_PRIVATE_KEY + clientCertPath;
|
||||
usercertificate = "keystore://" + Credentials.WIFI + "HS20" + Credentials.USER_CERTIFICATE + clientCertPath;
|
||||
}
|
||||
Log.d(TAG, "privatekey:" + privatekey);
|
||||
Log.d(TAG, "usercertificate:" + usercertificate);
|
||||
if (privatekey != null && usercertificate != null) {
|
||||
setValue.invoke(privateKey.get(wfg), privatekey);
|
||||
setValue.invoke(clientCert.get(wfg), usercertificate);
|
||||
}
|
||||
}
|
||||
} catch (Exception e) {
|
||||
Log.d(TAG, "createWifiConfiguration err:" + e);
|
||||
}
|
||||
|
||||
return wfg;
|
||||
}
|
||||
|
||||
/** {@inheritDoc} @hide */
|
||||
public int compareTo(WifiPasspointPolicy another) {
|
||||
Log.d(TAG, "this:" + this);
|
||||
Log.d(TAG, "another:" + another);
|
||||
|
||||
if (another == null) {
|
||||
return -1;
|
||||
} else if (this.mIsHomeSp == true && another.isHomeSp() == false) {
|
||||
//home sp priority is higher then roaming
|
||||
Log.d(TAG, "compare HomeSP first, this is HomeSP, another isn't");
|
||||
return -1;
|
||||
} else if ((this.mIsHomeSp == true && another.isHomeSp() == true)) {
|
||||
Log.d(TAG, "both HomeSP");
|
||||
//if both home sp, compare credential priority
|
||||
if (this.mCredentialPriority < another.getCredentialPriority()) {
|
||||
Log.d(TAG, "this priority is higher");
|
||||
return -1;
|
||||
} else if (this.mCredentialPriority == another.getCredentialPriority()) {
|
||||
Log.d(TAG, "both priorities equal");
|
||||
//if priority still the same, compare name(ssid)
|
||||
if (this.mName.compareTo(another.mName) != 0) {
|
||||
Log.d(TAG, "compare mName return:" + this.mName.compareTo(another.mName));
|
||||
return this.mName.compareTo(another.mName);
|
||||
}
|
||||
/**
|
||||
*if name still the same, compare credential
|
||||
*the device may has two more credentials(TLS,SIM..etc)
|
||||
*it can associate to one AP(same ssid). so we should compare by credential
|
||||
*/
|
||||
if (this.mCredential != null && another.mCredential != null) {
|
||||
if (this.mCredential.compareTo(another.mCredential) != 0) {
|
||||
Log.d(TAG,
|
||||
"compare mCredential return:" + this.mName.compareTo(another.mName));
|
||||
return this.mCredential.compareTo(another.mCredential);
|
||||
}
|
||||
}
|
||||
} else {
|
||||
return 1;
|
||||
}
|
||||
} else if ((this.mIsHomeSp == false && another.isHomeSp() == false)) {
|
||||
Log.d(TAG, "both RoamingSp");
|
||||
//if both roaming sp, compare roaming priority(preferredRoamingPartnerList/<X+>/priority)
|
||||
if (this.mRoamingPriority < another.getRoamingPriority()) {
|
||||
Log.d(TAG, "this priority is higher");
|
||||
return -1;
|
||||
} else if (this.mRoamingPriority == another.getRoamingPriority()) {//priority equals, compare name
|
||||
Log.d(TAG, "both priorities equal");
|
||||
//if priority still the same, compare name(ssid)
|
||||
if (this.mName.compareTo(another.mName) != 0) {
|
||||
Log.d(TAG, "compare mName return:" + this.mName.compareTo(another.mName));
|
||||
return this.mName.compareTo(another.mName);
|
||||
}
|
||||
//if name still the same, compare credential
|
||||
if (this.mCredential != null && another.mCredential != null) {
|
||||
if (this.mCredential.compareTo(another.mCredential) != 0) {
|
||||
Log.d(TAG,
|
||||
"compare mCredential return:"
|
||||
+ this.mCredential.compareTo(another.mCredential));
|
||||
return this.mCredential.compareTo(another.mCredential);
|
||||
}
|
||||
}
|
||||
} else {
|
||||
return 1;
|
||||
}
|
||||
}
|
||||
|
||||
Log.d(TAG, "both policies equal");
|
||||
return 0;
|
||||
}
|
||||
|
||||
@Override
|
||||
/** @hide */
|
||||
public String toString() {
|
||||
return "PasspointPolicy: name=" + mName + " CredentialPriority=" + mCredentialPriority +
|
||||
" mRoamingPriority" + mRoamingPriority +
|
||||
" ssid=" + mSsid + " restriction=" + mRestriction +
|
||||
" ishomesp=" + mIsHomeSp + " Credential=" + mCredential;
|
||||
}
|
||||
|
||||
/** Implement the Parcelable interface {@hide} */
|
||||
@Override
|
||||
public int describeContents() {
|
||||
return 0;
|
||||
}
|
||||
|
||||
/** Implement the Parcelable interface {@hide} */
|
||||
@Override
|
||||
public void writeToParcel(Parcel dest, int flags) {
|
||||
// TODO
|
||||
}
|
||||
|
||||
/** Implement the Parcelable interface {@hide} */
|
||||
public static final Creator<WifiPasspointPolicy> CREATOR =
|
||||
new Creator<WifiPasspointPolicy>() {
|
||||
@Override
|
||||
public WifiPasspointPolicy createFromParcel(Parcel in) {
|
||||
return null;
|
||||
}
|
||||
|
||||
@Override
|
||||
public WifiPasspointPolicy[] newArray(int size) {
|
||||
return new WifiPasspointPolicy[size];
|
||||
}
|
||||
};
|
||||
}
|
||||
Reference in New Issue
Block a user