Skip to content

Commit

Permalink
Merge pull request #83 from cardano-foundation/feat/accounting_type_tree
Browse files Browse the repository at this point in the history
feat: organisation costCenter and projects
  • Loading branch information
M4rc0Russ0 authored Nov 15, 2024
2 parents d99cdd1 + 3004103 commit bafbd0b
Show file tree
Hide file tree
Showing 11 changed files with 131 additions and 9 deletions.
Original file line number Diff line number Diff line change
Expand Up @@ -23,4 +23,4 @@ store.cardano.shelley-genesis-file: classpath:/devkit/shelley-genesis.json
store.cardano.alonzo-genesis-file: classpath:/devkit/alonzo-genesis.json
store.cardano.conway-genesis-file: classpath:/devkit/conway-genesis.json

#spring.profiles.active=dev--yaci-dev-kit
#spring.profiles.active=dev--yaci-dev-kit
Original file line number Diff line number Diff line change
Expand Up @@ -80,8 +80,8 @@ public List<Object[]> findAllReconciliationSpecialCount(Set<ReconciliationReject
val jpql = "SELECT count(rv.transactionId) " +
"FROM accounting_reporting_core.reconcilation.ReconcilationEntity r " +
"JOIN r.violations rv " +
"LEFT JOIN accounting_reporting_core.TransactionEntity tr ON rv.transactionId = tr.id " +
"WHERE (r.id = tr.lastReconcilation.id or tr.id IS NULL) ";
"FULL JOIN accounting_reporting_core.TransactionEntity tr ON rv.transactionId = tr.id " +
"WHERE (r.id = tr.lastReconcilation.id or tr.lastReconcilation IS NULL) ";

String where = "";
if (!rejectionCodes.isEmpty()) {
Expand Down Expand Up @@ -115,7 +115,7 @@ public List<Object[]> findAllReconciliationSpecialCount(Set<ReconciliationReject
where += " AND r.createdAt > :startDate AND r.createdAt < :endDate ";
}

where += "GROUP BY rv.transactionId, tr.id, rv.amountLcySum, rv.rejectionCode, rv.sourceDiff, rv.transactionEntryDate, rv.transactionInternalNumber, rv.transactionType ";
where += "GROUP BY rv.transactionId, tr.id, rv.amountLcySum, rv.transactionEntryDate, rv.transactionInternalNumber, rv.transactionType ";

Query resultQuery = em.createQuery(jpql + where);

Expand Down Expand Up @@ -245,7 +245,7 @@ public Object findCalcReconciliationStatistic() {
"JOIN r.violations rv " +
"FULL JOIN accounting_reporting_core.TransactionEntity tr ON rv.transactionId = tr.id " +
"WHERE (r.id = tr.lastReconcilation.id or tr.id IS NULL) " +
"GROUP BY rv.transactionId, tr.id, rv.amountLcySum, rv.rejectionCode, rv.sourceDiff, rv.transactionEntryDate, rv.transactionInternalNumber, rv.transactionType " +
"GROUP BY rv.transactionId, tr.id, rv.amountLcySum, rv.transactionEntryDate, rv.transactionInternalNumber, rv.transactionType " +
") ";

String txNever = "select count(txNever) from ( " +
Expand Down Expand Up @@ -299,7 +299,7 @@ private String reconciliationQuery(Set<ReconciliationRejectionCodeRequest> rejec
if (getDateFrom.isPresent()) {
where += " AND r.createdAt > :startDate AND r.createdAt < :endDate ";
}
where += "GROUP BY rv.transactionId, tr.id, rv.amountLcySum, rv.rejectionCode, rv.sourceDiff, rv.transactionEntryDate, rv.transactionInternalNumber, rv.transactionType ";
where += "GROUP BY rv.transactionId, tr.id, rv.amountLcySum, rv.rejectionCode, rv.sourceDiff, rv.transactionEntryDate, rv.transactionInternalNumber, rv.transactionType ORDER BY rv.transactionId ";

return jpql + where;
}
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -53,7 +53,21 @@ public class AccountingCorePresentationViewService {
public ReconciliationResponseView allReconciliationTransaction(ReconciliationFilterRequest body) {
val transactionsStatistic = accountingCoreTransactionRepository.findCalcReconciliationStatistic();
if (body.getFilter().equals(ReconciliationFilterStatusRequest.UNRECONCILED)) {
Set<Object> txDuplicated = new HashSet<>();
val transactions = accountingCoreTransactionRepository.findAllReconciliationSpecial(body.getReconciliationRejectionCode(), body.getDateFrom(), body.getLimit(), body.getPage()).stream()
.filter(o -> {
if (o[0] instanceof TransactionEntity) {
if (!txDuplicated.contains(o[0])) {
txDuplicated.add(o[0]);
return true;
}
}
if (o[1] instanceof ReconcilationViolation) {
return true;
}

return false;
})
.map(this::getReconciliationTransactionsSelector)
.collect(toSet());

Expand Down Expand Up @@ -317,7 +331,7 @@ private TransactionReconciliationTransactionsView getTransactionReconciliationVi
TransactionReconciliationTransactionsView.ReconciliationCodeView.NOK,
TransactionReconciliationTransactionsView.ReconciliationCodeView.NOK,
TransactionReconciliationTransactionsView.ReconciliationCodeView.NOK,
Set.of(ReconciliationRejectionCodeRequest.of(reconcilationViolation.getRejectionCode(),false)),
Set.of(ReconciliationRejectionCodeRequest.of(reconcilationViolation.getRejectionCode(), false)),
null,
new LinkedHashSet<>(),
new LinkedHashSet<>()
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -54,5 +54,4 @@ public Optional<OrganisationChartOfAccount> getChartOfAccounts(String organisati
public Optional<AccountEvent> findEventCode(String organisationId, String customerCode) {
return accountEventService.findById(organisationId, customerCode);
}

}
Original file line number Diff line number Diff line change
@@ -0,0 +1,17 @@
package org.cardanofoundation.lob.app.organisation.domain.view;

import lombok.AllArgsConstructor;
import lombok.Builder;
import lombok.Getter;

@Getter
@Builder
@AllArgsConstructor
public class OrganisationCostCenterView {

private String customerCode;

private String externalCustomerCode;

private String name;
}
Original file line number Diff line number Diff line change
Expand Up @@ -9,6 +9,7 @@

import java.time.LocalDate;
import java.time.format.DateTimeFormatter;
import java.util.Set;

@Getter
@Builder
Expand Down Expand Up @@ -38,6 +39,10 @@ public class OrganisationView {
@Schema(example = "[email protected]")
private String adminEmail;

private Set<OrganisationCostCenterView> costCenter;

private Set<OrganisationCostCenterView> projects;

@Schema(example = "")
private String logo;

Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -2,7 +2,14 @@

import org.cardanofoundation.lob.app.organisation.domain.entity.OrganisationCostCenter;
import org.springframework.data.jpa.repository.JpaRepository;
import org.springframework.data.jpa.repository.Query;
import org.springframework.data.repository.query.Param;

import java.util.Optional;
import java.util.Set;

public interface CostCenterRepository extends JpaRepository<OrganisationCostCenter, OrganisationCostCenter.Id> {

@Query("SELECT t FROM OrganisationCostCenter t WHERE t.id.organisationId = :organisationId")
Set<OrganisationCostCenter> findAllByOrganisationId(@Param("organisationId") String organisationId);
}
Original file line number Diff line number Diff line change
@@ -1,9 +1,14 @@
package org.cardanofoundation.lob.app.organisation.repository;

import org.cardanofoundation.lob.app.organisation.domain.entity.OrganisationCostCenter;
import org.cardanofoundation.lob.app.organisation.domain.entity.OrganisationProject;
import org.springframework.data.jpa.repository.JpaRepository;
import org.springframework.data.jpa.repository.Query;
import org.springframework.data.repository.query.Param;

public interface ProjectMappingRepository extends JpaRepository<OrganisationProject, OrganisationProject.Id> {
import java.util.Set;

public interface ProjectMappingRepository extends JpaRepository<OrganisationProject, OrganisationProject.Id> {
@Query("SELECT t FROM OrganisationProject t WHERE t.id.organisationId = :organisationId")
Set<OrganisationProject> findAllByOrganisationId(@Param("organisationId") String organisationId);
}
Loading

0 comments on commit bafbd0b

Please sign in to comment.