144 lines
5.3 KiB
Java
Raw Normal View History

2019-01-30 03:10:12 -05:00
package com.topjohnwu.magisk.utils;
2016-08-23 03:50:46 +08:00
2016-08-28 03:52:03 +08:00
import android.content.Context;
2019-03-24 02:16:19 -04:00
import android.content.Intent;
2017-01-28 06:13:07 +08:00
import android.content.SharedPreferences;
2018-10-17 19:44:48 -04:00
import android.content.pm.ApplicationInfo;
import android.content.pm.PackageManager;
import android.content.res.Configuration;
import android.content.res.Resources;
2016-08-29 06:35:07 +08:00
import android.net.Uri;
2018-07-31 17:41:54 +08:00
import android.widget.Toast;
2016-08-28 03:52:03 +08:00
2019-01-30 03:10:12 -05:00
import com.topjohnwu.magisk.App;
import com.topjohnwu.magisk.BuildConfig;
2019-03-24 02:16:19 -04:00
import com.topjohnwu.magisk.ClassMap;
2019-01-30 03:10:12 -05:00
import com.topjohnwu.magisk.Config;
import com.topjohnwu.magisk.Const;
2019-03-24 02:16:19 -04:00
import com.topjohnwu.magisk.R;
import com.topjohnwu.magisk.model.entity.OldModule;
import com.topjohnwu.magisk.model.update.UpdateCheckService;
2018-12-12 05:51:45 -05:00
import com.topjohnwu.net.Networking;
2018-10-28 00:54:56 -04:00
import com.topjohnwu.superuser.Shell;
2019-01-31 23:49:57 -05:00
import com.topjohnwu.superuser.internal.UiThreadHandler;
2018-08-02 00:41:10 +08:00
import com.topjohnwu.superuser.io.SuFile;
2016-08-28 03:52:03 +08:00
2017-07-22 22:14:02 +08:00
import java.util.Locale;
2018-08-02 00:41:10 +08:00
import java.util.Map;
2019-03-24 02:16:19 -04:00
import java.util.concurrent.TimeUnit;
2016-08-20 17:26:49 +02:00
import androidx.annotation.WorkerThread;
import androidx.work.Constraints;
import androidx.work.ExistingPeriodicWorkPolicy;
2019-05-13 15:34:53 +02:00
import androidx.work.ListenableWorker;
import androidx.work.NetworkType;
import androidx.work.PeriodicWorkRequest;
import androidx.work.WorkManager;
2016-08-20 17:26:49 +02:00
public class Utils {
public static void toast(CharSequence msg, int duration) {
2019-01-31 23:49:57 -05:00
UiThreadHandler.run(() -> Toast.makeText(App.self, msg, duration).show());
}
public static void toast(int resId, int duration) {
2019-01-31 23:49:57 -05:00
UiThreadHandler.run(() -> Toast.makeText(App.self, resId, duration).show());
}
public static String dlString(String url) {
String s = Networking.get(url).execForString().getResult();
return s == null ? "" : s;
}
2017-01-28 06:13:07 +08:00
public static int getPrefsInt(SharedPreferences prefs, String key, int def) {
return Integer.parseInt(prefs.getString(key, String.valueOf(def)));
}
2017-08-29 01:34:42 +08:00
public static int getPrefsInt(SharedPreferences prefs, String key) {
return getPrefsInt(prefs, key, 0);
}
2017-11-20 03:09:08 +08:00
public static int dpInPx(int dp) {
float scale = App.self.getResources().getDisplayMetrics().density;
2017-11-20 03:09:08 +08:00
return (int) (dp * scale + 0.5);
}
public static String fmt(String fmt, Object... args) {
return String.format(Locale.US, fmt, args);
}
2018-05-06 02:51:23 +08:00
public static String getAppLabel(ApplicationInfo info, PackageManager pm) {
try {
if (info.labelRes > 0) {
Resources res = pm.getResourcesForApplication(info);
Configuration config = new Configuration();
config.setLocale(LocaleManager.getLocale());
res.updateConfiguration(config, res.getDisplayMetrics());
return res.getString(info.labelRes);
}
} catch (Exception ignored) {}
return info.loadLabel(pm).toString();
2018-07-31 17:41:54 +08:00
}
public static String getLegalFilename(CharSequence filename) {
return filename.toString().replace(" ", "_").replace("'", "").replace("\"", "")
.replace("$", "").replace("`", "").replace("*", "").replace("/", "_")
.replace("#", "").replace("@", "").replace("\\", "_");
2018-07-31 17:41:54 +08:00
}
2018-08-02 00:41:10 +08:00
@WorkerThread
public static Map<String, OldModule> loadModulesLeanback() {
final Map<String, OldModule> moduleMap = new ValueSortedMap<>();
final SuFile path = new SuFile(Const.MAGISK_PATH);
final SuFile[] modules = path.listFiles((file, name) ->
!name.equals("lost+found") && !name.equals(".core")
);
for (SuFile file : modules) {
if (file.isFile()) continue;
OldModule module = new OldModule(Const.MAGISK_PATH + "/" + file.getName());
moduleMap.put(module.getId(), module);
}
return moduleMap;
}
2018-10-28 00:54:56 -04:00
public static boolean showSuperUser() {
return Shell.rootAccess() && (Const.USER_ID == 0 ||
2019-01-21 15:49:03 -05:00
(int) Config.get(Config.Key.SU_MULTIUSER_MODE) !=
Config.Value.MULTIUSER_MODE_OWNER_MANAGED);
2018-10-28 00:54:56 -04:00
}
public static boolean isCanary() {
return BuildConfig.VERSION_NAME.contains("-");
}
2019-03-24 02:16:19 -04:00
2019-05-13 15:34:53 +02:00
@SuppressWarnings("unchecked")
2019-03-24 02:16:19 -04:00
public static void scheduleUpdateCheck() {
if (Config.get(Config.Key.CHECK_UPDATES)) {
Constraints constraints = new Constraints.Builder()
.setRequiredNetworkType(NetworkType.CONNECTED)
.build();
2019-05-13 15:34:53 +02:00
Class<? extends ListenableWorker> service = (Class<? extends ListenableWorker>) ClassMap.get(UpdateCheckService.class);
2019-03-24 02:16:19 -04:00
PeriodicWorkRequest request = new PeriodicWorkRequest
2019-05-13 15:34:53 +02:00
.Builder(service, 12, TimeUnit.HOURS)
2019-03-24 02:16:19 -04:00
.setConstraints(constraints)
.build();
WorkManager.getInstance().enqueueUniquePeriodicWork(
Const.ID.CHECK_MAGISK_UPDATE_WORKER_ID,
ExistingPeriodicWorkPolicy.REPLACE, request);
} else {
WorkManager.getInstance().cancelUniqueWork(Const.ID.CHECK_MAGISK_UPDATE_WORKER_ID);
}
}
public static void openLink(Context context, Uri link) {
Intent intent = new Intent(Intent.ACTION_VIEW, link);
intent.addFlags(Intent.FLAG_ACTIVITY_NEW_TASK);
if (intent.resolveActivity(context.getPackageManager()) != null) {
context.startActivity(intent);
} else {
toast(R.string.open_link_failed_toast, Toast.LENGTH_SHORT);
}
}
}