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

com.thinkbiganalytics.metadata.jpa.feed.OpsManagerFeedRepository Maven / Gradle / Ivy

There is a newer version: 0.10.0
Show newest version
package com.thinkbiganalytics.metadata.jpa.feed;

/*-
 * #%L
 * thinkbig-operational-metadata-jpa
 * %%
 * 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.metadata.api.feed.OpsManagerFeed;
import com.thinkbiganalytics.metadata.jpa.feed.security.FeedOpsAccessControlRepository;

import org.springframework.data.jpa.repository.JpaRepository;
import org.springframework.data.jpa.repository.Query;
import org.springframework.data.jpa.repository.query.Procedure;
import org.springframework.data.querydsl.QueryDslPredicateExecutor;
import org.springframework.data.repository.query.Param;

import java.util.List;
import java.util.Set;

/**
 * Spring data repository for accessing {@link JpaOpsManagerFeed}
 */
@RepositoryType(FeedSecuringRepository.class)
public interface OpsManagerFeedRepository extends JpaRepository, QueryDslPredicateExecutor {

    JpaOpsManagerFeed findByName(String name);


    @Query("select distinct feed from JpaOpsManagerFeed as feed "
           + FeedOpsAccessControlRepository.JOIN_ACL_TO_FEED
           + " where feed.name = :feedName"
           + " and " + FeedOpsAccessControlRepository.WHERE_PRINCIPALS_MATCH)
    JpaOpsManagerFeed findByNameWithAcl(@Param("feedName") String feedName);

    @Query("select distinct feed from JpaOpsManagerFeed as feed "
           + " where feed.name = :feedName ")
    JpaOpsManagerFeed findByNameWithoutAcl(@Param("feedName") String feedName);

    @Query("select distinct feed from JpaOpsManagerFeed as feed "
           + " where feed.name = :feedName ")
    List findFeedsByNameWithoutAcl(@Param("feedName") String feedName);

    @Query("select distinct feed from JpaOpsManagerFeed as feed "
           + " where feed.name in (:feedNames) ")
    List findFeedsByNameWithoutAcl(@Param("feedNames") List feedNames);


    @Query("select new com.thinkbiganalytics.metadata.jpa.feed.JpaFeedNameCount(feed.name ,count(feed.name) ) "
           + "from JpaOpsManagerFeed as feed "
           + " group by feed.name"
           + " having count(feed.name) >1")
    List findFeedsWithSameName();


    @Query("select distinct feed from JpaOpsManagerFeed as feed "
           + FeedOpsAccessControlRepository.JOIN_ACL_TO_FEED
           + " where feed.id = :id "
           + " and " + FeedOpsAccessControlRepository.WHERE_PRINCIPALS_MATCH)
    JpaOpsManagerFeed findByIdWithAcl(@Param("id") OpsManagerFeed.ID id);

    @Query("select distinct feed from JpaOpsManagerFeed as feed "
           + " where feed.id = :id")
    JpaOpsManagerFeed findByIdWithoutAcl(@Param("id") OpsManagerFeed.ID id);


    @Query("select distinct feed from JpaOpsManagerFeed as feed "
           + FeedOpsAccessControlRepository.JOIN_ACL_TO_FEED
           + " where feed.id in(:ids)"
           + " and " + FeedOpsAccessControlRepository.WHERE_PRINCIPALS_MATCH)
    List findByFeedIdsWithAcl(@Param("ids") List ids);

    @Query("select distinct feed from JpaOpsManagerFeed as feed "
           + " where feed.id in(:ids)")
    List findByFeedIdsWithoutAcl(@Param("ids") List ids);

    @Query("SELECT distinct feed.name FROM JpaOpsManagerFeed AS feed "
           + FeedOpsAccessControlRepository.JOIN_ACL_TO_FEED
           + "where " + FeedOpsAccessControlRepository.WHERE_PRINCIPALS_MATCH)
    List getFeedNamesWithAcl();

    @Query("SELECT distinct feed.name FROM JpaOpsManagerFeed AS feed ")
    List getFeedNamesWithoutAcl();

    @Procedure(name = "OpsManagerFeed.deleteFeedJobs")
    Integer deleteFeedJobs(@Param("category") String category, @Param("feed") String feed);

    @Procedure(name = "OpsManagerFeed.abandonFeedJobs")
    Integer abandonFeedJobs(@Param("feed") String feed, @Param("exitMessage") String exitMessage, @Param("username") String username);


    @Query("select distinct feed from JpaOpsManagerFeed as feed "
           + FeedOpsAccessControlRepository.JOIN_ACL_TO_FEED
           + " where feed.name in(:feedNames)"
           + " and " + FeedOpsAccessControlRepository.WHERE_PRINCIPALS_MATCH)
    List findByNamesWithAcl(@Param("feedNames") Set feedName);


    @Query("select feed from JpaOpsManagerFeed as feed "
           + " where feed.name in(:feedNames)")
    List findByNamesWithoutAcl(@Param("feedNames") Set feedName);


    @Query("select distinct feed from JpaOpsManagerFeed as feed "
           + FeedOpsAccessControlRepository.JOIN_ACL_TO_FEED
           + " where " + FeedOpsAccessControlRepository.WHERE_PRINCIPALS_MATCH)
    List findAllWithAcl();

    @Query("select distinct feed from JpaOpsManagerFeed as feed ")
    List findAllWithoutAcl();
}




© 2015 - 2025 Weber Informatics LLC | Privacy Policy