Files
Aether/app/src/main/java/com/acitelight/aether/service/AuthManager.kt

73 lines
2.2 KiB
Kotlin

package com.acitelight.aether.service
import android.util.Base64
import android.util.Log
import com.acitelight.aether.model.ChallengeResponse
import kotlinx.coroutines.Dispatchers
import kotlinx.coroutines.runBlocking
import kotlinx.coroutines.withContext
import okhttp3.Call
import okhttp3.EventListener
import okhttp3.Handshake
import okhttp3.OkHttpClient
import okhttp3.Request
import org.bouncycastle.crypto.params.Ed25519PrivateKeyParameters
import org.bouncycastle.crypto.signers.Ed25519Signer
import java.io.IOException
import java.lang.reflect.Proxy
import java.net.InetSocketAddress
import java.security.PrivateKey
import java.security.Signature
import javax.inject.Inject
import javax.inject.Singleton
@Singleton
class AuthManager @Inject constructor(
private val apiClient: ApiClient
) {
suspend fun fetchToken(username: String, privateKey: String): String? {
val api = apiClient.api
var challengeBase64 = ""
try{
challengeBase64 = api!!.getChallenge(username).string()
}catch (e: Exception)
{
return null
}
val signedBase64 = signChallenge(db64(privateKey), db64(challengeBase64))
return try {
api.verifyChallenge(username, ChallengeResponse(response = signedBase64)).string()
} catch (e: Exception) {
e.printStackTrace()
null
}
}
fun db64(b64: String): ByteArray {
return Base64.decode(b64, Base64.DEFAULT) // 32 bytes
}
fun signChallenge(privateKey: ByteArray, data: ByteArray): String
{
val privateKeyParams = Ed25519PrivateKeyParameters(privateKey, 0)
val signer = Ed25519Signer()
signer.init(true, privateKeyParams)
signer.update(data, 0, data.size)
val signature = signer.generateSignature()
return Base64.encodeToString(signature, Base64.NO_WRAP)
}
fun signChallengeByte(privateKey: ByteArray, data: ByteArray): ByteArray //64 Byte
{
val privateKeyParams = Ed25519PrivateKeyParameters(privateKey, 0)
val signer = Ed25519Signer()
signer.init(true, privateKeyParams)
signer.update(data, 0, data.size)
return signer.generateSignature()
}
}