From 6d7bfef8a5fe8180f13904739996bb2b8de8a0d4 Mon Sep 17 00:00:00 2001 From: ByteHamster Date: Fri, 5 May 2023 23:09:03 +0200 Subject: Download Service Rewrite (#6420) --- .../antennapod/model/download/DownloadResult.java | 128 +++++++++++++++++ .../antennapod/model/download/DownloadStatus.java | 156 ++------------------- 2 files changed, 141 insertions(+), 143 deletions(-) create mode 100644 model/src/main/java/de/danoeh/antennapod/model/download/DownloadResult.java (limited to 'model/src/main') diff --git a/model/src/main/java/de/danoeh/antennapod/model/download/DownloadResult.java b/model/src/main/java/de/danoeh/antennapod/model/download/DownloadResult.java new file mode 100644 index 000000000..66901cf65 --- /dev/null +++ b/model/src/main/java/de/danoeh/antennapod/model/download/DownloadResult.java @@ -0,0 +1,128 @@ +package de.danoeh.antennapod.model.download; + +import androidx.annotation.NonNull; + +import java.util.Date; + +import de.danoeh.antennapod.model.feed.FeedFile; + +/** + * Contains status attributes for one download + */ +public class DownloadResult { + /** + * Downloaders should use this constant for the size attribute if necessary + * so that the listadapters etc. can react properly. + */ + public static final int SIZE_UNKNOWN = -1; + + /** + * A human-readable string which is shown to the user so that he can + * identify the download. Should be the title of the item/feed/media or the + * URL if the download has no other title. + */ + private final String title; + private final long feedfileId; + /** + * Is used to determine the type of the feedfile even if the feedfile does + * not exist anymore. The value should be FEEDFILETYPE_FEED, + * FEEDFILETYPE_FEEDIMAGE or FEEDFILETYPE_FEEDMEDIA + */ + private final int feedfileType; + /** + * Unique id for storing the object in database. + */ + private long id; + private DownloadError reason; + /** + * A message which can be presented to the user to give more information. + * Should be null if Download was successful. + */ + private String reasonDetailed; + private boolean successful; + private final Date completionDate; + + /** + * Constructor for creating new completed downloads. + */ + public DownloadResult(@NonNull FeedFile feedfile, String title, DownloadError reason, boolean successful, + String reasonDetailed) { + this(0, title, feedfile.getId(), feedfile.getTypeAsInt(), successful, reason, new Date(), + reasonDetailed); + } + + public DownloadResult(long id, String title, long feedfileId, int feedfileType, boolean successful, + DownloadError reason, Date completionDate, + String reasonDetailed) { + this.id = id; + this.title = title; + this.feedfileId = feedfileId; + this.reason = reason; + this.successful = successful; + this.completionDate = (Date) completionDate.clone(); + this.reasonDetailed = reasonDetailed; + this.feedfileType = feedfileType; + } + + @Override + @NonNull + public String toString() { + return "DownloadStatus [id=" + id + ", title=" + title + ", reason=" + + reason + ", reasonDetailed=" + reasonDetailed + + ", successful=" + successful + ", completionDate=" + + completionDate + ", feedfileId=" + feedfileId + + ", feedfileType=" + feedfileType + "]"; + } + + public long getId() { + return id; + } + + public void setId(long id) { + this.id = id; + } + + public String getTitle() { + return title; + } + + public DownloadError getReason() { + return reason; + } + + public String getReasonDetailed() { + return reasonDetailed; + } + + public boolean isSuccessful() { + return successful; + } + + public Date getCompletionDate() { + return (Date) completionDate.clone(); + } + + public long getFeedfileId() { + return feedfileId; + } + + public int getFeedfileType() { + return feedfileType; + } + + public void setSuccessful() { + this.successful = true; + this.reason = DownloadError.SUCCESS; + } + + public void setFailed(DownloadError reason, String reasonDetailed) { + this.successful = false; + this.reason = reason; + this.reasonDetailed = reasonDetailed; + } + + public void setCancelled() { + this.successful = false; + this.reason = DownloadError.ERROR_DOWNLOAD_CANCELLED; + } +} \ No newline at end of file diff --git a/model/src/main/java/de/danoeh/antennapod/model/download/DownloadStatus.java b/model/src/main/java/de/danoeh/antennapod/model/download/DownloadStatus.java index 0a18973df..823c183d2 100644 --- a/model/src/main/java/de/danoeh/antennapod/model/download/DownloadStatus.java +++ b/model/src/main/java/de/danoeh/antennapod/model/download/DownloadStatus.java @@ -1,153 +1,23 @@ package de.danoeh.antennapod.model.download; -import androidx.annotation.NonNull; - -import java.util.Date; - -import de.danoeh.antennapod.model.feed.FeedFile; - -/** - * Contains status attributes for one download - */ public class DownloadStatus { - /** - * Downloaders should use this constant for the size attribute if necessary - * so that the listadapters etc. can react properly. - */ - public static final int SIZE_UNKNOWN = -1; + public static final int STATE_QUEUED = 0; + public static final int STATE_COMPLETED = 1; // Both successful and not successful + public static final int STATE_RUNNING = 2; - // ----------------------------------- ATTRIBUTES STORED IN DB - /** - * A human-readable string which is shown to the user so that he can - * identify the download. Should be the title of the item/feed/media or the - * URL if the download has no other title. - */ - private final String title; - private final long feedfileId; - /** - * Is used to determine the type of the feedfile even if the feedfile does - * not exist anymore. The value should be FEEDFILETYPE_FEED, - * FEEDFILETYPE_FEEDIMAGE or FEEDFILETYPE_FEEDMEDIA - */ - private final int feedfileType; - private final boolean initiatedByUser; - /** - * Unique id for storing the object in database. - */ - private long id; - private DownloadError reason; - /** - * A message which can be presented to the user to give more information. - * Should be null if Download was successful. - */ - private String reasonDetailed; - private boolean successful; - private final Date completionDate; - // ------------------------------------ NOT STORED IN DB - private boolean done; - private boolean cancelled; - - /** - * Constructor for creating new completed downloads. - */ - public DownloadStatus(@NonNull FeedFile feedfile, String title, DownloadError reason, boolean successful, - String reasonDetailed, boolean initiatedByUser) { - this(0, title, feedfile.getId(), feedfile.getTypeAsInt(), successful, false, true, reason, new Date(), - reasonDetailed, initiatedByUser); - } - - public DownloadStatus(long id, String title, long feedfileId, int feedfileType, boolean successful, - boolean cancelled, boolean done, DownloadError reason, Date completionDate, - String reasonDetailed, boolean initiatedByUser) { - this.id = id; - this.title = title; - this.feedfileId = feedfileId; - this.reason = reason; - this.successful = successful; - this.cancelled = cancelled; - this.done = done; - this.completionDate = (Date) completionDate.clone(); - this.reasonDetailed = reasonDetailed; - this.feedfileType = feedfileType; - this.initiatedByUser = initiatedByUser; - } - - @Override - @NonNull - public String toString() { - return "DownloadStatus [id=" + id + ", title=" + title + ", reason=" - + reason + ", reasonDetailed=" + reasonDetailed - + ", successful=" + successful + ", completionDate=" - + completionDate + ", feedfileId=" + feedfileId - + ", feedfileType=" + feedfileType + ", done=" + done - + ", cancelled=" + cancelled + "]"; - } - - public long getId() { - return id; - } - - public void setId(long id) { - this.id = id; - } - - public String getTitle() { - return title; - } - - public DownloadError getReason() { - return reason; - } - - public String getReasonDetailed() { - return reasonDetailed; - } - - public boolean isSuccessful() { - return successful; - } - - public Date getCompletionDate() { - return (Date) completionDate.clone(); - } - - public long getFeedfileId() { - return feedfileId; - } - - public int getFeedfileType() { - return feedfileType; - } - - public boolean isInitiatedByUser() { - return initiatedByUser; - } - - public boolean isDone() { - return done; - } - - public boolean isCancelled() { - return cancelled; - } + private final int state; + private final int progress; - public void setSuccessful() { - this.successful = true; - this.reason = DownloadError.SUCCESS; - this.done = true; + public DownloadStatus(int state, int progress) { + this.state = state; + this.progress = progress; } - public void setFailed(DownloadError reason, String reasonDetailed) { - this.successful = false; - this.reason = reason; - this.reasonDetailed = reasonDetailed; - this.done = true; + public int getState() { + return state; } - public void setCancelled() { - this.successful = false; - this.reason = DownloadError.ERROR_DOWNLOAD_CANCELLED; - this.done = true; - this.cancelled = true; + public int getProgress() { + return progress; } -} \ No newline at end of file +} -- cgit v1.2.3