summaryrefslogtreecommitdiff
path: root/nexus/src/test/kotlin/MySerializers.kt
blob: 987079480b81dd0ad17df32512b9e2889038e09a (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
/*
 * This file is part of LibEuFin.
 * Copyright (C) 2024 Taler Systems S.A.

 * LibEuFin is free software; you can redistribute it and/or modify
 * it under the terms of the GNU Affero General Public License as
 * published by the Free Software Foundation; either version 3, or
 * (at your option) any later version.

 * LibEuFin is distributed in the hope that it will be useful, but
 * WITHOUT ANY WARRANTY; without even the implied warranty of MERCHANTABILITY
 * or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU Affero General
 * Public License for more details.

 * You should have received a copy of the GNU Affero General Public
 * License along with LibEuFin; see the file COPYING.  If not, see
 * <http://www.gnu.org/licenses/>
 */

import org.junit.Test
import tech.libeufin.common.Base32Crockford
import tech.libeufin.common.crypto.CryptoUtil
import tech.libeufin.nexus.ClientPrivateKeysFile
import tech.libeufin.nexus.JSON
import kotlin.test.assertEquals

class MySerializers {
    // Testing deserialization of RSA private keys.
    @Test
    fun rsaPrivDeserialization() {
        val s = Base32Crockford.encode(CryptoUtil.generateRsaKeyPair(2048).private.encoded)
        val a = Base32Crockford.encode(CryptoUtil.generateRsaKeyPair(2048).private.encoded)
        val e = Base32Crockford.encode(CryptoUtil.generateRsaKeyPair(2048).private.encoded)
        val obj = JSON.decodeFromString<ClientPrivateKeysFile>("""
            {
              "signature_private_key": "$s",
              "authentication_private_key": "$a",
              "encryption_private_key": "$e",
              "submitted_ini": true,
              "submitted_hia": true
            }
        """.trimIndent())
        assertEquals(obj.signature_private_key, CryptoUtil.loadRsaPrivateKey(Base32Crockford.decode(s)))
        assertEquals(obj.authentication_private_key, CryptoUtil.loadRsaPrivateKey(Base32Crockford.decode(a)))
        assertEquals(obj.encryption_private_key, CryptoUtil.loadRsaPrivateKey(Base32Crockford.decode(e)))
    }
}