001 /* 002 * Copyright 2007-2008 The Kuali Foundation 003 * 004 * Licensed under the Educational Community License, Version 2.0 (the "License"); 005 * you may not use this file except in compliance with the License. 006 * You may obtain a copy of the License at 007 * 008 * http://www.opensource.org/licenses/ecl2.php 009 * 010 * Unless required by applicable law or agreed to in writing, software 011 * distributed under the License is distributed on an "AS IS" BASIS, 012 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. 013 * See the License for the specific language governing permissions and 014 * limitations under the License. 015 */ 016 package org.kuali.rice.ksb.messaging.bam.dao.impl; 017 018 import java.util.List; 019 020 import javax.persistence.EntityManager; 021 import javax.persistence.PersistenceContext; 022 import javax.xml.namespace.QName; 023 024 import org.kuali.rice.core.api.reflect.ObjectDefinition; 025 import org.kuali.rice.core.api.reflect.ObjectDefinition; 026 import org.kuali.rice.ksb.messaging.bam.BAMTargetEntry; 027 import org.kuali.rice.ksb.messaging.bam.dao.BAMDAO; 028 029 030 public class BAMDaoJpaImpl implements BAMDAO { 031 032 private EntityManager entityManager; 033 034 @PersistenceContext 035 public void setEntityManager(EntityManager entityManager) { 036 this.entityManager = entityManager; 037 } 038 039 public void clearBAMTables() { 040 entityManager.createQuery("delete from BAMTargetEntry").executeUpdate(); 041 entityManager.createQuery("delete from BAMParam").executeUpdate(); 042 } 043 044 public List<BAMTargetEntry> getCallsForService(QName serviceName, String methodName) { 045 return (List<BAMTargetEntry>) entityManager.createQuery("select bte from BAMTargetEntry bte where bte.serviceName = :serviceName and bte.methodName = :methodName").setParameter("serviceName", serviceName.toString()).setParameter("methodName", methodName).getResultList(); 046 } 047 048 public void save(BAMTargetEntry bamEntry) { 049 if(bamEntry.getBamId() == null) { 050 entityManager.persist(bamEntry); 051 } 052 else { 053 entityManager.merge(bamEntry); 054 } 055 } 056 057 public List<BAMTargetEntry> getCallsForService(QName serviceName) { 058 return (List<BAMTargetEntry>) entityManager.createQuery("select bte from BAMTargetEntry bte where bte.serviceName = :serviceName").setParameter("serviceName", serviceName.toString()).getResultList(); 059 } 060 061 public List<BAMTargetEntry> getCallsForRemotedClasses(ObjectDefinition objDef) { 062 QName qname = new QName(objDef.getApplicationId(), objDef.getClassName()); 063 return (List<BAMTargetEntry>) entityManager.createQuery("select bte from BAMTargetEntry bte where bte.serviceName like :serviceName%").setParameter("serviceName", qname.toString()).getResultList(); 064 } 065 066 public List<BAMTargetEntry> getCallsForRemotedClasses(ObjectDefinition objDef, String methodName) { 067 QName qname = new QName(objDef.getApplicationId(), objDef.getClassName()); 068 return (List<BAMTargetEntry>) entityManager.createQuery("select bte from BAMTargetEntry bte where bte.serviceName like :serviceName% and bte.methodName = :methodName").setParameter("serviceName", qname.toString()).setParameter("methodName", methodName).getResultList(); 069 } 070 071 }