Fixes and refactoring in file saving and import functions

This commit is contained in:
albexk 2023-12-14 18:00:58 +03:00
parent 836ca1cc6b
commit 0cabf60dc4
3 changed files with 67 additions and 27 deletions

View file

@ -15,8 +15,9 @@
<!-- %%INSERT_FEATURES --> <!-- %%INSERT_FEATURES -->
<uses-permission android:name="android.permission.INTERNET" /> <uses-permission android:name="android.permission.INTERNET" />
<!-- To request network state for android < 31 --> <!-- To request network state -->
<uses-permission android:name="android.permission.CHANGE_NETWORK_STATE" /> <uses-permission android:name="android.permission.CHANGE_NETWORK_STATE" android:maxSdkVersion="30" />
<uses-permission android:name="android.permission.READ_EXTERNAL_STORAGE" android:maxSdkVersion="28" />
<uses-permission android:name="android.permission.CAMERA" /> <uses-permission android:name="android.permission.CAMERA" />
<uses-permission android:name="android.permission.FOREGROUND_SERVICE" /> <uses-permission android:name="android.permission.FOREGROUND_SERVICE" />
<uses-permission android:name="android.permission.FOREGROUND_SERVICE_SPECIAL_USE" /> <uses-permission android:name="android.permission.FOREGROUND_SERVICE_SPECIAL_USE" />

View file

