com.thinkbiganalytics.metadata.jpa.feed.OpsManagerFeedRepository Maven / Gradle / Ivy
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