LibreTube/app/src/main/java/com/github/libretube/services/DownloadService.kt

242 lines
9.3 KiB
Kotlin
Raw Normal View History

2022-06-28 20:02:26 +05:30
package com.github.libretube.services
2022-03-03 12:08:36 +05:30
2022-05-21 13:32:04 +05:30
import android.app.DownloadManager
import android.app.PendingIntent
import android.app.Service
2022-03-03 12:08:36 +05:30
import android.content.BroadcastReceiver
import android.content.Context
import android.content.Intent
import android.content.IntentFilter
import android.net.Uri
import android.os.Build
import android.os.Environment
2022-05-21 13:32:04 +05:30
import android.os.Environment.DIRECTORY_DOWNLOADS
2022-06-09 17:52:07 +05:30
import android.os.Environment.DIRECTORY_MOVIES
import android.os.Environment.DIRECTORY_MUSIC
2022-03-03 12:08:36 +05:30
import android.os.IBinder
import android.util.Log
import androidx.core.app.NotificationCompat
2022-03-05 00:22:30 +05:30
import androidx.core.app.NotificationManagerCompat
2022-07-30 14:51:18 +05:30
import com.github.libretube.DOWNLOAD_CHANNEL_ID
import com.github.libretube.DOWNLOAD_FAILURE_NOTIFICATION_ID
import com.github.libretube.DOWNLOAD_PENDING_NOTIFICATION_ID
import com.github.libretube.DOWNLOAD_SUCCESS_NOTIFICATION_ID
2022-07-18 22:59:56 +05:30
import com.github.libretube.Globals
2022-06-28 20:02:26 +05:30
import com.github.libretube.R
2022-08-14 13:25:28 +05:30
import com.github.libretube.extensions.TAG
2022-07-12 01:30:56 +05:30
import com.github.libretube.obj.DownloadType
2022-07-02 21:53:24 +05:30
import com.github.libretube.preferences.PreferenceHelper
2022-07-17 21:48:39 +05:30
import com.github.libretube.preferences.PreferenceKeys
2022-03-03 12:08:36 +05:30
import java.io.File
2022-03-04 23:30:50 +05:30
2022-05-20 03:52:10 +05:30
class DownloadService : Service() {
2022-07-12 01:30:56 +05:30
private lateinit var notification: NotificationCompat.Builder
2022-05-20 03:52:10 +05:30
private var downloadId: Long = -1
private lateinit var videoName: String
2022-03-03 12:08:36 +05:30
private lateinit var videoUrl: String
private lateinit var audioUrl: String
2022-07-12 01:30:56 +05:30
private var downloadType: Int = 3
2022-05-21 13:32:04 +05:30
2022-03-03 12:08:36 +05:30
private lateinit var audioDir: File
private lateinit var videoDir: File
2022-06-05 23:10:16 +05:30
private lateinit var libretubeDir: File
private lateinit var tempDir: File
2022-03-04 21:27:10 +05:30
override fun onCreate() {
super.onCreate()
2022-07-18 22:59:56 +05:30
Globals.IS_DOWNLOAD_RUNNING = true
2022-03-04 21:27:10 +05:30
}
2022-03-03 12:08:36 +05:30
override fun onStartCommand(intent: Intent?, flags: Int, startId: Int): Int {
videoName = intent?.getStringExtra("videoName")!!
2022-03-03 12:08:36 +05:30
videoUrl = intent.getStringExtra("videoUrl")!!
audioUrl = intent.getStringExtra("audioUrl")!!
2022-08-24 21:26:57 +05:30
downloadType = if (audioUrl != "") {
DownloadType.AUDIO
} else if (videoUrl != "") {
DownloadType.VIDEO
} else {
DownloadType.NONE
}
2022-07-12 01:30:56 +05:30
if (downloadType != DownloadType.NONE) {
2022-06-05 23:10:16 +05:30
downloadNotification(intent)
downloadManager()
} else {
onDestroy()
}
2022-03-03 12:08:36 +05:30
return super.onStartCommand(intent, flags, startId)
}
2022-05-21 13:32:04 +05:30
2022-03-03 12:08:36 +05:30
override fun onBind(intent: Intent?): IBinder? {
TODO("Not yet implemented")
}
private fun downloadManager() {
2022-06-05 23:10:16 +05:30
// create folder for temporary files
tempDir = File(
applicationContext.getExternalFilesDir(DIRECTORY_DOWNLOADS),
".tmp"
)
if (!tempDir.exists()) {
tempDir.mkdirs()
2022-08-14 13:25:28 +05:30
Log.e(TAG(), "Directory make")
2022-03-03 12:08:36 +05:30
} else {
2022-06-05 23:10:16 +05:30
tempDir.deleteRecursively()
tempDir.mkdirs()
2022-08-14 13:25:28 +05:30
Log.e(TAG(), "Directory already have")
2022-03-03 12:08:36 +05:30
}
2022-06-05 23:10:16 +05:30
2022-07-17 21:48:39 +05:30
val downloadLocationPref = PreferenceHelper.getString(PreferenceKeys.DOWNLOAD_LOCATION, "")
val folderName = PreferenceHelper.getString(PreferenceKeys.DOWNLOAD_FOLDER, "LibreTube")
2022-06-09 17:52:07 +05:30
val location = when (downloadLocationPref) {
"downloads" -> Environment.getExternalStoragePublicDirectory(DIRECTORY_DOWNLOADS)
"music" -> Environment.getExternalStoragePublicDirectory(DIRECTORY_MUSIC)
"movies" -> Environment.getExternalStoragePublicDirectory(DIRECTORY_MOVIES)
"sdcard" -> Environment.getExternalStorageDirectory()
else -> Environment.getExternalStoragePublicDirectory(DIRECTORY_DOWNLOADS)
}
2022-06-05 23:10:16 +05:30
libretubeDir = File(
2022-06-09 17:52:07 +05:30
location,
folderName
2022-06-05 23:10:16 +05:30
)
if (!libretubeDir.exists()) libretubeDir.mkdirs()
2022-08-14 13:25:28 +05:30
Log.i(TAG(), libretubeDir.toString())
2022-06-05 23:10:16 +05:30
// start download
2022-03-03 12:08:36 +05:30
try {
2022-05-21 13:32:04 +05:30
registerReceiver(
onDownloadComplete,
IntentFilter(DownloadManager.ACTION_DOWNLOAD_COMPLETE)
)
2022-06-05 23:10:16 +05:30
when (downloadType) {
2022-07-12 01:30:56 +05:30
DownloadType.VIDEO -> {
videoDir = File(libretubeDir, videoName)
2022-06-17 20:20:48 +05:30
downloadId = downloadManagerRequest(
getString(R.string.video),
getString(R.string.downloading),
videoUrl,
videoDir
)
2022-06-05 23:10:16 +05:30
}
2022-07-12 01:30:56 +05:30
DownloadType.AUDIO -> {
audioDir = File(libretubeDir, videoName)
2022-06-17 20:20:48 +05:30
downloadId = downloadManagerRequest(
getString(R.string.audio),
getString(R.string.downloading),
audioUrl,
audioDir
)
2022-06-05 23:10:16 +05:30
}
2022-05-21 13:32:04 +05:30
}
2022-03-03 12:08:36 +05:30
} catch (e: IllegalArgumentException) {
2022-08-14 13:25:28 +05:30
Log.e(TAG(), "download error $e")
downloadFailedNotification()
2022-03-03 12:08:36 +05:30
}
}
private val onDownloadComplete: BroadcastReceiver = object : BroadcastReceiver() {
override fun onReceive(context: Context, intent: Intent) {
2022-05-20 03:52:10 +05:30
// Fetching the download id received with the broadcast
2022-03-03 12:08:36 +05:30
val id = intent.getLongExtra(DownloadManager.EXTRA_DOWNLOAD_ID, -1)
2022-05-20 03:52:10 +05:30
// Checking if the received broadcast is for our enqueued download by matching download id
2022-06-05 23:10:16 +05:30
if (downloadId == id) {
2022-07-12 01:30:56 +05:30
if (downloadType == DownloadType.MUX) {
2022-06-17 20:20:48 +05:30
downloadManagerRequest(
2022-06-17 20:33:17 +05:30
getString(R.string.audio),
2022-06-17 20:20:48 +05:30
getString(R.string.downloading),
audioUrl,
audioDir
)
2022-03-04 21:27:10 +05:30
} else {
2022-06-05 23:10:16 +05:30
downloadSucceededNotification()
onDestroy()
2022-03-04 21:27:10 +05:30
}
2022-03-03 12:08:36 +05:30
}
}
}
2022-06-05 22:02:32 +05:30
private fun downloadManagerRequest(
title: String,
descriptionText: String,
url: String,
fileDir: File
): Long {
2022-06-05 21:38:47 +05:30
val request: DownloadManager.Request =
DownloadManager.Request(Uri.parse(url))
.setTitle(title) // Title of the Download Notification
.setDescription(descriptionText) // Description of the Download Notification
.setNotificationVisibility(DownloadManager.Request.VISIBILITY_VISIBLE) // Visibility of the download Notification
.setDestinationUri(Uri.fromFile(fileDir))
.setAllowedOverMetered(true) // Set if download is allowed on Mobile network
.setAllowedOverRoaming(true) //
val downloadManager: DownloadManager =
applicationContext.getSystemService(DOWNLOAD_SERVICE) as DownloadManager
return downloadManager.enqueue(request)
}
private fun downloadNotification(intent: Intent) {
var pendingIntent: PendingIntent? = null
pendingIntent = if (Build.VERSION.SDK_INT >= Build.VERSION_CODES.S) {
PendingIntent.getActivity(this, 0, intent, PendingIntent.FLAG_MUTABLE)
} else {
PendingIntent.getActivity(this, 0, intent, PendingIntent.FLAG_ONE_SHOT)
}
// Creating a notification and setting its various attributes
notification =
2022-07-30 14:51:18 +05:30
NotificationCompat.Builder(this@DownloadService, DOWNLOAD_CHANNEL_ID)
2022-06-05 21:38:47 +05:30
.setSmallIcon(R.drawable.ic_download)
.setContentTitle("LibreTube")
2022-06-17 20:09:05 +05:30
.setContentText(getString(R.string.downloading))
2022-06-05 21:38:47 +05:30
.setPriority(NotificationCompat.PRIORITY_LOW)
.setOngoing(true)
.setOnlyAlertOnce(true)
.setProgress(100, 0, true)
.setContentIntent(pendingIntent)
.setAutoCancel(true)
2022-07-30 14:51:18 +05:30
startForeground(DOWNLOAD_PENDING_NOTIFICATION_ID, notification.build())
2022-06-05 21:38:47 +05:30
}
private fun downloadFailedNotification() {
2022-07-30 14:51:18 +05:30
val builder = NotificationCompat.Builder(this@DownloadService, DOWNLOAD_CHANNEL_ID)
2022-06-05 21:38:47 +05:30
.setSmallIcon(R.drawable.ic_download)
.setContentTitle(resources.getString(R.string.downloadfailed))
2022-06-17 20:09:05 +05:30
.setContentText(getString(R.string.fail))
2022-06-05 21:38:47 +05:30
.setPriority(NotificationCompat.PRIORITY_HIGH)
with(NotificationManagerCompat.from(this@DownloadService)) {
// notificationId is a unique int for each notification that you must define
2022-07-30 14:51:18 +05:30
notify(DOWNLOAD_FAILURE_NOTIFICATION_ID, builder.build())
2022-06-05 21:38:47 +05:30
}
}
2022-06-05 23:10:16 +05:30
private fun downloadSucceededNotification() {
2022-08-14 13:25:28 +05:30
Log.i(TAG(), "Download succeeded")
2022-07-30 14:51:18 +05:30
val builder = NotificationCompat.Builder(this@DownloadService, DOWNLOAD_CHANNEL_ID)
2022-06-05 23:10:16 +05:30
.setSmallIcon(R.drawable.ic_download)
.setContentTitle(resources.getString(R.string.success))
.setContentText(getString(R.string.downloadsucceeded))
2022-06-05 23:10:16 +05:30
.setPriority(NotificationCompat.PRIORITY_HIGH)
with(NotificationManagerCompat.from(this@DownloadService)) {
// notificationId is a unique int for each notification that you must define
2022-07-30 14:51:18 +05:30
notify(DOWNLOAD_SUCCESS_NOTIFICATION_ID, builder.build())
2022-06-05 21:38:47 +05:30
}
2022-06-05 23:10:16 +05:30
}
2022-03-03 12:08:36 +05:30
override fun onDestroy() {
2022-03-04 21:27:10 +05:30
try {
unregisterReceiver(onDownloadComplete)
2022-06-07 12:22:11 +05:30
} catch (e: Exception) {
}
2022-06-05 23:10:16 +05:30
2022-07-18 22:59:56 +05:30
Globals.IS_DOWNLOAD_RUNNING = false
2022-08-14 13:25:28 +05:30
Log.d(TAG(), "dl finished!")
2022-06-05 23:10:16 +05:30
stopForeground(true)
stopService(Intent(this@DownloadService, DownloadService::class.java))
2022-03-03 12:08:36 +05:30
super.onDestroy()
}
}