/** * */ 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; } } }