NIFI-854: Ensure that controller services are included in template if any processor (or other service) in the template references it, regardless of how many levels deep the component's ProcessGroup is

This commit is contained in:
Mark Payne 2015-08-20 11:25:17 -04:00
parent 82d32230e6
commit 1ddd736558
2 changed files with 42 additions and 14 deletions

View File

@ -201,4 +201,31 @@ public class ControllerServiceDTO extends NiFiComponentDTO {
public void setValidationErrors(Collection<String> validationErrors) { public void setValidationErrors(Collection<String> validationErrors) {
this.validationErrors = validationErrors; this.validationErrors = validationErrors;
} }
@Override
public int hashCode() {
final String id = getId();
return 37 + 3 * ((id == null) ? 0 : id.hashCode());
}
@Override
public boolean equals(final Object obj) {
if (obj == null) {
return false;
}
if (obj == this) {
return true;
}
if (obj.getClass() != ControllerServiceDTO.class) {
return false;
}
final ControllerServiceDTO other = (ControllerServiceDTO) obj;
if (getId() == null || other.getId() == null) {
return false;
}
return getId().equals(other.getId());
}
} }

View File

@ -190,17 +190,23 @@ public final class SnippetUtils {
} }
if (includeControllerServices) { if (includeControllerServices) {
addControllerServicesToSnippet(snippetDto); Set<ControllerServiceDTO> controllerServices = snippetDto.getControllerServices();
if (controllerServices == null) {
controllerServices = new HashSet<>();
snippetDto.setControllerServices(controllerServices);
}
addControllerServicesToSnippet(snippetDto, controllerServices);
} }
return snippetDto; return snippetDto;
} }
private void addControllerServicesToSnippet(final FlowSnippetDTO snippetDto) { private void addControllerServicesToSnippet(final FlowSnippetDTO snippetDto, final Set<ControllerServiceDTO> destinationSet) {
final Set<ProcessorDTO> processors = snippetDto.getProcessors(); final Set<ProcessorDTO> processors = snippetDto.getProcessors();
if (processors != null) { if (processors != null) {
for (final ProcessorDTO processorDto : processors) { for (final ProcessorDTO processorDto : processors) {
addControllerServicesToSnippet(snippetDto, processorDto); addControllerServicesToSnippet(snippetDto, processorDto, destinationSet);
} }
} }
@ -209,13 +215,13 @@ public final class SnippetUtils {
for (final ProcessGroupDTO processGroupDto : childGroups) { for (final ProcessGroupDTO processGroupDto : childGroups) {
final FlowSnippetDTO childGroupDto = processGroupDto.getContents(); final FlowSnippetDTO childGroupDto = processGroupDto.getContents();
if (childGroupDto != null) { if (childGroupDto != null) {
addControllerServicesToSnippet(childGroupDto); addControllerServicesToSnippet(childGroupDto, destinationSet);
} }
} }
} }
} }
private void addControllerServicesToSnippet(final FlowSnippetDTO snippet, final ProcessorDTO processorDto) { private void addControllerServicesToSnippet(final FlowSnippetDTO snippet, final ProcessorDTO processorDto, final Set<ControllerServiceDTO> destinationSet) {
final ProcessorConfigDTO configDto = processorDto.getConfig(); final ProcessorConfigDTO configDto = processorDto.getConfig();
if (configDto == null) { if (configDto == null) {
return; return;
@ -236,25 +242,20 @@ public final class SnippetUtils {
if (propertyDescriptorDto != null && propertyDescriptorDto.getIdentifiesControllerService() != null) { if (propertyDescriptorDto != null && propertyDescriptorDto.getIdentifiesControllerService() != null) {
final ControllerServiceNode serviceNode = flowController.getControllerServiceNode(propValue); final ControllerServiceNode serviceNode = flowController.getControllerServiceNode(propValue);
if (serviceNode != null) { if (serviceNode != null) {
addControllerServicesToSnippet(snippet, serviceNode); addControllerServicesToSnippet(snippet, serviceNode, destinationSet);
} }
} }
} }
} }
} }
private void addControllerServicesToSnippet(final FlowSnippetDTO snippet, final ControllerServiceNode serviceNode) { private void addControllerServicesToSnippet(final FlowSnippetDTO snippet, final ControllerServiceNode serviceNode, final Set<ControllerServiceDTO> destinationSet) {
if (isServicePresent(serviceNode.getIdentifier(), snippet.getControllerServices())) { if (isServicePresent(serviceNode.getIdentifier(), snippet.getControllerServices())) {
return; return;
} }
final ControllerServiceDTO serviceNodeDto = dtoFactory.createControllerServiceDto(serviceNode); final ControllerServiceDTO serviceNodeDto = dtoFactory.createControllerServiceDto(serviceNode);
Set<ControllerServiceDTO> existingServiceDtos = snippet.getControllerServices(); destinationSet.add(serviceNodeDto);
if (existingServiceDtos == null) {
existingServiceDtos = new HashSet<>();
snippet.setControllerServices(existingServiceDtos);
}
existingServiceDtos.add(serviceNodeDto);
for (final Map.Entry<PropertyDescriptor, String> entry : serviceNode.getProperties().entrySet()) { for (final Map.Entry<PropertyDescriptor, String> entry : serviceNode.getProperties().entrySet()) {
final PropertyDescriptor descriptor = entry.getKey(); final PropertyDescriptor descriptor = entry.getKey();
@ -270,7 +271,7 @@ public final class SnippetUtils {
final boolean alreadyPresent = isServicePresent(referencedNodeId, snippet.getControllerServices()); final boolean alreadyPresent = isServicePresent(referencedNodeId, snippet.getControllerServices());
if (!alreadyPresent) { if (!alreadyPresent) {
addControllerServicesToSnippet(snippet, referencedNode); addControllerServicesToSnippet(snippet, referencedNode, destinationSet);
} }
} }
} }