in service/src/main/java/org/apache/fineract/cn/individuallending/internal/command/handler/IndividualLoanCommandHandler.java [566:608]
public IndividualLoanCommandEvent process(final MarkInArrearsCommand command) {
final String productIdentifier = command.getProductIdentifier();
final String caseIdentifier = command.getCaseIdentifier();
final DataContextOfAction dataContextOfAction = dataContextService.checkedGetDataContext(
productIdentifier, caseIdentifier, Collections.emptyList());
IndividualLendingPatternFactory.checkActionCanBeExecuted(Case.State.valueOf(dataContextOfAction.getCustomerCaseEntity().getCurrentState()), Action.MARK_LATE);
checkIfTasksAreOutstanding(dataContextOfAction, Action.MARK_IN_ARREARS);
if (dataContextOfAction.getCustomerCaseEntity().getEndOfTerm() == null)
throw ServiceException.internalError(
"End of term not set for active case ''{0}.{1}.''", productIdentifier, caseIdentifier);
final DesignatorToAccountIdentifierMapper designatorToAccountIdentifierMapper
= new DesignatorToAccountIdentifierMapper(dataContextOfAction);
final RealRunningBalances runningBalances = new RealRunningBalances(
accountingAdapter,
dataContextOfAction);
final PaymentBuilder paymentBuilder =
markInArrearsPaymentBuilderService.getPaymentBuilder(
dataContextOfAction,
BigDecimal.valueOf(command.getDaysLate()),
DateConverter.fromIsoString(command.getForTime()).toLocalDate(),
runningBalances);
final Optional<String> transactionUniqueifier = accountingAdapter.bookCharges(paymentBuilder.getBalanceAdjustments(),
designatorToAccountIdentifierMapper,
"Marked in arrears on " + command.getForTime(),
command.getForTime(),
dataContextOfAction.getMessageForCharge(Action.MARK_IN_ARREARS),
Action.MARK_IN_ARREARS.getTransactionType());
final CaseEntity customerCase = dataContextOfAction.getCustomerCaseEntity();
recordCommand(
command.getForTime(),
customerCase.getId(),
Action.MARK_IN_ARREARS,
transactionUniqueifier);
return new IndividualLoanCommandEvent(productIdentifier, caseIdentifier, command.getForTime());
}