mirror of
https://github.com/corda/corda.git
synced 2025-01-03 03:36:48 +00:00
[CORDA-1595]: If adminAddress is not included in rpcSettings configuration node fails with NullPointerException (fix). (#3385)
This commit is contained in:
parent
a0c6de7758
commit
c2585e8c8e
@ -200,23 +200,27 @@ data class NodeConfigurationImpl(
|
|||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
override val rpcOptions: NodeRpcOptions = initialiseRpcOptions(rpcAddress, rpcSettings, BrokerRpcSslOptions(baseDirectory / "certificates" / "nodekeystore.jks", keyStorePassword))
|
private val actualRpcSettings: NodeRpcSettings
|
||||||
|
|
||||||
private fun initialiseRpcOptions(explicitAddress: NetworkHostAndPort?, settings: NodeRpcSettings, fallbackSslOptions: BrokerRpcSslOptions): NodeRpcOptions {
|
init {
|
||||||
return when {
|
actualRpcSettings = when {
|
||||||
explicitAddress != null -> {
|
rpcAddress != null -> {
|
||||||
require(settings.address == null) { "Can't provide top-level rpcAddress and rpcSettings.address (they control the same property)." }
|
require(rpcSettings.address == null) { "Can't provide top-level rpcAddress and rpcSettings.address (they control the same property)." }
|
||||||
logger.warn("Top-level declaration of property 'rpcAddress' is deprecated. Please use 'rpcSettings.address' instead.")
|
logger.warn("Top-level declaration of property 'rpcAddress' is deprecated. Please use 'rpcSettings.address' instead.")
|
||||||
|
|
||||||
settings.copy(address = explicitAddress)
|
rpcSettings.copy(address = rpcAddress)
|
||||||
}
|
}
|
||||||
else -> {
|
else -> {
|
||||||
settings.address ?: throw ConfigException.Missing("rpcSettings.address")
|
rpcSettings.address ?: throw ConfigException.Missing("rpcSettings.address")
|
||||||
settings
|
rpcSettings
|
||||||
|
}
|
||||||
}
|
}
|
||||||
}.asOptions(fallbackSslOptions)
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
override val rpcOptions: NodeRpcOptions
|
||||||
|
get() {
|
||||||
|
return actualRpcSettings.asOptions(BrokerRpcSslOptions(baseDirectory / "certificates" / "nodekeystore.jks", keyStorePassword))
|
||||||
|
}
|
||||||
|
|
||||||
private fun validateTlsCertCrlConfig(): List<String> {
|
private fun validateTlsCertCrlConfig(): List<String> {
|
||||||
val errors = mutableListOf<String>()
|
val errors = mutableListOf<String>()
|
||||||
@ -239,7 +243,12 @@ data class NodeConfigurationImpl(
|
|||||||
override fun validate(): List<String> {
|
override fun validate(): List<String> {
|
||||||
val errors = mutableListOf<String>()
|
val errors = mutableListOf<String>()
|
||||||
errors += validateDevModeOptions()
|
errors += validateDevModeOptions()
|
||||||
errors += validateRpcOptions(rpcOptions)
|
val rpcSettingsErrors = validateRpcSettings(rpcSettings)
|
||||||
|
errors += rpcSettingsErrors
|
||||||
|
if (rpcSettingsErrors.isEmpty()) {
|
||||||
|
// Forces lazy property to initialise in order to throw exceptions
|
||||||
|
rpcOptions
|
||||||
|
}
|
||||||
errors += validateTlsCertCrlConfig()
|
errors += validateTlsCertCrlConfig()
|
||||||
errors += validateNetworkServices()
|
errors += validateNetworkServices()
|
||||||
errors += validateH2Settings()
|
errors += validateH2Settings()
|
||||||
@ -254,7 +263,7 @@ data class NodeConfigurationImpl(
|
|||||||
return errors
|
return errors
|
||||||
}
|
}
|
||||||
|
|
||||||
private fun validateRpcOptions(options: NodeRpcOptions): List<String> {
|
private fun validateRpcSettings(options: NodeRpcSettings): List<String> {
|
||||||
val errors = mutableListOf<String>()
|
val errors = mutableListOf<String>()
|
||||||
if (options.address != null) {
|
if (options.address != null) {
|
||||||
if (!options.useSsl && options.adminAddress == null) {
|
if (!options.useSsl && options.adminAddress == null) {
|
||||||
|
@ -191,6 +191,16 @@ class NodeConfigurationImplTest {
|
|||||||
assertThatCode { rawConfig.parseAsNodeConfiguration() }.doesNotThrowAnyException()
|
assertThatCode { rawConfig.parseAsNodeConfiguration() }.doesNotThrowAnyException()
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@Test
|
||||||
|
fun `missing rpcSettings_adminAddress cause a graceful failure`() {
|
||||||
|
var rawConfig = ConfigFactory.parseResources("working-config.conf", ConfigParseOptions.defaults().setAllowMissing(false))
|
||||||
|
rawConfig = rawConfig.withoutPath("rpcSettings.adminAddress")
|
||||||
|
|
||||||
|
val config = rawConfig.parseAsNodeConfiguration()
|
||||||
|
|
||||||
|
assertThat(config.validate().filter { it.contains("rpcSettings.adminAddress") }).isNotEmpty
|
||||||
|
}
|
||||||
|
|
||||||
@Test
|
@Test
|
||||||
fun `compatiilityZoneURL populates NetworkServices`() {
|
fun `compatiilityZoneURL populates NetworkServices`() {
|
||||||
val compatibilityZoneURL = URI.create("https://r3.com").toURL()
|
val compatibilityZoneURL = URI.create("https://r3.com").toURL()
|
||||||
|
Loading…
Reference in New Issue
Block a user