mirror of https://github.com/apache/nifi.git
NIFI-9288: Updated data model to use for cnofig verification requests so that only properties are necessary not the full component/config dtos. Also added endpoint necessary for determining which attributes are referenced by a component's properties and removed the referencedAttributes field from the compnoents themselves, since there's now a new endpoint for it. Also fixed a bug that was encountered where the VerifyConfigRequestDTO's complete flag was incorrect in case of failures
Signed-off-by: Joe Gresock <jgresock@gmail.com> This closes #5452.
This commit is contained in:
parent
207894ebe0
commit
151a9361fa
|
@ -0,0 +1,57 @@
|
||||||
|
/*
|
||||||
|
* 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.web.api.dto;
|
||||||
|
|
||||||
|
import io.swagger.annotations.ApiModelProperty;
|
||||||
|
|
||||||
|
import javax.xml.bind.annotation.XmlType;
|
||||||
|
import java.util.Map;
|
||||||
|
|
||||||
|
@XmlType(name = "configurationAnalysis")
|
||||||
|
public class ConfigurationAnalysisDTO {
|
||||||
|
private String componentId;
|
||||||
|
private Map<String, String> properties;
|
||||||
|
private Map<String, String> referencedAttributes;
|
||||||
|
|
||||||
|
@ApiModelProperty("The ID of the component")
|
||||||
|
public String getComponentId() {
|
||||||
|
return componentId;
|
||||||
|
}
|
||||||
|
|
||||||
|
public void setComponentId(final String componentId) {
|
||||||
|
this.componentId = componentId;
|
||||||
|
}
|
||||||
|
|
||||||
|
@ApiModelProperty("The configured properties for the component")
|
||||||
|
public Map<String, String> getProperties() {
|
||||||
|
return properties;
|
||||||
|
}
|
||||||
|
|
||||||
|
public void setProperties(final Map<String, String> properties) {
|
||||||
|
this.properties = properties;
|
||||||
|
}
|
||||||
|
|
||||||
|
@ApiModelProperty("The attributes that are referenced by the properties, mapped to recently used values")
|
||||||
|
public Map<String, String> getReferencedAttributes() {
|
||||||
|
return referencedAttributes;
|
||||||
|
}
|
||||||
|
|
||||||
|
public void setReferencedAttributes(final Map<String, String> referencedAttributes) {
|
||||||
|
this.referencedAttributes = referencedAttributes;
|
||||||
|
}
|
||||||
|
}
|
|
@ -17,7 +17,6 @@
|
||||||
package org.apache.nifi.web.api.dto;
|
package org.apache.nifi.web.api.dto;
|
||||||
|
|
||||||
import io.swagger.annotations.ApiModelProperty;
|
import io.swagger.annotations.ApiModelProperty;
|
||||||
import io.swagger.annotations.ApiModelProperty.AccessMode;
|
|
||||||
import org.apache.nifi.web.api.entity.ControllerServiceReferencingComponentEntity;
|
import org.apache.nifi.web.api.entity.ControllerServiceReferencingComponentEntity;
|
||||||
|
|
||||||
import javax.xml.bind.annotation.XmlType;
|
import javax.xml.bind.annotation.XmlType;
|
||||||
|
@ -46,7 +45,6 @@ public class ControllerServiceDTO extends ComponentDTO {
|
||||||
private Boolean deprecated;
|
private Boolean deprecated;
|
||||||
private Boolean isExtensionMissing;
|
private Boolean isExtensionMissing;
|
||||||
private Boolean multipleVersionsAvailable;
|
private Boolean multipleVersionsAvailable;
|
||||||
private Set<String> referencedAttributes;
|
|
||||||
|
|
||||||
private Map<String, String> properties;
|
private Map<String, String> properties;
|
||||||
private Map<String, PropertyDescriptorDTO> descriptors;
|
private Map<String, PropertyDescriptorDTO> descriptors;
|
||||||
|
@ -315,15 +313,6 @@ public class ControllerServiceDTO extends ComponentDTO {
|
||||||
this.validationStatus = validationStatus;
|
this.validationStatus = validationStatus;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ApiModelProperty(value = "The set of FlowFile Attributes that are referenced via Expression Language by the configured properties", accessMode = AccessMode.READ_ONLY)
|
|
||||||
public Set<String> getReferencedAttributes() {
|
|
||||||
return referencedAttributes;
|
|
||||||
}
|
|
||||||
|
|
||||||
public void setReferencedAttributes(final Set<String> referencedAttributes) {
|
|
||||||
this.referencedAttributes = referencedAttributes;
|
|
||||||
}
|
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public int hashCode() {
|
public int hashCode() {
|
||||||
final String id = getId();
|
final String id = getId();
|
||||||
|
|
|
@ -17,7 +17,6 @@
|
||||||
package org.apache.nifi.web.api.dto;
|
package org.apache.nifi.web.api.dto;
|
||||||
|
|
||||||
import io.swagger.annotations.ApiModelProperty;
|
import io.swagger.annotations.ApiModelProperty;
|
||||||
import io.swagger.annotations.ApiModelProperty.AccessMode;
|
|
||||||
|
|
||||||
import javax.xml.bind.annotation.XmlType;
|
import javax.xml.bind.annotation.XmlType;
|
||||||
import java.util.Map;
|
import java.util.Map;
|
||||||
|
@ -51,7 +50,6 @@ public class ProcessorConfigDTO {
|
||||||
|
|
||||||
private Map<String, String> defaultConcurrentTasks;
|
private Map<String, String> defaultConcurrentTasks;
|
||||||
private Map<String, String> defaultSchedulingPeriod;
|
private Map<String, String> defaultSchedulingPeriod;
|
||||||
private Set<String> referencedAttributes;
|
|
||||||
|
|
||||||
public ProcessorConfigDTO() {
|
public ProcessorConfigDTO() {
|
||||||
|
|
||||||
|
@ -310,12 +308,4 @@ public class ProcessorConfigDTO {
|
||||||
this.defaultSchedulingPeriod = defaultSchedulingPeriod;
|
this.defaultSchedulingPeriod = defaultSchedulingPeriod;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ApiModelProperty(value = "The set of FlowFile Attributes that are referenced via Expression Language by the configured properties", accessMode = AccessMode.READ_ONLY)
|
|
||||||
public Set<String> getReferencedAttributes() {
|
|
||||||
return referencedAttributes;
|
|
||||||
}
|
|
||||||
|
|
||||||
public void setReferencedAttributes(final Set<String> referencedAttributes) {
|
|
||||||
this.referencedAttributes = referencedAttributes;
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
|
|
@ -24,29 +24,29 @@ import javax.xml.bind.annotation.XmlType;
|
||||||
import java.util.List;
|
import java.util.List;
|
||||||
import java.util.Map;
|
import java.util.Map;
|
||||||
|
|
||||||
@XmlType(name = "verifyProcessorConfigRequest")
|
@XmlType(name = "verifyConfigRequest")
|
||||||
public class VerifyProcessorConfigRequestDTO extends AsynchronousRequestDTO<VerifyConfigUpdateStepDTO> {
|
public class VerifyConfigRequestDTO extends AsynchronousRequestDTO<VerifyConfigUpdateStepDTO> {
|
||||||
private String processorId;
|
private String componentId;
|
||||||
private ProcessorConfigDTO processorConfigDTO;
|
private Map<String, String> properties;
|
||||||
private Map<String, String> attributes;
|
private Map<String, String> attributes;
|
||||||
private List<ConfigVerificationResultDTO> results;
|
private List<ConfigVerificationResultDTO> results;
|
||||||
|
|
||||||
@ApiModelProperty("The ID of the Processor whose configuration was verified")
|
@ApiModelProperty("The ID of the component whose configuration was verified")
|
||||||
public String getProcessorId() {
|
public String getComponentId() {
|
||||||
return processorId;
|
return componentId;
|
||||||
}
|
}
|
||||||
|
|
||||||
public void setProcessorId(final String processorId) {
|
public void setComponentId(final String componentId) {
|
||||||
this.processorId = processorId;
|
this.componentId = componentId;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ApiModelProperty("The configuration for the Processor")
|
@ApiModelProperty("The configured component properties")
|
||||||
public ProcessorConfigDTO getProcessorConfig() {
|
public Map<String, String> getProperties() {
|
||||||
return processorConfigDTO;
|
return properties;
|
||||||
}
|
}
|
||||||
|
|
||||||
public void setProcessorConfig(final ProcessorConfigDTO processorConfigDTO) {
|
public void setProperties(final Map<String, String> properties) {
|
||||||
this.processorConfigDTO = processorConfigDTO;
|
this.properties = properties;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ApiModelProperty("FlowFile Attributes that should be used to evaluate Expression Language for resolving property values")
|
@ApiModelProperty("FlowFile Attributes that should be used to evaluate Expression Language for resolving property values")
|
|
@ -1,69 +0,0 @@
|
||||||
/*
|
|
||||||
* 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.web.api.dto;
|
|
||||||
|
|
||||||
import io.swagger.annotations.ApiModelProperty;
|
|
||||||
import io.swagger.annotations.ApiModelProperty.AccessMode;
|
|
||||||
|
|
||||||
import javax.xml.bind.annotation.XmlType;
|
|
||||||
import java.util.List;
|
|
||||||
import java.util.Map;
|
|
||||||
|
|
||||||
@XmlType(name = "verifyControllerServiceConfigRequest")
|
|
||||||
public class VerifyControllerServiceConfigRequestDTO extends AsynchronousRequestDTO<VerifyConfigUpdateStepDTO> {
|
|
||||||
private String controllerServiceId;
|
|
||||||
private ControllerServiceDTO controllerService;
|
|
||||||
private Map<String, String> attributes;
|
|
||||||
private List<ConfigVerificationResultDTO> results;
|
|
||||||
|
|
||||||
@ApiModelProperty("The ID of the Controller Service whose configuration was verified")
|
|
||||||
public String getControllerServiceId() {
|
|
||||||
return controllerServiceId;
|
|
||||||
}
|
|
||||||
|
|
||||||
public void setControllerServiceId(final String controllerServiceId) {
|
|
||||||
this.controllerServiceId = controllerServiceId;
|
|
||||||
}
|
|
||||||
|
|
||||||
@ApiModelProperty("The Controller Service")
|
|
||||||
public ControllerServiceDTO getControllerService() {
|
|
||||||
return controllerService;
|
|
||||||
}
|
|
||||||
|
|
||||||
public void setControllerService(final ControllerServiceDTO controllerService) {
|
|
||||||
this.controllerService = controllerService;
|
|
||||||
}
|
|
||||||
|
|
||||||
@ApiModelProperty("FlowFile Attributes that should be used to evaluate Expression Language for resolving property values")
|
|
||||||
public Map<String, String> getAttributes() {
|
|
||||||
return attributes;
|
|
||||||
}
|
|
||||||
|
|
||||||
public void setAttributes(final Map<String, String> attributes) {
|
|
||||||
this.attributes = attributes;
|
|
||||||
}
|
|
||||||
|
|
||||||
@ApiModelProperty(value="The Results of the verification", accessMode = AccessMode.READ_ONLY)
|
|
||||||
public List<ConfigVerificationResultDTO> getResults() {
|
|
||||||
return results;
|
|
||||||
}
|
|
||||||
|
|
||||||
public void setResults(final List<ConfigVerificationResultDTO> results) {
|
|
||||||
this.results = results;
|
|
||||||
}
|
|
||||||
}
|
|
|
@ -1,58 +0,0 @@
|
||||||
/*
|
|
||||||
* 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.web.api.dto;
|
|
||||||
|
|
||||||
import io.swagger.annotations.ApiModelProperty;
|
|
||||||
import io.swagger.annotations.ApiModelProperty.AccessMode;
|
|
||||||
|
|
||||||
import javax.xml.bind.annotation.XmlType;
|
|
||||||
import java.util.List;
|
|
||||||
|
|
||||||
@XmlType(name = "verifyReportingTaskConfigRequest")
|
|
||||||
public class VerifyReportingTaskConfigRequestDTO extends AsynchronousRequestDTO<VerifyConfigUpdateStepDTO> {
|
|
||||||
private String reportingTaskId;
|
|
||||||
private ReportingTaskDTO reportingTask;
|
|
||||||
private List<ConfigVerificationResultDTO> results;
|
|
||||||
|
|
||||||
@ApiModelProperty("The ID of the Controller Service whose configuration was verified")
|
|
||||||
public String getReportingTaskId() {
|
|
||||||
return reportingTaskId;
|
|
||||||
}
|
|
||||||
|
|
||||||
public void setReportingTaskId(final String reportingTaskId) {
|
|
||||||
this.reportingTaskId = reportingTaskId;
|
|
||||||
}
|
|
||||||
|
|
||||||
@ApiModelProperty("The Controller Service")
|
|
||||||
public ReportingTaskDTO getReportingTask() {
|
|
||||||
return reportingTask;
|
|
||||||
}
|
|
||||||
|
|
||||||
public void setReportingTask(final ReportingTaskDTO reportingTask) {
|
|
||||||
this.reportingTask = reportingTask;
|
|
||||||
}
|
|
||||||
|
|
||||||
@ApiModelProperty(value="The Results of the verification", accessMode = AccessMode.READ_ONLY)
|
|
||||||
public List<ConfigVerificationResultDTO> getResults() {
|
|
||||||
return results;
|
|
||||||
}
|
|
||||||
|
|
||||||
public void setResults(final List<ConfigVerificationResultDTO> results) {
|
|
||||||
this.results = results;
|
|
||||||
}
|
|
||||||
}
|
|
|
@ -18,20 +18,20 @@
|
||||||
package org.apache.nifi.web.api.entity;
|
package org.apache.nifi.web.api.entity;
|
||||||
|
|
||||||
import io.swagger.annotations.ApiModelProperty;
|
import io.swagger.annotations.ApiModelProperty;
|
||||||
import org.apache.nifi.web.api.dto.VerifyReportingTaskConfigRequestDTO;
|
import org.apache.nifi.web.api.dto.ConfigurationAnalysisDTO;
|
||||||
|
|
||||||
import javax.xml.bind.annotation.XmlRootElement;
|
import javax.xml.bind.annotation.XmlRootElement;
|
||||||
|
|
||||||
@XmlRootElement(name="verifyReportingTaskConfigRequest")
|
@XmlRootElement(name = "configurationAnalysis")
|
||||||
public class VerifyReportingTaskConfigRequestEntity extends Entity {
|
public class ConfigurationAnalysisEntity extends Entity {
|
||||||
private VerifyReportingTaskConfigRequestDTO request;
|
private ConfigurationAnalysisDTO configurationAnalysis;
|
||||||
|
|
||||||
@ApiModelProperty("The request")
|
@ApiModelProperty("The configuration analysis")
|
||||||
public VerifyReportingTaskConfigRequestDTO getRequest() {
|
public ConfigurationAnalysisDTO getConfigurationAnalysis() {
|
||||||
return request;
|
return configurationAnalysis;
|
||||||
}
|
}
|
||||||
|
|
||||||
public void setRequest(final VerifyReportingTaskConfigRequestDTO request) {
|
public void setConfigurationAnalysis(final ConfigurationAnalysisDTO configurationAnalysis) {
|
||||||
this.request = request;
|
this.configurationAnalysis = configurationAnalysis;
|
||||||
}
|
}
|
||||||
}
|
}
|
|
@ -18,20 +18,20 @@
|
||||||
package org.apache.nifi.web.api.entity;
|
package org.apache.nifi.web.api.entity;
|
||||||
|
|
||||||
import io.swagger.annotations.ApiModelProperty;
|
import io.swagger.annotations.ApiModelProperty;
|
||||||
import org.apache.nifi.web.api.dto.VerifyProcessorConfigRequestDTO;
|
import org.apache.nifi.web.api.dto.VerifyConfigRequestDTO;
|
||||||
|
|
||||||
import javax.xml.bind.annotation.XmlRootElement;
|
import javax.xml.bind.annotation.XmlRootElement;
|
||||||
|
|
||||||
@XmlRootElement(name="verifyProcessorConfigRequest")
|
@XmlRootElement(name="verifyConfigRequest")
|
||||||
public class VerifyProcessorConfigRequestEntity extends Entity {
|
public class VerifyConfigRequestEntity extends Entity {
|
||||||
private VerifyProcessorConfigRequestDTO request;
|
private VerifyConfigRequestDTO request;
|
||||||
|
|
||||||
@ApiModelProperty("The request")
|
@ApiModelProperty("The request")
|
||||||
public VerifyProcessorConfigRequestDTO getRequest() {
|
public VerifyConfigRequestDTO getRequest() {
|
||||||
return request;
|
return request;
|
||||||
}
|
}
|
||||||
|
|
||||||
public void setRequest(final VerifyProcessorConfigRequestDTO request) {
|
public void setRequest(final VerifyConfigRequestDTO request) {
|
||||||
this.request = request;
|
this.request = request;
|
||||||
}
|
}
|
||||||
}
|
}
|
|
@ -1,37 +0,0 @@
|
||||||
/*
|
|
||||||
* 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.web.api.entity;
|
|
||||||
|
|
||||||
import io.swagger.annotations.ApiModelProperty;
|
|
||||||
import org.apache.nifi.web.api.dto.VerifyControllerServiceConfigRequestDTO;
|
|
||||||
|
|
||||||
import javax.xml.bind.annotation.XmlRootElement;
|
|
||||||
|
|
||||||
@XmlRootElement(name="verifyControllerServiceConfigRequest")
|
|
||||||
public class VerifyControllerServiceConfigRequestEntity extends Entity {
|
|
||||||
private VerifyControllerServiceConfigRequestDTO request;
|
|
||||||
|
|
||||||
@ApiModelProperty("The request")
|
|
||||||
public VerifyControllerServiceConfigRequestDTO getRequest() {
|
|
||||||
return request;
|
|
||||||
}
|
|
||||||
|
|
||||||
public void setRequest(final VerifyControllerServiceConfigRequestDTO request) {
|
|
||||||
this.request = request;
|
|
||||||
}
|
|
||||||
}
|
|
|
@ -77,9 +77,7 @@ import org.apache.nifi.cluster.coordination.http.endpoints.UserGroupEndpointMerg
|
||||||
import org.apache.nifi.cluster.coordination.http.endpoints.UserGroupsEndpointMerger;
|
import org.apache.nifi.cluster.coordination.http.endpoints.UserGroupsEndpointMerger;
|
||||||
import org.apache.nifi.cluster.coordination.http.endpoints.UsersEndpointMerger;
|
import org.apache.nifi.cluster.coordination.http.endpoints.UsersEndpointMerger;
|
||||||
import org.apache.nifi.cluster.coordination.http.endpoints.VariableRegistryEndpointMerger;
|
import org.apache.nifi.cluster.coordination.http.endpoints.VariableRegistryEndpointMerger;
|
||||||
import org.apache.nifi.cluster.coordination.http.endpoints.VerifyControllerServiceConfigEndpointMerger;
|
import org.apache.nifi.cluster.coordination.http.endpoints.VerifyConfigEndpointMerger;
|
||||||
import org.apache.nifi.cluster.coordination.http.endpoints.VerifyProcessorConfigEndpointMerger;
|
|
||||||
import org.apache.nifi.cluster.coordination.http.endpoints.VerifyReportingTaskConfigEndpointMerger;
|
|
||||||
import org.apache.nifi.cluster.coordination.http.replication.RequestReplicator;
|
import org.apache.nifi.cluster.coordination.http.replication.RequestReplicator;
|
||||||
import org.apache.nifi.cluster.manager.NodeResponse;
|
import org.apache.nifi.cluster.manager.NodeResponse;
|
||||||
import org.apache.nifi.stream.io.NullOutputStream;
|
import org.apache.nifi.stream.io.NullOutputStream;
|
||||||
|
@ -172,9 +170,7 @@ public class StandardHttpResponseMapper implements HttpResponseMapper {
|
||||||
endpointMergers.add(new ParameterContextsEndpointMerger());
|
endpointMergers.add(new ParameterContextsEndpointMerger());
|
||||||
endpointMergers.add(new ParameterContextEndpointMerger());
|
endpointMergers.add(new ParameterContextEndpointMerger());
|
||||||
endpointMergers.add(new ParameterContextUpdateEndpointMerger());
|
endpointMergers.add(new ParameterContextUpdateEndpointMerger());
|
||||||
endpointMergers.add(new VerifyProcessorConfigEndpointMerger());
|
endpointMergers.add(new VerifyConfigEndpointMerger());
|
||||||
endpointMergers.add(new VerifyControllerServiceConfigEndpointMerger());
|
|
||||||
endpointMergers.add(new VerifyReportingTaskConfigEndpointMerger());
|
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
|
|
|
@ -20,8 +20,8 @@ package org.apache.nifi.cluster.coordination.http.endpoints;
|
||||||
import org.apache.nifi.cluster.manager.NodeResponse;
|
import org.apache.nifi.cluster.manager.NodeResponse;
|
||||||
import org.apache.nifi.cluster.protocol.NodeIdentifier;
|
import org.apache.nifi.cluster.protocol.NodeIdentifier;
|
||||||
import org.apache.nifi.web.api.dto.ConfigVerificationResultDTO;
|
import org.apache.nifi.web.api.dto.ConfigVerificationResultDTO;
|
||||||
import org.apache.nifi.web.api.dto.VerifyProcessorConfigRequestDTO;
|
import org.apache.nifi.web.api.dto.VerifyConfigRequestDTO;
|
||||||
import org.apache.nifi.web.api.entity.VerifyProcessorConfigRequestEntity;
|
import org.apache.nifi.web.api.entity.VerifyConfigRequestEntity;
|
||||||
|
|
||||||
import java.net.URI;
|
import java.net.URI;
|
||||||
import java.util.List;
|
import java.util.List;
|
||||||
|
@ -29,24 +29,28 @@ import java.util.Map;
|
||||||
import java.util.Set;
|
import java.util.Set;
|
||||||
import java.util.regex.Pattern;
|
import java.util.regex.Pattern;
|
||||||
|
|
||||||
public class VerifyProcessorConfigEndpointMerger extends AbstractSingleEntityEndpoint<VerifyProcessorConfigRequestEntity> {
|
public class VerifyConfigEndpointMerger extends AbstractSingleEntityEndpoint<VerifyConfigRequestEntity> {
|
||||||
public static final Pattern VERIFY_PROCESSOR_CONFIG_URI_PATTERN = Pattern.compile("/nifi-api/processors/[a-f0-9\\-]{36}/config/verification-requests(/[a-f0-9\\-]{36})?");
|
public static final Pattern VERIFY_PROCESSOR_CONFIG_URI_PATTERN = Pattern.compile("/nifi-api/processors/[a-f0-9\\-]{36}/config/verification-requests(/[a-f0-9\\-]{36})?");
|
||||||
|
public static final Pattern VERIFY_CONTROLLER_SERVICE_CONFIG_URI_PATTERN = Pattern.compile("/nifi-api/controller-services/[a-f0-9\\-]{36}/config/verification-requests(/[a-f0-9\\-]{36})?");
|
||||||
|
public static final Pattern VERIFY_REPORTING_TASK_CONFIG_URI_PATTERN = Pattern.compile("/nifi-api/reporting-tasks/[a-f0-9\\-]{36}/config/verification-requests(/[a-f0-9\\-]{36})?");
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
protected Class<VerifyProcessorConfigRequestEntity> getEntityClass() {
|
protected Class<VerifyConfigRequestEntity> getEntityClass() {
|
||||||
return VerifyProcessorConfigRequestEntity.class;
|
return VerifyConfigRequestEntity.class;
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public boolean canHandle(final URI uri, final String method) {
|
public boolean canHandle(final URI uri, final String method) {
|
||||||
return VERIFY_PROCESSOR_CONFIG_URI_PATTERN.matcher(uri.getPath()).matches();
|
return VERIFY_PROCESSOR_CONFIG_URI_PATTERN.matcher(uri.getPath()).matches()
|
||||||
|
|| VERIFY_CONTROLLER_SERVICE_CONFIG_URI_PATTERN.matcher(uri.getPath()).matches()
|
||||||
|
|| VERIFY_REPORTING_TASK_CONFIG_URI_PATTERN.matcher(uri.getPath()).matches();
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
protected void mergeResponses(final VerifyProcessorConfigRequestEntity clientEntity, final Map<NodeIdentifier, VerifyProcessorConfigRequestEntity> entityMap,
|
protected void mergeResponses(final VerifyConfigRequestEntity clientEntity, final Map<NodeIdentifier, VerifyConfigRequestEntity> entityMap,
|
||||||
final Set<NodeResponse> successfulResponses, final Set<NodeResponse> problematicResponses) {
|
final Set<NodeResponse> successfulResponses, final Set<NodeResponse> problematicResponses) {
|
||||||
|
|
||||||
final VerifyProcessorConfigRequestDTO requestDto = clientEntity.getRequest();
|
final VerifyConfigRequestDTO requestDto = clientEntity.getRequest();
|
||||||
final List<ConfigVerificationResultDTO> results = requestDto.getResults();
|
final List<ConfigVerificationResultDTO> results = requestDto.getResults();
|
||||||
|
|
||||||
// If the result hasn't been set, the task is not yet complete, so we don't have to bother merging the results.
|
// If the result hasn't been set, the task is not yet complete, so we don't have to bother merging the results.
|
||||||
|
@ -56,9 +60,9 @@ public class VerifyProcessorConfigEndpointMerger extends AbstractSingleEntityEnd
|
||||||
|
|
||||||
// Aggregate the Config Verification Results across all nodes into a single List
|
// Aggregate the Config Verification Results across all nodes into a single List
|
||||||
final ConfigVerificationResultMerger resultMerger = new ConfigVerificationResultMerger();
|
final ConfigVerificationResultMerger resultMerger = new ConfigVerificationResultMerger();
|
||||||
for (final Map.Entry<NodeIdentifier, VerifyProcessorConfigRequestEntity> entry : entityMap.entrySet()) {
|
for (final Map.Entry<NodeIdentifier, VerifyConfigRequestEntity> entry : entityMap.entrySet()) {
|
||||||
final NodeIdentifier nodeId = entry.getKey();
|
final NodeIdentifier nodeId = entry.getKey();
|
||||||
final VerifyProcessorConfigRequestEntity entity = entry.getValue();
|
final VerifyConfigRequestEntity entity = entry.getValue();
|
||||||
|
|
||||||
final List<ConfigVerificationResultDTO> nodeResults = entity.getRequest().getResults();
|
final List<ConfigVerificationResultDTO> nodeResults = entity.getRequest().getResults();
|
||||||
resultMerger.addNodeResults(nodeId, nodeResults);
|
resultMerger.addNodeResults(nodeId, nodeResults);
|
|
@ -1,73 +0,0 @@
|
||||||
/*
|
|
||||||
* 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.cluster.coordination.http.endpoints;
|
|
||||||
|
|
||||||
import org.apache.nifi.cluster.manager.NodeResponse;
|
|
||||||
import org.apache.nifi.cluster.protocol.NodeIdentifier;
|
|
||||||
import org.apache.nifi.web.api.dto.ConfigVerificationResultDTO;
|
|
||||||
import org.apache.nifi.web.api.dto.VerifyControllerServiceConfigRequestDTO;
|
|
||||||
import org.apache.nifi.web.api.entity.VerifyControllerServiceConfigRequestEntity;
|
|
||||||
|
|
||||||
import java.net.URI;
|
|
||||||
import java.util.List;
|
|
||||||
import java.util.Map;
|
|
||||||
import java.util.Set;
|
|
||||||
import java.util.regex.Pattern;
|
|
||||||
|
|
||||||
public class VerifyControllerServiceConfigEndpointMerger extends AbstractSingleEntityEndpoint<VerifyControllerServiceConfigRequestEntity> {
|
|
||||||
public static final Pattern VERIFY_PROCESSOR_CONFIG_URI_PATTERN = Pattern.compile("/nifi-api/controller-services/[a-f0-9\\-]{36}/config/verification-requests(/[a-f0-9\\-]{36})?");
|
|
||||||
|
|
||||||
@Override
|
|
||||||
protected Class<VerifyControllerServiceConfigRequestEntity> getEntityClass() {
|
|
||||||
return VerifyControllerServiceConfigRequestEntity.class;
|
|
||||||
}
|
|
||||||
|
|
||||||
@Override
|
|
||||||
public boolean canHandle(final URI uri, final String method) {
|
|
||||||
return VERIFY_PROCESSOR_CONFIG_URI_PATTERN.matcher(uri.getPath()).matches();
|
|
||||||
}
|
|
||||||
|
|
||||||
@Override
|
|
||||||
protected void mergeResponses(final VerifyControllerServiceConfigRequestEntity clientEntity, final Map<NodeIdentifier, VerifyControllerServiceConfigRequestEntity> entityMap,
|
|
||||||
final Set<NodeResponse> successfulResponses, final Set<NodeResponse> problematicResponses) {
|
|
||||||
|
|
||||||
final VerifyControllerServiceConfigRequestDTO requestDto = clientEntity.getRequest();
|
|
||||||
final List<ConfigVerificationResultDTO> results = requestDto.getResults();
|
|
||||||
|
|
||||||
// If the result hasn't been set, the task is not yet complete, so we don't have to bother merging the results.
|
|
||||||
if (results == null) {
|
|
||||||
return;
|
|
||||||
}
|
|
||||||
|
|
||||||
// Aggregate the Config Verification Results across all nodes into a single List
|
|
||||||
final ConfigVerificationResultMerger resultMerger = new ConfigVerificationResultMerger();
|
|
||||||
for (final Map.Entry<NodeIdentifier, VerifyControllerServiceConfigRequestEntity> entry : entityMap.entrySet()) {
|
|
||||||
final NodeIdentifier nodeId = entry.getKey();
|
|
||||||
final VerifyControllerServiceConfigRequestEntity entity = entry.getValue();
|
|
||||||
|
|
||||||
final List<ConfigVerificationResultDTO> nodeResults = entity.getRequest().getResults();
|
|
||||||
resultMerger.addNodeResults(nodeId, nodeResults);
|
|
||||||
}
|
|
||||||
|
|
||||||
final List<ConfigVerificationResultDTO> aggregateResults = resultMerger.computeAggregateResults();
|
|
||||||
|
|
||||||
|
|
||||||
clientEntity.getRequest().setResults(aggregateResults);
|
|
||||||
}
|
|
||||||
|
|
||||||
}
|
|
|
@ -1,71 +0,0 @@
|
||||||
/*
|
|
||||||
* 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.cluster.coordination.http.endpoints;
|
|
||||||
|
|
||||||
import org.apache.nifi.cluster.manager.NodeResponse;
|
|
||||||
import org.apache.nifi.cluster.protocol.NodeIdentifier;
|
|
||||||
import org.apache.nifi.web.api.dto.ConfigVerificationResultDTO;
|
|
||||||
import org.apache.nifi.web.api.dto.VerifyReportingTaskConfigRequestDTO;
|
|
||||||
import org.apache.nifi.web.api.entity.VerifyReportingTaskConfigRequestEntity;
|
|
||||||
|
|
||||||
import java.net.URI;
|
|
||||||
import java.util.List;
|
|
||||||
import java.util.Map;
|
|
||||||
import java.util.Set;
|
|
||||||
import java.util.regex.Pattern;
|
|
||||||
|
|
||||||
public class VerifyReportingTaskConfigEndpointMerger extends AbstractSingleEntityEndpoint<VerifyReportingTaskConfigRequestEntity> {
|
|
||||||
public static final Pattern VERIFY_REPORTING_TASK_CONFIG_URI_PATTERN = Pattern.compile("/nifi-api/reporting-tasks/[a-f0-9\\-]{36}/config/verification-requests(/[a-f0-9\\-]{36})?");
|
|
||||||
|
|
||||||
@Override
|
|
||||||
protected Class<VerifyReportingTaskConfigRequestEntity> getEntityClass() {
|
|
||||||
return VerifyReportingTaskConfigRequestEntity.class;
|
|
||||||
}
|
|
||||||
|
|
||||||
@Override
|
|
||||||
public boolean canHandle(final URI uri, final String method) {
|
|
||||||
return VERIFY_REPORTING_TASK_CONFIG_URI_PATTERN.matcher(uri.getPath()).matches();
|
|
||||||
}
|
|
||||||
|
|
||||||
@Override
|
|
||||||
protected void mergeResponses(final VerifyReportingTaskConfigRequestEntity clientEntity, final Map<NodeIdentifier, VerifyReportingTaskConfigRequestEntity> entityMap,
|
|
||||||
final Set<NodeResponse> successfulResponses, final Set<NodeResponse> problematicResponses) {
|
|
||||||
|
|
||||||
final VerifyReportingTaskConfigRequestDTO requestDto = clientEntity.getRequest();
|
|
||||||
final List<ConfigVerificationResultDTO> results = requestDto.getResults();
|
|
||||||
|
|
||||||
// If the result hasn't been set, the task is not yet complete, so we don't have to bother merging the results.
|
|
||||||
if (results == null) {
|
|
||||||
return;
|
|
||||||
}
|
|
||||||
|
|
||||||
// Aggregate the Config Verification Results across all nodes into a single List
|
|
||||||
final ConfigVerificationResultMerger resultMerger = new ConfigVerificationResultMerger();
|
|
||||||
for (final Map.Entry<NodeIdentifier, VerifyReportingTaskConfigRequestEntity> entry : entityMap.entrySet()) {
|
|
||||||
final NodeIdentifier nodeId = entry.getKey();
|
|
||||||
final VerifyReportingTaskConfigRequestEntity entity = entry.getValue();
|
|
||||||
|
|
||||||
final List<ConfigVerificationResultDTO> nodeResults = entity.getRequest().getResults();
|
|
||||||
resultMerger.addNodeResults(nodeId, nodeResults);
|
|
||||||
}
|
|
||||||
|
|
||||||
final List<ConfigVerificationResultDTO> aggregateResults = resultMerger.computeAggregateResults();
|
|
||||||
clientEntity.getRequest().setResults(aggregateResults);
|
|
||||||
}
|
|
||||||
|
|
||||||
}
|
|
|
@ -563,7 +563,9 @@ public abstract class AbstractComponentNode implements ComponentNode {
|
||||||
|
|
||||||
final Map<PropertyDescriptor, String> props = new LinkedHashMap<>();
|
final Map<PropertyDescriptor, String> props = new LinkedHashMap<>();
|
||||||
for (final PropertyDescriptor descriptor : supported) {
|
for (final PropertyDescriptor descriptor : supported) {
|
||||||
props.put(descriptor, null);
|
if (descriptor != null) {
|
||||||
|
props.put(descriptor, descriptor.getDefaultValue());
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
properties.forEach((descriptor, config) -> props.put(descriptor, valueFunction.apply(config)));
|
properties.forEach((descriptor, config) -> props.put(descriptor, valueFunction.apply(config)));
|
||||||
|
|
|
@ -238,7 +238,6 @@ public class TemplateUtils {
|
||||||
processorConfig.setCustomUiUrl(null);
|
processorConfig.setCustomUiUrl(null);
|
||||||
processorConfig.setDefaultConcurrentTasks(null);
|
processorConfig.setDefaultConcurrentTasks(null);
|
||||||
processorConfig.setDefaultSchedulingPeriod(null);
|
processorConfig.setDefaultSchedulingPeriod(null);
|
||||||
processorConfig.setReferencedAttributes(null);
|
|
||||||
processorConfig.setAutoTerminatedRelationships(null);
|
processorConfig.setAutoTerminatedRelationships(null);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -307,7 +306,6 @@ public class TemplateUtils {
|
||||||
serviceDTO.setCustomUiUrl(null);
|
serviceDTO.setCustomUiUrl(null);
|
||||||
serviceDTO.setValidationErrors(null);
|
serviceDTO.setValidationErrors(null);
|
||||||
serviceDTO.setValidationStatus(null);
|
serviceDTO.setValidationStatus(null);
|
||||||
serviceDTO.setReferencedAttributes(null);
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -25,13 +25,13 @@ import org.apache.nifi.components.ConfigurableComponent;
|
||||||
import org.apache.nifi.controller.ScheduledState;
|
import org.apache.nifi.controller.ScheduledState;
|
||||||
import org.apache.nifi.controller.repository.claim.ContentDirection;
|
import org.apache.nifi.controller.repository.claim.ContentDirection;
|
||||||
import org.apache.nifi.controller.service.ControllerServiceState;
|
import org.apache.nifi.controller.service.ControllerServiceState;
|
||||||
|
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.registry.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.registry.flow.VersionedParameterContext;
|
||||||
import org.apache.nifi.flow.VersionedProcessGroup;
|
|
||||||
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;
|
||||||
|
@ -59,7 +59,6 @@ import org.apache.nifi.web.api.dto.NodeDTO;
|
||||||
import org.apache.nifi.web.api.dto.ParameterContextDTO;
|
import org.apache.nifi.web.api.dto.ParameterContextDTO;
|
||||||
import org.apache.nifi.web.api.dto.PortDTO;
|
import org.apache.nifi.web.api.dto.PortDTO;
|
||||||
import org.apache.nifi.web.api.dto.ProcessGroupDTO;
|
import org.apache.nifi.web.api.dto.ProcessGroupDTO;
|
||||||
import org.apache.nifi.web.api.dto.ProcessorConfigDTO;
|
|
||||||
import org.apache.nifi.web.api.dto.ProcessorDTO;
|
import org.apache.nifi.web.api.dto.ProcessorDTO;
|
||||||
import org.apache.nifi.web.api.dto.PropertyDescriptorDTO;
|
import org.apache.nifi.web.api.dto.PropertyDescriptorDTO;
|
||||||
import org.apache.nifi.web.api.dto.RegistryDTO;
|
import org.apache.nifi.web.api.dto.RegistryDTO;
|
||||||
|
@ -89,6 +88,7 @@ import org.apache.nifi.web.api.entity.AffectedComponentEntity;
|
||||||
import org.apache.nifi.web.api.entity.BucketEntity;
|
import org.apache.nifi.web.api.entity.BucketEntity;
|
||||||
import org.apache.nifi.web.api.entity.BulletinEntity;
|
import org.apache.nifi.web.api.entity.BulletinEntity;
|
||||||
import org.apache.nifi.web.api.entity.ComponentValidationResultEntity;
|
import org.apache.nifi.web.api.entity.ComponentValidationResultEntity;
|
||||||
|
import org.apache.nifi.web.api.entity.ConfigurationAnalysisEntity;
|
||||||
import org.apache.nifi.web.api.entity.ConnectionEntity;
|
import org.apache.nifi.web.api.entity.ConnectionEntity;
|
||||||
import org.apache.nifi.web.api.entity.ConnectionStatisticsEntity;
|
import org.apache.nifi.web.api.entity.ConnectionStatisticsEntity;
|
||||||
import org.apache.nifi.web.api.entity.ConnectionStatusEntity;
|
import org.apache.nifi.web.api.entity.ConnectionStatusEntity;
|
||||||
|
@ -638,11 +638,19 @@ public interface NiFiServiceFacade {
|
||||||
/**
|
/**
|
||||||
* Performs verification of the given Processor Configuration for the Processor with the given ID
|
* Performs verification of the given Processor Configuration for the Processor with the given ID
|
||||||
* @param processorId the id of the processor
|
* @param processorId the id of the processor
|
||||||
* @param processorConfig the configuration to verify
|
* @param properties the configured properties to verify
|
||||||
* @param attributes a map of values that can be used for resolving FlowFile attributes for Expression Language
|
* @param attributes a map of values that can be used for resolving FlowFile attributes for Expression Language
|
||||||
* @return verification results
|
* @return verification results
|
||||||
*/
|
*/
|
||||||
List<ConfigVerificationResultDTO> verifyProcessorConfiguration(String processorId, ProcessorConfigDTO processorConfig, Map<String, String> attributes);
|
List<ConfigVerificationResultDTO> verifyProcessorConfiguration(String processorId, Map<String, String> properties, Map<String, String> attributes);
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Performs analysis of the given properties, determining which attributes are referenced by properties
|
||||||
|
* @param processorId the ID of the processor
|
||||||
|
* @param properties the properties
|
||||||
|
* @return analysis results
|
||||||
|
*/
|
||||||
|
ConfigurationAnalysisEntity analyzeProcessorConfiguration(String processorId, Map<String, String> properties);
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Verifies the specified processor can be removed.
|
* Verifies the specified processor can be removed.
|
||||||
|
@ -2046,12 +2054,19 @@ public interface NiFiServiceFacade {
|
||||||
/**
|
/**
|
||||||
* Performs verification of the given Configuration for the Controller Service with the given ID
|
* Performs verification of the given Configuration for the Controller Service with the given ID
|
||||||
* @param controllerServiceId the id of the controller service
|
* @param controllerServiceId the id of the controller service
|
||||||
* @param controllerService the configuration to verify
|
* @param properties the configured properties to verify
|
||||||
* @param variables a map of values that can be used for resolving FlowFile attributes for Expression Language
|
* @param variables a map of values that can be used for resolving FlowFile attributes for Expression Language
|
||||||
* @return verification results
|
* @return verification results
|
||||||
*/
|
*/
|
||||||
List<ConfigVerificationResultDTO> verifyControllerServiceConfiguration(String controllerServiceId, ControllerServiceDTO controllerService, Map<String, String> variables);
|
List<ConfigVerificationResultDTO> verifyControllerServiceConfiguration(String controllerServiceId, Map<String, String> properties, Map<String, String> variables);
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Performs analysis of the given properties, determining which attributes are referenced by properties
|
||||||
|
* @param controllerServiceId the ID of the Controller Service
|
||||||
|
* @param properties the properties
|
||||||
|
* @return analysis results
|
||||||
|
*/
|
||||||
|
ConfigurationAnalysisEntity analyzeControllerServiceConfiguration(String controllerServiceId, Map<String, String> properties);
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Deletes the specified label.
|
* Deletes the specified label.
|
||||||
|
@ -2141,10 +2156,18 @@ public interface NiFiServiceFacade {
|
||||||
/**
|
/**
|
||||||
* Performs verification of the given Configuration for the Reporting Task with the given ID
|
* Performs verification of the given Configuration for the Reporting Task with the given ID
|
||||||
* @param reportingTaskId the id of the reporting task
|
* @param reportingTaskId the id of the reporting task
|
||||||
* @param reportingTask the configuration to verify
|
* @param properties the configured properties to verify
|
||||||
* @return verification results
|
* @return verification results
|
||||||
*/
|
*/
|
||||||
List<ConfigVerificationResultDTO> verifyReportingTaskConfiguration(String reportingTaskId, ReportingTaskDTO reportingTask);
|
List<ConfigVerificationResultDTO> verifyReportingTaskConfiguration(String reportingTaskId, Map<String, String> properties);
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Performs analysis of the given properties, determining which attributes are referenced by properties
|
||||||
|
* @param reportingTaskId the ID of the Reporting Task
|
||||||
|
* @param properties the properties
|
||||||
|
* @return analysis results
|
||||||
|
*/
|
||||||
|
ConfigurationAnalysisEntity analyzeReportingTaskConfiguration(String reportingTaskId, Map<String, String> properties);
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Deletes the specified reporting task.
|
* Deletes the specified reporting task.
|
||||||
|
|
|
@ -25,6 +25,7 @@ import org.apache.nifi.action.FlowChangeAction;
|
||||||
import org.apache.nifi.action.Operation;
|
import org.apache.nifi.action.Operation;
|
||||||
import org.apache.nifi.action.details.FlowChangePurgeDetails;
|
import org.apache.nifi.action.details.FlowChangePurgeDetails;
|
||||||
import org.apache.nifi.admin.service.AuditService;
|
import org.apache.nifi.admin.service.AuditService;
|
||||||
|
import org.apache.nifi.attribute.expression.language.Query;
|
||||||
import org.apache.nifi.authorization.AccessDeniedException;
|
import org.apache.nifi.authorization.AccessDeniedException;
|
||||||
import org.apache.nifi.authorization.AccessPolicy;
|
import org.apache.nifi.authorization.AccessPolicy;
|
||||||
import org.apache.nifi.authorization.AuthorizableLookup;
|
import org.apache.nifi.authorization.AuthorizableLookup;
|
||||||
|
@ -74,6 +75,8 @@ import org.apache.nifi.controller.ControllerService;
|
||||||
import org.apache.nifi.controller.Counter;
|
import org.apache.nifi.controller.Counter;
|
||||||
import org.apache.nifi.controller.FlowController;
|
import org.apache.nifi.controller.FlowController;
|
||||||
import org.apache.nifi.controller.ProcessorNode;
|
import org.apache.nifi.controller.ProcessorNode;
|
||||||
|
import org.apache.nifi.controller.PropertyConfiguration;
|
||||||
|
import org.apache.nifi.controller.PropertyConfigurationMapper;
|
||||||
import org.apache.nifi.controller.ReportingTaskNode;
|
import org.apache.nifi.controller.ReportingTaskNode;
|
||||||
import org.apache.nifi.controller.ScheduledState;
|
import org.apache.nifi.controller.ScheduledState;
|
||||||
import org.apache.nifi.controller.Snippet;
|
import org.apache.nifi.controller.Snippet;
|
||||||
|
@ -91,6 +94,7 @@ import org.apache.nifi.controller.status.ProcessGroupStatus;
|
||||||
import org.apache.nifi.controller.status.ProcessorStatus;
|
import org.apache.nifi.controller.status.ProcessorStatus;
|
||||||
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.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;
|
||||||
|
@ -111,6 +115,7 @@ import org.apache.nifi.parameter.Parameter;
|
||||||
import org.apache.nifi.parameter.ParameterContext;
|
import org.apache.nifi.parameter.ParameterContext;
|
||||||
import org.apache.nifi.parameter.ParameterContextLookup;
|
import org.apache.nifi.parameter.ParameterContextLookup;
|
||||||
import org.apache.nifi.parameter.ParameterDescriptor;
|
import org.apache.nifi.parameter.ParameterDescriptor;
|
||||||
|
import org.apache.nifi.parameter.ParameterLookup;
|
||||||
import org.apache.nifi.parameter.ParameterReferenceManager;
|
import org.apache.nifi.parameter.ParameterReferenceManager;
|
||||||
import org.apache.nifi.parameter.StandardParameterContext;
|
import org.apache.nifi.parameter.StandardParameterContext;
|
||||||
import org.apache.nifi.prometheus.util.BulletinMetricsRegistry;
|
import org.apache.nifi.prometheus.util.BulletinMetricsRegistry;
|
||||||
|
@ -174,6 +179,7 @@ import org.apache.nifi.web.api.dto.ComponentRestrictionPermissionDTO;
|
||||||
import org.apache.nifi.web.api.dto.ComponentStateDTO;
|
import org.apache.nifi.web.api.dto.ComponentStateDTO;
|
||||||
import org.apache.nifi.web.api.dto.ComponentValidationResultDTO;
|
import org.apache.nifi.web.api.dto.ComponentValidationResultDTO;
|
||||||
import org.apache.nifi.web.api.dto.ConfigVerificationResultDTO;
|
import org.apache.nifi.web.api.dto.ConfigVerificationResultDTO;
|
||||||
|
import org.apache.nifi.web.api.dto.ConfigurationAnalysisDTO;
|
||||||
import org.apache.nifi.web.api.dto.ConnectionDTO;
|
import org.apache.nifi.web.api.dto.ConnectionDTO;
|
||||||
import org.apache.nifi.web.api.dto.ControllerConfigurationDTO;
|
import org.apache.nifi.web.api.dto.ControllerConfigurationDTO;
|
||||||
import org.apache.nifi.web.api.dto.ControllerDTO;
|
import org.apache.nifi.web.api.dto.ControllerDTO;
|
||||||
|
@ -251,6 +257,7 @@ import org.apache.nifi.web.api.entity.BucketEntity;
|
||||||
import org.apache.nifi.web.api.entity.BulletinEntity;
|
import org.apache.nifi.web.api.entity.BulletinEntity;
|
||||||
import org.apache.nifi.web.api.entity.ComponentReferenceEntity;
|
import org.apache.nifi.web.api.entity.ComponentReferenceEntity;
|
||||||
import org.apache.nifi.web.api.entity.ComponentValidationResultEntity;
|
import org.apache.nifi.web.api.entity.ComponentValidationResultEntity;
|
||||||
|
import org.apache.nifi.web.api.entity.ConfigurationAnalysisEntity;
|
||||||
import org.apache.nifi.web.api.entity.ConnectionEntity;
|
import org.apache.nifi.web.api.entity.ConnectionEntity;
|
||||||
import org.apache.nifi.web.api.entity.ConnectionStatisticsEntity;
|
import org.apache.nifi.web.api.entity.ConnectionStatisticsEntity;
|
||||||
import org.apache.nifi.web.api.entity.ConnectionStatusEntity;
|
import org.apache.nifi.web.api.entity.ConnectionStatusEntity;
|
||||||
|
@ -765,8 +772,59 @@ public class StandardNiFiServiceFacade implements NiFiServiceFacade {
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public List<ConfigVerificationResultDTO> verifyProcessorConfiguration(final String processorId, final ProcessorConfigDTO processorConfig, final Map<String, String> attributes) {
|
public List<ConfigVerificationResultDTO> verifyProcessorConfiguration(final String processorId, final Map<String, String> properties, final Map<String, String> attributes) {
|
||||||
return processorDAO.verifyProcessorConfiguration(processorId, processorConfig, attributes);
|
return processorDAO.verifyProcessorConfiguration(processorId, properties, attributes);
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public ConfigurationAnalysisEntity analyzeProcessorConfiguration(final String processorId, final Map<String, String> properties) {
|
||||||
|
final ProcessorNode processorNode = processorDAO.getProcessor(processorId);
|
||||||
|
final ProcessGroup processGroup = processorNode.getProcessGroup();
|
||||||
|
final ParameterContext parameterContext = processGroup.getParameterContext();
|
||||||
|
|
||||||
|
final ConfigurationAnalysisEntity configurationAnalysisEntity = analyzeConfiguration(processorNode, properties, parameterContext);
|
||||||
|
return configurationAnalysisEntity;
|
||||||
|
}
|
||||||
|
|
||||||
|
private ConfigurationAnalysisEntity analyzeConfiguration(final ComponentNode componentNode, final Map<String, String> properties, final ParameterContext parameterContext) {
|
||||||
|
final Map<String, String> referencedAttributes = determineReferencedAttributes(properties, componentNode, parameterContext);
|
||||||
|
|
||||||
|
final ConfigurationAnalysisDTO dto = new ConfigurationAnalysisDTO();
|
||||||
|
dto.setComponentId(componentNode.getIdentifier());
|
||||||
|
dto.setProperties(properties);
|
||||||
|
dto.setReferencedAttributes(referencedAttributes);
|
||||||
|
|
||||||
|
final ConfigurationAnalysisEntity entity = new ConfigurationAnalysisEntity();
|
||||||
|
entity.setConfigurationAnalysis(dto);
|
||||||
|
return entity;
|
||||||
|
}
|
||||||
|
|
||||||
|
private Map<String, String> determineReferencedAttributes(final Map<String, String> properties, final ComponentNode componentNode, final ParameterContext parameterContext) {
|
||||||
|
final Map<String, String> mergedProperties = new LinkedHashMap<>();
|
||||||
|
componentNode.getRawPropertyValues().forEach((desc, value) -> mergedProperties.put(desc.getName(), value));
|
||||||
|
mergedProperties.putAll(properties);
|
||||||
|
|
||||||
|
final Set<String> propertiesNotSupportingEL = new HashSet<>();
|
||||||
|
for (final String propertyName : mergedProperties.keySet()) {
|
||||||
|
final PropertyDescriptor descriptor = componentNode.getPropertyDescriptor(propertyName);
|
||||||
|
final boolean allowsAttributes = descriptor.isExpressionLanguageSupported() || descriptor.getExpressionLanguageScope() == ExpressionLanguageScope.FLOWFILE_ATTRIBUTES;
|
||||||
|
if (descriptor.isSensitive() || !allowsAttributes) {
|
||||||
|
propertiesNotSupportingEL.add(propertyName);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
propertiesNotSupportingEL.forEach(mergedProperties::remove);
|
||||||
|
|
||||||
|
final PropertyConfigurationMapper configurationMapper = new PropertyConfigurationMapper();
|
||||||
|
final Map<String, PropertyConfiguration> configurationMap = configurationMapper.mapRawPropertyValuesToPropertyConfiguration(componentNode, mergedProperties);
|
||||||
|
|
||||||
|
final Map<String, String> referencedAttributes = new HashMap<>();
|
||||||
|
for (final PropertyConfiguration propertyConfiguration : configurationMap.values()) {
|
||||||
|
final String effectiveValue = propertyConfiguration.getEffectiveValue(parameterContext == null ? ParameterLookup.EMPTY : parameterContext);
|
||||||
|
final Set<String> attributes = Query.prepareWithParametersPreEvaluated(effectiveValue).getExplicitlyReferencedAttributes();
|
||||||
|
attributes.forEach(attr -> referencedAttributes.put(attr, null));
|
||||||
|
}
|
||||||
|
|
||||||
|
return referencedAttributes;
|
||||||
}
|
}
|
||||||
|
|
||||||
private void awaitValidationCompletion(final ComponentNode component) {
|
private void awaitValidationCompletion(final ComponentNode component) {
|
||||||
|
@ -2776,8 +2834,18 @@ public class StandardNiFiServiceFacade implements NiFiServiceFacade {
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public List<ConfigVerificationResultDTO> verifyControllerServiceConfiguration(final String controllerServiceId, final ControllerServiceDTO controllerService, final Map<String, String> variables) {
|
public List<ConfigVerificationResultDTO> verifyControllerServiceConfiguration(final String controllerServiceId, final Map<String, String> properties, final Map<String, String> variables) {
|
||||||
return controllerServiceDAO.verifyConfiguration(controllerServiceId, controllerService, variables);
|
return controllerServiceDAO.verifyConfiguration(controllerServiceId, properties, variables);
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public ConfigurationAnalysisEntity analyzeControllerServiceConfiguration(final String controllerServiceId, final Map<String, String> properties) {
|
||||||
|
final ControllerServiceNode serviceNode = controllerServiceDAO.getControllerService(controllerServiceId);
|
||||||
|
final ProcessGroup processGroup = serviceNode.getProcessGroup();
|
||||||
|
final ParameterContext parameterContext = processGroup == null ? null : processGroup.getParameterContext();
|
||||||
|
|
||||||
|
final ConfigurationAnalysisEntity configurationAnalysisEntity = analyzeConfiguration(serviceNode, properties, parameterContext);
|
||||||
|
return configurationAnalysisEntity;
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
|
@ -3159,8 +3227,15 @@ public class StandardNiFiServiceFacade implements NiFiServiceFacade {
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public List<ConfigVerificationResultDTO> verifyReportingTaskConfiguration(final String reportingTaskId, final ReportingTaskDTO reportingTask) {
|
public List<ConfigVerificationResultDTO> verifyReportingTaskConfiguration(final String reportingTaskId, final Map<String, String> properties) {
|
||||||
return reportingTaskDAO.verifyConfiguration(reportingTaskId, reportingTask);
|
return reportingTaskDAO.verifyConfiguration(reportingTaskId, properties);
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public ConfigurationAnalysisEntity analyzeReportingTaskConfiguration(final String reportingTaskId, final Map<String, String> properties) {
|
||||||
|
final ReportingTaskNode taskNode = reportingTaskDAO.getReportingTask(reportingTaskId);
|
||||||
|
final ConfigurationAnalysisEntity configurationAnalysisEntity = analyzeConfiguration(taskNode, properties, null);
|
||||||
|
return configurationAnalysisEntity;
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
|
|
|
@ -49,17 +49,19 @@ import org.apache.nifi.web.api.concurrent.UpdateStep;
|
||||||
import org.apache.nifi.web.api.dto.BundleDTO;
|
import org.apache.nifi.web.api.dto.BundleDTO;
|
||||||
import org.apache.nifi.web.api.dto.ComponentStateDTO;
|
import org.apache.nifi.web.api.dto.ComponentStateDTO;
|
||||||
import org.apache.nifi.web.api.dto.ConfigVerificationResultDTO;
|
import org.apache.nifi.web.api.dto.ConfigVerificationResultDTO;
|
||||||
|
import org.apache.nifi.web.api.dto.ConfigurationAnalysisDTO;
|
||||||
import org.apache.nifi.web.api.dto.ControllerServiceDTO;
|
import org.apache.nifi.web.api.dto.ControllerServiceDTO;
|
||||||
import org.apache.nifi.web.api.dto.PropertyDescriptorDTO;
|
import org.apache.nifi.web.api.dto.PropertyDescriptorDTO;
|
||||||
import org.apache.nifi.web.api.dto.RevisionDTO;
|
import org.apache.nifi.web.api.dto.RevisionDTO;
|
||||||
import org.apache.nifi.web.api.dto.VerifyControllerServiceConfigRequestDTO;
|
import org.apache.nifi.web.api.dto.VerifyConfigRequestDTO;
|
||||||
import org.apache.nifi.web.api.entity.ComponentStateEntity;
|
import org.apache.nifi.web.api.entity.ComponentStateEntity;
|
||||||
|
import org.apache.nifi.web.api.entity.ConfigurationAnalysisEntity;
|
||||||
import org.apache.nifi.web.api.entity.ControllerServiceEntity;
|
import org.apache.nifi.web.api.entity.ControllerServiceEntity;
|
||||||
import org.apache.nifi.web.api.entity.ControllerServiceReferencingComponentsEntity;
|
import org.apache.nifi.web.api.entity.ControllerServiceReferencingComponentsEntity;
|
||||||
import org.apache.nifi.web.api.entity.ControllerServiceRunStatusEntity;
|
import org.apache.nifi.web.api.entity.ControllerServiceRunStatusEntity;
|
||||||
import org.apache.nifi.web.api.entity.PropertyDescriptorEntity;
|
import org.apache.nifi.web.api.entity.PropertyDescriptorEntity;
|
||||||
import org.apache.nifi.web.api.entity.UpdateControllerServiceReferenceRequestEntity;
|
import org.apache.nifi.web.api.entity.UpdateControllerServiceReferenceRequestEntity;
|
||||||
import org.apache.nifi.web.api.entity.VerifyControllerServiceConfigRequestEntity;
|
import org.apache.nifi.web.api.entity.VerifyConfigRequestEntity;
|
||||||
import org.apache.nifi.web.api.request.ClientIdParameter;
|
import org.apache.nifi.web.api.request.ClientIdParameter;
|
||||||
import org.apache.nifi.web.api.request.LongParameter;
|
import org.apache.nifi.web.api.request.LongParameter;
|
||||||
import org.slf4j.Logger;
|
import org.slf4j.Logger;
|
||||||
|
@ -102,7 +104,7 @@ public class ControllerServiceResource extends ApplicationResource {
|
||||||
|
|
||||||
private static final Logger logger = LoggerFactory.getLogger(ControllerServiceResource.class);
|
private static final Logger logger = LoggerFactory.getLogger(ControllerServiceResource.class);
|
||||||
private static final String VERIFICATION_REQUEST_TYPE = "verification-request";
|
private static final String VERIFICATION_REQUEST_TYPE = "verification-request";
|
||||||
private RequestManager<VerifyControllerServiceConfigRequestEntity, List<ConfigVerificationResultDTO>> updateRequestManager =
|
private RequestManager<VerifyConfigRequestEntity, List<ConfigVerificationResultDTO>> updateRequestManager =
|
||||||
new AsyncRequestManager<>(100, TimeUnit.MINUTES.toMillis(1L), "Verify Controller Service Config Thread");
|
new AsyncRequestManager<>(100, TimeUnit.MINUTES.toMillis(1L), "Verify Controller Service Config Thread");
|
||||||
|
|
||||||
private NiFiServiceFacade serviceFacade;
|
private NiFiServiceFacade serviceFacade;
|
||||||
|
@ -841,6 +843,66 @@ public class ControllerServiceResource extends ApplicationResource {
|
||||||
);
|
);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@POST
|
||||||
|
@Consumes(MediaType.APPLICATION_JSON)
|
||||||
|
@Produces(MediaType.APPLICATION_JSON)
|
||||||
|
@Path("/{id}/config/analysis")
|
||||||
|
@ApiOperation(
|
||||||
|
value = "Performs analysis of the component's configuration, providing information about which attributes are referenced.",
|
||||||
|
response = ConfigurationAnalysisEntity.class,
|
||||||
|
authorizations = {
|
||||||
|
@Authorization(value = "Read - /controller-services/{uuid}")
|
||||||
|
}
|
||||||
|
)
|
||||||
|
@ApiResponses(
|
||||||
|
value = {
|
||||||
|
@ApiResponse(code = 400, message = "NiFi was unable to complete the request because it was invalid. The request should not be retried without modification."),
|
||||||
|
@ApiResponse(code = 401, message = "Client could not be authenticated."),
|
||||||
|
@ApiResponse(code = 403, message = "Client is not authorized to make this request."),
|
||||||
|
@ApiResponse(code = 404, message = "The specified resource could not be found."),
|
||||||
|
@ApiResponse(code = 409, message = "The request was valid but NiFi was not in the appropriate state to process it. Retrying the same request later may be successful.")
|
||||||
|
}
|
||||||
|
)
|
||||||
|
public Response analyzeConfiguration(
|
||||||
|
@ApiParam(value = "The controller service id.", required = true) @PathParam("id") final String controllerServiceId,
|
||||||
|
@ApiParam(value = "The configuration analysis request.", required = true) final ConfigurationAnalysisEntity configurationAnalysis) {
|
||||||
|
|
||||||
|
if (configurationAnalysis == null || configurationAnalysis.getConfigurationAnalysis() == null) {
|
||||||
|
throw new IllegalArgumentException("Controller Service's configuration must be specified");
|
||||||
|
}
|
||||||
|
|
||||||
|
final ConfigurationAnalysisDTO dto = configurationAnalysis.getConfigurationAnalysis();
|
||||||
|
if (dto.getComponentId() == null) {
|
||||||
|
throw new IllegalArgumentException("Controller Service's identifier must be specified in the request");
|
||||||
|
}
|
||||||
|
|
||||||
|
if (!dto.getComponentId().equals(controllerServiceId)) {
|
||||||
|
throw new IllegalArgumentException("Controller Service's identifier in the request must match the identifier provided in the URL");
|
||||||
|
}
|
||||||
|
|
||||||
|
if (dto.getProperties() == null) {
|
||||||
|
throw new IllegalArgumentException("Controller Service's properties must be specified in the request");
|
||||||
|
}
|
||||||
|
|
||||||
|
if (isReplicateRequest()) {
|
||||||
|
return replicate(HttpMethod.POST, configurationAnalysis);
|
||||||
|
}
|
||||||
|
|
||||||
|
return withWriteLock(
|
||||||
|
serviceFacade,
|
||||||
|
configurationAnalysis,
|
||||||
|
lookup -> {
|
||||||
|
final ComponentAuthorizable controllerService = lookup.getControllerService(controllerServiceId);
|
||||||
|
controllerService.getAuthorizable().authorize(authorizer, RequestAction.READ, NiFiUserUtils.getNiFiUser());
|
||||||
|
},
|
||||||
|
() -> { },
|
||||||
|
entity -> {
|
||||||
|
final ConfigurationAnalysisDTO analysis = entity.getConfigurationAnalysis();
|
||||||
|
final ConfigurationAnalysisEntity resultsEntity = serviceFacade.analyzeControllerServiceConfiguration(analysis.getComponentId(), analysis.getProperties());
|
||||||
|
return generateOkResponse(resultsEntity).build();
|
||||||
|
}
|
||||||
|
);
|
||||||
|
}
|
||||||
|
|
||||||
@POST
|
@POST
|
||||||
@Consumes(MediaType.APPLICATION_JSON)
|
@Consumes(MediaType.APPLICATION_JSON)
|
||||||
|
@ -848,7 +910,7 @@ public class ControllerServiceResource extends ApplicationResource {
|
||||||
@Path("/{id}/config/verification-requests")
|
@Path("/{id}/config/verification-requests")
|
||||||
@ApiOperation(
|
@ApiOperation(
|
||||||
value = "Performs verification of the Controller Service's configuration",
|
value = "Performs verification of the Controller Service's configuration",
|
||||||
response = VerifyControllerServiceConfigRequestEntity.class,
|
response = VerifyConfigRequestEntity.class,
|
||||||
notes = "This will initiate the process of verifying a given Controller Service configuration. This may be a long-running task. As a result, this endpoint will immediately return a " +
|
notes = "This will initiate the process of verifying a given Controller Service configuration. This may be a long-running task. As a result, this endpoint will immediately return a " +
|
||||||
"ControllerServiceConfigVerificationRequestEntity, and the process of performing the verification will occur asynchronously in the background. " +
|
"ControllerServiceConfigVerificationRequestEntity, and the process of performing the verification will occur asynchronously in the background. " +
|
||||||
"The client may then periodically poll the status of the request by " +
|
"The client may then periodically poll the status of the request by " +
|
||||||
|
@ -869,22 +931,22 @@ public class ControllerServiceResource extends ApplicationResource {
|
||||||
)
|
)
|
||||||
public Response submitConfigVerificationRequest(
|
public Response submitConfigVerificationRequest(
|
||||||
@ApiParam(value = "The controller service id.", required = true) @PathParam("id") final String controllerServiceId,
|
@ApiParam(value = "The controller service id.", required = true) @PathParam("id") final String controllerServiceId,
|
||||||
@ApiParam(value = "The controller service configuration verification request.", required = true) final VerifyControllerServiceConfigRequestEntity controllerServiceConfigRequest) {
|
@ApiParam(value = "The controller service configuration verification request.", required = true) final VerifyConfigRequestEntity controllerServiceConfigRequest) {
|
||||||
|
|
||||||
if (controllerServiceConfigRequest == null) {
|
if (controllerServiceConfigRequest == null) {
|
||||||
throw new IllegalArgumentException("Controller Service's configuration must be specified");
|
throw new IllegalArgumentException("Controller Service's configuration must be specified");
|
||||||
}
|
}
|
||||||
|
|
||||||
final VerifyControllerServiceConfigRequestDTO requestDto = controllerServiceConfigRequest.getRequest();
|
final VerifyConfigRequestDTO requestDto = controllerServiceConfigRequest.getRequest();
|
||||||
if (requestDto == null || requestDto.getControllerService() == null) {
|
if (requestDto == null || requestDto.getProperties() == null) {
|
||||||
throw new IllegalArgumentException("Controller Service must be specified");
|
throw new IllegalArgumentException("Controller Service properties must be specified");
|
||||||
}
|
}
|
||||||
|
|
||||||
if (requestDto.getControllerServiceId() == null) {
|
if (requestDto.getComponentId() == null) {
|
||||||
throw new IllegalArgumentException("Controller Service's identifier must be specified in the request");
|
throw new IllegalArgumentException("Controller Service's identifier must be specified in the request");
|
||||||
}
|
}
|
||||||
|
|
||||||
if (!requestDto.getControllerServiceId().equals(controllerServiceId)) {
|
if (!requestDto.getComponentId().equals(controllerServiceId)) {
|
||||||
throw new IllegalArgumentException("Controller Service's identifier in the request must match the identifier provided in the URL");
|
throw new IllegalArgumentException("Controller Service's identifier in the request must match the identifier provided in the URL");
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -914,7 +976,7 @@ public class ControllerServiceResource extends ApplicationResource {
|
||||||
@Path("{id}/config/verification-requests/{requestId}")
|
@Path("{id}/config/verification-requests/{requestId}")
|
||||||
@ApiOperation(
|
@ApiOperation(
|
||||||
value = "Returns the Verification Request with the given ID",
|
value = "Returns the Verification Request with the given ID",
|
||||||
response = VerifyControllerServiceConfigRequestEntity.class,
|
response = VerifyConfigRequestEntity.class,
|
||||||
notes = "Returns the Verification Request with the given ID. Once an Verification Request has been created, "
|
notes = "Returns the Verification Request with the given ID. Once an Verification Request has been created, "
|
||||||
+ "that request can subsequently be retrieved via this endpoint, and the request that is fetched will contain the updated state, such as percent complete, the "
|
+ "that request can subsequently be retrieved via this endpoint, and the request that is fetched will contain the updated state, such as percent complete, the "
|
||||||
+ "current state of the request, and any failures. ",
|
+ "current state of the request, and any failures. ",
|
||||||
|
@ -939,10 +1001,10 @@ public class ControllerServiceResource extends ApplicationResource {
|
||||||
final NiFiUser user = NiFiUserUtils.getNiFiUser();
|
final NiFiUser user = NiFiUserUtils.getNiFiUser();
|
||||||
|
|
||||||
// request manager will ensure that the current is the user that submitted this request
|
// request manager will ensure that the current is the user that submitted this request
|
||||||
final AsynchronousWebRequest<VerifyControllerServiceConfigRequestEntity, List<ConfigVerificationResultDTO>> asyncRequest =
|
final AsynchronousWebRequest<VerifyConfigRequestEntity, List<ConfigVerificationResultDTO>> asyncRequest =
|
||||||
updateRequestManager.getRequest(VERIFICATION_REQUEST_TYPE, requestId, user);
|
updateRequestManager.getRequest(VERIFICATION_REQUEST_TYPE, requestId, user);
|
||||||
|
|
||||||
final VerifyControllerServiceConfigRequestEntity updateRequestEntity = createVerifyControllerServiceConfigRequestEntity(asyncRequest, requestId);
|
final VerifyConfigRequestEntity updateRequestEntity = createVerifyControllerServiceConfigRequestEntity(asyncRequest, requestId);
|
||||||
return generateOkResponse(updateRequestEntity).build();
|
return generateOkResponse(updateRequestEntity).build();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -953,7 +1015,7 @@ public class ControllerServiceResource extends ApplicationResource {
|
||||||
@Path("{id}/config/verification-requests/{requestId}")
|
@Path("{id}/config/verification-requests/{requestId}")
|
||||||
@ApiOperation(
|
@ApiOperation(
|
||||||
value = "Deletes the Verification Request with the given ID",
|
value = "Deletes the Verification Request with the given ID",
|
||||||
response = VerifyControllerServiceConfigRequestEntity.class,
|
response = VerifyConfigRequestEntity.class,
|
||||||
notes = "Deletes the Verification Request with the given ID. After a request is created, it is expected "
|
notes = "Deletes the Verification Request with the given ID. After a request is created, it is expected "
|
||||||
+ "that the client will properly clean up the request by DELETE'ing it, once the Verification process has completed. If the request is deleted before the request "
|
+ "that the client will properly clean up the request by DELETE'ing it, once the Verification process has completed. If the request is deleted before the request "
|
||||||
+ "completes, then the Verification request will finish the step that it is currently performing and then will cancel any subsequent steps.",
|
+ "completes, then the Verification request will finish the step that it is currently performing and then will cancel any subsequent steps.",
|
||||||
|
@ -982,7 +1044,7 @@ public class ControllerServiceResource extends ApplicationResource {
|
||||||
// If this is a standalone node, or if this is the execution phase of the request, perform the actual request.
|
// If this is a standalone node, or if this is the execution phase of the request, perform the actual request.
|
||||||
if (!twoPhaseRequest || executionPhase) {
|
if (!twoPhaseRequest || executionPhase) {
|
||||||
// request manager will ensure that the current is the user that submitted this request
|
// request manager will ensure that the current is the user that submitted this request
|
||||||
final AsynchronousWebRequest<VerifyControllerServiceConfigRequestEntity, List<ConfigVerificationResultDTO>> asyncRequest =
|
final AsynchronousWebRequest<VerifyConfigRequestEntity, List<ConfigVerificationResultDTO>> asyncRequest =
|
||||||
updateRequestManager.removeRequest(VERIFICATION_REQUEST_TYPE, requestId, user);
|
updateRequestManager.removeRequest(VERIFICATION_REQUEST_TYPE, requestId, user);
|
||||||
|
|
||||||
if (asyncRequest == null) {
|
if (asyncRequest == null) {
|
||||||
|
@ -993,7 +1055,7 @@ public class ControllerServiceResource extends ApplicationResource {
|
||||||
asyncRequest.cancel();
|
asyncRequest.cancel();
|
||||||
}
|
}
|
||||||
|
|
||||||
final VerifyControllerServiceConfigRequestEntity updateRequestEntity = createVerifyControllerServiceConfigRequestEntity(asyncRequest, requestId);
|
final VerifyConfigRequestEntity updateRequestEntity = createVerifyControllerServiceConfigRequestEntity(asyncRequest, requestId);
|
||||||
return generateOkResponse(updateRequestEntity).build();
|
return generateOkResponse(updateRequestEntity).build();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -1009,22 +1071,22 @@ public class ControllerServiceResource extends ApplicationResource {
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
public Response performAsyncConfigVerification(final VerifyControllerServiceConfigRequestEntity configRequest, final NiFiUser user) {
|
public Response performAsyncConfigVerification(final VerifyConfigRequestEntity configRequest, final NiFiUser user) {
|
||||||
// Create an asynchronous request that will occur in the background, because this request may take an indeterminate amount of time.
|
// Create an asynchronous request that will occur in the background, because this request may take an indeterminate amount of time.
|
||||||
final String requestId = generateUuid();
|
final String requestId = generateUuid();
|
||||||
|
|
||||||
final VerifyControllerServiceConfigRequestDTO requestDto = configRequest.getRequest();
|
final VerifyConfigRequestDTO requestDto = configRequest.getRequest();
|
||||||
final String serviceId = requestDto.getControllerServiceId();
|
final String serviceId = requestDto.getComponentId();
|
||||||
final List<UpdateStep> updateSteps = Collections.singletonList(new StandardUpdateStep("Verify Controller Service Configuration"));
|
final List<UpdateStep> updateSteps = Collections.singletonList(new StandardUpdateStep("Verify Controller Service Configuration"));
|
||||||
|
|
||||||
final AsynchronousWebRequest<VerifyControllerServiceConfigRequestEntity, List<ConfigVerificationResultDTO>> request =
|
final AsynchronousWebRequest<VerifyConfigRequestEntity, List<ConfigVerificationResultDTO>> request =
|
||||||
new StandardAsynchronousWebRequest<>(requestId, configRequest, serviceId, user, updateSteps);
|
new StandardAsynchronousWebRequest<>(requestId, configRequest, serviceId, user, updateSteps);
|
||||||
|
|
||||||
// Submit the request to be performed in the background
|
// Submit the request to be performed in the background
|
||||||
final Consumer<AsynchronousWebRequest<VerifyControllerServiceConfigRequestEntity, List<ConfigVerificationResultDTO>>> updateTask = asyncRequest -> {
|
final Consumer<AsynchronousWebRequest<VerifyConfigRequestEntity, List<ConfigVerificationResultDTO>>> updateTask = asyncRequest -> {
|
||||||
try {
|
try {
|
||||||
final Map<String, String> attributes = requestDto.getAttributes() == null ? Collections.emptyMap() : requestDto.getAttributes();
|
final Map<String, String> attributes = requestDto.getAttributes() == null ? Collections.emptyMap() : requestDto.getAttributes();
|
||||||
final List<ConfigVerificationResultDTO> results = serviceFacade.verifyControllerServiceConfiguration(serviceId, requestDto.getControllerService(), attributes);
|
final List<ConfigVerificationResultDTO> results = serviceFacade.verifyControllerServiceConfiguration(serviceId, requestDto.getProperties(), attributes);
|
||||||
asyncRequest.markStepComplete(results);
|
asyncRequest.markStepComplete(results);
|
||||||
} catch (final Exception e) {
|
} catch (final Exception e) {
|
||||||
logger.error("Failed to verify Controller Service configuration", e);
|
logger.error("Failed to verify Controller Service configuration", e);
|
||||||
|
@ -1035,30 +1097,30 @@ public class ControllerServiceResource extends ApplicationResource {
|
||||||
updateRequestManager.submitRequest(VERIFICATION_REQUEST_TYPE, requestId, request, updateTask);
|
updateRequestManager.submitRequest(VERIFICATION_REQUEST_TYPE, requestId, request, updateTask);
|
||||||
|
|
||||||
// Generate the response
|
// Generate the response
|
||||||
final VerifyControllerServiceConfigRequestEntity resultsEntity = createVerifyControllerServiceConfigRequestEntity(request, requestId);
|
final VerifyConfigRequestEntity resultsEntity = createVerifyControllerServiceConfigRequestEntity(request, requestId);
|
||||||
return generateOkResponse(resultsEntity).build();
|
return generateOkResponse(resultsEntity).build();
|
||||||
}
|
}
|
||||||
|
|
||||||
private VerifyControllerServiceConfigRequestEntity createVerifyControllerServiceConfigRequestEntity(
|
private VerifyConfigRequestEntity createVerifyControllerServiceConfigRequestEntity(
|
||||||
final AsynchronousWebRequest<VerifyControllerServiceConfigRequestEntity, List<ConfigVerificationResultDTO>> asyncRequest, final String requestId) {
|
final AsynchronousWebRequest<VerifyConfigRequestEntity, List<ConfigVerificationResultDTO>> asyncRequest, final String requestId) {
|
||||||
|
|
||||||
final VerifyControllerServiceConfigRequestDTO requestDto = asyncRequest.getRequest().getRequest();
|
final VerifyConfigRequestDTO requestDto = asyncRequest.getRequest().getRequest();
|
||||||
final List<ConfigVerificationResultDTO> resultsList = asyncRequest.getResults();
|
final List<ConfigVerificationResultDTO> resultsList = asyncRequest.getResults();
|
||||||
|
|
||||||
final VerifyControllerServiceConfigRequestDTO dto = new VerifyControllerServiceConfigRequestDTO();
|
final VerifyConfigRequestDTO dto = new VerifyConfigRequestDTO();
|
||||||
dto.setControllerServiceId(requestDto.getControllerServiceId());
|
dto.setComponentId(requestDto.getComponentId());
|
||||||
dto.setControllerService(requestDto.getControllerService());
|
dto.setProperties(requestDto.getProperties());
|
||||||
dto.setResults(resultsList);
|
dto.setResults(resultsList);
|
||||||
|
|
||||||
dto.setComplete(resultsList != null);
|
dto.setComplete(asyncRequest.isComplete());
|
||||||
dto.setFailureReason(asyncRequest.getFailureReason());
|
dto.setFailureReason(asyncRequest.getFailureReason());
|
||||||
dto.setLastUpdated(asyncRequest.getLastUpdated());
|
dto.setLastUpdated(asyncRequest.getLastUpdated());
|
||||||
dto.setPercentCompleted(asyncRequest.getPercentComplete());
|
dto.setPercentCompleted(asyncRequest.getPercentComplete());
|
||||||
dto.setRequestId(requestId);
|
dto.setRequestId(requestId);
|
||||||
dto.setState(asyncRequest.getState());
|
dto.setState(asyncRequest.getState());
|
||||||
dto.setUri(generateResourceUri("controller-services", requestDto.getControllerServiceId(), "config", "verification-requests", requestId));
|
dto.setUri(generateResourceUri("controller-services", requestDto.getComponentId(), "config", "verification-requests", requestId));
|
||||||
|
|
||||||
final VerifyControllerServiceConfigRequestEntity entity = new VerifyControllerServiceConfigRequestEntity();
|
final VerifyConfigRequestEntity entity = new VerifyConfigRequestEntity();
|
||||||
entity.setRequest(dto);
|
entity.setRequest(dto);
|
||||||
return entity;
|
return entity;
|
||||||
}
|
}
|
||||||
|
|
|
@ -46,19 +46,21 @@ import org.apache.nifi.web.api.concurrent.UpdateStep;
|
||||||
import org.apache.nifi.web.api.dto.BundleDTO;
|
import org.apache.nifi.web.api.dto.BundleDTO;
|
||||||
import org.apache.nifi.web.api.dto.ComponentStateDTO;
|
import org.apache.nifi.web.api.dto.ComponentStateDTO;
|
||||||
import org.apache.nifi.web.api.dto.ConfigVerificationResultDTO;
|
import org.apache.nifi.web.api.dto.ConfigVerificationResultDTO;
|
||||||
|
import org.apache.nifi.web.api.dto.ConfigurationAnalysisDTO;
|
||||||
import org.apache.nifi.web.api.dto.PositionDTO;
|
import org.apache.nifi.web.api.dto.PositionDTO;
|
||||||
import org.apache.nifi.web.api.dto.ProcessorConfigDTO;
|
import org.apache.nifi.web.api.dto.ProcessorConfigDTO;
|
||||||
import org.apache.nifi.web.api.dto.ProcessorDTO;
|
import org.apache.nifi.web.api.dto.ProcessorDTO;
|
||||||
import org.apache.nifi.web.api.dto.PropertyDescriptorDTO;
|
import org.apache.nifi.web.api.dto.PropertyDescriptorDTO;
|
||||||
import org.apache.nifi.web.api.dto.VerifyProcessorConfigRequestDTO;
|
import org.apache.nifi.web.api.dto.VerifyConfigRequestDTO;
|
||||||
import org.apache.nifi.web.api.entity.ComponentStateEntity;
|
import org.apache.nifi.web.api.entity.ComponentStateEntity;
|
||||||
|
import org.apache.nifi.web.api.entity.ConfigurationAnalysisEntity;
|
||||||
import org.apache.nifi.web.api.entity.ProcessorDiagnosticsEntity;
|
import org.apache.nifi.web.api.entity.ProcessorDiagnosticsEntity;
|
||||||
import org.apache.nifi.web.api.entity.ProcessorEntity;
|
import org.apache.nifi.web.api.entity.ProcessorEntity;
|
||||||
import org.apache.nifi.web.api.entity.ProcessorRunStatusEntity;
|
import org.apache.nifi.web.api.entity.ProcessorRunStatusEntity;
|
||||||
import org.apache.nifi.web.api.entity.ProcessorsRunStatusDetailsEntity;
|
import org.apache.nifi.web.api.entity.ProcessorsRunStatusDetailsEntity;
|
||||||
import org.apache.nifi.web.api.entity.PropertyDescriptorEntity;
|
import org.apache.nifi.web.api.entity.PropertyDescriptorEntity;
|
||||||
import org.apache.nifi.web.api.entity.RunStatusDetailsRequestEntity;
|
import org.apache.nifi.web.api.entity.RunStatusDetailsRequestEntity;
|
||||||
import org.apache.nifi.web.api.entity.VerifyProcessorConfigRequestEntity;
|
import org.apache.nifi.web.api.entity.VerifyConfigRequestEntity;
|
||||||
import org.apache.nifi.web.api.request.ClientIdParameter;
|
import org.apache.nifi.web.api.request.ClientIdParameter;
|
||||||
import org.apache.nifi.web.api.request.LongParameter;
|
import org.apache.nifi.web.api.request.LongParameter;
|
||||||
import org.slf4j.Logger;
|
import org.slf4j.Logger;
|
||||||
|
@ -99,7 +101,7 @@ public class ProcessorResource extends ApplicationResource {
|
||||||
private static final Logger logger = LoggerFactory.getLogger(ProcessorResource.class);
|
private static final Logger logger = LoggerFactory.getLogger(ProcessorResource.class);
|
||||||
|
|
||||||
private static final String VERIFICATION_REQUEST_TYPE = "verification-request";
|
private static final String VERIFICATION_REQUEST_TYPE = "verification-request";
|
||||||
private RequestManager<VerifyProcessorConfigRequestEntity, List<ConfigVerificationResultDTO>> updateRequestManager =
|
private RequestManager<VerifyConfigRequestEntity, List<ConfigVerificationResultDTO>> updateRequestManager =
|
||||||
new AsyncRequestManager<>(100, TimeUnit.MINUTES.toMillis(1L), "Verify Processor Config Thread");
|
new AsyncRequestManager<>(100, TimeUnit.MINUTES.toMillis(1L), "Verify Processor Config Thread");
|
||||||
|
|
||||||
private NiFiServiceFacade serviceFacade;
|
private NiFiServiceFacade serviceFacade;
|
||||||
|
@ -547,13 +549,75 @@ public class ProcessorResource extends ApplicationResource {
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
@POST
|
||||||
|
@Consumes(MediaType.APPLICATION_JSON)
|
||||||
|
@Produces(MediaType.APPLICATION_JSON)
|
||||||
|
@Path("/{id}/config/analysis")
|
||||||
|
@ApiOperation(
|
||||||
|
value = "Performs analysis of the component's configuration, providing information about which attributes are referenced.",
|
||||||
|
response = ConfigurationAnalysisEntity.class,
|
||||||
|
authorizations = {
|
||||||
|
@Authorization(value = "Read - /processors/{uuid}")
|
||||||
|
}
|
||||||
|
)
|
||||||
|
@ApiResponses(
|
||||||
|
value = {
|
||||||
|
@ApiResponse(code = 400, message = "NiFi was unable to complete the request because it was invalid. The request should not be retried without modification."),
|
||||||
|
@ApiResponse(code = 401, message = "Client could not be authenticated."),
|
||||||
|
@ApiResponse(code = 403, message = "Client is not authorized to make this request."),
|
||||||
|
@ApiResponse(code = 404, message = "The specified resource could not be found."),
|
||||||
|
@ApiResponse(code = 409, message = "The request was valid but NiFi was not in the appropriate state to process it. Retrying the same request later may be successful.")
|
||||||
|
}
|
||||||
|
)
|
||||||
|
public Response analyzeConfiguration(
|
||||||
|
@ApiParam(value = "The processor id.", required = true) @PathParam("id") final String processorId,
|
||||||
|
@ApiParam(value = "The processor configuration analysis request.", required = true) final ConfigurationAnalysisEntity configurationAnalysis) {
|
||||||
|
|
||||||
|
if (configurationAnalysis == null || configurationAnalysis.getConfigurationAnalysis() == null) {
|
||||||
|
throw new IllegalArgumentException("Processor's configuration must be specified");
|
||||||
|
}
|
||||||
|
|
||||||
|
final ConfigurationAnalysisDTO dto = configurationAnalysis.getConfigurationAnalysis();
|
||||||
|
if (dto.getComponentId() == null) {
|
||||||
|
throw new IllegalArgumentException("Processor's identifier must be specified in the request");
|
||||||
|
}
|
||||||
|
|
||||||
|
if (!dto.getComponentId().equals(processorId)) {
|
||||||
|
throw new IllegalArgumentException("Processor's identifier in the request must match the identifier provided in the URL");
|
||||||
|
}
|
||||||
|
|
||||||
|
if (dto.getProperties() == null) {
|
||||||
|
throw new IllegalArgumentException("Processor's properties must be specified in the request");
|
||||||
|
}
|
||||||
|
|
||||||
|
if (isReplicateRequest()) {
|
||||||
|
return replicate(HttpMethod.POST, configurationAnalysis);
|
||||||
|
}
|
||||||
|
|
||||||
|
return withWriteLock(
|
||||||
|
serviceFacade,
|
||||||
|
configurationAnalysis,
|
||||||
|
lookup -> {
|
||||||
|
final ComponentAuthorizable processor = lookup.getProcessor(processorId);
|
||||||
|
processor.getAuthorizable().authorize(authorizer, RequestAction.READ, NiFiUserUtils.getNiFiUser());
|
||||||
|
},
|
||||||
|
() -> { },
|
||||||
|
entity -> {
|
||||||
|
final ConfigurationAnalysisDTO analysis = entity.getConfigurationAnalysis();
|
||||||
|
final ConfigurationAnalysisEntity resultsEntity = serviceFacade.analyzeProcessorConfiguration(analysis.getComponentId(), analysis.getProperties());
|
||||||
|
return generateOkResponse(resultsEntity).build();
|
||||||
|
}
|
||||||
|
);
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
@POST
|
@POST
|
||||||
@Consumes(MediaType.APPLICATION_JSON)
|
@Consumes(MediaType.APPLICATION_JSON)
|
||||||
@Produces(MediaType.APPLICATION_JSON)
|
@Produces(MediaType.APPLICATION_JSON)
|
||||||
@Path("/{id}/config/verification-requests")
|
@Path("/{id}/config/verification-requests")
|
||||||
@ApiOperation(
|
@ApiOperation(
|
||||||
value = "Performs verification of the Processor's configuration",
|
value = "Performs verification of the Processor's configuration",
|
||||||
response = VerifyProcessorConfigRequestEntity.class,
|
response = VerifyConfigRequestEntity.class,
|
||||||
notes = "This will initiate the process of verifying a given Processor configuration. This may be a long-running task. As a result, this endpoint will immediately return a " +
|
notes = "This will initiate the process of verifying a given Processor configuration. This may be a long-running task. As a result, this endpoint will immediately return a " +
|
||||||
"ProcessorConfigVerificationRequestEntity, and the process of performing the verification will occur asynchronously in the background. " +
|
"ProcessorConfigVerificationRequestEntity, and the process of performing the verification will occur asynchronously in the background. " +
|
||||||
"The client may then periodically poll the status of the request by " +
|
"The client may then periodically poll the status of the request by " +
|
||||||
|
@ -574,22 +638,22 @@ public class ProcessorResource extends ApplicationResource {
|
||||||
)
|
)
|
||||||
public Response submitProcessorVerificationRequest(
|
public Response submitProcessorVerificationRequest(
|
||||||
@ApiParam(value = "The processor id.", required = true) @PathParam("id") final String processorId,
|
@ApiParam(value = "The processor id.", required = true) @PathParam("id") final String processorId,
|
||||||
@ApiParam(value = "The processor configuration verification request.", required = true) final VerifyProcessorConfigRequestEntity processorConfigRequest) {
|
@ApiParam(value = "The processor configuration verification request.", required = true) final VerifyConfigRequestEntity processorConfigRequest) {
|
||||||
|
|
||||||
if (processorConfigRequest == null) {
|
if (processorConfigRequest == null) {
|
||||||
throw new IllegalArgumentException("Processor's configuration must be specified");
|
throw new IllegalArgumentException("Processor's configuration must be specified");
|
||||||
}
|
}
|
||||||
|
|
||||||
final VerifyProcessorConfigRequestDTO requestDto = processorConfigRequest.getRequest();
|
final VerifyConfigRequestDTO requestDto = processorConfigRequest.getRequest();
|
||||||
if (requestDto == null || requestDto.getProcessorConfig() == null) {
|
if (requestDto == null || requestDto.getProperties() == null) {
|
||||||
throw new IllegalArgumentException("Processor's configuration must be specified");
|
throw new IllegalArgumentException("Processor's properties must be specified");
|
||||||
}
|
}
|
||||||
|
|
||||||
if (requestDto.getProcessorId() == null) {
|
if (requestDto.getComponentId() == null) {
|
||||||
throw new IllegalArgumentException("Processor's identifier must be specified in the request");
|
throw new IllegalArgumentException("Processor's identifier must be specified in the request");
|
||||||
}
|
}
|
||||||
|
|
||||||
if (!requestDto.getProcessorId().equals(processorId)) {
|
if (!requestDto.getComponentId().equals(processorId)) {
|
||||||
throw new IllegalArgumentException("Processor's identifier in the request must match the identifier provided in the URL");
|
throw new IllegalArgumentException("Processor's identifier in the request must match the identifier provided in the URL");
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -619,7 +683,7 @@ public class ProcessorResource extends ApplicationResource {
|
||||||
@Path("{id}/config/verification-requests/{requestId}")
|
@Path("{id}/config/verification-requests/{requestId}")
|
||||||
@ApiOperation(
|
@ApiOperation(
|
||||||
value = "Returns the Verification Request with the given ID",
|
value = "Returns the Verification Request with the given ID",
|
||||||
response = VerifyProcessorConfigRequestEntity.class,
|
response = VerifyConfigRequestEntity.class,
|
||||||
notes = "Returns the Verification Request with the given ID. Once an Verification Request has been created, "
|
notes = "Returns the Verification Request with the given ID. Once an Verification Request has been created, "
|
||||||
+ "that request can subsequently be retrieved via this endpoint, and the request that is fetched will contain the updated state, such as percent complete, the "
|
+ "that request can subsequently be retrieved via this endpoint, and the request that is fetched will contain the updated state, such as percent complete, the "
|
||||||
+ "current state of the request, and any failures. ",
|
+ "current state of the request, and any failures. ",
|
||||||
|
@ -644,8 +708,8 @@ public class ProcessorResource extends ApplicationResource {
|
||||||
final NiFiUser user = NiFiUserUtils.getNiFiUser();
|
final NiFiUser user = NiFiUserUtils.getNiFiUser();
|
||||||
|
|
||||||
// request manager will ensure that the current is the user that submitted this request
|
// request manager will ensure that the current is the user that submitted this request
|
||||||
final AsynchronousWebRequest<VerifyProcessorConfigRequestEntity, List<ConfigVerificationResultDTO>> asyncRequest = updateRequestManager.getRequest(VERIFICATION_REQUEST_TYPE, requestId, user);
|
final AsynchronousWebRequest<VerifyConfigRequestEntity, List<ConfigVerificationResultDTO>> asyncRequest = updateRequestManager.getRequest(VERIFICATION_REQUEST_TYPE, requestId, user);
|
||||||
final VerifyProcessorConfigRequestEntity updateRequestEntity = createVerifyProcessorConfigRequestEntity(asyncRequest, requestId);
|
final VerifyConfigRequestEntity updateRequestEntity = createVerifyProcessorConfigRequestEntity(asyncRequest, requestId);
|
||||||
return generateOkResponse(updateRequestEntity).build();
|
return generateOkResponse(updateRequestEntity).build();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -656,7 +720,7 @@ public class ProcessorResource extends ApplicationResource {
|
||||||
@Path("{id}/config/verification-requests/{requestId}")
|
@Path("{id}/config/verification-requests/{requestId}")
|
||||||
@ApiOperation(
|
@ApiOperation(
|
||||||
value = "Deletes the Verification Request with the given ID",
|
value = "Deletes the Verification Request with the given ID",
|
||||||
response = VerifyProcessorConfigRequestEntity.class,
|
response = VerifyConfigRequestEntity.class,
|
||||||
notes = "Deletes the Verification Request with the given ID. After a request is created, it is expected "
|
notes = "Deletes the Verification Request with the given ID. After a request is created, it is expected "
|
||||||
+ "that the client will properly clean up the request by DELETE'ing it, once the Verification process has completed. If the request is deleted before the request "
|
+ "that the client will properly clean up the request by DELETE'ing it, once the Verification process has completed. If the request is deleted before the request "
|
||||||
+ "completes, then the Verification request will finish the step that it is currently performing and then will cancel any subsequent steps.",
|
+ "completes, then the Verification request will finish the step that it is currently performing and then will cancel any subsequent steps.",
|
||||||
|
@ -685,14 +749,14 @@ public class ProcessorResource extends ApplicationResource {
|
||||||
// If this is a standalone node, or if this is the execution phase of the request, perform the actual request.
|
// If this is a standalone node, or if this is the execution phase of the request, perform the actual request.
|
||||||
if (!twoPhaseRequest || executionPhase) {
|
if (!twoPhaseRequest || executionPhase) {
|
||||||
// request manager will ensure that the current is the user that submitted this request
|
// request manager will ensure that the current is the user that submitted this request
|
||||||
final AsynchronousWebRequest<VerifyProcessorConfigRequestEntity, List<ConfigVerificationResultDTO>> asyncRequest =
|
final AsynchronousWebRequest<VerifyConfigRequestEntity, List<ConfigVerificationResultDTO>> asyncRequest =
|
||||||
updateRequestManager.removeRequest(VERIFICATION_REQUEST_TYPE, requestId, user);
|
updateRequestManager.removeRequest(VERIFICATION_REQUEST_TYPE, requestId, user);
|
||||||
|
|
||||||
if (!asyncRequest.isComplete()) {
|
if (!asyncRequest.isComplete()) {
|
||||||
asyncRequest.cancel();
|
asyncRequest.cancel();
|
||||||
}
|
}
|
||||||
|
|
||||||
final VerifyProcessorConfigRequestEntity updateRequestEntity = createVerifyProcessorConfigRequestEntity(asyncRequest, requestId);
|
final VerifyConfigRequestEntity updateRequestEntity = createVerifyProcessorConfigRequestEntity(asyncRequest, requestId);
|
||||||
return generateOkResponse(updateRequestEntity).build();
|
return generateOkResponse(updateRequestEntity).build();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -986,23 +1050,23 @@ public class ProcessorResource extends ApplicationResource {
|
||||||
return dto;
|
return dto;
|
||||||
}
|
}
|
||||||
|
|
||||||
public Response performAsyncConfigVerification(final VerifyProcessorConfigRequestEntity processorConfigRequest, final NiFiUser user) {
|
public Response performAsyncConfigVerification(final VerifyConfigRequestEntity processorConfigRequest, final NiFiUser user) {
|
||||||
// Create an asynchronous request that will occur in the background, because this request may take an indeterminate amount of time.
|
// Create an asynchronous request that will occur in the background, because this request may take an indeterminate amount of time.
|
||||||
final String requestId = generateUuid();
|
final String requestId = generateUuid();
|
||||||
logger.debug("Generated Config Verification Request with ID {} for Processor {}", requestId, processorConfigRequest.getRequest().getProcessorId());
|
logger.debug("Generated Config Verification Request with ID {} for Processor {}", requestId, processorConfigRequest.getRequest().getComponentId());
|
||||||
|
|
||||||
final VerifyProcessorConfigRequestDTO requestDto = processorConfigRequest.getRequest();
|
final VerifyConfigRequestDTO requestDto = processorConfigRequest.getRequest();
|
||||||
final String processorId = requestDto.getProcessorId();
|
final String processorId = requestDto.getComponentId();
|
||||||
final List<UpdateStep> updateSteps = Collections.singletonList(new StandardUpdateStep("Verify Processor Configuration"));
|
final List<UpdateStep> updateSteps = Collections.singletonList(new StandardUpdateStep("Verify Processor Configuration"));
|
||||||
|
|
||||||
final AsynchronousWebRequest<VerifyProcessorConfigRequestEntity, List<ConfigVerificationResultDTO>> request =
|
final AsynchronousWebRequest<VerifyConfigRequestEntity, List<ConfigVerificationResultDTO>> request =
|
||||||
new StandardAsynchronousWebRequest<>(requestId, processorConfigRequest, processorId, user, updateSteps);
|
new StandardAsynchronousWebRequest<>(requestId, processorConfigRequest, processorId, user, updateSteps);
|
||||||
|
|
||||||
// Submit the request to be performed in the background
|
// Submit the request to be performed in the background
|
||||||
final Consumer<AsynchronousWebRequest<VerifyProcessorConfigRequestEntity, List<ConfigVerificationResultDTO>>> updateTask = asyncRequest -> {
|
final Consumer<AsynchronousWebRequest<VerifyConfigRequestEntity, List<ConfigVerificationResultDTO>>> updateTask = asyncRequest -> {
|
||||||
try {
|
try {
|
||||||
final Map<String, String> attributes = requestDto.getAttributes() == null ? Collections.emptyMap() : requestDto.getAttributes();
|
final Map<String, String> attributes = requestDto.getAttributes() == null ? Collections.emptyMap() : requestDto.getAttributes();
|
||||||
final List<ConfigVerificationResultDTO> results = serviceFacade.verifyProcessorConfiguration(processorId, requestDto.getProcessorConfig(), attributes);
|
final List<ConfigVerificationResultDTO> results = serviceFacade.verifyProcessorConfiguration(processorId, requestDto.getProperties(), attributes);
|
||||||
asyncRequest.markStepComplete(results);
|
asyncRequest.markStepComplete(results);
|
||||||
} catch (final Exception e) {
|
} catch (final Exception e) {
|
||||||
logger.error("Failed to verify Processor configuration", e);
|
logger.error("Failed to verify Processor configuration", e);
|
||||||
|
@ -1013,30 +1077,30 @@ public class ProcessorResource extends ApplicationResource {
|
||||||
updateRequestManager.submitRequest(VERIFICATION_REQUEST_TYPE, requestId, request, updateTask);
|
updateRequestManager.submitRequest(VERIFICATION_REQUEST_TYPE, requestId, request, updateTask);
|
||||||
|
|
||||||
// Generate the response
|
// Generate the response
|
||||||
final VerifyProcessorConfigRequestEntity resultsEntity = createVerifyProcessorConfigRequestEntity(request, requestId);
|
final VerifyConfigRequestEntity resultsEntity = createVerifyProcessorConfigRequestEntity(request, requestId);
|
||||||
return generateOkResponse(resultsEntity).build();
|
return generateOkResponse(resultsEntity).build();
|
||||||
}
|
}
|
||||||
|
|
||||||
private VerifyProcessorConfigRequestEntity createVerifyProcessorConfigRequestEntity(
|
private VerifyConfigRequestEntity createVerifyProcessorConfigRequestEntity(
|
||||||
final AsynchronousWebRequest<VerifyProcessorConfigRequestEntity, List<ConfigVerificationResultDTO>> asyncRequest,
|
final AsynchronousWebRequest<VerifyConfigRequestEntity, List<ConfigVerificationResultDTO>> asyncRequest,
|
||||||
final String requestId) {
|
final String requestId) {
|
||||||
final VerifyProcessorConfigRequestDTO requestDto = asyncRequest.getRequest().getRequest();
|
final VerifyConfigRequestDTO requestDto = asyncRequest.getRequest().getRequest();
|
||||||
final List<ConfigVerificationResultDTO> resultsList = asyncRequest.getResults();
|
final List<ConfigVerificationResultDTO> resultsList = asyncRequest.getResults();
|
||||||
|
|
||||||
final VerifyProcessorConfigRequestDTO dto = new VerifyProcessorConfigRequestDTO();
|
final VerifyConfigRequestDTO dto = new VerifyConfigRequestDTO();
|
||||||
dto.setProcessorId(requestDto.getProcessorId());
|
dto.setComponentId(requestDto.getComponentId());
|
||||||
dto.setProcessorConfig(requestDto.getProcessorConfig());
|
dto.setProperties(requestDto.getProperties());
|
||||||
dto.setResults(resultsList);
|
dto.setResults(resultsList);
|
||||||
|
|
||||||
dto.setComplete(resultsList != null);
|
dto.setComplete(asyncRequest.isComplete());
|
||||||
dto.setFailureReason(asyncRequest.getFailureReason());
|
dto.setFailureReason(asyncRequest.getFailureReason());
|
||||||
dto.setLastUpdated(asyncRequest.getLastUpdated());
|
dto.setLastUpdated(asyncRequest.getLastUpdated());
|
||||||
dto.setPercentCompleted(asyncRequest.getPercentComplete());
|
dto.setPercentCompleted(asyncRequest.getPercentComplete());
|
||||||
dto.setRequestId(requestId);
|
dto.setRequestId(requestId);
|
||||||
dto.setState(asyncRequest.getState());
|
dto.setState(asyncRequest.getState());
|
||||||
dto.setUri(generateResourceUri("processors", requestDto.getProcessorId(), "config", "verification-requests", requestId));
|
dto.setUri(generateResourceUri("processors", requestDto.getComponentId(), "config", "verification-requests", requestId));
|
||||||
|
|
||||||
final VerifyProcessorConfigRequestEntity entity = new VerifyProcessorConfigRequestEntity();
|
final VerifyConfigRequestEntity entity = new VerifyConfigRequestEntity();
|
||||||
entity.setRequest(dto);
|
entity.setRequest(dto);
|
||||||
return entity;
|
return entity;
|
||||||
}
|
}
|
||||||
|
|
|
@ -46,14 +46,16 @@ import org.apache.nifi.web.api.concurrent.UpdateStep;
|
||||||
import org.apache.nifi.web.api.dto.BundleDTO;
|
import org.apache.nifi.web.api.dto.BundleDTO;
|
||||||
import org.apache.nifi.web.api.dto.ComponentStateDTO;
|
import org.apache.nifi.web.api.dto.ComponentStateDTO;
|
||||||
import org.apache.nifi.web.api.dto.ConfigVerificationResultDTO;
|
import org.apache.nifi.web.api.dto.ConfigVerificationResultDTO;
|
||||||
|
import org.apache.nifi.web.api.dto.ConfigurationAnalysisDTO;
|
||||||
import org.apache.nifi.web.api.dto.PropertyDescriptorDTO;
|
import org.apache.nifi.web.api.dto.PropertyDescriptorDTO;
|
||||||
import org.apache.nifi.web.api.dto.ReportingTaskDTO;
|
import org.apache.nifi.web.api.dto.ReportingTaskDTO;
|
||||||
import org.apache.nifi.web.api.dto.VerifyReportingTaskConfigRequestDTO;
|
import org.apache.nifi.web.api.dto.VerifyConfigRequestDTO;
|
||||||
import org.apache.nifi.web.api.entity.ComponentStateEntity;
|
import org.apache.nifi.web.api.entity.ComponentStateEntity;
|
||||||
|
import org.apache.nifi.web.api.entity.ConfigurationAnalysisEntity;
|
||||||
import org.apache.nifi.web.api.entity.PropertyDescriptorEntity;
|
import org.apache.nifi.web.api.entity.PropertyDescriptorEntity;
|
||||||
import org.apache.nifi.web.api.entity.ReportingTaskEntity;
|
import org.apache.nifi.web.api.entity.ReportingTaskEntity;
|
||||||
import org.apache.nifi.web.api.entity.ReportingTaskRunStatusEntity;
|
import org.apache.nifi.web.api.entity.ReportingTaskRunStatusEntity;
|
||||||
import org.apache.nifi.web.api.entity.VerifyReportingTaskConfigRequestEntity;
|
import org.apache.nifi.web.api.entity.VerifyConfigRequestEntity;
|
||||||
import org.apache.nifi.web.api.request.ClientIdParameter;
|
import org.apache.nifi.web.api.request.ClientIdParameter;
|
||||||
import org.apache.nifi.web.api.request.LongParameter;
|
import org.apache.nifi.web.api.request.LongParameter;
|
||||||
import org.slf4j.Logger;
|
import org.slf4j.Logger;
|
||||||
|
@ -93,7 +95,7 @@ public class ReportingTaskResource extends ApplicationResource {
|
||||||
|
|
||||||
private static final Logger logger = LoggerFactory.getLogger(ReportingTaskResource.class);
|
private static final Logger logger = LoggerFactory.getLogger(ReportingTaskResource.class);
|
||||||
private static final String VERIFICATION_REQUEST_TYPE = "verification-request";
|
private static final String VERIFICATION_REQUEST_TYPE = "verification-request";
|
||||||
private RequestManager<VerifyReportingTaskConfigRequestEntity, List<ConfigVerificationResultDTO>> updateRequestManager =
|
private RequestManager<VerifyConfigRequestEntity, List<ConfigVerificationResultDTO>> updateRequestManager =
|
||||||
new AsyncRequestManager<>(100, TimeUnit.MINUTES.toMillis(1L), "Verify Reporting Task Config Thread");
|
new AsyncRequestManager<>(100, TimeUnit.MINUTES.toMillis(1L), "Verify Reporting Task Config Thread");
|
||||||
|
|
||||||
private NiFiServiceFacade serviceFacade;
|
private NiFiServiceFacade serviceFacade;
|
||||||
|
@ -646,6 +648,66 @@ public class ReportingTaskResource extends ApplicationResource {
|
||||||
);
|
);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@POST
|
||||||
|
@Consumes(MediaType.APPLICATION_JSON)
|
||||||
|
@Produces(MediaType.APPLICATION_JSON)
|
||||||
|
@Path("/{id}/config/analysis")
|
||||||
|
@ApiOperation(
|
||||||
|
value = "Performs analysis of the component's configuration, providing information about which attributes are referenced.",
|
||||||
|
response = ConfigurationAnalysisEntity.class,
|
||||||
|
authorizations = {
|
||||||
|
@Authorization(value = "Read - /reporting-tasks/{uuid}")
|
||||||
|
}
|
||||||
|
)
|
||||||
|
@ApiResponses(
|
||||||
|
value = {
|
||||||
|
@ApiResponse(code = 400, message = "NiFi was unable to complete the request because it was invalid. The request should not be retried without modification."),
|
||||||
|
@ApiResponse(code = 401, message = "Client could not be authenticated."),
|
||||||
|
@ApiResponse(code = 403, message = "Client is not authorized to make this request."),
|
||||||
|
@ApiResponse(code = 404, message = "The specified resource could not be found."),
|
||||||
|
@ApiResponse(code = 409, message = "The request was valid but NiFi was not in the appropriate state to process it. Retrying the same request later may be successful.")
|
||||||
|
}
|
||||||
|
)
|
||||||
|
public Response analyzeConfiguration(
|
||||||
|
@ApiParam(value = "The reporting task id.", required = true) @PathParam("id") final String reportingTaskId,
|
||||||
|
@ApiParam(value = "The configuration analysis request.", required = true) final ConfigurationAnalysisEntity configurationAnalysis) {
|
||||||
|
|
||||||
|
if (configurationAnalysis == null || configurationAnalysis.getConfigurationAnalysis() == null) {
|
||||||
|
throw new IllegalArgumentException("Reporting Tasks's configuration must be specified");
|
||||||
|
}
|
||||||
|
|
||||||
|
final ConfigurationAnalysisDTO dto = configurationAnalysis.getConfigurationAnalysis();
|
||||||
|
if (dto.getComponentId() == null) {
|
||||||
|
throw new IllegalArgumentException("Reporting Tasks's identifier must be specified in the request");
|
||||||
|
}
|
||||||
|
|
||||||
|
if (!dto.getComponentId().equals(reportingTaskId)) {
|
||||||
|
throw new IllegalArgumentException("Reporting Tasks's identifier in the request must match the identifier provided in the URL");
|
||||||
|
}
|
||||||
|
|
||||||
|
if (dto.getProperties() == null) {
|
||||||
|
throw new IllegalArgumentException("Reporting Tasks's properties must be specified in the request");
|
||||||
|
}
|
||||||
|
|
||||||
|
if (isReplicateRequest()) {
|
||||||
|
return replicate(HttpMethod.POST, configurationAnalysis);
|
||||||
|
}
|
||||||
|
|
||||||
|
return withWriteLock(
|
||||||
|
serviceFacade,
|
||||||
|
configurationAnalysis,
|
||||||
|
lookup -> {
|
||||||
|
final ComponentAuthorizable reportingTask = lookup.getReportingTask(reportingTaskId);
|
||||||
|
reportingTask.getAuthorizable().authorize(authorizer, RequestAction.READ, NiFiUserUtils.getNiFiUser());
|
||||||
|
},
|
||||||
|
() -> { },
|
||||||
|
entity -> {
|
||||||
|
final ConfigurationAnalysisDTO analysis = entity.getConfigurationAnalysis();
|
||||||
|
final ConfigurationAnalysisEntity resultsEntity = serviceFacade.analyzeReportingTaskConfiguration(analysis.getComponentId(), analysis.getProperties());
|
||||||
|
return generateOkResponse(resultsEntity).build();
|
||||||
|
}
|
||||||
|
);
|
||||||
|
}
|
||||||
|
|
||||||
@POST
|
@POST
|
||||||
@Consumes(MediaType.APPLICATION_JSON)
|
@Consumes(MediaType.APPLICATION_JSON)
|
||||||
|
@ -653,7 +715,7 @@ public class ReportingTaskResource extends ApplicationResource {
|
||||||
@Path("/{id}/config/verification-requests")
|
@Path("/{id}/config/verification-requests")
|
||||||
@ApiOperation(
|
@ApiOperation(
|
||||||
value = "Performs verification of the Reporting Task's configuration",
|
value = "Performs verification of the Reporting Task's configuration",
|
||||||
response = VerifyReportingTaskConfigRequestEntity.class,
|
response = VerifyConfigRequestEntity.class,
|
||||||
notes = "This will initiate the process of verifying a given Reporting Task configuration. This may be a long-running task. As a result, this endpoint will immediately return a " +
|
notes = "This will initiate the process of verifying a given Reporting Task configuration. This may be a long-running task. As a result, this endpoint will immediately return a " +
|
||||||
"ReportingTaskConfigVerificationRequestEntity, and the process of performing the verification will occur asynchronously in the background. " +
|
"ReportingTaskConfigVerificationRequestEntity, and the process of performing the verification will occur asynchronously in the background. " +
|
||||||
"The client may then periodically poll the status of the request by " +
|
"The client may then periodically poll the status of the request by " +
|
||||||
|
@ -674,22 +736,22 @@ public class ReportingTaskResource extends ApplicationResource {
|
||||||
)
|
)
|
||||||
public Response submitConfigVerificationRequest(
|
public Response submitConfigVerificationRequest(
|
||||||
@ApiParam(value = "The reporting task id.", required = true) @PathParam("id") final String reportingTaskId,
|
@ApiParam(value = "The reporting task id.", required = true) @PathParam("id") final String reportingTaskId,
|
||||||
@ApiParam(value = "The reporting task configuration verification request.", required = true) final VerifyReportingTaskConfigRequestEntity reportingTaskConfigRequest) {
|
@ApiParam(value = "The reporting task configuration verification request.", required = true) final VerifyConfigRequestEntity reportingTaskConfigRequest) {
|
||||||
|
|
||||||
if (reportingTaskConfigRequest == null) {
|
if (reportingTaskConfigRequest == null) {
|
||||||
throw new IllegalArgumentException("Reporting Task's configuration must be specified");
|
throw new IllegalArgumentException("Reporting Task's configuration must be specified");
|
||||||
}
|
}
|
||||||
|
|
||||||
final VerifyReportingTaskConfigRequestDTO requestDto = reportingTaskConfigRequest.getRequest();
|
final VerifyConfigRequestDTO requestDto = reportingTaskConfigRequest.getRequest();
|
||||||
if (requestDto == null || requestDto.getReportingTask() == null) {
|
if (requestDto == null || requestDto.getProperties() == null) {
|
||||||
throw new IllegalArgumentException("Reporting Task must be specified");
|
throw new IllegalArgumentException("Reporting Task Properties must be specified");
|
||||||
}
|
}
|
||||||
|
|
||||||
if (requestDto.getReportingTaskId() == null) {
|
if (requestDto.getComponentId() == null) {
|
||||||
throw new IllegalArgumentException("Reporting Task's identifier must be specified in the request");
|
throw new IllegalArgumentException("Reporting Task's identifier must be specified in the request");
|
||||||
}
|
}
|
||||||
|
|
||||||
if (!requestDto.getReportingTaskId().equals(reportingTaskId)) {
|
if (!requestDto.getComponentId().equals(reportingTaskId)) {
|
||||||
throw new IllegalArgumentException("Reporting Task's identifier in the request must match the identifier provided in the URL");
|
throw new IllegalArgumentException("Reporting Task's identifier in the request must match the identifier provided in the URL");
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -719,7 +781,7 @@ public class ReportingTaskResource extends ApplicationResource {
|
||||||
@Path("{id}/config/verification-requests/{requestId}")
|
@Path("{id}/config/verification-requests/{requestId}")
|
||||||
@ApiOperation(
|
@ApiOperation(
|
||||||
value = "Returns the Verification Request with the given ID",
|
value = "Returns the Verification Request with the given ID",
|
||||||
response = VerifyReportingTaskConfigRequestEntity.class,
|
response = VerifyConfigRequestEntity.class,
|
||||||
notes = "Returns the Verification Request with the given ID. Once an Verification Request has been created, "
|
notes = "Returns the Verification Request with the given ID. Once an Verification Request has been created, "
|
||||||
+ "that request can subsequently be retrieved via this endpoint, and the request that is fetched will contain the updated state, such as percent complete, the "
|
+ "that request can subsequently be retrieved via this endpoint, and the request that is fetched will contain the updated state, such as percent complete, the "
|
||||||
+ "current state of the request, and any failures. ",
|
+ "current state of the request, and any failures. ",
|
||||||
|
@ -744,10 +806,10 @@ public class ReportingTaskResource extends ApplicationResource {
|
||||||
final NiFiUser user = NiFiUserUtils.getNiFiUser();
|
final NiFiUser user = NiFiUserUtils.getNiFiUser();
|
||||||
|
|
||||||
// request manager will ensure that the current is the user that submitted this request
|
// request manager will ensure that the current is the user that submitted this request
|
||||||
final AsynchronousWebRequest<VerifyReportingTaskConfigRequestEntity, List<ConfigVerificationResultDTO>> asyncRequest =
|
final AsynchronousWebRequest<VerifyConfigRequestEntity, List<ConfigVerificationResultDTO>> asyncRequest =
|
||||||
updateRequestManager.getRequest(VERIFICATION_REQUEST_TYPE, requestId, user);
|
updateRequestManager.getRequest(VERIFICATION_REQUEST_TYPE, requestId, user);
|
||||||
|
|
||||||
final VerifyReportingTaskConfigRequestEntity updateRequestEntity = createVerifyReportingTaskConfigRequestEntity(asyncRequest, requestId);
|
final VerifyConfigRequestEntity updateRequestEntity = createVerifyReportingTaskConfigRequestEntity(asyncRequest, requestId);
|
||||||
return generateOkResponse(updateRequestEntity).build();
|
return generateOkResponse(updateRequestEntity).build();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -758,7 +820,7 @@ public class ReportingTaskResource extends ApplicationResource {
|
||||||
@Path("{id}/config/verification-requests/{requestId}")
|
@Path("{id}/config/verification-requests/{requestId}")
|
||||||
@ApiOperation(
|
@ApiOperation(
|
||||||
value = "Deletes the Verification Request with the given ID",
|
value = "Deletes the Verification Request with the given ID",
|
||||||
response = VerifyReportingTaskConfigRequestEntity.class,
|
response = VerifyConfigRequestEntity.class,
|
||||||
notes = "Deletes the Verification Request with the given ID. After a request is created, it is expected "
|
notes = "Deletes the Verification Request with the given ID. After a request is created, it is expected "
|
||||||
+ "that the client will properly clean up the request by DELETE'ing it, once the Verification process has completed. If the request is deleted before the request "
|
+ "that the client will properly clean up the request by DELETE'ing it, once the Verification process has completed. If the request is deleted before the request "
|
||||||
+ "completes, then the Verification request will finish the step that it is currently performing and then will cancel any subsequent steps.",
|
+ "completes, then the Verification request will finish the step that it is currently performing and then will cancel any subsequent steps.",
|
||||||
|
@ -787,7 +849,7 @@ public class ReportingTaskResource extends ApplicationResource {
|
||||||
// If this is a standalone node, or if this is the execution phase of the request, perform the actual request.
|
// If this is a standalone node, or if this is the execution phase of the request, perform the actual request.
|
||||||
if (!twoPhaseRequest || executionPhase) {
|
if (!twoPhaseRequest || executionPhase) {
|
||||||
// request manager will ensure that the current is the user that submitted this request
|
// request manager will ensure that the current is the user that submitted this request
|
||||||
final AsynchronousWebRequest<VerifyReportingTaskConfigRequestEntity, List<ConfigVerificationResultDTO>> asyncRequest =
|
final AsynchronousWebRequest<VerifyConfigRequestEntity, List<ConfigVerificationResultDTO>> asyncRequest =
|
||||||
updateRequestManager.removeRequest(VERIFICATION_REQUEST_TYPE, requestId, user);
|
updateRequestManager.removeRequest(VERIFICATION_REQUEST_TYPE, requestId, user);
|
||||||
|
|
||||||
if (asyncRequest == null) {
|
if (asyncRequest == null) {
|
||||||
|
@ -798,7 +860,7 @@ public class ReportingTaskResource extends ApplicationResource {
|
||||||
asyncRequest.cancel();
|
asyncRequest.cancel();
|
||||||
}
|
}
|
||||||
|
|
||||||
final VerifyReportingTaskConfigRequestEntity updateRequestEntity = createVerifyReportingTaskConfigRequestEntity(asyncRequest, requestId);
|
final VerifyConfigRequestEntity updateRequestEntity = createVerifyReportingTaskConfigRequestEntity(asyncRequest, requestId);
|
||||||
return generateOkResponse(updateRequestEntity).build();
|
return generateOkResponse(updateRequestEntity).build();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -815,21 +877,21 @@ public class ReportingTaskResource extends ApplicationResource {
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
public Response performAsyncConfigVerification(final VerifyReportingTaskConfigRequestEntity configRequest, final NiFiUser user) {
|
public Response performAsyncConfigVerification(final VerifyConfigRequestEntity configRequest, final NiFiUser user) {
|
||||||
// Create an asynchronous request that will occur in the background, because this request may take an indeterminate amount of time.
|
// Create an asynchronous request that will occur in the background, because this request may take an indeterminate amount of time.
|
||||||
final String requestId = generateUuid();
|
final String requestId = generateUuid();
|
||||||
|
|
||||||
final VerifyReportingTaskConfigRequestDTO requestDto = configRequest.getRequest();
|
final VerifyConfigRequestDTO requestDto = configRequest.getRequest();
|
||||||
final String taskId = requestDto.getReportingTaskId();
|
final String taskId = requestDto.getComponentId();
|
||||||
final List<UpdateStep> updateSteps = Collections.singletonList(new StandardUpdateStep("Verify Reporting Task Configuration"));
|
final List<UpdateStep> updateSteps = Collections.singletonList(new StandardUpdateStep("Verify Reporting Task Configuration"));
|
||||||
|
|
||||||
final AsynchronousWebRequest<VerifyReportingTaskConfigRequestEntity, List<ConfigVerificationResultDTO>> request =
|
final AsynchronousWebRequest<VerifyConfigRequestEntity, List<ConfigVerificationResultDTO>> request =
|
||||||
new StandardAsynchronousWebRequest<>(requestId, configRequest, taskId, user, updateSteps);
|
new StandardAsynchronousWebRequest<>(requestId, configRequest, taskId, user, updateSteps);
|
||||||
|
|
||||||
// Submit the request to be performed in the background
|
// Submit the request to be performed in the background
|
||||||
final Consumer<AsynchronousWebRequest<VerifyReportingTaskConfigRequestEntity, List<ConfigVerificationResultDTO>>> updateTask = asyncRequest -> {
|
final Consumer<AsynchronousWebRequest<VerifyConfigRequestEntity, List<ConfigVerificationResultDTO>>> updateTask = asyncRequest -> {
|
||||||
try {
|
try {
|
||||||
final List<ConfigVerificationResultDTO> results = serviceFacade.verifyReportingTaskConfiguration(taskId, requestDto.getReportingTask());
|
final List<ConfigVerificationResultDTO> results = serviceFacade.verifyReportingTaskConfiguration(taskId, requestDto.getProperties());
|
||||||
asyncRequest.markStepComplete(results);
|
asyncRequest.markStepComplete(results);
|
||||||
} catch (final Exception e) {
|
} catch (final Exception e) {
|
||||||
logger.error("Failed to verify Reporting Task configuration", e);
|
logger.error("Failed to verify Reporting Task configuration", e);
|
||||||
|
@ -840,30 +902,30 @@ public class ReportingTaskResource extends ApplicationResource {
|
||||||
updateRequestManager.submitRequest(VERIFICATION_REQUEST_TYPE, requestId, request, updateTask);
|
updateRequestManager.submitRequest(VERIFICATION_REQUEST_TYPE, requestId, request, updateTask);
|
||||||
|
|
||||||
// Generate the response
|
// Generate the response
|
||||||
final VerifyReportingTaskConfigRequestEntity resultsEntity = createVerifyReportingTaskConfigRequestEntity(request, requestId);
|
final VerifyConfigRequestEntity resultsEntity = createVerifyReportingTaskConfigRequestEntity(request, requestId);
|
||||||
return generateOkResponse(resultsEntity).build();
|
return generateOkResponse(resultsEntity).build();
|
||||||
}
|
}
|
||||||
|
|
||||||
private VerifyReportingTaskConfigRequestEntity createVerifyReportingTaskConfigRequestEntity(
|
private VerifyConfigRequestEntity createVerifyReportingTaskConfigRequestEntity(
|
||||||
final AsynchronousWebRequest<VerifyReportingTaskConfigRequestEntity, List<ConfigVerificationResultDTO>> asyncRequest, final String requestId) {
|
final AsynchronousWebRequest<VerifyConfigRequestEntity, List<ConfigVerificationResultDTO>> asyncRequest, final String requestId) {
|
||||||
|
|
||||||
final VerifyReportingTaskConfigRequestDTO requestDto = asyncRequest.getRequest().getRequest();
|
final VerifyConfigRequestDTO requestDto = asyncRequest.getRequest().getRequest();
|
||||||
final List<ConfigVerificationResultDTO> resultsList = asyncRequest.getResults();
|
final List<ConfigVerificationResultDTO> resultsList = asyncRequest.getResults();
|
||||||
|
|
||||||
final VerifyReportingTaskConfigRequestDTO dto = new VerifyReportingTaskConfigRequestDTO();
|
final VerifyConfigRequestDTO dto = new VerifyConfigRequestDTO();
|
||||||
dto.setReportingTaskId(requestDto.getReportingTaskId());
|
dto.setComponentId(requestDto.getComponentId());
|
||||||
dto.setReportingTask(requestDto.getReportingTask());
|
dto.setProperties(requestDto.getProperties());
|
||||||
dto.setResults(resultsList);
|
dto.setResults(resultsList);
|
||||||
|
|
||||||
dto.setComplete(resultsList != null);
|
dto.setComplete(asyncRequest.isComplete());
|
||||||
dto.setFailureReason(asyncRequest.getFailureReason());
|
dto.setFailureReason(asyncRequest.getFailureReason());
|
||||||
dto.setLastUpdated(asyncRequest.getLastUpdated());
|
dto.setLastUpdated(asyncRequest.getLastUpdated());
|
||||||
dto.setPercentCompleted(asyncRequest.getPercentComplete());
|
dto.setPercentCompleted(asyncRequest.getPercentComplete());
|
||||||
dto.setRequestId(requestId);
|
dto.setRequestId(requestId);
|
||||||
dto.setState(asyncRequest.getState());
|
dto.setState(asyncRequest.getState());
|
||||||
dto.setUri(generateResourceUri("reporting-tasks", requestDto.getReportingTaskId(), "config", "verification-requests", requestId));
|
dto.setUri(generateResourceUri("reporting-tasks", requestDto.getComponentId(), "config", "verification-requests", requestId));
|
||||||
|
|
||||||
final VerifyReportingTaskConfigRequestEntity entity = new VerifyReportingTaskConfigRequestEntity();
|
final VerifyConfigRequestEntity entity = new VerifyConfigRequestEntity();
|
||||||
entity.setRequest(dto);
|
entity.setRequest(dto);
|
||||||
return entity;
|
return entity;
|
||||||
}
|
}
|
||||||
|
|
|
@ -37,7 +37,7 @@ public class StandardUpdateStep implements UpdateStep {
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public synchronized String getFailureReason() {
|
public synchronized String getFailureReason() {
|
||||||
return null;
|
return failureReason;
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
|
|
|
@ -1679,7 +1679,6 @@ public final class DtoFactory {
|
||||||
dto.getProperties().put(descriptor.getName(), propertyValue);
|
dto.getProperties().put(descriptor.getName(), propertyValue);
|
||||||
}
|
}
|
||||||
|
|
||||||
dto.setReferencedAttributes(controllerServiceNode.getReferencedAttributeNames());
|
|
||||||
dto.setValidationStatus(controllerServiceNode.getValidationStatus(1, TimeUnit.MILLISECONDS).name());
|
dto.setValidationStatus(controllerServiceNode.getValidationStatus(1, TimeUnit.MILLISECONDS).name());
|
||||||
|
|
||||||
// add the validation errors
|
// add the validation errors
|
||||||
|
@ -4014,7 +4013,6 @@ public final class DtoFactory {
|
||||||
dto.setSchedulingStrategy(procNode.getSchedulingStrategy().name());
|
dto.setSchedulingStrategy(procNode.getSchedulingStrategy().name());
|
||||||
dto.setExecutionNode(procNode.getExecutionNode().name());
|
dto.setExecutionNode(procNode.getExecutionNode().name());
|
||||||
dto.setAnnotationData(procNode.getAnnotationData());
|
dto.setAnnotationData(procNode.getAnnotationData());
|
||||||
dto.setReferencedAttributes(procNode.getReferencedAttributeNames());
|
|
||||||
|
|
||||||
// set up the default values for concurrent tasks and scheduling period
|
// set up the default values for concurrent tasks and scheduling period
|
||||||
final Map<String, String> defaultConcurrentTasks = new HashMap<>();
|
final Map<String, String> defaultConcurrentTasks = new HashMap<>();
|
||||||
|
@ -4145,7 +4143,6 @@ public final class DtoFactory {
|
||||||
copy.setParentGroupId(original.getParentGroupId());
|
copy.setParentGroupId(original.getParentGroupId());
|
||||||
copy.setName(original.getName());
|
copy.setName(original.getName());
|
||||||
copy.setProperties(copy(original.getProperties()));
|
copy.setProperties(copy(original.getProperties()));
|
||||||
copy.setReferencedAttributes(copy(original.getReferencedAttributes()));
|
|
||||||
copy.setReferencingComponents(copy(original.getReferencingComponents()));
|
copy.setReferencingComponents(copy(original.getReferencingComponents()));
|
||||||
copy.setState(original.getState());
|
copy.setState(original.getState());
|
||||||
copy.setType(original.getType());
|
copy.setType(original.getType());
|
||||||
|
@ -4258,7 +4255,6 @@ public final class DtoFactory {
|
||||||
copy.setBulletinLevel(original.getBulletinLevel());
|
copy.setBulletinLevel(original.getBulletinLevel());
|
||||||
copy.setDefaultConcurrentTasks(original.getDefaultConcurrentTasks());
|
copy.setDefaultConcurrentTasks(original.getDefaultConcurrentTasks());
|
||||||
copy.setDefaultSchedulingPeriod(original.getDefaultSchedulingPeriod());
|
copy.setDefaultSchedulingPeriod(original.getDefaultSchedulingPeriod());
|
||||||
copy.setReferencedAttributes(original.getReferencedAttributes());
|
|
||||||
copy.setLossTolerant(original.isLossTolerant());
|
copy.setLossTolerant(original.isLossTolerant());
|
||||||
|
|
||||||
return copy;
|
return copy;
|
||||||
|
|
|
@ -140,11 +140,11 @@ public interface ControllerServiceDAO {
|
||||||
/**
|
/**
|
||||||
* Performs verification of the Configuration for the Controller Service with the given ID
|
* Performs verification of the Configuration for the Controller Service with the given ID
|
||||||
* @param controllerServiceId the id of the controller service
|
* @param controllerServiceId the id of the controller service
|
||||||
* @param controllerService the configuration to verify
|
* @param properties the configured properties to verify
|
||||||
* @param variables a map of values that can be used for resolving FlowFile attributes for Expression Language
|
* @param variables a map of values that can be used for resolving FlowFile attributes for Expression Language
|
||||||
* @return verification results
|
* @return verification results
|
||||||
*/
|
*/
|
||||||
List<ConfigVerificationResultDTO> verifyConfiguration(String controllerServiceId, ControllerServiceDTO controllerService, Map<String, String> variables);
|
List<ConfigVerificationResultDTO> verifyConfiguration(String controllerServiceId, Map<String, String> properties, Map<String, String> variables);
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Clears the state of the specified controller service.
|
* Clears the state of the specified controller service.
|
||||||
|
|
|
@ -20,7 +20,6 @@ import org.apache.nifi.components.state.Scope;
|
||||||
import org.apache.nifi.components.state.StateMap;
|
import org.apache.nifi.components.state.StateMap;
|
||||||
import org.apache.nifi.controller.ProcessorNode;
|
import org.apache.nifi.controller.ProcessorNode;
|
||||||
import org.apache.nifi.web.api.dto.ConfigVerificationResultDTO;
|
import org.apache.nifi.web.api.dto.ConfigVerificationResultDTO;
|
||||||
import org.apache.nifi.web.api.dto.ProcessorConfigDTO;
|
|
||||||
import org.apache.nifi.web.api.dto.ProcessorDTO;
|
import org.apache.nifi.web.api.dto.ProcessorDTO;
|
||||||
|
|
||||||
import java.util.List;
|
import java.util.List;
|
||||||
|
@ -106,11 +105,11 @@ public interface ProcessorDAO {
|
||||||
/**
|
/**
|
||||||
* Performs verification of the given Processor Configuration for the Processor with the given ID
|
* Performs verification of the given Processor Configuration for the Processor with the given ID
|
||||||
* @param processorId the id of the processor
|
* @param processorId the id of the processor
|
||||||
* @param processorConfig the configuration to verify
|
* @param properties the property configuration to verify
|
||||||
* @param attributes a map of values that can be used for resolving FlowFile attributes for Expression Language
|
* @param attributes a map of values that can be used for resolving FlowFile attributes for Expression Language
|
||||||
* @return verification results
|
* @return verification results
|
||||||
*/
|
*/
|
||||||
List<ConfigVerificationResultDTO> verifyProcessorConfiguration(String processorId, ProcessorConfigDTO processorConfig, Map<String, String> attributes);
|
List<ConfigVerificationResultDTO> verifyProcessorConfiguration(String processorId, Map<String, String> properties, Map<String, String> attributes);
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Verifies the specified processor can be removed.
|
* Verifies the specified processor can be removed.
|
||||||
|
|
|
@ -23,6 +23,7 @@ import org.apache.nifi.web.api.dto.ConfigVerificationResultDTO;
|
||||||
import org.apache.nifi.web.api.dto.ReportingTaskDTO;
|
import org.apache.nifi.web.api.dto.ReportingTaskDTO;
|
||||||
|
|
||||||
import java.util.List;
|
import java.util.List;
|
||||||
|
import java.util.Map;
|
||||||
import java.util.Set;
|
import java.util.Set;
|
||||||
|
|
||||||
public interface ReportingTaskDAO {
|
public interface ReportingTaskDAO {
|
||||||
|
@ -89,10 +90,10 @@ public interface ReportingTaskDAO {
|
||||||
/**
|
/**
|
||||||
* Performs verification of the Configuration for the Reporting Task with the given ID
|
* Performs verification of the Configuration for the Reporting Task with the given ID
|
||||||
* @param reportingTaskId the id of the Reporting Task
|
* @param reportingTaskId the id of the Reporting Task
|
||||||
* @param reportingTask the configuration to verify
|
* @param properties the configured properties to verify
|
||||||
* @return verification results
|
* @return verification results
|
||||||
*/
|
*/
|
||||||
List<ConfigVerificationResultDTO> verifyConfiguration(String reportingTaskId, ReportingTaskDTO reportingTask);
|
List<ConfigVerificationResultDTO> verifyConfiguration(String reportingTaskId, Map<String, String> properties);
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Determines whether this reporting task can be removed.
|
* Determines whether this reporting task can be removed.
|
||||||
|
|
|
@ -401,7 +401,7 @@ public class StandardControllerServiceDAO extends ComponentDAO implements Contro
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public List<ConfigVerificationResultDTO> verifyConfiguration(final String controllerServiceId, final ControllerServiceDTO controllerService, final Map<String, String> variables) {
|
public List<ConfigVerificationResultDTO> verifyConfiguration(final String controllerServiceId, final Map<String, String> properties, final Map<String, String> variables) {
|
||||||
final ControllerServiceNode serviceNode = locateControllerService(controllerServiceId);
|
final ControllerServiceNode serviceNode = locateControllerService(controllerServiceId);
|
||||||
|
|
||||||
final LogRepository logRepository = new NopLogRepository();
|
final LogRepository logRepository = new NopLogRepository();
|
||||||
|
@ -409,7 +409,7 @@ public class StandardControllerServiceDAO extends ComponentDAO implements Contro
|
||||||
final ExtensionManager extensionManager = flowController.getExtensionManager();
|
final ExtensionManager extensionManager = flowController.getExtensionManager();
|
||||||
|
|
||||||
final ParameterLookup parameterLookup = serviceNode.getProcessGroup() == null ? ParameterLookup.EMPTY : serviceNode.getProcessGroup().getParameterContext();
|
final ParameterLookup parameterLookup = serviceNode.getProcessGroup() == null ? ParameterLookup.EMPTY : serviceNode.getProcessGroup().getParameterContext();
|
||||||
final ConfigurationContext configurationContext = new StandardConfigurationContext(serviceNode, controllerService.getProperties(), controllerService.getAnnotationData(),
|
final ConfigurationContext configurationContext = new StandardConfigurationContext(serviceNode, properties, serviceNode.getAnnotationData(),
|
||||||
parameterLookup, flowController.getControllerServiceProvider(), null, flowController.getVariableRegistry());
|
parameterLookup, flowController.getControllerServiceProvider(), null, flowController.getVariableRegistry());
|
||||||
|
|
||||||
final List<ConfigVerificationResult> verificationResults = serviceNode.verifyConfiguration(configurationContext, configVerificationLog, variables, extensionManager);
|
final List<ConfigVerificationResult> verificationResults = serviceNode.verifyConfiguration(configurationContext, configVerificationLog, variables, extensionManager);
|
||||||
|
|
|
@ -442,10 +442,10 @@ public class StandardProcessorDAO extends ComponentDAO implements ProcessorDAO {
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public List<ConfigVerificationResultDTO> verifyProcessorConfiguration(final String processorId, final ProcessorConfigDTO processorConfig, final Map<String, String> attributes) {
|
public List<ConfigVerificationResultDTO> verifyProcessorConfiguration(final String processorId, final Map<String, String> properties, final Map<String, String> attributes) {
|
||||||
final ProcessorNode processor = locateProcessor(processorId);
|
final ProcessorNode processor = locateProcessor(processorId);
|
||||||
|
|
||||||
final ProcessContext processContext = new StandardProcessContext(processor, processorConfig.getProperties(), processorConfig.getAnnotationData(),
|
final ProcessContext processContext = new StandardProcessContext(processor, properties, processor.getAnnotationData(),
|
||||||
processor.getProcessGroup().getParameterContext(), flowController.getControllerServiceProvider(), flowController.getEncryptor(),
|
processor.getProcessGroup().getParameterContext(), flowController.getControllerServiceProvider(), flowController.getEncryptor(),
|
||||||
new NopStateManager(), () -> false, flowController);
|
new NopStateManager(), () -> false, flowController);
|
||||||
|
|
||||||
|
|
|
@ -261,7 +261,7 @@ public class StandardReportingTaskDAO extends ComponentDAO implements ReportingT
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public List<ConfigVerificationResultDTO> verifyConfiguration(final String reportingTaskId, final ReportingTaskDTO reportingTask) {
|
public List<ConfigVerificationResultDTO> verifyConfiguration(final String reportingTaskId, final Map<String, String> properties) {
|
||||||
final ReportingTaskNode taskNode = locateReportingTask(reportingTaskId);
|
final ReportingTaskNode taskNode = locateReportingTask(reportingTaskId);
|
||||||
|
|
||||||
final LogRepository logRepository = new NopLogRepository();
|
final LogRepository logRepository = new NopLogRepository();
|
||||||
|
@ -269,7 +269,7 @@ public class StandardReportingTaskDAO extends ComponentDAO implements ReportingT
|
||||||
final ExtensionManager extensionManager = flowController.getExtensionManager();
|
final ExtensionManager extensionManager = flowController.getExtensionManager();
|
||||||
|
|
||||||
final ParameterLookup parameterLookup = ParameterLookup.EMPTY;
|
final ParameterLookup parameterLookup = ParameterLookup.EMPTY;
|
||||||
final ConfigurationContext configurationContext = new StandardConfigurationContext(taskNode, reportingTask.getProperties(), reportingTask.getAnnotationData(),
|
final ConfigurationContext configurationContext = new StandardConfigurationContext(taskNode, properties, taskNode.getAnnotationData(),
|
||||||
parameterLookup, flowController.getControllerServiceProvider(), null, flowController.getVariableRegistry());
|
parameterLookup, flowController.getControllerServiceProvider(), null, flowController.getVariableRegistry());
|
||||||
|
|
||||||
final List<ConfigVerificationResult> verificationResults = taskNode.verifyConfiguration(configurationContext, configVerificationLog, extensionManager);
|
final List<ConfigVerificationResult> verificationResults = taskNode.verifyConfiguration(configurationContext, configVerificationLog, extensionManager);
|
||||||
|
|
|
@ -50,9 +50,7 @@ import org.apache.nifi.web.api.dto.ReportingTaskDTO;
|
||||||
import org.apache.nifi.web.api.dto.RevisionDTO;
|
import org.apache.nifi.web.api.dto.RevisionDTO;
|
||||||
import org.apache.nifi.web.api.dto.VariableDTO;
|
import org.apache.nifi.web.api.dto.VariableDTO;
|
||||||
import org.apache.nifi.web.api.dto.VariableRegistryDTO;
|
import org.apache.nifi.web.api.dto.VariableRegistryDTO;
|
||||||
import org.apache.nifi.web.api.dto.VerifyControllerServiceConfigRequestDTO;
|
import org.apache.nifi.web.api.dto.VerifyConfigRequestDTO;
|
||||||
import org.apache.nifi.web.api.dto.VerifyProcessorConfigRequestDTO;
|
|
||||||
import org.apache.nifi.web.api.dto.VerifyReportingTaskConfigRequestDTO;
|
|
||||||
import org.apache.nifi.web.api.dto.flow.FlowDTO;
|
import org.apache.nifi.web.api.dto.flow.FlowDTO;
|
||||||
import org.apache.nifi.web.api.dto.flow.ProcessGroupFlowDTO;
|
import org.apache.nifi.web.api.dto.flow.ProcessGroupFlowDTO;
|
||||||
import org.apache.nifi.web.api.dto.provenance.ProvenanceDTO;
|
import org.apache.nifi.web.api.dto.provenance.ProvenanceDTO;
|
||||||
|
@ -85,9 +83,7 @@ import org.apache.nifi.web.api.entity.ScheduleComponentsEntity;
|
||||||
import org.apache.nifi.web.api.entity.VariableEntity;
|
import org.apache.nifi.web.api.entity.VariableEntity;
|
||||||
import org.apache.nifi.web.api.entity.VariableRegistryEntity;
|
import org.apache.nifi.web.api.entity.VariableRegistryEntity;
|
||||||
import org.apache.nifi.web.api.entity.VariableRegistryUpdateRequestEntity;
|
import org.apache.nifi.web.api.entity.VariableRegistryUpdateRequestEntity;
|
||||||
import org.apache.nifi.web.api.entity.VerifyControllerServiceConfigRequestEntity;
|
import org.apache.nifi.web.api.entity.VerifyConfigRequestEntity;
|
||||||
import org.apache.nifi.web.api.entity.VerifyProcessorConfigRequestEntity;
|
|
||||||
import org.apache.nifi.web.api.entity.VerifyReportingTaskConfigRequestEntity;
|
|
||||||
import org.junit.Assert;
|
import org.junit.Assert;
|
||||||
import org.slf4j.Logger;
|
import org.slf4j.Logger;
|
||||||
import org.slf4j.LoggerFactory;
|
import org.slf4j.LoggerFactory;
|
||||||
|
@ -985,18 +981,15 @@ public class NiFiClientUtil {
|
||||||
|
|
||||||
public List<ConfigVerificationResultDTO> verifyProcessorConfig(final String processorId, final Map<String, String> properties, final Map<String, String> attributes)
|
public List<ConfigVerificationResultDTO> verifyProcessorConfig(final String processorId, final Map<String, String> properties, final Map<String, String> attributes)
|
||||||
throws NiFiClientException, IOException, InterruptedException {
|
throws NiFiClientException, IOException, InterruptedException {
|
||||||
final ProcessorConfigDTO processorConfig = new ProcessorConfigDTO();
|
final VerifyConfigRequestDTO requestDto = new VerifyConfigRequestDTO();
|
||||||
processorConfig.setProperties(properties);
|
requestDto.setComponentId(processorId);
|
||||||
|
requestDto.setProperties(properties);
|
||||||
final VerifyProcessorConfigRequestDTO requestDto = new VerifyProcessorConfigRequestDTO();
|
|
||||||
requestDto.setProcessorId(processorId);
|
|
||||||
requestDto.setProcessorConfig(processorConfig);
|
|
||||||
requestDto.setAttributes(attributes);
|
requestDto.setAttributes(attributes);
|
||||||
|
|
||||||
final VerifyProcessorConfigRequestEntity verificationRequest = new VerifyProcessorConfigRequestEntity();
|
final VerifyConfigRequestEntity verificationRequest = new VerifyConfigRequestEntity();
|
||||||
verificationRequest.setRequest(requestDto);
|
verificationRequest.setRequest(requestDto);
|
||||||
|
|
||||||
VerifyProcessorConfigRequestEntity results = nifiClient.getProcessorClient().submitConfigVerificationRequest(verificationRequest);
|
VerifyConfigRequestEntity results = nifiClient.getProcessorClient().submitConfigVerificationRequest(verificationRequest);
|
||||||
while (!results.getRequest().isComplete()) {
|
while (!results.getRequest().isComplete()) {
|
||||||
Thread.sleep(50L);
|
Thread.sleep(50L);
|
||||||
results = nifiClient.getProcessorClient().getConfigVerificationRequest(processorId, results.getRequest().getRequestId());
|
results = nifiClient.getProcessorClient().getConfigVerificationRequest(processorId, results.getRequest().getRequestId());
|
||||||
|
@ -1019,15 +1012,15 @@ public class NiFiClientUtil {
|
||||||
serviceDto.setProperties(properties);
|
serviceDto.setProperties(properties);
|
||||||
serviceDto.setId(serviceId);
|
serviceDto.setId(serviceId);
|
||||||
|
|
||||||
final VerifyControllerServiceConfigRequestDTO requestDto = new VerifyControllerServiceConfigRequestDTO();
|
final VerifyConfigRequestDTO requestDto = new VerifyConfigRequestDTO();
|
||||||
requestDto.setControllerService(serviceDto);
|
requestDto.setComponentId(serviceId);
|
||||||
requestDto.setAttributes(attributes);
|
requestDto.setAttributes(attributes);
|
||||||
requestDto.setControllerServiceId(serviceId);
|
requestDto.setProperties(properties);
|
||||||
|
|
||||||
final VerifyControllerServiceConfigRequestEntity verificationRequest = new VerifyControllerServiceConfigRequestEntity();
|
final VerifyConfigRequestEntity verificationRequest = new VerifyConfigRequestEntity();
|
||||||
verificationRequest.setRequest(requestDto);
|
verificationRequest.setRequest(requestDto);
|
||||||
|
|
||||||
VerifyControllerServiceConfigRequestEntity results = nifiClient.getControllerServicesClient().submitConfigVerificationRequest(verificationRequest);
|
VerifyConfigRequestEntity results = nifiClient.getControllerServicesClient().submitConfigVerificationRequest(verificationRequest);
|
||||||
while (!results.getRequest().isComplete()) {
|
while (!results.getRequest().isComplete()) {
|
||||||
Thread.sleep(50L);
|
Thread.sleep(50L);
|
||||||
results = nifiClient.getControllerServicesClient().getConfigVerificationRequest(serviceId, results.getRequest().getRequestId());
|
results = nifiClient.getControllerServicesClient().getConfigVerificationRequest(serviceId, results.getRequest().getRequestId());
|
||||||
|
@ -1041,18 +1034,14 @@ public class NiFiClientUtil {
|
||||||
public List<ConfigVerificationResultDTO> verifyReportingTaskConfig(final String taskId, final Map<String, String> properties)
|
public List<ConfigVerificationResultDTO> verifyReportingTaskConfig(final String taskId, final Map<String, String> properties)
|
||||||
throws InterruptedException, IOException,NiFiClientException {
|
throws InterruptedException, IOException,NiFiClientException {
|
||||||
|
|
||||||
final ReportingTaskDTO taskDto = new ReportingTaskDTO();
|
final VerifyConfigRequestDTO requestDto = new VerifyConfigRequestDTO();
|
||||||
taskDto.setProperties(properties);
|
requestDto.setComponentId(taskId);
|
||||||
taskDto.setId(taskId);
|
requestDto.setProperties(properties);
|
||||||
|
|
||||||
final VerifyReportingTaskConfigRequestDTO requestDto = new VerifyReportingTaskConfigRequestDTO();
|
final VerifyConfigRequestEntity verificationRequest = new VerifyConfigRequestEntity();
|
||||||
requestDto.setReportingTaskId(taskId);
|
|
||||||
requestDto.setReportingTask(taskDto);
|
|
||||||
|
|
||||||
final VerifyReportingTaskConfigRequestEntity verificationRequest = new VerifyReportingTaskConfigRequestEntity();
|
|
||||||
verificationRequest.setRequest(requestDto);
|
verificationRequest.setRequest(requestDto);
|
||||||
|
|
||||||
VerifyReportingTaskConfigRequestEntity results = nifiClient.getReportingTasksClient().submitConfigVerificationRequest(verificationRequest);
|
VerifyConfigRequestEntity results = nifiClient.getReportingTasksClient().submitConfigVerificationRequest(verificationRequest);
|
||||||
while (!results.getRequest().isComplete()) {
|
while (!results.getRequest().isComplete()) {
|
||||||
Thread.sleep(50L);
|
Thread.sleep(50L);
|
||||||
results = nifiClient.getReportingTasksClient().getConfigVerificationRequest(taskId, results.getRequest().getRequestId());
|
results = nifiClient.getReportingTasksClient().getConfigVerificationRequest(taskId, results.getRequest().getRequestId());
|
||||||
|
|
|
@ -20,7 +20,7 @@ import org.apache.nifi.web.api.entity.ControllerServiceEntity;
|
||||||
import org.apache.nifi.web.api.entity.ControllerServiceReferencingComponentsEntity;
|
import org.apache.nifi.web.api.entity.ControllerServiceReferencingComponentsEntity;
|
||||||
import org.apache.nifi.web.api.entity.ControllerServiceRunStatusEntity;
|
import org.apache.nifi.web.api.entity.ControllerServiceRunStatusEntity;
|
||||||
import org.apache.nifi.web.api.entity.UpdateControllerServiceReferenceRequestEntity;
|
import org.apache.nifi.web.api.entity.UpdateControllerServiceReferenceRequestEntity;
|
||||||
import org.apache.nifi.web.api.entity.VerifyControllerServiceConfigRequestEntity;
|
import org.apache.nifi.web.api.entity.VerifyConfigRequestEntity;
|
||||||
|
|
||||||
import java.io.IOException;
|
import java.io.IOException;
|
||||||
|
|
||||||
|
@ -43,10 +43,10 @@ public interface ControllerServicesClient {
|
||||||
|
|
||||||
ControllerServiceReferencingComponentsEntity updateControllerServiceReferences(UpdateControllerServiceReferenceRequestEntity referencesEntity) throws NiFiClientException, IOException;
|
ControllerServiceReferencingComponentsEntity updateControllerServiceReferences(UpdateControllerServiceReferenceRequestEntity referencesEntity) throws NiFiClientException, IOException;
|
||||||
|
|
||||||
VerifyControllerServiceConfigRequestEntity submitConfigVerificationRequest(VerifyControllerServiceConfigRequestEntity configRequestEntity) throws NiFiClientException, IOException;
|
VerifyConfigRequestEntity submitConfigVerificationRequest(VerifyConfigRequestEntity configRequestEntity) throws NiFiClientException, IOException;
|
||||||
|
|
||||||
VerifyControllerServiceConfigRequestEntity getConfigVerificationRequest(String serviceId, String verificationRequestId) throws NiFiClientException, IOException;
|
VerifyConfigRequestEntity getConfigVerificationRequest(String serviceId, String verificationRequestId) throws NiFiClientException, IOException;
|
||||||
|
|
||||||
VerifyControllerServiceConfigRequestEntity deleteConfigVerificationRequest(String serviceId, String verificationRequestId) throws NiFiClientException, IOException;
|
VerifyConfigRequestEntity deleteConfigVerificationRequest(String serviceId, String verificationRequestId) throws NiFiClientException, IOException;
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
|
@ -17,7 +17,7 @@
|
||||||
package org.apache.nifi.toolkit.cli.impl.client.nifi;
|
package org.apache.nifi.toolkit.cli.impl.client.nifi;
|
||||||
|
|
||||||
import org.apache.nifi.web.api.entity.ProcessorEntity;
|
import org.apache.nifi.web.api.entity.ProcessorEntity;
|
||||||
import org.apache.nifi.web.api.entity.VerifyProcessorConfigRequestEntity;
|
import org.apache.nifi.web.api.entity.VerifyConfigRequestEntity;
|
||||||
|
|
||||||
import java.io.IOException;
|
import java.io.IOException;
|
||||||
|
|
||||||
|
@ -48,10 +48,10 @@ public interface ProcessorClient {
|
||||||
|
|
||||||
ProcessorEntity deleteProcessor(ProcessorEntity processorEntity) throws NiFiClientException, IOException;
|
ProcessorEntity deleteProcessor(ProcessorEntity processorEntity) throws NiFiClientException, IOException;
|
||||||
|
|
||||||
VerifyProcessorConfigRequestEntity submitConfigVerificationRequest(VerifyProcessorConfigRequestEntity configRequestEntity) throws NiFiClientException, IOException;
|
VerifyConfigRequestEntity submitConfigVerificationRequest(VerifyConfigRequestEntity configRequestEntity) throws NiFiClientException, IOException;
|
||||||
|
|
||||||
VerifyProcessorConfigRequestEntity getConfigVerificationRequest(String processorId, String verificationRequestId) throws NiFiClientException, IOException;
|
VerifyConfigRequestEntity getConfigVerificationRequest(String processorId, String verificationRequestId) throws NiFiClientException, IOException;
|
||||||
|
|
||||||
VerifyProcessorConfigRequestEntity deleteConfigVerificationRequest(String processorId, String verificationRequestId) throws NiFiClientException, IOException;
|
VerifyConfigRequestEntity deleteConfigVerificationRequest(String processorId, String verificationRequestId) throws NiFiClientException, IOException;
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
|
@ -19,7 +19,7 @@ package org.apache.nifi.toolkit.cli.impl.client.nifi;
|
||||||
|
|
||||||
import org.apache.nifi.web.api.entity.ReportingTaskEntity;
|
import org.apache.nifi.web.api.entity.ReportingTaskEntity;
|
||||||
import org.apache.nifi.web.api.entity.ReportingTaskRunStatusEntity;
|
import org.apache.nifi.web.api.entity.ReportingTaskRunStatusEntity;
|
||||||
import org.apache.nifi.web.api.entity.VerifyReportingTaskConfigRequestEntity;
|
import org.apache.nifi.web.api.entity.VerifyConfigRequestEntity;
|
||||||
|
|
||||||
import java.io.IOException;
|
import java.io.IOException;
|
||||||
|
|
||||||
|
@ -34,10 +34,10 @@ public interface ReportingTasksClient {
|
||||||
|
|
||||||
ReportingTaskEntity activateReportingTask(String id, ReportingTaskRunStatusEntity runStatusEntity) throws NiFiClientException, IOException;
|
ReportingTaskEntity activateReportingTask(String id, ReportingTaskRunStatusEntity runStatusEntity) throws NiFiClientException, IOException;
|
||||||
|
|
||||||
VerifyReportingTaskConfigRequestEntity submitConfigVerificationRequest(VerifyReportingTaskConfigRequestEntity configRequestEntity) throws NiFiClientException, IOException;
|
VerifyConfigRequestEntity submitConfigVerificationRequest(VerifyConfigRequestEntity configRequestEntity) throws NiFiClientException, IOException;
|
||||||
|
|
||||||
VerifyReportingTaskConfigRequestEntity getConfigVerificationRequest(String taskId, String verificationRequestId) throws NiFiClientException, IOException;
|
VerifyConfigRequestEntity getConfigVerificationRequest(String taskId, String verificationRequestId) throws NiFiClientException, IOException;
|
||||||
|
|
||||||
VerifyReportingTaskConfigRequestEntity deleteConfigVerificationRequest(String taskId, String verificationRequestId) throws NiFiClientException, IOException;
|
VerifyConfigRequestEntity deleteConfigVerificationRequest(String taskId, String verificationRequestId) throws NiFiClientException, IOException;
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
|
@ -25,7 +25,7 @@ import org.apache.nifi.web.api.entity.ControllerServiceEntity;
|
||||||
import org.apache.nifi.web.api.entity.ControllerServiceReferencingComponentsEntity;
|
import org.apache.nifi.web.api.entity.ControllerServiceReferencingComponentsEntity;
|
||||||
import org.apache.nifi.web.api.entity.ControllerServiceRunStatusEntity;
|
import org.apache.nifi.web.api.entity.ControllerServiceRunStatusEntity;
|
||||||
import org.apache.nifi.web.api.entity.UpdateControllerServiceReferenceRequestEntity;
|
import org.apache.nifi.web.api.entity.UpdateControllerServiceReferenceRequestEntity;
|
||||||
import org.apache.nifi.web.api.entity.VerifyControllerServiceConfigRequestEntity;
|
import org.apache.nifi.web.api.entity.VerifyConfigRequestEntity;
|
||||||
|
|
||||||
import javax.ws.rs.client.Entity;
|
import javax.ws.rs.client.Entity;
|
||||||
import javax.ws.rs.client.WebTarget;
|
import javax.ws.rs.client.WebTarget;
|
||||||
|
@ -178,35 +178,35 @@ public class JerseyControllerServicesClient extends AbstractJerseyClient impleme
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public VerifyControllerServiceConfigRequestEntity submitConfigVerificationRequest(final VerifyControllerServiceConfigRequestEntity configRequestEntity) throws NiFiClientException, IOException {
|
public VerifyConfigRequestEntity submitConfigVerificationRequest(final VerifyConfigRequestEntity configRequestEntity) throws NiFiClientException, IOException {
|
||||||
if (configRequestEntity == null) {
|
if (configRequestEntity == null) {
|
||||||
throw new IllegalArgumentException("Config Request Entity cannot be null");
|
throw new IllegalArgumentException("Config Request Entity cannot be null");
|
||||||
}
|
}
|
||||||
if (configRequestEntity.getRequest() == null) {
|
if (configRequestEntity.getRequest() == null) {
|
||||||
throw new IllegalArgumentException("Config Request DTO cannot be null");
|
throw new IllegalArgumentException("Config Request DTO cannot be null");
|
||||||
}
|
}
|
||||||
if (configRequestEntity.getRequest().getControllerServiceId() == null) {
|
if (configRequestEntity.getRequest().getComponentId() == null) {
|
||||||
throw new IllegalArgumentException("Controller Service ID cannot be null");
|
throw new IllegalArgumentException("Controller Service ID cannot be null");
|
||||||
}
|
}
|
||||||
if (configRequestEntity.getRequest().getControllerService() == null) {
|
if (configRequestEntity.getRequest().getProperties() == null) {
|
||||||
throw new IllegalArgumentException("Controller Service cannot be null");
|
throw new IllegalArgumentException("Controller Service properties cannot be null");
|
||||||
}
|
}
|
||||||
|
|
||||||
return executeAction("Error submitting Config Verification Request", () -> {
|
return executeAction("Error submitting Config Verification Request", () -> {
|
||||||
final WebTarget target = controllerServicesTarget
|
final WebTarget target = controllerServicesTarget
|
||||||
.path("{id}/config/verification-requests")
|
.path("{id}/config/verification-requests")
|
||||||
.resolveTemplate("id", configRequestEntity.getRequest().getControllerServiceId());
|
.resolveTemplate("id", configRequestEntity.getRequest().getComponentId());
|
||||||
|
|
||||||
return getRequestBuilder(target).post(
|
return getRequestBuilder(target).post(
|
||||||
Entity.entity(configRequestEntity, MediaType.APPLICATION_JSON_TYPE),
|
Entity.entity(configRequestEntity, MediaType.APPLICATION_JSON_TYPE),
|
||||||
VerifyControllerServiceConfigRequestEntity.class
|
VerifyConfigRequestEntity.class
|
||||||
);
|
);
|
||||||
});
|
});
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public VerifyControllerServiceConfigRequestEntity getConfigVerificationRequest(final String serviceId, final String verificationRequestId) throws NiFiClientException, IOException {
|
public VerifyConfigRequestEntity getConfigVerificationRequest(final String serviceId, final String verificationRequestId) throws NiFiClientException, IOException {
|
||||||
if (verificationRequestId == null) {
|
if (verificationRequestId == null) {
|
||||||
throw new IllegalArgumentException("Verification Request ID cannot be null");
|
throw new IllegalArgumentException("Verification Request ID cannot be null");
|
||||||
}
|
}
|
||||||
|
@ -217,12 +217,12 @@ public class JerseyControllerServicesClient extends AbstractJerseyClient impleme
|
||||||
.resolveTemplate("id", serviceId)
|
.resolveTemplate("id", serviceId)
|
||||||
.resolveTemplate("requestId", verificationRequestId);
|
.resolveTemplate("requestId", verificationRequestId);
|
||||||
|
|
||||||
return getRequestBuilder(target).get(VerifyControllerServiceConfigRequestEntity.class);
|
return getRequestBuilder(target).get(VerifyConfigRequestEntity.class);
|
||||||
});
|
});
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public VerifyControllerServiceConfigRequestEntity deleteConfigVerificationRequest(final String serviceId, final String verificationRequestId) throws NiFiClientException, IOException {
|
public VerifyConfigRequestEntity deleteConfigVerificationRequest(final String serviceId, final String verificationRequestId) throws NiFiClientException, IOException {
|
||||||
if (verificationRequestId == null) {
|
if (verificationRequestId == null) {
|
||||||
throw new IllegalArgumentException("Verification Request ID cannot be null");
|
throw new IllegalArgumentException("Verification Request ID cannot be null");
|
||||||
}
|
}
|
||||||
|
@ -233,7 +233,7 @@ public class JerseyControllerServicesClient extends AbstractJerseyClient impleme
|
||||||
.resolveTemplate("id", serviceId)
|
.resolveTemplate("id", serviceId)
|
||||||
.resolveTemplate("requestId", verificationRequestId);
|
.resolveTemplate("requestId", verificationRequestId);
|
||||||
|
|
||||||
return getRequestBuilder(target).delete(VerifyControllerServiceConfigRequestEntity.class);
|
return getRequestBuilder(target).delete(VerifyConfigRequestEntity.class);
|
||||||
});
|
});
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -23,7 +23,7 @@ import org.apache.nifi.toolkit.cli.impl.client.nifi.RequestConfig;
|
||||||
import org.apache.nifi.web.api.dto.RevisionDTO;
|
import org.apache.nifi.web.api.dto.RevisionDTO;
|
||||||
import org.apache.nifi.web.api.entity.ProcessorEntity;
|
import org.apache.nifi.web.api.entity.ProcessorEntity;
|
||||||
import org.apache.nifi.web.api.entity.ProcessorRunStatusEntity;
|
import org.apache.nifi.web.api.entity.ProcessorRunStatusEntity;
|
||||||
import org.apache.nifi.web.api.entity.VerifyProcessorConfigRequestEntity;
|
import org.apache.nifi.web.api.entity.VerifyConfigRequestEntity;
|
||||||
|
|
||||||
import javax.ws.rs.client.Entity;
|
import javax.ws.rs.client.Entity;
|
||||||
import javax.ws.rs.client.WebTarget;
|
import javax.ws.rs.client.WebTarget;
|
||||||
|
@ -181,34 +181,34 @@ public class JerseyProcessorClient extends AbstractJerseyClient implements Proce
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public VerifyProcessorConfigRequestEntity submitConfigVerificationRequest(final VerifyProcessorConfigRequestEntity configRequestEntity) throws NiFiClientException, IOException {
|
public VerifyConfigRequestEntity submitConfigVerificationRequest(final VerifyConfigRequestEntity configRequestEntity) throws NiFiClientException, IOException {
|
||||||
if (configRequestEntity == null) {
|
if (configRequestEntity == null) {
|
||||||
throw new IllegalArgumentException("Config Request Entity cannot be null");
|
throw new IllegalArgumentException("Config Request Entity cannot be null");
|
||||||
}
|
}
|
||||||
if (configRequestEntity.getRequest() == null) {
|
if (configRequestEntity.getRequest() == null) {
|
||||||
throw new IllegalArgumentException("Config Request DTO cannot be null");
|
throw new IllegalArgumentException("Config Request DTO cannot be null");
|
||||||
}
|
}
|
||||||
if (configRequestEntity.getRequest().getProcessorId() == null) {
|
if (configRequestEntity.getRequest().getComponentId() == null) {
|
||||||
throw new IllegalArgumentException("Processor ID cannot be null");
|
throw new IllegalArgumentException("Processor ID cannot be null");
|
||||||
}
|
}
|
||||||
if (configRequestEntity.getRequest().getProcessorConfig() == null) {
|
if (configRequestEntity.getRequest().getProperties() == null) {
|
||||||
throw new IllegalArgumentException("Processor Config cannot be null");
|
throw new IllegalArgumentException("Processor properties cannot be null");
|
||||||
}
|
}
|
||||||
|
|
||||||
return executeAction("Error submitting Config Verification Request", () -> {
|
return executeAction("Error submitting Config Verification Request", () -> {
|
||||||
final WebTarget target = processorTarget
|
final WebTarget target = processorTarget
|
||||||
.path("/config/verification-requests")
|
.path("/config/verification-requests")
|
||||||
.resolveTemplate("id", configRequestEntity.getRequest().getProcessorId());
|
.resolveTemplate("id", configRequestEntity.getRequest().getComponentId());
|
||||||
|
|
||||||
return getRequestBuilder(target).post(
|
return getRequestBuilder(target).post(
|
||||||
Entity.entity(configRequestEntity, MediaType.APPLICATION_JSON_TYPE),
|
Entity.entity(configRequestEntity, MediaType.APPLICATION_JSON_TYPE),
|
||||||
VerifyProcessorConfigRequestEntity.class
|
VerifyConfigRequestEntity.class
|
||||||
);
|
);
|
||||||
});
|
});
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public VerifyProcessorConfigRequestEntity getConfigVerificationRequest(final String processorId, final String verificationRequestId) throws NiFiClientException, IOException {
|
public VerifyConfigRequestEntity getConfigVerificationRequest(final String processorId, final String verificationRequestId) throws NiFiClientException, IOException {
|
||||||
if (verificationRequestId == null) {
|
if (verificationRequestId == null) {
|
||||||
throw new IllegalArgumentException("Verification Request ID cannot be null");
|
throw new IllegalArgumentException("Verification Request ID cannot be null");
|
||||||
}
|
}
|
||||||
|
@ -219,12 +219,12 @@ public class JerseyProcessorClient extends AbstractJerseyClient implements Proce
|
||||||
.resolveTemplate("id", processorId)
|
.resolveTemplate("id", processorId)
|
||||||
.resolveTemplate("requestId", verificationRequestId);
|
.resolveTemplate("requestId", verificationRequestId);
|
||||||
|
|
||||||
return getRequestBuilder(target).get(VerifyProcessorConfigRequestEntity.class);
|
return getRequestBuilder(target).get(VerifyConfigRequestEntity.class);
|
||||||
});
|
});
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public VerifyProcessorConfigRequestEntity deleteConfigVerificationRequest(final String processorId, final String verificationRequestId) throws NiFiClientException, IOException {
|
public VerifyConfigRequestEntity deleteConfigVerificationRequest(final String processorId, final String verificationRequestId) throws NiFiClientException, IOException {
|
||||||
if (verificationRequestId == null) {
|
if (verificationRequestId == null) {
|
||||||
throw new IllegalArgumentException("Verification Request ID cannot be null");
|
throw new IllegalArgumentException("Verification Request ID cannot be null");
|
||||||
}
|
}
|
||||||
|
@ -235,7 +235,7 @@ public class JerseyProcessorClient extends AbstractJerseyClient implements Proce
|
||||||
.resolveTemplate("id", processorId)
|
.resolveTemplate("id", processorId)
|
||||||
.resolveTemplate("requestId", verificationRequestId);
|
.resolveTemplate("requestId", verificationRequestId);
|
||||||
|
|
||||||
return getRequestBuilder(target).delete(VerifyProcessorConfigRequestEntity.class);
|
return getRequestBuilder(target).delete(VerifyConfigRequestEntity.class);
|
||||||
});
|
});
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -23,7 +23,7 @@ import org.apache.nifi.toolkit.cli.impl.client.nifi.ReportingTasksClient;
|
||||||
import org.apache.nifi.toolkit.cli.impl.client.nifi.RequestConfig;
|
import org.apache.nifi.toolkit.cli.impl.client.nifi.RequestConfig;
|
||||||
import org.apache.nifi.web.api.entity.ReportingTaskEntity;
|
import org.apache.nifi.web.api.entity.ReportingTaskEntity;
|
||||||
import org.apache.nifi.web.api.entity.ReportingTaskRunStatusEntity;
|
import org.apache.nifi.web.api.entity.ReportingTaskRunStatusEntity;
|
||||||
import org.apache.nifi.web.api.entity.VerifyReportingTaskConfigRequestEntity;
|
import org.apache.nifi.web.api.entity.VerifyConfigRequestEntity;
|
||||||
|
|
||||||
import javax.ws.rs.client.Entity;
|
import javax.ws.rs.client.Entity;
|
||||||
import javax.ws.rs.client.WebTarget;
|
import javax.ws.rs.client.WebTarget;
|
||||||
|
@ -96,34 +96,34 @@ public class JerseyReportingTasksClient extends AbstractJerseyClient implements
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public VerifyReportingTaskConfigRequestEntity submitConfigVerificationRequest(final VerifyReportingTaskConfigRequestEntity configRequestEntity) throws NiFiClientException, IOException {
|
public VerifyConfigRequestEntity submitConfigVerificationRequest(final VerifyConfigRequestEntity configRequestEntity) throws NiFiClientException, IOException {
|
||||||
if (configRequestEntity == null) {
|
if (configRequestEntity == null) {
|
||||||
throw new IllegalArgumentException("Config Request Entity cannot be null");
|
throw new IllegalArgumentException("Config Request Entity cannot be null");
|
||||||
}
|
}
|
||||||
if (configRequestEntity.getRequest() == null) {
|
if (configRequestEntity.getRequest() == null) {
|
||||||
throw new IllegalArgumentException("Config Request DTO cannot be null");
|
throw new IllegalArgumentException("Config Request DTO cannot be null");
|
||||||
}
|
}
|
||||||
if (configRequestEntity.getRequest().getReportingTaskId() == null) {
|
if (configRequestEntity.getRequest().getComponentId() == null) {
|
||||||
throw new IllegalArgumentException("Reporting Task ID cannot be null");
|
throw new IllegalArgumentException("Reporting Task ID cannot be null");
|
||||||
}
|
}
|
||||||
if (configRequestEntity.getRequest().getReportingTask() == null) {
|
if (configRequestEntity.getRequest().getProperties() == null) {
|
||||||
throw new IllegalArgumentException("Reporting Task cannot be null");
|
throw new IllegalArgumentException("Reporting Task properties cannot be null");
|
||||||
}
|
}
|
||||||
|
|
||||||
return executeAction("Error submitting Config Verification Request", () -> {
|
return executeAction("Error submitting Config Verification Request", () -> {
|
||||||
final WebTarget target = reportingTasksTarget
|
final WebTarget target = reportingTasksTarget
|
||||||
.path("{id}/config/verification-requests")
|
.path("{id}/config/verification-requests")
|
||||||
.resolveTemplate("id", configRequestEntity.getRequest().getReportingTaskId());
|
.resolveTemplate("id", configRequestEntity.getRequest().getComponentId());
|
||||||
|
|
||||||
return getRequestBuilder(target).post(
|
return getRequestBuilder(target).post(
|
||||||
Entity.entity(configRequestEntity, MediaType.APPLICATION_JSON_TYPE),
|
Entity.entity(configRequestEntity, MediaType.APPLICATION_JSON_TYPE),
|
||||||
VerifyReportingTaskConfigRequestEntity.class
|
VerifyConfigRequestEntity.class
|
||||||
);
|
);
|
||||||
});
|
});
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public VerifyReportingTaskConfigRequestEntity getConfigVerificationRequest(final String taskId, final String verificationRequestId) throws NiFiClientException, IOException {
|
public VerifyConfigRequestEntity getConfigVerificationRequest(final String taskId, final String verificationRequestId) throws NiFiClientException, IOException {
|
||||||
if (verificationRequestId == null) {
|
if (verificationRequestId == null) {
|
||||||
throw new IllegalArgumentException("Verification Request ID cannot be null");
|
throw new IllegalArgumentException("Verification Request ID cannot be null");
|
||||||
}
|
}
|
||||||
|
@ -134,12 +134,12 @@ public class JerseyReportingTasksClient extends AbstractJerseyClient implements
|
||||||
.resolveTemplate("id", taskId)
|
.resolveTemplate("id", taskId)
|
||||||
.resolveTemplate("requestId", verificationRequestId);
|
.resolveTemplate("requestId", verificationRequestId);
|
||||||
|
|
||||||
return getRequestBuilder(target).get(VerifyReportingTaskConfigRequestEntity.class);
|
return getRequestBuilder(target).get(VerifyConfigRequestEntity.class);
|
||||||
});
|
});
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public VerifyReportingTaskConfigRequestEntity deleteConfigVerificationRequest(final String taskId, final String verificationRequestId) throws NiFiClientException, IOException {
|
public VerifyConfigRequestEntity deleteConfigVerificationRequest(final String taskId, final String verificationRequestId) throws NiFiClientException, IOException {
|
||||||
if (verificationRequestId == null) {
|
if (verificationRequestId == null) {
|
||||||
throw new IllegalArgumentException("Verification Request ID cannot be null");
|
throw new IllegalArgumentException("Verification Request ID cannot be null");
|
||||||
}
|
}
|
||||||
|
@ -150,7 +150,7 @@ public class JerseyReportingTasksClient extends AbstractJerseyClient implements
|
||||||
.resolveTemplate("id", taskId)
|
.resolveTemplate("id", taskId)
|
||||||
.resolveTemplate("requestId", verificationRequestId);
|
.resolveTemplate("requestId", verificationRequestId);
|
||||||
|
|
||||||
return getRequestBuilder(target).delete(VerifyReportingTaskConfigRequestEntity.class);
|
return getRequestBuilder(target).delete(VerifyConfigRequestEntity.class);
|
||||||
});
|
});
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
Loading…
Reference in New Issue