mirror of
https://github.com/topjohnwu/Magisk.git
synced 2025-01-13 17:43:38 +00:00
Add restore stock image feature
This commit is contained in:
parent
4c230d9e61
commit
2ee22fd374
@ -1,14 +1,8 @@
|
|||||||
package com.topjohnwu.magisk;
|
package com.topjohnwu.magisk;
|
||||||
|
|
||||||
import android.app.Activity;
|
|
||||||
import android.app.AlertDialog;
|
|
||||||
import android.app.NotificationManager;
|
import android.app.NotificationManager;
|
||||||
import android.app.ProgressDialog;
|
|
||||||
import android.content.Context;
|
import android.content.Context;
|
||||||
import android.content.Intent;
|
|
||||||
import android.net.Uri;
|
|
||||||
import android.os.Bundle;
|
import android.os.Bundle;
|
||||||
import android.os.CountDownTimer;
|
|
||||||
import android.support.annotation.Nullable;
|
import android.support.annotation.Nullable;
|
||||||
import android.support.design.widget.Snackbar;
|
import android.support.design.widget.Snackbar;
|
||||||
import android.support.v4.widget.SwipeRefreshLayout;
|
import android.support.v4.widget.SwipeRefreshLayout;
|
||||||
@ -24,23 +18,15 @@ import android.widget.LinearLayout;
|
|||||||
import android.widget.ProgressBar;
|
import android.widget.ProgressBar;
|
||||||
import android.widget.Spinner;
|
import android.widget.Spinner;
|
||||||
import android.widget.TextView;
|
import android.widget.TextView;
|
||||||
import android.widget.Toast;
|
|
||||||
|
|
||||||
import com.topjohnwu.magisk.asyncs.CheckUpdates;
|
import com.topjohnwu.magisk.asyncs.CheckUpdates;
|
||||||
import com.topjohnwu.magisk.components.AlertDialogBuilder;
|
|
||||||
import com.topjohnwu.magisk.components.ExpandableView;
|
import com.topjohnwu.magisk.components.ExpandableView;
|
||||||
import com.topjohnwu.magisk.components.Fragment;
|
import com.topjohnwu.magisk.components.Fragment;
|
||||||
import com.topjohnwu.magisk.components.SnackbarMaker;
|
import com.topjohnwu.magisk.components.SnackbarMaker;
|
||||||
import com.topjohnwu.magisk.receivers.DownloadReceiver;
|
|
||||||
import com.topjohnwu.magisk.receivers.ManagerUpdate;
|
|
||||||
import com.topjohnwu.magisk.utils.Shell;
|
import com.topjohnwu.magisk.utils.Shell;
|
||||||
import com.topjohnwu.magisk.utils.Topic;
|
import com.topjohnwu.magisk.utils.Topic;
|
||||||
import com.topjohnwu.magisk.utils.Utils;
|
import com.topjohnwu.magisk.utils.Utils;
|
||||||
|
|
||||||
import java.io.File;
|
|
||||||
import java.io.FileOutputStream;
|
|
||||||
import java.io.IOException;
|
|
||||||
import java.io.InputStream;
|
|
||||||
import java.util.ArrayList;
|
import java.util.ArrayList;
|
||||||
import java.util.List;
|
import java.util.List;
|
||||||
|
|
||||||
@ -53,10 +39,6 @@ import butterknife.Unbinder;
|
|||||||
public class MagiskFragment extends Fragment
|
public class MagiskFragment extends Fragment
|
||||||
implements Topic.Subscriber, SwipeRefreshLayout.OnRefreshListener, ExpandableView {
|
implements Topic.Subscriber, SwipeRefreshLayout.OnRefreshListener, ExpandableView {
|
||||||
|
|
||||||
private static final String UNINSTALLER = "magisk_uninstaller.sh";
|
|
||||||
private static final String UTIL_FUNCTIONS= "util_functions.sh";
|
|
||||||
private static final int SELECT_BOOT_IMG = 3;
|
|
||||||
|
|
||||||
private Container expandableContainer = new Container();
|
private Container expandableContainer = new Container();
|
||||||
|
|
||||||
private MagiskManager mm;
|
private MagiskManager mm;
|
||||||
@ -102,7 +84,7 @@ public class MagiskFragment extends Fragment
|
|||||||
@BindColor(R.color.blue500) int colorInfo;
|
@BindColor(R.color.blue500) int colorInfo;
|
||||||
|
|
||||||
@OnClick(R.id.safetyNet_title)
|
@OnClick(R.id.safetyNet_title)
|
||||||
public void safetyNet() {
|
void safetyNet() {
|
||||||
safetyNetProgress.setVisibility(View.VISIBLE);
|
safetyNetProgress.setVisibility(View.VISIBLE);
|
||||||
safetyNetRefreshIcon.setVisibility(View.GONE);
|
safetyNetRefreshIcon.setVisibility(View.GONE);
|
||||||
safetyNetStatusText.setText(R.string.checking_safetyNet_status);
|
safetyNetStatusText.setText(R.string.checking_safetyNet_status);
|
||||||
@ -111,169 +93,23 @@ public class MagiskFragment extends Fragment
|
|||||||
}
|
}
|
||||||
|
|
||||||
@OnClick(R.id.install_button)
|
@OnClick(R.id.install_button)
|
||||||
public void install() {
|
void install() {
|
||||||
shownDialog = true;
|
shownDialog = true;
|
||||||
|
|
||||||
// Show Manager update first
|
// Show Manager update first
|
||||||
if (mm.remoteManagerVersionCode > BuildConfig.VERSION_CODE) {
|
if (mm.remoteManagerVersionCode > BuildConfig.VERSION_CODE) {
|
||||||
new AlertDialogBuilder(getActivity())
|
Utils.showManagerInstallDialog(getActivity());
|
||||||
.setTitle(getString(R.string.repo_install_title, getString(R.string.app_name)))
|
|
||||||
.setMessage(getString(R.string.repo_install_msg,
|
|
||||||
Utils.getLegalFilename("MagiskManager-v" +
|
|
||||||
mm.remoteManagerVersionString + ".apk")))
|
|
||||||
.setCancelable(true)
|
|
||||||
.setPositiveButton(R.string.install, (d, i) -> {
|
|
||||||
Intent intent = new Intent(mm, ManagerUpdate.class);
|
|
||||||
intent.putExtra(MagiskManager.INTENT_LINK, mm.managerLink);
|
|
||||||
intent.putExtra(MagiskManager.INTENT_VERSION, mm.remoteManagerVersionString);
|
|
||||||
getActivity().sendBroadcast(intent);
|
|
||||||
})
|
|
||||||
.setNegativeButton(R.string.no_thanks, null)
|
|
||||||
.show();
|
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
String bootImage = null;
|
((NotificationManager) mm.getSystemService(Context.NOTIFICATION_SERVICE)).cancelAll();
|
||||||
if (Shell.rootAccess()) {
|
Utils.showMagiskInstallDialog(this,
|
||||||
if (mm.bootBlock != null) {
|
keepEncChkbox.isChecked(), keepVerityChkbox.isChecked());
|
||||||
bootImage = mm.bootBlock;
|
|
||||||
} else {
|
|
||||||
int idx = spinner.getSelectedItemPosition();
|
|
||||||
if (idx > 0) {
|
|
||||||
bootImage = mm.blockList.get(idx - 1);
|
|
||||||
} else {
|
|
||||||
SnackbarMaker.make(getActivity(),
|
|
||||||
R.string.manual_boot_image, Snackbar.LENGTH_LONG).show();
|
|
||||||
return;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
final String boot = bootImage;
|
|
||||||
((NotificationManager) getActivity().getSystemService(Context.NOTIFICATION_SERVICE)).cancelAll();
|
|
||||||
String filename = "Magisk-v" + mm.remoteMagiskVersionString + ".zip";
|
|
||||||
new AlertDialogBuilder(getActivity())
|
|
||||||
.setTitle(getString(R.string.repo_install_title, getString(R.string.magisk)))
|
|
||||||
.setMessage(getString(R.string.repo_install_msg, filename))
|
|
||||||
.setCancelable(true)
|
|
||||||
.setPositiveButton(
|
|
||||||
R.string.install,
|
|
||||||
(d, i) -> {
|
|
||||||
List<String> options = new ArrayList<>();
|
|
||||||
options.add(getString(R.string.download_zip_only));
|
|
||||||
options.add(getString(R.string.patch_boot_file));
|
|
||||||
if (Shell.rootAccess()) {
|
|
||||||
options.add(getString(R.string.direct_install));
|
|
||||||
}
|
|
||||||
new AlertDialog.Builder(getActivity())
|
|
||||||
.setTitle(R.string.select_method)
|
|
||||||
.setItems(
|
|
||||||
options.toArray(new String [0]),
|
|
||||||
(dialog, idx) -> {
|
|
||||||
DownloadReceiver receiver = null;
|
|
||||||
switch (idx) {
|
|
||||||
case 1:
|
|
||||||
if (mm.remoteMagiskVersionCode < 1370) {
|
|
||||||
mm.toast(R.string.no_boot_file_patch_support, Toast.LENGTH_LONG);
|
|
||||||
return;
|
|
||||||
}
|
|
||||||
Intent intent = new Intent(Intent.ACTION_GET_CONTENT);
|
|
||||||
intent.setType("*/*");
|
|
||||||
startActivityForResult(intent, SELECT_BOOT_IMG);
|
|
||||||
return;
|
|
||||||
case 0:
|
|
||||||
receiver = new DownloadReceiver() {
|
|
||||||
@Override
|
|
||||||
public void onDownloadDone(Uri uri) {
|
|
||||||
Utils.showUriSnack(getActivity(), uri);
|
|
||||||
}
|
|
||||||
};
|
|
||||||
break;
|
|
||||||
case 2:
|
|
||||||
receiver = new DownloadReceiver() {
|
|
||||||
@Override
|
|
||||||
public void onDownloadDone(Uri uri) {
|
|
||||||
Intent intent = new Intent(getActivity(), FlashActivity.class);
|
|
||||||
intent.setData(uri)
|
|
||||||
.putExtra(FlashActivity.SET_BOOT, boot)
|
|
||||||
.putExtra(FlashActivity.SET_ENC, keepEncChkbox.isChecked())
|
|
||||||
.putExtra(FlashActivity.SET_VERITY, keepVerityChkbox.isChecked())
|
|
||||||
.putExtra(FlashActivity.SET_ACTION, FlashActivity.FLASH_MAGISK);
|
|
||||||
startActivity(intent);
|
|
||||||
}
|
|
||||||
};
|
|
||||||
break;
|
|
||||||
}
|
|
||||||
Utils.dlAndReceive(
|
|
||||||
getActivity(),
|
|
||||||
receiver,
|
|
||||||
mm.magiskLink,
|
|
||||||
Utils.getLegalFilename(filename)
|
|
||||||
);
|
|
||||||
}
|
|
||||||
).show();
|
|
||||||
}
|
|
||||||
)
|
|
||||||
.setNeutralButton(R.string.release_notes, (d, i) -> {
|
|
||||||
if (mm.releaseNoteLink != null) {
|
|
||||||
Intent openReleaseNoteLink = new Intent(Intent.ACTION_VIEW, Uri.parse(mm.releaseNoteLink));
|
|
||||||
openReleaseNoteLink.addFlags(Intent.FLAG_ACTIVITY_NEW_TASK);
|
|
||||||
mm.startActivity(openReleaseNoteLink);
|
|
||||||
}
|
|
||||||
})
|
|
||||||
.setNegativeButton(R.string.no_thanks, null)
|
|
||||||
.show();
|
|
||||||
}
|
}
|
||||||
|
|
||||||
@OnClick(R.id.uninstall_button)
|
@OnClick(R.id.uninstall_button)
|
||||||
public void uninstall() {
|
void uninstall() {
|
||||||
new AlertDialogBuilder(getActivity())
|
Utils.showUninstallDialog(this);
|
||||||
.setTitle(R.string.uninstall_magisk_title)
|
|
||||||
.setMessage(R.string.uninstall_magisk_msg)
|
|
||||||
.setPositiveButton(R.string.yes, (d, i) -> {
|
|
||||||
try {
|
|
||||||
InputStream in = mm.getAssets().open(UNINSTALLER);
|
|
||||||
File uninstaller = new File(mm.getCacheDir(), UNINSTALLER);
|
|
||||||
FileOutputStream out = new FileOutputStream(uninstaller);
|
|
||||||
byte[] bytes = new byte[1024];
|
|
||||||
int read;
|
|
||||||
while ((read = in.read(bytes)) != -1) {
|
|
||||||
out.write(bytes, 0, read);
|
|
||||||
}
|
|
||||||
in.close();
|
|
||||||
out.close();
|
|
||||||
in = mm.getAssets().open(UTIL_FUNCTIONS);
|
|
||||||
File utils = new File(mm.getCacheDir(), UTIL_FUNCTIONS);
|
|
||||||
out = new FileOutputStream(utils);
|
|
||||||
while ((read = in.read(bytes)) != -1) {
|
|
||||||
out.write(bytes, 0, read);
|
|
||||||
}
|
|
||||||
in.close();
|
|
||||||
out.close();
|
|
||||||
ProgressDialog progress = new ProgressDialog(getActivity());
|
|
||||||
progress.setTitle(R.string.reboot);
|
|
||||||
progress.show();
|
|
||||||
new CountDownTimer(5000, 1000) {
|
|
||||||
@Override
|
|
||||||
public void onTick(long millisUntilFinished) {
|
|
||||||
progress.setMessage(getString(R.string.reboot_countdown, millisUntilFinished / 1000));
|
|
||||||
}
|
|
||||||
|
|
||||||
@Override
|
|
||||||
public void onFinish() {
|
|
||||||
progress.setMessage(getString(R.string.reboot_countdown, 0));
|
|
||||||
getShell().su_raw(
|
|
||||||
"mv -f " + uninstaller + " /cache/" + UNINSTALLER,
|
|
||||||
"mv -f " + utils + " /data/magisk/" + UTIL_FUNCTIONS,
|
|
||||||
"reboot"
|
|
||||||
);
|
|
||||||
}
|
|
||||||
}.start();
|
|
||||||
} catch (IOException e) {
|
|
||||||
e.printStackTrace();
|
|
||||||
}
|
|
||||||
})
|
|
||||||
.setNegativeButton(R.string.no_thanks, null)
|
|
||||||
.show();
|
|
||||||
}
|
}
|
||||||
|
|
||||||
@Nullable
|
@Nullable
|
||||||
@ -321,29 +157,6 @@ public class MagiskFragment extends Fragment
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
|
||||||
public void onActivityResult(int requestCode, int resultCode, Intent data) {
|
|
||||||
if (requestCode == SELECT_BOOT_IMG && resultCode == Activity.RESULT_OK && data != null) {
|
|
||||||
Utils.dlAndReceive(
|
|
||||||
getActivity(),
|
|
||||||
new DownloadReceiver() {
|
|
||||||
@Override
|
|
||||||
public void onDownloadDone(Uri uri) {
|
|
||||||
Intent intent = new Intent(getActivity(), FlashActivity.class);
|
|
||||||
intent.setData(uri)
|
|
||||||
.putExtra(FlashActivity.SET_BOOT, data.getData())
|
|
||||||
.putExtra(FlashActivity.SET_ENC, keepEncChkbox.isChecked())
|
|
||||||
.putExtra(FlashActivity.SET_VERITY, keepVerityChkbox.isChecked())
|
|
||||||
.putExtra(FlashActivity.SET_ACTION, FlashActivity.PATCH_BOOT);
|
|
||||||
startActivity(intent);
|
|
||||||
}
|
|
||||||
},
|
|
||||||
mm.magiskLink,
|
|
||||||
Utils.getLegalFilename("Magisk-v" + mm.remoteMagiskVersionString + ".zip")
|
|
||||||
);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public void onTopicPublished(Topic topic) {
|
public void onTopicPublished(Topic topic) {
|
||||||
if (topic == mm.updateCheckDone) {
|
if (topic == mm.updateCheckDone) {
|
||||||
@ -369,6 +182,25 @@ public class MagiskFragment extends Fragment
|
|||||||
return expandableContainer;
|
return expandableContainer;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
public String getSelectedBootImage() {
|
||||||
|
if (Shell.rootAccess()) {
|
||||||
|
if (mm.bootBlock != null) {
|
||||||
|
return mm.bootBlock;
|
||||||
|
} else {
|
||||||
|
int idx = spinner.getSelectedItemPosition();
|
||||||
|
if (idx > 0) {
|
||||||
|
return mm.blockList.get(idx - 1);
|
||||||
|
} else {
|
||||||
|
SnackbarMaker.make(getActivity(),
|
||||||
|
R.string.manual_boot_image, Snackbar.LENGTH_LONG).show();
|
||||||
|
return null;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
} else {
|
||||||
|
return null;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
private void updateUI() {
|
private void updateUI() {
|
||||||
((MainActivity) getActivity()).checkHideSection();
|
((MainActivity) getActivity()).checkHideSection();
|
||||||
|
|
||||||
|
@ -1,5 +1,6 @@
|
|||||||
package com.topjohnwu.magisk.adapters;
|
package com.topjohnwu.magisk.adapters;
|
||||||
|
|
||||||
|
import android.app.Activity;
|
||||||
import android.content.pm.PackageManager;
|
import android.content.pm.PackageManager;
|
||||||
import android.support.design.widget.Snackbar;
|
import android.support.design.widget.Snackbar;
|
||||||
import android.support.v7.widget.RecyclerView;
|
import android.support.v7.widget.RecyclerView;
|
||||||
@ -92,7 +93,7 @@ public class PolicyAdapter extends RecyclerView.Adapter<PolicyAdapter.ViewHolder
|
|||||||
dbHelper.updatePolicy(policy);
|
dbHelper.updatePolicy(policy);
|
||||||
}
|
}
|
||||||
});
|
});
|
||||||
holder.delete.setOnClickListener(v -> new AlertDialogBuilder(v.getContext())
|
holder.delete.setOnClickListener(v -> new AlertDialogBuilder((Activity) v.getContext())
|
||||||
.setTitle(R.string.su_revoke_title)
|
.setTitle(R.string.su_revoke_title)
|
||||||
.setMessage(v.getContext().getString(R.string.su_revoke_msg, policy.appName))
|
.setMessage(v.getContext().getString(R.string.su_revoke_msg, policy.appName))
|
||||||
.setPositiveButton(R.string.yes, (dialog, which) -> {
|
.setPositiveButton(R.string.yes, (dialog, which) -> {
|
||||||
|
@ -100,7 +100,7 @@ public class ReposAdapter extends SectionedAdapter<ReposAdapter.SectionHolder, R
|
|||||||
|
|
||||||
holder.downloadImage.setOnClickListener(v -> {
|
holder.downloadImage.setOnClickListener(v -> {
|
||||||
String filename = repo.getName() + "-" + repo.getVersion() + ".zip";
|
String filename = repo.getName() + "-" + repo.getVersion() + ".zip";
|
||||||
new AlertDialogBuilder(context)
|
new AlertDialogBuilder((Activity) context)
|
||||||
.setTitle(context.getString(R.string.repo_install_title, repo.getName()))
|
.setTitle(context.getString(R.string.repo_install_title, repo.getName()))
|
||||||
.setMessage(context.getString(R.string.repo_install_msg, filename))
|
.setMessage(context.getString(R.string.repo_install_msg, filename))
|
||||||
.setCancelable(true)
|
.setCancelable(true)
|
||||||
|
@ -0,0 +1,40 @@
|
|||||||
|
package com.topjohnwu.magisk.asyncs;
|
||||||
|
|
||||||
|
import android.content.Context;
|
||||||
|
import android.widget.Toast;
|
||||||
|
|
||||||
|
import com.topjohnwu.magisk.R;
|
||||||
|
import com.topjohnwu.magisk.utils.Utils;
|
||||||
|
|
||||||
|
import java.util.List;
|
||||||
|
|
||||||
|
public class RestoreStockBoot extends ParallelTask<Void, Void, Boolean> {
|
||||||
|
|
||||||
|
private String mBoot;
|
||||||
|
|
||||||
|
public RestoreStockBoot(Context context, String boot) {
|
||||||
|
super(context);
|
||||||
|
mBoot = boot;
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
protected Boolean doInBackground(Void... voids) {
|
||||||
|
List<String> ret = getShell().su("cat /init.magisk.rc | grep STOCKSHA1");
|
||||||
|
if (!Utils.isValidShellResponse(ret))
|
||||||
|
return false;
|
||||||
|
String stock_boot = "/data/stock_boot_" + ret.get(0).substring(ret.get(0).indexOf('=') + 1) + ".img.gz";
|
||||||
|
if (!Utils.itemExist(getShell(), stock_boot))
|
||||||
|
return false;
|
||||||
|
getShell().su_raw("gzip -d < " + stock_boot + " | cat - /dev/zero | dd of=" + mBoot + " bs=4096");
|
||||||
|
return true;
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
protected void onPostExecute(Boolean result) {
|
||||||
|
if (result) {
|
||||||
|
getMagiskManager().toast(R.string.restore_done, Toast.LENGTH_SHORT);
|
||||||
|
} else {
|
||||||
|
getMagiskManager().toast(R.string.restore_fail, Toast.LENGTH_LONG);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
@ -1,6 +1,6 @@
|
|||||||
package com.topjohnwu.magisk.components;
|
package com.topjohnwu.magisk.components;
|
||||||
|
|
||||||
import android.content.Context;
|
import android.app.Activity;
|
||||||
import android.content.DialogInterface;
|
import android.content.DialogInterface;
|
||||||
import android.support.annotation.NonNull;
|
import android.support.annotation.NonNull;
|
||||||
import android.support.annotation.Nullable;
|
import android.support.annotation.Nullable;
|
||||||
@ -37,12 +37,12 @@ public class AlertDialogBuilder extends AlertDialog.Builder {
|
|||||||
|
|
||||||
private AlertDialog dialog;
|
private AlertDialog dialog;
|
||||||
|
|
||||||
public AlertDialogBuilder(@NonNull Context context) {
|
public AlertDialogBuilder(@NonNull Activity context) {
|
||||||
super(context);
|
super(context);
|
||||||
setup();
|
setup();
|
||||||
}
|
}
|
||||||
|
|
||||||
public AlertDialogBuilder(@NonNull Context context, @StyleRes int themeResId) {
|
public AlertDialogBuilder(@NonNull Activity context, @StyleRes int themeResId) {
|
||||||
super(context, themeResId);
|
super(context, themeResId);
|
||||||
setup();
|
setup();
|
||||||
}
|
}
|
||||||
|
@ -1,5 +1,7 @@
|
|||||||
package com.topjohnwu.magisk.components;
|
package com.topjohnwu.magisk.components;
|
||||||
|
|
||||||
|
import android.content.Intent;
|
||||||
|
|
||||||
import com.topjohnwu.magisk.MagiskManager;
|
import com.topjohnwu.magisk.MagiskManager;
|
||||||
import com.topjohnwu.magisk.utils.Shell;
|
import com.topjohnwu.magisk.utils.Shell;
|
||||||
import com.topjohnwu.magisk.utils.Topic;
|
import com.topjohnwu.magisk.utils.Topic;
|
||||||
@ -7,6 +9,8 @@ import com.topjohnwu.magisk.utils.Utils;
|
|||||||
|
|
||||||
public class Fragment extends android.support.v4.app.Fragment {
|
public class Fragment extends android.support.v4.app.Fragment {
|
||||||
|
|
||||||
|
private ActivityResultListener activityResultListener;
|
||||||
|
|
||||||
public MagiskManager getApplication() {
|
public MagiskManager getApplication() {
|
||||||
return Utils.getMagiskManager(getActivity());
|
return Utils.getMagiskManager(getActivity());
|
||||||
}
|
}
|
||||||
@ -30,4 +34,20 @@ public class Fragment extends android.support.v4.app.Fragment {
|
|||||||
}
|
}
|
||||||
super.onPause();
|
super.onPause();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public void onActivityResult(int requestCode, int resultCode, Intent data) {
|
||||||
|
if (activityResultListener != null)
|
||||||
|
activityResultListener.onActivityResult(requestCode, resultCode, data);
|
||||||
|
activityResultListener = null;
|
||||||
|
}
|
||||||
|
|
||||||
|
public void startActivityForResult(Intent intent, int requestCode, ActivityResultListener listener) {
|
||||||
|
activityResultListener = listener;
|
||||||
|
super.startActivityForResult(intent, requestCode);
|
||||||
|
}
|
||||||
|
|
||||||
|
public interface ActivityResultListener {
|
||||||
|
void onActivityResult(int requestCode, int resultCode, Intent data);
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
@ -5,6 +5,7 @@ import android.app.Activity;
|
|||||||
import android.app.DownloadManager;
|
import android.app.DownloadManager;
|
||||||
import android.app.NotificationManager;
|
import android.app.NotificationManager;
|
||||||
import android.app.PendingIntent;
|
import android.app.PendingIntent;
|
||||||
|
import android.app.ProgressDialog;
|
||||||
import android.content.Context;
|
import android.content.Context;
|
||||||
import android.content.Intent;
|
import android.content.Intent;
|
||||||
import android.content.IntentFilter;
|
import android.content.IntentFilter;
|
||||||
@ -15,6 +16,7 @@ import android.database.Cursor;
|
|||||||
import android.net.ConnectivityManager;
|
import android.net.ConnectivityManager;
|
||||||
import android.net.NetworkInfo;
|
import android.net.NetworkInfo;
|
||||||
import android.net.Uri;
|
import android.net.Uri;
|
||||||
|
import android.os.CountDownTimer;
|
||||||
import android.os.Environment;
|
import android.os.Environment;
|
||||||
import android.provider.OpenableColumns;
|
import android.provider.OpenableColumns;
|
||||||
import android.support.annotation.StringRes;
|
import android.support.annotation.StringRes;
|
||||||
@ -24,18 +26,26 @@ import android.support.v4.app.FragmentActivity;
|
|||||||
import android.support.v4.app.NotificationCompat;
|
import android.support.v4.app.NotificationCompat;
|
||||||
import android.support.v4.app.TaskStackBuilder;
|
import android.support.v4.app.TaskStackBuilder;
|
||||||
import android.support.v4.content.ContextCompat;
|
import android.support.v4.content.ContextCompat;
|
||||||
|
import android.support.v7.app.AlertDialog;
|
||||||
import android.text.TextUtils;
|
import android.text.TextUtils;
|
||||||
import android.widget.Toast;
|
import android.widget.Toast;
|
||||||
|
|
||||||
|
import com.topjohnwu.magisk.FlashActivity;
|
||||||
|
import com.topjohnwu.magisk.MagiskFragment;
|
||||||
import com.topjohnwu.magisk.MagiskManager;
|
import com.topjohnwu.magisk.MagiskManager;
|
||||||
import com.topjohnwu.magisk.R;
|
import com.topjohnwu.magisk.R;
|
||||||
import com.topjohnwu.magisk.SplashActivity;
|
import com.topjohnwu.magisk.SplashActivity;
|
||||||
|
import com.topjohnwu.magisk.asyncs.RestoreStockBoot;
|
||||||
import com.topjohnwu.magisk.asyncs.UpdateRepos;
|
import com.topjohnwu.magisk.asyncs.UpdateRepos;
|
||||||
|
import com.topjohnwu.magisk.components.AlertDialogBuilder;
|
||||||
import com.topjohnwu.magisk.components.SnackbarMaker;
|
import com.topjohnwu.magisk.components.SnackbarMaker;
|
||||||
import com.topjohnwu.magisk.receivers.DownloadReceiver;
|
import com.topjohnwu.magisk.receivers.DownloadReceiver;
|
||||||
import com.topjohnwu.magisk.receivers.ManagerUpdate;
|
import com.topjohnwu.magisk.receivers.ManagerUpdate;
|
||||||
|
|
||||||
import java.io.File;
|
import java.io.File;
|
||||||
|
import java.io.FileOutputStream;
|
||||||
|
import java.io.IOException;
|
||||||
|
import java.io.InputStream;
|
||||||
import java.security.SecureRandom;
|
import java.security.SecureRandom;
|
||||||
import java.util.ArrayList;
|
import java.util.ArrayList;
|
||||||
import java.util.Collections;
|
import java.util.Collections;
|
||||||
@ -45,6 +55,9 @@ import java.util.Locale;
|
|||||||
|
|
||||||
public class Utils {
|
public class Utils {
|
||||||
|
|
||||||
|
public static final int SELECT_BOOT_IMG = 3;
|
||||||
|
public static final String UNINSTALLER = "magisk_uninstaller.sh";
|
||||||
|
public static final String UTIL_FUNCTIONS= "util_functions.sh";
|
||||||
public static boolean isDownloading = false;
|
public static boolean isDownloading = false;
|
||||||
|
|
||||||
private static final int MAGISK_UPDATE_NOTIFICATION_ID = 1;
|
private static final int MAGISK_UPDATE_NOTIFICATION_ID = 1;
|
||||||
@ -185,7 +198,7 @@ public class Utils {
|
|||||||
return networkInfo != null && networkInfo.isConnected();
|
return networkInfo != null && networkInfo.isConnected();
|
||||||
}
|
}
|
||||||
|
|
||||||
public static void showMagiskUpdate(MagiskManager mm) {
|
public static void showMagiskUpdateNotification(MagiskManager mm) {
|
||||||
NotificationCompat.Builder builder = new NotificationCompat.Builder(mm, MagiskManager.NOTIFICATION_CHANNEL);
|
NotificationCompat.Builder builder = new NotificationCompat.Builder(mm, MagiskManager.NOTIFICATION_CHANNEL);
|
||||||
builder.setSmallIcon(R.drawable.ic_magisk)
|
builder.setSmallIcon(R.drawable.ic_magisk)
|
||||||
.setContentTitle(mm.getString(R.string.magisk_update_title))
|
.setContentTitle(mm.getString(R.string.magisk_update_title))
|
||||||
@ -205,7 +218,7 @@ public class Utils {
|
|||||||
notificationManager.notify(MAGISK_UPDATE_NOTIFICATION_ID, builder.build());
|
notificationManager.notify(MAGISK_UPDATE_NOTIFICATION_ID, builder.build());
|
||||||
}
|
}
|
||||||
|
|
||||||
public static void showManagerUpdate(MagiskManager mm) {
|
public static void showManagerUpdateNotification(MagiskManager mm) {
|
||||||
NotificationCompat.Builder builder = new NotificationCompat.Builder(mm, MagiskManager.NOTIFICATION_CHANNEL);
|
NotificationCompat.Builder builder = new NotificationCompat.Builder(mm, MagiskManager.NOTIFICATION_CHANNEL);
|
||||||
builder.setSmallIcon(R.drawable.ic_magisk)
|
builder.setSmallIcon(R.drawable.ic_magisk)
|
||||||
.setContentTitle(mm.getString(R.string.manager_update_title))
|
.setContentTitle(mm.getString(R.string.manager_update_title))
|
||||||
@ -314,4 +327,180 @@ public class Utils {
|
|||||||
callback.run();
|
callback.run();
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
public static void showMagiskInstallDialog(MagiskFragment fragment, boolean enc, boolean verity) {
|
||||||
|
MagiskManager mm = getMagiskManager(fragment.getActivity());
|
||||||
|
String filename = getLegalFilename("Magisk-v" + mm.remoteMagiskVersionString + ".zip");
|
||||||
|
new AlertDialogBuilder(fragment.getActivity())
|
||||||
|
.setTitle(mm.getString(R.string.repo_install_title, mm.getString(R.string.magisk)))
|
||||||
|
.setMessage(mm.getString(R.string.repo_install_msg, filename))
|
||||||
|
.setCancelable(true)
|
||||||
|
.setPositiveButton(R.string.install, (d, i) -> {
|
||||||
|
List<String> options = new ArrayList<>();
|
||||||
|
options.add(mm.getString(R.string.download_zip_only));
|
||||||
|
options.add(mm.getString(R.string.patch_boot_file));
|
||||||
|
if (Shell.rootAccess()) {
|
||||||
|
options.add(mm.getString(R.string.direct_install));
|
||||||
|
}
|
||||||
|
new AlertDialog.Builder(fragment.getActivity())
|
||||||
|
.setTitle(R.string.select_method)
|
||||||
|
.setItems(
|
||||||
|
options.toArray(new String [0]),
|
||||||
|
(dialog, idx) -> {
|
||||||
|
DownloadReceiver receiver = null;
|
||||||
|
switch (idx) {
|
||||||
|
case 1:
|
||||||
|
if (mm.remoteMagiskVersionCode < 1370) {
|
||||||
|
mm.toast(R.string.no_boot_file_patch_support, Toast.LENGTH_LONG);
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
Intent intent = new Intent(Intent.ACTION_GET_CONTENT);
|
||||||
|
intent.setType("*/*");
|
||||||
|
fragment.startActivityForResult(intent, SELECT_BOOT_IMG,
|
||||||
|
(requestCode, resultCode, data) -> {
|
||||||
|
if (requestCode == SELECT_BOOT_IMG
|
||||||
|
&& resultCode == Activity.RESULT_OK && data != null) {
|
||||||
|
dlAndReceive(
|
||||||
|
fragment.getActivity(),
|
||||||
|
new DownloadReceiver() {
|
||||||
|
@Override
|
||||||
|
public void onDownloadDone(Uri uri) {
|
||||||
|
Intent intent = new Intent(mm, FlashActivity.class);
|
||||||
|
intent.setData(uri)
|
||||||
|
.setFlags(Intent.FLAG_ACTIVITY_NEW_TASK)
|
||||||
|
.putExtra(FlashActivity.SET_BOOT, data.getData())
|
||||||
|
.putExtra(FlashActivity.SET_ENC, enc)
|
||||||
|
.putExtra(FlashActivity.SET_VERITY, verity)
|
||||||
|
.putExtra(FlashActivity.SET_ACTION, FlashActivity.PATCH_BOOT);
|
||||||
|
mm.startActivity(intent);
|
||||||
|
}
|
||||||
|
},
|
||||||
|
mm.magiskLink,
|
||||||
|
filename
|
||||||
|
);
|
||||||
|
}
|
||||||
|
});
|
||||||
|
return;
|
||||||
|
case 0:
|
||||||
|
receiver = new DownloadReceiver() {
|
||||||
|
@Override
|
||||||
|
public void onDownloadDone(Uri uri) {
|
||||||
|
showUriSnack(fragment.getActivity(), uri);
|
||||||
|
}
|
||||||
|
};
|
||||||
|
break;
|
||||||
|
case 2:
|
||||||
|
final String boot = fragment.getSelectedBootImage();
|
||||||
|
if (boot == null)
|
||||||
|
return;
|
||||||
|
receiver = new DownloadReceiver() {
|
||||||
|
@Override
|
||||||
|
public void onDownloadDone(Uri uri) {
|
||||||
|
Intent intent = new Intent(mm, FlashActivity.class);
|
||||||
|
intent.setData(uri)
|
||||||
|
.setFlags(Intent.FLAG_ACTIVITY_NEW_TASK)
|
||||||
|
.putExtra(FlashActivity.SET_BOOT, boot)
|
||||||
|
.putExtra(FlashActivity.SET_ENC, enc)
|
||||||
|
.putExtra(FlashActivity.SET_VERITY, verity)
|
||||||
|
.putExtra(FlashActivity.SET_ACTION, FlashActivity.FLASH_MAGISK);
|
||||||
|
mm.startActivity(intent);
|
||||||
|
}
|
||||||
|
};
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
Utils.dlAndReceive(
|
||||||
|
mm,
|
||||||
|
receiver,
|
||||||
|
mm.magiskLink,
|
||||||
|
filename
|
||||||
|
);
|
||||||
|
}
|
||||||
|
).show();
|
||||||
|
})
|
||||||
|
.setNeutralButton(R.string.release_notes, (d, i) -> {
|
||||||
|
if (mm.releaseNoteLink != null) {
|
||||||
|
Intent openLink = new Intent(Intent.ACTION_VIEW, Uri.parse(mm.releaseNoteLink));
|
||||||
|
openLink.addFlags(Intent.FLAG_ACTIVITY_NEW_TASK);
|
||||||
|
mm.startActivity(openLink);
|
||||||
|
}
|
||||||
|
})
|
||||||
|
.setNegativeButton(R.string.no_thanks, null)
|
||||||
|
.show();
|
||||||
|
}
|
||||||
|
|
||||||
|
public static void showManagerInstallDialog(Activity activity) {
|
||||||
|
MagiskManager mm = Utils.getMagiskManager(activity);
|
||||||
|
new AlertDialogBuilder(activity)
|
||||||
|
.setTitle(mm.getString(R.string.repo_install_title, mm.getString(R.string.app_name)))
|
||||||
|
.setMessage(mm.getString(R.string.repo_install_msg,
|
||||||
|
Utils.getLegalFilename("MagiskManager-v" +
|
||||||
|
mm.remoteManagerVersionString + ".apk")))
|
||||||
|
.setCancelable(true)
|
||||||
|
.setPositiveButton(R.string.install, (d, i) -> {
|
||||||
|
Intent intent = new Intent(mm, ManagerUpdate.class);
|
||||||
|
intent.putExtra(MagiskManager.INTENT_LINK, mm.managerLink);
|
||||||
|
intent.putExtra(MagiskManager.INTENT_VERSION, mm.remoteManagerVersionString);
|
||||||
|
mm.sendBroadcast(intent);
|
||||||
|
})
|
||||||
|
.setNegativeButton(R.string.no_thanks, null)
|
||||||
|
.show();
|
||||||
|
}
|
||||||
|
|
||||||
|
public static void showUninstallDialog(MagiskFragment fragment) {
|
||||||
|
MagiskManager mm = Utils.getMagiskManager(fragment.getActivity());
|
||||||
|
new AlertDialogBuilder(fragment.getActivity())
|
||||||
|
.setTitle(R.string.uninstall_magisk_title)
|
||||||
|
.setMessage(R.string.uninstall_magisk_msg)
|
||||||
|
.setPositiveButton(R.string.complete_uninstall, (d, i) -> {
|
||||||
|
try {
|
||||||
|
InputStream in = mm.getAssets().open(UNINSTALLER);
|
||||||
|
File uninstaller = new File(mm.getCacheDir(), UNINSTALLER);
|
||||||
|
FileOutputStream out = new FileOutputStream(uninstaller);
|
||||||
|
byte[] bytes = new byte[1024];
|
||||||
|
int read;
|
||||||
|
while ((read = in.read(bytes)) != -1) {
|
||||||
|
out.write(bytes, 0, read);
|
||||||
|
}
|
||||||
|
in.close();
|
||||||
|
out.close();
|
||||||
|
in = mm.getAssets().open(UTIL_FUNCTIONS);
|
||||||
|
File utils = new File(mm.getCacheDir(), UTIL_FUNCTIONS);
|
||||||
|
out = new FileOutputStream(utils);
|
||||||
|
while ((read = in.read(bytes)) != -1) {
|
||||||
|
out.write(bytes, 0, read);
|
||||||
|
}
|
||||||
|
in.close();
|
||||||
|
out.close();
|
||||||
|
ProgressDialog progress = new ProgressDialog(fragment.getActivity());
|
||||||
|
progress.setTitle(R.string.reboot);
|
||||||
|
progress.show();
|
||||||
|
new CountDownTimer(5000, 1000) {
|
||||||
|
@Override
|
||||||
|
public void onTick(long millisUntilFinished) {
|
||||||
|
progress.setMessage(mm.getString(R.string.reboot_countdown,
|
||||||
|
millisUntilFinished / 1000));
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public void onFinish() {
|
||||||
|
progress.setMessage(mm.getString(R.string.reboot_countdown, 0));
|
||||||
|
Shell.getShell(mm).su_raw(
|
||||||
|
"mv -f " + uninstaller + " /cache/" + UNINSTALLER,
|
||||||
|
"mv -f " + utils + " /data/magisk/" + UTIL_FUNCTIONS,
|
||||||
|
"reboot"
|
||||||
|
);
|
||||||
|
}
|
||||||
|
}.start();
|
||||||
|
} catch (IOException e) {
|
||||||
|
e.printStackTrace();
|
||||||
|
}
|
||||||
|
})
|
||||||
|
.setNeutralButton(R.string.restore_stock_boot, (d, i) -> {
|
||||||
|
String boot = fragment.getSelectedBootImage();
|
||||||
|
if (boot == null) return;
|
||||||
|
new RestoreStockBoot(mm, boot).exec();
|
||||||
|
})
|
||||||
|
.setNegativeButton(R.string.no_thanks, null)
|
||||||
|
.show();
|
||||||
|
}
|
||||||
}
|
}
|
@ -399,7 +399,7 @@
|
|||||||
android:id="@+id/imageView"
|
android:id="@+id/imageView"
|
||||||
android:layout_width="50dp"
|
android:layout_width="50dp"
|
||||||
android:layout_height="wrap_content"
|
android:layout_height="wrap_content"
|
||||||
android:layout_marginEnd="20dp"
|
android:layout_marginEnd="5dp"
|
||||||
android:layout_weight="0"
|
android:layout_weight="0"
|
||||||
app:srcCompat="@mipmap/ic_launcher" />
|
app:srcCompat="@mipmap/ic_launcher" />
|
||||||
|
|
||||||
@ -419,7 +419,7 @@
|
|||||||
<FrameLayout
|
<FrameLayout
|
||||||
android:layout_width="50dp"
|
android:layout_width="50dp"
|
||||||
android:layout_height="match_parent"
|
android:layout_height="match_parent"
|
||||||
android:layout_marginStart="20dp"
|
android:layout_marginStart="5dp"
|
||||||
android:layout_weight="0">
|
android:layout_weight="0">
|
||||||
|
|
||||||
</FrameLayout>
|
</FrameLayout>
|
||||||
|
@ -38,7 +38,6 @@
|
|||||||
<string name="uninstall">إلغاء التثبيت</string>
|
<string name="uninstall">إلغاء التثبيت</string>
|
||||||
<string name="reboot_countdown">إعادة التشغيل في %1$d</string>
|
<string name="reboot_countdown">إعادة التشغيل في %1$d</string>
|
||||||
<string name="uninstall_magisk_title">إلغاء تثبيت Magisk</string>
|
<string name="uninstall_magisk_title">إلغاء تثبيت Magisk</string>
|
||||||
<string name="uninstall_magisk_msg">سيؤدي هذا إلى إزالة جميع الإضافات، MagiskSU، وربما تشفير البيانات الخاصة بك إذا لم يتم تشفيرها\nهل أنت متأكد من الاستمرار؟</string>
|
|
||||||
|
|
||||||
<!--Module Fragment-->
|
<!--Module Fragment-->
|
||||||
<string name="no_info_provided">(لم يتم توفير أي معلومات)</string>
|
<string name="no_info_provided">(لم يتم توفير أي معلومات)</string>
|
||||||
|
@ -34,7 +34,6 @@
|
|||||||
<string name="uninstall">Odinstalovat</string>
|
<string name="uninstall">Odinstalovat</string>
|
||||||
<string name="reboot_countdown">Restart za %1$d</string>
|
<string name="reboot_countdown">Restart za %1$d</string>
|
||||||
<string name="uninstall_magisk_title">Odinstalovat Magisk</string>
|
<string name="uninstall_magisk_title">Odinstalovat Magisk</string>
|
||||||
<string name="uninstall_magisk_msg">Tímto odstraníte veškeré moduly, MagiskSU a potencionálně zašifrujete svá data pokud ještě nejsou\nOpravdu chcete pokračovat?</string>
|
|
||||||
|
|
||||||
<!--Module Fragment-->
|
<!--Module Fragment-->
|
||||||
<string name="no_info_provided">(Žádné info)</string>
|
<string name="no_info_provided">(Žádné info)</string>
|
||||||
|
@ -41,7 +41,6 @@
|
|||||||
<string name="uninstall">Deinstallieren</string>
|
<string name="uninstall">Deinstallieren</string>
|
||||||
<string name="reboot_countdown">Neustart in %1$d</string>
|
<string name="reboot_countdown">Neustart in %1$d</string>
|
||||||
<string name="uninstall_magisk_title">Magisk deinstallieren</string>
|
<string name="uninstall_magisk_title">Magisk deinstallieren</string>
|
||||||
<string name="uninstall_magisk_msg">Dies entfernt alle Module, MagiskSU und verschlüsselt unter Umständen deine Daten, falls nicht bereits verschlüsselt.\nMöchtest du wirklich fortfahren?</string>
|
|
||||||
|
|
||||||
<!--Module Fragment-->
|
<!--Module Fragment-->
|
||||||
<string name="no_info_provided">(Nichts angegeben)</string>
|
<string name="no_info_provided">(Nichts angegeben)</string>
|
||||||
|
@ -36,7 +36,6 @@
|
|||||||
<string name="uninstall">Απεγκατάσταση</string>
|
<string name="uninstall">Απεγκατάσταση</string>
|
||||||
<string name="reboot_countdown">Επανεκκίνηση σε %1$d</string>
|
<string name="reboot_countdown">Επανεκκίνηση σε %1$d</string>
|
||||||
<string name="uninstall_magisk_title">Απεγκατάσταση Magisk</string>
|
<string name="uninstall_magisk_title">Απεγκατάσταση Magisk</string>
|
||||||
<string name="uninstall_magisk_msg">Αυτό θα αφαιρέσει όλες τις ενότητες, το MagiskSU και πιθανόν να κρυπτογραφήσει τα δεδομένα σας αν δεν είναι κρυπτογραφυμένα\nΕίστε σίγουρος/η ότι θέλετε να συνεχίσετε;</string>
|
|
||||||
<string name="update">Ενημέρωση %1$s</string>
|
<string name="update">Ενημέρωση %1$s</string>
|
||||||
|
|
||||||
<!--Module Fragment-->
|
<!--Module Fragment-->
|
||||||
|
@ -38,7 +38,6 @@
|
|||||||
<string name="uninstall">Desinstalar</string>
|
<string name="uninstall">Desinstalar</string>
|
||||||
<string name="reboot_countdown">Reiniciando en %1$d</string>
|
<string name="reboot_countdown">Reiniciando en %1$d</string>
|
||||||
<string name="uninstall_magisk_title">Desinstalar Magisk</string>
|
<string name="uninstall_magisk_title">Desinstalar Magisk</string>
|
||||||
<string name="uninstall_magisk_msg">Esto eliminará todos los módulos, MagiskSU, y potencialmente puede cifrar sus datos si no está encriptada\nEstas seguro de continuar?</string>
|
|
||||||
<string name="update">Actualización %1$s</string>
|
<string name="update">Actualización %1$s</string>
|
||||||
|
|
||||||
<!--Module Fragment-->
|
<!--Module Fragment-->
|
||||||
|
@ -30,7 +30,6 @@
|
|||||||
<string name="uninstall">Désinstaller</string>
|
<string name="uninstall">Désinstaller</string>
|
||||||
<string name="reboot_countdown">Redémarrage dans %1$d</string>
|
<string name="reboot_countdown">Redémarrage dans %1$d</string>
|
||||||
<string name="uninstall_magisk_title">Désinstaller Magisk</string>
|
<string name="uninstall_magisk_title">Désinstaller Magisk</string>
|
||||||
<string name="uninstall_magisk_msg">Cela va supprimer tous les modules, MagiskSU et éventuellement chiffrer vos données si vous n\'êtes pas chiffré\nÊtes-vous sûr de vouloir continuer ?</string>
|
|
||||||
<!--Module Fragment-->
|
<!--Module Fragment-->
|
||||||
<string name="no_info_provided">(Aucune information transmise)</string>
|
<string name="no_info_provided">(Aucune information transmise)</string>
|
||||||
<string name="no_modules_found">Aucun module trouvé</string>
|
<string name="no_modules_found">Aucun module trouvé</string>
|
||||||
|
@ -38,7 +38,6 @@
|
|||||||
<string name="uninstall">Disinstalla</string>
|
<string name="uninstall">Disinstalla</string>
|
||||||
<string name="reboot_countdown">Riavvio tra %1$d</string>
|
<string name="reboot_countdown">Riavvio tra %1$d</string>
|
||||||
<string name="uninstall_magisk_title">Disinstalla Magisk</string>
|
<string name="uninstall_magisk_title">Disinstalla Magisk</string>
|
||||||
<string name="uninstall_magisk_msg">Questo rimuoverà tutti i moduli, MagiskSU, e potenzialmente crittograferà i dati, se non crittografati/nVuoi continuare?</string>
|
|
||||||
<string name="update">Aggiorna %1$s</string>
|
<string name="update">Aggiorna %1$s</string>
|
||||||
|
|
||||||
<!--Module Fragment-->
|
<!--Module Fragment-->
|
||||||
|
@ -34,7 +34,6 @@
|
|||||||
<string name="uninstall">アンインストール</string>
|
<string name="uninstall">アンインストール</string>
|
||||||
<string name="reboot_countdown">%1$dで再起動します</string>
|
<string name="reboot_countdown">%1$dで再起動します</string>
|
||||||
<string name="uninstall_magisk_title">Magiskをアンインストールします</string>
|
<string name="uninstall_magisk_title">Magiskをアンインストールします</string>
|
||||||
<string name="uninstall_magisk_msg">これにより、すべてのモジュールとMagiskSUを削除します。暗号化されていないデータが暗号化される可能性があります。\ n続行しますか?</string>
|
|
||||||
|
|
||||||
<!--Module Fragment-->
|
<!--Module Fragment-->
|
||||||
<string name="no_info_provided">(情報がありません)</string>
|
<string name="no_info_provided">(情報がありません)</string>
|
||||||
|
@ -34,7 +34,6 @@
|
|||||||
<string name="uninstall">제거</string>
|
<string name="uninstall">제거</string>
|
||||||
<string name="reboot_countdown">%1$d초 안에 다시 시작됨</string>
|
<string name="reboot_countdown">%1$d초 안에 다시 시작됨</string>
|
||||||
<string name="uninstall_magisk_title">Magisk 제거</string>
|
<string name="uninstall_magisk_title">Magisk 제거</string>
|
||||||
<string name="uninstall_magisk_msg">모든 모듈과 MagiskSU를 제거합니다. 또한 데이터가 암호화되어 있지 않은 경우 암호화될 가능성이 있습니다.\n정말 계속하시겠습니까?</string>
|
|
||||||
|
|
||||||
<!--Module Fragment-->
|
<!--Module Fragment-->
|
||||||
<string name="no_info_provided">(제공된 정보 없음)</string>
|
<string name="no_info_provided">(제공된 정보 없음)</string>
|
||||||
|
@ -38,7 +38,6 @@
|
|||||||
<string name="uninstall">Deïnstalleren</string>
|
<string name="uninstall">Deïnstalleren</string>
|
||||||
<string name="reboot_countdown">Herstarten in %1$d</string>
|
<string name="reboot_countdown">Herstarten in %1$d</string>
|
||||||
<string name="uninstall_magisk_title">Magisk deïnstalleren</string>
|
<string name="uninstall_magisk_title">Magisk deïnstalleren</string>
|
||||||
<string name="uninstall_magisk_msg">Dit verwijdert alle modules, MagiskSU, en versleutelt mogelijk alle niet-versleutelde data\nZeker weten voortzetten?</string>
|
|
||||||
<string name="update">Bijwerken %1$s</string>
|
<string name="update">Bijwerken %1$s</string>
|
||||||
|
|
||||||
<!--Module Fragment-->
|
<!--Module Fragment-->
|
||||||
|
@ -41,7 +41,6 @@
|
|||||||
<string name="uninstall">Odinstaluj</string>
|
<string name="uninstall">Odinstaluj</string>
|
||||||
<string name="reboot_countdown">Restartuj do %1$d</string>
|
<string name="reboot_countdown">Restartuj do %1$d</string>
|
||||||
<string name="uninstall_magisk_title">Odinstaluj Magisk</string>
|
<string name="uninstall_magisk_title">Odinstaluj Magisk</string>
|
||||||
<string name="uninstall_magisk_msg">Spowoduje to usunięcie wszystkich modułów, MagiskSU i potencjalnie szyfrowanie danych jeśli nie były szyfrowane \ nCzy na pewno kontynuować?</string>
|
|
||||||
<string name="update">Aktualizacja %1$s</string>
|
<string name="update">Aktualizacja %1$s</string>
|
||||||
|
|
||||||
<!--Module Fragment-->
|
<!--Module Fragment-->
|
||||||
|
@ -41,7 +41,6 @@
|
|||||||
<string name="uninstall">Desinstalar</string>
|
<string name="uninstall">Desinstalar</string>
|
||||||
<string name="reboot_countdown">Reiniciando em %1$d</string>
|
<string name="reboot_countdown">Reiniciando em %1$d</string>
|
||||||
<string name="uninstall_magisk_title">Desinstalar Magisk</string>
|
<string name="uninstall_magisk_title">Desinstalar Magisk</string>
|
||||||
<string name="uninstall_magisk_msg">Isso removerá todos os módulos, MagiskSU, e Potencialmente criptografar seus dados se não criptografados\nVocê deseja continuar?</string>
|
|
||||||
|
|
||||||
<!--Module Fragment-->
|
<!--Module Fragment-->
|
||||||
<string name="no_info_provided">(Nenhuma informação fornecida)</string>
|
<string name="no_info_provided">(Nenhuma informação fornecida)</string>
|
||||||
|
@ -38,8 +38,6 @@
|
|||||||
<string name="uninstall">Desinstalar</string>
|
<string name="uninstall">Desinstalar</string>
|
||||||
<string name="reboot_countdown">A reiniciar em %1$d</string>
|
<string name="reboot_countdown">A reiniciar em %1$d</string>
|
||||||
<string name="uninstall_magisk_title">Desinstalar Magisk</string>
|
<string name="uninstall_magisk_title">Desinstalar Magisk</string>
|
||||||
<string name="uninstall_magisk_msg">Isso irá remover todos os módulos, MagiskSU, e Potencialmente encriptar seus dados se estiverem encriptados
|
|
||||||
\nDeseja continuar?</string>
|
|
||||||
<string name="update">Atualizar %1$s</string>
|
<string name="update">Atualizar %1$s</string>
|
||||||
|
|
||||||
<!--Module Fragment-->
|
<!--Module Fragment-->
|
||||||
|
@ -32,7 +32,6 @@
|
|||||||
<string name="uninstall">Dezinstalare</string>
|
<string name="uninstall">Dezinstalare</string>
|
||||||
<string name="reboot_countdown">Repornire în %1$d</string>
|
<string name="reboot_countdown">Repornire în %1$d</string>
|
||||||
<string name="uninstall_magisk_title">Dezinstalare Magisk</string>
|
<string name="uninstall_magisk_title">Dezinstalare Magisk</string>
|
||||||
<string name="uninstall_magisk_msg">Aceasta va elimina toate modulele, MagiskSU, şi potențial să cripteze datele, dacă nu sunt criptate\nContinuaţi?</string>
|
|
||||||
<string name="update">Actualizare %1$s</string>
|
<string name="update">Actualizare %1$s</string>
|
||||||
|
|
||||||
|
|
||||||
|
@ -38,7 +38,6 @@
|
|||||||
<string name="uninstall">Удалить</string>
|
<string name="uninstall">Удалить</string>
|
||||||
<string name="reboot_countdown">Перезагрузка через %1$d</string>
|
<string name="reboot_countdown">Перезагрузка через %1$d</string>
|
||||||
<string name="uninstall_magisk_title">Удалить Magisk</string>
|
<string name="uninstall_magisk_title">Удалить Magisk</string>
|
||||||
<string name="uninstall_magisk_msg">Данное действие приведет к удалению всех модулей, MagiskSU, и может зашифровать данные, если они не зашифрованы.\nУверены, что желаете продолжить?</string>
|
|
||||||
<string name="update">Обновить %1$s</string>
|
<string name="update">Обновить %1$s</string>
|
||||||
|
|
||||||
<!--Module Fragment-->
|
<!--Module Fragment-->
|
||||||
|
@ -38,7 +38,6 @@
|
|||||||
<string name="uninstall">Avinstallera</string>
|
<string name="uninstall">Avinstallera</string>
|
||||||
<string name="reboot_countdown">Omstart om %1$d</string>
|
<string name="reboot_countdown">Omstart om %1$d</string>
|
||||||
<string name="uninstall_magisk_title">Avinstallera Magisk</string>
|
<string name="uninstall_magisk_title">Avinstallera Magisk</string>
|
||||||
<string name="uninstall_magisk_msg">Detta kommer att ta bort alla moduler, MagiskSU, och potentiellt kryptera din data om inte krypterad\nÄr det säker du vill fortsätta?</string>
|
|
||||||
<string name="update">Uppdatera %1$s</string>
|
<string name="update">Uppdatera %1$s</string>
|
||||||
|
|
||||||
<!--Module Fragment-->
|
<!--Module Fragment-->
|
||||||
|
@ -37,7 +37,6 @@
|
|||||||
<string name="uninstall">Kaldır</string>
|
<string name="uninstall">Kaldır</string>
|
||||||
<string name="reboot_countdown">%1$d saniye içinde yeniden başlatılacak</string>
|
<string name="reboot_countdown">%1$d saniye içinde yeniden başlatılacak</string>
|
||||||
<string name="uninstall_magisk_title">"Magisk\'i kaldır"</string>
|
<string name="uninstall_magisk_title">"Magisk\'i kaldır"</string>
|
||||||
<string name="uninstall_magisk_msg">"Bu, tüm modülleri, MagiskSU\'yu kaldıracak ve şifrelenmemişse verilerinizi potansiyel olarak şifreleyecektir\nDevam etmek istediğinize emin misiniz?"</string>
|
|
||||||
<string name="update">Güncelle %1$s</string>
|
<string name="update">Güncelle %1$s</string>
|
||||||
|
|
||||||
<!--Module Fragment-->
|
<!--Module Fragment-->
|
||||||
|
@ -37,7 +37,6 @@
|
|||||||
<string name="uninstall">Видалити</string>
|
<string name="uninstall">Видалити</string>
|
||||||
<string name="reboot_countdown">Перезавантаження через %1$d</string>
|
<string name="reboot_countdown">Перезавантаження через %1$d</string>
|
||||||
<string name="uninstall_magisk_title">Видалити Magisk</string>
|
<string name="uninstall_magisk_title">Видалити Magisk</string>
|
||||||
<string name="uninstall_magisk_msg">Ця дія призведе до видалення всіх модулів, MagiskSU, і може зашифрувати дані, якщо вони не зашифровані.\nВпевнені, що бажаєте продовжити?</string>
|
|
||||||
<string name="update">Оновити %1$s</string>
|
<string name="update">Оновити %1$s</string>
|
||||||
|
|
||||||
<!--Module Fragment-->
|
<!--Module Fragment-->
|
||||||
|
@ -34,7 +34,6 @@
|
|||||||
<string name="uninstall">Gỡ bỏ</string>
|
<string name="uninstall">Gỡ bỏ</string>
|
||||||
<string name="reboot_countdown">Khởi động lại trong %1$d</string>
|
<string name="reboot_countdown">Khởi động lại trong %1$d</string>
|
||||||
<string name="uninstall_magisk_title">Gỡ bỏ Magisk</string>
|
<string name="uninstall_magisk_title">Gỡ bỏ Magisk</string>
|
||||||
<string name="uninstall_magisk_msg">Việc này sẽ xoá tất cả các mô-đun, MagiskSU và có khả năng sẽ mã hoá dữ liệu nếu chưa được mã hoá\nBạn chắc muốn tiếp tục?</string>
|
|
||||||
|
|
||||||
<!--Module Fragment-->
|
<!--Module Fragment-->
|
||||||
<string name="no_info_provided">(Không có thông tin được cung cấp)</string>
|
<string name="no_info_provided">(Không có thông tin được cung cấp)</string>
|
||||||
|
@ -38,7 +38,6 @@
|
|||||||
<string name="uninstall">卸载</string>
|
<string name="uninstall">卸载</string>
|
||||||
<string name="reboot_countdown">将在 %1$d 后重启</string>
|
<string name="reboot_countdown">将在 %1$d 后重启</string>
|
||||||
<string name="uninstall_magisk_title">卸载 Magisk</string>
|
<string name="uninstall_magisk_title">卸载 Magisk</string>
|
||||||
<string name="uninstall_magisk_msg">将会删除所有模块及 MagiskSU,并有可能在目前未加密的情况下加密你的数据\n你确定要继续吗?</string>
|
|
||||||
<string name="update">更新 %1$s</string>
|
<string name="update">更新 %1$s</string>
|
||||||
|
|
||||||
<!--Module Fragment-->
|
<!--Module Fragment-->
|
||||||
|
@ -157,7 +157,7 @@
|
|||||||
<string name="download">下載</string>
|
<string name="download">下載</string>
|
||||||
<string name="zip_process_title">處理中</string>
|
<string name="zip_process_title">處理中</string>
|
||||||
<string name="uninstall_magisk_title">解除安裝 Magisk</string>
|
<string name="uninstall_magisk_title">解除安裝 Magisk</string>
|
||||||
<string name="uninstall_magisk_msg">這將會刪除所有模組,MagiskSU,並有可能在目前資料未加密的情況下進行加密\n你確定要繼續嗎?</string>
|
<string name="uninstall_magisk_msg">所有模組將會被停用 / 刪除。root會被移除,並有可能在目前資料未加密的情況下被加密</string>
|
||||||
<string name="manual_boot_image">請手動選取 boot 映像位置</string>
|
<string name="manual_boot_image">請手動選取 boot 映像位置</string>
|
||||||
<string name="cannot_auto_detect">(無法自動偵測)</string>
|
<string name="cannot_auto_detect">(無法自動偵測)</string>
|
||||||
<string name="settings_notification_summary">有更新的時候顯示通知</string>
|
<string name="settings_notification_summary">有更新的時候顯示通知</string>
|
||||||
@ -208,5 +208,9 @@
|
|||||||
<string name="zip_download_title">正在下載</string>
|
<string name="zip_download_title">正在下載</string>
|
||||||
<string name="zip_download_msg">正在下載 Zip 文件 …</string>
|
<string name="zip_download_msg">正在下載 Zip 文件 …</string>
|
||||||
<string name="settings_boot_format_summary">選擇已補丁 Boot 映像文件輸出格式\n若要透過 fastboot/download 模式刷入,請選擇 .img 格式;若要透過 ODIN 刷入,則選擇 .img.tar\n</string>
|
<string name="settings_boot_format_summary">選擇已補丁 Boot 映像文件輸出格式\n若要透過 fastboot/download 模式刷入,請選擇 .img 格式;若要透過 ODIN 刷入,則選擇 .img.tar\n</string>
|
||||||
|
<string name="complete_uninstall">完全解除安裝</string>
|
||||||
|
<string name="restore_stock_boot">還原原廠 boot 映像</string>
|
||||||
|
<string name="restore_done">還原完成!</string>
|
||||||
|
<string name="restore_fail">原廠 boot 映像備份不存在!</string>
|
||||||
|
|
||||||
</resources>
|
</resources>
|
||||||
|
@ -41,7 +41,7 @@
|
|||||||
<string name="uninstall">Uninstall</string>
|
<string name="uninstall">Uninstall</string>
|
||||||
<string name="reboot_countdown">Rebooting in %1$d</string>
|
<string name="reboot_countdown">Rebooting in %1$d</string>
|
||||||
<string name="uninstall_magisk_title">Uninstall Magisk</string>
|
<string name="uninstall_magisk_title">Uninstall Magisk</string>
|
||||||
<string name="uninstall_magisk_msg">This will remove all modules, MagiskSU, and potentially encrypt your data if not encrypted\nAre you sure to continue?</string>
|
<string name="uninstall_magisk_msg">All modules will be disabled/removed. Root will be removed, and potentially encrypt your data if your data is not currently encrypted</string>
|
||||||
<string name="update">Update %1$s</string>
|
<string name="update">Update %1$s</string>
|
||||||
|
|
||||||
<!--Module Fragment-->
|
<!--Module Fragment-->
|
||||||
@ -116,6 +116,10 @@
|
|||||||
<string name="direct_install">Direct Install (Recommend)</string>
|
<string name="direct_install">Direct Install (Recommend)</string>
|
||||||
<string name="select_method">Select Method</string>
|
<string name="select_method">Select Method</string>
|
||||||
<string name="no_boot_file_patch_support">Target Magisk version doesn\'t support boot image file patching</string>
|
<string name="no_boot_file_patch_support">Target Magisk version doesn\'t support boot image file patching</string>
|
||||||
|
<string name="complete_uninstall">Complete Uninstall</string>
|
||||||
|
<string name="restore_stock_boot">Restore Stock Boot</string>
|
||||||
|
<string name="restore_done">Restoration done!</string>
|
||||||
|
<string name="restore_fail">Stock backup does not exist!</string>
|
||||||
|
|
||||||
<!--Settings Activity -->
|
<!--Settings Activity -->
|
||||||
<string name="settings_general_category">General</string>
|
<string name="settings_general_category">General</string>
|
||||||
|
Loading…
x
Reference in New Issue
Block a user