001/**
002 * Copyright 2005-2016 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 */
016package org.kuali.rice.ksb.messaging.service.impl;
017
018import org.apache.log4j.Logger;
019import org.kuali.rice.core.api.config.CoreConfigHelper;
020import org.kuali.rice.core.api.config.property.ConfigContext;
021import org.kuali.rice.core.api.util.RiceUtilities;
022import org.kuali.rice.ksb.api.bus.ServiceConfiguration;
023import org.kuali.rice.ksb.api.messaging.AsynchronousCall;
024import org.kuali.rice.ksb.messaging.PersistedMessageBO;
025import org.kuali.rice.ksb.messaging.PersistedMessagePayload;
026import org.kuali.rice.ksb.messaging.dao.MessageQueueDAO;
027import org.kuali.rice.ksb.messaging.service.MessageQueueService;
028import org.kuali.rice.ksb.util.KSBConstants;
029
030import javax.xml.namespace.QName;
031import java.sql.Timestamp;
032import java.util.List;
033import java.util.Map;
034
035public class MessageQueueServiceImpl implements MessageQueueService {
036
037
038    private static final Logger LOG = Logger.getLogger(MessageQueueServiceImpl.class);
039    private MessageQueueDAO messageQueueDao;
040
041    public void delete(PersistedMessageBO routeQueue) {
042        if (Boolean.valueOf(ConfigContext.getCurrentContextConfig().getProperty(KSBConstants.Config.MESSAGE_PERSISTENCE))) {
043            if (LOG.isDebugEnabled()) {
044                LOG.debug("Message Persistence is on.  Deleting stored message" + routeQueue);
045            }
046            this.getMessageQueueDao().remove(routeQueue);
047        }
048    }
049
050    public void save(PersistedMessageBO routeQueue) {
051        if (Boolean.valueOf(ConfigContext.getCurrentContextConfig().getProperty(KSBConstants.Config.MESSAGE_PERSISTENCE))) {
052            if (LOG.isDebugEnabled()) {
053                LOG.debug("Persisting Message " + routeQueue);
054            }
055            this.getMessageQueueDao().save(routeQueue);
056        }
057    }
058
059    public List<PersistedMessageBO> findAll() {
060        return this.getMessageQueueDao().findAll();
061    }
062
063    public List<PersistedMessageBO> findAll(int maxRows) {
064        return this.getMessageQueueDao().findAll(maxRows);
065    }
066
067    public PersistedMessageBO findByRouteQueueId(Long routeQueueId) {
068        return getMessageQueueDao().findByRouteQueueId(routeQueueId);
069    }
070
071    public PersistedMessagePayload findByPersistedMessageByRouteQueueId(Long routeQueueId) {
072        return messageQueueDao.findByPersistedMessageByRouteQueueId(routeQueueId);
073    }
074
075    public List<PersistedMessageBO> getNextDocuments(Integer maxDocuments) {
076        return this.getMessageQueueDao().getNextDocuments(maxDocuments);
077    }
078
079    public MessageQueueDAO getMessageQueueDao() {
080        return this.messageQueueDao;
081    }
082
083    public void setMessageQueueDao(MessageQueueDAO queueDAO) {
084        this.messageQueueDao = queueDAO;
085    }
086
087    public List<PersistedMessageBO> findByServiceName(QName serviceName, String methodName) {
088        return getMessageQueueDao().findByServiceName(serviceName, methodName);
089    }
090
091    public List<PersistedMessageBO> findByValues(Map<String, String> criteriaValues, int maxRows) {
092        return getMessageQueueDao().findByValues(criteriaValues, maxRows);
093    }
094
095    public Integer getMaxRetryAttempts() {
096        return new Integer(ConfigContext.getCurrentContextConfig().getProperty(KSBConstants.Config.ROUTE_QUEUE_MAX_RETRY_ATTEMPTS_KEY));
097    }
098
099}