All Downloads are FREE. Search and download functionalities are using the official Maven repository.

com.thinkbiganalytics.policy.precondition.FeedExecutedSinceFeeds Maven / Gradle / Ivy

package com.thinkbiganalytics.policy.precondition;

/*-
 * #%L
 * thinkbig-precondition-default
 * %%
 * 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.google.common.collect.Lists;
import com.google.common.collect.Sets;
import com.thinkbiganalytics.metadata.api.sla.FeedExecutedSinceFeed;
import com.thinkbiganalytics.metadata.rest.model.sla.Obligation;
import com.thinkbiganalytics.metadata.sla.api.Metric;
import com.thinkbiganalytics.metadata.sla.api.ObligationGroup;
import com.thinkbiganalytics.policy.PolicyProperty;
import com.thinkbiganalytics.policy.PolicyPropertyRef;
import com.thinkbiganalytics.policy.PolicyPropertyTypes;

import org.apache.commons.lang3.StringUtils;

import java.util.Arrays;
import java.util.HashSet;
import java.util.List;
import java.util.Set;

/**
 * Precondition to trigger a feed when another feed finishes
 */
@PreconditionPolicy(name = PreconditionPolicyConstants.FEED_EXECUTED_SINCE_FEEDS_NAME, description = "Policy will trigger the feed when all of the supplied feeds have successfully finished")
public class FeedExecutedSinceFeeds implements Precondition, DependentFeedPrecondition {

    /**
     * the name of the current "trigger" feed that should get executed when the {@link #categoryAndFeedList} signal they are complete
     */
    @PolicyProperty(name = "Since Feed", type = PolicyPropertyTypes.PROPERTY_TYPE.currentFeed, hidden = true)
    private String sinceCategoryAndFeedName;

    /**
     * a comman separated list of feeds that this current feed depends upon
     **/
    @PolicyProperty(name = "Dependent Feeds", required = true, type = PolicyPropertyTypes.PROPERTY_TYPE.feedChips, placeholder = "Start typing a feed",
                    hint = "Select feed(s) that this feed is dependent upon")
    private String categoryAndFeeds;

    /**
     * a derived list created from the {@link #categoryAndFeeds} string
     **/
    private List categoryAndFeedList;

    public FeedExecutedSinceFeeds(@PolicyPropertyRef(name = "Since Feed") String sinceCategoryAndFeedName, @PolicyPropertyRef(name = "Dependent Feeds") String categoryAndFeeds) {
        this.sinceCategoryAndFeedName = sinceCategoryAndFeedName;
        this.categoryAndFeeds = categoryAndFeeds;
        categoryAndFeedList = Arrays.asList(StringUtils.split(categoryAndFeeds, ","));
    }

    public String getSinceCategoryAndFeedName() {
        return sinceCategoryAndFeedName;
    }

    public void setSinceCategoryAndFeedName(String sinceCategoryAndFeedName) {
        this.sinceCategoryAndFeedName = sinceCategoryAndFeedName;
    }

    public String getCategoryAndFeeds() {
        return categoryAndFeeds;
    }

    public void setCategoryAndFeeds(String categoryAndFeeds) {
        this.categoryAndFeeds = categoryAndFeeds;
    }

    public List getCategoryAndFeedList() {
        return categoryAndFeedList;
    }

    public void setCategoryAndFeedList(List categoryAndFeedList) {
        this.categoryAndFeedList = categoryAndFeedList;
    }

    @Override
    public List getDependentFeedNames() {
        return categoryAndFeedList;
    }

    @Override
    public Set buildPreconditionObligations() {
        return Sets.newHashSet(buildPreconditionObligation());
    }

    /**
     * Builds the ObligationGroup that holds the metric that will be used to assess if this precondition is met or not
     */
    public com.thinkbiganalytics.metadata.rest.model.sla.ObligationGroup buildPreconditionObligation() {
        Set metrics = new HashSet<>();
        for (String categoryAndFeed : categoryAndFeedList) {
            FeedExecutedSinceFeed metric = new FeedExecutedSinceFeed(sinceCategoryAndFeedName, categoryAndFeed);
            metrics.add(metric);
        }
        Obligation obligation = new Obligation();
        obligation.setMetrics(Lists.newArrayList(metrics));
        com.thinkbiganalytics.metadata.rest.model.sla.ObligationGroup group = new com.thinkbiganalytics.metadata.rest.model.sla.ObligationGroup();
        group.addObligation(obligation);
        group.setCondition(ObligationGroup.Condition.REQUIRED.name());
        return group;
    }

}




© 2015 - 2024 Weber Informatics LLC | Privacy Policy