mirror of https://github.com/apache/nifi.git
NIFI-9754: Introduced VersionedExternalFlow
- Updated stateless and StandardProcessGroup, etc. to make use of VersionedExternalFlow - Updated StatelessDataflowDefinition to use ExternalVersionedFlow instead of generic type - Updated Stateless Bootstrap to avoid loading stateless engine libs from root class path but instead use a NarClassLoader to load the statelss nar Signed-off-by: Joe Gresock <jgresock@gmail.com> This closes #5832.
This commit is contained in:
parent
7438bc9244
commit
8959226b50
|
@ -14,7 +14,7 @@
|
||||||
* See the License for the specific language governing permissions and
|
* See the License for the specific language governing permissions and
|
||||||
* limitations under the License.
|
* limitations under the License.
|
||||||
*/
|
*/
|
||||||
package org.apache.nifi.registry.flow;
|
package org.apache.nifi.flow;
|
||||||
|
|
||||||
import io.swagger.annotations.ApiModel;
|
import io.swagger.annotations.ApiModel;
|
||||||
import io.swagger.annotations.ApiModelProperty;
|
import io.swagger.annotations.ApiModelProperty;
|
|
@ -0,0 +1,59 @@
|
||||||
|
/*
|
||||||
|
* 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.flow;
|
||||||
|
|
||||||
|
import java.util.Map;
|
||||||
|
|
||||||
|
public class VersionedExternalFlow {
|
||||||
|
private VersionedProcessGroup flowContents;
|
||||||
|
private Map<String, ExternalControllerServiceReference> externalControllerServices;
|
||||||
|
private Map<String, VersionedParameterContext> parameterContexts;
|
||||||
|
private VersionedExternalFlowMetadata metadata;
|
||||||
|
|
||||||
|
public VersionedProcessGroup getFlowContents() {
|
||||||
|
return flowContents;
|
||||||
|
}
|
||||||
|
|
||||||
|
public void setFlowContents(final VersionedProcessGroup flowContents) {
|
||||||
|
this.flowContents = flowContents;
|
||||||
|
}
|
||||||
|
|
||||||
|
public Map<String, ExternalControllerServiceReference> getExternalControllerServices() {
|
||||||
|
return externalControllerServices;
|
||||||
|
}
|
||||||
|
|
||||||
|
public void setExternalControllerServices(final Map<String, ExternalControllerServiceReference> externalControllerServices) {
|
||||||
|
this.externalControllerServices = externalControllerServices;
|
||||||
|
}
|
||||||
|
|
||||||
|
public Map<String, VersionedParameterContext> getParameterContexts() {
|
||||||
|
return parameterContexts;
|
||||||
|
}
|
||||||
|
|
||||||
|
public void setParameterContexts(final Map<String, VersionedParameterContext> parameterContexts) {
|
||||||
|
this.parameterContexts = parameterContexts;
|
||||||
|
}
|
||||||
|
|
||||||
|
public VersionedExternalFlowMetadata getMetadata() {
|
||||||
|
return metadata;
|
||||||
|
}
|
||||||
|
|
||||||
|
public void setMetadata(final VersionedExternalFlowMetadata metadata) {
|
||||||
|
this.metadata = metadata;
|
||||||
|
}
|
||||||
|
}
|
|
@ -0,0 +1,84 @@
|
||||||
|
/*
|
||||||
|
* 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.flow;
|
||||||
|
|
||||||
|
public class VersionedExternalFlowMetadata {
|
||||||
|
private String bucketId;
|
||||||
|
private String flowId;
|
||||||
|
private int version;
|
||||||
|
private String flowName;
|
||||||
|
private String author;
|
||||||
|
private String comments;
|
||||||
|
private long timestamp;
|
||||||
|
|
||||||
|
public String getBucketIdentifier() {
|
||||||
|
return bucketId;
|
||||||
|
}
|
||||||
|
|
||||||
|
public void setBucketIdentifier(final String bucketIdentifier) {
|
||||||
|
this.bucketId = bucketIdentifier;
|
||||||
|
}
|
||||||
|
|
||||||
|
public String getFlowIdentifier() {
|
||||||
|
return flowId;
|
||||||
|
}
|
||||||
|
|
||||||
|
public void setFlowIdentifier(final String flowId) {
|
||||||
|
this.flowId = flowId;
|
||||||
|
}
|
||||||
|
|
||||||
|
public int getVersion() {
|
||||||
|
return version;
|
||||||
|
}
|
||||||
|
|
||||||
|
public void setVersion(final int version) {
|
||||||
|
this.version = version;
|
||||||
|
}
|
||||||
|
|
||||||
|
public String getFlowName() {
|
||||||
|
return flowName;
|
||||||
|
}
|
||||||
|
|
||||||
|
public void setFlowName(final String flowName) {
|
||||||
|
this.flowName = flowName;
|
||||||
|
}
|
||||||
|
|
||||||
|
public String getAuthor() {
|
||||||
|
return author;
|
||||||
|
}
|
||||||
|
|
||||||
|
public void setAuthor(final String author) {
|
||||||
|
this.author = author;
|
||||||
|
}
|
||||||
|
|
||||||
|
public String getComments() {
|
||||||
|
return comments;
|
||||||
|
}
|
||||||
|
|
||||||
|
public void setComments(final String comments) {
|
||||||
|
this.comments = comments;
|
||||||
|
}
|
||||||
|
|
||||||
|
public long getTimestamp() {
|
||||||
|
return timestamp;
|
||||||
|
}
|
||||||
|
|
||||||
|
public void setTimestamp(final long timestamp) {
|
||||||
|
this.timestamp = timestamp;
|
||||||
|
}
|
||||||
|
}
|
|
@ -14,7 +14,7 @@
|
||||||
* See the License for the specific language governing permissions and
|
* See the License for the specific language governing permissions and
|
||||||
* limitations under the License.
|
* limitations under the License.
|
||||||
*/
|
*/
|
||||||
package org.apache.nifi.registry.flow;
|
package org.apache.nifi.flow;
|
||||||
|
|
||||||
import io.swagger.annotations.ApiModelProperty;
|
import io.swagger.annotations.ApiModelProperty;
|
||||||
|
|
|
@ -14,11 +14,9 @@
|
||||||
* See the License for the specific language governing permissions and
|
* See the License for the specific language governing permissions and
|
||||||
* limitations under the License.
|
* limitations under the License.
|
||||||
*/
|
*/
|
||||||
package org.apache.nifi.registry.flow;
|
package org.apache.nifi.flow;
|
||||||
|
|
||||||
import io.swagger.annotations.ApiModelProperty;
|
import io.swagger.annotations.ApiModelProperty;
|
||||||
import org.apache.nifi.flow.ComponentType;
|
|
||||||
import org.apache.nifi.flow.VersionedComponent;
|
|
||||||
|
|
||||||
import java.util.List;
|
import java.util.List;
|
||||||
import java.util.Set;
|
import java.util.Set;
|
|
@ -155,7 +155,7 @@ public class StatelessKafkaConnectorUtil {
|
||||||
final List<ParameterOverride> parameterOverrides = parseParameterOverrides(properties);
|
final List<ParameterOverride> parameterOverrides = parseParameterOverrides(properties);
|
||||||
final String dataflowName = properties.get(DATAFLOW_NAME);
|
final String dataflowName = properties.get(DATAFLOW_NAME);
|
||||||
|
|
||||||
final DataflowDefinition<?> dataflowDefinition;
|
final DataflowDefinition dataflowDefinition;
|
||||||
final StatelessBootstrap bootstrap;
|
final StatelessBootstrap bootstrap;
|
||||||
try {
|
try {
|
||||||
final Map<String, String> dataflowDefinitionProperties = new HashMap<>();
|
final Map<String, String> dataflowDefinitionProperties = new HashMap<>();
|
||||||
|
|
|
@ -18,18 +18,18 @@
|
||||||
package org.apache.nifi.groups;
|
package org.apache.nifi.groups;
|
||||||
|
|
||||||
import org.apache.nifi.controller.exception.ProcessorInstantiationException;
|
import org.apache.nifi.controller.exception.ProcessorInstantiationException;
|
||||||
|
import org.apache.nifi.flow.VersionedExternalFlow;
|
||||||
import org.apache.nifi.flow.VersionedProcessGroup;
|
import org.apache.nifi.flow.VersionedProcessGroup;
|
||||||
import org.apache.nifi.registry.flow.VersionedFlowSnapshot;
|
|
||||||
|
|
||||||
public interface ProcessGroupSynchronizer {
|
public interface ProcessGroupSynchronizer {
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Synchronize the given Process Group to match the proposed snaphsot
|
* Synchronize the given Process Group to match the proposed snaphsot
|
||||||
* @param group the Process Group to update
|
* @param group the Process Group to update
|
||||||
* @param proposedSnapshot the proposed/desired state for the process group
|
* @param proposedFlow the proposed/desired state for the process group
|
||||||
* @param synchronizationOptions options for how to synchronize the group
|
* @param synchronizationOptions options for how to synchronize the group
|
||||||
*/
|
*/
|
||||||
void synchronize(ProcessGroup group, VersionedFlowSnapshot proposedSnapshot, GroupSynchronizationOptions synchronizationOptions) throws ProcessorInstantiationException;
|
void synchronize(ProcessGroup group, VersionedExternalFlow proposedFlow, GroupSynchronizationOptions synchronizationOptions) throws ProcessorInstantiationException;
|
||||||
|
|
||||||
void verifyCanSynchronize(ProcessGroup group, VersionedProcessGroup proposed, boolean verifyConnectionRemoval);
|
void verifyCanSynchronize(ProcessGroup group, VersionedProcessGroup proposed, boolean verifyConnectionRemoval);
|
||||||
|
|
||||||
|
|
|
@ -64,6 +64,7 @@ import org.apache.nifi.controller.service.ControllerServiceReference;
|
||||||
import org.apache.nifi.controller.service.ControllerServiceState;
|
import org.apache.nifi.controller.service.ControllerServiceState;
|
||||||
import org.apache.nifi.controller.service.StandardConfigurationContext;
|
import org.apache.nifi.controller.service.StandardConfigurationContext;
|
||||||
import org.apache.nifi.encrypt.PropertyEncryptor;
|
import org.apache.nifi.encrypt.PropertyEncryptor;
|
||||||
|
import org.apache.nifi.flow.VersionedExternalFlow;
|
||||||
import org.apache.nifi.flow.VersionedProcessGroup;
|
import org.apache.nifi.flow.VersionedProcessGroup;
|
||||||
import org.apache.nifi.logging.LogRepository;
|
import org.apache.nifi.logging.LogRepository;
|
||||||
import org.apache.nifi.logging.LogRepositoryFactory;
|
import org.apache.nifi.logging.LogRepositoryFactory;
|
||||||
|
@ -3778,7 +3779,7 @@ public final class StandardProcessGroup implements ProcessGroup {
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public void updateFlow(final VersionedFlowSnapshot proposedSnapshot, final String componentIdSeed, final boolean verifyNotDirty, final boolean updateSettings,
|
public void updateFlow(final VersionedExternalFlow proposedSnapshot, final String componentIdSeed, final boolean verifyNotDirty, final boolean updateSettings,
|
||||||
final boolean updateDescendantVersionedFlows) {
|
final boolean updateDescendantVersionedFlows) {
|
||||||
|
|
||||||
final ComponentIdGenerator idGenerator = (proposedId, instanceId, destinationGroupId) -> generateUuid(proposedId, destinationGroupId, componentIdSeed);
|
final ComponentIdGenerator idGenerator = (proposedId, instanceId, destinationGroupId) -> generateUuid(proposedId, destinationGroupId, componentIdSeed);
|
||||||
|
@ -3815,7 +3816,7 @@ public final class StandardProcessGroup implements ProcessGroup {
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public void synchronizeFlow(final VersionedFlowSnapshot proposedSnapshot, final GroupSynchronizationOptions synchronizationOptions, final FlowMappingOptions flowMappingOptions) {
|
public void synchronizeFlow(final VersionedExternalFlow proposedSnapshot, final GroupSynchronizationOptions synchronizationOptions, final FlowMappingOptions flowMappingOptions) {
|
||||||
writeLock.lock();
|
writeLock.lock();
|
||||||
try {
|
try {
|
||||||
verifyCanUpdate(proposedSnapshot, true, !synchronizationOptions.isIgnoreLocalModifications());
|
verifyCanUpdate(proposedSnapshot, true, !synchronizationOptions.isIgnoreLocalModifications());
|
||||||
|
@ -3924,13 +3925,13 @@ public final class StandardProcessGroup implements ProcessGroup {
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public void verifyCanUpdate(final VersionedFlowSnapshot updatedFlow, final boolean verifyConnectionRemoval, final boolean verifyNotDirty) {
|
public void verifyCanUpdate(final VersionedExternalFlow updatedFlow, final boolean verifyConnectionRemoval, final boolean verifyNotDirty) {
|
||||||
readLock.lock();
|
readLock.lock();
|
||||||
try {
|
try {
|
||||||
// flow id match and not dirty check concepts are only applicable to versioned flows
|
// flow id match and not dirty check concepts are only applicable to versioned flows
|
||||||
final VersionControlInformation versionControlInfo = getVersionControlInformation();
|
final VersionControlInformation versionControlInfo = getVersionControlInformation();
|
||||||
if (versionControlInfo != null) {
|
if (versionControlInfo != null) {
|
||||||
if (!versionControlInfo.getFlowIdentifier().equals(updatedFlow.getSnapshotMetadata().getFlowIdentifier())) {
|
if (!versionControlInfo.getFlowIdentifier().equals(updatedFlow.getMetadata().getFlowIdentifier())) {
|
||||||
throw new IllegalStateException(this + " is under version control but the given flow does not match the flow that this Process Group is synchronized with");
|
throw new IllegalStateException(this + " is under version control but the given flow does not match the flow that this Process Group is synchronized with");
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -48,6 +48,7 @@ import org.apache.nifi.flow.ConnectableComponent;
|
||||||
import org.apache.nifi.flow.VersionedComponent;
|
import org.apache.nifi.flow.VersionedComponent;
|
||||||
import org.apache.nifi.flow.VersionedConnection;
|
import org.apache.nifi.flow.VersionedConnection;
|
||||||
import org.apache.nifi.flow.VersionedControllerService;
|
import org.apache.nifi.flow.VersionedControllerService;
|
||||||
|
import org.apache.nifi.flow.VersionedExternalFlow;
|
||||||
import org.apache.nifi.flow.VersionedFlowCoordinates;
|
import org.apache.nifi.flow.VersionedFlowCoordinates;
|
||||||
import org.apache.nifi.flow.VersionedFunnel;
|
import org.apache.nifi.flow.VersionedFunnel;
|
||||||
import org.apache.nifi.flow.VersionedLabel;
|
import org.apache.nifi.flow.VersionedLabel;
|
||||||
|
@ -71,8 +72,8 @@ import org.apache.nifi.registry.flow.StandardVersionControlInformation;
|
||||||
import org.apache.nifi.registry.flow.VersionControlInformation;
|
import org.apache.nifi.registry.flow.VersionControlInformation;
|
||||||
import org.apache.nifi.registry.flow.VersionedFlowSnapshot;
|
import org.apache.nifi.registry.flow.VersionedFlowSnapshot;
|
||||||
import org.apache.nifi.registry.flow.VersionedFlowState;
|
import org.apache.nifi.registry.flow.VersionedFlowState;
|
||||||
import org.apache.nifi.registry.flow.VersionedParameter;
|
import org.apache.nifi.flow.VersionedParameter;
|
||||||
import org.apache.nifi.registry.flow.VersionedParameterContext;
|
import org.apache.nifi.flow.VersionedParameterContext;
|
||||||
import org.apache.nifi.registry.flow.diff.ComparableDataFlow;
|
import org.apache.nifi.registry.flow.diff.ComparableDataFlow;
|
||||||
import org.apache.nifi.registry.flow.diff.DifferenceType;
|
import org.apache.nifi.registry.flow.diff.DifferenceType;
|
||||||
import org.apache.nifi.registry.flow.diff.FlowComparator;
|
import org.apache.nifi.registry.flow.diff.FlowComparator;
|
||||||
|
@ -142,13 +143,13 @@ public class StandardProcessGroupSynchronizer implements ProcessGroupSynchronize
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public void synchronize(final ProcessGroup group, final VersionedFlowSnapshot proposedSnapshot, final GroupSynchronizationOptions options) {
|
public void synchronize(final ProcessGroup group, final VersionedExternalFlow versionedExternalFlow, final GroupSynchronizationOptions options) {
|
||||||
|
|
||||||
final NiFiRegistryFlowMapper mapper = new NiFiRegistryFlowMapper(context.getExtensionManager(), context.getFlowMappingOptions());
|
final NiFiRegistryFlowMapper mapper = new NiFiRegistryFlowMapper(context.getExtensionManager(), context.getFlowMappingOptions());
|
||||||
final VersionedProcessGroup versionedGroup = mapper.mapProcessGroup(group, context.getControllerServiceProvider(), context.getFlowRegistryClient(), true);
|
final VersionedProcessGroup versionedGroup = mapper.mapProcessGroup(group, context.getControllerServiceProvider(), context.getFlowRegistryClient(), true);
|
||||||
|
|
||||||
final ComparableDataFlow localFlow = new StandardComparableDataFlow("Currently Loaded Flow", versionedGroup);
|
final ComparableDataFlow localFlow = new StandardComparableDataFlow("Currently Loaded Flow", versionedGroup);
|
||||||
final ComparableDataFlow proposedFlow = new StandardComparableDataFlow("Proposed Flow", proposedSnapshot.getFlowContents());
|
final ComparableDataFlow proposedFlow = new StandardComparableDataFlow("Proposed Flow", versionedExternalFlow.getFlowContents());
|
||||||
|
|
||||||
final PropertyDecryptor decryptor = options.getPropertyDecryptor();
|
final PropertyDecryptor decryptor = options.getPropertyDecryptor();
|
||||||
final FlowComparator flowComparator = new StandardFlowComparator(proposedFlow, localFlow, group.getAncestorServiceIds(), new StaticDifferenceDescriptor(), decryptor::decrypt);
|
final FlowComparator flowComparator = new StandardFlowComparator(proposedFlow, localFlow, group.getAncestorServiceIds(), new StaticDifferenceDescriptor(), decryptor::decrypt);
|
||||||
|
@ -199,7 +200,7 @@ public class StandardProcessGroupSynchronizer implements ProcessGroupSynchronize
|
||||||
.map(FlowDifference::toString)
|
.map(FlowDifference::toString)
|
||||||
.collect(Collectors.joining("\n"));
|
.collect(Collectors.joining("\n"));
|
||||||
|
|
||||||
LOG.info("Updating {} to {}; there are {} differences to take into account:\n{}", group, proposedSnapshot,
|
LOG.info("Updating {} to {}; there are {} differences to take into account:\n{}", group, versionedExternalFlow,
|
||||||
flowComparison.getDifferences().size(), differencesByLine);
|
flowComparison.getDifferences().size(), differencesByLine);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -217,7 +218,7 @@ public class StandardProcessGroupSynchronizer implements ProcessGroupSynchronize
|
||||||
|
|
||||||
context.getFlowManager().withParameterContextResolution(() -> {
|
context.getFlowManager().withParameterContextResolution(() -> {
|
||||||
try {
|
try {
|
||||||
synchronize(group, proposedSnapshot.getFlowContents(), proposedSnapshot.getParameterContexts());
|
synchronize(group, versionedExternalFlow.getFlowContents(), versionedExternalFlow.getParameterContexts());
|
||||||
} catch (final ProcessorInstantiationException pie) {
|
} catch (final ProcessorInstantiationException pie) {
|
||||||
throw new RuntimeException(pie);
|
throw new RuntimeException(pie);
|
||||||
}
|
}
|
||||||
|
|
|
@ -18,7 +18,9 @@
|
||||||
package org.apache.nifi.registry.flow;
|
package org.apache.nifi.registry.flow;
|
||||||
|
|
||||||
import org.apache.nifi.authorization.user.NiFiUser;
|
import org.apache.nifi.authorization.user.NiFiUser;
|
||||||
|
import org.apache.nifi.flow.ExternalControllerServiceReference;
|
||||||
import org.apache.nifi.flow.VersionedFlowCoordinates;
|
import org.apache.nifi.flow.VersionedFlowCoordinates;
|
||||||
|
import org.apache.nifi.flow.VersionedParameterContext;
|
||||||
import org.apache.nifi.flow.VersionedProcessGroup;
|
import org.apache.nifi.flow.VersionedProcessGroup;
|
||||||
import org.apache.nifi.registry.bucket.Bucket;
|
import org.apache.nifi.registry.bucket.Bucket;
|
||||||
import org.apache.nifi.registry.client.BucketClient;
|
import org.apache.nifi.registry.client.BucketClient;
|
||||||
|
|
|
@ -17,7 +17,7 @@
|
||||||
|
|
||||||
package org.apache.nifi.registry.flow.mapping;
|
package org.apache.nifi.registry.flow.mapping;
|
||||||
|
|
||||||
import org.apache.nifi.registry.flow.ExternalControllerServiceReference;
|
import org.apache.nifi.flow.ExternalControllerServiceReference;
|
||||||
import org.apache.nifi.flow.VersionedProcessGroup;
|
import org.apache.nifi.flow.VersionedProcessGroup;
|
||||||
|
|
||||||
import javax.xml.bind.annotation.XmlTransient;
|
import javax.xml.bind.annotation.XmlTransient;
|
||||||
|
|
|
@ -67,12 +67,12 @@ import org.apache.nifi.parameter.ParameterContext;
|
||||||
import org.apache.nifi.parameter.ParameterDescriptor;
|
import org.apache.nifi.parameter.ParameterDescriptor;
|
||||||
import org.apache.nifi.processor.Relationship;
|
import org.apache.nifi.processor.Relationship;
|
||||||
import org.apache.nifi.registry.VariableDescriptor;
|
import org.apache.nifi.registry.VariableDescriptor;
|
||||||
import org.apache.nifi.registry.flow.ExternalControllerServiceReference;
|
import org.apache.nifi.flow.ExternalControllerServiceReference;
|
||||||
import org.apache.nifi.registry.flow.FlowRegistry;
|
import org.apache.nifi.registry.flow.FlowRegistry;
|
||||||
import org.apache.nifi.registry.flow.FlowRegistryClient;
|
import org.apache.nifi.registry.flow.FlowRegistryClient;
|
||||||
import org.apache.nifi.registry.flow.VersionControlInformation;
|
import org.apache.nifi.registry.flow.VersionControlInformation;
|
||||||
import org.apache.nifi.registry.flow.VersionedParameter;
|
import org.apache.nifi.flow.VersionedParameter;
|
||||||
import org.apache.nifi.registry.flow.VersionedParameterContext;
|
import org.apache.nifi.flow.VersionedParameterContext;
|
||||||
import org.apache.nifi.remote.PublicPort;
|
import org.apache.nifi.remote.PublicPort;
|
||||||
import org.apache.nifi.remote.RemoteGroupPort;
|
import org.apache.nifi.remote.RemoteGroupPort;
|
||||||
|
|
||||||
|
|
|
@ -20,7 +20,7 @@ package org.apache.nifi.registry.flow.mapping;
|
||||||
import org.apache.nifi.flow.VersionedControllerService;
|
import org.apache.nifi.flow.VersionedControllerService;
|
||||||
import org.apache.nifi.flow.VersionedProcessGroup;
|
import org.apache.nifi.flow.VersionedProcessGroup;
|
||||||
import org.apache.nifi.flow.VersionedReportingTask;
|
import org.apache.nifi.flow.VersionedReportingTask;
|
||||||
import org.apache.nifi.registry.flow.VersionedParameterContext;
|
import org.apache.nifi.flow.VersionedParameterContext;
|
||||||
import org.apache.nifi.registry.flow.diff.ComparableDataFlow;
|
import org.apache.nifi.registry.flow.diff.ComparableDataFlow;
|
||||||
|
|
||||||
import java.util.Collections;
|
import java.util.Collections;
|
||||||
|
|
|
@ -20,7 +20,7 @@ package org.apache.nifi.controller.flow;
|
||||||
import org.apache.nifi.flow.VersionedControllerService;
|
import org.apache.nifi.flow.VersionedControllerService;
|
||||||
import org.apache.nifi.flow.VersionedProcessGroup;
|
import org.apache.nifi.flow.VersionedProcessGroup;
|
||||||
import org.apache.nifi.flow.VersionedReportingTask;
|
import org.apache.nifi.flow.VersionedReportingTask;
|
||||||
import org.apache.nifi.registry.flow.VersionedParameterContext;
|
import org.apache.nifi.flow.VersionedParameterContext;
|
||||||
|
|
||||||
import java.util.List;
|
import java.util.List;
|
||||||
import java.util.Set;
|
import java.util.Set;
|
||||||
|
|
|
@ -33,6 +33,7 @@ import org.apache.nifi.controller.Triggerable;
|
||||||
import org.apache.nifi.controller.label.Label;
|
import org.apache.nifi.controller.label.Label;
|
||||||
import org.apache.nifi.controller.queue.DropFlowFileStatus;
|
import org.apache.nifi.controller.queue.DropFlowFileStatus;
|
||||||
import org.apache.nifi.controller.service.ControllerServiceNode;
|
import org.apache.nifi.controller.service.ControllerServiceNode;
|
||||||
|
import org.apache.nifi.flow.VersionedExternalFlow;
|
||||||
import org.apache.nifi.flowfile.FlowFile;
|
import org.apache.nifi.flowfile.FlowFile;
|
||||||
import org.apache.nifi.parameter.ParameterContext;
|
import org.apache.nifi.parameter.ParameterContext;
|
||||||
import org.apache.nifi.parameter.ParameterUpdate;
|
import org.apache.nifi.parameter.ParameterUpdate;
|
||||||
|
@ -40,7 +41,6 @@ import org.apache.nifi.processor.Processor;
|
||||||
import org.apache.nifi.registry.ComponentVariableRegistry;
|
import org.apache.nifi.registry.ComponentVariableRegistry;
|
||||||
import org.apache.nifi.registry.flow.FlowRegistryClient;
|
import org.apache.nifi.registry.flow.FlowRegistryClient;
|
||||||
import org.apache.nifi.registry.flow.VersionControlInformation;
|
import org.apache.nifi.registry.flow.VersionControlInformation;
|
||||||
import org.apache.nifi.registry.flow.VersionedFlowSnapshot;
|
|
||||||
import org.apache.nifi.registry.flow.mapping.FlowMappingOptions;
|
import org.apache.nifi.registry.flow.mapping.FlowMappingOptions;
|
||||||
import org.apache.nifi.remote.RemoteGroupPort;
|
import org.apache.nifi.remote.RemoteGroupPort;
|
||||||
|
|
||||||
|
@ -880,7 +880,7 @@ public interface ProcessGroup extends ComponentAuthorizable, Positionable, Versi
|
||||||
* @param updateDescendantVersionedFlows if a child/descendant Process Group is under Version Control, specifies whether or not to
|
* @param updateDescendantVersionedFlows if a child/descendant Process Group is under Version Control, specifies whether or not to
|
||||||
* update the contents of that Process Group
|
* update the contents of that Process Group
|
||||||
*/
|
*/
|
||||||
void updateFlow(VersionedFlowSnapshot proposedSnapshot, String componentIdSeed, boolean verifyNotDirty, boolean updateSettings, boolean updateDescendantVersionedFlows);
|
void updateFlow(VersionedExternalFlow proposedSnapshot, String componentIdSeed, boolean verifyNotDirty, boolean updateSettings, boolean updateDescendantVersionedFlows);
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Updates the Process Group to match the proposed flow
|
* Updates the Process Group to match the proposed flow
|
||||||
|
@ -889,7 +889,7 @@ public interface ProcessGroup extends ComponentAuthorizable, Positionable, Versi
|
||||||
* @param synchronizationOptions options for how the synchronization should occur
|
* @param synchronizationOptions options for how the synchronization should occur
|
||||||
* @param flowMappingOptions options for how to map the existing dataflow into Versioned components so that it can be compared to the proposed snapshot
|
* @param flowMappingOptions options for how to map the existing dataflow into Versioned components so that it can be compared to the proposed snapshot
|
||||||
*/
|
*/
|
||||||
void synchronizeFlow(VersionedFlowSnapshot proposedSnapshot, GroupSynchronizationOptions synchronizationOptions, FlowMappingOptions flowMappingOptions);
|
void synchronizeFlow(VersionedExternalFlow proposedSnapshot, GroupSynchronizationOptions synchronizationOptions, FlowMappingOptions flowMappingOptions);
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Verifies a template with the specified name can be created.
|
* Verifies a template with the specified name can be created.
|
||||||
|
@ -976,7 +976,7 @@ public interface ProcessGroup extends ComponentAuthorizable, Positionable, Versi
|
||||||
*
|
*
|
||||||
* @throws IllegalStateException if the Process Group is not in a state that will allow the update
|
* @throws IllegalStateException if the Process Group is not in a state that will allow the update
|
||||||
*/
|
*/
|
||||||
void verifyCanUpdate(VersionedFlowSnapshot updatedFlow, boolean verifyConnectionRemoval, boolean verifyNotDirty);
|
void verifyCanUpdate(VersionedExternalFlow updatedFlow, boolean verifyConnectionRemoval, boolean verifyNotDirty);
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Ensures that the Process Group can have any local changes reverted
|
* Ensures that the Process Group can have any local changes reverted
|
||||||
|
|
|
@ -18,6 +18,8 @@
|
||||||
package org.apache.nifi.registry.flow;
|
package org.apache.nifi.registry.flow;
|
||||||
|
|
||||||
import org.apache.nifi.authorization.user.NiFiUser;
|
import org.apache.nifi.authorization.user.NiFiUser;
|
||||||
|
import org.apache.nifi.flow.ExternalControllerServiceReference;
|
||||||
|
import org.apache.nifi.flow.VersionedParameterContext;
|
||||||
import org.apache.nifi.flow.VersionedProcessGroup;
|
import org.apache.nifi.flow.VersionedProcessGroup;
|
||||||
import org.apache.nifi.registry.bucket.Bucket;
|
import org.apache.nifi.registry.bucket.Bucket;
|
||||||
import org.apache.nifi.registry.client.NiFiRegistryException;
|
import org.apache.nifi.registry.client.NiFiRegistryException;
|
||||||
|
|
|
@ -36,7 +36,7 @@ import org.apache.nifi.nar.ExtensionManager;
|
||||||
import org.apache.nifi.parameter.ParameterContext;
|
import org.apache.nifi.parameter.ParameterContext;
|
||||||
import org.apache.nifi.registry.flow.FlowRegistry;
|
import org.apache.nifi.registry.flow.FlowRegistry;
|
||||||
import org.apache.nifi.registry.flow.FlowRegistryClient;
|
import org.apache.nifi.registry.flow.FlowRegistryClient;
|
||||||
import org.apache.nifi.registry.flow.VersionedParameterContext;
|
import org.apache.nifi.flow.VersionedParameterContext;
|
||||||
import org.apache.nifi.registry.flow.mapping.ComponentIdLookup;
|
import org.apache.nifi.registry.flow.mapping.ComponentIdLookup;
|
||||||
import org.apache.nifi.registry.flow.mapping.FlowMappingOptions;
|
import org.apache.nifi.registry.flow.mapping.FlowMappingOptions;
|
||||||
import org.apache.nifi.registry.flow.mapping.NiFiRegistryFlowMapper;
|
import org.apache.nifi.registry.flow.mapping.NiFiRegistryFlowMapper;
|
||||||
|
|
|
@ -52,6 +52,9 @@ import org.apache.nifi.encrypt.PropertyEncryptor;
|
||||||
import org.apache.nifi.flow.Bundle;
|
import org.apache.nifi.flow.Bundle;
|
||||||
import org.apache.nifi.flow.ScheduledState;
|
import org.apache.nifi.flow.ScheduledState;
|
||||||
import org.apache.nifi.flow.VersionedControllerService;
|
import org.apache.nifi.flow.VersionedControllerService;
|
||||||
|
import org.apache.nifi.flow.VersionedExternalFlow;
|
||||||
|
import org.apache.nifi.flow.VersionedParameter;
|
||||||
|
import org.apache.nifi.flow.VersionedParameterContext;
|
||||||
import org.apache.nifi.flow.VersionedProcessGroup;
|
import org.apache.nifi.flow.VersionedProcessGroup;
|
||||||
import org.apache.nifi.flow.VersionedProcessor;
|
import org.apache.nifi.flow.VersionedProcessor;
|
||||||
import org.apache.nifi.flow.VersionedReportingTask;
|
import org.apache.nifi.flow.VersionedReportingTask;
|
||||||
|
@ -69,9 +72,6 @@ import org.apache.nifi.parameter.ParameterDescriptor;
|
||||||
import org.apache.nifi.persistence.FlowConfigurationArchiveManager;
|
import org.apache.nifi.persistence.FlowConfigurationArchiveManager;
|
||||||
import org.apache.nifi.registry.flow.FlowRegistry;
|
import org.apache.nifi.registry.flow.FlowRegistry;
|
||||||
import org.apache.nifi.registry.flow.FlowRegistryClient;
|
import org.apache.nifi.registry.flow.FlowRegistryClient;
|
||||||
import org.apache.nifi.registry.flow.VersionedFlowSnapshot;
|
|
||||||
import org.apache.nifi.registry.flow.VersionedParameter;
|
|
||||||
import org.apache.nifi.registry.flow.VersionedParameterContext;
|
|
||||||
import org.apache.nifi.registry.flow.diff.ComparableDataFlow;
|
import org.apache.nifi.registry.flow.diff.ComparableDataFlow;
|
||||||
import org.apache.nifi.registry.flow.diff.DifferenceDescriptor;
|
import org.apache.nifi.registry.flow.diff.DifferenceDescriptor;
|
||||||
import org.apache.nifi.registry.flow.diff.FlowComparator;
|
import org.apache.nifi.registry.flow.diff.FlowComparator;
|
||||||
|
@ -298,9 +298,9 @@ public class VersionedFlowSynchronizer implements FlowSynchronizer {
|
||||||
final Map<String, VersionedParameterContext> versionedParameterContextMap = new HashMap<>();
|
final Map<String, VersionedParameterContext> versionedParameterContextMap = new HashMap<>();
|
||||||
versionedFlow.getParameterContexts().forEach(context -> versionedParameterContextMap.put(context.getName(), context));
|
versionedFlow.getParameterContexts().forEach(context -> versionedParameterContextMap.put(context.getName(), context));
|
||||||
|
|
||||||
final VersionedFlowSnapshot versionedFlowSnapshot = new VersionedFlowSnapshot();
|
final VersionedExternalFlow versionedExternalFlow = new VersionedExternalFlow();
|
||||||
versionedFlowSnapshot.setParameterContexts(versionedParameterContextMap);
|
versionedExternalFlow.setParameterContexts(versionedParameterContextMap);
|
||||||
versionedFlowSnapshot.setFlowContents(versionedFlow.getRootGroup());
|
versionedExternalFlow.setFlowContents(versionedFlow.getRootGroup());
|
||||||
|
|
||||||
// Inherit controller-level components.
|
// Inherit controller-level components.
|
||||||
inheritControllerServices(controller, versionedFlow, affectedComponentSet);
|
inheritControllerServices(controller, versionedFlow, affectedComponentSet);
|
||||||
|
@ -313,7 +313,7 @@ public class VersionedFlowSynchronizer implements FlowSynchronizer {
|
||||||
final ComponentScheduler componentScheduler = new FlowControllerComponentScheduler(controller);
|
final ComponentScheduler componentScheduler = new FlowControllerComponentScheduler(controller);
|
||||||
|
|
||||||
if (rootGroup.isEmpty()) {
|
if (rootGroup.isEmpty()) {
|
||||||
final VersionedProcessGroup versionedRoot = versionedFlowSnapshot.getFlowContents();
|
final VersionedProcessGroup versionedRoot = versionedExternalFlow.getFlowContents();
|
||||||
rootGroup = controller.getFlowManager().createProcessGroup(versionedRoot.getInstanceIdentifier());
|
rootGroup = controller.getFlowManager().createProcessGroup(versionedRoot.getInstanceIdentifier());
|
||||||
rootGroup.setComments(versionedRoot.getComments());
|
rootGroup.setComments(versionedRoot.getComments());
|
||||||
rootGroup.setPosition(new Position(versionedRoot.getPosition().getX(), versionedRoot.getPosition().getY()));
|
rootGroup.setPosition(new Position(versionedRoot.getPosition().getX(), versionedRoot.getPosition().getY()));
|
||||||
|
@ -350,7 +350,7 @@ public class VersionedFlowSynchronizer implements FlowSynchronizer {
|
||||||
.mapControllerServiceReferencesToVersionedId(false)
|
.mapControllerServiceReferencesToVersionedId(false)
|
||||||
.build();
|
.build();
|
||||||
|
|
||||||
rootGroup.synchronizeFlow(versionedFlowSnapshot, syncOptions, flowMappingOptions);
|
rootGroup.synchronizeFlow(versionedExternalFlow, syncOptions, flowMappingOptions);
|
||||||
|
|
||||||
// Inherit templates, now that all necessary Process Groups have been created
|
// Inherit templates, now that all necessary Process Groups have been created
|
||||||
inheritTemplates(controller, versionedFlow);
|
inheritTemplates(controller, versionedFlow);
|
||||||
|
|
|
@ -33,6 +33,7 @@ import org.apache.nifi.controller.flow.FlowManager;
|
||||||
import org.apache.nifi.controller.label.Label;
|
import org.apache.nifi.controller.label.Label;
|
||||||
import org.apache.nifi.controller.queue.DropFlowFileStatus;
|
import org.apache.nifi.controller.queue.DropFlowFileStatus;
|
||||||
import org.apache.nifi.controller.service.ControllerServiceNode;
|
import org.apache.nifi.controller.service.ControllerServiceNode;
|
||||||
|
import org.apache.nifi.flow.VersionedExternalFlow;
|
||||||
import org.apache.nifi.groups.BatchCounts;
|
import org.apache.nifi.groups.BatchCounts;
|
||||||
import org.apache.nifi.groups.DataValve;
|
import org.apache.nifi.groups.DataValve;
|
||||||
import org.apache.nifi.groups.FlowFileConcurrency;
|
import org.apache.nifi.groups.FlowFileConcurrency;
|
||||||
|
@ -48,7 +49,6 @@ import org.apache.nifi.parameter.ParameterUpdate;
|
||||||
import org.apache.nifi.registry.VariableRegistry;
|
import org.apache.nifi.registry.VariableRegistry;
|
||||||
import org.apache.nifi.registry.flow.FlowRegistryClient;
|
import org.apache.nifi.registry.flow.FlowRegistryClient;
|
||||||
import org.apache.nifi.registry.flow.VersionControlInformation;
|
import org.apache.nifi.registry.flow.VersionControlInformation;
|
||||||
import org.apache.nifi.registry.flow.VersionedFlowSnapshot;
|
|
||||||
import org.apache.nifi.registry.flow.mapping.FlowMappingOptions;
|
import org.apache.nifi.registry.flow.mapping.FlowMappingOptions;
|
||||||
import org.apache.nifi.registry.variable.MutableVariableRegistry;
|
import org.apache.nifi.registry.variable.MutableVariableRegistry;
|
||||||
import org.apache.nifi.remote.RemoteGroupPort;
|
import org.apache.nifi.remote.RemoteGroupPort;
|
||||||
|
@ -703,7 +703,7 @@ public class MockProcessGroup implements ProcessGroup {
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public void verifyCanUpdate(VersionedFlowSnapshot updatedFlow, boolean verifyConnectionRemoval, boolean verifyNotDirty) {
|
public void verifyCanUpdate(VersionedExternalFlow updatedFlow, boolean verifyConnectionRemoval, boolean verifyNotDirty) {
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
|
@ -715,11 +715,11 @@ public class MockProcessGroup implements ProcessGroup {
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public void updateFlow(VersionedFlowSnapshot proposedFlow, String componentIdSeed, boolean verifyNotDirty, boolean updateSettings, boolean updateDescendantVerisonedFlows) {
|
public void updateFlow(VersionedExternalFlow proposedFlow, String componentIdSeed, boolean verifyNotDirty, boolean updateSettings, boolean updateDescendantVerisonedFlows) {
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public void synchronizeFlow(final VersionedFlowSnapshot proposedSnapshot, final GroupSynchronizationOptions synchronizationOptions, final FlowMappingOptions flowMappingOptions) {
|
public void synchronizeFlow(final VersionedExternalFlow proposedSnapshot, final GroupSynchronizationOptions synchronizationOptions, final FlowMappingOptions flowMappingOptions) {
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
|
|
|
@ -19,13 +19,13 @@ package org.apache.nifi.integration;
|
||||||
import org.apache.nifi.authorization.user.NiFiUser;
|
import org.apache.nifi.authorization.user.NiFiUser;
|
||||||
import org.apache.nifi.registry.bucket.Bucket;
|
import org.apache.nifi.registry.bucket.Bucket;
|
||||||
import org.apache.nifi.registry.client.NiFiRegistryException;
|
import org.apache.nifi.registry.client.NiFiRegistryException;
|
||||||
import org.apache.nifi.registry.flow.ExternalControllerServiceReference;
|
import org.apache.nifi.flow.ExternalControllerServiceReference;
|
||||||
import org.apache.nifi.registry.flow.FlowRegistry;
|
import org.apache.nifi.registry.flow.FlowRegistry;
|
||||||
import org.apache.nifi.registry.flow.FlowRegistryClient;
|
import org.apache.nifi.registry.flow.FlowRegistryClient;
|
||||||
import org.apache.nifi.registry.flow.VersionedFlow;
|
import org.apache.nifi.registry.flow.VersionedFlow;
|
||||||
import org.apache.nifi.registry.flow.VersionedFlowSnapshot;
|
import org.apache.nifi.registry.flow.VersionedFlowSnapshot;
|
||||||
import org.apache.nifi.registry.flow.VersionedFlowSnapshotMetadata;
|
import org.apache.nifi.registry.flow.VersionedFlowSnapshotMetadata;
|
||||||
import org.apache.nifi.registry.flow.VersionedParameterContext;
|
import org.apache.nifi.flow.VersionedParameterContext;
|
||||||
import org.apache.nifi.flow.VersionedProcessGroup;
|
import org.apache.nifi.flow.VersionedProcessGroup;
|
||||||
|
|
||||||
import java.io.IOException;
|
import java.io.IOException;
|
||||||
|
|
|
@ -26,9 +26,17 @@ import org.apache.nifi.controller.ControllerService;
|
||||||
import org.apache.nifi.controller.ProcessorNode;
|
import org.apache.nifi.controller.ProcessorNode;
|
||||||
import org.apache.nifi.controller.StandardSnippet;
|
import org.apache.nifi.controller.StandardSnippet;
|
||||||
import org.apache.nifi.controller.service.ControllerServiceNode;
|
import org.apache.nifi.controller.service.ControllerServiceNode;
|
||||||
|
import org.apache.nifi.flow.Bundle;
|
||||||
import org.apache.nifi.flow.VersionedConnection;
|
import org.apache.nifi.flow.VersionedConnection;
|
||||||
|
import org.apache.nifi.flow.VersionedControllerService;
|
||||||
|
import org.apache.nifi.flow.VersionedExternalFlow;
|
||||||
|
import org.apache.nifi.flow.VersionedExternalFlowMetadata;
|
||||||
import org.apache.nifi.flow.VersionedFunnel;
|
import org.apache.nifi.flow.VersionedFunnel;
|
||||||
|
import org.apache.nifi.flow.VersionedParameter;
|
||||||
|
import org.apache.nifi.flow.VersionedParameterContext;
|
||||||
import org.apache.nifi.flow.VersionedPort;
|
import org.apache.nifi.flow.VersionedPort;
|
||||||
|
import org.apache.nifi.flow.VersionedProcessGroup;
|
||||||
|
import org.apache.nifi.flow.VersionedProcessor;
|
||||||
import org.apache.nifi.groups.ProcessGroup;
|
import org.apache.nifi.groups.ProcessGroup;
|
||||||
import org.apache.nifi.integration.DirectInjectionExtensionManager;
|
import org.apache.nifi.integration.DirectInjectionExtensionManager;
|
||||||
import org.apache.nifi.integration.FrameworkIntegrationTest;
|
import org.apache.nifi.integration.FrameworkIntegrationTest;
|
||||||
|
@ -44,15 +52,7 @@ import org.apache.nifi.parameter.StandardParameterContext;
|
||||||
import org.apache.nifi.parameter.StandardParameterReferenceManager;
|
import org.apache.nifi.parameter.StandardParameterReferenceManager;
|
||||||
import org.apache.nifi.processor.Processor;
|
import org.apache.nifi.processor.Processor;
|
||||||
import org.apache.nifi.registry.bucket.Bucket;
|
import org.apache.nifi.registry.bucket.Bucket;
|
||||||
import org.apache.nifi.flow.Bundle;
|
|
||||||
import org.apache.nifi.flow.VersionedControllerService;
|
|
||||||
import org.apache.nifi.registry.flow.VersionedFlow;
|
import org.apache.nifi.registry.flow.VersionedFlow;
|
||||||
import org.apache.nifi.registry.flow.VersionedFlowSnapshot;
|
|
||||||
import org.apache.nifi.registry.flow.VersionedFlowSnapshotMetadata;
|
|
||||||
import org.apache.nifi.registry.flow.VersionedParameter;
|
|
||||||
import org.apache.nifi.registry.flow.VersionedParameterContext;
|
|
||||||
import org.apache.nifi.flow.VersionedProcessGroup;
|
|
||||||
import org.apache.nifi.flow.VersionedProcessor;
|
|
||||||
import org.apache.nifi.registry.flow.diff.ComparableDataFlow;
|
import org.apache.nifi.registry.flow.diff.ComparableDataFlow;
|
||||||
import org.apache.nifi.registry.flow.diff.ConciseEvolvingDifferenceDescriptor;
|
import org.apache.nifi.registry.flow.diff.ConciseEvolvingDifferenceDescriptor;
|
||||||
import org.apache.nifi.registry.flow.diff.DifferenceType;
|
import org.apache.nifi.registry.flow.diff.DifferenceType;
|
||||||
|
@ -103,7 +103,7 @@ public class ImportFlowIT extends FrameworkIntegrationTest {
|
||||||
processor.setAutoTerminatedRelationships(Collections.singleton(REL_SUCCESS));
|
processor.setAutoTerminatedRelationships(Collections.singleton(REL_SUCCESS));
|
||||||
processor.setProperties(Collections.singletonMap(NopServiceReferencingProcessor.SERVICE.getName(), controllerService.getIdentifier()));
|
processor.setProperties(Collections.singletonMap(NopServiceReferencingProcessor.SERVICE.getName(), controllerService.getIdentifier()));
|
||||||
|
|
||||||
final VersionedFlowSnapshot proposedFlow = createFlowSnapshot(Collections.singletonList(controllerService), Collections.singletonList(processor), null);
|
final VersionedExternalFlow proposedFlow = createFlowSnapshot(Collections.singletonList(controllerService), Collections.singletonList(processor), null);
|
||||||
|
|
||||||
// Create an Inner Process Group and update it to match the Versioned Flow.
|
// Create an Inner Process Group and update it to match the Versioned Flow.
|
||||||
final ProcessGroup innerGroup = getFlowController().getFlowManager().createProcessGroup("inner-group-id");
|
final ProcessGroup innerGroup = getFlowController().getFlowManager().createProcessGroup("inner-group-id");
|
||||||
|
@ -146,8 +146,8 @@ public class ImportFlowIT extends FrameworkIntegrationTest {
|
||||||
final ProcessorNode processor = createProcessorNode(UsernamePasswordProcessor.class);
|
final ProcessorNode processor = createProcessorNode(UsernamePasswordProcessor.class);
|
||||||
processor.setProperties(Collections.singletonMap(UsernamePasswordProcessor.PASSWORD.getName(), "password"));
|
processor.setProperties(Collections.singletonMap(UsernamePasswordProcessor.PASSWORD.getName(), "password"));
|
||||||
|
|
||||||
// Create a VersionedFlowSnapshot that contains the processor
|
// Create a VersionedExternalFlow that contains the processor
|
||||||
final VersionedFlowSnapshot versionedFlowWithExplicitValue = createFlowSnapshot(Collections.emptyList(), Collections.singletonList(processor), null);
|
final VersionedExternalFlow versionedFlowWithExplicitValue = createFlowSnapshot(Collections.emptyList(), Collections.singletonList(processor), null);
|
||||||
|
|
||||||
// Create child group
|
// Create child group
|
||||||
final ProcessGroup innerGroup = getFlowController().getFlowManager().createProcessGroup("inner-group-id");
|
final ProcessGroup innerGroup = getFlowController().getFlowManager().createProcessGroup("inner-group-id");
|
||||||
|
@ -173,7 +173,7 @@ public class ImportFlowIT extends FrameworkIntegrationTest {
|
||||||
assertEquals(DifferenceType.PROPERTY_PARAMETERIZED, differences.iterator().next().getDifferenceType());
|
assertEquals(DifferenceType.PROPERTY_PARAMETERIZED, differences.iterator().next().getDifferenceType());
|
||||||
|
|
||||||
// Create a Versioned Flow that contains the Parameter Reference.
|
// Create a Versioned Flow that contains the Parameter Reference.
|
||||||
final VersionedFlowSnapshot versionedFlowWithParameterReference = createFlowSnapshot(Collections.emptyList(), Collections.singletonList(processor), null);
|
final VersionedExternalFlow versionedFlowWithParameterReference = createFlowSnapshot(Collections.emptyList(), Collections.singletonList(processor), null);
|
||||||
|
|
||||||
// Ensure no difference between the current configuration and the versioned flow
|
// Ensure no difference between the current configuration and the versioned flow
|
||||||
differences = getLocalModifications(innerGroup, versionedFlowWithParameterReference);
|
differences = getLocalModifications(innerGroup, versionedFlowWithParameterReference);
|
||||||
|
@ -191,9 +191,9 @@ public class ImportFlowIT extends FrameworkIntegrationTest {
|
||||||
final ProcessorNode processor = createProcessorNode(UsernamePasswordProcessor.class);
|
final ProcessorNode processor = createProcessorNode(UsernamePasswordProcessor.class);
|
||||||
processor.setProperties(Collections.singletonMap(UsernamePasswordProcessor.PASSWORD.getName(), "#{secret-param}"));
|
processor.setProperties(Collections.singletonMap(UsernamePasswordProcessor.PASSWORD.getName(), "#{secret-param}"));
|
||||||
|
|
||||||
// Create a VersionedFlowSnapshot that contains the processor
|
// Create a VersionedExternalFlow that contains the processor
|
||||||
final Parameter parameter = new Parameter(new ParameterDescriptor.Builder().name("secret-param").sensitive(true).build(), null);
|
final Parameter parameter = new Parameter(new ParameterDescriptor.Builder().name("secret-param").sensitive(true).build(), null);
|
||||||
final VersionedFlowSnapshot versionedFlowWithParameterReference = createFlowSnapshot(Collections.emptyList(), Collections.singletonList(processor), Collections.singleton(parameter));
|
final VersionedExternalFlow versionedFlowWithParameterReference = createFlowSnapshot(Collections.emptyList(), Collections.singletonList(processor), Collections.singleton(parameter));
|
||||||
|
|
||||||
// Create child group
|
// Create child group
|
||||||
final ProcessGroup innerGroup = getFlowController().getFlowManager().createProcessGroup("inner-group-id");
|
final ProcessGroup innerGroup = getFlowController().getFlowManager().createProcessGroup("inner-group-id");
|
||||||
|
@ -223,9 +223,9 @@ public class ImportFlowIT extends FrameworkIntegrationTest {
|
||||||
final ProcessorNode processor = createProcessorNode(UsernamePasswordProcessor.class);
|
final ProcessorNode processor = createProcessorNode(UsernamePasswordProcessor.class);
|
||||||
processor.setProperties(Collections.singletonMap(UsernamePasswordProcessor.PASSWORD.getName(), "#{secret-param}"));
|
processor.setProperties(Collections.singletonMap(UsernamePasswordProcessor.PASSWORD.getName(), "#{secret-param}"));
|
||||||
|
|
||||||
// Create a VersionedFlowSnapshot that contains the processor
|
// Create a VersionedExternalFlow that contains the processor
|
||||||
final Parameter parameter = new Parameter(new ParameterDescriptor.Builder().name("secret-param").sensitive(true).build(), null);
|
final Parameter parameter = new Parameter(new ParameterDescriptor.Builder().name("secret-param").sensitive(true).build(), null);
|
||||||
final VersionedFlowSnapshot versionedFlowWithParameterReference = createFlowSnapshot(Collections.emptyList(), Collections.singletonList(processor), Collections.singleton(parameter));
|
final VersionedExternalFlow versionedFlowWithParameterReference = createFlowSnapshot(Collections.emptyList(), Collections.singletonList(processor), Collections.singleton(parameter));
|
||||||
|
|
||||||
// Create child group
|
// Create child group
|
||||||
final ProcessGroup innerGroup = getFlowController().getFlowManager().createProcessGroup("inner-group-id");
|
final ProcessGroup innerGroup = getFlowController().getFlowManager().createProcessGroup("inner-group-id");
|
||||||
|
@ -253,15 +253,15 @@ public class ImportFlowIT extends FrameworkIntegrationTest {
|
||||||
final ProcessorNode initialProcessor = createProcessorNode(UsernamePasswordProcessor.class);
|
final ProcessorNode initialProcessor = createProcessorNode(UsernamePasswordProcessor.class);
|
||||||
initialProcessor.setProperties(Collections.singletonMap(UsernamePasswordProcessor.PASSWORD.getName(), "#{secret-param}"));
|
initialProcessor.setProperties(Collections.singletonMap(UsernamePasswordProcessor.PASSWORD.getName(), "#{secret-param}"));
|
||||||
|
|
||||||
// Create a VersionedFlowSnapshot that contains the processor
|
// Create a VersionedExternalFlow that contains the processor
|
||||||
final Parameter parameter = new Parameter(new ParameterDescriptor.Builder().name("secret-param").sensitive(true).build(), null);
|
final Parameter parameter = new Parameter(new ParameterDescriptor.Builder().name("secret-param").sensitive(true).build(), null);
|
||||||
final VersionedFlowSnapshot versionedFlowWithParameterReference = createFlowSnapshot(Collections.emptyList(),
|
final VersionedExternalFlow versionedFlowWithParameterReference = createFlowSnapshot(Collections.emptyList(),
|
||||||
Collections.singletonList(initialProcessor), Collections.singleton(parameter));
|
Collections.singletonList(initialProcessor), Collections.singleton(parameter));
|
||||||
|
|
||||||
|
|
||||||
// Update processor to have an explicit value for the second version of the flow.
|
// Update processor to have an explicit value for the second version of the flow.
|
||||||
initialProcessor.setProperties(Collections.singletonMap(UsernamePasswordProcessor.PASSWORD.getName(), "secret-value"));
|
initialProcessor.setProperties(Collections.singletonMap(UsernamePasswordProcessor.PASSWORD.getName(), "secret-value"));
|
||||||
final VersionedFlowSnapshot versionedFlowExplicitValue = createFlowSnapshot(Collections.emptyList(), Collections.singletonList(initialProcessor), null);
|
final VersionedExternalFlow versionedFlowExplicitValue = createFlowSnapshot(Collections.emptyList(), Collections.singletonList(initialProcessor), null);
|
||||||
|
|
||||||
// Create child group and update to the first version of the flow, with parameter ref
|
// Create child group and update to the first version of the flow, with parameter ref
|
||||||
final ProcessGroup innerGroup = getFlowController().getFlowManager().createProcessGroup("inner-group-id");
|
final ProcessGroup innerGroup = getFlowController().getFlowManager().createProcessGroup("inner-group-id");
|
||||||
|
@ -290,7 +290,7 @@ public class ImportFlowIT extends FrameworkIntegrationTest {
|
||||||
initialProperties.put(UsernamePasswordProcessor.PASSWORD.getName(), "pass");
|
initialProperties.put(UsernamePasswordProcessor.PASSWORD.getName(), "pass");
|
||||||
initialProcessor.setProperties(initialProperties);
|
initialProcessor.setProperties(initialProperties);
|
||||||
|
|
||||||
final VersionedFlowSnapshot initialVersionSnapshot = createFlowSnapshot(Collections.emptyList(), Collections.singletonList(initialProcessor), null);
|
final VersionedExternalFlow initialVersionSnapshot = createFlowSnapshot(Collections.emptyList(), Collections.singletonList(initialProcessor), null);
|
||||||
|
|
||||||
// Update processor to have a different explicit value for both sensitive and non-sensitive properties and create a versioned flow for it.
|
// Update processor to have a different explicit value for both sensitive and non-sensitive properties and create a versioned flow for it.
|
||||||
final Map<String, String> updatedProperties = new HashMap<>();
|
final Map<String, String> updatedProperties = new HashMap<>();
|
||||||
|
@ -298,7 +298,7 @@ public class ImportFlowIT extends FrameworkIntegrationTest {
|
||||||
updatedProperties.put(UsernamePasswordProcessor.PASSWORD.getName(), "pass");
|
updatedProperties.put(UsernamePasswordProcessor.PASSWORD.getName(), "pass");
|
||||||
initialProcessor.setProperties(updatedProperties);
|
initialProcessor.setProperties(updatedProperties);
|
||||||
|
|
||||||
final VersionedFlowSnapshot updatedVersionSnapshot = createFlowSnapshot(Collections.emptyList(), Collections.singletonList(initialProcessor), null);
|
final VersionedExternalFlow updatedVersionSnapshot = createFlowSnapshot(Collections.emptyList(), Collections.singletonList(initialProcessor), null);
|
||||||
|
|
||||||
// Create child group and update to the first version of the flow, with parameter ref
|
// Create child group and update to the first version of the flow, with parameter ref
|
||||||
final ProcessGroup innerGroup = getFlowController().getFlowManager().createProcessGroup("inner-group-id");
|
final ProcessGroup innerGroup = getFlowController().getFlowManager().createProcessGroup("inner-group-id");
|
||||||
|
@ -335,7 +335,7 @@ public class ImportFlowIT extends FrameworkIntegrationTest {
|
||||||
initialProperties.put(UsernamePasswordProcessor.PASSWORD.getName(), "#{secret-param}");
|
initialProperties.put(UsernamePasswordProcessor.PASSWORD.getName(), "#{secret-param}");
|
||||||
initialProcessor.setProperties(initialProperties);
|
initialProcessor.setProperties(initialProperties);
|
||||||
|
|
||||||
final VersionedFlowSnapshot initialVersionSnapshot = createFlowSnapshot(Collections.emptyList(), Collections.singletonList(initialProcessor), null);
|
final VersionedExternalFlow initialVersionSnapshot = createFlowSnapshot(Collections.emptyList(), Collections.singletonList(initialProcessor), null);
|
||||||
|
|
||||||
// Update processor to have a different explicit value for both sensitive and non-sensitive properties and create a versioned flow for it.
|
// Update processor to have a different explicit value for both sensitive and non-sensitive properties and create a versioned flow for it.
|
||||||
final Map<String, String> updatedProperties = new HashMap<>();
|
final Map<String, String> updatedProperties = new HashMap<>();
|
||||||
|
@ -343,7 +343,7 @@ public class ImportFlowIT extends FrameworkIntegrationTest {
|
||||||
updatedProperties.put(UsernamePasswordProcessor.PASSWORD.getName(), "#{other-param}");
|
updatedProperties.put(UsernamePasswordProcessor.PASSWORD.getName(), "#{other-param}");
|
||||||
initialProcessor.setProperties(updatedProperties);
|
initialProcessor.setProperties(updatedProperties);
|
||||||
|
|
||||||
final VersionedFlowSnapshot updatedVersionSnapshot = createFlowSnapshot(Collections.emptyList(), Collections.singletonList(initialProcessor), null);
|
final VersionedExternalFlow updatedVersionSnapshot = createFlowSnapshot(Collections.emptyList(), Collections.singletonList(initialProcessor), null);
|
||||||
|
|
||||||
// Create child group and update to the first version of the flow, with parameter ref
|
// Create child group and update to the first version of the flow, with parameter ref
|
||||||
final ProcessGroup innerGroup = getFlowController().getFlowManager().createProcessGroup("inner-group-id");
|
final ProcessGroup innerGroup = getFlowController().getFlowManager().createProcessGroup("inner-group-id");
|
||||||
|
@ -369,12 +369,12 @@ public class ImportFlowIT extends FrameworkIntegrationTest {
|
||||||
processorWithExplicitValue.setProperties(Collections.singletonMap(UsernamePasswordProcessor.PASSWORD.getName(), "secret-value"));
|
processorWithExplicitValue.setProperties(Collections.singletonMap(UsernamePasswordProcessor.PASSWORD.getName(), "secret-value"));
|
||||||
|
|
||||||
|
|
||||||
// Create a VersionedFlowSnapshot that contains the processor
|
// Create a VersionedExternalFlow that contains the processor
|
||||||
final Parameter parameter = new Parameter(new ParameterDescriptor.Builder().name("secret-param").sensitive(true).build(), null);
|
final Parameter parameter = new Parameter(new ParameterDescriptor.Builder().name("secret-param").sensitive(true).build(), null);
|
||||||
final VersionedFlowSnapshot versionedFlowWithParameterReference = createFlowSnapshot(Collections.emptyList(),
|
final VersionedExternalFlow versionedFlowWithParameterReference = createFlowSnapshot(Collections.emptyList(),
|
||||||
Collections.singletonList(processorWithParamRef), Collections.singleton(parameter));
|
Collections.singletonList(processorWithParamRef), Collections.singleton(parameter));
|
||||||
|
|
||||||
final VersionedFlowSnapshot versionedFlowExplicitValue = createFlowSnapshot(Collections.emptyList(), Collections.singletonList(processorWithExplicitValue), null);
|
final VersionedExternalFlow versionedFlowExplicitValue = createFlowSnapshot(Collections.emptyList(), Collections.singletonList(processorWithExplicitValue), null);
|
||||||
|
|
||||||
// Create child group and update to the first version of the flow, with parameter ref
|
// Create child group and update to the first version of the flow, with parameter ref
|
||||||
final ProcessGroup innerGroup = getFlowController().getFlowManager().createProcessGroup("inner-group-id");
|
final ProcessGroup innerGroup = getFlowController().getFlowManager().createProcessGroup("inner-group-id");
|
||||||
|
@ -406,7 +406,7 @@ public class ImportFlowIT extends FrameworkIntegrationTest {
|
||||||
groupA.addInputPort(port);
|
groupA.addInputPort(port);
|
||||||
|
|
||||||
//Create a snapshot
|
//Create a snapshot
|
||||||
final VersionedFlowSnapshot version1 = createFlowSnapshot(groupA);
|
final VersionedExternalFlow version1 = createFlowSnapshot(groupA);
|
||||||
|
|
||||||
//Create Process Group B under Process Group A
|
//Create Process Group B under Process Group A
|
||||||
final ProcessGroup groupB = createProcessGroup("group-b-id", "Group B", groupA);
|
final ProcessGroup groupB = createProcessGroup("group-b-id", "Group B", groupA);
|
||||||
|
@ -421,7 +421,7 @@ public class ImportFlowIT extends FrameworkIntegrationTest {
|
||||||
final Connection connection = connect(groupA, processor, port, processor.getRelationships());
|
final Connection connection = connect(groupA, processor, port, processor.getRelationships());
|
||||||
|
|
||||||
//Create another snapshot
|
//Create another snapshot
|
||||||
final VersionedFlowSnapshot version2 = createFlowSnapshot(groupA);
|
final VersionedExternalFlow version2 = createFlowSnapshot(groupA);
|
||||||
|
|
||||||
//Change Process Group A version to Version 1
|
//Change Process Group A version to Version 1
|
||||||
groupA.updateFlow(version1, null, false, true, true);
|
groupA.updateFlow(version1, null, false, true, true);
|
||||||
|
@ -463,7 +463,7 @@ public class ImportFlowIT extends FrameworkIntegrationTest {
|
||||||
final Connection connection = connect(group, processor, port, processor.getRelationships());
|
final Connection connection = connect(group, processor, port, processor.getRelationships());
|
||||||
|
|
||||||
//Create a snapshot
|
//Create a snapshot
|
||||||
final VersionedFlowSnapshot version1 = createFlowSnapshot(group);
|
final VersionedExternalFlow version1 = createFlowSnapshot(group);
|
||||||
|
|
||||||
//Create Funnel under Process Group
|
//Create Funnel under Process Group
|
||||||
Funnel funnel = getFlowController().getFlowManager().createFunnel("funnel-id");
|
Funnel funnel = getFlowController().getFlowManager().createFunnel("funnel-id");
|
||||||
|
@ -476,7 +476,7 @@ public class ImportFlowIT extends FrameworkIntegrationTest {
|
||||||
group.removeOutputPort(port);
|
group.removeOutputPort(port);
|
||||||
|
|
||||||
//Create another snapshot
|
//Create another snapshot
|
||||||
final VersionedFlowSnapshot version2 = createFlowSnapshot(group);
|
final VersionedExternalFlow version2 = createFlowSnapshot(group);
|
||||||
|
|
||||||
//Change Process Group version to Version 1
|
//Change Process Group version to Version 1
|
||||||
group.updateFlow(version1, null, false, true, true);
|
group.updateFlow(version1, null, false, true, true);
|
||||||
|
@ -534,7 +534,7 @@ public class ImportFlowIT extends FrameworkIntegrationTest {
|
||||||
final Connection connection2 = connect(groupA, processor1, inputPort, processor1.getRelationships());
|
final Connection connection2 = connect(groupA, processor1, inputPort, processor1.getRelationships());
|
||||||
|
|
||||||
//Create a snapshot
|
//Create a snapshot
|
||||||
final VersionedFlowSnapshot version1 = createFlowSnapshot(groupA);
|
final VersionedExternalFlow version1 = createFlowSnapshot(groupA);
|
||||||
|
|
||||||
//Modify Connection 1 to point to Processor 2
|
//Modify Connection 1 to point to Processor 2
|
||||||
connection1.setDestination(processor2);
|
connection1.setDestination(processor2);
|
||||||
|
@ -543,7 +543,7 @@ public class ImportFlowIT extends FrameworkIntegrationTest {
|
||||||
moveOutputPort(outputPort, groupB);
|
moveOutputPort(outputPort, groupB);
|
||||||
|
|
||||||
//Create another snapshot
|
//Create another snapshot
|
||||||
final VersionedFlowSnapshot version2 = createFlowSnapshot(groupA);
|
final VersionedExternalFlow version2 = createFlowSnapshot(groupA);
|
||||||
|
|
||||||
//Delete connection 2
|
//Delete connection 2
|
||||||
groupA.removeConnection(connection2);
|
groupA.removeConnection(connection2);
|
||||||
|
@ -552,7 +552,7 @@ public class ImportFlowIT extends FrameworkIntegrationTest {
|
||||||
groupB.removeInputPort(inputPort);
|
groupB.removeInputPort(inputPort);
|
||||||
|
|
||||||
//Create another snapshot
|
//Create another snapshot
|
||||||
final VersionedFlowSnapshot version3 = createFlowSnapshot(groupA);
|
final VersionedExternalFlow version3 = createFlowSnapshot(groupA);
|
||||||
|
|
||||||
//Change Process Group version to Version 1
|
//Change Process Group version to Version 1
|
||||||
groupA.updateFlow(version1, null, false, true, true);
|
groupA.updateFlow(version1, null, false, true, true);
|
||||||
|
@ -612,7 +612,7 @@ public class ImportFlowIT extends FrameworkIntegrationTest {
|
||||||
final Connection connection2 = connect(groupA, processor1, inputPort, processor1.getRelationships());
|
final Connection connection2 = connect(groupA, processor1, inputPort, processor1.getRelationships());
|
||||||
|
|
||||||
//Create a snapshot
|
//Create a snapshot
|
||||||
final VersionedFlowSnapshot version1 = createFlowSnapshot(groupA);
|
final VersionedExternalFlow version1 = createFlowSnapshot(groupA);
|
||||||
|
|
||||||
//Modify Connection 1 to point to Processor 2
|
//Modify Connection 1 to point to Processor 2
|
||||||
connection1.setDestination(processor2);
|
connection1.setDestination(processor2);
|
||||||
|
@ -621,7 +621,7 @@ public class ImportFlowIT extends FrameworkIntegrationTest {
|
||||||
groupA.removeOutputPort(outputPort);
|
groupA.removeOutputPort(outputPort);
|
||||||
|
|
||||||
//Create another snapshot
|
//Create another snapshot
|
||||||
final VersionedFlowSnapshot version2 = createFlowSnapshot(groupA);
|
final VersionedExternalFlow version2 = createFlowSnapshot(groupA);
|
||||||
|
|
||||||
//Delete connection 2
|
//Delete connection 2
|
||||||
groupA.removeConnection(connection2);
|
groupA.removeConnection(connection2);
|
||||||
|
@ -630,7 +630,7 @@ public class ImportFlowIT extends FrameworkIntegrationTest {
|
||||||
moveInputPort(inputPort, groupA);
|
moveInputPort(inputPort, groupA);
|
||||||
|
|
||||||
//Create another snapshot
|
//Create another snapshot
|
||||||
final VersionedFlowSnapshot version3 = createFlowSnapshot(groupA);
|
final VersionedExternalFlow version3 = createFlowSnapshot(groupA);
|
||||||
|
|
||||||
//Change Process Group version to Version 1
|
//Change Process Group version to Version 1
|
||||||
groupA.updateFlow(version1, null, false, true, true);
|
groupA.updateFlow(version1, null, false, true, true);
|
||||||
|
@ -686,10 +686,10 @@ public class ImportFlowIT extends FrameworkIntegrationTest {
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
private Set<FlowDifference> getLocalModifications(final ProcessGroup processGroup, final VersionedFlowSnapshot versionedFlowSnapshot) {
|
private Set<FlowDifference> getLocalModifications(final ProcessGroup processGroup, final VersionedExternalFlow VersionedExternalFlow) {
|
||||||
final NiFiRegistryFlowMapper mapper = new NiFiRegistryFlowMapper(getFlowController().getExtensionManager());
|
final NiFiRegistryFlowMapper mapper = new NiFiRegistryFlowMapper(getFlowController().getExtensionManager());
|
||||||
final VersionedProcessGroup localGroup = mapper.mapProcessGroup(processGroup, getFlowController().getControllerServiceProvider(), getFlowController().getFlowRegistryClient(), true);
|
final VersionedProcessGroup localGroup = mapper.mapProcessGroup(processGroup, getFlowController().getControllerServiceProvider(), getFlowController().getFlowRegistryClient(), true);
|
||||||
final VersionedProcessGroup registryGroup = versionedFlowSnapshot.getFlowContents();
|
final VersionedProcessGroup registryGroup = VersionedExternalFlow.getFlowContents();
|
||||||
|
|
||||||
final ComparableDataFlow localFlow = new StandardComparableDataFlow("Local Flow", localGroup);
|
final ComparableDataFlow localFlow = new StandardComparableDataFlow("Local Flow", localGroup);
|
||||||
final ComparableDataFlow registryFlow = new StandardComparableDataFlow("Versioned Flow", registryGroup);
|
final ComparableDataFlow registryFlow = new StandardComparableDataFlow("Versioned Flow", registryGroup);
|
||||||
|
@ -707,14 +707,8 @@ public class ImportFlowIT extends FrameworkIntegrationTest {
|
||||||
return differences;
|
return differences;
|
||||||
}
|
}
|
||||||
|
|
||||||
private VersionedFlowSnapshot createFlowSnapshot(final ProcessGroup group, final List<ControllerServiceNode> controllerServices,
|
private VersionedExternalFlow createFlowSnapshot(final ProcessGroup group, final List<ControllerServiceNode> controllerServices,
|
||||||
final List<ProcessorNode> processors, final Set<Parameter> parameters) {
|
final List<ProcessorNode> processors, final Set<Parameter> parameters) {
|
||||||
final VersionedFlowSnapshotMetadata snapshotMetadata = createSnapshotMetadata();
|
|
||||||
|
|
||||||
final Bucket bucket = createBucket();
|
|
||||||
|
|
||||||
final VersionedFlow flow = createVersionedFlow();
|
|
||||||
|
|
||||||
createBundle();
|
createBundle();
|
||||||
|
|
||||||
final NiFiRegistryFlowMapper flowMapper = new NiFiRegistryFlowMapper(getExtensionManager());
|
final NiFiRegistryFlowMapper flowMapper = new NiFiRegistryFlowMapper(getExtensionManager());
|
||||||
|
@ -804,7 +798,14 @@ public class ImportFlowIT extends FrameworkIntegrationTest {
|
||||||
flowContents.setFunnels(versionedFunnels);
|
flowContents.setFunnels(versionedFunnels);
|
||||||
flowContents.setConnections(versionedConnections);
|
flowContents.setConnections(versionedConnections);
|
||||||
|
|
||||||
final VersionedFlowSnapshot versionedFlowSnapshot = createVersionedFlowSnapshot(snapshotMetadata, bucket, flow, flowContents);
|
final VersionedExternalFlow externalFlow = new VersionedExternalFlow();
|
||||||
|
|
||||||
|
final VersionedExternalFlowMetadata metadata = new VersionedExternalFlowMetadata();
|
||||||
|
externalFlow.setMetadata(metadata);
|
||||||
|
metadata.setBucketIdentifier("unit-test-bucket");
|
||||||
|
metadata.setFlowIdentifier("unit-test-flow");
|
||||||
|
metadata.setVersion(1);
|
||||||
|
metadata.setFlowName("unit-test-flow");
|
||||||
|
|
||||||
if (parameters != null) {
|
if (parameters != null) {
|
||||||
final Set<VersionedParameter> versionedParameters = new HashSet<>();
|
final Set<VersionedParameter> versionedParameters = new HashSet<>();
|
||||||
|
@ -820,31 +821,22 @@ public class ImportFlowIT extends FrameworkIntegrationTest {
|
||||||
final VersionedParameterContext versionedParameterContext = new VersionedParameterContext();
|
final VersionedParameterContext versionedParameterContext = new VersionedParameterContext();
|
||||||
versionedParameterContext.setName("Unit Test Context");
|
versionedParameterContext.setName("Unit Test Context");
|
||||||
versionedParameterContext.setParameters(versionedParameters);
|
versionedParameterContext.setParameters(versionedParameters);
|
||||||
versionedFlowSnapshot.setParameterContexts(Collections.singletonMap(versionedParameterContext.getName(), versionedParameterContext));
|
externalFlow.setParameterContexts(Collections.singletonMap(versionedParameterContext.getName(), versionedParameterContext));
|
||||||
|
|
||||||
flowContents.setParameterContextName("Unit Test Context");
|
flowContents.setParameterContextName("Unit Test Context");
|
||||||
}
|
}
|
||||||
|
|
||||||
return versionedFlowSnapshot;
|
return externalFlow;
|
||||||
}
|
}
|
||||||
|
|
||||||
private VersionedFlowSnapshot createFlowSnapshot(final List<ControllerServiceNode> controllerServices, final List<ProcessorNode> processors, final Set<Parameter> parameters) {
|
private VersionedExternalFlow createFlowSnapshot(final List<ControllerServiceNode> controllerServices, final List<ProcessorNode> processors, final Set<Parameter> parameters) {
|
||||||
return createFlowSnapshot(null, controllerServices, processors, parameters);
|
return createFlowSnapshot(null, controllerServices, processors, parameters);
|
||||||
}
|
}
|
||||||
|
|
||||||
private VersionedFlowSnapshot createFlowSnapshot(final ProcessGroup group) {
|
private VersionedExternalFlow createFlowSnapshot(final ProcessGroup group) {
|
||||||
return createFlowSnapshot(group, Collections.EMPTY_LIST, Collections.EMPTY_LIST, null);
|
return createFlowSnapshot(group, Collections.emptyList(), Collections.emptyList(), null);
|
||||||
}
|
}
|
||||||
|
|
||||||
@NotNull
|
|
||||||
private VersionedFlowSnapshot createVersionedFlowSnapshot(VersionedFlowSnapshotMetadata snapshotMetadata, Bucket bucket, VersionedFlow flow, VersionedProcessGroup flowContents) {
|
|
||||||
final VersionedFlowSnapshot versionedFlowSnapshot = new VersionedFlowSnapshot();
|
|
||||||
versionedFlowSnapshot.setSnapshotMetadata(snapshotMetadata);
|
|
||||||
versionedFlowSnapshot.setBucket(bucket);
|
|
||||||
versionedFlowSnapshot.setFlow(flow);
|
|
||||||
versionedFlowSnapshot.setFlowContents(flowContents);
|
|
||||||
return versionedFlowSnapshot;
|
|
||||||
}
|
|
||||||
|
|
||||||
@NotNull
|
@NotNull
|
||||||
private VersionedProcessGroup createFlowContents() {
|
private VersionedProcessGroup createFlowContents() {
|
||||||
|
@ -882,14 +874,4 @@ public class ImportFlowIT extends FrameworkIntegrationTest {
|
||||||
return bucket;
|
return bucket;
|
||||||
}
|
}
|
||||||
|
|
||||||
@NotNull
|
|
||||||
private VersionedFlowSnapshotMetadata createSnapshotMetadata() {
|
|
||||||
final VersionedFlowSnapshotMetadata snapshotMetadata = new VersionedFlowSnapshotMetadata();
|
|
||||||
snapshotMetadata.setAuthor("unit-test");
|
|
||||||
snapshotMetadata.setBucketIdentifier("unit-test-bucket");
|
|
||||||
snapshotMetadata.setFlowIdentifier("unit-test-flow");
|
|
||||||
snapshotMetadata.setTimestamp(System.currentTimeMillis());
|
|
||||||
snapshotMetadata.setVersion(1);
|
|
||||||
return snapshotMetadata;
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
|
|
@ -51,7 +51,7 @@ import org.apache.nifi.parameter.ParameterDescriptor;
|
||||||
import org.apache.nifi.registry.ComponentVariableRegistry;
|
import org.apache.nifi.registry.ComponentVariableRegistry;
|
||||||
import org.apache.nifi.registry.VariableDescriptor;
|
import org.apache.nifi.registry.VariableDescriptor;
|
||||||
import org.apache.nifi.flow.ComponentType;
|
import org.apache.nifi.flow.ComponentType;
|
||||||
import org.apache.nifi.registry.flow.ExternalControllerServiceReference;
|
import org.apache.nifi.flow.ExternalControllerServiceReference;
|
||||||
import org.apache.nifi.registry.flow.FlowRegistry;
|
import org.apache.nifi.registry.flow.FlowRegistry;
|
||||||
import org.apache.nifi.registry.flow.FlowRegistryClient;
|
import org.apache.nifi.registry.flow.FlowRegistryClient;
|
||||||
import org.apache.nifi.flow.PortType;
|
import org.apache.nifi.flow.PortType;
|
||||||
|
@ -61,8 +61,8 @@ import org.apache.nifi.flow.VersionedControllerService;
|
||||||
import org.apache.nifi.flow.VersionedFlowCoordinates;
|
import org.apache.nifi.flow.VersionedFlowCoordinates;
|
||||||
import org.apache.nifi.flow.VersionedFunnel;
|
import org.apache.nifi.flow.VersionedFunnel;
|
||||||
import org.apache.nifi.flow.VersionedLabel;
|
import org.apache.nifi.flow.VersionedLabel;
|
||||||
import org.apache.nifi.registry.flow.VersionedParameter;
|
import org.apache.nifi.flow.VersionedParameter;
|
||||||
import org.apache.nifi.registry.flow.VersionedParameterContext;
|
import org.apache.nifi.flow.VersionedParameterContext;
|
||||||
import org.apache.nifi.flow.VersionedPort;
|
import org.apache.nifi.flow.VersionedPort;
|
||||||
import org.apache.nifi.flow.VersionedProcessGroup;
|
import org.apache.nifi.flow.VersionedProcessGroup;
|
||||||
import org.apache.nifi.flow.VersionedProcessor;
|
import org.apache.nifi.flow.VersionedProcessor;
|
||||||
|
|
|
@ -25,8 +25,8 @@ import org.apache.nifi.parameter.ParameterContext;
|
||||||
import org.apache.nifi.parameter.ParameterDescriptor;
|
import org.apache.nifi.parameter.ParameterDescriptor;
|
||||||
import org.apache.nifi.parameter.ParameterParser;
|
import org.apache.nifi.parameter.ParameterParser;
|
||||||
import org.apache.nifi.parameter.ParameterTokenList;
|
import org.apache.nifi.parameter.ParameterTokenList;
|
||||||
import org.apache.nifi.registry.flow.VersionedParameter;
|
import org.apache.nifi.flow.VersionedParameter;
|
||||||
import org.apache.nifi.registry.flow.VersionedParameterContext;
|
import org.apache.nifi.flow.VersionedParameterContext;
|
||||||
import org.apache.nifi.web.NiFiServiceFacade;
|
import org.apache.nifi.web.NiFiServiceFacade;
|
||||||
import org.apache.nifi.web.api.dto.ControllerServiceDTO;
|
import org.apache.nifi.web.api.dto.ControllerServiceDTO;
|
||||||
import org.apache.nifi.web.api.dto.FlowSnippetDTO;
|
import org.apache.nifi.web.api.dto.FlowSnippetDTO;
|
||||||
|
|
|
@ -29,10 +29,10 @@ import org.apache.nifi.controller.service.ControllerServiceState;
|
||||||
import org.apache.nifi.flow.VersionedProcessGroup;
|
import org.apache.nifi.flow.VersionedProcessGroup;
|
||||||
import org.apache.nifi.groups.ProcessGroup;
|
import org.apache.nifi.groups.ProcessGroup;
|
||||||
import org.apache.nifi.parameter.ParameterContext;
|
import org.apache.nifi.parameter.ParameterContext;
|
||||||
import org.apache.nifi.registry.flow.ExternalControllerServiceReference;
|
import org.apache.nifi.flow.ExternalControllerServiceReference;
|
||||||
import org.apache.nifi.registry.flow.VersionedFlow;
|
import org.apache.nifi.registry.flow.VersionedFlow;
|
||||||
import org.apache.nifi.registry.flow.VersionedFlowSnapshot;
|
import org.apache.nifi.registry.flow.VersionedFlowSnapshot;
|
||||||
import org.apache.nifi.registry.flow.VersionedParameterContext;
|
import org.apache.nifi.flow.VersionedParameterContext;
|
||||||
import org.apache.nifi.web.api.dto.AccessPolicyDTO;
|
import org.apache.nifi.web.api.dto.AccessPolicyDTO;
|
||||||
import org.apache.nifi.web.api.dto.AffectedComponentDTO;
|
import org.apache.nifi.web.api.dto.AffectedComponentDTO;
|
||||||
import org.apache.nifi.web.api.dto.BulletinBoardDTO;
|
import org.apache.nifi.web.api.dto.BulletinBoardDTO;
|
||||||
|
|
|
@ -98,11 +98,14 @@ import org.apache.nifi.controller.status.history.ProcessGroupStatusDescriptor;
|
||||||
import org.apache.nifi.diagnostics.SystemDiagnostics;
|
import org.apache.nifi.diagnostics.SystemDiagnostics;
|
||||||
import org.apache.nifi.events.BulletinFactory;
|
import org.apache.nifi.events.BulletinFactory;
|
||||||
import org.apache.nifi.expression.ExpressionLanguageScope;
|
import org.apache.nifi.expression.ExpressionLanguageScope;
|
||||||
|
import org.apache.nifi.flow.ExternalControllerServiceReference;
|
||||||
import org.apache.nifi.flow.VersionedComponent;
|
import org.apache.nifi.flow.VersionedComponent;
|
||||||
import org.apache.nifi.flow.VersionedConfigurableComponent;
|
import org.apache.nifi.flow.VersionedConfigurableComponent;
|
||||||
import org.apache.nifi.flow.VersionedConnection;
|
import org.apache.nifi.flow.VersionedConnection;
|
||||||
import org.apache.nifi.flow.VersionedControllerService;
|
import org.apache.nifi.flow.VersionedControllerService;
|
||||||
|
import org.apache.nifi.flow.VersionedExternalFlow;
|
||||||
import org.apache.nifi.flow.VersionedFlowCoordinates;
|
import org.apache.nifi.flow.VersionedFlowCoordinates;
|
||||||
|
import org.apache.nifi.flow.VersionedParameterContext;
|
||||||
import org.apache.nifi.flow.VersionedProcessGroup;
|
import org.apache.nifi.flow.VersionedProcessGroup;
|
||||||
import org.apache.nifi.flow.VersionedProcessor;
|
import org.apache.nifi.flow.VersionedProcessor;
|
||||||
import org.apache.nifi.flow.VersionedPropertyDescriptor;
|
import org.apache.nifi.flow.VersionedPropertyDescriptor;
|
||||||
|
@ -129,10 +132,10 @@ import org.apache.nifi.prometheus.util.JvmMetricsRegistry;
|
||||||
import org.apache.nifi.prometheus.util.NiFiMetricsRegistry;
|
import org.apache.nifi.prometheus.util.NiFiMetricsRegistry;
|
||||||
import org.apache.nifi.prometheus.util.PrometheusMetricsUtil;
|
import org.apache.nifi.prometheus.util.PrometheusMetricsUtil;
|
||||||
import org.apache.nifi.registry.ComponentVariableRegistry;
|
import org.apache.nifi.registry.ComponentVariableRegistry;
|
||||||
|
import org.apache.nifi.registry.VersionedFlowConverter;
|
||||||
import org.apache.nifi.registry.authorization.Permissions;
|
import org.apache.nifi.registry.authorization.Permissions;
|
||||||
import org.apache.nifi.registry.bucket.Bucket;
|
import org.apache.nifi.registry.bucket.Bucket;
|
||||||
import org.apache.nifi.registry.client.NiFiRegistryException;
|
import org.apache.nifi.registry.client.NiFiRegistryException;
|
||||||
import org.apache.nifi.registry.flow.ExternalControllerServiceReference;
|
|
||||||
import org.apache.nifi.registry.flow.FlowRegistry;
|
import org.apache.nifi.registry.flow.FlowRegistry;
|
||||||
import org.apache.nifi.registry.flow.FlowRegistryClient;
|
import org.apache.nifi.registry.flow.FlowRegistryClient;
|
||||||
import org.apache.nifi.registry.flow.RestBasedFlowRegistry;
|
import org.apache.nifi.registry.flow.RestBasedFlowRegistry;
|
||||||
|
@ -141,7 +144,6 @@ import org.apache.nifi.registry.flow.VersionedFlow;
|
||||||
import org.apache.nifi.registry.flow.VersionedFlowSnapshot;
|
import org.apache.nifi.registry.flow.VersionedFlowSnapshot;
|
||||||
import org.apache.nifi.registry.flow.VersionedFlowSnapshotMetadata;
|
import org.apache.nifi.registry.flow.VersionedFlowSnapshotMetadata;
|
||||||
import org.apache.nifi.registry.flow.VersionedFlowState;
|
import org.apache.nifi.registry.flow.VersionedFlowState;
|
||||||
import org.apache.nifi.registry.flow.VersionedParameterContext;
|
|
||||||
import org.apache.nifi.registry.flow.diff.ComparableDataFlow;
|
import org.apache.nifi.registry.flow.diff.ComparableDataFlow;
|
||||||
import org.apache.nifi.registry.flow.diff.ConciseEvolvingDifferenceDescriptor;
|
import org.apache.nifi.registry.flow.diff.ConciseEvolvingDifferenceDescriptor;
|
||||||
import org.apache.nifi.registry.flow.diff.DifferenceType;
|
import org.apache.nifi.registry.flow.diff.DifferenceType;
|
||||||
|
@ -4919,7 +4921,8 @@ public class StandardNiFiServiceFacade implements NiFiServiceFacade {
|
||||||
@Override
|
@Override
|
||||||
public void verifyCanUpdate(final String groupId, final VersionedFlowSnapshot proposedFlow, final boolean verifyConnectionRemoval, final boolean verifyNotDirty) {
|
public void verifyCanUpdate(final String groupId, final VersionedFlowSnapshot proposedFlow, final boolean verifyConnectionRemoval, final boolean verifyNotDirty) {
|
||||||
final ProcessGroup group = processGroupDAO.getProcessGroup(groupId);
|
final ProcessGroup group = processGroupDAO.getProcessGroup(groupId);
|
||||||
group.verifyCanUpdate(proposedFlow, verifyConnectionRemoval, verifyNotDirty);
|
final VersionedExternalFlow externalFlow = VersionedFlowConverter.createVersionedExternalFlow(proposedFlow);
|
||||||
|
group.verifyCanUpdate(externalFlow, verifyConnectionRemoval, verifyNotDirty);
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
|
@ -4936,7 +4939,8 @@ public class StandardNiFiServiceFacade implements NiFiServiceFacade {
|
||||||
// verify that the process group can be updated to the given snapshot. We do not verify that connections can
|
// verify that the process group can be updated to the given snapshot. We do not verify that connections can
|
||||||
// be removed, because the flow may still be running, and it only matters that the connections can be removed once the components
|
// be removed, because the flow may still be running, and it only matters that the connections can be removed once the components
|
||||||
// have been stopped.
|
// have been stopped.
|
||||||
group.verifyCanUpdate(versionedFlowSnapshot, false, false);
|
final VersionedExternalFlow externalFlow = VersionedFlowConverter.createVersionedExternalFlow(versionedFlowSnapshot);
|
||||||
|
group.verifyCanUpdate(externalFlow, false, false);
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
|
@ -5347,7 +5351,8 @@ public class StandardNiFiServiceFacade implements NiFiServiceFacade {
|
||||||
@Override
|
@Override
|
||||||
public RevisionUpdate<ProcessGroupDTO> update() {
|
public RevisionUpdate<ProcessGroupDTO> update() {
|
||||||
// update the Process Group
|
// update the Process Group
|
||||||
final ProcessGroup updatedProcessGroup = processGroupDAO.updateProcessGroupFlow(groupId, proposedFlowSnapshot, versionControlInfo, componentIdSeed, verifyNotModified, updateSettings,
|
final VersionedExternalFlow externalFlow = VersionedFlowConverter.createVersionedExternalFlow(proposedFlowSnapshot);
|
||||||
|
processGroupDAO.updateProcessGroupFlow(groupId, externalFlow, versionControlInfo, componentIdSeed, verifyNotModified, updateSettings,
|
||||||
updateDescendantVersionedFlows);
|
updateDescendantVersionedFlows);
|
||||||
|
|
||||||
// update the revisions
|
// update the revisions
|
||||||
|
|
|
@ -31,7 +31,7 @@ import org.apache.nifi.controller.service.ControllerServiceState;
|
||||||
import org.apache.nifi.flow.VersionedProcessGroup;
|
import org.apache.nifi.flow.VersionedProcessGroup;
|
||||||
import org.apache.nifi.registry.flow.FlowRegistryUtils;
|
import org.apache.nifi.registry.flow.FlowRegistryUtils;
|
||||||
import org.apache.nifi.registry.flow.VersionedFlowSnapshot;
|
import org.apache.nifi.registry.flow.VersionedFlowSnapshot;
|
||||||
import org.apache.nifi.registry.flow.VersionedParameterContext;
|
import org.apache.nifi.flow.VersionedParameterContext;
|
||||||
import org.apache.nifi.web.NiFiServiceFacade;
|
import org.apache.nifi.web.NiFiServiceFacade;
|
||||||
import org.apache.nifi.web.ResourceNotFoundException;
|
import org.apache.nifi.web.ResourceNotFoundException;
|
||||||
import org.apache.nifi.web.ResumeFlowException;
|
import org.apache.nifi.web.ResumeFlowException;
|
||||||
|
|
|
@ -108,7 +108,7 @@ import org.apache.nifi.registry.flow.FlowRegistryUtils;
|
||||||
import org.apache.nifi.registry.flow.VersionedFlow;
|
import org.apache.nifi.registry.flow.VersionedFlow;
|
||||||
import org.apache.nifi.registry.flow.VersionedFlowSnapshot;
|
import org.apache.nifi.registry.flow.VersionedFlowSnapshot;
|
||||||
import org.apache.nifi.registry.flow.VersionedFlowState;
|
import org.apache.nifi.registry.flow.VersionedFlowState;
|
||||||
import org.apache.nifi.registry.flow.VersionedParameterContext;
|
import org.apache.nifi.flow.VersionedParameterContext;
|
||||||
import org.apache.nifi.flow.VersionedProcessGroup;
|
import org.apache.nifi.flow.VersionedProcessGroup;
|
||||||
import org.apache.nifi.registry.variable.VariableRegistryUpdateRequest;
|
import org.apache.nifi.registry.variable.VariableRegistryUpdateRequest;
|
||||||
import org.apache.nifi.registry.variable.VariableRegistryUpdateStep;
|
import org.apache.nifi.registry.variable.VariableRegistryUpdateStep;
|
||||||
|
|
|
@ -19,8 +19,8 @@ package org.apache.nifi.web.dao;
|
||||||
import org.apache.nifi.controller.ScheduledState;
|
import org.apache.nifi.controller.ScheduledState;
|
||||||
import org.apache.nifi.controller.queue.DropFlowFileStatus;
|
import org.apache.nifi.controller.queue.DropFlowFileStatus;
|
||||||
import org.apache.nifi.controller.service.ControllerServiceState;
|
import org.apache.nifi.controller.service.ControllerServiceState;
|
||||||
|
import org.apache.nifi.flow.VersionedExternalFlow;
|
||||||
import org.apache.nifi.groups.ProcessGroup;
|
import org.apache.nifi.groups.ProcessGroup;
|
||||||
import org.apache.nifi.registry.flow.VersionedFlowSnapshot;
|
|
||||||
import org.apache.nifi.web.api.dto.ProcessGroupDTO;
|
import org.apache.nifi.web.api.dto.ProcessGroupDTO;
|
||||||
import org.apache.nifi.web.api.dto.VariableRegistryDTO;
|
import org.apache.nifi.web.api.dto.VariableRegistryDTO;
|
||||||
import org.apache.nifi.web.api.dto.VersionControlInformationDTO;
|
import org.apache.nifi.web.api.dto.VersionControlInformationDTO;
|
||||||
|
@ -136,7 +136,7 @@ public interface ProcessGroupDAO {
|
||||||
* update the contents of that Process Group
|
* update the contents of that Process Group
|
||||||
* @return the process group
|
* @return the process group
|
||||||
*/
|
*/
|
||||||
ProcessGroup updateProcessGroupFlow(String groupId, VersionedFlowSnapshot proposedSnapshot, VersionControlInformationDTO versionControlInformation, String componentIdSeed,
|
ProcessGroup updateProcessGroupFlow(String groupId, VersionedExternalFlow proposedSnapshot, VersionControlInformationDTO versionControlInformation, String componentIdSeed,
|
||||||
boolean verifyNotModified, boolean updateSettings, boolean updateDescendantVersionedFlows);
|
boolean verifyNotModified, boolean updateSettings, boolean updateDescendantVersionedFlows);
|
||||||
|
|
||||||
/**
|
/**
|
||||||
|
|
|
@ -28,6 +28,8 @@ import org.apache.nifi.controller.flow.FlowManager;
|
||||||
import org.apache.nifi.controller.queue.DropFlowFileStatus;
|
import org.apache.nifi.controller.queue.DropFlowFileStatus;
|
||||||
import org.apache.nifi.controller.service.ControllerServiceNode;
|
import org.apache.nifi.controller.service.ControllerServiceNode;
|
||||||
import org.apache.nifi.controller.service.ControllerServiceState;
|
import org.apache.nifi.controller.service.ControllerServiceState;
|
||||||
|
import org.apache.nifi.flow.VersionedExternalFlow;
|
||||||
|
import org.apache.nifi.flow.VersionedProcessGroup;
|
||||||
import org.apache.nifi.groups.FlowFileConcurrency;
|
import org.apache.nifi.groups.FlowFileConcurrency;
|
||||||
import org.apache.nifi.groups.FlowFileOutboundPolicy;
|
import org.apache.nifi.groups.FlowFileOutboundPolicy;
|
||||||
import org.apache.nifi.groups.ProcessGroup;
|
import org.apache.nifi.groups.ProcessGroup;
|
||||||
|
@ -36,8 +38,6 @@ import org.apache.nifi.parameter.ParameterContext;
|
||||||
import org.apache.nifi.registry.flow.FlowRegistry;
|
import org.apache.nifi.registry.flow.FlowRegistry;
|
||||||
import org.apache.nifi.registry.flow.StandardVersionControlInformation;
|
import org.apache.nifi.registry.flow.StandardVersionControlInformation;
|
||||||
import org.apache.nifi.registry.flow.VersionControlInformation;
|
import org.apache.nifi.registry.flow.VersionControlInformation;
|
||||||
import org.apache.nifi.registry.flow.VersionedFlowSnapshot;
|
|
||||||
import org.apache.nifi.flow.VersionedProcessGroup;
|
|
||||||
import org.apache.nifi.registry.flow.mapping.NiFiRegistryFlowMapper;
|
import org.apache.nifi.registry.flow.mapping.NiFiRegistryFlowMapper;
|
||||||
import org.apache.nifi.remote.RemoteGroupPort;
|
import org.apache.nifi.remote.RemoteGroupPort;
|
||||||
import org.apache.nifi.web.ResourceNotFoundException;
|
import org.apache.nifi.web.ResourceNotFoundException;
|
||||||
|
@ -424,7 +424,7 @@ public class StandardProcessGroupDAO extends ComponentDAO implements ProcessGrou
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public ProcessGroup updateProcessGroupFlow(final String groupId, final VersionedFlowSnapshot proposedSnapshot, final VersionControlInformationDTO versionControlInformation,
|
public ProcessGroup updateProcessGroupFlow(final String groupId, final VersionedExternalFlow proposedSnapshot, final VersionControlInformationDTO versionControlInformation,
|
||||||
final String componentIdSeed, final boolean verifyNotModified, final boolean updateSettings, final boolean updateDescendantVersionedFlows) {
|
final String componentIdSeed, final boolean verifyNotModified, final boolean updateSettings, final boolean updateDescendantVersionedFlows) {
|
||||||
|
|
||||||
final ProcessGroup group = locateProcessGroup(flowController, groupId);
|
final ProcessGroup group = locateProcessGroup(flowController, groupId);
|
||||||
|
|
|
@ -40,11 +40,11 @@ import org.apache.nifi.groups.RemoteProcessGroup;
|
||||||
import org.apache.nifi.history.History;
|
import org.apache.nifi.history.History;
|
||||||
import org.apache.nifi.history.HistoryQuery;
|
import org.apache.nifi.history.HistoryQuery;
|
||||||
import org.apache.nifi.nar.ExtensionManager;
|
import org.apache.nifi.nar.ExtensionManager;
|
||||||
import org.apache.nifi.registry.flow.ExternalControllerServiceReference;
|
import org.apache.nifi.flow.ExternalControllerServiceReference;
|
||||||
import org.apache.nifi.registry.flow.RestBasedFlowRegistry;
|
import org.apache.nifi.registry.flow.RestBasedFlowRegistry;
|
||||||
import org.apache.nifi.registry.flow.VersionControlInformation;
|
import org.apache.nifi.registry.flow.VersionControlInformation;
|
||||||
import org.apache.nifi.registry.flow.VersionedFlowSnapshot;
|
import org.apache.nifi.registry.flow.VersionedFlowSnapshot;
|
||||||
import org.apache.nifi.registry.flow.VersionedParameterContext;
|
import org.apache.nifi.flow.VersionedParameterContext;
|
||||||
import org.apache.nifi.registry.flow.mapping.InstantiatedVersionedProcessGroup;
|
import org.apache.nifi.registry.flow.mapping.InstantiatedVersionedProcessGroup;
|
||||||
import org.apache.nifi.registry.flow.mapping.NiFiRegistryFlowMapper;
|
import org.apache.nifi.registry.flow.mapping.NiFiRegistryFlowMapper;
|
||||||
import org.apache.nifi.web.api.dto.DtoFactory;
|
import org.apache.nifi.web.api.dto.DtoFactory;
|
||||||
|
|
|
@ -41,6 +41,7 @@ import org.apache.nifi.components.resource.ResourceType;
|
||||||
import org.apache.nifi.flow.Bundle;
|
import org.apache.nifi.flow.Bundle;
|
||||||
import org.apache.nifi.flow.VersionedConnection;
|
import org.apache.nifi.flow.VersionedConnection;
|
||||||
import org.apache.nifi.flow.VersionedControllerService;
|
import org.apache.nifi.flow.VersionedControllerService;
|
||||||
|
import org.apache.nifi.flow.VersionedExternalFlow;
|
||||||
import org.apache.nifi.flow.VersionedLabel;
|
import org.apache.nifi.flow.VersionedLabel;
|
||||||
import org.apache.nifi.flow.VersionedPort;
|
import org.apache.nifi.flow.VersionedPort;
|
||||||
import org.apache.nifi.flow.VersionedProcessGroup;
|
import org.apache.nifi.flow.VersionedProcessGroup;
|
||||||
|
@ -60,6 +61,7 @@ import org.apache.nifi.processors.stateless.retrieval.CachingDataflowProvider;
|
||||||
import org.apache.nifi.processors.stateless.retrieval.DataflowProvider;
|
import org.apache.nifi.processors.stateless.retrieval.DataflowProvider;
|
||||||
import org.apache.nifi.processors.stateless.retrieval.FileSystemDataflowProvider;
|
import org.apache.nifi.processors.stateless.retrieval.FileSystemDataflowProvider;
|
||||||
import org.apache.nifi.processors.stateless.retrieval.RegistryDataflowProvider;
|
import org.apache.nifi.processors.stateless.retrieval.RegistryDataflowProvider;
|
||||||
|
import org.apache.nifi.registry.VersionedFlowConverter;
|
||||||
import org.apache.nifi.registry.bucket.Bucket;
|
import org.apache.nifi.registry.bucket.Bucket;
|
||||||
import org.apache.nifi.registry.flow.VersionedFlow;
|
import org.apache.nifi.registry.flow.VersionedFlow;
|
||||||
import org.apache.nifi.registry.flow.VersionedFlowSnapshot;
|
import org.apache.nifi.registry.flow.VersionedFlowSnapshot;
|
||||||
|
@ -462,7 +464,7 @@ public class ExecuteStateless extends AbstractProcessor implements Searchable {
|
||||||
final StatelessEngineConfiguration engineConfiguration = createEngineConfiguration(context, dataflowIndex);
|
final StatelessEngineConfiguration engineConfiguration = createEngineConfiguration(context, dataflowIndex);
|
||||||
final StatelessBootstrap bootstrap = StatelessBootstrap.bootstrap(engineConfiguration, Thread.currentThread().getContextClassLoader());
|
final StatelessBootstrap bootstrap = StatelessBootstrap.bootstrap(engineConfiguration, Thread.currentThread().getContextClassLoader());
|
||||||
|
|
||||||
final DataflowDefinition<VersionedFlowSnapshot> dataflowDefinition = createDataflowDefinition(context, flowSnapshot);
|
final DataflowDefinition dataflowDefinition = createDataflowDefinition(context, flowSnapshot);
|
||||||
|
|
||||||
final StatelessDataflow dataflow = bootstrap.createDataflow(dataflowDefinition);
|
final StatelessDataflow dataflow = bootstrap.createDataflow(dataflowDefinition);
|
||||||
dataflow.initialize();
|
dataflow.initialize();
|
||||||
|
@ -746,7 +748,8 @@ public class ExecuteStateless extends AbstractProcessor implements Searchable {
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
private DataflowDefinition<VersionedFlowSnapshot> createDataflowDefinition(final ProcessContext context, final VersionedFlowSnapshot flowSnapshot) {
|
private DataflowDefinition createDataflowDefinition(final ProcessContext context, final VersionedFlowSnapshot flowSnapshot) {
|
||||||
|
final VersionedExternalFlow externalFlow = VersionedFlowConverter.createVersionedExternalFlow(flowSnapshot);
|
||||||
final ParameterValueProviderDefinition parameterValueProviderDefinition = new ParameterValueProviderDefinition();
|
final ParameterValueProviderDefinition parameterValueProviderDefinition = new ParameterValueProviderDefinition();
|
||||||
parameterValueProviderDefinition.setType("org.apache.nifi.stateless.parameter.OverrideParameterValueProvider");
|
parameterValueProviderDefinition.setType("org.apache.nifi.stateless.parameter.OverrideParameterValueProvider");
|
||||||
parameterValueProviderDefinition.setName("Parameter Override");
|
parameterValueProviderDefinition.setName("Parameter Override");
|
||||||
|
@ -783,10 +786,10 @@ public class ExecuteStateless extends AbstractProcessor implements Searchable {
|
||||||
}
|
}
|
||||||
};
|
};
|
||||||
|
|
||||||
return new DataflowDefinition<VersionedFlowSnapshot>() {
|
return new DataflowDefinition() {
|
||||||
@Override
|
@Override
|
||||||
public VersionedFlowSnapshot getFlowSnapshot() {
|
public VersionedExternalFlow getVersionedExternalFlow() {
|
||||||
return flowSnapshot;
|
return externalFlow;
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
|
|
|
@ -0,0 +1,54 @@
|
||||||
|
/*
|
||||||
|
* 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.registry;
|
||||||
|
|
||||||
|
import org.apache.nifi.flow.VersionedExternalFlow;
|
||||||
|
import org.apache.nifi.flow.VersionedExternalFlowMetadata;
|
||||||
|
import org.apache.nifi.registry.flow.VersionedFlow;
|
||||||
|
import org.apache.nifi.registry.flow.VersionedFlowSnapshot;
|
||||||
|
import org.apache.nifi.registry.flow.VersionedFlowSnapshotMetadata;
|
||||||
|
|
||||||
|
public class VersionedFlowConverter {
|
||||||
|
public static VersionedExternalFlow createVersionedExternalFlow(final VersionedFlowSnapshot flowSnapshot) {
|
||||||
|
final VersionedExternalFlowMetadata externalFlowMetadata = new VersionedExternalFlowMetadata();
|
||||||
|
final VersionedFlowSnapshotMetadata snapshotMetadata = flowSnapshot.getSnapshotMetadata();
|
||||||
|
if (snapshotMetadata != null) {
|
||||||
|
externalFlowMetadata.setAuthor(snapshotMetadata.getAuthor());
|
||||||
|
externalFlowMetadata.setBucketIdentifier(snapshotMetadata.getBucketIdentifier());
|
||||||
|
externalFlowMetadata.setComments(snapshotMetadata.getComments());
|
||||||
|
externalFlowMetadata.setFlowIdentifier(snapshotMetadata.getFlowIdentifier());
|
||||||
|
externalFlowMetadata.setTimestamp(snapshotMetadata.getTimestamp());
|
||||||
|
externalFlowMetadata.setVersion(snapshotMetadata.getVersion());
|
||||||
|
}
|
||||||
|
|
||||||
|
final VersionedFlow versionedFlow = flowSnapshot.getFlow();
|
||||||
|
if (versionedFlow == null) {
|
||||||
|
externalFlowMetadata.setFlowName(flowSnapshot.getFlowContents().getName());
|
||||||
|
} else {
|
||||||
|
externalFlowMetadata.setFlowName(versionedFlow.getName());
|
||||||
|
}
|
||||||
|
|
||||||
|
final VersionedExternalFlow externalFlow = new VersionedExternalFlow();
|
||||||
|
externalFlow.setFlowContents(flowSnapshot.getFlowContents());
|
||||||
|
externalFlow.setExternalControllerServices(flowSnapshot.getExternalControllerServices());
|
||||||
|
externalFlow.setParameterContexts(flowSnapshot.getParameterContexts());
|
||||||
|
externalFlow.setMetadata(externalFlowMetadata);
|
||||||
|
|
||||||
|
return externalFlow;
|
||||||
|
}
|
||||||
|
}
|
|
@ -19,6 +19,8 @@ package org.apache.nifi.registry.flow;
|
||||||
|
|
||||||
import io.swagger.annotations.ApiModel;
|
import io.swagger.annotations.ApiModel;
|
||||||
import io.swagger.annotations.ApiModelProperty;
|
import io.swagger.annotations.ApiModelProperty;
|
||||||
|
import org.apache.nifi.flow.ExternalControllerServiceReference;
|
||||||
|
import org.apache.nifi.flow.VersionedParameterContext;
|
||||||
import org.apache.nifi.flow.VersionedProcessGroup;
|
import org.apache.nifi.flow.VersionedProcessGroup;
|
||||||
import org.apache.nifi.registry.bucket.Bucket;
|
import org.apache.nifi.registry.bucket.Bucket;
|
||||||
|
|
||||||
|
@ -117,7 +119,7 @@ public class VersionedFlowSnapshot {
|
||||||
@ApiModelProperty(value = "The parameter contexts referenced by process groups in the flow contents. " +
|
@ApiModelProperty(value = "The parameter contexts referenced by process groups in the flow contents. " +
|
||||||
"The mapping is from the name of the context to the context instance, and it is expected that any " +
|
"The mapping is from the name of the context to the context instance, and it is expected that any " +
|
||||||
"context in this map is referenced by at least one process group in this flow.")
|
"context in this map is referenced by at least one process group in this flow.")
|
||||||
public Map<String,VersionedParameterContext> getParameterContexts() {
|
public Map<String, VersionedParameterContext> getParameterContexts() {
|
||||||
return parameterContexts;
|
return parameterContexts;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -20,7 +20,7 @@ package org.apache.nifi.registry.flow.diff;
|
||||||
import org.apache.nifi.flow.VersionedControllerService;
|
import org.apache.nifi.flow.VersionedControllerService;
|
||||||
import org.apache.nifi.flow.VersionedProcessGroup;
|
import org.apache.nifi.flow.VersionedProcessGroup;
|
||||||
import org.apache.nifi.flow.VersionedReportingTask;
|
import org.apache.nifi.flow.VersionedReportingTask;
|
||||||
import org.apache.nifi.registry.flow.VersionedParameterContext;
|
import org.apache.nifi.flow.VersionedParameterContext;
|
||||||
|
|
||||||
import java.util.Set;
|
import java.util.Set;
|
||||||
|
|
||||||
|
|
|
@ -20,7 +20,7 @@ package org.apache.nifi.registry.flow.diff;
|
||||||
import org.apache.nifi.flow.VersionedControllerService;
|
import org.apache.nifi.flow.VersionedControllerService;
|
||||||
import org.apache.nifi.flow.VersionedProcessGroup;
|
import org.apache.nifi.flow.VersionedProcessGroup;
|
||||||
import org.apache.nifi.flow.VersionedReportingTask;
|
import org.apache.nifi.flow.VersionedReportingTask;
|
||||||
import org.apache.nifi.registry.flow.VersionedParameterContext;
|
import org.apache.nifi.flow.VersionedParameterContext;
|
||||||
|
|
||||||
import java.util.Collections;
|
import java.util.Collections;
|
||||||
import java.util.HashSet;
|
import java.util.HashSet;
|
||||||
|
|
|
@ -30,8 +30,8 @@ import org.apache.nifi.flow.VersionedPropertyDescriptor;
|
||||||
import org.apache.nifi.flow.VersionedRemoteGroupPort;
|
import org.apache.nifi.flow.VersionedRemoteGroupPort;
|
||||||
import org.apache.nifi.flow.VersionedRemoteProcessGroup;
|
import org.apache.nifi.flow.VersionedRemoteProcessGroup;
|
||||||
import org.apache.nifi.flow.VersionedReportingTask;
|
import org.apache.nifi.flow.VersionedReportingTask;
|
||||||
import org.apache.nifi.registry.flow.VersionedParameter;
|
import org.apache.nifi.flow.VersionedParameter;
|
||||||
import org.apache.nifi.registry.flow.VersionedParameterContext;
|
import org.apache.nifi.flow.VersionedParameterContext;
|
||||||
|
|
||||||
import java.util.Collection;
|
import java.util.Collection;
|
||||||
import java.util.Collections;
|
import java.util.Collections;
|
||||||
|
|
|
@ -16,7 +16,7 @@
|
||||||
*/
|
*/
|
||||||
package org.apache.nifi.registry.serialization;
|
package org.apache.nifi.registry.serialization;
|
||||||
|
|
||||||
import org.apache.nifi.registry.flow.ExternalControllerServiceReference;
|
import org.apache.nifi.flow.ExternalControllerServiceReference;
|
||||||
import org.apache.nifi.registry.flow.VersionedFlowSnapshot;
|
import org.apache.nifi.registry.flow.VersionedFlowSnapshot;
|
||||||
import org.apache.nifi.flow.VersionedProcessGroup;
|
import org.apache.nifi.flow.VersionedProcessGroup;
|
||||||
import org.apache.nifi.flow.VersionedProcessor;
|
import org.apache.nifi.flow.VersionedProcessor;
|
||||||
|
|
|
@ -60,12 +60,12 @@ import org.apache.nifi.registry.extension.repo.ExtensionRepoGroup;
|
||||||
import org.apache.nifi.registry.extension.repo.ExtensionRepoVersion;
|
import org.apache.nifi.registry.extension.repo.ExtensionRepoVersion;
|
||||||
import org.apache.nifi.registry.extension.repo.ExtensionRepoVersionSummary;
|
import org.apache.nifi.registry.extension.repo.ExtensionRepoVersionSummary;
|
||||||
import org.apache.nifi.registry.field.Fields;
|
import org.apache.nifi.registry.field.Fields;
|
||||||
import org.apache.nifi.registry.flow.ExternalControllerServiceReference;
|
import org.apache.nifi.flow.ExternalControllerServiceReference;
|
||||||
import org.apache.nifi.registry.flow.VersionedFlow;
|
import org.apache.nifi.registry.flow.VersionedFlow;
|
||||||
import org.apache.nifi.registry.flow.VersionedFlowSnapshot;
|
import org.apache.nifi.registry.flow.VersionedFlowSnapshot;
|
||||||
import org.apache.nifi.registry.flow.VersionedFlowSnapshotMetadata;
|
import org.apache.nifi.registry.flow.VersionedFlowSnapshotMetadata;
|
||||||
import org.apache.nifi.registry.flow.VersionedParameter;
|
import org.apache.nifi.flow.VersionedParameter;
|
||||||
import org.apache.nifi.registry.flow.VersionedParameterContext;
|
import org.apache.nifi.flow.VersionedParameterContext;
|
||||||
import org.apache.nifi.flow.VersionedProcessGroup;
|
import org.apache.nifi.flow.VersionedProcessGroup;
|
||||||
import org.apache.nifi.flow.VersionedProcessor;
|
import org.apache.nifi.flow.VersionedProcessor;
|
||||||
import org.apache.nifi.flow.VersionedPropertyDescriptor;
|
import org.apache.nifi.flow.VersionedPropertyDescriptor;
|
||||||
|
|
|
@ -17,6 +17,7 @@
|
||||||
|
|
||||||
package org.apache.nifi.stateless.flow;
|
package org.apache.nifi.stateless.flow;
|
||||||
|
|
||||||
|
import org.apache.nifi.flow.VersionedExternalFlow;
|
||||||
import org.apache.nifi.stateless.config.ParameterContextDefinition;
|
import org.apache.nifi.stateless.config.ParameterContextDefinition;
|
||||||
import org.apache.nifi.stateless.config.ParameterValueProviderDefinition;
|
import org.apache.nifi.stateless.config.ParameterValueProviderDefinition;
|
||||||
import org.apache.nifi.stateless.config.ReportingTaskDefinition;
|
import org.apache.nifi.stateless.config.ReportingTaskDefinition;
|
||||||
|
@ -24,8 +25,8 @@ import org.apache.nifi.stateless.config.ReportingTaskDefinition;
|
||||||
import java.util.List;
|
import java.util.List;
|
||||||
import java.util.Set;
|
import java.util.Set;
|
||||||
|
|
||||||
public interface DataflowDefinition<T> {
|
public interface DataflowDefinition {
|
||||||
T getFlowSnapshot();
|
VersionedExternalFlow getVersionedExternalFlow();
|
||||||
|
|
||||||
String getFlowName();
|
String getFlowName();
|
||||||
|
|
||||||
|
|
|
@ -27,9 +27,9 @@ import java.util.List;
|
||||||
import java.util.Map;
|
import java.util.Map;
|
||||||
|
|
||||||
public interface DataflowDefinitionParser {
|
public interface DataflowDefinitionParser {
|
||||||
DataflowDefinition<?> parseFlowDefinition(File configurationFile, StatelessEngineConfiguration engineConfiguration, List<ParameterOverride> parameterOverrides)
|
DataflowDefinition parseFlowDefinition(File configurationFile, StatelessEngineConfiguration engineConfiguration, List<ParameterOverride> parameterOverrides)
|
||||||
throws StatelessConfigurationException, IOException;
|
throws StatelessConfigurationException, IOException;
|
||||||
|
|
||||||
DataflowDefinition<?> parseFlowDefinition(Map<String, String> configurationProperties, StatelessEngineConfiguration engineConfiguration, List<ParameterOverride> parameterOverrides)
|
DataflowDefinition parseFlowDefinition(Map<String, String> configurationProperties, StatelessEngineConfiguration engineConfiguration, List<ParameterOverride> parameterOverrides)
|
||||||
throws StatelessConfigurationException, IOException;
|
throws StatelessConfigurationException, IOException;
|
||||||
}
|
}
|
||||||
|
|
|
@ -22,7 +22,7 @@ import org.apache.nifi.stateless.engine.StatelessEngineConfiguration;
|
||||||
|
|
||||||
import java.io.IOException;
|
import java.io.IOException;
|
||||||
|
|
||||||
public interface StatelessDataflowFactory<T> {
|
public interface StatelessDataflowFactory {
|
||||||
StatelessDataflow createDataflow(StatelessEngineConfiguration statelessEngineConfiguration, DataflowDefinition<T> dataflowDefinition, ClassLoader extensionClassLoader)
|
StatelessDataflow createDataflow(StatelessEngineConfiguration statelessEngineConfiguration, DataflowDefinition dataflowDefinition, ClassLoader extensionClassLoader)
|
||||||
throws IOException, StatelessConfigurationException;
|
throws IOException, StatelessConfigurationException;
|
||||||
}
|
}
|
||||||
|
|
|
@ -89,7 +89,7 @@ public class RunStatelessFlow {
|
||||||
final long initializeStart = System.currentTimeMillis();
|
final long initializeStart = System.currentTimeMillis();
|
||||||
|
|
||||||
final StatelessBootstrap bootstrap = StatelessBootstrap.bootstrap(engineConfiguration);
|
final StatelessBootstrap bootstrap = StatelessBootstrap.bootstrap(engineConfiguration);
|
||||||
final DataflowDefinition<?> dataflowDefinition = bootstrap.parseDataflowDefinition(flowDefinitionFile, parameterOverrides);
|
final DataflowDefinition dataflowDefinition = bootstrap.parseDataflowDefinition(flowDefinitionFile, parameterOverrides);
|
||||||
|
|
||||||
final StatelessDataflow dataflow = bootstrap.createDataflow(dataflowDefinition);
|
final StatelessDataflow dataflow = bootstrap.createDataflow(dataflowDefinition);
|
||||||
dataflow.initialize();
|
dataflow.initialize();
|
||||||
|
|
|
@ -19,6 +19,7 @@ package org.apache.nifi.stateless.bootstrap;
|
||||||
|
|
||||||
import org.apache.nifi.bundle.Bundle;
|
import org.apache.nifi.bundle.Bundle;
|
||||||
import org.apache.nifi.bundle.BundleCoordinate;
|
import org.apache.nifi.bundle.BundleCoordinate;
|
||||||
|
import org.apache.nifi.nar.NarClassLoader;
|
||||||
import org.apache.nifi.nar.NarClassLoaders;
|
import org.apache.nifi.nar.NarClassLoaders;
|
||||||
import org.apache.nifi.nar.NarUnpacker;
|
import org.apache.nifi.nar.NarUnpacker;
|
||||||
import org.apache.nifi.nar.SystemBundle;
|
import org.apache.nifi.nar.SystemBundle;
|
||||||
|
@ -67,24 +68,24 @@ public class StatelessBootstrap {
|
||||||
this.engineConfiguration = engineConfiguration;
|
this.engineConfiguration = engineConfiguration;
|
||||||
}
|
}
|
||||||
|
|
||||||
public <T> StatelessDataflow createDataflow(final DataflowDefinition<T> dataflowDefinition)
|
public StatelessDataflow createDataflow(final DataflowDefinition dataflowDefinition)
|
||||||
throws IOException, StatelessConfigurationException {
|
throws IOException, StatelessConfigurationException {
|
||||||
final StatelessDataflowFactory<T> dataflowFactory = getSingleInstance(engineClassLoader, StatelessDataflowFactory.class);
|
final StatelessDataflowFactory dataflowFactory = getSingleInstance(engineClassLoader, StatelessDataflowFactory.class);
|
||||||
final StatelessDataflow dataflow = dataflowFactory.createDataflow(engineConfiguration, dataflowDefinition, extensionClassLoader);
|
final StatelessDataflow dataflow = dataflowFactory.createDataflow(engineConfiguration, dataflowDefinition, extensionClassLoader);
|
||||||
return dataflow;
|
return dataflow;
|
||||||
}
|
}
|
||||||
|
|
||||||
public DataflowDefinition<?> parseDataflowDefinition(final File flowDefinitionFile, final List<ParameterOverride> parameterOverrides)
|
public DataflowDefinition parseDataflowDefinition(final File flowDefinitionFile, final List<ParameterOverride> parameterOverrides)
|
||||||
throws StatelessConfigurationException, IOException {
|
throws StatelessConfigurationException, IOException {
|
||||||
final DataflowDefinitionParser dataflowDefinitionParser = getSingleInstance(engineClassLoader, DataflowDefinitionParser.class);
|
final DataflowDefinitionParser dataflowDefinitionParser = getSingleInstance(engineClassLoader, DataflowDefinitionParser.class);
|
||||||
final DataflowDefinition<?> dataflowDefinition = dataflowDefinitionParser.parseFlowDefinition(flowDefinitionFile, engineConfiguration, parameterOverrides);
|
final DataflowDefinition dataflowDefinition = dataflowDefinitionParser.parseFlowDefinition(flowDefinitionFile, engineConfiguration, parameterOverrides);
|
||||||
return dataflowDefinition;
|
return dataflowDefinition;
|
||||||
}
|
}
|
||||||
|
|
||||||
public DataflowDefinition<?> parseDataflowDefinition(final Map<String, String> flowDefinitionProperties, final List<ParameterOverride> parameterOverrides)
|
public DataflowDefinition parseDataflowDefinition(final Map<String, String> flowDefinitionProperties, final List<ParameterOverride> parameterOverrides)
|
||||||
throws StatelessConfigurationException, IOException {
|
throws StatelessConfigurationException, IOException {
|
||||||
final DataflowDefinitionParser dataflowDefinitionParser = getSingleInstance(engineClassLoader, DataflowDefinitionParser.class);
|
final DataflowDefinitionParser dataflowDefinitionParser = getSingleInstance(engineClassLoader, DataflowDefinitionParser.class);
|
||||||
final DataflowDefinition<?> dataflowDefinition = dataflowDefinitionParser.parseFlowDefinition(flowDefinitionProperties, engineConfiguration, parameterOverrides);
|
final DataflowDefinition dataflowDefinition = dataflowDefinitionParser.parseFlowDefinition(flowDefinitionProperties, engineConfiguration, parameterOverrides);
|
||||||
return dataflowDefinition;
|
return dataflowDefinition;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -119,47 +120,18 @@ public class StatelessBootstrap {
|
||||||
final long unpackMillis = System.currentTimeMillis() - unpackStart;
|
final long unpackMillis = System.currentTimeMillis() - unpackStart;
|
||||||
logger.info("Unpacked NAR files in {} millis", unpackMillis);
|
logger.info("Unpacked NAR files in {} millis", unpackMillis);
|
||||||
|
|
||||||
|
final BlockListClassLoader statelessClassLoader = createExtensionRootClassLoader(narDirectory, rootClassLoader);
|
||||||
|
|
||||||
final File statelessNarWorkingDir = locateStatelessNarWorkingDirectory(extensionsWorkingDir);
|
final File statelessNarWorkingDir = locateStatelessNarWorkingDirectory(extensionsWorkingDir);
|
||||||
final File statelessNarInf = new File(statelessNarWorkingDir, "NAR-INF");
|
final NarClassLoader engineClassLoader;
|
||||||
final File statelessNarDependencies = new File(statelessNarInf, "bundled-dependencies");
|
try {
|
||||||
final File[] statelessNarContents = statelessNarDependencies.listFiles();
|
engineClassLoader = new NarClassLoader(statelessNarWorkingDir, statelessClassLoader);
|
||||||
if (statelessNarContents == null || statelessNarContents.length == 0) {
|
} catch (final ClassNotFoundException e) {
|
||||||
throw new IOException("Could not access contents of Stateless NAR dependencies at " + statelessNarDependencies);
|
throw new IOException("Could not create NarClassLoader for Stateless NAR located at " + statelessNarWorkingDir.getAbsolutePath(), e);
|
||||||
}
|
}
|
||||||
|
|
||||||
final List<URL> urls = new ArrayList<>();
|
|
||||||
final List<String> filenames = new ArrayList<>();
|
|
||||||
for (final File dependency : statelessNarContents) {
|
|
||||||
final URL url = dependency.toURI().toURL();
|
|
||||||
urls.add(url);
|
|
||||||
filenames.add(dependency.getName());
|
|
||||||
}
|
|
||||||
|
|
||||||
logger.info("Creating Stateless Bootstrap with the following files in the classpath: {}", filenames);
|
|
||||||
|
|
||||||
final URL[] urlArray = urls.toArray(new URL[0]);
|
|
||||||
final BlockListClassLoader extensionClassLoader = createExtensionRootClassLoader(narDirectory, rootClassLoader);
|
|
||||||
|
|
||||||
final Set<String> classesBlockedExtensions = extensionClassLoader.getClassesBlocked();
|
|
||||||
|
|
||||||
// For the engine ClassLoader, we also want to block everything that we block for extensions except for the classes
|
|
||||||
// that the engine needs specifically (i.e., the classes in the stateless engine nar). We do this because there are some
|
|
||||||
// classes that may need to be shared between the bootstrap and the caller. For example, VersionedFlowSnapshot.
|
|
||||||
final URLClassLoader engineUrlClassLoader = new URLClassLoader(urlArray, rootClassLoader);
|
|
||||||
final Set<String> engineSpecificClassNames = new HashSet<>();
|
|
||||||
final Set<String> engineSpecificFiles = new HashSet<>();
|
|
||||||
findClassNamesInJars(urls, engineSpecificClassNames, engineSpecificFiles);
|
|
||||||
|
|
||||||
final Set<String> classesBlockedEngine = new HashSet<>(classesBlockedExtensions);
|
|
||||||
classesBlockedEngine.removeAll(engineSpecificClassNames);
|
|
||||||
|
|
||||||
logger.debug("Blocking the following classes from being loaded from parent {} for Engine by Stateless ClassLoaders: {}", engineUrlClassLoader, classesBlockedEngine);
|
|
||||||
logger.debug("Blocking the following files from being loaded from parent {} for Engine by Stateless ClassLoaders: {}", engineUrlClassLoader, engineSpecificFiles);
|
|
||||||
|
|
||||||
final BlockListClassLoader engineClassLoader = new BlockListClassLoader(engineUrlClassLoader, classesBlockedEngine);
|
|
||||||
|
|
||||||
Thread.currentThread().setContextClassLoader(engineClassLoader);
|
Thread.currentThread().setContextClassLoader(engineClassLoader);
|
||||||
return new StatelessBootstrap(engineClassLoader, extensionClassLoader, engineConfiguration);
|
return new StatelessBootstrap(engineClassLoader, statelessClassLoader, engineConfiguration);
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
|
|
|
@ -30,10 +30,10 @@ import org.apache.nifi.stateless.engine.StatelessEngine;
|
||||||
import java.util.Map;
|
import java.util.Map;
|
||||||
|
|
||||||
public class StatelessReportingContext extends AbstractReportingContext implements ReportingContext {
|
public class StatelessReportingContext extends AbstractReportingContext implements ReportingContext {
|
||||||
private final StatelessEngine<?> statelessEngine;
|
private final StatelessEngine statelessEngine;
|
||||||
private final FlowManager flowManager;
|
private final FlowManager flowManager;
|
||||||
|
|
||||||
public StatelessReportingContext(final StatelessEngine<?> statelessEngine, final FlowManager flowManager,
|
public StatelessReportingContext(final StatelessEngine statelessEngine, final FlowManager flowManager,
|
||||||
final Map<PropertyDescriptor, String> properties, final ReportingTask reportingTask,
|
final Map<PropertyDescriptor, String> properties, final ReportingTask reportingTask,
|
||||||
final VariableRegistry variableRegistry, final ParameterLookup parameterLookup) {
|
final VariableRegistry variableRegistry, final ParameterLookup parameterLookup) {
|
||||||
super(reportingTask, statelessEngine.getBulletinRepository(), properties, statelessEngine.getControllerServiceProvider(), parameterLookup, variableRegistry);
|
super(reportingTask, statelessEngine.getBulletinRepository(), properties, statelessEngine.getControllerServiceProvider(), parameterLookup, variableRegistry);
|
||||||
|
|
|
@ -35,9 +35,9 @@ import org.apache.nifi.stateless.engine.StatelessEngine;
|
||||||
|
|
||||||
public class StatelessReportingTaskNode extends AbstractReportingTaskNode implements ReportingTaskNode {
|
public class StatelessReportingTaskNode extends AbstractReportingTaskNode implements ReportingTaskNode {
|
||||||
private final FlowManager flowManager;
|
private final FlowManager flowManager;
|
||||||
private final StatelessEngine<?> statelessEngine;
|
private final StatelessEngine statelessEngine;
|
||||||
|
|
||||||
public StatelessReportingTaskNode(final LoggableComponent<ReportingTask> reportingTask, final String id, final StatelessEngine<?> statelessEngine,
|
public StatelessReportingTaskNode(final LoggableComponent<ReportingTask> reportingTask, final String id, final StatelessEngine statelessEngine,
|
||||||
final FlowManager flowManager, final ProcessScheduler processScheduler, final ValidationContextFactory validationContextFactory,
|
final FlowManager flowManager, final ProcessScheduler processScheduler, final ValidationContextFactory validationContextFactory,
|
||||||
final ComponentVariableRegistry variableRegistry, final ReloadComponent reloadComponent, final ExtensionManager extensionManager,
|
final ComponentVariableRegistry variableRegistry, final ReloadComponent reloadComponent, final ExtensionManager extensionManager,
|
||||||
final ValidationTrigger validationTrigger) {
|
final ValidationTrigger validationTrigger) {
|
||||||
|
|
|
@ -104,7 +104,7 @@ public class StatelessProcessScheduler implements ProcessScheduler {
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
public void initialize(final ProcessContextFactory processContextFactory, final DataflowDefinition<?> dataflowDefinition) {
|
public void initialize(final ProcessContextFactory processContextFactory, final DataflowDefinition dataflowDefinition) {
|
||||||
this.processContextFactory = processContextFactory;
|
this.processContextFactory = processContextFactory;
|
||||||
|
|
||||||
final String threadNameSuffix = dataflowDefinition.getFlowName() == null ? "" : " for dataflow " + dataflowDefinition.getFlowName();
|
final String threadNameSuffix = dataflowDefinition.getFlowName() == null ? "" : " for dataflow " + dataflowDefinition.getFlowName();
|
||||||
|
|
|
@ -18,6 +18,10 @@
|
||||||
package org.apache.nifi.registry.flow;
|
package org.apache.nifi.registry.flow;
|
||||||
|
|
||||||
import org.apache.nifi.authorization.user.NiFiUser;
|
import org.apache.nifi.authorization.user.NiFiUser;
|
||||||
|
import org.apache.nifi.flow.ExternalControllerServiceReference;
|
||||||
|
import org.apache.nifi.flow.VersionedExternalFlow;
|
||||||
|
import org.apache.nifi.flow.VersionedExternalFlowMetadata;
|
||||||
|
import org.apache.nifi.flow.VersionedParameterContext;
|
||||||
import org.apache.nifi.flow.VersionedProcessGroup;
|
import org.apache.nifi.flow.VersionedProcessGroup;
|
||||||
import org.apache.nifi.registry.bucket.Bucket;
|
import org.apache.nifi.registry.bucket.Bucket;
|
||||||
import org.apache.nifi.registry.client.NiFiRegistryException;
|
import org.apache.nifi.registry.client.NiFiRegistryException;
|
||||||
|
@ -40,7 +44,7 @@ public class InMemoryFlowRegistry implements FlowRegistry {
|
||||||
private volatile String name;
|
private volatile String name;
|
||||||
private volatile String url;
|
private volatile String url;
|
||||||
|
|
||||||
private final Map<FlowCoordinates, List<VersionedFlowSnapshot>> flowSnapshots = new ConcurrentHashMap<>();
|
private final Map<FlowCoordinates, List<VersionedExternalFlow>> flowSnapshots = new ConcurrentHashMap<>();
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public String getIdentifier() {
|
public String getIdentifier() {
|
||||||
|
@ -109,9 +113,9 @@ public class InMemoryFlowRegistry implements FlowRegistry {
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public VersionedFlowSnapshot registerVersionedFlowSnapshot(final VersionedFlow flow, final VersionedProcessGroup snapshot,
|
public VersionedFlowSnapshot registerVersionedFlowSnapshot(final VersionedFlow flow, final VersionedProcessGroup snapshot,
|
||||||
final Map<String, ExternalControllerServiceReference> externalControllerServices,
|
final Map<String, ExternalControllerServiceReference> externalControllerServices,
|
||||||
final Map<String, VersionedParameterContext> parameterContexts, final String comments,
|
final Map<String, VersionedParameterContext> parameterContexts, final String comments,
|
||||||
final int expectedVersion, final NiFiUser user) {
|
final int expectedVersion, final NiFiUser user) {
|
||||||
throw new UnsupportedOperationException(USER_SPECIFIC_ACTIONS_NOT_SUPPORTED);
|
throw new UnsupportedOperationException(USER_SPECIFIC_ACTIONS_NOT_SUPPORTED);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -133,21 +137,44 @@ public class InMemoryFlowRegistry implements FlowRegistry {
|
||||||
@Override
|
@Override
|
||||||
public VersionedFlowSnapshot getFlowContents(final String bucketId, final String flowId, final int version, final boolean fetchRemoteFlows) throws NiFiRegistryException {
|
public VersionedFlowSnapshot getFlowContents(final String bucketId, final String flowId, final int version, final boolean fetchRemoteFlows) throws NiFiRegistryException {
|
||||||
final FlowCoordinates flowCoordinates = new FlowCoordinates(bucketId, flowId);
|
final FlowCoordinates flowCoordinates = new FlowCoordinates(bucketId, flowId);
|
||||||
final List<VersionedFlowSnapshot> snapshots = flowSnapshots.get(flowCoordinates);
|
final List<VersionedExternalFlow> snapshots = flowSnapshots.get(flowCoordinates);
|
||||||
|
|
||||||
final VersionedFlowSnapshot versionedFlowSnapshot = snapshots.stream()
|
final VersionedExternalFlow versionedExternalFlow = snapshots.stream()
|
||||||
.filter(snapshot -> snapshot.getSnapshotMetadata().getVersion() == version)
|
.filter(snapshot -> snapshot.getMetadata().getVersion() == version)
|
||||||
.findAny()
|
.findAny()
|
||||||
.orElseThrow(() -> new NiFiRegistryException("Could not find flow: bucketId=" + bucketId + ", flowId=" + flowId + ", version=" + version));
|
.orElseThrow(() -> new NiFiRegistryException("Could not find flow: bucketId=" + bucketId + ", flowId=" + flowId + ", version=" + version));
|
||||||
|
|
||||||
|
final VersionedFlowSnapshot versionedFlowSnapshot = convertToVersionedFlowSnapshot(versionedExternalFlow);
|
||||||
return versionedFlowSnapshot;
|
return versionedFlowSnapshot;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
private VersionedFlowSnapshot convertToVersionedFlowSnapshot(final VersionedExternalFlow externalFlow) {
|
||||||
|
final VersionedExternalFlowMetadata externalFlowMetadata = externalFlow.getMetadata();
|
||||||
|
|
||||||
|
final VersionedFlowSnapshotMetadata snapshotMetadata = new VersionedFlowSnapshotMetadata();
|
||||||
|
snapshotMetadata.setBucketIdentifier(externalFlowMetadata.getBucketIdentifier());
|
||||||
|
snapshotMetadata.setVersion(externalFlowMetadata.getVersion());
|
||||||
|
snapshotMetadata.setFlowIdentifier(externalFlowMetadata.getFlowIdentifier());
|
||||||
|
|
||||||
|
final VersionedFlow versionedFlow = new VersionedFlow();
|
||||||
|
versionedFlow.setName(externalFlowMetadata.getFlowName());
|
||||||
|
versionedFlow.setIdentifier(externalFlowMetadata.getFlowIdentifier());
|
||||||
|
versionedFlow.setBucketIdentifier(externalFlowMetadata.getBucketIdentifier());
|
||||||
|
|
||||||
|
final VersionedFlowSnapshot flowSnapshot = new VersionedFlowSnapshot();
|
||||||
|
flowSnapshot.setExternalControllerServices(externalFlow.getExternalControllerServices());
|
||||||
|
flowSnapshot.setFlowContents(externalFlow.getFlowContents());
|
||||||
|
flowSnapshot.setParameterContexts(externalFlow.getParameterContexts());
|
||||||
|
flowSnapshot.setSnapshotMetadata(snapshotMetadata);
|
||||||
|
flowSnapshot.setFlow(versionedFlow);
|
||||||
|
|
||||||
|
return flowSnapshot;
|
||||||
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public VersionedFlow getVersionedFlow(final String bucketId, final String flowId) {
|
public VersionedFlow getVersionedFlow(final String bucketId, final String flowId) {
|
||||||
final FlowCoordinates flowCoordinates = new FlowCoordinates(bucketId, flowId);
|
final FlowCoordinates flowCoordinates = new FlowCoordinates(bucketId, flowId);
|
||||||
final List<VersionedFlowSnapshot> snapshots = flowSnapshots.get(flowCoordinates);
|
final List<VersionedExternalFlow> snapshots = flowSnapshots.get(flowCoordinates);
|
||||||
|
|
||||||
final VersionedFlow versionedFlow = new VersionedFlow();
|
final VersionedFlow versionedFlow = new VersionedFlow();
|
||||||
versionedFlow.setBucketIdentifier(bucketId);
|
versionedFlow.setBucketIdentifier(bucketId);
|
||||||
|
@ -160,8 +187,8 @@ public class InMemoryFlowRegistry implements FlowRegistry {
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
public synchronized void addFlowSnapshot(final VersionedFlowSnapshot flowSnapshot) {
|
public synchronized void addFlowSnapshot(final VersionedExternalFlow versionedExternalFlow) {
|
||||||
final VersionedFlowSnapshotMetadata metadata = flowSnapshot.getSnapshotMetadata();
|
final VersionedExternalFlowMetadata metadata = versionedExternalFlow.getMetadata();
|
||||||
final String bucketId;
|
final String bucketId;
|
||||||
final String flowId;
|
final String flowId;
|
||||||
final int version;
|
final int version;
|
||||||
|
@ -177,16 +204,16 @@ public class InMemoryFlowRegistry implements FlowRegistry {
|
||||||
|
|
||||||
final FlowCoordinates coordinates = new FlowCoordinates(bucketId, flowId);
|
final FlowCoordinates coordinates = new FlowCoordinates(bucketId, flowId);
|
||||||
|
|
||||||
final List<VersionedFlowSnapshot> snapshots = flowSnapshots.computeIfAbsent(coordinates, key -> Collections.synchronizedList(new ArrayList<>()));
|
final List<VersionedExternalFlow> snapshots = flowSnapshots.computeIfAbsent(coordinates, key -> Collections.synchronizedList(new ArrayList<>()));
|
||||||
final Optional<VersionedFlowSnapshot> optionalSnapshot = snapshots.stream()
|
final Optional<VersionedExternalFlow> optionalSnapshot = snapshots.stream()
|
||||||
.filter(snapshot -> snapshot.getSnapshotMetadata().getVersion() == version)
|
.filter(snapshot -> snapshot.getMetadata().getVersion() == version)
|
||||||
.findAny();
|
.findAny();
|
||||||
|
|
||||||
if (optionalSnapshot.isPresent()) {
|
if (optionalSnapshot.isPresent()) {
|
||||||
throw new IllegalStateException("Versioned Flow Snapshot already exists for bucketId=" + bucketId + ", flowId=" + flowId + ", version=" + version);
|
throw new IllegalStateException("Versioned Flow Snapshot already exists for bucketId=" + bucketId + ", flowId=" + flowId + ", version=" + version);
|
||||||
}
|
}
|
||||||
|
|
||||||
snapshots.add(flowSnapshot);
|
snapshots.add(versionedExternalFlow);
|
||||||
}
|
}
|
||||||
|
|
||||||
private static class FlowCoordinates {
|
private static class FlowCoordinates {
|
||||||
|
|
|
@ -24,7 +24,9 @@ import okhttp3.OkHttpClient;
|
||||||
import okhttp3.Request;
|
import okhttp3.Request;
|
||||||
import okhttp3.Response;
|
import okhttp3.Response;
|
||||||
import okhttp3.ResponseBody;
|
import okhttp3.ResponseBody;
|
||||||
|
import org.apache.nifi.flow.VersionedExternalFlow;
|
||||||
import org.apache.nifi.processor.DataUnit;
|
import org.apache.nifi.processor.DataUnit;
|
||||||
|
import org.apache.nifi.registry.VersionedFlowConverter;
|
||||||
import org.apache.nifi.registry.client.NiFiRegistryException;
|
import org.apache.nifi.registry.client.NiFiRegistryException;
|
||||||
import org.apache.nifi.registry.flow.VersionedFlowSnapshot;
|
import org.apache.nifi.registry.flow.VersionedFlowSnapshot;
|
||||||
import org.apache.nifi.registry.flow.VersionedFlowSnapshotMetadata;
|
import org.apache.nifi.registry.flow.VersionedFlowSnapshotMetadata;
|
||||||
|
@ -98,13 +100,13 @@ public class PropertiesFileFlowDefinitionParser implements DataflowDefinitionPar
|
||||||
private static final String TRANSACTION_THRESHOLD_TIME = "nifi.stateless.transaction.thresholds.time";
|
private static final String TRANSACTION_THRESHOLD_TIME = "nifi.stateless.transaction.thresholds.time";
|
||||||
|
|
||||||
|
|
||||||
public DataflowDefinition<VersionedFlowSnapshot> parseFlowDefinition(final File propertiesFile, final StatelessEngineConfiguration engineConfig, final List<ParameterOverride> parameterOverrides)
|
public DataflowDefinition parseFlowDefinition(final File propertiesFile, final StatelessEngineConfiguration engineConfig, final List<ParameterOverride> parameterOverrides)
|
||||||
throws IOException, StatelessConfigurationException {
|
throws IOException, StatelessConfigurationException {
|
||||||
final Map<String, String> properties = readPropertyValues(propertiesFile);
|
final Map<String, String> properties = readPropertyValues(propertiesFile);
|
||||||
return parseFlowDefinition(properties, engineConfig, parameterOverrides);
|
return parseFlowDefinition(properties, engineConfig, parameterOverrides);
|
||||||
}
|
}
|
||||||
|
|
||||||
public DataflowDefinition<VersionedFlowSnapshot> parseFlowDefinition(final Map<String, String> properties, final StatelessEngineConfiguration engineConfig,
|
public DataflowDefinition parseFlowDefinition(final Map<String, String> properties, final StatelessEngineConfiguration engineConfig,
|
||||||
final List<ParameterOverride> parameterOverrides) throws IOException, StatelessConfigurationException {
|
final List<ParameterOverride> parameterOverrides) throws IOException, StatelessConfigurationException {
|
||||||
|
|
||||||
// A common problem is users accidentally including whitespace at the beginning or end of property values.
|
// A common problem is users accidentally including whitespace at the beginning or end of property values.
|
||||||
|
@ -115,17 +117,16 @@ public class PropertiesFileFlowDefinitionParser implements DataflowDefinitionPar
|
||||||
|
|
||||||
final Set<String> failurePortNames = getFailurePortNames(properties);
|
final Set<String> failurePortNames = getFailurePortNames(properties);
|
||||||
final VersionedFlowSnapshot flowSnapshot = fetchVersionedFlowSnapshot(properties, engineConfig.getSslContext());
|
final VersionedFlowSnapshot flowSnapshot = fetchVersionedFlowSnapshot(properties, engineConfig.getSslContext());
|
||||||
|
final VersionedExternalFlow externalFlow = VersionedFlowConverter.createVersionedExternalFlow(flowSnapshot);
|
||||||
final List<ParameterContextDefinition> parameterContextDefinitions = getParameterContexts(properties);
|
final List<ParameterContextDefinition> parameterContextDefinitions = getParameterContexts(properties);
|
||||||
final List<ReportingTaskDefinition> reportingTaskDefinitions = getReportingTasks(properties);
|
final List<ReportingTaskDefinition> reportingTaskDefinitions = getReportingTasks(properties);
|
||||||
final List<ParameterValueProviderDefinition> parameterValueProviderDefinitions = getParameterValueProviders(properties, parameterOverrides);
|
final List<ParameterValueProviderDefinition> parameterValueProviderDefinitions = getParameterValueProviders(properties, parameterOverrides);
|
||||||
final TransactionThresholds transactionThresholds = getTransactionThresholds(properties);
|
final TransactionThresholds transactionThresholds = getTransactionThresholds(properties);
|
||||||
|
|
||||||
final String rootGroupName = flowSnapshot.getFlowContents().getName();
|
final String flowName = properties.getOrDefault(FLOW_NAME, externalFlow.getMetadata().getFlowName());
|
||||||
final String flowName = properties.getOrDefault(FLOW_NAME, rootGroupName);
|
|
||||||
|
|
||||||
return new StandardDataflowDefinition.Builder()
|
return new StandardDataflowDefinition.Builder()
|
||||||
.flowSnapshot(flowSnapshot)
|
.versionedExternalFlow(externalFlow)
|
||||||
.flowName(flowName)
|
|
||||||
.failurePortNames(failurePortNames)
|
.failurePortNames(failurePortNames)
|
||||||
.parameterContexts(parameterContextDefinitions)
|
.parameterContexts(parameterContextDefinitions)
|
||||||
.reportingTasks(reportingTaskDefinitions)
|
.reportingTasks(reportingTaskDefinitions)
|
||||||
|
@ -480,6 +481,7 @@ public class PropertiesFileFlowDefinitionParser implements DataflowDefinitionPar
|
||||||
return envValue == null ? "" : envValue;
|
return envValue == null ? "" : envValue;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
private VersionedFlowSnapshot fetchVersionedFlowSnapshot(final Map<String, String> properties, final SslContextDefinition sslContextDefinition)
|
private VersionedFlowSnapshot fetchVersionedFlowSnapshot(final Map<String, String> properties, final SslContextDefinition sslContextDefinition)
|
||||||
throws IOException, StatelessConfigurationException {
|
throws IOException, StatelessConfigurationException {
|
||||||
|
|
||||||
|
|
|
@ -56,7 +56,6 @@ import org.apache.nifi.processor.StandardProcessorInitializationContext;
|
||||||
import org.apache.nifi.processor.StandardValidationContextFactory;
|
import org.apache.nifi.processor.StandardValidationContextFactory;
|
||||||
import org.apache.nifi.registry.ComponentVariableRegistry;
|
import org.apache.nifi.registry.ComponentVariableRegistry;
|
||||||
import org.apache.nifi.registry.VariableRegistry;
|
import org.apache.nifi.registry.VariableRegistry;
|
||||||
import org.apache.nifi.registry.flow.VersionedFlowSnapshot;
|
|
||||||
import org.apache.nifi.registry.variable.StandardComponentVariableRegistry;
|
import org.apache.nifi.registry.variable.StandardComponentVariableRegistry;
|
||||||
import org.apache.nifi.reporting.ReportingInitializationContext;
|
import org.apache.nifi.reporting.ReportingInitializationContext;
|
||||||
import org.apache.nifi.reporting.ReportingTask;
|
import org.apache.nifi.reporting.ReportingTask;
|
||||||
|
@ -74,14 +73,14 @@ import java.util.Set;
|
||||||
public class ComponentBuilder {
|
public class ComponentBuilder {
|
||||||
private static final Logger logger = LoggerFactory.getLogger(ComponentBuilder.class);
|
private static final Logger logger = LoggerFactory.getLogger(ComponentBuilder.class);
|
||||||
|
|
||||||
private StatelessEngine<VersionedFlowSnapshot> statelessEngine;
|
private StatelessEngine statelessEngine;
|
||||||
private FlowManager flowManager;
|
private FlowManager flowManager;
|
||||||
private String identifier;
|
private String identifier;
|
||||||
private String type;
|
private String type;
|
||||||
private BundleCoordinate bundleCoordinate;
|
private BundleCoordinate bundleCoordinate;
|
||||||
private Set<URL> additionalClassPathUrls;
|
private Set<URL> additionalClassPathUrls;
|
||||||
|
|
||||||
public ComponentBuilder statelessEngine(final StatelessEngine<VersionedFlowSnapshot> statelessEngine) {
|
public ComponentBuilder statelessEngine(final StatelessEngine statelessEngine) {
|
||||||
this.statelessEngine = statelessEngine;
|
this.statelessEngine = statelessEngine;
|
||||||
return this;
|
return this;
|
||||||
}
|
}
|
||||||
|
|
|
@ -43,6 +43,7 @@ import org.apache.nifi.controller.service.ControllerServiceProvider;
|
||||||
import org.apache.nifi.encrypt.PropertyEncryptor;
|
import org.apache.nifi.encrypt.PropertyEncryptor;
|
||||||
import org.apache.nifi.engine.FlowEngine;
|
import org.apache.nifi.engine.FlowEngine;
|
||||||
import org.apache.nifi.extensions.ExtensionRepository;
|
import org.apache.nifi.extensions.ExtensionRepository;
|
||||||
|
import org.apache.nifi.flow.VersionedExternalFlowMetadata;
|
||||||
import org.apache.nifi.flow.VersionedProcessGroup;
|
import org.apache.nifi.flow.VersionedProcessGroup;
|
||||||
import org.apache.nifi.groups.ProcessGroup;
|
import org.apache.nifi.groups.ProcessGroup;
|
||||||
import org.apache.nifi.logging.LogRepositoryFactory;
|
import org.apache.nifi.logging.LogRepositoryFactory;
|
||||||
|
@ -57,8 +58,6 @@ import org.apache.nifi.processor.StandardValidationContext;
|
||||||
import org.apache.nifi.provenance.ProvenanceRepository;
|
import org.apache.nifi.provenance.ProvenanceRepository;
|
||||||
import org.apache.nifi.registry.VariableRegistry;
|
import org.apache.nifi.registry.VariableRegistry;
|
||||||
import org.apache.nifi.registry.flow.FlowRegistryClient;
|
import org.apache.nifi.registry.flow.FlowRegistryClient;
|
||||||
import org.apache.nifi.registry.flow.VersionedFlow;
|
|
||||||
import org.apache.nifi.registry.flow.VersionedFlowSnapshot;
|
|
||||||
import org.apache.nifi.reporting.BulletinRepository;
|
import org.apache.nifi.reporting.BulletinRepository;
|
||||||
import org.apache.nifi.reporting.ReportingTask;
|
import org.apache.nifi.reporting.ReportingTask;
|
||||||
import org.apache.nifi.scheduling.SchedulingStrategy;
|
import org.apache.nifi.scheduling.SchedulingStrategy;
|
||||||
|
@ -98,7 +97,7 @@ import java.util.stream.Collectors;
|
||||||
|
|
||||||
import static java.util.Objects.requireNonNull;
|
import static java.util.Objects.requireNonNull;
|
||||||
|
|
||||||
public class StandardStatelessEngine implements StatelessEngine<VersionedFlowSnapshot> {
|
public class StandardStatelessEngine implements StatelessEngine {
|
||||||
private static final Logger logger = LoggerFactory.getLogger(StandardStatelessEngine.class);
|
private static final Logger logger = LoggerFactory.getLogger(StandardStatelessEngine.class);
|
||||||
private static final int CONCURRENT_EXTENSION_DOWNLOADS = 8;
|
private static final int CONCURRENT_EXTENSION_DOWNLOADS = 8;
|
||||||
public static final Duration DEFAULT_STATUS_TASK_PERIOD = Duration.of(1, ChronoUnit.MINUTES);
|
public static final Duration DEFAULT_STATUS_TASK_PERIOD = Duration.of(1, ChronoUnit.MINUTES);
|
||||||
|
@ -158,13 +157,14 @@ public class StandardStatelessEngine implements StatelessEngine<VersionedFlowSna
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public StatelessDataflow createFlow(final DataflowDefinition<VersionedFlowSnapshot> dataflowDefinition) {
|
public StatelessDataflow createFlow(final DataflowDefinition dataflowDefinition) {
|
||||||
if (!this.initialized) {
|
if (!this.initialized) {
|
||||||
throw new IllegalStateException("Cannot create Flow without first initializing Stateless Engine");
|
throw new IllegalStateException("Cannot create Flow without first initializing Stateless Engine");
|
||||||
}
|
}
|
||||||
|
|
||||||
final VersionedFlow versionedFlow = dataflowDefinition.getFlowSnapshot().getFlow();
|
final VersionedExternalFlowMetadata metadata = dataflowDefinition.getVersionedExternalFlow().getMetadata();
|
||||||
logger.info("Building Dataflow {}", versionedFlow == null ? "" : versionedFlow.getName());
|
final String flowName = metadata == null ? "" : metadata.getFlowName();
|
||||||
|
logger.info("Building Dataflow {}", flowName);
|
||||||
|
|
||||||
loadNecessaryExtensions(dataflowDefinition);
|
loadNecessaryExtensions(dataflowDefinition);
|
||||||
|
|
||||||
|
@ -178,7 +178,7 @@ public class StandardStatelessEngine implements StatelessEngine<VersionedFlowSna
|
||||||
rootGroup.addProcessGroup(childGroup);
|
rootGroup.addProcessGroup(childGroup);
|
||||||
|
|
||||||
LogRepositoryFactory.purge();
|
LogRepositoryFactory.purge();
|
||||||
childGroup.updateFlow(dataflowDefinition.getFlowSnapshot(), "stateless-component-id-seed", false, true, true);
|
childGroup.updateFlow(dataflowDefinition.getVersionedExternalFlow(), "stateless-component-id-seed", false, true, true);
|
||||||
|
|
||||||
final ParameterValueProvider parameterValueProvider = createParameterValueProvider(dataflowDefinition);
|
final ParameterValueProvider parameterValueProvider = createParameterValueProvider(dataflowDefinition);
|
||||||
|
|
||||||
|
@ -205,7 +205,7 @@ public class StandardStatelessEngine implements StatelessEngine<VersionedFlowSna
|
||||||
return dataflow;
|
return dataflow;
|
||||||
}
|
}
|
||||||
|
|
||||||
private ParameterValueProvider createParameterValueProvider(final DataflowDefinition<?> dataflowDefinition) {
|
private ParameterValueProvider createParameterValueProvider(final DataflowDefinition dataflowDefinition) {
|
||||||
// Create a Provider for each definition
|
// Create a Provider for each definition
|
||||||
final List<ParameterValueProvider> providers = new ArrayList<>();
|
final List<ParameterValueProvider> providers = new ArrayList<>();
|
||||||
for (final ParameterValueProviderDefinition definition : dataflowDefinition.getParameterValueProviderDefinitions()) {
|
for (final ParameterValueProviderDefinition definition : dataflowDefinition.getParameterValueProviderDefinitions()) {
|
||||||
|
@ -300,8 +300,8 @@ public class StandardStatelessEngine implements StatelessEngine<VersionedFlowSna
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
private void loadNecessaryExtensions(final DataflowDefinition<VersionedFlowSnapshot> dataflowDefinition) {
|
private void loadNecessaryExtensions(final DataflowDefinition dataflowDefinition) {
|
||||||
final VersionedProcessGroup group = dataflowDefinition.getFlowSnapshot().getFlowContents();
|
final VersionedProcessGroup group = dataflowDefinition.getVersionedExternalFlow().getFlowContents();
|
||||||
final Set<BundleCoordinate> requiredBundles = gatherRequiredBundles(group);
|
final Set<BundleCoordinate> requiredBundles = gatherRequiredBundles(group);
|
||||||
|
|
||||||
for (final ReportingTaskDefinition reportingTaskDefinition : dataflowDefinition.getReportingTaskDefinitions()) {
|
for (final ReportingTaskDefinition reportingTaskDefinition : dataflowDefinition.getReportingTaskDefinitions()) {
|
||||||
|
@ -380,7 +380,7 @@ public class StandardStatelessEngine implements StatelessEngine<VersionedFlowSna
|
||||||
return new BundleCoordinate(bundle.getGroup(), bundle.getArtifact(), bundle.getVersion());
|
return new BundleCoordinate(bundle.getGroup(), bundle.getArtifact(), bundle.getVersion());
|
||||||
}
|
}
|
||||||
|
|
||||||
private List<ReportingTaskNode> createReportingTasks(final DataflowDefinition<?> dataflowDefinition) {
|
private List<ReportingTaskNode> createReportingTasks(final DataflowDefinition dataflowDefinition) {
|
||||||
final List<ReportingTaskNode> reportingTaskNodes = new ArrayList<>();
|
final List<ReportingTaskNode> reportingTaskNodes = new ArrayList<>();
|
||||||
for (final ReportingTaskDefinition taskDefinition : dataflowDefinition.getReportingTaskDefinitions()) {
|
for (final ReportingTaskDefinition taskDefinition : dataflowDefinition.getReportingTaskDefinitions()) {
|
||||||
final ReportingTaskNode taskNode = createReportingTask(taskDefinition);
|
final ReportingTaskNode taskNode = createReportingTask(taskDefinition);
|
||||||
|
|
|
@ -37,11 +37,11 @@ import org.apache.nifi.stateless.flow.StatelessDataflow;
|
||||||
|
|
||||||
import java.time.Duration;
|
import java.time.Duration;
|
||||||
|
|
||||||
public interface StatelessEngine<T> {
|
public interface StatelessEngine {
|
||||||
|
|
||||||
void initialize(StatelessEngineInitializationContext initializationContext);
|
void initialize(StatelessEngineInitializationContext initializationContext);
|
||||||
|
|
||||||
StatelessDataflow createFlow(DataflowDefinition<T> dataflowDefinition);
|
StatelessDataflow createFlow(DataflowDefinition dataflowDefinition);
|
||||||
|
|
||||||
ExtensionManager getExtensionManager();
|
ExtensionManager getExtensionManager();
|
||||||
|
|
||||||
|
|
|
@ -65,7 +65,6 @@ import org.apache.nifi.nar.NarCloseable;
|
||||||
import org.apache.nifi.parameter.ParameterContextManager;
|
import org.apache.nifi.parameter.ParameterContextManager;
|
||||||
import org.apache.nifi.processor.Relationship;
|
import org.apache.nifi.processor.Relationship;
|
||||||
import org.apache.nifi.processor.StandardProcessContext;
|
import org.apache.nifi.processor.StandardProcessContext;
|
||||||
import org.apache.nifi.registry.flow.VersionedFlowSnapshot;
|
|
||||||
import org.apache.nifi.registry.variable.MutableVariableRegistry;
|
import org.apache.nifi.registry.variable.MutableVariableRegistry;
|
||||||
import org.apache.nifi.remote.StandardRemoteProcessGroup;
|
import org.apache.nifi.remote.StandardRemoteProcessGroup;
|
||||||
import org.apache.nifi.reporting.BulletinRepository;
|
import org.apache.nifi.reporting.BulletinRepository;
|
||||||
|
@ -91,12 +90,12 @@ import static java.util.Objects.requireNonNull;
|
||||||
public class StatelessFlowManager extends AbstractFlowManager implements FlowManager {
|
public class StatelessFlowManager extends AbstractFlowManager implements FlowManager {
|
||||||
private static final Logger logger = LoggerFactory.getLogger(StatelessFlowManager.class);
|
private static final Logger logger = LoggerFactory.getLogger(StatelessFlowManager.class);
|
||||||
|
|
||||||
private final StatelessEngine<VersionedFlowSnapshot> statelessEngine;
|
private final StatelessEngine statelessEngine;
|
||||||
private final SSLContext sslContext;
|
private final SSLContext sslContext;
|
||||||
private final BulletinRepository bulletinRepository;
|
private final BulletinRepository bulletinRepository;
|
||||||
|
|
||||||
public StatelessFlowManager(final FlowFileEventRepository flowFileEventRepository, final ParameterContextManager parameterContextManager,
|
public StatelessFlowManager(final FlowFileEventRepository flowFileEventRepository, final ParameterContextManager parameterContextManager,
|
||||||
final StatelessEngine<VersionedFlowSnapshot> statelessEngine, final BooleanSupplier flowInitializedCheck,
|
final StatelessEngine statelessEngine, final BooleanSupplier flowInitializedCheck,
|
||||||
final SSLContext sslContext, final BulletinRepository bulletinRepository) {
|
final SSLContext sslContext, final BulletinRepository bulletinRepository) {
|
||||||
super(flowFileEventRepository, parameterContextManager, statelessEngine.getFlowRegistryClient(), flowInitializedCheck);
|
super(flowFileEventRepository, parameterContextManager, statelessEngine.getFlowRegistryClient(), flowInitializedCheck);
|
||||||
|
|
||||||
|
|
|
@ -29,7 +29,6 @@ import org.apache.nifi.controller.ReportingTaskNode;
|
||||||
import org.apache.nifi.controller.TerminationAwareLogger;
|
import org.apache.nifi.controller.TerminationAwareLogger;
|
||||||
import org.apache.nifi.controller.exception.ControllerServiceInstantiationException;
|
import org.apache.nifi.controller.exception.ControllerServiceInstantiationException;
|
||||||
import org.apache.nifi.controller.exception.ProcessorInstantiationException;
|
import org.apache.nifi.controller.exception.ProcessorInstantiationException;
|
||||||
import org.apache.nifi.controller.reporting.ReportingTaskInstantiationException;
|
|
||||||
import org.apache.nifi.controller.service.ControllerServiceInvocationHandler;
|
import org.apache.nifi.controller.service.ControllerServiceInvocationHandler;
|
||||||
import org.apache.nifi.controller.service.ControllerServiceNode;
|
import org.apache.nifi.controller.service.ControllerServiceNode;
|
||||||
import org.apache.nifi.controller.service.StandardConfigurationContext;
|
import org.apache.nifi.controller.service.StandardConfigurationContext;
|
||||||
|
@ -40,7 +39,6 @@ import org.apache.nifi.nar.NarCloseable;
|
||||||
import org.apache.nifi.processor.Processor;
|
import org.apache.nifi.processor.Processor;
|
||||||
import org.apache.nifi.processor.SimpleProcessLogger;
|
import org.apache.nifi.processor.SimpleProcessLogger;
|
||||||
import org.apache.nifi.processor.StandardProcessContext;
|
import org.apache.nifi.processor.StandardProcessContext;
|
||||||
import org.apache.nifi.registry.flow.VersionedFlowSnapshot;
|
|
||||||
import org.apache.nifi.reporting.ReportingTask;
|
import org.apache.nifi.reporting.ReportingTask;
|
||||||
import org.apache.nifi.util.ReflectionUtils;
|
import org.apache.nifi.util.ReflectionUtils;
|
||||||
import org.slf4j.Logger;
|
import org.slf4j.Logger;
|
||||||
|
@ -52,9 +50,9 @@ import java.util.Set;
|
||||||
public class StatelessReloadComponent implements ReloadComponent {
|
public class StatelessReloadComponent implements ReloadComponent {
|
||||||
private static final Logger logger = LoggerFactory.getLogger(StatelessReloadComponent.class);
|
private static final Logger logger = LoggerFactory.getLogger(StatelessReloadComponent.class);
|
||||||
|
|
||||||
private final StatelessEngine<VersionedFlowSnapshot> statelessEngine;
|
private final StatelessEngine statelessEngine;
|
||||||
|
|
||||||
public StatelessReloadComponent(final StatelessEngine<VersionedFlowSnapshot> statelessEngine) {
|
public StatelessReloadComponent(final StatelessEngine statelessEngine) {
|
||||||
this.statelessEngine = statelessEngine;
|
this.statelessEngine = statelessEngine;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -169,7 +167,7 @@ public class StatelessReloadComponent implements ReloadComponent {
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public void reload(final ReportingTaskNode existingNode, final String newType, final BundleCoordinate bundleCoordinate, final Set<URL> additionalUrls) throws ReportingTaskInstantiationException {
|
public void reload(final ReportingTaskNode existingNode, final String newType, final BundleCoordinate bundleCoordinate, final Set<URL> additionalUrls) {
|
||||||
if (existingNode == null) {
|
if (existingNode == null) {
|
||||||
throw new IllegalStateException("Existing ReportingTaskNode cannot be null");
|
throw new IllegalStateException("Existing ReportingTaskNode cannot be null");
|
||||||
}
|
}
|
||||||
|
|
|
@ -19,10 +19,10 @@ package org.apache.nifi.stateless.flow;
|
||||||
|
|
||||||
import org.apache.nifi.flow.Bundle;
|
import org.apache.nifi.flow.Bundle;
|
||||||
import org.apache.nifi.flow.VersionedControllerService;
|
import org.apache.nifi.flow.VersionedControllerService;
|
||||||
|
import org.apache.nifi.flow.VersionedExternalFlow;
|
||||||
import org.apache.nifi.flow.VersionedPort;
|
import org.apache.nifi.flow.VersionedPort;
|
||||||
import org.apache.nifi.flow.VersionedProcessGroup;
|
import org.apache.nifi.flow.VersionedProcessGroup;
|
||||||
import org.apache.nifi.flow.VersionedProcessor;
|
import org.apache.nifi.flow.VersionedProcessor;
|
||||||
import org.apache.nifi.registry.flow.VersionedFlowSnapshot;
|
|
||||||
import org.apache.nifi.stateless.config.ParameterContextDefinition;
|
import org.apache.nifi.stateless.config.ParameterContextDefinition;
|
||||||
import org.apache.nifi.stateless.config.ParameterValueProviderDefinition;
|
import org.apache.nifi.stateless.config.ParameterValueProviderDefinition;
|
||||||
import org.apache.nifi.stateless.config.ReportingTaskDefinition;
|
import org.apache.nifi.stateless.config.ReportingTaskDefinition;
|
||||||
|
@ -35,33 +35,31 @@ import java.util.stream.Collectors;
|
||||||
|
|
||||||
import static java.util.Objects.requireNonNull;
|
import static java.util.Objects.requireNonNull;
|
||||||
|
|
||||||
public class StandardDataflowDefinition implements DataflowDefinition<VersionedFlowSnapshot> {
|
public class StandardDataflowDefinition implements DataflowDefinition {
|
||||||
private final VersionedFlowSnapshot flowSnapshot;
|
private final VersionedExternalFlow versionedExternalFlow;
|
||||||
private final Set<String> failurePortNames;
|
private final Set<String> failurePortNames;
|
||||||
private final List<ParameterContextDefinition> parameterContexts;
|
private final List<ParameterContextDefinition> parameterContexts;
|
||||||
private final List<ReportingTaskDefinition> reportingTaskDefinitions;
|
private final List<ReportingTaskDefinition> reportingTaskDefinitions;
|
||||||
private final List<ParameterValueProviderDefinition> parameterValueProviderDefinitions;
|
private final List<ParameterValueProviderDefinition> parameterValueProviderDefinitions;
|
||||||
private final TransactionThresholds transactionThresholds;
|
private final TransactionThresholds transactionThresholds;
|
||||||
private final String flowName;
|
|
||||||
|
|
||||||
private StandardDataflowDefinition(final Builder builder) {
|
private StandardDataflowDefinition(final Builder builder) {
|
||||||
flowSnapshot = requireNonNull(builder.flowSnapshot, "Flow Snapshot must be provided");
|
versionedExternalFlow = requireNonNull(builder.versionedExternalFlow, "Flow Snapshot must be provided");
|
||||||
failurePortNames = builder.failurePortNames == null ? Collections.emptySet() : builder.failurePortNames;
|
failurePortNames = builder.failurePortNames == null ? Collections.emptySet() : builder.failurePortNames;
|
||||||
parameterContexts = builder.parameterContexts == null ? Collections.emptyList() : builder.parameterContexts;
|
parameterContexts = builder.parameterContexts == null ? Collections.emptyList() : builder.parameterContexts;
|
||||||
reportingTaskDefinitions = builder.reportingTaskDefinitions == null ? Collections.emptyList() : builder.reportingTaskDefinitions;
|
reportingTaskDefinitions = builder.reportingTaskDefinitions == null ? Collections.emptyList() : builder.reportingTaskDefinitions;
|
||||||
transactionThresholds = builder.transactionThresholds == null ? TransactionThresholds.SINGLE_FLOWFILE : builder.transactionThresholds;
|
transactionThresholds = builder.transactionThresholds == null ? TransactionThresholds.SINGLE_FLOWFILE : builder.transactionThresholds;
|
||||||
parameterValueProviderDefinitions = builder.parameterValueProviderDefinitions == null ? Collections.emptyList() : builder.parameterValueProviderDefinitions;
|
parameterValueProviderDefinitions = builder.parameterValueProviderDefinitions == null ? Collections.emptyList() : builder.parameterValueProviderDefinitions;
|
||||||
flowName = builder.flowName;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public VersionedFlowSnapshot getFlowSnapshot() {
|
public VersionedExternalFlow getVersionedExternalFlow() {
|
||||||
return flowSnapshot;
|
return versionedExternalFlow;
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public String getFlowName() {
|
public String getFlowName() {
|
||||||
return flowName;
|
return versionedExternalFlow.getMetadata().getFlowName();
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
|
@ -71,14 +69,14 @@ public class StandardDataflowDefinition implements DataflowDefinition<VersionedF
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public Set<String> getInputPortNames() {
|
public Set<String> getInputPortNames() {
|
||||||
return flowSnapshot.getFlowContents().getInputPorts().stream()
|
return versionedExternalFlow.getFlowContents().getInputPorts().stream()
|
||||||
.map(VersionedPort::getName)
|
.map(VersionedPort::getName)
|
||||||
.collect(Collectors.toSet());
|
.collect(Collectors.toSet());
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public Set<String> getOutputPortNames() {
|
public Set<String> getOutputPortNames() {
|
||||||
return flowSnapshot.getFlowContents().getOutputPorts().stream()
|
return versionedExternalFlow.getFlowContents().getOutputPorts().stream()
|
||||||
.map(VersionedPort::getName)
|
.map(VersionedPort::getName)
|
||||||
.collect(Collectors.toSet());
|
.collect(Collectors.toSet());
|
||||||
}
|
}
|
||||||
|
@ -105,7 +103,7 @@ public class StandardDataflowDefinition implements DataflowDefinition<VersionedF
|
||||||
|
|
||||||
public Set<Bundle> getReferencedBundles() {
|
public Set<Bundle> getReferencedBundles() {
|
||||||
final Set<Bundle> referenced = new HashSet<>();
|
final Set<Bundle> referenced = new HashSet<>();
|
||||||
final VersionedProcessGroup rootGroup = flowSnapshot.getFlowContents();
|
final VersionedProcessGroup rootGroup = versionedExternalFlow.getFlowContents();
|
||||||
discoverReferencedBundles(rootGroup, referenced);
|
discoverReferencedBundles(rootGroup, referenced);
|
||||||
return referenced;
|
return referenced;
|
||||||
}
|
}
|
||||||
|
@ -125,21 +123,15 @@ public class StandardDataflowDefinition implements DataflowDefinition<VersionedF
|
||||||
}
|
}
|
||||||
|
|
||||||
public static class Builder {
|
public static class Builder {
|
||||||
private VersionedFlowSnapshot flowSnapshot;
|
private VersionedExternalFlow versionedExternalFlow;
|
||||||
private Set<String> failurePortNames;
|
private Set<String> failurePortNames;
|
||||||
private List<ParameterContextDefinition> parameterContexts;
|
private List<ParameterContextDefinition> parameterContexts;
|
||||||
private List<ReportingTaskDefinition> reportingTaskDefinitions;
|
private List<ReportingTaskDefinition> reportingTaskDefinitions;
|
||||||
private List<ParameterValueProviderDefinition> parameterValueProviderDefinitions;
|
private List<ParameterValueProviderDefinition> parameterValueProviderDefinitions;
|
||||||
private TransactionThresholds transactionThresholds;
|
private TransactionThresholds transactionThresholds;
|
||||||
private String flowName;
|
|
||||||
|
|
||||||
public Builder flowSnapshot(final VersionedFlowSnapshot flowSnapshot) {
|
public Builder versionedExternalFlow(final VersionedExternalFlow versionedExternalFlow) {
|
||||||
this.flowSnapshot = flowSnapshot;
|
this.versionedExternalFlow = versionedExternalFlow;
|
||||||
return this;
|
|
||||||
}
|
|
||||||
|
|
||||||
public Builder flowName(final String flowName) {
|
|
||||||
this.flowName = flowName;
|
|
||||||
return this;
|
return this;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -52,7 +52,6 @@ import org.apache.nifi.registry.VariableRegistry;
|
||||||
import org.apache.nifi.registry.flow.FlowRegistryClient;
|
import org.apache.nifi.registry.flow.FlowRegistryClient;
|
||||||
import org.apache.nifi.registry.flow.InMemoryFlowRegistry;
|
import org.apache.nifi.registry.flow.InMemoryFlowRegistry;
|
||||||
import org.apache.nifi.registry.flow.StandardFlowRegistryClient;
|
import org.apache.nifi.registry.flow.StandardFlowRegistryClient;
|
||||||
import org.apache.nifi.registry.flow.VersionedFlowSnapshot;
|
|
||||||
import org.apache.nifi.reporting.Bulletin;
|
import org.apache.nifi.reporting.Bulletin;
|
||||||
import org.apache.nifi.reporting.BulletinRepository;
|
import org.apache.nifi.reporting.BulletinRepository;
|
||||||
import org.apache.nifi.stateless.bootstrap.ExtensionDiscovery;
|
import org.apache.nifi.stateless.bootstrap.ExtensionDiscovery;
|
||||||
|
@ -88,17 +87,15 @@ import java.util.ArrayList;
|
||||||
import java.util.List;
|
import java.util.List;
|
||||||
import java.util.Optional;
|
import java.util.Optional;
|
||||||
|
|
||||||
public class StandardStatelessDataflowFactory implements StatelessDataflowFactory<VersionedFlowSnapshot> {
|
public class StandardStatelessDataflowFactory implements StatelessDataflowFactory {
|
||||||
private static final Logger logger = LoggerFactory.getLogger(StandardStatelessDataflowFactory.class);
|
private static final Logger logger = LoggerFactory.getLogger(StandardStatelessDataflowFactory.class);
|
||||||
|
|
||||||
@Override
|
|
||||||
public StatelessDataflow createDataflow(final StatelessEngineConfiguration engineConfiguration, final DataflowDefinition<VersionedFlowSnapshot> dataflowDefinition,
|
public StatelessDataflow createDataflow(final StatelessEngineConfiguration engineConfiguration, final DataflowDefinition dataflowDefinition,
|
||||||
final ClassLoader extensionRootClassLoader)
|
final ClassLoader extensionRootClassLoader)
|
||||||
throws IOException, StatelessConfigurationException {
|
throws IOException, StatelessConfigurationException {
|
||||||
final long start = System.currentTimeMillis();
|
final long start = System.currentTimeMillis();
|
||||||
|
|
||||||
final VersionedFlowSnapshot flowSnapshot = dataflowDefinition.getFlowSnapshot();
|
|
||||||
|
|
||||||
ProvenanceRepository provenanceRepo = null;
|
ProvenanceRepository provenanceRepo = null;
|
||||||
ContentRepository contentRepo = null;
|
ContentRepository contentRepo = null;
|
||||||
StatelessProcessScheduler processScheduler = null;
|
StatelessProcessScheduler processScheduler = null;
|
||||||
|
@ -114,7 +111,7 @@ public class StandardStatelessDataflowFactory implements StatelessDataflowFactor
|
||||||
}
|
}
|
||||||
|
|
||||||
final InMemoryFlowRegistry flowRegistry = new InMemoryFlowRegistry();
|
final InMemoryFlowRegistry flowRegistry = new InMemoryFlowRegistry();
|
||||||
flowRegistry.addFlowSnapshot(flowSnapshot);
|
flowRegistry.addFlowSnapshot(dataflowDefinition.getVersionedExternalFlow());
|
||||||
final FlowRegistryClient flowRegistryClient = new StandardFlowRegistryClient();
|
final FlowRegistryClient flowRegistryClient = new StandardFlowRegistryClient();
|
||||||
flowRegistryClient.addFlowRegistry(flowRegistry);
|
flowRegistryClient.addFlowRegistry(flowRegistry);
|
||||||
|
|
||||||
|
@ -184,7 +181,7 @@ public class StandardStatelessDataflowFactory implements StatelessDataflowFactor
|
||||||
System.setProperty("java.security.krb5.conf", krb5File.getAbsolutePath());
|
System.setProperty("java.security.krb5.conf", krb5File.getAbsolutePath());
|
||||||
}
|
}
|
||||||
|
|
||||||
final StatelessEngine<VersionedFlowSnapshot> statelessEngine = new StandardStatelessEngine.Builder()
|
final StatelessEngine statelessEngine = new StandardStatelessEngine.Builder()
|
||||||
.bulletinRepository(bulletinRepository)
|
.bulletinRepository(bulletinRepository)
|
||||||
.encryptor(lazyInitializedEncryptor)
|
.encryptor(lazyInitializedEncryptor)
|
||||||
.extensionManager(extensionManager)
|
.extensionManager(extensionManager)
|
||||||
|
|
|
@ -107,7 +107,7 @@ public class StandardStatelessFlow implements StatelessDataflow {
|
||||||
private final ProcessContextFactory processContextFactory;
|
private final ProcessContextFactory processContextFactory;
|
||||||
private final RepositoryContextFactory repositoryContextFactory;
|
private final RepositoryContextFactory repositoryContextFactory;
|
||||||
private final List<FlowFileQueue> internalFlowFileQueues;
|
private final List<FlowFileQueue> internalFlowFileQueues;
|
||||||
private final DataflowDefinition<?> dataflowDefinition;
|
private final DataflowDefinition dataflowDefinition;
|
||||||
private final StatelessStateManagerProvider stateManagerProvider;
|
private final StatelessStateManagerProvider stateManagerProvider;
|
||||||
private final ObjectMapper objectMapper = new ObjectMapper();
|
private final ObjectMapper objectMapper = new ObjectMapper();
|
||||||
private final ProcessScheduler processScheduler;
|
private final ProcessScheduler processScheduler;
|
||||||
|
@ -122,7 +122,7 @@ public class StandardStatelessFlow implements StatelessDataflow {
|
||||||
private volatile Boolean stateful = null;
|
private volatile Boolean stateful = null;
|
||||||
|
|
||||||
public StandardStatelessFlow(final ProcessGroup rootGroup, final List<ReportingTaskNode> reportingTasks, final ControllerServiceProvider controllerServiceProvider,
|
public StandardStatelessFlow(final ProcessGroup rootGroup, final List<ReportingTaskNode> reportingTasks, final ControllerServiceProvider controllerServiceProvider,
|
||||||
final ProcessContextFactory processContextFactory, final RepositoryContextFactory repositoryContextFactory, final DataflowDefinition<?> dataflowDefinition,
|
final ProcessContextFactory processContextFactory, final RepositoryContextFactory repositoryContextFactory, final DataflowDefinition dataflowDefinition,
|
||||||
final StatelessStateManagerProvider stateManagerProvider, final ProcessScheduler processScheduler, final BulletinRepository bulletinRepository) {
|
final StatelessStateManagerProvider stateManagerProvider, final ProcessScheduler processScheduler, final BulletinRepository bulletinRepository) {
|
||||||
this.rootGroup = rootGroup;
|
this.rootGroup = rootGroup;
|
||||||
this.allConnections = rootGroup.findAllConnections();
|
this.allConnections = rootGroup.findAllConnections();
|
||||||
|
|
|
@ -45,7 +45,7 @@ public class TestPropertiesFileFlowDefinitionParser {
|
||||||
|
|
||||||
final List<ParameterOverride> parameterOverrides = new ArrayList<>();
|
final List<ParameterOverride> parameterOverrides = new ArrayList<>();
|
||||||
final StatelessEngineConfiguration engineConfig = createStatelessEngineConfiguration();
|
final StatelessEngineConfiguration engineConfig = createStatelessEngineConfiguration();
|
||||||
final DataflowDefinition<?> dataflowDefinition = parser.parseFlowDefinition(new File("src/test/resources/flow-configuration.properties"), engineConfig, parameterOverrides);
|
final DataflowDefinition dataflowDefinition = parser.parseFlowDefinition(new File("src/test/resources/flow-configuration.properties"), engineConfig, parameterOverrides);
|
||||||
assertEquals(new HashSet<>(Arrays.asList("foo", "bar", "baz")), dataflowDefinition.getFailurePortNames());
|
assertEquals(new HashSet<>(Arrays.asList("foo", "bar", "baz")), dataflowDefinition.getFailurePortNames());
|
||||||
|
|
||||||
final List<ParameterContextDefinition> contextDefinitions = dataflowDefinition.getParameterContexts();
|
final List<ParameterContextDefinition> contextDefinitions = dataflowDefinition.getParameterContexts();
|
||||||
|
|
|
@ -19,7 +19,9 @@ package org.apache.nifi.stateless;
|
||||||
|
|
||||||
import com.fasterxml.jackson.databind.ObjectMapper;
|
import com.fasterxml.jackson.databind.ObjectMapper;
|
||||||
import org.apache.nifi.flow.Bundle;
|
import org.apache.nifi.flow.Bundle;
|
||||||
|
import org.apache.nifi.flow.VersionedExternalFlow;
|
||||||
import org.apache.nifi.flow.VersionedPort;
|
import org.apache.nifi.flow.VersionedPort;
|
||||||
|
import org.apache.nifi.registry.VersionedFlowConverter;
|
||||||
import org.apache.nifi.registry.flow.VersionedFlowSnapshot;
|
import org.apache.nifi.registry.flow.VersionedFlowSnapshot;
|
||||||
import org.apache.nifi.stateless.bootstrap.StatelessBootstrap;
|
import org.apache.nifi.stateless.bootstrap.StatelessBootstrap;
|
||||||
import org.apache.nifi.stateless.config.ExtensionClientDefinition;
|
import org.apache.nifi.stateless.config.ExtensionClientDefinition;
|
||||||
|
@ -164,13 +166,22 @@ public class StatelessSystemIT {
|
||||||
}
|
}
|
||||||
|
|
||||||
protected StatelessDataflow loadDataflow(final VersionedFlowSnapshot versionedFlowSnapshot, final List<ParameterContextDefinition> parameterContexts,
|
protected StatelessDataflow loadDataflow(final VersionedFlowSnapshot versionedFlowSnapshot, final List<ParameterContextDefinition> parameterContexts,
|
||||||
|
final List<ParameterValueProviderDefinition> parameterValueProviderDefinitions, final Set<String> failurePortNames,
|
||||||
|
final TransactionThresholds transactionThresholds)
|
||||||
|
throws IOException, StatelessConfigurationException {
|
||||||
|
|
||||||
|
final VersionedExternalFlow externalFlow = VersionedFlowConverter.createVersionedExternalFlow(versionedFlowSnapshot);
|
||||||
|
return loadDataflow(externalFlow, parameterContexts, parameterValueProviderDefinitions, failurePortNames, transactionThresholds);
|
||||||
|
}
|
||||||
|
|
||||||
|
protected StatelessDataflow loadDataflow(final VersionedExternalFlow versionedExternalFlow, final List<ParameterContextDefinition> parameterContexts,
|
||||||
final List<ParameterValueProviderDefinition> parameterValueProviderDefinitions, final Set<String> failurePortNames,
|
final List<ParameterValueProviderDefinition> parameterValueProviderDefinitions, final Set<String> failurePortNames,
|
||||||
final TransactionThresholds transactionThresholds) throws IOException, StatelessConfigurationException {
|
final TransactionThresholds transactionThresholds) throws IOException, StatelessConfigurationException {
|
||||||
|
|
||||||
final DataflowDefinition<VersionedFlowSnapshot> dataflowDefinition = new DataflowDefinition<VersionedFlowSnapshot>() {
|
final DataflowDefinition dataflowDefinition = new DataflowDefinition() {
|
||||||
@Override
|
@Override
|
||||||
public VersionedFlowSnapshot getFlowSnapshot() {
|
public VersionedExternalFlow getVersionedExternalFlow() {
|
||||||
return versionedFlowSnapshot;
|
return versionedExternalFlow;
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
|
@ -185,14 +196,14 @@ public class StatelessSystemIT {
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public Set<String> getInputPortNames() {
|
public Set<String> getInputPortNames() {
|
||||||
return versionedFlowSnapshot.getFlowContents().getInputPorts().stream()
|
return versionedExternalFlow.getFlowContents().getInputPorts().stream()
|
||||||
.map(VersionedPort::getName)
|
.map(VersionedPort::getName)
|
||||||
.collect(Collectors.toSet());
|
.collect(Collectors.toSet());
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public Set<String> getOutputPortNames() {
|
public Set<String> getOutputPortNames() {
|
||||||
return versionedFlowSnapshot.getFlowContents().getOutputPorts().stream()
|
return versionedExternalFlow.getFlowContents().getOutputPorts().stream()
|
||||||
.map(VersionedPort::getName)
|
.map(VersionedPort::getName)
|
||||||
.collect(Collectors.toSet());
|
.collect(Collectors.toSet());
|
||||||
}
|
}
|
||||||
|
|
|
@ -29,7 +29,7 @@ import org.apache.nifi.flow.VersionedComponent;
|
||||||
import org.apache.nifi.flow.VersionedConnection;
|
import org.apache.nifi.flow.VersionedConnection;
|
||||||
import org.apache.nifi.flow.VersionedControllerService;
|
import org.apache.nifi.flow.VersionedControllerService;
|
||||||
import org.apache.nifi.registry.flow.VersionedFlowSnapshot;
|
import org.apache.nifi.registry.flow.VersionedFlowSnapshot;
|
||||||
import org.apache.nifi.registry.flow.VersionedParameterContext;
|
import org.apache.nifi.flow.VersionedParameterContext;
|
||||||
import org.apache.nifi.flow.VersionedPort;
|
import org.apache.nifi.flow.VersionedPort;
|
||||||
import org.apache.nifi.flow.VersionedProcessGroup;
|
import org.apache.nifi.flow.VersionedProcessGroup;
|
||||||
import org.apache.nifi.flow.VersionedProcessor;
|
import org.apache.nifi.flow.VersionedProcessor;
|
||||||
|
|
|
@ -20,8 +20,8 @@ package org.apache.nifi.stateless.parameters;
|
||||||
import org.apache.nifi.flowfile.FlowFile;
|
import org.apache.nifi.flowfile.FlowFile;
|
||||||
import org.apache.nifi.processor.Relationship;
|
import org.apache.nifi.processor.Relationship;
|
||||||
import org.apache.nifi.registry.flow.VersionedFlowSnapshot;
|
import org.apache.nifi.registry.flow.VersionedFlowSnapshot;
|
||||||
import org.apache.nifi.registry.flow.VersionedParameter;
|
import org.apache.nifi.flow.VersionedParameter;
|
||||||
import org.apache.nifi.registry.flow.VersionedParameterContext;
|
import org.apache.nifi.flow.VersionedParameterContext;
|
||||||
import org.apache.nifi.flow.VersionedPort;
|
import org.apache.nifi.flow.VersionedPort;
|
||||||
import org.apache.nifi.flow.VersionedProcessGroup;
|
import org.apache.nifi.flow.VersionedProcessGroup;
|
||||||
import org.apache.nifi.flow.VersionedProcessor;
|
import org.apache.nifi.flow.VersionedProcessor;
|
||||||
|
|
Loading…
Reference in New Issue