add PublicKeyProvider
This commit is contained in:
35
src/main/kotlin/ltd/hlaeja/util/PublicKeyProvider.kt
Normal file
35
src/main/kotlin/ltd/hlaeja/util/PublicKeyProvider.kt
Normal file
@@ -0,0 +1,35 @@
|
|||||||
|
package ltd.hlaeja.util
|
||||||
|
|
||||||
|
import java.security.KeyFactory
|
||||||
|
import java.security.interfaces.RSAPublicKey
|
||||||
|
import java.security.spec.X509EncodedKeySpec
|
||||||
|
import java.util.Base64.getDecoder
|
||||||
|
import ltd.hlaeja.exception.KeyProviderException
|
||||||
|
|
||||||
|
object PublicKeyProvider {
|
||||||
|
|
||||||
|
fun load(
|
||||||
|
pemFile: String,
|
||||||
|
): RSAPublicKey = readPublicPemFile(pemFile)
|
||||||
|
.let(::makePublicKey)
|
||||||
|
|
||||||
|
private fun makePublicKey(
|
||||||
|
publicKeyBytes: ByteArray,
|
||||||
|
): RSAPublicKey = KeyFactory.getInstance("RSA")
|
||||||
|
.generatePublic(X509EncodedKeySpec(publicKeyBytes)) as RSAPublicKey
|
||||||
|
|
||||||
|
private fun readPublicPemFile(
|
||||||
|
publicKey: String,
|
||||||
|
): ByteArray = javaClass.classLoader
|
||||||
|
.getResource(publicKey)
|
||||||
|
?.readText()
|
||||||
|
?.let(::getPublicKeyByteArray)
|
||||||
|
?: throw KeyProviderException("Could not load public key")
|
||||||
|
|
||||||
|
private fun getPublicKeyByteArray(
|
||||||
|
keyText: String,
|
||||||
|
): ByteArray = keyText.replace(Regex("[\r\n]+"), "")
|
||||||
|
.removePrefix("-----BEGIN PUBLIC KEY-----")
|
||||||
|
.removeSuffix("-----END PUBLIC KEY-----")
|
||||||
|
.let { getDecoder().decode(it) }
|
||||||
|
}
|
||||||
Reference in New Issue
Block a user