Coverage Report - org.kuali.rice.kew.stats.dao.impl.StatsDAOOjbImpl
 
Classes in this File Line Coverage Branch Coverage Complexity
StatsDAOOjbImpl
0%
0/91
0%
0/28
3.833
 
 1  
 /*
 2  
  * Copyright 2005-2008 The Kuali Foundation
 3  
  *
 4  
  *
 5  
  * Licensed under the Educational Community License, Version 2.0 (the "License");
 6  
  * you may not use this file except in compliance with the License.
 7  
  * You may obtain a copy of the License at
 8  
  *
 9  
  * http://www.opensource.org/licenses/ecl2.php
 10  
  *
 11  
  * Unless required by applicable law or agreed to in writing, software
 12  
  * distributed under the License is distributed on an "AS IS" BASIS,
 13  
  * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
 14  
  * See the License for the specific language governing permissions and
 15  
  * limitations under the License.
 16  
  */
 17  
 package org.kuali.rice.kew.stats.dao.impl;
 18  
 
 19  
 import java.sql.Connection;
 20  
 import java.sql.PreparedStatement;
 21  
 import java.sql.ResultSet;
 22  
 import java.sql.SQLException;
 23  
 import java.sql.Timestamp;
 24  
 import java.util.ArrayList;
 25  
 import java.util.Calendar;
 26  
 import java.util.Date;
 27  
 import java.util.List;
 28  
 
 29  
 import org.apache.ojb.broker.PersistenceBroker;
 30  
 import org.apache.ojb.broker.accesslayer.LookupException;
 31  
 import org.kuali.rice.core.util.ConcreteKeyValue;
 32  
 import org.kuali.rice.core.util.KeyValue;
 33  
 import org.kuali.rice.kew.stats.Stats;
 34  
 import org.kuali.rice.kew.stats.dao.StatsDAO;
 35  
 import org.kuali.rice.kew.util.KEWConstants;
 36  
 import org.springmodules.orm.ojb.support.PersistenceBrokerDaoSupport;
 37  
 
 38  
 
 39  0
 public class StatsDAOOjbImpl extends PersistenceBrokerDaoSupport implements StatsDAO {
 40  
 
 41  0
     private static final org.apache.log4j.Logger LOG = org.apache.log4j.Logger.getLogger(StatsDAOOjbImpl.class);
 42  
 
 43  
     public static final String SQL_NUM_ACTIVE_ITEMS = "select count(*) from krew_actn_itm_t";
 44  
     public static final String SQL_NUM_DOC_TYPES_REPORT = "select count(*) as num from krew_doc_typ_t where cur_ind = 1";
 45  
     public static final String SQL_DOCUMENTS_ROUTED = "select count(*) as count, krew_doc_hdr_t.doc_hdr_stat_cd from krew_doc_hdr_t where krew_doc_hdr_t.crte_dt between ? and ? group by doc_hdr_stat_cd";
 46  
     public static final String SQL_NUM_USERS = "select count(distinct prncpl_id) as prsn_count from KREW_USR_OPTN_T";
 47  
     public static final String SQL_NUM_DOCS_INITIATED = "select count(*), krew_doc_typ_t.doc_typ_nm from krew_doc_hdr_t, krew_doc_typ_t where krew_doc_hdr_t.crte_dt > ? and krew_doc_hdr_t.doc_typ_id = krew_doc_typ_t.doc_typ_id group by krew_doc_typ_t.doc_typ_nm";
 48  
 
 49  
     @Override
 50  
         public void NumActiveItemsReport(Stats stats) throws SQLException, LookupException {
 51  
 
 52  0
         LOG.debug("NumActiveItemsReport()");
 53  0
         PersistenceBroker broker = this.getPersistenceBroker(false);
 54  0
         Connection conn = broker.serviceConnectionManager().getConnection();
 55  0
         PreparedStatement ps = conn.prepareStatement(StatsDAOOjbImpl.SQL_NUM_ACTIVE_ITEMS);
 56  0
         ResultSet rs = ps.executeQuery();
 57  
 
 58  0
         while (rs.next()) {
 59  0
             stats.setNumActionItems(new Integer(rs.getInt(1)).toString());
 60  
         }
 61  
 
 62  0
         closeDatabaseObjects(rs, ps, conn/*, broker*/);
 63  0
     }
 64  
 
 65  
     @Override
 66  
         public void NumberOfDocTypesReport(Stats stats) throws SQLException, LookupException {
 67  
 
 68  0
         LOG.debug("NumberOfDocTypesReport()");
 69  0
         PersistenceBroker broker = this.getPersistenceBroker(false);
 70  0
         Connection conn = broker.serviceConnectionManager().getConnection();
 71  0
         PreparedStatement ps = conn.prepareStatement(StatsDAOOjbImpl.SQL_NUM_DOC_TYPES_REPORT);
 72  0
         ResultSet rs = ps.executeQuery();
 73  
 
 74  0
         while (rs.next()) {
 75  0
             stats.setNumDocTypes(new Integer(rs.getInt(1)).toString());
 76  
         }
 77  
 
 78  0
         closeDatabaseObjects(rs, ps, conn/*, broker*/);
 79  0
     }
 80  
 
 81  
     @Override
 82  
         public void DocumentsRoutedReport(Stats stats, Date begDate, Date endDate) throws SQLException, LookupException {
 83  
 
 84  0
         LOG.debug("DocumentsRoutedReport()");
 85  0
         PersistenceBroker broker = this.getPersistenceBroker(false);
 86  0
         Connection conn = broker.serviceConnectionManager().getConnection();
 87  0
         PreparedStatement ps = conn.prepareStatement(StatsDAOOjbImpl.SQL_DOCUMENTS_ROUTED);
 88  0
         ps.setTimestamp(1, new Timestamp(begDate.getTime()));
 89  0
         ps.setTimestamp(2, new Timestamp(endDate.getTime()));
 90  0
         ResultSet rs = ps.executeQuery();
 91  
 
 92  0
         while (rs.next()) {
 93  
 
 94  0
             String actionType = rs.getString(2);
 95  0
             String number = new Integer(rs.getInt(1)).toString();
 96  0
             if (actionType.equals(KEWConstants.ROUTE_HEADER_APPROVED_CD)) {
 97  0
                 stats.setApprovedNumber(number);
 98  0
             } else if (actionType.equals(KEWConstants.ROUTE_HEADER_CANCEL_CD)) {
 99  0
                 stats.setCanceledNumber(number);
 100  0
             } else if (actionType.equals(KEWConstants.ROUTE_HEADER_DISAPPROVED_CD)) {
 101  0
                 stats.setDisapprovedNumber(number);
 102  0
             } else if (actionType.equals(KEWConstants.ROUTE_HEADER_ENROUTE_CD)) {
 103  0
                 stats.setEnrouteNumber(number);
 104  0
             } else if (actionType.equals(KEWConstants.ROUTE_HEADER_EXCEPTION_CD)) {
 105  0
                 stats.setExceptionNumber(number);
 106  0
             } else if (actionType.equals(KEWConstants.ROUTE_HEADER_FINAL_CD)) {
 107  0
                 stats.setFinalNumber(number);
 108  0
             } else if (actionType.equals(KEWConstants.ROUTE_HEADER_INITIATED_CD)) {
 109  0
                 stats.setInitiatedNumber(number);
 110  0
             } else if (actionType.equals(KEWConstants.ROUTE_HEADER_PROCESSED_CD)) {
 111  0
                 stats.setProcessedNumber(number);
 112  0
             } else if (actionType.equals(KEWConstants.ROUTE_HEADER_SAVED_CD)) {
 113  0
                 stats.setSavedNumber(number);
 114  
             }
 115  0
         }
 116  
 
 117  0
         closeDatabaseObjects(rs, ps, conn/*, broker*/);
 118  0
     }
 119  
 
 120  
     @Override
 121  
         public void NumUsersReport(Stats stats) throws SQLException, LookupException {
 122  
 
 123  0
         LOG.debug("NumUsersReport()");
 124  0
         PersistenceBroker broker = this.getPersistenceBroker(false);
 125  0
         Connection conn = broker.serviceConnectionManager().getConnection();
 126  0
         PreparedStatement ps = conn.prepareStatement(StatsDAOOjbImpl.SQL_NUM_USERS);
 127  0
         ResultSet rs = ps.executeQuery();
 128  
 
 129  0
         while (rs.next()) {
 130  0
             stats.setNumUsers(new Integer(rs.getInt("prsn_count")).toString());
 131  
         }
 132  
 
 133  0
         closeDatabaseObjects(rs, ps, conn/*, broker*/);
 134  0
     }
 135  
 
 136  
     @Override
 137  
         public void NumInitiatedDocsByDocTypeReport(Stats stats) throws SQLException, LookupException {
 138  
 
 139  0
         LOG.debug("NumInitiatedDocsByDocType()");
 140  0
         PersistenceBroker broker = this.getPersistenceBroker(false);
 141  0
         Connection conn = broker.serviceConnectionManager().getConnection();
 142  0
         PreparedStatement ps = conn.prepareStatement(StatsDAOOjbImpl.SQL_NUM_DOCS_INITIATED);
 143  0
         Calendar calendar = Calendar.getInstance();
 144  0
         calendar.add(Calendar.DAY_OF_YEAR, -29);
 145  0
         calendar.set(Calendar.HOUR_OF_DAY, 0);
 146  0
         calendar.set(Calendar.MINUTE, 0);
 147  0
         calendar.set(Calendar.SECOND, 0);
 148  0
         calendar.set(Calendar.MILLISECOND, 0);
 149  0
         ps.setTimestamp(1, new Timestamp(calendar.getTime().getTime()));
 150  0
         ResultSet rs = ps.executeQuery();
 151  
 
 152  0
         List<KeyValue> numDocs = new ArrayList<KeyValue>();
 153  
 
 154  0
         while (rs.next()) {
 155  0
             numDocs.add(new ConcreteKeyValue(rs.getString(2), new Integer(rs.getInt(1)).toString()));
 156  
         }
 157  0
         stats.setNumInitiatedDocsByDocType(numDocs);
 158  
 
 159  0
         closeDatabaseObjects(rs, ps, conn/*, broker*/);
 160  
 
 161  0
     }
 162  
 
 163  
     private void closeDatabaseObjects(ResultSet rs, PreparedStatement ps, Connection conn/*, PersistenceBroker broker*/) {
 164  
 
 165  
         try {
 166  0
             rs.close();
 167  0
         } catch (SQLException ex) {
 168  0
             LOG.warn("Failed to close ResultSet.", ex);
 169  0
         }
 170  
 
 171  
         try {
 172  0
             ps.close();
 173  0
         } catch (SQLException ex) {
 174  0
             LOG.warn("Failed to close PreparedStatement.", ex);
 175  0
         }
 176  
 
 177  
         try {
 178  0
             conn.close();
 179  0
         } catch (SQLException ex) {
 180  0
             LOG.warn("Failed to close Connection.", ex);
 181  0
         }
 182  
 /*
 183  
         try {
 184  
             broker.close();
 185  
         } catch (Exception ex) {
 186  
             LOG.warn("Failed to close broker.", ex);
 187  
         }
 188  
 */
 189  0
     }
 190  
 
 191  
 }