Restart Wi-Fi tethering automatically if configuration change
- When the Wi-Fi Hotspot is already started, if the user changes the configuration, the Wi-Fi Hotspot will be restarted automatically. - When the Wi-Fi hotspot restarts, display a circle on the screen to indicate that it is processing. Bug: 245258763 Test: manual test atest -c WifiTetherSettingsTest \ WifiHotspotSpeedSettingsTest atest -c WifiHotspotRepositoryTest \ WifiHotspotSecuritySettingsTest \ WifiHotspotSecurityViewModelTest \ WifiHotspotSpeedViewModelTest \ WifiTetherViewModelTest Change-Id: I6fdd5892916703095f28d0589ebc3b7dd59fcd61
This commit is contained in:
@@ -18,6 +18,7 @@ package com.android.settings.wifi.factory;
|
||||
|
||||
import android.annotation.Nullable;
|
||||
import android.content.Context;
|
||||
import android.net.TetheringManager;
|
||||
import android.net.wifi.WifiManager;
|
||||
import android.util.Log;
|
||||
|
||||
@@ -40,6 +41,7 @@ public class WifiFeatureProvider {
|
||||
|
||||
private final Context mAppContext;
|
||||
private WifiManager mWifiManager;
|
||||
private TetheringManager mTetheringManager;
|
||||
private WifiVerboseLogging mWifiVerboseLogging;
|
||||
private WifiHotspotRepository mWifiHotspotRepository;
|
||||
|
||||
@@ -48,7 +50,7 @@ public class WifiFeatureProvider {
|
||||
}
|
||||
|
||||
/**
|
||||
* Get WifiManager
|
||||
* Gets WifiManager
|
||||
*/
|
||||
public WifiManager getWifiManager() {
|
||||
if (mWifiManager == null) {
|
||||
@@ -58,7 +60,18 @@ public class WifiFeatureProvider {
|
||||
}
|
||||
|
||||
/**
|
||||
* Get WifiVerboseLogging
|
||||
* Gets TetheringManager
|
||||
*/
|
||||
public TetheringManager getTetheringManager() {
|
||||
if (mTetheringManager == null) {
|
||||
mTetheringManager = mAppContext.getSystemService(TetheringManager.class);
|
||||
verboseLog(TAG, "getTetheringManager():" + mTetheringManager);
|
||||
}
|
||||
return mTetheringManager;
|
||||
}
|
||||
|
||||
/**
|
||||
* Gets WifiVerboseLogging
|
||||
*/
|
||||
public WifiVerboseLogging getWifiVerboseLogging() {
|
||||
if (mWifiVerboseLogging == null) {
|
||||
@@ -68,25 +81,26 @@ public class WifiFeatureProvider {
|
||||
}
|
||||
|
||||
/**
|
||||
* Get WifiHotspotRepository
|
||||
* Gets WifiHotspotRepository
|
||||
*/
|
||||
public WifiHotspotRepository getWifiHotspotRepository() {
|
||||
if (mWifiHotspotRepository == null) {
|
||||
mWifiHotspotRepository = new WifiHotspotRepository(mAppContext, getWifiManager());
|
||||
mWifiHotspotRepository = new WifiHotspotRepository(mAppContext, getWifiManager(),
|
||||
getTetheringManager());
|
||||
verboseLog(TAG, "getWifiHotspotRepository():" + mWifiHotspotRepository);
|
||||
}
|
||||
return mWifiHotspotRepository;
|
||||
}
|
||||
|
||||
/**
|
||||
* Get WifiTetherViewModel
|
||||
* Gets WifiTetherViewModel
|
||||
*/
|
||||
public WifiTetherViewModel getWifiTetherViewModel(@NotNull ViewModelStoreOwner owner) {
|
||||
return new ViewModelProvider(owner).get(WifiTetherViewModel.class);
|
||||
}
|
||||
|
||||
/**
|
||||
* Get WifiHotspotSecurityViewModel
|
||||
* Gets WifiHotspotSecurityViewModel
|
||||
*/
|
||||
public WifiHotspotSecurityViewModel getWifiHotspotSecurityViewModel(
|
||||
@NotNull ViewModelStoreOwner owner) {
|
||||
@@ -97,7 +111,7 @@ public class WifiFeatureProvider {
|
||||
}
|
||||
|
||||
/**
|
||||
* Get WifiHotspotSpeedViewModel
|
||||
* Gets WifiHotspotSpeedViewModel
|
||||
*/
|
||||
public WifiHotspotSpeedViewModel getWifiHotspotSpeedViewModel(
|
||||
@NotNull ViewModelStoreOwner owner) {
|
||||
|
@@ -16,14 +16,18 @@
|
||||
|
||||
package com.android.settings.wifi.repository;
|
||||
|
||||
import static android.net.TetheringManager.TETHERING_WIFI;
|
||||
import static android.net.wifi.SoftApConfiguration.BAND_2GHZ;
|
||||
import static android.net.wifi.SoftApConfiguration.BAND_5GHZ;
|
||||
import static android.net.wifi.SoftApConfiguration.BAND_6GHZ;
|
||||
import static android.net.wifi.SoftApConfiguration.SECURITY_TYPE_OPEN;
|
||||
import static android.net.wifi.SoftApConfiguration.SECURITY_TYPE_WPA3_SAE;
|
||||
import static android.net.wifi.WifiAvailableChannel.OP_MODE_SAP;
|
||||
import static android.net.wifi.WifiManager.WIFI_AP_STATE_DISABLED;
|
||||
import static android.net.wifi.WifiManager.WIFI_AP_STATE_ENABLED;
|
||||
|
||||
import android.content.Context;
|
||||
import android.net.TetheringManager;
|
||||
import android.net.wifi.SoftApConfiguration;
|
||||
import android.net.wifi.WifiAvailableChannel;
|
||||
import android.net.wifi.WifiManager;
|
||||
@@ -51,6 +55,8 @@ import java.util.function.Consumer;
|
||||
public class WifiHotspotRepository {
|
||||
private static final String TAG = "WifiHotspotRepository";
|
||||
|
||||
private static final int RESTART_INTERVAL_MS = 100;
|
||||
|
||||
/** Wi-Fi hotspot band unknown. */
|
||||
public static final int BAND_UNKNOWN = 0;
|
||||
/** Wi-Fi hotspot band 2.4GHz and 5GHz. */
|
||||
@@ -79,8 +85,9 @@ public class WifiHotspotRepository {
|
||||
sSpeedMap.put(BAND_2GHZ_5GHZ, SPEED_2GHZ_5GHZ);
|
||||
}
|
||||
|
||||
protected final Context mAppContext;
|
||||
protected final WifiManager mWifiManager;
|
||||
private final Context mAppContext;
|
||||
private final WifiManager mWifiManager;
|
||||
private final TetheringManager mTetheringManager;
|
||||
|
||||
protected String mLastPassword;
|
||||
protected LastPasswordListener mLastPasswordListener = new LastPasswordListener();
|
||||
@@ -102,9 +109,24 @@ public class WifiHotspotRepository {
|
||||
Boolean mIsConfigShowSpeed;
|
||||
private Boolean mIsSpeedFeatureAvailable;
|
||||
|
||||
public WifiHotspotRepository(@NonNull Context appContext, @NonNull WifiManager wifiManager) {
|
||||
@VisibleForTesting
|
||||
SoftApCallback mSoftApCallback = new SoftApCallback();
|
||||
@VisibleForTesting
|
||||
StartTetheringCallback mStartTetheringCallback;
|
||||
@VisibleForTesting
|
||||
int mWifiApState = WIFI_AP_STATE_DISABLED;
|
||||
|
||||
@VisibleForTesting
|
||||
boolean mIsRestarting;
|
||||
@VisibleForTesting
|
||||
MutableLiveData<Boolean> mRestarting;
|
||||
|
||||
public WifiHotspotRepository(@NonNull Context appContext, @NonNull WifiManager wifiManager,
|
||||
@NonNull TetheringManager tetheringManager) {
|
||||
mAppContext = appContext;
|
||||
mWifiManager = wifiManager;
|
||||
mTetheringManager = tetheringManager;
|
||||
mWifiManager.registerSoftApCallback(mAppContext.getMainExecutor(), mSoftApCallback);
|
||||
}
|
||||
|
||||
/**
|
||||
@@ -126,6 +148,15 @@ public class WifiHotspotRepository {
|
||||
return !TextUtils.isEmpty(mLastPassword) ? mLastPassword : generateRandomPassword();
|
||||
}
|
||||
|
||||
@VisibleForTesting
|
||||
String generatePassword(SoftApConfiguration config) {
|
||||
String password = config.getPassphrase();
|
||||
if (TextUtils.isEmpty(password)) {
|
||||
password = generatePassword();
|
||||
}
|
||||
return password;
|
||||
}
|
||||
|
||||
private class LastPasswordListener implements Consumer<String> {
|
||||
@Override
|
||||
public void accept(String password) {
|
||||
@@ -139,14 +170,28 @@ public class WifiHotspotRepository {
|
||||
return randomUUID.substring(0, 8) + randomUUID.substring(9, 13);
|
||||
}
|
||||
|
||||
/**
|
||||
* Gets the Wi-Fi tethered AP Configuration.
|
||||
*
|
||||
* @return AP details in {@link SoftApConfiguration}
|
||||
*/
|
||||
public SoftApConfiguration getSoftApConfiguration() {
|
||||
return mWifiManager.getSoftApConfiguration();
|
||||
}
|
||||
|
||||
/**
|
||||
* Sets the tethered Wi-Fi AP Configuration.
|
||||
*
|
||||
* @param config A valid SoftApConfiguration specifying the configuration of the SAP.
|
||||
*/
|
||||
public void setSoftApConfiguration(@NonNull SoftApConfiguration config) {
|
||||
if (mIsRestarting) {
|
||||
Log.e(TAG, "Skip setSoftApConfiguration because hotspot is restarting.");
|
||||
return;
|
||||
}
|
||||
mWifiManager.setSoftApConfiguration(config);
|
||||
refresh();
|
||||
restartTetheringIfNeeded();
|
||||
}
|
||||
|
||||
/**
|
||||
@@ -217,13 +262,7 @@ public class WifiHotspotRepository {
|
||||
return;
|
||||
}
|
||||
SoftApConfiguration.Builder configBuilder = new SoftApConfiguration.Builder(config);
|
||||
String passphrase = null;
|
||||
if (securityType != SECURITY_TYPE_OPEN) {
|
||||
passphrase = config.getPassphrase();
|
||||
if (TextUtils.isEmpty(passphrase)) {
|
||||
passphrase = generatePassword();
|
||||
}
|
||||
}
|
||||
String passphrase = (securityType == SECURITY_TYPE_OPEN) ? null : generatePassword(config);
|
||||
configBuilder.setPassphrase(passphrase, securityType);
|
||||
setSoftApConfiguration(configBuilder.build());
|
||||
|
||||
@@ -302,7 +341,7 @@ public class WifiHotspotRepository {
|
||||
configBuilder.setBand(BAND_2GHZ_5GHZ_6GHZ);
|
||||
if (config.getSecurityType() != SECURITY_TYPE_WPA3_SAE) {
|
||||
log("setSpeedType(), setPassphrase(SECURITY_TYPE_WPA3_SAE)");
|
||||
configBuilder.setPassphrase(generatePassword(), SECURITY_TYPE_WPA3_SAE);
|
||||
configBuilder.setPassphrase(generatePassword(config), SECURITY_TYPE_WPA3_SAE);
|
||||
}
|
||||
} else if (speedType == SPEED_5GHZ) {
|
||||
log("setSpeedType(), setBand(BAND_2GHZ_5GHZ)");
|
||||
@@ -543,6 +582,84 @@ public class WifiHotspotRepository {
|
||||
}
|
||||
}
|
||||
|
||||
/**
|
||||
* Gets Restarting LiveData
|
||||
*/
|
||||
public LiveData<Boolean> getRestarting() {
|
||||
if (mRestarting == null) {
|
||||
mRestarting = new MutableLiveData<>();
|
||||
mRestarting.setValue(mIsRestarting);
|
||||
}
|
||||
return mRestarting;
|
||||
}
|
||||
|
||||
private void setRestarting(boolean isRestarting) {
|
||||
log("setRestarting(), isRestarting:" + isRestarting);
|
||||
mIsRestarting = isRestarting;
|
||||
if (mRestarting != null) {
|
||||
mRestarting.setValue(mIsRestarting);
|
||||
}
|
||||
}
|
||||
|
||||
@VisibleForTesting
|
||||
void restartTetheringIfNeeded() {
|
||||
if (mWifiApState != WIFI_AP_STATE_ENABLED) {
|
||||
return;
|
||||
}
|
||||
log("restartTetheringIfNeeded()");
|
||||
mAppContext.getMainThreadHandler().postDelayed(() -> {
|
||||
setRestarting(true);
|
||||
stopTethering();
|
||||
}, RESTART_INTERVAL_MS);
|
||||
}
|
||||
|
||||
private void startTethering() {
|
||||
if (mStartTetheringCallback == null) {
|
||||
mStartTetheringCallback = new StartTetheringCallback();
|
||||
}
|
||||
log("startTethering()");
|
||||
mTetheringManager.startTethering(TETHERING_WIFI, mAppContext.getMainExecutor(),
|
||||
mStartTetheringCallback);
|
||||
}
|
||||
|
||||
private void stopTethering() {
|
||||
log("startTethering()");
|
||||
mTetheringManager.stopTethering(TETHERING_WIFI);
|
||||
}
|
||||
|
||||
@VisibleForTesting
|
||||
class SoftApCallback implements WifiManager.SoftApCallback {
|
||||
@Override
|
||||
public void onStateChanged(int state, int failureReason) {
|
||||
log("onStateChanged(), state:" + state + ", failureReason:" + failureReason);
|
||||
mWifiApState = state;
|
||||
if (!mIsRestarting) {
|
||||
return;
|
||||
}
|
||||
if (state == WIFI_AP_STATE_DISABLED) {
|
||||
mAppContext.getMainThreadHandler().postDelayed(() -> startTethering(),
|
||||
RESTART_INTERVAL_MS);
|
||||
return;
|
||||
}
|
||||
if (state == WIFI_AP_STATE_ENABLED) {
|
||||
refresh();
|
||||
setRestarting(false);
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
private class StartTetheringCallback implements TetheringManager.StartTetheringCallback {
|
||||
@Override
|
||||
public void onTetheringStarted() {
|
||||
log("onTetheringStarted()");
|
||||
}
|
||||
|
||||
@Override
|
||||
public void onTetheringFailed(int error) {
|
||||
log("onTetheringFailed(), error:" + error);
|
||||
}
|
||||
}
|
||||
|
||||
private void log(String msg) {
|
||||
FeatureFactory.getFactory(mAppContext).getWifiFeatureProvider().verboseLog(TAG, msg);
|
||||
}
|
||||
|
@@ -19,6 +19,7 @@ package com.android.settings.wifi.tether;
|
||||
import android.app.settings.SettingsEnums;
|
||||
import android.os.Bundle;
|
||||
|
||||
import androidx.annotation.VisibleForTesting;
|
||||
import androidx.lifecycle.LiveData;
|
||||
|
||||
import com.android.settings.R;
|
||||
@@ -72,6 +73,7 @@ public class WifiHotspotSecuritySettings extends DashboardFragment implements
|
||||
SelectorWithWidgetPreference preference = findPreference(viewItem.mKey);
|
||||
preference.setOnClickListener(this);
|
||||
}
|
||||
mWifiHotspotSecurityViewModel.getRestarting().observe(this, this::onRestartingChanged);
|
||||
}
|
||||
|
||||
protected void onViewItemListDataChanged(
|
||||
@@ -96,6 +98,12 @@ public class WifiHotspotSecuritySettings extends DashboardFragment implements
|
||||
}
|
||||
}
|
||||
|
||||
@VisibleForTesting
|
||||
void onRestartingChanged(Boolean restarting) {
|
||||
log("onRestartingChanged(), restarting:" + restarting);
|
||||
setLoading(restarting, false);
|
||||
}
|
||||
|
||||
@Override
|
||||
public void onRadioButtonClicked(SelectorWithWidgetPreference emiter) {
|
||||
String key = emiter.getKey();
|
||||
|
@@ -129,6 +129,13 @@ public class WifiHotspotSecurityViewModel extends AndroidViewModel {
|
||||
mViewInfoListData.setValue(mViewItemMap.values().stream().toList());
|
||||
}
|
||||
|
||||
/**
|
||||
* Gets Restarting LiveData
|
||||
*/
|
||||
public LiveData<Boolean> getRestarting() {
|
||||
return mWifiHotspotRepository.getRestarting();
|
||||
}
|
||||
|
||||
/**
|
||||
* Wi-Fi Hotspot View Item
|
||||
*/
|
||||
|
@@ -24,6 +24,8 @@ import static com.android.settings.wifi.repository.WifiHotspotRepository.SPEED_6
|
||||
import android.app.settings.SettingsEnums;
|
||||
import android.os.Bundle;
|
||||
|
||||
import androidx.annotation.VisibleForTesting;
|
||||
|
||||
import com.android.settings.R;
|
||||
import com.android.settings.dashboard.DashboardFragment;
|
||||
import com.android.settings.overlay.FeatureFactory;
|
||||
@@ -80,6 +82,7 @@ public class WifiHotspotSpeedSettings extends DashboardFragment implements
|
||||
onSpeedInfoMapDataChanged(mWifiHotspotSpeedViewModel.getSpeedInfoMapData().getValue());
|
||||
mWifiHotspotSpeedViewModel.getSpeedInfoMapData()
|
||||
.observe(this, this::onSpeedInfoMapDataChanged);
|
||||
mWifiHotspotSpeedViewModel.getRestarting().observe(this, this::onRestartingChanged);
|
||||
}
|
||||
|
||||
protected void loadPreferences() {
|
||||
@@ -117,6 +120,12 @@ public class WifiHotspotSpeedSettings extends DashboardFragment implements
|
||||
}
|
||||
}
|
||||
|
||||
@VisibleForTesting
|
||||
void onRestartingChanged(Boolean restarting) {
|
||||
log("onRestartingChanged(), restarting:" + restarting);
|
||||
setLoading(restarting, false);
|
||||
}
|
||||
|
||||
@Override
|
||||
public void onRadioButtonClicked(SelectorWithWidgetPreference emiter) {
|
||||
String key = emiter.getKey();
|
||||
|
@@ -130,6 +130,13 @@ public class WifiHotspotSpeedViewModel extends AndroidViewModel {
|
||||
}
|
||||
}
|
||||
|
||||
/**
|
||||
* Gets Restarting LiveData
|
||||
*/
|
||||
public LiveData<Boolean> getRestarting() {
|
||||
return mWifiHotspotRepository.getRestarting();
|
||||
}
|
||||
|
||||
/**
|
||||
* Wi-Fi Hotspot Speed Information
|
||||
*/
|
||||
|
@@ -17,6 +17,8 @@
|
||||
package com.android.settings.wifi.tether;
|
||||
|
||||
import static android.net.wifi.WifiManager.WIFI_AP_STATE_CHANGED_ACTION;
|
||||
import static android.view.View.INVISIBLE;
|
||||
import static android.view.View.VISIBLE;
|
||||
|
||||
import static com.android.settings.wifi.WifiUtils.canShowWifiHotspot;
|
||||
|
||||
@@ -26,7 +28,6 @@ import android.content.Context;
|
||||
import android.content.Intent;
|
||||
import android.content.IntentFilter;
|
||||
import android.net.wifi.SoftApConfiguration;
|
||||
import android.net.wifi.WifiManager;
|
||||
import android.os.Bundle;
|
||||
import android.os.UserManager;
|
||||
import android.util.FeatureFlagUtils;
|
||||
@@ -76,6 +77,8 @@ public class WifiTetherSettings extends RestrictedDashboardFragment
|
||||
@VisibleForTesting
|
||||
static final String KEY_WIFI_HOTSPOT_SPEED = "wifi_hotspot_speed";
|
||||
|
||||
@VisibleForTesting
|
||||
SettingsMainSwitchBar mMainSwitchBar;
|
||||
private WifiTetherSwitchBarController mSwitchBarController;
|
||||
private WifiTetherSSIDPreferenceController mSSIDPreferenceController;
|
||||
private WifiTetherPasswordPreferenceController mPasswordPreferenceController;
|
||||
@@ -83,8 +86,6 @@ public class WifiTetherSettings extends RestrictedDashboardFragment
|
||||
private WifiTetherMaximizeCompatibilityPreferenceController mMaxCompatibilityPrefController;
|
||||
private WifiTetherAutoOffPreferenceController mWifiTetherAutoOffPreferenceController;
|
||||
|
||||
private WifiManager mWifiManager;
|
||||
private boolean mRestartWifiApAfterConfigChange;
|
||||
private boolean mUnavailable;
|
||||
private WifiRestriction mWifiRestriction;
|
||||
@VisibleForTesting
|
||||
@@ -138,6 +139,7 @@ public class WifiTetherSettings extends RestrictedDashboardFragment
|
||||
.getWifiTetherViewModel(this);
|
||||
if (mWifiTetherViewModel != null) {
|
||||
setupSpeedFeature(mWifiTetherViewModel.isSpeedFeatureAvailable());
|
||||
mWifiTetherViewModel.getRestarting().observe(this, this::onRestartingChanged);
|
||||
}
|
||||
}
|
||||
|
||||
@@ -159,7 +161,6 @@ public class WifiTetherSettings extends RestrictedDashboardFragment
|
||||
@Override
|
||||
public void onAttach(Context context) {
|
||||
super.onAttach(context);
|
||||
mWifiManager = (WifiManager) context.getSystemService(Context.WIFI_SERVICE);
|
||||
mTetherChangeReceiver = new TetherChangeReceiver();
|
||||
|
||||
mSSIDPreferenceController = use(WifiTetherSSIDPreferenceController.class);
|
||||
@@ -179,11 +180,11 @@ public class WifiTetherSettings extends RestrictedDashboardFragment
|
||||
// Assume we are in a SettingsActivity. This is only safe because we currently use
|
||||
// SettingsActivity as base for all preference fragments.
|
||||
final SettingsActivity activity = (SettingsActivity) getActivity();
|
||||
final SettingsMainSwitchBar switchBar = activity.getSwitchBar();
|
||||
switchBar.setTitle(getContext().getString(R.string.use_wifi_hotsopt_main_switch_title));
|
||||
mSwitchBarController = new WifiTetherSwitchBarController(activity, switchBar);
|
||||
mMainSwitchBar = activity.getSwitchBar();
|
||||
mMainSwitchBar.setTitle(getString(R.string.use_wifi_hotsopt_main_switch_title));
|
||||
mSwitchBarController = new WifiTetherSwitchBarController(activity, mMainSwitchBar);
|
||||
getSettingsLifecycle().addObserver(mSwitchBarController);
|
||||
switchBar.show();
|
||||
mMainSwitchBar.show();
|
||||
}
|
||||
|
||||
@Override
|
||||
@@ -259,40 +260,34 @@ public class WifiTetherSettings extends RestrictedDashboardFragment
|
||||
final SoftApConfiguration config = buildNewConfig();
|
||||
mPasswordPreferenceController.setSecurityType(config.getSecurityType());
|
||||
|
||||
/**
|
||||
* if soft AP is stopped, bring up
|
||||
* else restart with new config
|
||||
* TODO: update config on a running access point when framework support is added
|
||||
*/
|
||||
if (mWifiManager.getWifiApState() == WifiManager.WIFI_AP_STATE_ENABLED) {
|
||||
Log.d("TetheringSettings",
|
||||
"Wifi AP config changed while enabled, stop and restart");
|
||||
mRestartWifiApAfterConfigChange = true;
|
||||
mSwitchBarController.stopTether();
|
||||
}
|
||||
mWifiTetherViewModel.setSoftApConfiguration(config);
|
||||
}
|
||||
|
||||
@VisibleForTesting
|
||||
void onRestartingChanged(Boolean restarting) {
|
||||
mMainSwitchBar.setVisibility((restarting) ? INVISIBLE : VISIBLE);
|
||||
setLoading(restarting, false);
|
||||
}
|
||||
|
||||
private SoftApConfiguration buildNewConfig() {
|
||||
final SoftApConfiguration.Builder configBuilder = new SoftApConfiguration.Builder();
|
||||
final int securityType = mSecurityPreferenceController.getSecurityType();
|
||||
SoftApConfiguration.Builder configBuilder = new SoftApConfiguration.Builder();
|
||||
int securityType = (mWifiTetherViewModel.isSpeedFeatureAvailable())
|
||||
? mWifiTetherViewModel.getSoftApConfiguration().getSecurityType()
|
||||
: mSecurityPreferenceController.getSecurityType();
|
||||
configBuilder.setSsid(mSSIDPreferenceController.getSSID());
|
||||
if (securityType != SoftApConfiguration.SECURITY_TYPE_OPEN) {
|
||||
configBuilder.setPassphrase(
|
||||
mPasswordPreferenceController.getPasswordValidated(securityType),
|
||||
securityType);
|
||||
}
|
||||
mMaxCompatibilityPrefController.setupMaximizeCompatibility(configBuilder);
|
||||
if (!mWifiTetherViewModel.isSpeedFeatureAvailable()) {
|
||||
mMaxCompatibilityPrefController.setupMaximizeCompatibility(configBuilder);
|
||||
}
|
||||
configBuilder.setAutoShutdownEnabled(
|
||||
mWifiTetherAutoOffPreferenceController.isEnabled());
|
||||
return configBuilder.build();
|
||||
}
|
||||
|
||||
private void startTether() {
|
||||
mRestartWifiApAfterConfigChange = false;
|
||||
mSwitchBarController.startTether();
|
||||
}
|
||||
|
||||
private void updateDisplayWithNewConfig() {
|
||||
use(WifiTetherSSIDPreferenceController.class).updateDisplay();
|
||||
use(WifiTetherSecurityPreferenceController.class).updateDisplay();
|
||||
@@ -369,13 +364,6 @@ public class WifiTetherSettings extends RestrictedDashboardFragment
|
||||
String action = intent.getAction();
|
||||
Log.d(TAG, "updating display config due to receiving broadcast action " + action);
|
||||
updateDisplayWithNewConfig();
|
||||
if (action.equals(WIFI_AP_STATE_CHANGED_ACTION)) {
|
||||
int state = intent.getIntExtra(WifiManager.EXTRA_WIFI_AP_STATE, 0);
|
||||
if (state == WifiManager.WIFI_AP_STATE_DISABLED
|
||||
&& mRestartWifiApAfterConfigChange) {
|
||||
startTether();
|
||||
}
|
||||
}
|
||||
}
|
||||
}
|
||||
}
|
||||
|
@@ -100,6 +100,15 @@ public class WifiTetherViewModel extends AndroidViewModel {
|
||||
return mWifiHotspotRepository.isSpeedFeatureAvailable();
|
||||
}
|
||||
|
||||
/**
|
||||
* Gets the Wi-Fi tethered AP Configuration.
|
||||
*
|
||||
* @return AP details in {@link SoftApConfiguration}
|
||||
*/
|
||||
public SoftApConfiguration getSoftApConfiguration() {
|
||||
return mWifiHotspotRepository.getSoftApConfiguration();
|
||||
}
|
||||
|
||||
/**
|
||||
* Sets the tethered Wi-Fi AP Configuration.
|
||||
*
|
||||
@@ -153,4 +162,11 @@ public class WifiTetherViewModel extends AndroidViewModel {
|
||||
}
|
||||
mSpeedSummary.setValue(resId);
|
||||
}
|
||||
|
||||
/**
|
||||
* Gets Restarting LiveData
|
||||
*/
|
||||
public LiveData<Boolean> getRestarting() {
|
||||
return mWifiHotspotRepository.getRestarting();
|
||||
}
|
||||
}
|
||||
|
Reference in New Issue
Block a user