blob: 16093fd159308f492f7aa61d1964d0d7d0d32482 [file] [log] [blame]
/*
* Copyright 2016, 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.managedprovisioning.finalization;
import android.app.Activity;
import android.app.admin.DevicePolicyManager;
import android.os.Bundle;
/**
* This class is used to make sure that we start the MDM after we shut the setup wizard down.
* The shut down of the setup wizard is initiated in the
* {@link com.android.managedprovisioning.provisioning.ProvisioningActivity} by calling
* {@link DevicePolicyManager#setUserProvisioningState(int, int)}. This will cause the
* Setup wizard to shut down and send a ACTION_PROVISIONING_FINALIZATION intent. This intent is
* caught by this receiver instead which will send the
* ACTION_PROFILE_PROVISIONING_COMPLETE broadcast to the MDM, which can then present it's own
* activities.
*/
public class FinalizationActivity extends Activity {
@Override
public void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
// To prevent b/131315856, we finish this activity now only if we do not expect to launch
// the admin app. Otherwise let android:noHistory automatically finish it.
final FinalizationController finalizationController = new FinalizationController(this);
finalizationController.provisioningFinalized();
final int result = finalizationController.getProvisioningFinalizedResult();
if (result != FinalizationController.PROVISIONING_FINALIZED_RESULT_ADMIN_WILL_LAUNCH) {
finish();
}
}
}