001    /**
002     * Copyright 2004-2013 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.hr.time.clock.location.dao;
017    
018    import java.sql.Date;
019    import java.util.ArrayList;
020    import java.util.Collection;
021    import java.util.List;
022    
023    import com.google.common.collect.ImmutableList;
024    import org.apache.commons.collections.CollectionUtils;
025    import org.apache.commons.lang.StringUtils;
026    import org.apache.ojb.broker.query.Criteria;
027    import org.apache.ojb.broker.query.Query;
028    import org.apache.ojb.broker.query.QueryFactory;
029    import org.apache.ojb.broker.query.ReportQueryByCriteria;
030    import org.kuali.hr.core.util.OjbSubQueryUtil;
031    import org.kuali.hr.time.clock.location.ClockLocationRule;
032    import org.kuali.hr.time.clock.location.ClockLocationRuleIpAddress;
033    import org.kuali.hr.time.service.base.TkServiceLocator;
034    import org.kuali.hr.time.util.TKUtils;
035    import org.kuali.hr.time.workarea.WorkArea;
036    import org.kuali.rice.core.framework.persistence.ojb.dao.PlatformAwareDaoBaseOjb;
037    
038    public class ClockLocationDaoOjbImpl extends PlatformAwareDaoBaseOjb implements ClockLocationDao{
039        private static final ImmutableList<String> EQUAL_TO_FIELDS = new ImmutableList.Builder<String>()
040                .add("dept")
041                .add("workArea")
042                .add("jobNumber")
043                .add("principalId")
044                .build();
045    
046            public List<ClockLocationRule> getClockLocationRule(String dept, Long workArea, String principalId, Long jobNumber, Date asOfDate){
047                    Criteria root = new Criteria();
048    
049                    root.addEqualTo("dept", dept);
050                    root.addEqualTo("workArea", workArea);
051                    root.addEqualTo("principalId", principalId);
052                    root.addEqualTo("jobNumber", jobNumber);
053                    root.addEqualTo("effectiveDate", OjbSubQueryUtil.getEffectiveDateSubQuery(ClockLocationRule.class, asOfDate, EQUAL_TO_FIELDS, false));
054                    root.addEqualTo("timestamp", OjbSubQueryUtil.getTimestampSubQuery(ClockLocationRule.class, EQUAL_TO_FIELDS, false));
055                    //root.addEqualTo("active", true);
056                    
057                    Criteria activeFilter = new Criteria(); // Inner Join For Activity
058                    activeFilter.addEqualTo("active", true);
059                    root.addAndCriteria(activeFilter);
060                    
061                    Query query = QueryFactory.newQuery(ClockLocationRule.class, root);
062                    List<ClockLocationRule> clockLocationRules = (List<ClockLocationRule>)this.getPersistenceBrokerTemplate().getCollectionByQuery(query);
063                    if(clockLocationRules==null){
064                            clockLocationRules = new ArrayList<ClockLocationRule>();
065                    }
066                    for(ClockLocationRule clr : clockLocationRules ) {
067                            this.populateIPAddressesForCLR(clr);
068                    }
069                    return clockLocationRules;
070            }
071    
072            @SuppressWarnings("unchecked")
073            @Override
074            public List<ClockLocationRule> getNewerVersionClockLocationRule(
075                            String dept, Long workArea, String principalId, Long jobNumber,
076                            Date asOfDate) {
077                    Criteria root = new Criteria();
078                    root.addEqualTo("dept", dept);
079                    root.addEqualTo("workArea", workArea);
080                    root.addEqualTo("principalId", principalId);
081                    root.addEqualTo("jobNumber", jobNumber);
082                    root.addGreaterThan("effectiveDate", asOfDate);
083                    
084                    Criteria activeFilter = new Criteria(); // Inner Join For Activity
085                    activeFilter.addEqualTo("active", true);
086                    root.addAndCriteria(activeFilter);
087                    
088                    Query query = QueryFactory.newQuery(ClockLocationRule.class, root);
089                    List<ClockLocationRule> clockLocationRules = (List<ClockLocationRule>)this.getPersistenceBrokerTemplate().getCollectionByQuery(query);
090                    if(clockLocationRules==null){
091                            clockLocationRules = new ArrayList<ClockLocationRule>();
092                    }
093                    for(ClockLocationRule clr : clockLocationRules ) {
094                            this.populateIPAddressesForCLR(clr);
095                    }
096                    return clockLocationRules;
097            }
098            
099            public ClockLocationRule getClockLocationRule(String tkClockLocationRuleId){
100                    Criteria criteria = new Criteria();
101                    criteria.addEqualTo("tkClockLocationRuleId", tkClockLocationRuleId);
102                    ClockLocationRule clr = (ClockLocationRule) this.getPersistenceBrokerTemplate().getObjectByQuery(QueryFactory.newQuery(
103                                                                            ClockLocationRule.class, criteria));
104                    if(clr != null) {
105                            this.populateIPAddressesForCLR(clr);
106                    }
107                    return clr;
108            }
109            
110            // get ip address from tk_ip_addresses table for this ClockLocationRule
111            @SuppressWarnings("unchecked")
112            public void populateIPAddressesForCLR(ClockLocationRule clr) {
113                    if(clr.getTkClockLocationRuleId() == null) {
114                            return;
115                    }
116                    Criteria root = new Criteria();
117                    root.addEqualTo("tkClockLocationRuleId", clr.getTkClockLocationRuleId().toString());
118                    Query query = QueryFactory.newQuery(ClockLocationRuleIpAddress.class, root);
119                    List<ClockLocationRuleIpAddress> ipAddresses = (List<ClockLocationRuleIpAddress>) this.getPersistenceBrokerTemplate().getCollectionByQuery(query);
120                    clr.setIpAddresses(ipAddresses);
121            }
122    
123            @Override
124        @SuppressWarnings("unchecked")
125        public List<ClockLocationRule> getClockLocationRules(Date fromEffdt, Date toEffdt, String principalId, String jobNumber, String dept, String workArea, 
126                                                                                                             String active, String showHistory) {
127    
128            List<ClockLocationRule> results = new ArrayList<ClockLocationRule>();
129            
130            Criteria root = new Criteria();
131    
132            Criteria effectiveDateFilter = new Criteria();
133            if (fromEffdt != null) {
134                effectiveDateFilter.addGreaterOrEqualThan("effectiveDate", fromEffdt);
135            }
136            if (toEffdt != null) {
137                effectiveDateFilter.addLessOrEqualThan("effectiveDate", toEffdt);
138            }
139            if (fromEffdt == null && toEffdt == null) {
140                effectiveDateFilter.addLessOrEqualThan("effectiveDate", TKUtils.getCurrentDate());
141            }
142            root.addAndCriteria(effectiveDateFilter);
143    
144            if (StringUtils.isNotBlank(principalId)) {
145                root.addLike("principalId", principalId);
146            }
147    
148            if (StringUtils.isNotBlank(dept)) {
149                root.addLike("dept", dept);
150            }
151    
152            if (StringUtils.isNotBlank(jobNumber)) {
153                root.addLike("jobNumber", jobNumber);
154            }
155    
156            if (StringUtils.isNotBlank(dept)) {
157                Criteria workAreaCriteria = new Criteria();
158                Date asOfDate = toEffdt != null ? toEffdt : TKUtils.getCurrentDate();
159                Collection<WorkArea> workAreasForDept = TkServiceLocator.getWorkAreaService().getWorkAreas(dept,asOfDate);
160                if (CollectionUtils.isNotEmpty(workAreasForDept)) {
161                    List<Long> longWorkAreas = new ArrayList<Long>();
162                    for(WorkArea cwa : workAreasForDept){
163                        longWorkAreas.add(cwa.getWorkArea());
164                    }
165                    workAreaCriteria.addIn("workArea", longWorkAreas);
166                }
167                root.addAndCriteria(workAreaCriteria);
168            }
169    
170            if (StringUtils.isNotBlank(workArea)) {
171                OjbSubQueryUtil.addNumericCriteria(root, "workArea", workArea);
172            }
173            
174            if (StringUtils.isNotBlank(active)) {
175                    Criteria activeFilter = new Criteria();
176                if (StringUtils.equals(active, "Y")) {
177                    activeFilter.addEqualTo("active", true);
178                } else if (StringUtils.equals(active, "N")) {
179                    activeFilter.addEqualTo("active", false);
180                }
181                root.addAndCriteria(activeFilter);
182            }
183    
184            if (StringUtils.equals(showHistory, "N")) {
185                    root.addEqualTo("effectiveDate", OjbSubQueryUtil.getEffectiveDateSubQueryWithFilter(ClockLocationRule.class, effectiveDateFilter, EQUAL_TO_FIELDS, false));
186                    root.addEqualTo("timestamp", OjbSubQueryUtil.getTimestampSubQuery(ClockLocationRule.class, EQUAL_TO_FIELDS, false));
187            }
188            
189            Query query = QueryFactory.newQuery(ClockLocationRule.class, root);
190            results.addAll(getPersistenceBrokerTemplate().getCollectionByQuery(query));
191            
192            return results;
193        }
194    
195    }