/** * Licensed to the Apache Software Foundation (ASF) under one * or more contributor license agreements. See the NOTICE file * distributed with this work for additional information * regarding copyright ownership. The ASF licenses this file * to you 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. */ package org.apache.ambari.server.orm.dao; import java.util.Collections; import java.util.List; import javax.persistence.EntityManager; import javax.persistence.TypedQuery; import org.apache.ambari.server.orm.RequiresSession; import org.apache.ambari.server.orm.entities.PermissionEntity; import org.apache.ambari.server.orm.entities.PrincipalEntity; import org.apache.ambari.server.orm.entities.PrivilegeEntity; import org.apache.ambari.server.orm.entities.ResourceEntity; import com.google.inject.Inject; import com.google.inject.Provider; import com.google.inject.Singleton; import com.google.inject.persist.Transactional; /** * Privilege Data Access Object. */ @Singleton public class PrivilegeDAO { /** * JPA entity manager */ @Inject Provider<EntityManager> entityManagerProvider; @Inject DaoUtils daoUtils; /** * Find a privilege with the given id. * * @param id type id * * @return a matching privilege or null */ @RequiresSession public PrivilegeEntity findById(Integer id) { return entityManagerProvider.get().find(PrivilegeEntity.class, id); } /** * Find all privileges. * * @return all privileges or an empty List */ @RequiresSession public List<PrivilegeEntity> findAll() { TypedQuery<PrivilegeEntity> query = entityManagerProvider.get().createQuery("SELECT privilege FROM PrivilegeEntity privilege", PrivilegeEntity.class); return daoUtils.selectList(query); } /** * Find all privileges for given resource. * * @param id ID of the resource * @return all resource privileges or an empty list */ @RequiresSession public List<PrivilegeEntity> findByResourceId(Long id) { TypedQuery<PrivilegeEntity> query = entityManagerProvider.get().createQuery("SELECT privilege FROM PrivilegeEntity privilege WHERE privilege.resource.id = :resource_id", PrivilegeEntity.class); query.setParameter("resource_id", id); return daoUtils.selectList(query); } /** * Determine whether or not the given privilege entity exists. * * @param entity the privilege entity * * @return true if the given privilege entity already exists */ public boolean exists(PrivilegeEntity entity) { return exists(entity.getPrincipal(), entity.getResource(), entity.getPermission()); } /** * Determine whether or not the privilege entity exists defined by the given principal, resource and * permission exists. * * @param principalEntity the principal entity * @param resourceEntity the resource entity * @param permissionEntity the permission entity * * @return true if the privilege entity already exists */ @RequiresSession public boolean exists(PrincipalEntity principalEntity, ResourceEntity resourceEntity, PermissionEntity permissionEntity) { TypedQuery<PrivilegeEntity> query = entityManagerProvider.get().createQuery( "SELECT privilege FROM PrivilegeEntity privilege WHERE privilege.principal = :principal AND privilege.resource = :resource AND privilege.permission = :permission", PrivilegeEntity.class); query.setParameter("principal", principalEntity); query.setParameter("resource", resourceEntity); query.setParameter("permission", permissionEntity); List<PrivilegeEntity> privilegeEntities = daoUtils.selectList(query); return !(privilegeEntities == null || privilegeEntities.isEmpty()); } /** * Find the privileges entities for the given list of principals * * @param principalList the list of principal entities * * @return the list of privileges matching the query */ @RequiresSession public List<PrivilegeEntity> findAllByPrincipal(List<PrincipalEntity> principalList) { if (principalList == null || principalList.isEmpty()) { return Collections.emptyList(); } TypedQuery<PrivilegeEntity> query = entityManagerProvider.get().createQuery("SELECT privilege FROM PrivilegeEntity privilege WHERE privilege.principal IN :principalList", PrivilegeEntity.class); query.setParameter("principalList", principalList); return daoUtils.selectList(query); } /** * Make an instance managed and persistent. * * @param entity entity to persist */ @Transactional public void create(PrivilegeEntity entity) { entityManagerProvider.get().persist(entity); } /** * Merge the state of the given entity into the current persistence context. * * @param entity entity to merge * * @return the merged entity */ @Transactional public PrivilegeEntity merge(PrivilegeEntity entity) { return entityManagerProvider.get().merge(entity); } /** * Remove the entity instance. * * @param entity entity to remove */ @Transactional public void remove(PrivilegeEntity entity) { entityManagerProvider.get().remove(merge(entity)); } /** * Detach an instance from manager. * * @param entity entity to detach */ @Transactional public void detach(PrivilegeEntity entity) { entityManagerProvider.get().detach(entity); } }