/nifi-sdk

Custom processors, scripts, and templates for using Grey Matter Data with Apache NiFi

Primary LanguageJavaApache License 2.0Apache-2.0

Grey Matter NiFi SDK

This project contains custom Apache NiFi processors, groovy scripts, and sample templates for integrating NiFi with Grey Matter Data.

Processors

This repository contains custom processors packaged in a NAR file, as well as source scripts for groovy processors that may be manually loaded and tailored to specific needs. Extensive documentation for the processors as well as sample flows can be found in the doc folder.

In general, the processors facilitate creating folder hierarchy, preparing upload file requests, and listing files. Auxiliary processors support converting unix based file permissions and access control model (ACM) structures to the proprietary policy format suitable for Grey Matter Data.

Templates are available in the nifi-templates folder.

Dependencies

  • This project may be built with Maven from the gmd-sdk folder
  • The project must be built with Java 8
  • Maven downloads and compiles Scala code with version 2.12
  • Builds on NiFi 1.12.1

Testing

This is built and tested with Maven. To run unit tests:

cd gmd-sdk
docker-compose up -d
source .environment
mvn clean test

Building

This is built and installed into local repository with Maven. To build the processors:

cd gmd-sdk
docker-compose up -d # Skip this step if you are skipping tests
source .environment
mvn clean package
# To skip tests:
mvn package -DskipTests

The resulting NAR file should end up in the target folder

gmd-sdk/nifi-data-nar/target

as well as your M2 repository within

~/.m2/repository/com/deciphernow/greymatter/nifi-greymatter-data-nar/

Using processors in NiFi

The easiest way to start using these processors is simply running the docker-compose file in ./gmd-sdk. Otherwise you can follow the steps below:

  1. Get the NAR from either the build steps above or from one of the releases in https://github.com/greymatter-io/nifi-sdk/releases.
  2. Before starting NiFi, place the NAR file in ./lib
  • To preload templates place them in ./conf/templates
  1. Start NiFi. Load the UI in your web browser. The default URL is http://localhost:8080/nifi.
  2. To add a processor to your workflow follow the instructions at https://nifi.apache.org/docs/nifi-docs/html/getting-started.html#adding-a-processor

Here are some helpful links for navigating and using NiFi in general as well as customizing your NiFi setup

Requirements for adding a processor to the SDK

To add a processor to the SDK these are the things you need to do in order to make it accessible using the current process outlined in these docs:

  1. Add a reference to the processor's main class to ./gmd-sdk/nifi-data-processors/src/main/resources/META-INF/services/org.apache.nifi.processor.Processor.

  2. Update the release version for the project. The current list of files that need to be changed/hold references to the current version:

  1. Add a note to ./gmd-sdk/CHANGELOG.md listing the new processor and release version.

  2. Add a documentation page for the processor to ./doc. See examples in that directory for how the page should look.

  3. Add a reference to the documentation above to ./doc/README.md