All, We've needed the elusive extension registry for quite some time now, and with NiFi Registry I think we are in a good place to make some progress in this area.
I've started looking into adding "extension bundles" to NiFi Registry as the next type of versioned item, along side the existing versioned flows, and I wanted to take a minute to outline how that approach could work before getting too far into it. Also, I'd like to focus this discussion on the design and functionality of the extension registry, and not on how the community is going to use it. Topics like hosting a central registry, changing the build process, restructuring the git repo, releasing NARs, etc, are all important topics, but first we need an extension registry before we can do any of that :) Here is a high-level description of what needs to be done... NiFi Registry - Add a new type of item called an extension bundle, where each bundle can contain one ore extensions or APIs - Support bundles for traditional NiFi (aka NARs) and also bundles for MiNiFi CPP - Ability to upload the binary artifact for a bundle and extract the metadata about the bundle, and metadata about the extensions contained in the bundle (more on this later) - Provide a pluggable storage provider for saving the content of each extension bundle so that we can have different implementations like local fileysystem, S3, and other object stores - Provide a REST API for listing and retrieving available bundles, integrate this into the registry Java client and NiFi CLI NAR Maven Plugin - Generate a descriptor for each component in the NAR which will provide information like the description, tags, restricted or not, etc. - These descriptors will be parsed by NiFi Registry when a NAR is being uploaded so that NiFi Registry will know about the extensions contained with in the NAR NiFi - Provide some type of extension manager experience where users can search, browse, & install bundles that are available in any of the registry clients that have been defined - Introduce a new security policy to control which users are allowed to access the extension manager - Installing a bundle should load the NAR and make the extensions available leveraging the recent work done to auto-load new NARs - Importing versioned flows from registry should provide an easy way to install bundles that are required by the flow, but missing from the local NiFi instance If anyone has any thoughts or concerns about this approach, please let me know. Thanks, Bryan