blob: a47ab670511dc7f5bfbe1bf4d82d16e31f205536 [file] [log] [blame]
/*
* Copyright (C) 2017 The Android Open Source Project
*
* Licensed under the Apache License, Version 2.0 (the "License");
* you may not use this file except in compliance with the License.
* You may obtain a copy of the License at
*
* http://www.apache.org/licenses/LICENSE-2.0
*
* Unless required by applicable law or agreed to in writing, software
* distributed under the License is distributed on an "AS IS" BASIS,
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
* See the License for the specific language governing permissions and
* limitations under the License.
*/
package com.android.phone.otasp;
import android.content.BroadcastReceiver;
import android.content.Context;
import android.content.Intent;
import android.os.AsyncResult;
import android.os.Handler;
import android.os.Message;
import android.os.PersistableBundle;
import android.telephony.CarrierConfigManager;
import android.telephony.TelephonyManager;
import android.util.Log;
import com.android.internal.telephony.Phone;
import com.android.phone.PhoneGlobals;
public class OtaspSimStateReceiver extends BroadcastReceiver {
private static final String TAG = OtaspSimStateReceiver.class.getSimpleName();
private static final boolean DBG = true;
private Context mContext;
private static final int EVENT_OTASP_CHANGED = 1;
private Handler mOtaspHandler = new Handler() {
@Override
public void handleMessage(Message msg) {
AsyncResult ar;
switch (msg.what) {
case EVENT_OTASP_CHANGED:
ar = (AsyncResult) msg.obj;
if (ar.exception == null && ar.result != null) {
int otaspMode = (Integer) ar.result;
logd("EVENT_OTASP_CHANGED: otaspMode=" + otaspMode);
if (otaspMode == TelephonyManager.OTASP_NEEDED) {
logd("otasp activation required, start otaspActivationService");
mContext.startService(
new Intent(mContext, OtaspActivationService.class));
} else if (otaspMode == TelephonyManager.OTASP_NOT_NEEDED) {
OtaspActivationService.updateActivationState(mContext, true);
}
} else {
logd("EVENT_OTASP_CHANGED: exception=" + ar.exception);
}
break;
default:
super.handleMessage(msg);
break;
}
}
};
/**
* check if OTA service provisioning activation is supported by the current carrier
* @return true if otasp activation is needed, false otherwise
*/
private static boolean isCarrierSupported() {
final Phone phone = PhoneGlobals.getPhone();
final Context context = phone.getContext();
if (context != null) {
PersistableBundle b = null;
final CarrierConfigManager configManager = (CarrierConfigManager) context
.getSystemService(Context.CARRIER_CONFIG_SERVICE);
if (configManager != null) {
b = configManager.getConfig();
}
if (b != null && b.getBoolean(
CarrierConfigManager.KEY_USE_OTASP_FOR_PROVISIONING_BOOL)) {
return true;
}
}
logd("otasp activation not needed: no supported carrier");
return false;
}
@Override
public void onReceive(Context context, Intent intent) {
mContext = context;
if(CarrierConfigManager.ACTION_CARRIER_CONFIG_CHANGED.equals(intent.getAction())) {
if (DBG) logd("Received intent: " + intent.getAction());
// Allow the receiver to keep active after returning from onReceive().
final PendingResult result = goAsync();
// Do the actual work on another thread to prevent ANR.
new Thread(() -> {
if (DBG) logd("Start to process ACTION_CARRIER_CONFIG_CHANGED.");
if (PhoneGlobals.getPhone().getIccRecordsLoaded() && isCarrierSupported()) {
registerOtaspChangedHandler();
}
result.finish();
}).start();
}
}
// It's fine to call multiple times, as the registrants are de-duped by Handler object.
private void registerOtaspChangedHandler() {
if (DBG) logd("registerOtaspChangedHandler");
final Phone phone = PhoneGlobals.getPhone();
phone.registerForOtaspChange(mOtaspHandler, EVENT_OTASP_CHANGED, null);
}
private static void logd(String s) {
Log.d(TAG, s);
}
}