| /** |
| * Licensed to the Apache Software Foundation (ASF) under one |
| * or more contributor license agreements. See the NOTICE file |
| * distributed with this work for additional information |
| * regarding copyright ownership. The ASF licenses this file |
| * to you under the Apache License, Version 2.0 (the |
| * "License"); you may not use this file except in compliance |
| * with the License. You may obtain a copy of the License at |
| * |
| * http://www.apache.org/licenses/LICENSE-2.0 |
| * |
| * Unless required by applicable law or agreed to in writing, |
| * software distributed under the License is distributed on an |
| * "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY |
| * KIND, either express or implied. See the License for the |
| * specific language governing permissions and limitations |
| * under the License. |
| */ |
| package org.apache.fineract.portfolio.loanaccount.domain; |
| |
| import java.time.LocalDate; |
| import java.util.Collection; |
| import java.util.List; |
| import org.apache.fineract.infrastructure.core.domain.ExternalId; |
| import org.springframework.data.jpa.repository.JpaRepository; |
| import org.springframework.data.jpa.repository.JpaSpecificationExecutor; |
| import org.springframework.data.jpa.repository.Query; |
| import org.springframework.data.repository.query.Param; |
| |
| public interface LoanRepository extends JpaRepository<Loan, Long>, JpaSpecificationExecutor<Loan> { |
| |
| String FIND_GROUP_LOANS_DISBURSED_AFTER = "select l from Loan l where ( l.actualDisbursementDate IS NOT NULL and l.actualDisbursementDate > :disbursementDate) and " |
| + "l.group.id = :groupId and l.loanType = :loanType order by l.actualDisbursementDate"; |
| |
| String FIND_CLIENT_OR_JLG_LOANS_DISBURSED_AFTER = "select l from Loan l where (l.actualDisbursementDate IS NOT NULL and l.actualDisbursementDate > :disbursementDate) and " |
| + "l.client.id = :clientId order by l.actualDisbursementDate"; |
| |
| String FIND_MAX_GROUP_LOAN_COUNTER_QUERY = "Select MAX(l.loanCounter) from Loan l where l.group.id = :groupId " |
| + "and l.loanType = :loanType"; |
| |
| String FIND_MAX_GROUP_LOAN_PRODUCT_COUNTER_QUERY = "Select MAX(l.loanProductCounter) from Loan l where " |
| + "l.group.id = :groupId and l.loanType = :loanType and l.loanProduct.id = :productId"; |
| |
| String FIND_MAX_CLIENT_OR_JLG_LOAN_COUNTER_QUERY = "Select MAX(l.loanCounter) from Loan l where " + "l.client.id = :clientId"; |
| |
| String FIND_MAX_CLIENT_OR_JLG_LOAN_PRODUCT_COUNTER_QUERY = "Select MAX(l.loanProductCounter) from Loan l where " |
| + "l.client.id = :clientId and l.loanProduct.id = :productId"; |
| |
| String FIND_GROUP_LOANS_TO_UPDATE = "select l from Loan l where l.loanCounter > :loanCounter and " |
| + "l.group.id = :groupId and l.loanType = :groupLoanType order by l.loanCounter"; |
| |
| String FIND_CLIENT_OR_JLG_LOANS_TO_UPDATE = "select l from Loan l where l.loanCounter > :loanCounter and " |
| + "l.client.id = :clientId order by l.loanCounter"; |
| |
| String FIND_GROUP_LOANS_TO_UPDATE_LOANPRODUCT_COUNTER = "select l from Loan l where l.loanProductCounter > :loanProductCounter" |
| + " and l.group.id = :groupId and l.loanType = :groupLoanType and l.loanCounter is NULL order by l.loanProductCounter"; |
| |
| String FIND_CLIENT_LOANS_TO_UPDATE_LOANPRODUCT_COUNTER = "select l from Loan l where l.loanProductCounter > :loanProductCounter" |
| + " and l.client.id = :clientId and l.loanCounter is NULL order by l.loanProductCounter"; |
| |
| String FIND_ACTIVE_LOANS_PRODUCT_IDS_BY_CLIENT = "Select loan.loanProduct.id from Loan loan where " |
| + "loan.client.id = :clientId and loan.loanStatus = :loanStatus group by loan.loanProduct.id"; |
| |
| String FIND_ACTIVE_LOANS_PRODUCT_IDS_BY_GROUP = "Select loan.loanProduct.id from Loan loan where " |
| + "loan.group.id = :groupId and loan.loanStatus = :loanStatus and loan.client.id is NULL group by loan.loanProduct.id"; |
| |
| String DOES_CLIENT_HAVE_NON_CLOSED_LOANS = "select case when (count (loan) > 0) then 'true' else 'false' end from Loan loan where loan.client.id = :clientId and loan.loanStatus in (100,200,300,303,304,700)"; |
| |
| String DOES_PRODUCT_HAVE_NON_CLOSED_LOANS = "select case when (count (loan) > 0) then 'true' else 'false' end from Loan loan where loan.loanProduct.id = :productId and loan.loanStatus in (100,200,300,303,304,700)"; |
| |
| String FIND_NON_CLOSED_BY_ACCOUNT_NUMBER = "select loan from Loan loan where loan.accountNumber = :accountNumber and loan.loanStatus in (100,200,300,303,304)"; |
| |
| String FIND_ALL_NON_CLOSED = "select loan.id from Loan loan where loan.loanStatus in (100,200,300,303,304)"; |
| |
| String FIND_ALL_NON_CLOSED_ONE_DAY_BEHIND = "select loan.id from Loan loan where loan.loanStatus in (100,200,300,303,304) and (:last_closed_business_date = loan.lastClosedBusinessDate or loan.lastClosedBusinessDate is NULL)"; |
| |
| String FIND_NON_CLOSED_LOAN_THAT_BELONGS_TO_CLIENT = "select loan from Loan loan where loan.id = :loanId and loan.loanStatus = 300 and loan.client.id = :clientId"; |
| |
| String FIND_BY_ACCOUNT_NUMBER = "select loan from Loan loan where loan.accountNumber = :accountNumber"; |
| |
| String FIND_ID_BY_EXTERNAL_ID = "SELECT loan.id FROM Loan loan WHERE loan.externalId = :externalId"; |
| |
| @Query(FIND_GROUP_LOANS_DISBURSED_AFTER) |
| List<Loan> getGroupLoansDisbursedAfter(@Param("disbursementDate") LocalDate disbursementDate, @Param("groupId") Long groupId, |
| @Param("loanType") Integer loanType); |
| |
| @Query(FIND_CLIENT_OR_JLG_LOANS_DISBURSED_AFTER) |
| List<Loan> getClientOrJLGLoansDisbursedAfter(@Param("disbursementDate") LocalDate disbursementDate, @Param("clientId") Long clientId); |
| |
| @Query(FIND_MAX_GROUP_LOAN_COUNTER_QUERY) |
| Integer getMaxGroupLoanCounter(@Param("groupId") Long groupId, @Param("loanType") Integer loanType); |
| |
| @Query(FIND_MAX_GROUP_LOAN_PRODUCT_COUNTER_QUERY) |
| Integer getMaxGroupLoanProductCounter(@Param("productId") Long productId, @Param("groupId") Long groupId, |
| @Param("loanType") Integer loanType); |
| |
| @Query(FIND_MAX_CLIENT_OR_JLG_LOAN_COUNTER_QUERY) |
| Integer getMaxClientOrJLGLoanCounter(@Param("clientId") Long clientId); |
| |
| @Query(FIND_MAX_CLIENT_OR_JLG_LOAN_PRODUCT_COUNTER_QUERY) |
| Integer getMaxClientOrJLGLoanProductCounter(@Param("productId") Long productId, @Param("clientId") Long clientId); |
| |
| @Query(FIND_GROUP_LOANS_TO_UPDATE) |
| List<Loan> getGroupLoansToUpdateLoanCounter(@Param("loanCounter") Integer loanCounter, @Param("groupId") Long groupId, |
| @Param("groupLoanType") Integer groupLoanType); |
| |
| @Query(FIND_CLIENT_OR_JLG_LOANS_TO_UPDATE) |
| List<Loan> getClientOrJLGLoansToUpdateLoanCounter(@Param("loanCounter") Integer loanCounter, @Param("clientId") Long clientId); |
| |
| @Query(FIND_GROUP_LOANS_TO_UPDATE_LOANPRODUCT_COUNTER) |
| List<Loan> getGroupLoansToUpdateLoanProductCounter(@Param("loanProductCounter") Integer loanProductCounter, |
| @Param("groupId") Long groupId, @Param("groupLoanType") Integer groupLoanType); |
| |
| @Query(FIND_CLIENT_LOANS_TO_UPDATE_LOANPRODUCT_COUNTER) |
| List<Loan> getClientLoansToUpdateLoanProductCounter(@Param("loanProductCounter") Integer loanProductCounter, |
| @Param("clientId") Long clientId); |
| |
| @Query("select loan from Loan loan where loan.client.id = :clientId and loan.group.id = :groupId") |
| List<Loan> findByClientIdAndGroupId(@Param("clientId") Long clientId, @Param("groupId") Long groupId); |
| |
| @Query("select loan from Loan loan where loan.client.id = :clientId and loan.group.id = :groupId and loan.loanStatus IN :loanStatuses") |
| List<Loan> findByClientIdAndGroupIdAndLoanStatus(@Param("clientId") Long clientId, @Param("groupId") Long groupId, |
| @Param("loanStatuses") Collection<Integer> loanStatuses); |
| |
| @Query("select loan from Loan loan where loan.client.id = :clientId") |
| List<Loan> findLoanByClientId(@Param("clientId") Long clientId); |
| |
| @Query("select loan from Loan loan where loan.group.id = :groupId and loan.client.id is null") |
| List<Loan> findByGroupId(@Param("groupId") Long groupId); |
| |
| @Query("select loan from Loan loan where loan.glim.id = :glimId") |
| List<Loan> findByGlimId(@Param("glimId") Long glimId); |
| |
| @Query("select loan from Loan loan where loan.id IN :ids and loan.loanStatus IN :loanStatuses and loan.loanType IN :loanTypes") |
| List<Loan> findByIdsAndLoanStatusAndLoanType(@Param("ids") Collection<Long> ids, |
| @Param("loanStatuses") Collection<Integer> loanStatuses, @Param("loanTypes") Collection<Integer> loanTypes); |
| |
| @Query("select loan.id from Loan loan where loan.actualDisbursementDate > :disbursalDate order by loan.actualDisbursementDate") |
| List<Long> getLoansDisbursedAfter(@Param("disbursalDate") LocalDate disbursalDate); |
| |
| @Query("select loan from Loan loan where loan.client.office.id IN :officeIds and loan.loanStatus IN :loanStatuses") |
| List<Loan> findByClientOfficeIdsAndLoanStatus(@Param("officeIds") Collection<Long> officeIds, |
| @Param("loanStatuses") Collection<Integer> loanStatuses); |
| |
| @Query("select loan from Loan loan where loan.group.office.id IN :officeIds and loan.loanStatus IN :loanStatuses") |
| List<Loan> findByGroupOfficeIdsAndLoanStatus(@Param("officeIds") Collection<Long> officeIds, |
| @Param("loanStatuses") Collection<Integer> loanStatuses); |
| |
| /*** FIXME: Add more appropriate names for the query ***/ |
| @Query(FIND_ACTIVE_LOANS_PRODUCT_IDS_BY_CLIENT) |
| List<Long> findActiveLoansLoanProductIdsByClient(@Param("clientId") Long clientId, @Param("loanStatus") Integer loanStatus); |
| |
| @Query(FIND_ACTIVE_LOANS_PRODUCT_IDS_BY_GROUP) |
| List<Long> findActiveLoansLoanProductIdsByGroup(@Param("groupId") Long groupId, @Param("loanStatus") Integer loanStatus); |
| |
| @Query(DOES_CLIENT_HAVE_NON_CLOSED_LOANS) |
| boolean doNonClosedLoanAccountsExistForClient(@Param("clientId") Long clientId); |
| |
| @Query(DOES_PRODUCT_HAVE_NON_CLOSED_LOANS) |
| boolean doNonClosedLoanAccountsExistForProduct(@Param("productId") Long productId); |
| |
| @Query(FIND_NON_CLOSED_BY_ACCOUNT_NUMBER) |
| Loan findNonClosedLoanByAccountNumber(@Param("accountNumber") String accountNumber); |
| |
| @Query(FIND_NON_CLOSED_LOAN_THAT_BELONGS_TO_CLIENT) |
| Loan findNonClosedLoanThatBelongsToClient(@Param("loanId") Long loanId, @Param("clientId") Long clientId); |
| |
| @Query(FIND_BY_ACCOUNT_NUMBER) |
| Loan findLoanAccountByAccountNumber(@Param("accountNumber") String accountNumber); |
| |
| boolean existsByExternalId(@Param("externalId") ExternalId externalId); |
| |
| @Query(FIND_ALL_NON_CLOSED) |
| List<Long> findAllNonClosedLoanIds(); |
| |
| @Query(FIND_ID_BY_EXTERNAL_ID) |
| Long findIdByExternalId(@Param("externalId") ExternalId externalId); |
| |
| @Query(FIND_ALL_NON_CLOSED_ONE_DAY_BEHIND) |
| List<Long> findAllNonClosedLoanIdsOneDayBehind(@Param("last_closed_business_date") LocalDate businessDate); |
| |
| } |