Extracted postInCoroutine() and created a blocking WebClient for Kotlin/Native so that mutable objects don't get passed between threads in Kotlin/Native
This commit is contained in:
parent
aa532b864c
commit
7534c6eb54
|
@ -19,7 +19,7 @@ open class KtorWebClient : IWebClient {
|
|||
}
|
||||
|
||||
|
||||
protected val client = HttpClient() {
|
||||
protected val client = HttpClient {
|
||||
|
||||
}
|
||||
|
||||
|
@ -37,6 +37,11 @@ open class KtorWebClient : IWebClient {
|
|||
|
||||
override fun post(url: String, body: String, contentType: String, userAgent: String, callback: (WebClientResponse) -> Unit) {
|
||||
GlobalScope.async {
|
||||
postInCoroutine(url, body, contentType, userAgent, callback)
|
||||
}
|
||||
}
|
||||
|
||||
protected open suspend fun postInCoroutine(url: String, body: String, contentType: String, userAgent: String, callback: (WebClientResponse) -> Unit) {
|
||||
try {
|
||||
val clientResponse = client.post(url) {
|
||||
contentType(ContentType.Application.OctetStream)
|
||||
|
@ -52,6 +57,5 @@ open class KtorWebClient : IWebClient {
|
|||
callback(WebClientResponse(false, error = e))
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
}
|
|
@ -0,0 +1,14 @@
|
|||
package net.dankito.banking.fints.webclient
|
||||
import kotlinx.coroutines.runBlocking
|
||||
|
||||
|
||||
open class BlockingKtorWebClient : KtorWebClient() {
|
||||
|
||||
|
||||
override fun post(url: String, body: String, contentType: String, userAgent: String, callback: (WebClientResponse) -> Unit) {
|
||||
runBlocking {
|
||||
postInCoroutine(url, body, contentType, userAgent, callback)
|
||||
}
|
||||
}
|
||||
|
||||
}
|
Loading…
Reference in New Issue