mirror of
https://github.com/topjohnwu/Magisk.git
synced 2025-12-02 17:51:51 +00:00
Proper app relaunch for stub
This commit is contained in:
@@ -8,13 +8,19 @@ import java.io.File;
|
||||
// mapping when loading from platform (via LoadedApk.mClassLoader)
|
||||
class InjectedClassLoader extends ClassLoader {
|
||||
|
||||
private static final String PKEY = "PHOENIX";
|
||||
static final String PHOENIX = Mapping.inverseMap.get(PKEY);
|
||||
|
||||
InjectedClassLoader(File apk) {
|
||||
super(new DynamicClassLoader(apk));
|
||||
}
|
||||
|
||||
@Override
|
||||
protected Class<?> loadClass(String name, boolean resolve) throws ClassNotFoundException {
|
||||
return super.loadClass(Mapping.get(name), resolve);
|
||||
String n = Mapping.get(name);
|
||||
if (n.equals(PKEY))
|
||||
return PhoenixActivity.class;
|
||||
return super.loadClass(n, resolve);
|
||||
}
|
||||
}
|
||||
|
||||
|
||||
@@ -5,7 +5,6 @@ import static android.R.string.ok;
|
||||
import static android.R.string.yes;
|
||||
import static com.topjohnwu.magisk.R.string.dling;
|
||||
import static com.topjohnwu.magisk.R.string.no_internet_msg;
|
||||
import static com.topjohnwu.magisk.R.string.relaunch_app;
|
||||
import static com.topjohnwu.magisk.R.string.upgrade_msg;
|
||||
|
||||
import android.app.Activity;
|
||||
@@ -17,7 +16,6 @@ import android.os.AsyncTask;
|
||||
import android.os.Bundle;
|
||||
import android.util.Log;
|
||||
import android.view.ContextThemeWrapper;
|
||||
import android.widget.Toast;
|
||||
|
||||
import com.topjohnwu.magisk.net.Networking;
|
||||
import com.topjohnwu.magisk.net.Request;
|
||||
@@ -111,14 +109,14 @@ public class DownloadActivity extends Activity {
|
||||
dialog = ProgressDialog.show(themed, getString(dling), getString(dling) + " " + APP_NAME, true);
|
||||
Runnable onSuccess = () -> {
|
||||
dialog.dismiss();
|
||||
Toast.makeText(themed, relaunch_app, Toast.LENGTH_LONG).show();
|
||||
PhoenixActivity.rebirth(this, InjectedClassLoader.PHOENIX);
|
||||
finish();
|
||||
};
|
||||
// Download and upgrade the app
|
||||
File apk = dynLoad ? StubApk.current(this) : new File(getCacheDir(), "manager.apk");
|
||||
request(apkLink).setExecutor(AsyncTask.THREAD_POOL_EXECUTOR).getAsFile(apk, file -> {
|
||||
if (dynLoad) {
|
||||
// TODO
|
||||
runOnUiThread(onSuccess);
|
||||
} else {
|
||||
var receiver = APKInstall.register(this, BuildConfig.APPLICATION_ID, onSuccess);
|
||||
APKInstall.installapk(this, file);
|
||||
|
||||
Reference in New Issue
Block a user