mirror of https://github.com/apache/nifi.git
NIFI-13267 - Bump NiFi NAR Maven plugin version (#8860)
* NIFI-13267 - Bump NiFi NAR Maven plugin version * Review - adding Parameter Providers and Flow Analaysis Rules in c2-protocol-component-api ComponentManifest * Review - fix build() of ComponentManifest
This commit is contained in:
parent
6c8cc2dd3a
commit
9606102c49
|
@ -30,6 +30,8 @@ public class ComponentManifest implements Serializable {
|
||||||
private List<ControllerServiceDefinition> controllerServices;
|
private List<ControllerServiceDefinition> controllerServices;
|
||||||
private List<ProcessorDefinition> processors;
|
private List<ProcessorDefinition> processors;
|
||||||
private List<ReportingTaskDefinition> reportingTasks;
|
private List<ReportingTaskDefinition> reportingTasks;
|
||||||
|
private List<ParameterProviderDefinition> parameterProviders;
|
||||||
|
private List<FlowAnalysisRuleDefinition> flowAnalysisRules;
|
||||||
|
|
||||||
@Schema(description = "Public interfaces defined in this bundle")
|
@Schema(description = "Public interfaces defined in this bundle")
|
||||||
public List<DefinedType> getApis() {
|
public List<DefinedType> getApis() {
|
||||||
|
@ -67,4 +69,22 @@ public class ComponentManifest implements Serializable {
|
||||||
this.reportingTasks = reportingTasks;
|
this.reportingTasks = reportingTasks;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@Schema(description = "Parameter Providers provided in this bundle")
|
||||||
|
public List<ParameterProviderDefinition> getParameterProviders() {
|
||||||
|
return (parameterProviders != null ? Collections.unmodifiableList(parameterProviders) : null);
|
||||||
|
}
|
||||||
|
|
||||||
|
public void setParameterProviders(List<ParameterProviderDefinition> parameterProviders) {
|
||||||
|
this.parameterProviders = parameterProviders;
|
||||||
|
}
|
||||||
|
|
||||||
|
@Schema(description = "Flow Analysis Rules provided in this bundle")
|
||||||
|
public List<FlowAnalysisRuleDefinition> getFlowAnalysisRules() {
|
||||||
|
return (flowAnalysisRules != null ? Collections.unmodifiableList(flowAnalysisRules) : null);
|
||||||
|
}
|
||||||
|
|
||||||
|
public void setFlowAnalysisRules(List<FlowAnalysisRuleDefinition> flowAnalysisRules) {
|
||||||
|
this.flowAnalysisRules = flowAnalysisRules;
|
||||||
|
}
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
|
@ -0,0 +1,23 @@
|
||||||
|
/*
|
||||||
|
* Licensed to the Apache Software Foundation (ASF) under one or more
|
||||||
|
* contributor license agreements. See the NOTICE file distributed with
|
||||||
|
* this work for additional information regarding copyright ownership.
|
||||||
|
* The ASF licenses this file to You under the Apache License, Version 2.0
|
||||||
|
* (the "License"); you may not use this file except in compliance with
|
||||||
|
* the License. You may obtain a copy of the License at
|
||||||
|
*
|
||||||
|
* http://www.apache.org/licenses/LICENSE-2.0
|
||||||
|
*
|
||||||
|
* Unless required by applicable law or agreed to in writing, software
|
||||||
|
* distributed under the License is distributed on an "AS IS" BASIS,
|
||||||
|
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
||||||
|
* See the License for the specific language governing permissions and
|
||||||
|
* limitations under the License.
|
||||||
|
*/
|
||||||
|
|
||||||
|
package org.apache.nifi.c2.protocol.component.api;
|
||||||
|
|
||||||
|
public class FlowAnalysisRuleDefinition extends ConfigurableExtensionDefinition {
|
||||||
|
private static final long serialVersionUID = 1L;
|
||||||
|
|
||||||
|
}
|
|
@ -0,0 +1,23 @@
|
||||||
|
/*
|
||||||
|
* Licensed to the Apache Software Foundation (ASF) under one or more
|
||||||
|
* contributor license agreements. See the NOTICE file distributed with
|
||||||
|
* this work for additional information regarding copyright ownership.
|
||||||
|
* The ASF licenses this file to You under the Apache License, Version 2.0
|
||||||
|
* (the "License"); you may not use this file except in compliance with
|
||||||
|
* the License. You may obtain a copy of the License at
|
||||||
|
*
|
||||||
|
* http://www.apache.org/licenses/LICENSE-2.0
|
||||||
|
*
|
||||||
|
* Unless required by applicable law or agreed to in writing, software
|
||||||
|
* distributed under the License is distributed on an "AS IS" BASIS,
|
||||||
|
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
||||||
|
* See the License for the specific language governing permissions and
|
||||||
|
* limitations under the License.
|
||||||
|
*/
|
||||||
|
|
||||||
|
package org.apache.nifi.c2.protocol.component.api;
|
||||||
|
|
||||||
|
public class ParameterProviderDefinition extends ConfigurableExtensionDefinition {
|
||||||
|
private static final long serialVersionUID = 1L;
|
||||||
|
|
||||||
|
}
|
|
@ -25,6 +25,10 @@ public enum ExtensionType {
|
||||||
|
|
||||||
CONTROLLER_SERVICE,
|
CONTROLLER_SERVICE,
|
||||||
|
|
||||||
REPORTING_TASK;
|
REPORTING_TASK,
|
||||||
|
|
||||||
|
FLOW_ANALYSIS_RULE,
|
||||||
|
|
||||||
|
PARAMETER_PROVIDER;
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
|
@ -18,6 +18,8 @@ package org.apache.nifi.runtime.manifest;
|
||||||
|
|
||||||
import org.apache.nifi.c2.protocol.component.api.ComponentManifest;
|
import org.apache.nifi.c2.protocol.component.api.ComponentManifest;
|
||||||
import org.apache.nifi.c2.protocol.component.api.ControllerServiceDefinition;
|
import org.apache.nifi.c2.protocol.component.api.ControllerServiceDefinition;
|
||||||
|
import org.apache.nifi.c2.protocol.component.api.FlowAnalysisRuleDefinition;
|
||||||
|
import org.apache.nifi.c2.protocol.component.api.ParameterProviderDefinition;
|
||||||
import org.apache.nifi.c2.protocol.component.api.ProcessorDefinition;
|
import org.apache.nifi.c2.protocol.component.api.ProcessorDefinition;
|
||||||
import org.apache.nifi.c2.protocol.component.api.ReportingTaskDefinition;
|
import org.apache.nifi.c2.protocol.component.api.ReportingTaskDefinition;
|
||||||
|
|
||||||
|
@ -44,6 +46,18 @@ public interface ComponentManifestBuilder {
|
||||||
*/
|
*/
|
||||||
ComponentManifestBuilder addReportingTask(ReportingTaskDefinition reportingTaskDefinition);
|
ComponentManifestBuilder addReportingTask(ReportingTaskDefinition reportingTaskDefinition);
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @param parameterProviderDefinition a parameter provider definition to add
|
||||||
|
* @return the builder
|
||||||
|
*/
|
||||||
|
ComponentManifestBuilder addParameterProvider(ParameterProviderDefinition parameterProviderDefinition);
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @param flowAnalysisRuleDefinition a flow analysis rule definition to add
|
||||||
|
* @return the builder
|
||||||
|
*/
|
||||||
|
ComponentManifestBuilder addFlowAnalysisRule(FlowAnalysisRuleDefinition flowAnalysisRuleDefinition);
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* @return a component manifest containing all the added definitions
|
* @return a component manifest containing all the added definitions
|
||||||
*/
|
*/
|
||||||
|
|
|
@ -18,6 +18,8 @@ package org.apache.nifi.runtime.manifest.impl;
|
||||||
|
|
||||||
import org.apache.nifi.c2.protocol.component.api.ComponentManifest;
|
import org.apache.nifi.c2.protocol.component.api.ComponentManifest;
|
||||||
import org.apache.nifi.c2.protocol.component.api.ControllerServiceDefinition;
|
import org.apache.nifi.c2.protocol.component.api.ControllerServiceDefinition;
|
||||||
|
import org.apache.nifi.c2.protocol.component.api.FlowAnalysisRuleDefinition;
|
||||||
|
import org.apache.nifi.c2.protocol.component.api.ParameterProviderDefinition;
|
||||||
import org.apache.nifi.c2.protocol.component.api.ProcessorDefinition;
|
import org.apache.nifi.c2.protocol.component.api.ProcessorDefinition;
|
||||||
import org.apache.nifi.c2.protocol.component.api.ReportingTaskDefinition;
|
import org.apache.nifi.c2.protocol.component.api.ReportingTaskDefinition;
|
||||||
import org.apache.nifi.runtime.manifest.ComponentManifestBuilder;
|
import org.apache.nifi.runtime.manifest.ComponentManifestBuilder;
|
||||||
|
@ -33,6 +35,8 @@ public class StandardComponentManifestBuilder implements ComponentManifestBuilde
|
||||||
private final List<ProcessorDefinition> processors = new ArrayList<>();
|
private final List<ProcessorDefinition> processors = new ArrayList<>();
|
||||||
private final List<ControllerServiceDefinition> controllerServices = new ArrayList<>();
|
private final List<ControllerServiceDefinition> controllerServices = new ArrayList<>();
|
||||||
private final List<ReportingTaskDefinition> reportingTasks = new ArrayList<>();
|
private final List<ReportingTaskDefinition> reportingTasks = new ArrayList<>();
|
||||||
|
private final List<ParameterProviderDefinition> parameterProviders = new ArrayList<>();
|
||||||
|
private final List<FlowAnalysisRuleDefinition> flowAnalysisRules = new ArrayList<>();
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public ComponentManifestBuilder addProcessor(final ProcessorDefinition processorDefinition) {
|
public ComponentManifestBuilder addProcessor(final ProcessorDefinition processorDefinition) {
|
||||||
|
@ -61,12 +65,32 @@ public class StandardComponentManifestBuilder implements ComponentManifestBuilde
|
||||||
return this;
|
return this;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public ComponentManifestBuilder addParameterProvider(ParameterProviderDefinition parameterProviderDefinition) {
|
||||||
|
if (parameterProviderDefinition == null) {
|
||||||
|
throw new IllegalArgumentException("Parameter Provider definition cannot be null");
|
||||||
|
}
|
||||||
|
parameterProviders.add(parameterProviderDefinition);
|
||||||
|
return this;
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public ComponentManifestBuilder addFlowAnalysisRule(FlowAnalysisRuleDefinition flowAnalysisRuleDefinition) {
|
||||||
|
if (flowAnalysisRuleDefinition == null) {
|
||||||
|
throw new IllegalArgumentException("Flow Analysis Rule definition cannot be null");
|
||||||
|
}
|
||||||
|
flowAnalysisRules.add(flowAnalysisRuleDefinition);
|
||||||
|
return this;
|
||||||
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public ComponentManifest build() {
|
public ComponentManifest build() {
|
||||||
final ComponentManifest componentManifest = new ComponentManifest();
|
final ComponentManifest componentManifest = new ComponentManifest();
|
||||||
componentManifest.setProcessors(new ArrayList<>(processors));
|
componentManifest.setProcessors(new ArrayList<ProcessorDefinition>(processors));
|
||||||
componentManifest.setControllerServices(new ArrayList<>(controllerServices));
|
componentManifest.setControllerServices(new ArrayList<ControllerServiceDefinition>(controllerServices));
|
||||||
componentManifest.setReportingTasks(new ArrayList<>(reportingTasks));
|
componentManifest.setReportingTasks(new ArrayList<ReportingTaskDefinition>(reportingTasks));
|
||||||
|
componentManifest.setParameterProviders(new ArrayList<ParameterProviderDefinition>(parameterProviders));
|
||||||
|
componentManifest.setFlowAnalysisRules(new ArrayList<FlowAnalysisRuleDefinition>(flowAnalysisRules));
|
||||||
return componentManifest;
|
return componentManifest;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -23,7 +23,9 @@ import org.apache.nifi.c2.protocol.component.api.ConfigurableComponentDefinition
|
||||||
import org.apache.nifi.c2.protocol.component.api.ControllerServiceDefinition;
|
import org.apache.nifi.c2.protocol.component.api.ControllerServiceDefinition;
|
||||||
import org.apache.nifi.c2.protocol.component.api.DefinedType;
|
import org.apache.nifi.c2.protocol.component.api.DefinedType;
|
||||||
import org.apache.nifi.c2.protocol.component.api.ExtensionComponent;
|
import org.apache.nifi.c2.protocol.component.api.ExtensionComponent;
|
||||||
|
import org.apache.nifi.c2.protocol.component.api.FlowAnalysisRuleDefinition;
|
||||||
import org.apache.nifi.c2.protocol.component.api.MultiProcessorUseCase;
|
import org.apache.nifi.c2.protocol.component.api.MultiProcessorUseCase;
|
||||||
|
import org.apache.nifi.c2.protocol.component.api.ParameterProviderDefinition;
|
||||||
import org.apache.nifi.c2.protocol.component.api.ProcessorConfiguration;
|
import org.apache.nifi.c2.protocol.component.api.ProcessorConfiguration;
|
||||||
import org.apache.nifi.c2.protocol.component.api.ProcessorDefinition;
|
import org.apache.nifi.c2.protocol.component.api.ProcessorDefinition;
|
||||||
import org.apache.nifi.c2.protocol.component.api.PropertyAllowableValue;
|
import org.apache.nifi.c2.protocol.component.api.PropertyAllowableValue;
|
||||||
|
@ -201,6 +203,12 @@ public class StandardRuntimeManifestBuilder implements RuntimeManifestBuilder {
|
||||||
case REPORTING_TASK:
|
case REPORTING_TASK:
|
||||||
addReportingTaskDefinition(extensionManifest, extension, additionalDetails, componentManifestBuilder);
|
addReportingTaskDefinition(extensionManifest, extension, additionalDetails, componentManifestBuilder);
|
||||||
break;
|
break;
|
||||||
|
case FLOW_ANALYSIS_RULE:
|
||||||
|
addFlowAnalysisRuleDefinition(extensionManifest, extension, additionalDetails, componentManifestBuilder);
|
||||||
|
break;
|
||||||
|
case PARAMETER_PROVIDER:
|
||||||
|
addParameterProviderDefinition(extensionManifest, extension, additionalDetails, componentManifestBuilder);
|
||||||
|
break;
|
||||||
default:
|
default:
|
||||||
throw new IllegalArgumentException("Unknown extension type: " + extension.getType());
|
throw new IllegalArgumentException("Unknown extension type: " + extension.getType());
|
||||||
}
|
}
|
||||||
|
@ -369,6 +377,24 @@ public class StandardRuntimeManifestBuilder implements RuntimeManifestBuilder {
|
||||||
componentManifestBuilder.addControllerService(controllerServiceDefinition);
|
componentManifestBuilder.addControllerService(controllerServiceDefinition);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
private void addParameterProviderDefinition(final ExtensionManifest extensionManifest, final Extension extension, final String additionalDetails,
|
||||||
|
final ComponentManifestBuilder componentManifestBuilder) {
|
||||||
|
final ParameterProviderDefinition parameterProviderDefinition = new ParameterProviderDefinition();
|
||||||
|
populateDefinedType(extensionManifest, extension, parameterProviderDefinition);
|
||||||
|
populateExtensionComponent(extensionManifest, extension, additionalDetails, parameterProviderDefinition);
|
||||||
|
populateConfigurableComponent(extension, parameterProviderDefinition);
|
||||||
|
componentManifestBuilder.addParameterProvider(parameterProviderDefinition);
|
||||||
|
}
|
||||||
|
|
||||||
|
private void addFlowAnalysisRuleDefinition(final ExtensionManifest extensionManifest, final Extension extension, final String additionalDetails,
|
||||||
|
final ComponentManifestBuilder componentManifestBuilder) {
|
||||||
|
final FlowAnalysisRuleDefinition flowAnalysisRuleDefinition = new FlowAnalysisRuleDefinition();
|
||||||
|
populateDefinedType(extensionManifest, extension, flowAnalysisRuleDefinition);
|
||||||
|
populateExtensionComponent(extensionManifest, extension, additionalDetails, flowAnalysisRuleDefinition);
|
||||||
|
populateConfigurableComponent(extension, flowAnalysisRuleDefinition);
|
||||||
|
componentManifestBuilder.addFlowAnalysisRule(flowAnalysisRuleDefinition);
|
||||||
|
}
|
||||||
|
|
||||||
private void addReportingTaskDefinition(final ExtensionManifest extensionManifest, final Extension extension, final String additionalDetails,
|
private void addReportingTaskDefinition(final ExtensionManifest extensionManifest, final Extension extension, final String additionalDetails,
|
||||||
final ComponentManifestBuilder componentManifestBuilder) {
|
final ComponentManifestBuilder componentManifestBuilder) {
|
||||||
final ReportingTaskDefinition reportingTaskDefinition = new ReportingTaskDefinition();
|
final ReportingTaskDefinition reportingTaskDefinition = new ReportingTaskDefinition();
|
||||||
|
|
2
pom.xml
2
pom.xml
|
@ -104,7 +104,7 @@
|
||||||
<docker.image.tag>21</docker.image.tag>
|
<docker.image.tag>21</docker.image.tag>
|
||||||
<node.version>v22.1.0</node.version>
|
<node.version>v22.1.0</node.version>
|
||||||
<frontend.mvn.plugin.version>1.15.0</frontend.mvn.plugin.version>
|
<frontend.mvn.plugin.version>1.15.0</frontend.mvn.plugin.version>
|
||||||
<nifi.nar.maven.plugin.version>1.5.1</nifi.nar.maven.plugin.version>
|
<nifi.nar.maven.plugin.version>2.0.0</nifi.nar.maven.plugin.version>
|
||||||
<project.build.outputTimestamp>1706227889</project.build.outputTimestamp>
|
<project.build.outputTimestamp>1706227889</project.build.outputTimestamp>
|
||||||
<project.build.sourceEncoding>UTF-8</project.build.sourceEncoding>
|
<project.build.sourceEncoding>UTF-8</project.build.sourceEncoding>
|
||||||
<project.reporting.outputEncoding>UTF-8</project.reporting.outputEncoding>
|
<project.reporting.outputEncoding>UTF-8</project.reporting.outputEncoding>
|
||||||
|
|
Loading…
Reference in New Issue