Shutdown secondary SAP automatically
- If the "Extend compatibility" preference is not supported, then set to shutdown secondary SAP automatically within the "Turn off hotspot automatically" preference. Bug: 285914977 Test: manual test atest -c WifiTetherAutoOffPreferenceControllerTest Change-Id: I405107a4782a6f023442d196d0fca27515aab00e
This commit is contained in:
@@ -20,19 +20,29 @@ import android.content.Context;
|
||||
import android.net.wifi.SoftApConfiguration;
|
||||
import android.net.wifi.WifiManager;
|
||||
|
||||
import androidx.annotation.VisibleForTesting;
|
||||
import androidx.preference.Preference;
|
||||
import androidx.preference.SwitchPreference;
|
||||
|
||||
import com.android.settings.core.BasePreferenceController;
|
||||
import com.android.settings.overlay.FeatureFactory;
|
||||
import com.android.settings.wifi.repository.WifiHotspotRepository;
|
||||
|
||||
public class WifiTetherAutoOffPreferenceController extends BasePreferenceController implements
|
||||
Preference.OnPreferenceChangeListener {
|
||||
|
||||
private final WifiManager mWifiManager;
|
||||
private boolean mSettingsOn;
|
||||
@VisibleForTesting
|
||||
boolean mNeedShutdownSecondarySap;
|
||||
|
||||
public WifiTetherAutoOffPreferenceController(Context context, String preferenceKey) {
|
||||
super(context, preferenceKey);
|
||||
WifiHotspotRepository wifiHotspotRepository = FeatureFactory.getFactory(context)
|
||||
.getWifiFeatureProvider().getWifiHotspotRepository();
|
||||
if (wifiHotspotRepository.isSpeedFeatureAvailable() && wifiHotspotRepository.isDualBand()) {
|
||||
mNeedShutdownSecondarySap = true;
|
||||
}
|
||||
mWifiManager = context.getSystemService(WifiManager.class);
|
||||
}
|
||||
|
||||
@@ -51,14 +61,15 @@ public class WifiTetherAutoOffPreferenceController extends BasePreferenceControl
|
||||
|
||||
@Override
|
||||
public boolean onPreferenceChange(Preference preference, Object newValue) {
|
||||
final boolean settingsOn = (Boolean) newValue;
|
||||
SoftApConfiguration softApConfiguration = mWifiManager.getSoftApConfiguration();
|
||||
SoftApConfiguration newSoftApConfiguration =
|
||||
new SoftApConfiguration.Builder(softApConfiguration)
|
||||
.setAutoShutdownEnabled(settingsOn)
|
||||
.build();
|
||||
boolean settingsOn = (Boolean) newValue;
|
||||
SoftApConfiguration.Builder configBuilder =
|
||||
new SoftApConfiguration.Builder(mWifiManager.getSoftApConfiguration());
|
||||
configBuilder.setAutoShutdownEnabled(settingsOn);
|
||||
if (mNeedShutdownSecondarySap) {
|
||||
configBuilder.setBridgedModeOpportunisticShutdownEnabled(settingsOn);
|
||||
}
|
||||
mSettingsOn = settingsOn;
|
||||
return mWifiManager.setSoftApConfiguration(newSoftApConfiguration);
|
||||
return mWifiManager.setSoftApConfiguration(configBuilder.build());
|
||||
}
|
||||
|
||||
public boolean isEnabled() {
|
||||
|
Reference in New Issue
Block a user