mirror of
https://github.com/YTVanced/VancedManager
synced 2024-12-03 16:27:25 +00:00
Merge pull request #125 from ostajic/dev
Fix for new error Messages not being displayed
This commit is contained in:
commit
9c30b1d0ab
5 changed files with 116 additions and 116 deletions
|
@ -16,30 +16,47 @@ import com.vanced.manager.core.installer.RootSplitInstallerService
|
||||||
import com.vanced.manager.core.installer.SplitInstaller
|
import com.vanced.manager.core.installer.SplitInstaller
|
||||||
import com.vanced.manager.ui.fragments.HomeFragment
|
import com.vanced.manager.ui.fragments.HomeFragment
|
||||||
import com.vanced.manager.utils.AppUtils.installing
|
import com.vanced.manager.utils.AppUtils.installing
|
||||||
|
import com.vanced.manager.utils.InternetTools
|
||||||
import com.vanced.manager.utils.InternetTools.baseUrl
|
import com.vanced.manager.utils.InternetTools.baseUrl
|
||||||
import com.vanced.manager.utils.InternetTools.getFileNameFromUrl
|
import com.vanced.manager.utils.InternetTools.getFileNameFromUrl
|
||||||
import com.vanced.manager.utils.InternetTools.getObjectFromJson
|
import com.vanced.manager.utils.InternetTools.getObjectFromJson
|
||||||
|
import com.vanced.manager.utils.PackageHelper.getPkgVerCode
|
||||||
import kotlinx.coroutines.CoroutineScope
|
import kotlinx.coroutines.CoroutineScope
|
||||||
import kotlinx.coroutines.Dispatchers
|
import kotlinx.coroutines.Dispatchers
|
||||||
import kotlinx.coroutines.launch
|
import kotlinx.coroutines.launch
|
||||||
|
import kotlinx.coroutines.runBlocking
|
||||||
import java.io.File
|
import java.io.File
|
||||||
|
import java.io.IOException
|
||||||
|
import java.security.MessageDigest
|
||||||
|
|
||||||
class VancedDownloadService: Service() {
|
class VancedDownloadService: Service() {
|
||||||
|
|
||||||
|
private var sha256Val: String? = null
|
||||||
|
private var vancedVersionCode: Int? = null
|
||||||
|
|
||||||
//private var downloadId: Long = 0
|
//private var downloadId: Long = 0
|
||||||
//private var apkType: String = "arch"
|
//private var apkType: String = "arch"
|
||||||
private var count: Int = 0
|
private var count: Int = 0
|
||||||
private val localBroadcastManager by lazy { LocalBroadcastManager.getInstance(this) }
|
private val localBroadcastManager by lazy { LocalBroadcastManager.getInstance(this) }
|
||||||
|
private var hashUrl = ""
|
||||||
|
|
||||||
|
private val yPkg = "com.google.android.youtube"
|
||||||
|
|
||||||
|
suspend fun getVer()
|
||||||
|
{
|
||||||
|
vancedVersionCode = InternetTools.getJsonInt("vanced.json", "versionCode", application)
|
||||||
|
}
|
||||||
|
|
||||||
override fun onStartCommand(intent: Intent?, flags: Int, startId: Int): Int {
|
override fun onStartCommand(intent: Intent?, flags: Int, startId: Int): Int {
|
||||||
//registerReceiver(receiver, IntentFilter(DownloadManager.ACTION_DOWNLOAD_COMPLETE))
|
//registerReceiver(receiver, IntentFilter(DownloadManager.ACTION_DOWNLOAD_COMPLETE))
|
||||||
|
runBlocking { getVer() }
|
||||||
downloadSplits()
|
downloadSplits()
|
||||||
stopSelf()
|
stopSelf()
|
||||||
return START_NOT_STICKY
|
return START_NOT_STICKY
|
||||||
}
|
}
|
||||||
|
|
||||||
private fun downloadSplits(
|
private fun downloadSplits(
|
||||||
type: String = "arch"
|
type: String = "theme"
|
||||||
) {
|
) {
|
||||||
CoroutineScope(Dispatchers.IO).launch {
|
CoroutineScope(Dispatchers.IO).launch {
|
||||||
File(getExternalFilesDir("apk")?.path as String).deleteRecursively()
|
File(getExternalFilesDir("apk")?.path as String).deleteRecursively()
|
||||||
|
@ -58,10 +75,10 @@ class VancedDownloadService: Service() {
|
||||||
else -> "armeabi_v7a"
|
else -> "armeabi_v7a"
|
||||||
}
|
}
|
||||||
val themePath = "$installUrl/apks/v$vancedVer/$variant/Theme"
|
val themePath = "$installUrl/apks/v$vancedVer/$variant/Theme"
|
||||||
|
hashUrl = "apks/v$vancedVer/$variant/Theme/hash.json"
|
||||||
val url =
|
val url =
|
||||||
when (type) {
|
when (type) {
|
||||||
"arch" -> "$installUrl/apks/v$vancedVer/$variant/Arch/split_config.$arch.apk"
|
"arch" -> "$installUrl/apks/v$vancedVer/$variant/Arch/split_config.$arch.apk"
|
||||||
"hash" -> "$themePath/hash.json"
|
|
||||||
"theme" -> "$themePath/$theme.apk"
|
"theme" -> "$themePath/$theme.apk"
|
||||||
"stock" -> "$themePath/stock.apk"
|
"stock" -> "$themePath/stock.apk"
|
||||||
"dpi" -> "$themePath/dpi.apk"
|
"dpi" -> "$themePath/dpi.apk"
|
||||||
|
@ -83,11 +100,12 @@ class VancedDownloadService: Service() {
|
||||||
.start(object : OnDownloadListener {
|
.start(object : OnDownloadListener {
|
||||||
override fun onDownloadComplete() {
|
override fun onDownloadComplete() {
|
||||||
when (type) {
|
when (type) {
|
||||||
"arch" -> downloadSplits("theme")
|
"theme" -> if(variant=="root") {
|
||||||
"theme" -> if(variant=="root") downloadSplits("stock") else downloadSplits("lang")
|
if(ValidateTheme()) {if(downloadStockCheck())downloadSplits("arch") else prepareInstall(variant)} else downloadSplits("theme")
|
||||||
|
} else downloadSplits("arch")
|
||||||
|
"arch" -> if(variant=="root") downloadSplits("stock") else downloadSplits("lang")
|
||||||
"stock" -> downloadSplits("dpi")
|
"stock" -> downloadSplits("dpi")
|
||||||
"dpi" -> downloadSplits("hash")
|
"dpi" -> downloadSplits("lang")
|
||||||
"hash" -> downloadSplits("lang")
|
|
||||||
"lang" -> {
|
"lang" -> {
|
||||||
count++
|
count++
|
||||||
if (count < lang?.count()!!)
|
if (count < lang?.count()!!)
|
||||||
|
@ -107,6 +125,23 @@ class VancedDownloadService: Service() {
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
private fun downloadStockCheck():Boolean
|
||||||
|
{
|
||||||
|
return getPkgVerCode(yPkg, packageManager) != vancedVersionCode
|
||||||
|
}
|
||||||
|
suspend fun getSha256(obj: String) {
|
||||||
|
sha256Val = InternetTools.getJsonString(hashUrl,obj,applicationContext)
|
||||||
|
}
|
||||||
|
private fun ValidateTheme(): Boolean
|
||||||
|
{
|
||||||
|
val prefs = getSharedPreferences("installPrefs", Context.MODE_PRIVATE)
|
||||||
|
val theme = prefs?.getString("theme", "dark")
|
||||||
|
val themeS = getExternalFilesDir("apks")?.path + "/${theme}.apk"
|
||||||
|
val themeF = File(themeS)
|
||||||
|
runBlocking { getSha256(theme!!) }
|
||||||
|
return checkSHA256(sha256Val!!,themeF)
|
||||||
|
}
|
||||||
|
|
||||||
/*
|
/*
|
||||||
private val receiver = object : BroadcastReceiver() {
|
private val receiver = object : BroadcastReceiver() {
|
||||||
override fun onReceive(context: Context?, intent: Intent?) {
|
override fun onReceive(context: Context?, intent: Intent?) {
|
||||||
|
@ -147,4 +182,44 @@ class VancedDownloadService: Service() {
|
||||||
return null
|
return null
|
||||||
}
|
}
|
||||||
|
|
||||||
|
private fun checkSHA256(sha256: String, updateFile: File?): Boolean {
|
||||||
|
return try {
|
||||||
|
val dataBuffer = updateFile!!.readBytes()
|
||||||
|
// Generate the checksum
|
||||||
|
val sum = generateChecksum(dataBuffer)
|
||||||
|
|
||||||
|
sum == sha256
|
||||||
|
} catch (e: Exception) {
|
||||||
|
e.printStackTrace()
|
||||||
|
false
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
@Throws(IOException::class)
|
||||||
|
private fun generateChecksum(data: ByteArray): String {
|
||||||
|
try {
|
||||||
|
val digest: MessageDigest = MessageDigest.getInstance("SHA-256")
|
||||||
|
val hash: ByteArray = digest.digest(data)
|
||||||
|
return printableHexString(hash)
|
||||||
|
} catch (e: Exception) {
|
||||||
|
e.printStackTrace()
|
||||||
|
}
|
||||||
|
|
||||||
|
return ""
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
private fun printableHexString(data: ByteArray): String {
|
||||||
|
// Create Hex String
|
||||||
|
val hexString: StringBuilder = StringBuilder()
|
||||||
|
for (aMessageDigest:Byte in data) {
|
||||||
|
var h: String = Integer.toHexString(0xFF and aMessageDigest.toInt())
|
||||||
|
while (h.length < 2)
|
||||||
|
h = "0$h"
|
||||||
|
hexString.append(h)
|
||||||
|
}
|
||||||
|
return hexString.toString()
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
}
|
}
|
|
@ -8,10 +8,7 @@ import android.os.IBinder
|
||||||
import android.util.Log
|
import android.util.Log
|
||||||
import androidx.annotation.Nullable
|
import androidx.annotation.Nullable
|
||||||
import androidx.annotation.WorkerThread
|
import androidx.annotation.WorkerThread
|
||||||
import androidx.core.net.toUri
|
|
||||||
import androidx.localbroadcastmanager.content.LocalBroadcastManager
|
import androidx.localbroadcastmanager.content.LocalBroadcastManager
|
||||||
import com.beust.klaxon.JsonObject
|
|
||||||
import com.beust.klaxon.Parser
|
|
||||||
import com.topjohnwu.superuser.Shell
|
import com.topjohnwu.superuser.Shell
|
||||||
import com.topjohnwu.superuser.io.SuFile
|
import com.topjohnwu.superuser.io.SuFile
|
||||||
import com.vanced.manager.BuildConfig
|
import com.vanced.manager.BuildConfig
|
||||||
|
@ -20,15 +17,13 @@ import com.vanced.manager.utils.AppUtils.sendFailure
|
||||||
import com.vanced.manager.utils.FileInfo
|
import com.vanced.manager.utils.FileInfo
|
||||||
import com.vanced.manager.utils.InternetTools.getJsonInt
|
import com.vanced.manager.utils.InternetTools.getJsonInt
|
||||||
import com.vanced.manager.utils.PackageHelper
|
import com.vanced.manager.utils.PackageHelper
|
||||||
|
import com.vanced.manager.utils.PackageHelper.getPkgVerCode
|
||||||
import kotlinx.coroutines.CoroutineScope
|
import kotlinx.coroutines.CoroutineScope
|
||||||
import kotlinx.coroutines.Dispatchers
|
import kotlinx.coroutines.Dispatchers
|
||||||
import kotlinx.coroutines.launch
|
import kotlinx.coroutines.launch
|
||||||
import kotlinx.coroutines.runBlocking
|
import kotlinx.coroutines.runBlocking
|
||||||
import java.io.ByteArrayOutputStream
|
|
||||||
import java.io.File
|
import java.io.File
|
||||||
import java.io.FileInputStream
|
|
||||||
import java.io.IOException
|
import java.io.IOException
|
||||||
import java.security.MessageDigest
|
|
||||||
import java.text.SimpleDateFormat
|
import java.text.SimpleDateFormat
|
||||||
import java.util.*
|
import java.util.*
|
||||||
import java.util.regex.Pattern
|
import java.util.regex.Pattern
|
||||||
|
@ -37,7 +32,6 @@ import kotlin.collections.ArrayList
|
||||||
|
|
||||||
class RootSplitInstallerService: Service() {
|
class RootSplitInstallerService: Service() {
|
||||||
|
|
||||||
private var hashjson: FileInfo? = null
|
|
||||||
private var vancedVersionCode: Int = 0
|
private var vancedVersionCode: Int = 0
|
||||||
val yPkg = "com.google.android.youtube"
|
val yPkg = "com.google.android.youtube"
|
||||||
|
|
||||||
|
@ -71,35 +65,26 @@ class RootSplitInstallerService: Service() {
|
||||||
{
|
{
|
||||||
modApk = fil
|
modApk = fil
|
||||||
}
|
}
|
||||||
if(fil.name == "hash.json")
|
|
||||||
{
|
|
||||||
hashjson = fil
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
if (modApk != null && hashjson != null) {
|
if (modApk != null) {
|
||||||
|
|
||||||
val hash = parseJson(modApk.name.split(".")[0], hashjson!!)
|
if(overwriteBase(modApk, fileInfoList, vancedVersionCode))
|
||||||
if(overwriteBase(modApk, fileInfoList, vancedVersionCode,hash))
|
|
||||||
{
|
{
|
||||||
with(localBroadcastManager) {
|
with(localBroadcastManager) {
|
||||||
sendBroadcast(Intent(HomeFragment.REFRESH_HOME))
|
sendBroadcast(Intent(HomeFragment.REFRESH_HOME))
|
||||||
sendBroadcast(Intent(HomeFragment.VANCED_INSTALLED))
|
sendBroadcast(Intent(HomeFragment.VANCED_INSTALLED))
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
else
|
|
||||||
{
|
|
||||||
sendFailure(listOf("Install Failed").toMutableList(), applicationContext)
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
sendFailure(listOf("modApk Is Null Missing (dark.apk/black.apk) In apks Folder").toMutableList(), applicationContext)
|
sendFailure(listOf("ModApk_Missing").toMutableList(), applicationContext)
|
||||||
}
|
}
|
||||||
//installSplitApkFiles(fileInfoList)
|
//installSplitApkFiles(fileInfoList)
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
sendFailure(listOf("Files are missing, Failed Download?").toMutableList(), applicationContext)
|
sendFailure(listOf("Files_Missing_VA").toMutableList(), applicationContext)
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -108,14 +93,6 @@ class RootSplitInstallerService: Service() {
|
||||||
return START_NOT_STICKY
|
return START_NOT_STICKY
|
||||||
}
|
}
|
||||||
|
|
||||||
private fun parseJson(s: String, hashjson: FileInfo): String
|
|
||||||
{
|
|
||||||
val jsonData = SuFile.open(hashjson.file!!.absolutePath).readText(Charsets.UTF_8)
|
|
||||||
val jsonObject = Parser.default().parse(StringBuilder(jsonData)) as JsonObject
|
|
||||||
return jsonObject.string(s)!!
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
@WorkerThread
|
@WorkerThread
|
||||||
private fun installSplitApkFiles(apkFiles: ArrayList<FileInfo>) : Boolean {
|
private fun installSplitApkFiles(apkFiles: ArrayList<FileInfo>) : Boolean {
|
||||||
var sessionId: Int?
|
var sessionId: Int?
|
||||||
|
@ -207,36 +184,23 @@ class RootSplitInstallerService: Service() {
|
||||||
}
|
}
|
||||||
|
|
||||||
//install Vanced
|
//install Vanced
|
||||||
private fun overwriteBase(apkFile: FileInfo,baseApkFiles: ArrayList<FileInfo>, versionCode: Int,hash: String): Boolean
|
private fun overwriteBase(apkFile: FileInfo,baseApkFiles: ArrayList<FileInfo>, versionCode: Int): Boolean
|
||||||
{
|
{
|
||||||
if(checkVersion(versionCode,baseApkFiles))
|
if(checkVersion(versionCode,baseApkFiles))
|
||||||
{
|
{
|
||||||
val path = getVPath()
|
val path = getVPath()
|
||||||
apkFile.file?.let {
|
apkFile.file?.let {
|
||||||
val apath = it.absolutePath
|
val apath = it.absolutePath
|
||||||
if(sha256Check(apath,hash))
|
if(path?.let { it1 -> moveAPK(apath, it1) }!!)
|
||||||
{
|
{
|
||||||
if(path?.let { it1 -> moveAPK(apath, it1) }!!)
|
val fpath = SuFile.open(path).parent!!
|
||||||
{
|
return chConV(path)
|
||||||
val fpath = SuFile.open(path).parent!!
|
|
||||||
return chConV(path)
|
|
||||||
}
|
|
||||||
}
|
|
||||||
else
|
|
||||||
{
|
|
||||||
sendFailure(listOf("Download Went Corrupt, Retry or clear VanM Data").toMutableList(), applicationContext)
|
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
return false
|
return false
|
||||||
}
|
}
|
||||||
//do sha256 check on downloaded apk
|
|
||||||
private fun sha256Check(apath: String, hash: String): Boolean {
|
|
||||||
val sfile = SuFile.open(apath)
|
|
||||||
return checkSHA256(hash,sfile)
|
|
||||||
}
|
|
||||||
|
|
||||||
//check version and perform action based on result
|
//check version and perform action based on result
|
||||||
private fun checkVersion(versionCode: Int, baseApkFiles: ArrayList<FileInfo>): Boolean {
|
private fun checkVersion(versionCode: Int, baseApkFiles: ArrayList<FileInfo>): Boolean {
|
||||||
|
@ -244,7 +208,7 @@ class RootSplitInstallerService: Service() {
|
||||||
if (path != null) {
|
if (path != null) {
|
||||||
if(path.contains("/data/app/"))
|
if(path.contains("/data/app/"))
|
||||||
{
|
{
|
||||||
when(getPkgVerCode(yPkg)?.let { compareVersion(it,versionCode) })
|
when(getPkgVerCode(yPkg,packageManager)?.let { compareVersion(it,versionCode) })
|
||||||
{
|
{
|
||||||
1 -> {return fixHigherVer(baseApkFiles) }
|
1 -> {return fixHigherVer(baseApkFiles) }
|
||||||
-1 -> {return fixLowerVer(baseApkFiles) }
|
-1 -> {return fixLowerVer(baseApkFiles) }
|
||||||
|
@ -259,17 +223,6 @@ class RootSplitInstallerService: Service() {
|
||||||
return fixNoInstall(baseApkFiles)
|
return fixNoInstall(baseApkFiles)
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
private fun getPkgVerCode(pkg: String): Int? {
|
|
||||||
val pm = packageManager
|
|
||||||
return if (Build.VERSION.SDK_INT >= Build.VERSION_CODES.P)
|
|
||||||
pm.getPackageInfo(pkg, 0)?.longVersionCode?.and(0xFFFFFFFF)?.toInt()
|
|
||||||
else
|
|
||||||
pm.getPackageInfo(pkg, 0)?.versionCode
|
|
||||||
|
|
||||||
}
|
|
||||||
|
|
||||||
private fun getPkgInfo(pkg: String): PackageInfo?
|
private fun getPkgInfo(pkg: String): PackageInfo?
|
||||||
{
|
{
|
||||||
return try {
|
return try {
|
||||||
|
@ -298,7 +251,7 @@ class RootSplitInstallerService: Service() {
|
||||||
{
|
{
|
||||||
return installSplitApkFiles(apkFiles)
|
return installSplitApkFiles(apkFiles)
|
||||||
}
|
}
|
||||||
with(localBroadcastManager) {sendFailure(listOf("Failed Uninstall Of Installed Version, Try Manually").toMutableList(), applicationContext)}
|
with(localBroadcastManager) {sendFailure(listOf("Failed_Uninstall").toMutableList(), applicationContext)}
|
||||||
return false
|
return false
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -314,7 +267,7 @@ class RootSplitInstallerService: Service() {
|
||||||
|
|
||||||
//set chcon to apk_data_file
|
//set chcon to apk_data_file
|
||||||
private fun chConV(path: String): Boolean {
|
private fun chConV(path: String): Boolean {
|
||||||
val response = Shell.su("chcon -R u:object_r:apk_data_file:s0 $path").exec()
|
val response = Shell.su("chcon u:object_r:apk_data_file:s0 $path").exec()
|
||||||
//val response = Shell.su("chcon -R u:object_r:system_file:s0 $path").exec()
|
//val response = Shell.su("chcon -R u:object_r:system_file:s0 $path").exec()
|
||||||
return if(response.isSuccess) {
|
return if(response.isSuccess) {
|
||||||
true
|
true
|
||||||
|
@ -342,7 +295,7 @@ class RootSplitInstallerService: Service() {
|
||||||
return if(Shell.su("chown system:system $path").exec().isSuccess) {
|
return if(Shell.su("chown system:system $path").exec().isSuccess) {
|
||||||
true
|
true
|
||||||
} else {
|
} else {
|
||||||
sendFailure(listOf("Failed To Chown, Try Again").toMutableList(), applicationContext)
|
sendFailure(listOf("Chown_Fail").toMutableList(), applicationContext)
|
||||||
false
|
false
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -354,7 +307,7 @@ class RootSplitInstallerService: Service() {
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
else {
|
else {
|
||||||
sendFailure(listOf("Input File Missing").toMutableList(), applicationContext)
|
sendFailure(listOf("IFile_Missing").toMutableList(), applicationContext)
|
||||||
return false
|
return false
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -377,55 +330,6 @@ class RootSplitInstallerService: Service() {
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
private fun checkSHA256(sha256: String, updateFile: File?): Boolean {
|
|
||||||
try {
|
|
||||||
// get the raw file data of the photo
|
|
||||||
val mInputPFD = contentResolver.openFileDescriptor(updateFile!!.toUri() , "r")
|
|
||||||
val mContentFileDescriptor = mInputPFD!!.fileDescriptor
|
|
||||||
val fIS = FileInputStream(mContentFileDescriptor)
|
|
||||||
val mGraphicBuffer = ByteArrayOutputStream()
|
|
||||||
val buf = ByteArray(1024)
|
|
||||||
while (true) {
|
|
||||||
val readNum = fIS.read(buf)
|
|
||||||
if (readNum == -1) break
|
|
||||||
mGraphicBuffer.write(buf, 0, readNum)
|
|
||||||
}
|
|
||||||
|
|
||||||
// Generate the checksum
|
|
||||||
val sum = generateChecksum(mGraphicBuffer)
|
|
||||||
|
|
||||||
return sum == sha256
|
|
||||||
} catch (e: Exception) {
|
|
||||||
e.printStackTrace()
|
|
||||||
return false
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
@Throws(IOException::class)
|
|
||||||
private fun generateChecksum(data: ByteArrayOutputStream): String {
|
|
||||||
try {
|
|
||||||
val digest: MessageDigest = MessageDigest.getInstance("SHA-256")
|
|
||||||
val hash: ByteArray = digest.digest(data.toByteArray())
|
|
||||||
return printableHexString(hash)
|
|
||||||
} catch (e: Exception) {
|
|
||||||
e.printStackTrace()
|
|
||||||
}
|
|
||||||
|
|
||||||
return ""
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
private fun printableHexString(data: ByteArray): String {
|
|
||||||
// Create Hex String
|
|
||||||
val hexString: StringBuilder = StringBuilder()
|
|
||||||
for (aMessageDigest:Byte in data) {
|
|
||||||
var h: String = Integer.toHexString(0xFF and aMessageDigest.toInt())
|
|
||||||
while (h.length < 2)
|
|
||||||
h = "0$h"
|
|
||||||
hexString.append(h)
|
|
||||||
}
|
|
||||||
return hexString.toString()
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
}
|
}
|
|
@ -39,6 +39,12 @@ object AppUtils {
|
||||||
status.contains("INSTALL_FAILED_INVALID_APK") -> context.getString(R.string.installation_invalid)
|
status.contains("INSTALL_FAILED_INVALID_APK") -> context.getString(R.string.installation_invalid)
|
||||||
status.contains("INSTALL_FAILED_VERSION_DOWNGRADE") -> context.getString(R.string.installation_downgrade)
|
status.contains("INSTALL_FAILED_VERSION_DOWNGRADE") -> context.getString(R.string.installation_downgrade)
|
||||||
status.contains("INSTALL_PARSE_FAILED_NO_CERTIFICATES") -> context.getString(R.string.installation_signature)
|
status.contains("INSTALL_PARSE_FAILED_NO_CERTIFICATES") -> context.getString(R.string.installation_signature)
|
||||||
|
status.contains("Failed_Uninstall") -> context.getString(R.string.Failed_Uninstall)
|
||||||
|
status.contains("Chown_Fail") -> context.getString(R.string.Chown_Fail)
|
||||||
|
status.contains("IFile_Missing") -> context.getString(R.string.IFile_Missing)
|
||||||
|
status.contains("ModApk_Missing") -> context.getString(R.string.ModApk_Missing)
|
||||||
|
status.contains("Files_Missing_VA") -> context.getString(R.string.Files_Missing_VA)
|
||||||
|
status.contains("Corrupt_Data") -> context.getString(R.string.Corrupt_Data)
|
||||||
else ->
|
else ->
|
||||||
if (MiuiHelper.isMiui())
|
if (MiuiHelper.isMiui())
|
||||||
context.getString(R.string.installation_miui)
|
context.getString(R.string.installation_miui)
|
||||||
|
|
|
@ -5,6 +5,7 @@ import android.app.PendingIntent
|
||||||
import android.content.Context
|
import android.content.Context
|
||||||
import android.content.Intent
|
import android.content.Intent
|
||||||
import android.content.pm.PackageManager
|
import android.content.pm.PackageManager
|
||||||
|
import android.os.Build
|
||||||
import com.vanced.manager.core.installer.AppUninstallerService
|
import com.vanced.manager.core.installer.AppUninstallerService
|
||||||
import java.lang.Exception
|
import java.lang.Exception
|
||||||
|
|
||||||
|
@ -26,6 +27,14 @@ object PackageHelper {
|
||||||
""
|
""
|
||||||
}
|
}
|
||||||
|
|
||||||
|
fun getPkgVerCode(pkg: String, pm:PackageManager): Int? {
|
||||||
|
return if (Build.VERSION.SDK_INT >= Build.VERSION_CODES.P)
|
||||||
|
pm.getPackageInfo(pkg, 0)?.longVersionCode?.and(0xFFFFFFFF)?.toInt()
|
||||||
|
else
|
||||||
|
pm.getPackageInfo(pkg, 0)?.versionCode
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
fun uninstallApk(pkg: String, activity: Activity) {
|
fun uninstallApk(pkg: String, activity: Activity) {
|
||||||
val callbackIntent = Intent(activity.applicationContext, AppUninstallerService::class.java)
|
val callbackIntent = Intent(activity.applicationContext, AppUninstallerService::class.java)
|
||||||
callbackIntent.putExtra("pkg", pkg)
|
callbackIntent.putExtra("pkg", pkg)
|
||||||
|
|
|
@ -101,5 +101,11 @@
|
||||||
<string name="manager_dev">Manager Dev</string>
|
<string name="manager_dev">Manager Dev</string>
|
||||||
<string name="sources">Sources</string>
|
<string name="sources">Sources</string>
|
||||||
<string name="vanced_team">Vanced Team</string>
|
<string name="vanced_team">Vanced Team</string>
|
||||||
|
<string name="Failed_Uninstall">Failed Uninstall Of Installed Version, Try Manually</string>
|
||||||
|
<string name="Chown_Fail">Failed To Chown, Try Again</string>
|
||||||
|
<string name="IFile_Missing">Input File Missing</string>
|
||||||
|
<string name="ModApk_Missing">modApk Is Null Missing (dark.apk/black.apk) In apks Folder</string>
|
||||||
|
<string name="Files_Missing_VA">Files are missing, Failed Download?</string>
|
||||||
|
<string name="Corrupt_Data">Download Went Corrupt, Retry or clear VanM Data</string>
|
||||||
|
|
||||||
</resources>
|
</resources>
|
||||||
|
|
Loading…
Reference in a new issue