org.kuali.coeus.propdev.impl.core.LookupableDevelopmentProposalLookupableHelperServiceImpl.java Source code

Java tutorial

Introduction

Here is the source code for org.kuali.coeus.propdev.impl.core.LookupableDevelopmentProposalLookupableHelperServiceImpl.java

Source

/*
 * Kuali Coeus, a comprehensive research administration system for higher education.
 * 
 * Copyright 2005-2015 Kuali, Inc.
 * 
 * This program is free software: you can redistribute it and/or modify
 * it under the terms of the GNU Affero General Public License as
 * published by the Free Software Foundation, either version 3 of the
 * License, or (at your option) any later version.
 * 
 * This program is distributed in the hope that it will be useful,
 * but WITHOUT ANY WARRANTY; without even the implied warranty of
 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
 * GNU Affero General Public License for more details.
 * 
 * You should have received a copy of the GNU Affero General Public License
 * along with this program.  If not, see <http://www.gnu.org/licenses/>.
 */
package org.kuali.coeus.propdev.impl.core;

import java.sql.Date;
import java.util.ArrayList;
import java.util.Arrays;
import java.util.HashMap;
import java.util.List;
import java.util.Map;

import org.apache.commons.lang3.StringUtils;
import org.apache.commons.logging.Log;
import org.apache.commons.logging.LogFactory;
import org.kuali.coeus.propdev.impl.person.ProposalPerson;
import org.kuali.coeus.propdev.impl.auth.ProposalDevelopmentDocumentAuthorizer;
import org.kuali.coeus.propdev.impl.person.ProposalPersonService;
import org.kuali.coeus.sys.framework.lookup.KcKualiLookupableHelperServiceImpl;
import org.kuali.rice.kew.api.exception.WorkflowException;
import org.kuali.rice.kim.api.identity.Person;
import org.kuali.rice.krad.bo.BusinessObject;
import org.kuali.rice.krad.service.*;
import org.kuali.rice.krad.util.GlobalVariables;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.beans.factory.annotation.Qualifier;
import org.springframework.beans.factory.config.ConfigurableBeanFactory;
import org.springframework.context.annotation.Scope;
import org.springframework.stereotype.Component;

@Component("lookupableDevelopmentProposalLookupableHelperService")
@Scope(ConfigurableBeanFactory.SCOPE_PROTOTYPE)
public class LookupableDevelopmentProposalLookupableHelperServiceImpl extends KcKualiLookupableHelperServiceImpl {

    private static final List<String> VALID_LOOKUP_FIELDS = Arrays.asList("proposalNumber", "title", "sponsorCode",
            "ownedByUnitNumber", "ownedByUnitName", "proposalTypeCode");

    private static final Log LOG = LogFactory
            .getLog(LookupableDevelopmentProposalLookupableHelperServiceImpl.class);

    @Autowired
    @Qualifier("proposalPersonService")
    private ProposalPersonService proposalPersonService;

    @Autowired
    @Qualifier("documentService")
    private DocumentService documentService;

    @SuppressWarnings("unchecked")
    @Override
    public List<? extends BusinessObject> getSearchResults(Map<String, String> fieldValues) {
        // find matching names for potential PI's
        List<String> matchingProposals = new ArrayList<String>();
        Map<String, Object> proposalFields = new HashMap<String, Object>();
        // only going to do lookup if either no investigator search is given, or if it
        // is given and investigator lookup returns some entries
        boolean doLookup = true;
        for (String key : fieldValues.keySet()) {
            String value = fieldValues.get(key);
            if (StringUtils.isNotEmpty(value)) {
                if (StringUtils.equals(key, "investigator")) {
                    List<ProposalPerson> proposalPersons = proposalPersonService
                            .getProposalPersonsByPartialName(value);
                    for (ProposalPerson potentialPerson : proposalPersons) {
                        matchingProposals.add(potentialPerson.getDevelopmentProposal().getProposalNumber());
                    }
                    if (matchingProposals.size() > 0) {
                        proposalFields.put("proposalNumber", matchingProposals);
                    } else {
                        doLookup = false;
                    }
                } else if (VALID_LOOKUP_FIELDS.contains(key)) {
                    proposalFields.put(key, fieldValues.get(key));
                }
            }
        }
        if (!doLookup) {
            return new ArrayList<LookupableDevelopmentProposal>();
        }
        List<LookupableDevelopmentProposal> unboundedResults = (List<LookupableDevelopmentProposal>) businessObjectService
                .findMatching(LookupableDevelopmentProposal.class, proposalFields);
        List<LookupableDevelopmentProposal> filteredResults = filterForPermissionsAndDates(fieldValues,
                unboundedResults);
        return filteredResults;
    }

    // filter by lower and upper limits on deadline date, and by user permissions
    private List<LookupableDevelopmentProposal> filterForPermissionsAndDates(Map<String, String> fieldValues,
            List<LookupableDevelopmentProposal> unboundedResults) {
        String deadlineDate = fieldValues.get("deadlineDate");
        Date lowerLimit = null;
        Date upperLimit = null;
        boolean checkDates = true;
        if (StringUtils.isEmpty(deadlineDate)) {
            checkDates = false;
        } else {
            try {
                if (deadlineDate.indexOf("..") > -1) {
                    String temp = deadlineDate.substring(0, 10);
                    lowerLimit = new Date((new java.util.Date(temp)).getTime());
                    temp = deadlineDate.substring(12);
                    upperLimit = new Date((new java.util.Date(temp)).getTime());
                } else if (deadlineDate.indexOf("<=") > -1) {
                    String temp = deadlineDate.substring(2);
                    upperLimit = new Date((new java.util.Date(temp)).getTime());
                } else {
                    String temp = deadlineDate.substring(2);
                    lowerLimit = new Date((new java.util.Date(temp)).getTime());
                }
            } catch (Exception e) {
                LOG.warn("Error formatting dates. Original string = [" + deadlineDate + "]");
                lowerLimit = null;
                upperLimit = null;
            }
        }
        ProposalDevelopmentDocumentAuthorizer authorizer = new ProposalDevelopmentDocumentAuthorizer();
        Person user = GlobalVariables.getUserSession().getPerson();
        List<LookupableDevelopmentProposal> results = new ArrayList<LookupableDevelopmentProposal>();
        for (LookupableDevelopmentProposal potentialProposal : unboundedResults) {
            if (!checkDates || dateInRange(potentialProposal.getDeadlineDate(), lowerLimit, upperLimit)) {
                String documentNumber = potentialProposal.getDocumentNumber();
                try {
                    ProposalDevelopmentDocument document = (ProposalDevelopmentDocument) getDocumentService()
                            .getByDocumentHeaderId(documentNumber);
                    if (authorizer.canOpen(document, user)) {
                        results.add(potentialProposal);
                    }
                } catch (WorkflowException e) {
                    LOG.warn("Cannot find Document with header id " + documentNumber);
                }
            }
        }
        return results;
    }

    private boolean dateInRange(Date checkDate, Date lowerLimit, Date upperLimit) {
        if (checkDate == null) {
            return true;
        }
        if (lowerLimit != null && checkDate.before(lowerLimit)) {
            return false;
        }
        if (upperLimit != null && checkDate.after(upperLimit)) {
            return false;
        }
        return true;
    }

    public void setDocumentService(DocumentService documentService) {
        this.documentService = documentService;
    }

    public DocumentService getDocumentService() {
        return documentService;
    }
}