更新 MonitorService.java

dev
wangsiyuan 2023-12-09 17:06:22 +08:00
parent f95229b421
commit 935ded253b
1 changed files with 33 additions and 4 deletions

View File

@ -1,9 +1,12 @@
package com.nbee.echolink.service; package com.nbee.echolink.service;
import android.app.AlarmManager;
import android.app.Notification; import android.app.Notification;
import android.app.NotificationChannel; import android.app.NotificationChannel;
import android.app.NotificationManager; import android.app.NotificationManager;
import android.app.PendingIntent;
import android.app.Service; import android.app.Service;
import android.content.Context;
import android.content.Intent; import android.content.Intent;
import android.os.Build; import android.os.Build;
import android.os.IBinder; import android.os.IBinder;
@ -12,14 +15,25 @@ import android.util.Log;
import androidx.annotation.Nullable; import androidx.annotation.Nullable;
import androidx.core.app.NotificationCompat; import androidx.core.app.NotificationCompat;
import com.google.gson.Gson;
import com.google.gson.JsonSyntaxException;
import com.nbee.echolink.R; import com.nbee.echolink.R;
import com.nbee.echolink.broadcast.HeartbeatAlarmReceiver;
import com.nbee.echolink.model.CallInfo; import com.nbee.echolink.model.CallInfo;
import com.nbee.echolink.model.DeviceInfo;
import com.nbee.echolink.model.SMSInfo; import com.nbee.echolink.model.SMSInfo;
import com.nbee.echolink.response.ApiResponse;
import com.nbee.echolink.utils.DeviceInfoUtils;
import com.nbee.echolink.utils.NetworkUtil; import com.nbee.echolink.utils.NetworkUtil;
import java.io.IOException;
import java.text.SimpleDateFormat; import java.text.SimpleDateFormat;
import java.util.Date; import java.util.Date;
import okhttp3.MediaType;
import okhttp3.OkHttpClient;
import okhttp3.Request;
import okhttp3.RequestBody;
import timber.log.Timber; import timber.log.Timber;
public class MonitorService extends Service { public class MonitorService extends Service {
@ -27,18 +41,17 @@ public class MonitorService extends Service {
private static final String TAG = "MonitorService"; private static final String TAG = "MonitorService";
private String lastPhoneNumber = null; private String lastPhoneNumber = null;
private long lastCallTime = 0; private long lastCallTime = 0;
private int count; private static final long HEARTBEAT_INTERVAL_MINUTES = 10; // 10分钟
@Override @Override
public void onCreate() { public void onCreate() {
super.onCreate(); super.onCreate();
Timber.d("MonitorService onCreate"); Timber.d("监控服务 onCreate");
startForegroundService(); startForegroundService();
networkUtil = new NetworkUtil(this); networkUtil = new NetworkUtil(this);
scheduleHeartbeat(); // 启动心跳定时任务
} }
@Override @Override
public int onStartCommand(Intent intent, int flags, int startId) { public int onStartCommand(Intent intent, int flags, int startId) {
Timber.d("MonitorService onStartCommand");
if (intent != null) { if (intent != null) {
if (intent.hasExtra("incomingNumber")) { if (intent.hasExtra("incomingNumber")) {
String incomingNumber = intent.getStringExtra("incomingNumber"); String incomingNumber = intent.getStringExtra("incomingNumber");
@ -126,4 +139,20 @@ public class MonitorService extends Service {
Timber.d("MonitorService onBind"); Timber.d("MonitorService onBind");
return null; // 不提供绑定服务的接口 return null; // 不提供绑定服务的接口
} }
private void scheduleHeartbeat() {
AlarmManager alarmManager = (AlarmManager) getSystemService(Context.ALARM_SERVICE);
Intent intent = new Intent(this, HeartbeatAlarmReceiver.class); // HeartbeatAlarmReceiver是一个BroadcastReceiver
PendingIntent pendingIntent = PendingIntent.getBroadcast(this, 0, intent, 0);
long intervalMillis = HEARTBEAT_INTERVAL_MINUTES * 60 * 1000; // 10分钟的毫秒数
if (Build.VERSION.SDK_INT >= Build.VERSION_CODES.M) {
alarmManager.setExactAndAllowWhileIdle(AlarmManager.RTC_WAKEUP, System.currentTimeMillis() + intervalMillis, pendingIntent);
} else if (Build.VERSION.SDK_INT >= Build.VERSION_CODES.KITKAT) {
alarmManager.setExact(AlarmManager.RTC_WAKEUP, System.currentTimeMillis() + intervalMillis, pendingIntent);
} else {
alarmManager.set(AlarmManager.RTC_WAKEUP, System.currentTimeMillis() + intervalMillis, pendingIntent);
}
}
} }