Fixes and refactoring in file saving and import functions
This commit is contained in:
parent
836ca1cc6b
commit
0cabf60dc4
3 changed files with 67 additions and 27 deletions
|
@ -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" />
|
||||||
|
|
|
@ -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")
|
||||||
|
|
|
@ -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()
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
Loading…
Add table
Add a link
Reference in a new issue