chesnokoff commented on code in PR #355:
URL: https://github.com/apache/ignite-extensions/pull/355#discussion_r3466755540


##########
modules/auto-activation-ext/src/main/java/opt/apache/ignite/activation/AutoActivationPluginProvider.java:
##########
@@ -0,0 +1,135 @@
+package opt.apache.ignite.activation;
+
+import java.io.Serializable;
+import java.util.Collection;
+import java.util.UUID;
+import org.apache.ignite.Ignite;
+import org.apache.ignite.IgniteCluster;
+import org.apache.ignite.IgniteLogger;
+import org.apache.ignite.cluster.ClusterNode;
+import org.apache.ignite.cluster.ClusterState;
+import org.apache.ignite.lang.IgnitePredicate;
+import org.apache.ignite.plugin.CachePluginContext;
+import org.apache.ignite.plugin.CachePluginProvider;
+import org.apache.ignite.plugin.ExtensionRegistry;
+import org.apache.ignite.plugin.IgnitePlugin;
+import org.apache.ignite.plugin.PluginConfiguration;
+import org.apache.ignite.plugin.PluginContext;
+import org.apache.ignite.plugin.PluginProvider;
+import org.apache.ignite.plugin.PluginValidationException;
+
+/**
+ * Activate cluster when specified condition meet
+ */
+public class AutoActivationPluginProvider implements 
PluginProvider<PluginConfiguration> {
+    /** */
+    private final IgnitePredicate<Collection<ClusterNode>> condition;
+
+    /** */
+    private IgniteLogger logger;
+
+    /** */
+    private Ignite grid;
+
+    /**
+     * @param condition Auto activation condition.
+     */
+    public 
AutoActivationPluginProvider(IgnitePredicate<Collection<ClusterNode>> 
condition) {
+        if (condition == null)
+            throw new IllegalArgumentException("Auto activation condition must 
be set");
+
+        this.condition = condition;
+    }
+
+    /** {@inheritDoc} */
+    @Override public String name() {
+        return "Auto Activation Plugin";
+    }
+
+    /** {@inheritDoc} */
+    @Override public <T extends IgnitePlugin> T plugin() {
+        return (T)new IgnitePlugin() {
+            // No-op.
+        };
+    }
+
+    /** {@inheritDoc} */
+    @Override public String version() {
+        return "1.0";
+    }
+
+    /** {@inheritDoc} */
+    @Override public String copyright() {
+        return "";
+    }
+
+    /** {@inheritDoc} */
+    @Override public void initExtensions(PluginContext pc, ExtensionRegistry 
er) {
+        logger = pc.log(this.getClass());        
+        grid = pc.grid();
+    }
+
+    /** {@inheritDoc} */
+    @Override public <T> T createComponent(PluginContext pc, Class<T> type) {
+        return null;
+    }
+ 
+    /** {@inheritDoc} */
+    @Override public CachePluginProvider 
createCacheProvider(CachePluginContext cpc) {
+        return null;
+    }
+
+    /** {@inheritDoc} */
+    @Override public void start(PluginContext pc) {
+        // do nothing
+    }
+
+    /** {@inheritDoc} */
+    @Override public void stop(boolean bln) {
+        // do nothing
+    }
+
+    /** {@inheritDoc} */
+    @Override public void onIgniteStart() {
+
+        IgniteCluster cluster = grid.cluster();
+
+        if (cluster.state() == ClusterState.ACTIVE) {
+            if (logger.isInfoEnabled()) logger.info("Auto activation skipped - 
cluster already activated");
+            return;
+        }
+
+        if (cluster.currentBaselineTopology() != null) {
+            if (logger.isInfoEnabled()) logger.info("Auto activation skipped - 
baseline is not empty");
+            return;
+        }
+
+        if (condition.apply(cluster.nodes())) {
+            if (logger.isInfoEnabled()) logger.info("Auto activation plugin 
set cluster state ACTIVE - activation condition meet");
+            cluster.state(ClusterState.ACTIVE);
+        }
+        else {
+            if (logger.isInfoEnabled()) logger.info("Auto activation skipped - 
activation condition not meet");

Review Comment:
   ```suggestion
               if (logger.isInfoEnabled()) 
                   logger.info("Auto activation skipped - activation condition 
not meet");
   ```



-- 
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: [email protected]

For queries about this service, please contact Infrastructure at:
[email protected]

Reply via email to