Add IpcMessenger class
This commit is contained in:
parent
0ba5d754d5
commit
ad5ea1ca44
2 changed files with 54 additions and 37 deletions
|
@ -43,7 +43,7 @@ class AmneziaActivity : QtActivity() {
|
|||
private var isWaitingStatus = true
|
||||
private var isServiceConnected = false
|
||||
private var isInBoundState = false
|
||||
private var vpnServiceMessenger: Messenger? = null
|
||||
private lateinit var vpnServiceMessenger: IpcMessenger
|
||||
private var tmpFileContentToSave: String = ""
|
||||
|
||||
private val vpnServiceEventHandler: Handler by lazy(NONE) {
|
||||
|
@ -93,23 +93,23 @@ class AmneziaActivity : QtActivity() {
|
|||
override fun onServiceConnected(name: ComponentName?, service: IBinder?) {
|
||||
Log.d(TAG, "Service ${name?.flattenToString()} was connected")
|
||||
// get a messenger from the service to send actions to the service
|
||||
vpnServiceMessenger = Messenger(service)
|
||||
vpnServiceMessenger.set(Messenger(service))
|
||||
// send a messenger to the service to process service events
|
||||
sendToService {
|
||||
vpnServiceMessenger.send {
|
||||
Action.REGISTER_CLIENT.packToMessage().apply {
|
||||
replyTo = activityMessenger
|
||||
}
|
||||
}
|
||||
isServiceConnected = true
|
||||
if (isWaitingStatus) {
|
||||
sendToService(Action.REQUEST_STATUS)
|
||||
vpnServiceMessenger.send(Action.REQUEST_STATUS)
|
||||
}
|
||||
}
|
||||
|
||||
override fun onServiceDisconnected(name: ComponentName?) {
|
||||
Log.w(TAG, "Service ${name?.flattenToString()} was unexpectedly disconnected")
|
||||
isServiceConnected = false
|
||||
vpnServiceMessenger = null
|
||||
vpnServiceMessenger.reset()
|
||||
isWaitingStatus = true
|
||||
QtAndroidController.onServiceDisconnected()
|
||||
}
|
||||
|
@ -133,6 +133,10 @@ class AmneziaActivity : QtActivity() {
|
|||
super.onCreate(savedInstanceState)
|
||||
Log.v(TAG, "Create Amnezia activity")
|
||||
mainScope = CoroutineScope(SupervisorJob() + Dispatchers.Main.immediate)
|
||||
vpnServiceMessenger = IpcMessenger(
|
||||
onDeadObjectException = ::doUnbindService,
|
||||
messengerName = "VpnService"
|
||||
)
|
||||
}
|
||||
|
||||
override fun onStart() {
|
||||
|
@ -189,35 +193,6 @@ class AmneziaActivity : QtActivity() {
|
|||
}
|
||||
}
|
||||
|
||||
/**
|
||||
* Methods of communication with the service
|
||||
*/
|
||||
private fun sendToService(messenger: Messenger, msg: Message) {
|
||||
try {
|
||||
messenger.send(msg)
|
||||
} catch (e: DeadObjectException) {
|
||||
Log.w(TAG, "Service messenger is dead")
|
||||
doUnbindService()
|
||||
} catch (e: RemoteException) {
|
||||
Log.w(TAG, "Sending a message to the service failed: ${e.message}")
|
||||
doUnbindService()
|
||||
}
|
||||
}
|
||||
|
||||
@MainThread
|
||||
private fun sendToService(msg: () -> Message) {
|
||||
vpnServiceMessenger?.let {
|
||||
sendToService(it, msg())
|
||||
}
|
||||
}
|
||||
|
||||
@MainThread
|
||||
private fun sendToService(msg: Action) {
|
||||
vpnServiceMessenger?.let {
|
||||
sendToService(it, msg.packToMessage())
|
||||
}
|
||||
}
|
||||
|
||||
/**
|
||||
* Methods for service binding
|
||||
*/
|
||||
|
@ -236,7 +211,7 @@ class AmneziaActivity : QtActivity() {
|
|||
Log.v(TAG, "Unbind service")
|
||||
isWaitingStatus = true
|
||||
QtAndroidController.onServiceDisconnected()
|
||||
vpnServiceMessenger = null
|
||||
vpnServiceMessenger.reset()
|
||||
isServiceConnected = false
|
||||
isInBoundState = false
|
||||
unbindService(serviceConnection)
|
||||
|
@ -277,7 +252,7 @@ class AmneziaActivity : QtActivity() {
|
|||
|
||||
private fun connectToVpn(vpnConfig: String) {
|
||||
Log.v(TAG, "Connect to VPN")
|
||||
sendToService {
|
||||
vpnServiceMessenger.send {
|
||||
Action.CONNECT.packToMessage {
|
||||
putString(VPN_CONFIG, vpnConfig)
|
||||
}
|
||||
|
@ -295,7 +270,7 @@ class AmneziaActivity : QtActivity() {
|
|||
|
||||
private fun disconnectFromVpn() {
|
||||
Log.v(TAG, "Disconnect from VPN")
|
||||
sendToService(Action.DISCONNECT)
|
||||
vpnServiceMessenger.send(Action.DISCONNECT)
|
||||
}
|
||||
|
||||
// saving file
|
||||
|
|
42
client/android/src/org/amnezia/vpn/IpcMessenger.kt
Normal file
42
client/android/src/org/amnezia/vpn/IpcMessenger.kt
Normal file
|
@ -0,0 +1,42 @@
|
|||
package org.amnezia.vpn
|
||||
|
||||
import android.os.DeadObjectException
|
||||
import android.os.Message
|
||||
import android.os.Messenger
|
||||
import android.os.RemoteException
|
||||
|
||||
private const val TAG = "IpcMessenger"
|
||||
|
||||
class IpcMessenger(
|
||||
private val onDeadObjectException: () -> Unit = {},
|
||||
private val onRemoteException: () -> Unit = {},
|
||||
private val messengerName: String = "Unknown"
|
||||
) {
|
||||
private var messenger: Messenger? = null
|
||||
|
||||
fun set(messenger: Messenger) {
|
||||
this.messenger = messenger
|
||||
}
|
||||
|
||||
fun reset() {
|
||||
messenger = null
|
||||
}
|
||||
|
||||
fun send(msg: () -> Message) = messenger?.sendMsg(msg())
|
||||
|
||||
fun <T> send(msg: T)
|
||||
where T : Enum<T>, T : IpcMessage = messenger?.sendMsg(msg.packToMessage())
|
||||
|
||||
private fun Messenger.sendMsg(msg: Message) {
|
||||
try {
|
||||
send(msg)
|
||||
} catch (e: DeadObjectException) {
|
||||
Log.w(TAG, "$messengerName messenger is dead")
|
||||
messenger = null
|
||||
onDeadObjectException()
|
||||
} catch (e: RemoteException) {
|
||||
Log.w(TAG, "Sending a message to the $messengerName messenger failed: ${e.message}")
|
||||
onRemoteException()
|
||||
}
|
||||
}
|
||||
}
|
Loading…
Add table
Add a link
Reference in a new issue