mirror of
https://github.com/corda/corda.git
synced 2025-01-29 15:43:55 +00:00
CORDA-2016 Add unit tests to ensure SNI header generation will not be changed by accident (#4014)
* Add test for SNI header to prevent changing it accidentally. * added hardcoded values test to ensure hashing function and corda x500 name format can't be changed
This commit is contained in:
parent
1e72298a46
commit
149b6034e1
@ -167,5 +167,5 @@ internal fun x500toHostName(x500Name: CordaX500Name): String {
|
|||||||
val secureHash = SecureHash.sha256(x500Name.toString())
|
val secureHash = SecureHash.sha256(x500Name.toString())
|
||||||
// RFC 1035 specifies a limit 255 bytes for hostnames with each label being 63 bytes or less. Due to this, the string
|
// RFC 1035 specifies a limit 255 bytes for hostnames with each label being 63 bytes or less. Due to this, the string
|
||||||
// representation of the SHA256 hash is truncated to 32 characters.
|
// representation of the SHA256 hash is truncated to 32 characters.
|
||||||
return String.format(HOSTNAME_FORMAT, secureHash.toString().substring(0..32).toLowerCase())
|
return String.format(HOSTNAME_FORMAT, secureHash.toString().take(32).toLowerCase())
|
||||||
}
|
}
|
||||||
|
@ -0,0 +1,35 @@
|
|||||||
|
package net.corda.nodeapi.internal.protonwrapper.netty
|
||||||
|
|
||||||
|
import net.corda.core.crypto.SecureHash
|
||||||
|
import net.corda.core.identity.CordaX500Name
|
||||||
|
import net.corda.core.utilities.NetworkHostAndPort
|
||||||
|
import net.corda.nodeapi.internal.config.CertificateStore
|
||||||
|
import net.corda.testing.internal.configureTestSSL
|
||||||
|
import org.junit.Test
|
||||||
|
import javax.net.ssl.KeyManagerFactory
|
||||||
|
import javax.net.ssl.SNIHostName
|
||||||
|
import javax.net.ssl.TrustManagerFactory
|
||||||
|
import kotlin.test.assertEquals
|
||||||
|
|
||||||
|
class SSLHelperTest {
|
||||||
|
@Test
|
||||||
|
fun `ensure SNI header in correct format`() {
|
||||||
|
val legalName = CordaX500Name("Test", "London", "GB")
|
||||||
|
val sslConfig = configureTestSSL(legalName)
|
||||||
|
|
||||||
|
val keyManagerFactory = KeyManagerFactory.getInstance(KeyManagerFactory.getDefaultAlgorithm())
|
||||||
|
val trustManagerFactory = TrustManagerFactory.getInstance(TrustManagerFactory.getDefaultAlgorithm())
|
||||||
|
|
||||||
|
keyManagerFactory.init(CertificateStore.fromFile(sslConfig.keyStore.path, sslConfig.keyStore.password, false))
|
||||||
|
trustManagerFactory.init(initialiseTrustStoreAndEnableCrlChecking(CertificateStore.fromFile(sslConfig.trustStore.path, sslConfig.trustStore.password, false), false))
|
||||||
|
|
||||||
|
val sslHandler = createClientSslHelper(NetworkHostAndPort("localhost", 1234), setOf(legalName), keyManagerFactory, trustManagerFactory)
|
||||||
|
val legalNameHash = SecureHash.sha256(legalName.toString()).toString().take(32).toLowerCase()
|
||||||
|
|
||||||
|
// These hardcoded values must not be changed, something is broken if you have to change these hardcoded values.
|
||||||
|
assertEquals("O=Test, L=London, C=GB", legalName.toString())
|
||||||
|
assertEquals("f3df3c01a5f5aa5b9d394680cde3a414", legalNameHash)
|
||||||
|
assertEquals(1, sslHandler.engine().sslParameters.serverNames.size)
|
||||||
|
assertEquals("$legalNameHash.corda.net", (sslHandler.engine().sslParameters.serverNames.first() as SNIHostName).asciiName)
|
||||||
|
}
|
||||||
|
}
|
Loading…
x
Reference in New Issue
Block a user