@ -321,13 +321,9 @@ class AmneziaActivity : QtActivity() {
// saving file // saving file
private fun alterDocument(uri: Uri) { private fun alterDocument(uri: Uri) {
try { try {
applicationContext.contentResolver.openFileDescriptor(uri, "w")?.use { fd -> contentResolver.openOutputStream(uri)?.use { os ->
FileOutputStream(fd.fileDescriptor).use { fos -> os.bufferedWriter().use { it.write(tmpFileContentToSave) }
fos.write(tmpFileContentToSave.toByteArray())
}
} }
} catch (e: FileNotFoundException) {
e.printStackTrace()
} catch (e: IOException) { } catch (e: IOException) {
e.printStackTrace() e.printStackTrace()
} }
@ -363,16 +359,17 @@ class AmneziaActivity : QtActivity() {
@Suppress("unused") @Suppress("unused")
fun saveFile(fileName: String, data: String) { fun saveFile(fileName: String, data: String) {
Log.v(TAG, "Save file $fileName") Log.v(TAG, "Save file $fileName")
// todo: refactor mainScope.launch {
tmpFileContentToSave = data tmpFileContentToSave = data
val intent = Intent(Intent.ACTION_CREATE_DOCUMENT).apply { Intent(Intent.ACTION_CREATE_DOCUMENT).apply {
addCategory(Intent.CATEGORY_OPENABLE) addCategory(Intent.CATEGORY_OPENABLE)
type = "text/*" type = "text/*"
putExtra(Intent.EXTRA_TITLE, fileName) putExtra(Intent.EXTRA_TITLE, fileName)
}.also {
startActivityForResult(it, CREATE_FILE_ACTION_CODE)
}
} }
startActivityForResult(intent, CREATE_FILE_ACTION_CODE)
} }
@Suppress("unused") @Suppress("unused")

View file

@ -1,17 +1,23 @@
package org.amnezia.vpn package org.amnezia.vpn
import android.Manifest
import android.content.Intent import android.content.Intent
import android.content.Intent.ACTION_SEND import android.content.Intent.ACTION_SEND
import android.content.Intent.ACTION_VIEW import android.content.Intent.ACTION_VIEW
import android.content.Intent.CATEGORY_DEFAULT import android.content.Intent.CATEGORY_DEFAULT
import android.content.Intent.EXTRA_TEXT import android.content.Intent.EXTRA_TEXT
import android.content.Intent.FLAG_ACTIVITY_NEW_TASK import android.content.Intent.FLAG_ACTIVITY_NEW_TASK
import android.content.pm.PackageManager
import android.net.Uri import android.net.Uri
import android.os.Build.VERSION import android.os.Build.VERSION
import android.os.Build.VERSION_CODES import android.os.Build.VERSION_CODES
import android.os.Bundle import android.os.Bundle
import android.os.Process
import android.widget.Toast
import androidx.activity.ComponentActivity import androidx.activity.ComponentActivity
import androidx.activity.result.contract.ActivityResultContracts.RequestPermission
import java.io.BufferedReader import java.io.BufferedReader
import java.io.IOException
import org.amnezia.vpn.util.Log import org.amnezia.vpn.util.Log
private const val TAG = "ImportConfigActivity" private const val TAG = "ImportConfigActivity"
@ -38,8 +44,16 @@ class ImportConfigActivity : ComponentActivity() {
ACTION_SEND -> { ACTION_SEND -> {
Log.v(TAG, "Process SEND action, type: ${intent.type}") Log.v(TAG, "Process SEND action, type: ${intent.type}")
when (intent.type) { when (intent.type) {
"application/octet-stream" -> "application/octet-stream" -> {
processStream(intent) intent.getUriCompat()?.let { uri ->
checkPermissions(
uri,
onSuccess = ::processUri,
onFail = ::finish
)
}
return
}
"text/plain" -> { "text/plain" -> {
intent.getStringExtra(EXTRA_TEXT)?.let(::startMainActivity) intent.getStringExtra(EXTRA_TEXT)?.let(::startMainActivity)
@ -55,20 +69,49 @@ class ImportConfigActivity : ComponentActivity() {
finish() finish()
} }
private fun processStream(intent: Intent) { private fun checkPermissions(uri: Uri, onSuccess: (Uri) -> Unit, onFail: () -> Unit) {
getUriCompat(intent)?.let { uri -> if (checkUriReadPermission(uri) == PackageManager.PERMISSION_GRANTED) {
contentResolver.openInputStream(uri)?.use { onSuccess(uri)
it.bufferedReader().use(BufferedReader::readText).let(::startMainActivity) } else {
} val requestPermissionLauncher =
registerForActivityResult(RequestPermission()) { isGranted ->
if (isGranted) onSuccess(uri)
else {
Toast.makeText(this, "Permission denied", Toast.LENGTH_SHORT).show()
onFail()
}
}
requestPermissionLauncher.launch(Manifest.permission.READ_EXTERNAL_STORAGE)
} }
} }
private fun getUriCompat(intent: Intent): Uri? = private fun checkUriReadPermission(uri: Uri) = checkUriPermission(
uri,
Manifest.permission.READ_EXTERNAL_STORAGE,
null,
Process.myPid(),
Process.myUid(),
Intent.FLAG_GRANT_READ_URI_PERMISSION
)
private fun processUri(uri: Uri) {
try {
contentResolver.openInputStream(uri)?.use {
it.bufferedReader().use(BufferedReader::readText).let(::startMainActivity)
}
} catch (e: IOException) {
e.printStackTrace()
} finally {
finish()
}
}
private fun Intent.getUriCompat(): Uri? =
if (VERSION.SDK_INT >= VERSION_CODES.TIRAMISU) { if (VERSION.SDK_INT >= VERSION_CODES.TIRAMISU) {
intent.getParcelableExtra(Intent.EXTRA_STREAM, Uri::class.java) getParcelableExtra(Intent.EXTRA_STREAM, Uri::class.java)
} else { } else {
@Suppress("DEPRECATION") @Suppress("DEPRECATION")
intent.getParcelableExtra(Intent.EXTRA_STREAM) getParcelableExtra(Intent.EXTRA_STREAM)
} }
private fun startMainActivity(config: String) { private fun startMainActivity(config: String) {
@ -83,6 +126,5 @@ class ImportConfigActivity : ComponentActivity() {
startActivity(it) startActivity(it)
} }
} }
finish()
} }
} }