TaskService.java 12 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288
  1. package xn.update.service;
  2. import android.app.Notification;
  3. import android.app.NotificationChannel;
  4. import android.app.NotificationManager;
  5. import android.app.Service;
  6. import android.content.Intent;
  7. import android.content.IntentFilter;
  8. import android.os.Build;
  9. import android.os.CountDownTimer;
  10. import android.os.IBinder;
  11. import android.text.TextUtils;
  12. import android.util.Log;
  13. import androidx.annotation.NonNull;
  14. import androidx.annotation.Nullable;
  15. import androidx.core.app.NotificationCompat;
  16. import androidx.core.util.Pair;
  17. import androidx.work.ExistingPeriodicWorkPolicy;
  18. import androidx.work.PeriodicWorkRequest;
  19. import androidx.work.WorkManager;
  20. import com.blankj.utilcode.util.ActivityUtils;
  21. import com.blankj.utilcode.util.AppUtils;
  22. import com.blankj.utilcode.util.FileUtils;
  23. import com.blankj.utilcode.util.LogUtils;
  24. import com.blankj.utilcode.util.NetworkUtils;
  25. import com.blankj.utilcode.util.SPUtils;
  26. import com.blankj.utilcode.util.ThreadUtils;
  27. import com.hikvision.dmb.display.InfoDisplayApi;
  28. import com.hikvision.dmb.network.InfoNetworkApi;
  29. import com.hikvision.dmb.system.InfoSystemApi;
  30. import com.hikvision.dmb.util.InfoUtilApi;
  31. import com.hjq.permissions.OnPermissionCallback;
  32. import com.hjq.permissions.Permission;
  33. import com.hjq.permissions.XXPermissions;
  34. import com.lxj.xpopup.XPopup;
  35. import org.greenrobot.eventbus.EventBus;
  36. import org.json.JSONObject;
  37. import java.io.File;
  38. import java.util.List;
  39. import java.util.concurrent.ThreadLocalRandom;
  40. import java.util.concurrent.TimeUnit;
  41. import okhttp3.Response;
  42. import xn.update.R;
  43. import xn.update.Tool;
  44. import xn.update.constant.AppConstant;
  45. import xn.update.evnet.UpdateUiEvent;
  46. import xn.update.http.HttpTool;
  47. import xn.update.receiver.TimeTickReceiver;
  48. import xn.update.works.TaskWork;
  49. public class TaskService extends Service {
  50. private TimeTickReceiver timeTickReceiver;
  51. private CountDownTimer permissionCdt;
  52. @Nullable
  53. @Override
  54. public IBinder onBind(Intent intent) {
  55. return null;
  56. }
  57. @Override
  58. public void onCreate() {
  59. super.onCreate();
  60. // 卸载老旧app
  61. Tool.INSTANCE.cmd("pm uninstall com.dlc.xn.eboard");
  62. // 启动保活worker
  63. PeriodicWorkRequest taskRequest = new PeriodicWorkRequest.Builder(TaskWork.class, 15, TimeUnit.MINUTES).build();
  64. WorkManager.getInstance(getApplicationContext()).enqueueUniquePeriodicWork("Task", ExistingPeriodicWorkPolicy.CANCEL_AND_REENQUEUE, taskRequest);
  65. // 自动更新应用
  66. SPUtils.getInstance().put(AppConstant.AUTO_UPDATE, true);
  67. // 自动拉起主应用
  68. SPUtils.getInstance().put(AppConstant.AUTO_MASTER, true);
  69. InfoSystemApi.openAdb();
  70. InfoDisplayApi.setStatusBarEnable(false);
  71. InfoDisplayApi.setNavigationBarEnable(false);
  72. InfoUtilApi.setUsbSwitch(false);
  73. SPUtils.getInstance().put("isRoot", 0 == InfoUtilApi.getRoot());
  74. SPUtils.getInstance().put("IP", InfoNetworkApi.getEthernetConfig().ipAddress);
  75. InfoUtilApi.enableProtection(AppUtils.getAppPackageName(), false);
  76. InfoSystemApi.setLauncherForced(AppUtils.getAppPackageName());
  77. createNotificationChannel();
  78. timeTickReceiver = new TimeTickReceiver();
  79. // 监听分钟广播
  80. registerReceiver(timeTickReceiver, new IntentFilter(Intent.ACTION_TIME_TICK));
  81. Tool.INSTANCE.cmd("pm grant " + AppUtils.getAppPackageName() + " android.permission.READ_EXTERNAL_STORAGE");
  82. Tool.INSTANCE.cmd("pm grant " + AppUtils.getAppPackageName() + " android.permission.WRITE_EXTERNAL_STORAGE");
  83. Tool.INSTANCE.cmd("pm grant " + AppUtils.getAppPackageName() + " android.permission.NOTIFICATION_SERVICE");
  84. permissionCdt = new CountDownTimer(1000, 1000) {
  85. @Override
  86. public void onTick(long millisUntilFinished) {
  87. }
  88. @Override
  89. public void onFinish() {
  90. if (!XXPermissions.isGranted(ActivityUtils.getTopActivity(), Permission.READ_EXTERNAL_STORAGE)
  91. || !XXPermissions.isGranted(ActivityUtils.getTopActivity(), Permission.WRITE_EXTERNAL_STORAGE)
  92. || !XXPermissions.isGranted(ActivityUtils.getTopActivity(), Permission.NOTIFICATION_SERVICE)
  93. ) {
  94. Tool.INSTANCE.cmd("pm grant " + AppUtils.getAppPackageName() + " android.permission.READ_EXTERNAL_STORAGE");
  95. Tool.INSTANCE.cmd("pm grant " + AppUtils.getAppPackageName() + " android.permission.WRITE_EXTERNAL_STORAGE");
  96. Tool.INSTANCE.cmd("pm grant " + AppUtils.getAppPackageName() + " android.permission.NOTIFICATION_SERVICE");
  97. permissionCdt.start();
  98. } else {
  99. requestPermission();
  100. permissionCdt.cancel();
  101. permissionCdt = null;
  102. }
  103. }
  104. };
  105. permissionCdt.start();
  106. }
  107. @Override
  108. public int onStartCommand(Intent intent, int flags, int startId) {
  109. LogUtils.d(getClass().getName(), "onStartCommand");
  110. Notification notification = createNotification();
  111. startForeground(1, notification);
  112. return START_REDELIVER_INTENT;
  113. }
  114. @Override
  115. public void onTaskRemoved(Intent rootIntent) {
  116. super.onTaskRemoved(rootIntent);
  117. LogUtils.d(getClass().getName(), "onTaskRemoved");
  118. stopSelf();
  119. }
  120. @Override
  121. public void onDestroy() {
  122. super.onDestroy();
  123. if (null != timeTickReceiver) {
  124. unregisterReceiver(timeTickReceiver);
  125. timeTickReceiver = null;
  126. }
  127. LogUtils.d(getClass().getName(), "onDestroy");
  128. }
  129. private void createNotificationChannel() {
  130. if (Build.VERSION.SDK_INT >= Build.VERSION_CODES.O) {
  131. int importance = NotificationManager.IMPORTANCE_DEFAULT;
  132. NotificationChannel channel = new NotificationChannel("task", "task", importance);
  133. NotificationManager notificationManager = getSystemService(NotificationManager.class);
  134. notificationManager.createNotificationChannel(channel);
  135. }
  136. }
  137. private Notification createNotification() {
  138. NotificationCompat.Builder builder = new NotificationCompat.Builder(this, "task")
  139. .setContentTitle("Task")
  140. .setContentText("Task is running")
  141. .setSmallIcon(R.mipmap.ic_launcher)
  142. .setContentIntent(null)
  143. .setSilent(true)
  144. .setPriority(NotificationCompat.PRIORITY_DEFAULT);
  145. return builder.build();
  146. }
  147. private void requestPermission() {
  148. // 全量权限申请
  149. XXPermissions.with(ActivityUtils.getTopActivity())
  150. .permission(Permission.READ_EXTERNAL_STORAGE)
  151. .permission(Permission.WRITE_EXTERNAL_STORAGE)
  152. .permission(Permission.NOTIFICATION_SERVICE)
  153. .request(new OnPermissionCallback() {
  154. @Override
  155. public void onGranted(@NonNull List<String> permissions, boolean allGranted) {
  156. if (allGranted) {
  157. terminalAuth();
  158. } else {
  159. new XPopup.Builder(TaskService.this)
  160. .dismissOnBackPressed(false)
  161. .dismissOnTouchOutside(false)
  162. .asConfirm("Tips", "您必须同意所有权限才可以继续使用", ()
  163. -> requestPermission())
  164. .show();
  165. }
  166. }
  167. @Override
  168. public void onDenied(@NonNull List<String> permissions, boolean doNotAskAgain) {
  169. OnPermissionCallback.super.onDenied(permissions, doNotAskAgain);
  170. if (doNotAskAgain) {
  171. new XPopup.Builder(TaskService.this)
  172. .dismissOnBackPressed(false)
  173. .dismissOnTouchOutside(false)
  174. .asConfirm("Tips", "您必须同意所有权限才可以继续使用", ()
  175. -> XXPermissions.startPermissionActivity(TaskService.this, permissions))
  176. .show();
  177. } else {
  178. new XPopup.Builder(TaskService.this)
  179. .dismissOnBackPressed(false)
  180. .dismissOnTouchOutside(false)
  181. .asConfirm("Tips", "您必须同意所有权限才可以继续使用", ()
  182. -> requestPermission())
  183. .show();
  184. }
  185. }
  186. });
  187. }
  188. ThreadUtils.SimpleTask<Boolean> simpleTask = new ThreadUtils.SimpleTask<Boolean>() {
  189. @Override
  190. public Boolean doInBackground() throws Throwable {
  191. return NetworkUtils.isAvailableByPing(Tool.INSTANCE.getBaseUrl().host());
  192. }
  193. @Override
  194. public void onSuccess(Boolean result) {
  195. if (result) {
  196. EventBus.getDefault().post(new UpdateUiEvent("鉴权中..."));
  197. ThreadUtils.executeByCached(new ThreadUtils.SimpleTask<Pair<Boolean, String>>() {
  198. @Override
  199. public Pair<Boolean, String> doInBackground() throws Throwable {
  200. try {
  201. SPUtils.getInstance().put("TerminalAuth", "");
  202. Response response = HttpTool.INSTANCE.terminalAuth();
  203. if (response.isSuccessful()) {
  204. String json = response.body().string();
  205. JSONObject jsonObject = new JSONObject(json);
  206. int code = jsonObject.getInt("code");
  207. if (200 == code) {
  208. String data = jsonObject.getString("data");
  209. SPUtils.getInstance().put("TerminalAuth", TextUtils.isEmpty(data) ? "" : data);
  210. return Pair.create(true, "");
  211. } else {
  212. return Pair.create(false, jsonObject.getString("message"));
  213. }
  214. }
  215. } catch (Exception e) {
  216. LogUtils.e(Log.getStackTraceString(e));
  217. }
  218. return Pair.create(false, "鉴权异常,请联系管理员!");
  219. }
  220. @Override
  221. public void onSuccess(Pair<Boolean, String> result) {
  222. if (result.first) {
  223. EventBus.getDefault().post(new UpdateUiEvent(result.second));
  224. ThreadUtils.cancel(simpleTask);
  225. } else {
  226. EventBus.getDefault().post(new UpdateUiEvent(result.second));
  227. }
  228. }
  229. });
  230. } else {
  231. EventBus.getDefault().post(new UpdateUiEvent("无法连接到服务器,请联系管理员!"));
  232. }
  233. }
  234. };
  235. private void terminalAuth() {
  236. ThreadUtils.executeByCachedAtFixRate(simpleTask, ThreadLocalRandom.current().nextInt(10, 20), TimeUnit.SECONDS);
  237. // 清理一个月前的log
  238. ThreadUtils.executeByCached(new ThreadUtils.SimpleTask<Object>() {
  239. @Override
  240. public Object doInBackground() throws Throwable {
  241. List<File> fileList = FileUtils.listFilesInDir("/sdcard/logs/");
  242. for (int i = 0; i < fileList.size(); i++) {
  243. File file = fileList.get(i);
  244. long oneMonth = 30 * 86400 * 1000L;
  245. if ((System.currentTimeMillis() - file.lastModified()) > oneMonth) {
  246. LogUtils.d("删除日志文件", file);
  247. FileUtils.delete(file);
  248. }
  249. }
  250. return null;
  251. }
  252. @Override
  253. public void onSuccess(Object result) {
  254. }
  255. });
  256. }
  257. }