/**
*
*/
package com.thinkbiganalytics.nifi.v2.common;
/*-
* #%L
* thinkbig-nifi-core-processors
* %%
* Copyright (C) 2017 ThinkBig Analytics
* %%
* Licensed 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.
* #L%
*/
import com.thinkbiganalytics.nifi.core.api.metadata.MetadataProvider;
import com.thinkbiganalytics.nifi.core.api.metadata.MetadataProviderService;
import com.thinkbiganalytics.nifi.core.api.metadata.MetadataRecorder;
import org.apache.nifi.annotation.lifecycle.OnScheduled;
import org.apache.nifi.components.PropertyDescriptor;
import org.apache.nifi.flowfile.FlowFile;
import org.apache.nifi.processor.ProcessContext;
import org.apache.nifi.processor.ProcessSession;
import org.slf4j.Logger;
import org.slf4j.LoggerFactory;
import java.util.List;
import static com.thinkbiganalytics.nifi.v2.common.CommonProperties.FEED_CATEGORY;
import static com.thinkbiganalytics.nifi.v2.common.CommonProperties.FEED_NAME;
/**
* An abstract processor that can be configured with the feed canteory and name and
* which will look up the feed's ID.
*/
public abstract class FeedProcessor extends BaseProcessor {
/**
* The attribute in the flow file containing feed ID
*/
public static final String FEED_ID_ATTR = "feedId";
private static final Logger log = LoggerFactory.getLogger(FeedProcessor.class);
private transient MetadataProviderService providerService;
@OnScheduled
public void scheduled(ProcessContext context) {
this.providerService = context.getProperty(CommonProperties.METADATA_SERVICE).asControllerService(MetadataProviderService.class);
}
public FlowFile initialize(ProcessContext context, ProcessSession session, FlowFile flowFile) {
return ensureFeedId(context, session, flowFile);
}
@Override
protected void addProperties(List<PropertyDescriptor> list) {
super.addProperties(list);
list.add(CommonProperties.METADATA_SERVICE);
list.add(CommonProperties.FEED_CATEGORY);
list.add(CommonProperties.FEED_NAME);
}
protected MetadataProvider getMetadataProvider() {
return this.providerService.getProvider();
}
protected MetadataRecorder getMetadataRecorder() {
return this.providerService.getRecorder();
}
protected String getFeedId(ProcessContext context, FlowFile flowFile) {
String feedId = flowFile.getAttribute(FEED_ID_ATTR);
if (feedId == null) {
final String category = context.getProperty(FEED_CATEGORY).evaluateAttributeExpressions(flowFile).getValue();
final String feedName = context.getProperty(FEED_NAME).evaluateAttributeExpressions(flowFile).getValue();
try {
log.info("Resolving ID for feed {}/{}", category, feedName);
feedId = getMetadataProvider().getFeedId(category, feedName);
if (feedId != null) {
log.info("Resolving id {} for feed {}/{}", feedId, category, feedName);
return feedId;
} else {
log.warn("ID for feed {}/{} could not be located", category, feedName);
throw new FeedIdNotFoundException(category, feedName);
}
} catch (Exception e) {
log.error("Failed to retrieve feed ID", e);
throw e;
}
} else {
return feedId;
}
}
protected FlowFile ensureFeedId(ProcessContext context, ProcessSession session, FlowFile flowFile) {
String feedId = flowFile.getAttribute(FEED_ID_ATTR);
if (feedId == null) {
final String category = context.getProperty(FEED_CATEGORY).evaluateAttributeExpressions(flowFile).getValue();
final String feedName = context.getProperty(FEED_NAME).evaluateAttributeExpressions(flowFile).getValue();
try {
log.info("Resolving ID for feed {}/{}", category, feedName);
feedId = getMetadataProvider().getFeedId(category, feedName);
if (feedId != null) {
log.info("Resolving id {} for feed {}/{}", feedId, category, feedName);
return session.putAttribute(flowFile, FEED_ID_ATTR, feedId);
} else {
log.warn("ID for feed {}/{} could not be located", category, feedName);
throw new FeedIdNotFoundException(category, feedName);
}
} catch (Exception e) {
log.error("Failed to retrieve feed ID", e);
throw e;
}
} else {
return flowFile;
}
}
}