正在查看: CallApp v2.226 应用的 DownloadService.java JAVA 源代码文件
本页面展示 JAVA 反编译生成的源代码文件,支持语法高亮显示。 仅供安全研究与技术分析使用,严禁用于任何非法用途。请遵守相关法律法规。
正在查看: CallApp v2.226 应用的 DownloadService.java JAVA 源代码文件
本页面展示 JAVA 反编译生成的源代码文件,支持语法高亮显示。 仅供安全研究与技术分析使用,严禁用于任何非法用途。请遵守相关法律法规。
package io.bidmachine.media3.exoplayer.offline;
import android.app.Notification;
import android.app.NotificationManager;
import android.app.Service;
import android.content.Context;
import android.content.Intent;
import android.os.Handler;
import android.os.IBinder;
import android.os.Looper;
import androidx.annotation.Nullable;
import io.bidmachine.ads.networks.gam_dynamic.versions.v22_0_0.f;
import io.bidmachine.media3.common.util.Assertions;
import io.bidmachine.media3.common.util.Log;
import io.bidmachine.media3.common.util.NotificationUtil;
import io.bidmachine.media3.common.util.UnstableApi;
import io.bidmachine.media3.common.util.Util;
import io.bidmachine.media3.exoplayer.offline.DownloadManager;
import io.bidmachine.media3.exoplayer.scheduler.Requirements;
import io.bidmachine.media3.exoplayer.scheduler.Scheduler;
import java.util.HashMap;
import java.util.List;
@UnstableApi
public abstract class DownloadService extends Service {
public static final String ACTION_ADD_DOWNLOAD = "io.bidmachine.media3.exoplayer.downloadService.action.ADD_DOWNLOAD";
public static final String ACTION_INIT = "io.bidmachine.media3.exoplayer.downloadService.action.INIT";
public static final String ACTION_PAUSE_DOWNLOADS = "io.bidmachine.media3.exoplayer.downloadService.action.PAUSE_DOWNLOADS";
public static final String ACTION_REMOVE_ALL_DOWNLOADS = "io.bidmachine.media3.exoplayer.downloadService.action.REMOVE_ALL_DOWNLOADS";
public static final String ACTION_REMOVE_DOWNLOAD = "io.bidmachine.media3.exoplayer.downloadService.action.REMOVE_DOWNLOAD";
private static final String ACTION_RESTART = "io.bidmachine.media3.exoplayer.downloadService.action.RESTART";
public static final String ACTION_RESUME_DOWNLOADS = "io.bidmachine.media3.exoplayer.downloadService.action.RESUME_DOWNLOADS";
public static final String ACTION_SET_REQUIREMENTS = "io.bidmachine.media3.exoplayer.downloadService.action.SET_REQUIREMENTS";
public static final String ACTION_SET_STOP_REASON = "io.bidmachine.media3.exoplayer.downloadService.action.SET_STOP_REASON";
public static final long DEFAULT_FOREGROUND_NOTIFICATION_UPDATE_INTERVAL = 1000;
public static final int FOREGROUND_NOTIFICATION_ID_NONE = 0;
public static final String KEY_CONTENT_ID = "content_id";
public static final String KEY_DOWNLOAD_REQUEST = "download_request";
public static final String KEY_FOREGROUND = "foreground";
public static final String KEY_REQUIREMENTS = "requirements";
public static final String KEY_STOP_REASON = "stop_reason";
private static final String TAG = "DownloadService";
private static final HashMap<Class<? extends DownloadService>, a> downloadManagerHelpers = new HashMap<>();
private final int channelDescriptionResourceId;
@Nullable
private final String channelId;
private final int channelNameResourceId;
private a downloadManagerHelper;
@Nullable
private final b foregroundNotificationUpdater;
private boolean isDestroyed;
private boolean isStopped;
private int lastStartId;
private boolean startedInForeground;
private boolean taskRemoved;
public static final class a implements DownloadManager.Listener {
private final Context context;
private final DownloadManager downloadManager;
@Nullable
private DownloadService downloadService;
private final boolean foregroundAllowed;
private Requirements scheduledRequirements;
@Nullable
private final Scheduler scheduler;
private final Class<? extends DownloadService> serviceClass;
private void cancelScheduler() {
Requirements requirements = new Requirements(0);
if (schedulerNeedsUpdate(requirements)) {
this.scheduler.cancel();
this.scheduledRequirements = requirements;
}
}
public void lambda$attachService$0(DownloadService downloadService) {
downloadService.notifyDownloads(this.downloadManager.getCurrentDownloads());
}
private void restartService() {
if (this.foregroundAllowed) {
try {
Util.startForegroundService(this.context, DownloadService.getIntent(this.context, this.serviceClass, DownloadService.ACTION_RESTART));
return;
} catch (IllegalStateException unused) {
Log.w(DownloadService.TAG, "Failed to restart (foreground launch restriction)");
return;
}
}
try {
this.context.startService(DownloadService.getIntent(this.context, this.serviceClass, DownloadService.ACTION_INIT));
} catch (IllegalStateException unused2) {
Log.w(DownloadService.TAG, "Failed to restart (process is idle)");
}
}
private boolean schedulerNeedsUpdate(Requirements requirements) {
return !Util.areEqual(this.scheduledRequirements, requirements);
}
private boolean serviceMayNeedRestart() {
DownloadService downloadService = this.downloadService;
return downloadService == null || downloadService.isStopped();
}
public void attachService(DownloadService downloadService) {
Assertions.checkState(this.downloadService == null);
this.downloadService = downloadService;
if (this.downloadManager.isInitialized()) {
Util.createHandlerForCurrentOrMainLooper().postAtFrontOfQueue(new f(26, this, downloadService));
}
}
public void detachService(DownloadService downloadService) {
Assertions.checkState(this.downloadService == downloadService);
this.downloadService = null;
}
@Override
public void onDownloadChanged(DownloadManager downloadManager, Download download, @Nullable Exception exc) {
DownloadService downloadService = this.downloadService;
if (downloadService != null) {
downloadService.notifyDownloadChanged(download);
}
if (serviceMayNeedRestart() && DownloadService.needsStartedService(download.state)) {
Log.w(DownloadService.TAG, "DownloadService wasn't running. Restarting.");
restartService();
}
}
@Override
public void onDownloadRemoved(DownloadManager downloadManager, Download download) {
DownloadService downloadService = this.downloadService;
if (downloadService != null) {
downloadService.notifyDownloadRemoved();
}
}
@Override
public void onDownloadsPausedChanged(DownloadManager downloadManager, boolean z) {
super.onDownloadsPausedChanged(downloadManager, z);
}
@Override
public final void onIdle(DownloadManager downloadManager) {
DownloadService downloadService = this.downloadService;
if (downloadService != null) {
downloadService.onIdle();
}
}
@Override
public void onInitialized(DownloadManager downloadManager) {
DownloadService downloadService = this.downloadService;
if (downloadService != null) {
downloadService.notifyDownloads(downloadManager.getCurrentDownloads());
}
}
@Override
public void onRequirementsStateChanged(DownloadManager downloadManager, Requirements requirements, int i) {
updateScheduler();
}
@Override
public void onWaitingForRequirementsChanged(DownloadManager downloadManager, boolean z) {
if (z || downloadManager.getDownloadsPaused() || !serviceMayNeedRestart()) {
return;
}
List<Download> currentDownloads = downloadManager.getCurrentDownloads();
for (int i = 0; i < currentDownloads.size(); i++) {
if (currentDownloads.get(i).state == 0) {
restartService();
return;
}
}
}
public boolean updateScheduler() {
boolean isWaitingForRequirements = this.downloadManager.isWaitingForRequirements();
if (this.scheduler == null) {
return !isWaitingForRequirements;
}
if (!isWaitingForRequirements) {
cancelScheduler();
return true;
}
Requirements requirements = this.downloadManager.getRequirements();
if (!this.scheduler.getSupportedRequirements(requirements).equals(requirements)) {
cancelScheduler();
return false;
}
if (!schedulerNeedsUpdate(requirements)) {
return true;
}
if (this.scheduler.schedule(requirements, this.context.getPackageName(), DownloadService.ACTION_RESTART)) {
this.scheduledRequirements = requirements;
return true;
}
Log.w(DownloadService.TAG, "Failed to schedule restart");
cancelScheduler();
return false;
}
private a(Context context, DownloadManager downloadManager, boolean z, @Nullable Scheduler scheduler, Class<? extends DownloadService> cls) {
this.context = context;
this.downloadManager = downloadManager;
this.foregroundAllowed = z;
this.scheduler = scheduler;
this.serviceClass = cls;
downloadManager.addListener(this);
updateScheduler();
}
}
public final class b {
private final Handler handler = new Handler(Looper.getMainLooper());
private boolean notificationDisplayed;
private final int notificationId;
private boolean periodicUpdatesStarted;
private final long updateInterval;
public b(int i, long j) {
this.notificationId = i;
this.updateInterval = j;
}
public void update() {
DownloadManager downloadManager = ((a) Assertions.checkNotNull(DownloadService.this.downloadManagerHelper)).downloadManager;
Notification foregroundNotification = DownloadService.this.getForegroundNotification(downloadManager.getCurrentDownloads(), downloadManager.getNotMetRequirements());
if (this.notificationDisplayed) {
((NotificationManager) DownloadService.this.getSystemService("notification")).notify(this.notificationId, foregroundNotification);
} else {
Util.setForegroundServiceNotification(DownloadService.this, this.notificationId, foregroundNotification, 1, "dataSync");
this.notificationDisplayed = true;
}
if (this.periodicUpdatesStarted) {
this.handler.removeCallbacksAndMessages(null);
this.handler.postDelayed(new i2.b(this, 25), this.updateInterval);
}
}
public void invalidate() {
if (this.notificationDisplayed) {
update();
}
}
public void showNotificationIfNotAlready() {
if (this.notificationDisplayed) {
return;
}
update();
}
public void startPeriodicUpdates() {
this.periodicUpdatesStarted = true;
update();
}
public void stopPeriodicUpdates() {
this.periodicUpdatesStarted = false;
this.handler.removeCallbacksAndMessages(null);
}
}
public DownloadService(int i) {
this(i, 1000L);
}
public static Intent buildAddDownloadIntent(Context context, Class<? extends DownloadService> cls, DownloadRequest downloadRequest, boolean z) {
return buildAddDownloadIntent(context, cls, downloadRequest, 0, z);
}
public static Intent buildPauseDownloadsIntent(Context context, Class<? extends DownloadService> cls, boolean z) {
return getIntent(context, cls, ACTION_PAUSE_DOWNLOADS, z);
}
public static Intent buildRemoveAllDownloadsIntent(Context context, Class<? extends DownloadService> cls, boolean z) {
return getIntent(context, cls, ACTION_REMOVE_ALL_DOWNLOADS, z);
}
public static Intent buildRemoveDownloadIntent(Context context, Class<? extends DownloadService> cls, String str, boolean z) {
return getIntent(context, cls, ACTION_REMOVE_DOWNLOAD, z).putExtra(KEY_CONTENT_ID, str);
}
public static Intent buildResumeDownloadsIntent(Context context, Class<? extends DownloadService> cls, boolean z) {
return getIntent(context, cls, ACTION_RESUME_DOWNLOADS, z);
}
public static Intent buildSetRequirementsIntent(Context context, Class<? extends DownloadService> cls, Requirements requirements, boolean z) {
return getIntent(context, cls, ACTION_SET_REQUIREMENTS, z).putExtra(KEY_REQUIREMENTS, requirements);
}
public static Intent buildSetStopReasonIntent(Context context, Class<? extends DownloadService> cls, @Nullable String str, int i, boolean z) {
return getIntent(context, cls, ACTION_SET_STOP_REASON, z).putExtra(KEY_CONTENT_ID, str).putExtra(KEY_STOP_REASON, i);
}
public static void clearDownloadManagerHelpers() {
downloadManagerHelpers.clear();
}
private static Intent getIntent(Context context, Class<? extends DownloadService> cls, String str, boolean z) {
return getIntent(context, cls, str).putExtra(KEY_FOREGROUND, z);
}
public boolean isStopped() {
return this.isStopped;
}
public static boolean needsStartedService(int i) {
return i == 2 || i == 5 || i == 7;
}
public void notifyDownloadChanged(Download download) {
if (this.foregroundNotificationUpdater != null) {
if (needsStartedService(download.state)) {
this.foregroundNotificationUpdater.startPeriodicUpdates();
} else {
this.foregroundNotificationUpdater.invalidate();
}
}
}
public void notifyDownloadRemoved() {
b bVar = this.foregroundNotificationUpdater;
if (bVar != null) {
bVar.invalidate();
}
}
public void notifyDownloads(List<Download> list) {
if (this.foregroundNotificationUpdater != null) {
for (int i = 0; i < list.size(); i++) {
if (needsStartedService(list.get(i).state)) {
this.foregroundNotificationUpdater.startPeriodicUpdates();
return;
}
}
}
}
public void onIdle() {
b bVar = this.foregroundNotificationUpdater;
if (bVar != null) {
bVar.stopPeriodicUpdates();
}
if (((a) Assertions.checkNotNull(this.downloadManagerHelper)).updateScheduler()) {
if (Util.SDK_INT >= 28 || !this.taskRemoved) {
this.isStopped |= stopSelfResult(this.lastStartId);
} else {
stopSelf();
this.isStopped = true;
}
}
}
public static void sendAddDownload(Context context, Class<? extends DownloadService> cls, DownloadRequest downloadRequest, boolean z) {
startService(context, buildAddDownloadIntent(context, cls, downloadRequest, z), z);
}
public static void sendPauseDownloads(Context context, Class<? extends DownloadService> cls, boolean z) {
startService(context, buildPauseDownloadsIntent(context, cls, z), z);
}
public static void sendRemoveAllDownloads(Context context, Class<? extends DownloadService> cls, boolean z) {
startService(context, buildRemoveAllDownloadsIntent(context, cls, z), z);
}
public static void sendRemoveDownload(Context context, Class<? extends DownloadService> cls, String str, boolean z) {
startService(context, buildRemoveDownloadIntent(context, cls, str, z), z);
}
public static void sendResumeDownloads(Context context, Class<? extends DownloadService> cls, boolean z) {
startService(context, buildResumeDownloadsIntent(context, cls, z), z);
}
public static void sendSetRequirements(Context context, Class<? extends DownloadService> cls, Requirements requirements, boolean z) {
startService(context, buildSetRequirementsIntent(context, cls, requirements, z), z);
}
public static void sendSetStopReason(Context context, Class<? extends DownloadService> cls, @Nullable String str, int i, boolean z) {
startService(context, buildSetStopReasonIntent(context, cls, str, i, z), z);
}
public static void start(Context context, Class<? extends DownloadService> cls) {
context.startService(getIntent(context, cls, ACTION_INIT));
}
public static void startForeground(Context context, Class<? extends DownloadService> cls) {
Util.startForegroundService(context, getIntent(context, cls, ACTION_INIT, true));
}
private static void startService(Context context, Intent intent, boolean z) {
if (z) {
Util.startForegroundService(context, intent);
} else {
context.startService(intent);
}
}
public abstract DownloadManager getDownloadManager();
public abstract Notification getForegroundNotification(List<Download> list, int i);
@Nullable
public abstract Scheduler getScheduler();
public final void invalidateForegroundNotification() {
b bVar = this.foregroundNotificationUpdater;
if (bVar == null || this.isDestroyed) {
return;
}
bVar.invalidate();
}
@Override
@Nullable
public final IBinder onBind(Intent intent) {
throw new UnsupportedOperationException();
}
@Override
public void onCreate() {
String str = this.channelId;
if (str != null) {
NotificationUtil.createNotificationChannel(this, str, this.channelNameResourceId, this.channelDescriptionResourceId, 2);
}
Class<?> cls = getClass();
HashMap<Class<? extends DownloadService>, a> hashMap = downloadManagerHelpers;
a aVar = (a) hashMap.get(cls);
if (aVar == null) {
boolean z = this.foregroundNotificationUpdater != null;
Scheduler scheduler = (z && (Util.SDK_INT < 31)) ? getScheduler() : null;
DownloadManager downloadManager = getDownloadManager();
downloadManager.resumeDownloads();
a aVar2 = new a(getApplicationContext(), downloadManager, z, scheduler, cls);
hashMap.put(cls, aVar2);
aVar = aVar2;
}
this.downloadManagerHelper = aVar;
aVar.attachService(this);
}
@Override
public void onDestroy() {
this.isDestroyed = true;
((a) Assertions.checkNotNull(this.downloadManagerHelper)).detachService(this);
b bVar = this.foregroundNotificationUpdater;
if (bVar != null) {
bVar.stopPeriodicUpdates();
}
}
@Override
public int onStartCommand(@Nullable Intent intent, int i, int i2) {
String str;
String str2;
DownloadManager downloadManager;
b bVar;
this.lastStartId = i2;
this.taskRemoved = false;
if (intent != null) {
str = intent.getAction();
str2 = intent.getStringExtra(KEY_CONTENT_ID);
this.startedInForeground |= intent.getBooleanExtra(KEY_FOREGROUND, false) || ACTION_RESTART.equals(str);
} else {
str = null;
str2 = null;
}
if (str == null) {
str = ACTION_INIT;
}
downloadManager = ((a) Assertions.checkNotNull(this.downloadManagerHelper)).downloadManager;
switch (str) {
case "io.bidmachine.media3.exoplayer.downloadService.action.ADD_DOWNLOAD":
DownloadRequest downloadRequest = (DownloadRequest) ((Intent) Assertions.checkNotNull(intent)).getParcelableExtra(KEY_DOWNLOAD_REQUEST);
if (downloadRequest != null) {
downloadManager.addDownload(downloadRequest, intent.getIntExtra(KEY_STOP_REASON, 0));
break;
} else {
Log.e(TAG, "Ignored ADD_DOWNLOAD: Missing download_request extra");
break;
}
case "io.bidmachine.media3.exoplayer.downloadService.action.PAUSE_DOWNLOADS":
downloadManager.pauseDownloads();
break;
case "io.bidmachine.media3.exoplayer.downloadService.action.RESUME_DOWNLOADS":
downloadManager.resumeDownloads();
break;
case "io.bidmachine.media3.exoplayer.downloadService.action.SET_STOP_REASON":
if (!((Intent) Assertions.checkNotNull(intent)).hasExtra(KEY_STOP_REASON)) {
Log.e(TAG, "Ignored SET_STOP_REASON: Missing stop_reason extra");
break;
} else {
downloadManager.setStopReason(str2, intent.getIntExtra(KEY_STOP_REASON, 0));
break;
}
case "io.bidmachine.media3.exoplayer.downloadService.action.REMOVE_ALL_DOWNLOADS":
downloadManager.removeAllDownloads();
break;
case "io.bidmachine.media3.exoplayer.downloadService.action.RESTART":
case "io.bidmachine.media3.exoplayer.downloadService.action.INIT":
break;
case "io.bidmachine.media3.exoplayer.downloadService.action.SET_REQUIREMENTS":
Requirements requirements = (Requirements) ((Intent) Assertions.checkNotNull(intent)).getParcelableExtra(KEY_REQUIREMENTS);
if (requirements != null) {
downloadManager.setRequirements(requirements);
break;
} else {
Log.e(TAG, "Ignored SET_REQUIREMENTS: Missing requirements extra");
break;
}
case "io.bidmachine.media3.exoplayer.downloadService.action.REMOVE_DOWNLOAD":
if (str2 != null) {
downloadManager.removeDownload(str2);
break;
} else {
Log.e(TAG, "Ignored REMOVE_DOWNLOAD: Missing content_id extra");
break;
}
default:
Log.e(TAG, "Ignored unrecognized action: ".concat(str));
break;
}
if (Util.SDK_INT >= 26 && this.startedInForeground && (bVar = this.foregroundNotificationUpdater) != null) {
bVar.showNotificationIfNotAlready();
}
this.isStopped = false;
if (downloadManager.isIdle()) {
onIdle();
}
return 1;
}
@Override
public void onTaskRemoved(Intent intent) {
this.taskRemoved = true;
}
public DownloadService(int i, long j) {
this(i, j, null, 0, 0);
}
public static Intent buildAddDownloadIntent(Context context, Class<? extends DownloadService> cls, DownloadRequest downloadRequest, int i, boolean z) {
return getIntent(context, cls, ACTION_ADD_DOWNLOAD, z).putExtra(KEY_DOWNLOAD_REQUEST, downloadRequest).putExtra(KEY_STOP_REASON, i);
}
public static Intent getIntent(Context context, Class<? extends DownloadService> cls, String str) {
return new Intent(context, cls).setAction(str);
}
public DownloadService(int i, long j, @Nullable String str, int i2, int i3) {
if (i == 0) {
this.foregroundNotificationUpdater = null;
this.channelId = null;
this.channelNameResourceId = 0;
this.channelDescriptionResourceId = 0;
return;
}
this.foregroundNotificationUpdater = new b(i, j);
this.channelId = str;
this.channelNameResourceId = i2;
this.channelDescriptionResourceId = i3;
}
public static void sendAddDownload(Context context, Class<? extends DownloadService> cls, DownloadRequest downloadRequest, int i, boolean z) {
startService(context, buildAddDownloadIntent(context, cls, downloadRequest, i, z), z);
}
}