sanpwc commented on code in PR #4675: URL: https://github.com/apache/ignite-3/pull/4675#discussion_r1836859797
########## modules/distribution-zones/src/main/java/org/apache/ignite/internal/distributionzones/configuration/DistributionZonesHighAvailabilityConfiguration.java: ########## @@ -35,22 +36,28 @@ public class DistributionZonesHighAvailabilityConfiguration { static final String PARTITION_DISTRIBUTION_RESET_TIMEOUT = "partitionDistributionResetTimeout"; /** Default value for the {@link #PARTITION_DISTRIBUTION_RESET_TIMEOUT}. */ - private static final long PARTITION_DISTRIBUTION_RESET_TIMEOUT_DEFAULT_VALUE = 0; + private static final int PARTITION_DISTRIBUTION_RESET_TIMEOUT_DEFAULT_VALUE = 0; private final SystemDistributedConfiguration systemDistributedConfig; /** Determines partition group reset timeout after a partition group majority loss. */ - private volatile long partitionDistributionResetTimeout; + private volatile int partitionDistributionResetTimeout; + + /** Listener, which receives (timeout, revision) on every configuration update. */ + private final BiConsumer<Integer, Long> partitionDistributionResetListener; /** Constructor. */ - public DistributionZonesHighAvailabilityConfiguration(SystemDistributedConfiguration systemDistributedConfig) { + public DistributionZonesHighAvailabilityConfiguration( + SystemDistributedConfiguration systemDistributedConfig, + BiConsumer<Integer, Long> partitionDistributionResetListener) { Review Comment: > Not sure that I understand: onPartitionDistributionResetTimeoutUpdate() must be a getter for the listener? No, I mean `onPartitionDistributionResetTimeoutUpdate(listener)` > Moreover we have no use cases for the mutating of the listener, so I wanted to highlight it in the contract - no any setters or getters, just the argument of the constructor Well, it's a valid point. I still believe that listener() is cleaner then constructor + start here though. Up to you. ########## modules/distribution-zones/src/main/java/org/apache/ignite/internal/distributionzones/configuration/DistributionZonesHighAvailabilityConfiguration.java: ########## @@ -35,22 +36,28 @@ public class DistributionZonesHighAvailabilityConfiguration { static final String PARTITION_DISTRIBUTION_RESET_TIMEOUT = "partitionDistributionResetTimeout"; /** Default value for the {@link #PARTITION_DISTRIBUTION_RESET_TIMEOUT}. */ - private static final long PARTITION_DISTRIBUTION_RESET_TIMEOUT_DEFAULT_VALUE = 0; + private static final int PARTITION_DISTRIBUTION_RESET_TIMEOUT_DEFAULT_VALUE = 0; private final SystemDistributedConfiguration systemDistributedConfig; /** Determines partition group reset timeout after a partition group majority loss. */ - private volatile long partitionDistributionResetTimeout; + private volatile int partitionDistributionResetTimeout; + + /** Listener, which receives (timeout, revision) on every configuration update. */ + private final BiConsumer<Integer, Long> partitionDistributionResetListener; /** Constructor. */ - public DistributionZonesHighAvailabilityConfiguration(SystemDistributedConfiguration systemDistributedConfig) { + public DistributionZonesHighAvailabilityConfiguration( + SystemDistributedConfiguration systemDistributedConfig, + BiConsumer<Integer, Long> partitionDistributionResetListener) { Review Comment: > Not sure that I understand: onPartitionDistributionResetTimeoutUpdate() must be a getter for the listener? No, I mean `onPartitionDistributionResetTimeoutUpdate(listener)` > Moreover we have no use cases for the mutating of the listener, so I wanted to highlight it in the contract - no any setters or getters, just the argument of the constructor Well, it's a valid point. I still believe that listener() is cleaner then constructor + start here though. Up to you. -- This is an automated message from the Apache Git Service. To respond to the message, please log on to GitHub and use the URL above to go to the specific comment. To unsubscribe, e-mail: notifications-unsubscr...@ignite.apache.org For queries about this service, please contact Infrastructure at: us...@infra.apache.org