Magisk/app/src/main/java/com/topjohnwu/magisk/MagiskLogFragment.java

228 lines
6.9 KiB
Java
Raw Normal View History

2017-01-27 03:38:53 +08:00
package com.topjohnwu.magisk;
import android.Manifest;
2017-01-27 03:38:53 +08:00
import android.os.Bundle;
import android.support.annotation.Nullable;
import android.support.design.widget.Snackbar;
import android.text.TextUtils;
import android.view.LayoutInflater;
import android.view.Menu;
import android.view.MenuInflater;
import android.view.MenuItem;
import android.view.View;
import android.view.ViewGroup;
import android.widget.HorizontalScrollView;
import android.widget.ProgressBar;
import android.widget.ScrollView;
import android.widget.TextView;
import android.widget.Toast;
2017-07-16 01:20:39 +08:00
import com.topjohnwu.magisk.asyncs.ParallelTask;
2017-02-07 02:01:32 +08:00
import com.topjohnwu.magisk.components.Fragment;
2017-02-15 05:24:02 +08:00
import com.topjohnwu.magisk.components.SnackbarMaker;
2017-11-06 04:41:23 +08:00
import com.topjohnwu.magisk.utils.Const;
import com.topjohnwu.magisk.utils.Shell;
import com.topjohnwu.magisk.utils.Utils;
2017-01-27 03:38:53 +08:00
import java.io.File;
import java.io.FileWriter;
import java.io.IOException;
import java.util.Calendar;
2017-11-18 00:04:31 +08:00
import java.util.Locale;
2017-01-27 03:38:53 +08:00
import butterknife.BindView;
import butterknife.ButterKnife;
import butterknife.Unbinder;
public class MagiskLogFragment extends Fragment {
private Unbinder unbinder;
2017-01-27 03:38:53 +08:00
@BindView(R.id.txtLog) TextView txtLog;
@BindView(R.id.svLog) ScrollView svLog;
@BindView(R.id.hsvLog) HorizontalScrollView hsvLog;
@BindView(R.id.progressBar) ProgressBar progressBar;
@Nullable
@Override
public View onCreateView(LayoutInflater inflater, ViewGroup container, Bundle savedInstanceState) {
View view = inflater.inflate(R.layout.fragment_magisk_log, container, false);
unbinder = ButterKnife.bind(this, view);
setHasOptionsMenu(true);
2017-01-27 03:38:53 +08:00
txtLog.setTextIsSelectable(true);
new LogManager().read();
2017-01-27 03:38:53 +08:00
return view;
}
@Override
public void onStart() {
super.onStart();
getActivity().setTitle(R.string.log);
}
@Override
public void onResume() {
super.onResume();
new LogManager().read();
2017-01-27 03:38:53 +08:00
}
@Override
public void onDestroyView() {
super.onDestroyView();
unbinder.unbind();
}
@Override
public void onCreateOptionsMenu(Menu menu, MenuInflater inflater) {
inflater.inflate(R.menu.menu_log, menu);
}
@Override
public boolean onOptionsItemSelected(MenuItem item) {
switch (item.getItemId()) {
case R.id.menu_refresh:
new LogManager().read();
2017-01-27 03:38:53 +08:00
return true;
case R.id.menu_save:
Utils.runWithPermission(getActivity(),
Manifest.permission.WRITE_EXTERNAL_STORAGE,
() -> new LogManager().save());
2017-01-27 03:38:53 +08:00
return true;
case R.id.menu_clear:
new LogManager().clear();
2017-01-27 03:38:53 +08:00
return true;
default:
return true;
}
}
2017-07-16 01:20:39 +08:00
private class LogManager extends ParallelTask<Object, Void, Object> {
2017-01-27 03:38:53 +08:00
private int mode;
private File targetFile;
2017-07-16 01:20:39 +08:00
LogManager() {
super(MagiskLogFragment.this.getActivity());
}
2017-01-27 03:38:53 +08:00
@Override
2017-07-16 01:20:39 +08:00
protected Object doInBackground(Object... params) {
2017-01-27 03:38:53 +08:00
mode = (int) params[0];
switch (mode) {
case 0:
StringBuildingList logList = new StringBuildingList();
2017-11-06 04:41:23 +08:00
Shell.su(logList, "cat " + Const.MAGISK_LOG + " | tail -n 1000");
return logList.getCharSequence();
2017-01-27 03:38:53 +08:00
case 1:
2017-11-06 04:41:23 +08:00
Shell.su_raw("echo -n > " + Const.MAGISK_LOG);
2017-02-15 05:24:02 +08:00
SnackbarMaker.make(txtLog, R.string.logs_cleared, Snackbar.LENGTH_SHORT).show();
2017-01-27 03:38:53 +08:00
return "";
case 2:
Calendar now = Calendar.getInstance();
2017-11-18 00:04:31 +08:00
String filename = String.format(Locale.US,
"magisk_log_%04d%02d%02d_%02d:%02d:%02d.log",
2017-01-27 03:38:53 +08:00
now.get(Calendar.YEAR), now.get(Calendar.MONTH) + 1,
now.get(Calendar.DAY_OF_MONTH), now.get(Calendar.HOUR_OF_DAY),
now.get(Calendar.MINUTE), now.get(Calendar.SECOND));
2017-11-18 00:04:31 +08:00
targetFile = new File(Const.EXTERNAL_PATH + "/logs", filename);
2017-01-27 03:38:53 +08:00
if ((!targetFile.getParentFile().exists() && !targetFile.getParentFile().mkdirs())
|| (targetFile.exists() && !targetFile.delete())) {
2017-01-27 03:38:53 +08:00
return false;
}
2017-01-27 03:38:53 +08:00
try (FileWriter out = new FileWriter(targetFile)) {
FileWritingList fileWritingList = new FileWritingList(out);
2017-11-06 04:41:23 +08:00
Shell.su(fileWritingList, "cat " + Const.MAGISK_LOG);
} catch (IOException e) {
e.printStackTrace();
return false;
2017-01-27 03:38:53 +08:00
}
return true;
2017-01-27 03:38:53 +08:00
}
return null;
}
@Override
protected void onPostExecute(Object o) {
if (o == null) return;
switch (mode) {
case 0:
case 1:
2017-11-06 04:41:23 +08:00
CharSequence llog = (CharSequence) o;
2017-01-27 03:38:53 +08:00
progressBar.setVisibility(View.GONE);
if (TextUtils.isEmpty(llog))
txtLog.setText(R.string.log_is_empty);
else
txtLog.setText(llog);
2017-10-16 14:08:14 +08:00
svLog.postDelayed(() -> svLog.fullScroll(ScrollView.FOCUS_DOWN), 100);
hsvLog.postDelayed(() -> hsvLog.fullScroll(ScrollView.FOCUS_LEFT), 100);
2017-01-27 03:38:53 +08:00
break;
case 2:
boolean bool = (boolean) o;
if (bool) {
2017-11-06 04:41:23 +08:00
MagiskManager.toast(targetFile.getPath(), Toast.LENGTH_LONG);
} else {
2017-10-16 00:54:48 +08:00
MagiskManager.toast(R.string.logs_save_failed, Toast.LENGTH_LONG);
}
2017-01-27 03:38:53 +08:00
break;
}
}
void read() {
2017-01-27 03:38:53 +08:00
exec(0);
}
void clear() {
2017-01-27 03:38:53 +08:00
exec(1);
}
void save() {
2017-01-27 03:38:53 +08:00
exec(2);
}
}
private static class StringBuildingList extends Shell.AbstractList<String> {
StringBuilder builder;
StringBuildingList() {
builder = new StringBuilder();
}
@Override
public boolean add(String s) {
builder.append(s).append("\n");
return true;
}
2017-11-06 04:41:23 +08:00
public CharSequence getCharSequence() {
return builder;
}
}
private static class FileWritingList extends Shell.AbstractList<String> {
private FileWriter writer;
FileWritingList(FileWriter out) {
writer = out;
}
@Override
public boolean add(String s) {
try {
writer.write(s + "\n");
} catch (IOException ignored) {}
return true;
}
}
2017-01-27 03:38:53 +08:00
}