[CORDA-1595]: If adminAddress is not included in rpcSettings configuration node fails with NullPointerException (fix). (#3385)

This commit is contained in:
Michele Sollecito 2018-06-18 13:41:31 +01:00 committed by GitHub
parent a0c6de7758
commit c2585e8c8e
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23
2 changed files with 30 additions and 11 deletions

View File

@ -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) {

View File

@ -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()