Versions Compared

Key

  • This line was added.
  • This line was removed.
  • Formatting was changed.

Anchor
top73
top73


Tip
titleWant to create a new Mathematical Function/Action?

It's simple! Learn to create customized Mathematical Function/Action in InSights Inference on this page.

In order to run create a new Mathematical Function/Action in  InSights Inference, there are changes that should be made in list of files shown on this page. Please adhere the following instructions, and make respective changes -

Panel

On this page:


Table of Contents


Info

%WORKSPACE%  is the directory which contains InSights - Development Platform.

Changes in ConfigAttributes.java


Browse the directory - "%WORKSPACE%\Insights\PlatformInsights\src\main\java\com\cognizant\devops\platforminsights\core\enums\ConfigAttributes.java"

Add the changes in ConfigAttributes.java as highlighted in Red in the below panel.

Panel
titleBGColor#ddfade
titleConfigAttributes.java

package com.cognizant.devops.platformcommons.core.enums;


public enum ExecutionActions {

AVERAGE, COUNT, MINMAX, (Add your new Mathematical Function/Action Name here)

}


Writing Java code for Custom Mathematical Function/Action


String MASTER = ApplicationConfigProvider.getInstance().getSparkConfigurations().getMaster();String SPARK_EXECUTOR_MEMORY = ApplicationConfigProvider.getInstance().getSparkConfigurations().getSparkExecutorMemory();String
  • Create a new package under "%WORKSPACE%\Insights\PlatformInsights\src\main\java". Use "com.cognizant.devops.platforminsights.core" as base, then append your custom package structure.
  • Import "ConfigConstants.java" from the package, and use the constants specified there to code the Mathematical Function/Action .
Panel
titleBGColor#ddfade
titleConfigConstants.java

package com.cognizant.devops.platforminsights.configs;

public interface ConfigConstants {

String APP_NAME = ApplicationConfigProvider.getInstance().getSparkConfigurations().getAppName();

  • such as SPARK_ES_HOST
= ApplicationConfigProvider.getInstance().getSparkConfigurations().getSparkElasticSearchHost();String
  • SPARK_ES_PORT
= ApplicationConfigProvider.getInstance().getSparkConfigurations().getSparkElasticSearchPort();String
  • , SPARK_ES_CONFIGINDEX
= ApplicationConfigProvider.getInstance().getSparkConfigurations().getSparkElasticSearchConfigIndex();String
  • , SPARK_ES_RESULTINDEX
= ApplicationConfigProvider.getInstance().getSparkConfigurations().getSparkElasticSearchResultIndex();String KPISIZE = ApplicationConfigProvider.getInstance().getSparkConfigurations().getKpiSize();Long SPARK_RESULT_SINCE = ApplicationConfigProvider.getInstance().getSparkConfigurations().getSparkResultSince();String SPARK_TIMEZONE = ApplicationConfigProvider.getInstance().getInsightsTimeZone();}
  • etc,.
  • Also, please refer to existing Mathematical Function/Action classes such as "CountActionImpl" , "MinMaxActionImpl" etc,. for coding strategies.


Info

ConfigConstants.java class reads/contains the "sparkConfigurations" from server-config.json. To check the changes in server-config, click here.



Changes in SparkJobExecutor.java


Browse the directory - "%WORKSPACE%\Insights\PlatformInsights\src\main\java\com\cognizant\devops\platforminsights\core\SparkJobExecutor.java"

Add the changes in ConfigAttributes.java as highlighted in Red in the below panel.

Panel
titleBGColor#ddfade
titleConfigAttributes.java

package com.cognizant.devops.platforminsights.core;


public enum SparkJobExecutor implements Job,Serializable{

...

...

...

private void executeJob(SparkJobConfiguration job)  throws InsightsSparkJobFailedException{


KPIDefinition kpiDefinition = job.getKpiDefinition(job.getKpiDefinition());


if(ExecutionActions.AVERAGE == kpiDefinition.getAction()){

log.debug("KPI action found as AVERAGE");

BaseActionImpl impl = new AverageActionImpl(kpiDefinition);

impl.execute();

} else if(ExecutionActions.COUNT == kpiDefinition.getAction()){

log.debug("KPI action found as COUNT");

BaseActionImpl impl = new CountActionImpl(kpiDefinition);

impl.execute();

}

else if(ExecutionActions.MINMAX == kpiDefinition.getAction()){

log.debug("KPI action found as MINMAX");

BaseActionImpl impl = new MinMaxActionImpl(kpiDefinition);

impl.execute();

}

//(Instance of a Custom Mathematical Function/Action)

else if(ExecutionActions.YourCustomActionName == kpiDefinition.getAction()){

log.debug("KPI action found as Your Custom Action name");

BaseActionImpl impl = new YourCustomActionImplementationClassName(kpiDefinition);

impl.execute();

}

}

...

...

...

}