From e94d98ea529c1f90ac38db4190a33c5da3739bbc Mon Sep 17 00:00:00 2001 From: Thomas Kerin Date: Thu, 17 Sep 2020 18:36:52 +0100 Subject: [PATCH] Fix: getBalances query should always join transacc table so journal restriction is applied --- .../minigl/src/main/java/org/jpos/gl/GLSession.java | 10 +++++----- 1 file changed, 5 insertions(+), 5 deletions(-) diff --git a/modules/minigl/src/main/java/org/jpos/gl/GLSession.java b/modules/minigl/src/main/java/org/jpos/gl/GLSession.java index 3e5c3c236e..09f670eccb 100644 --- a/modules/minigl/src/main/java/org/jpos/gl/GLSession.java +++ b/modules/minigl/src/main/java/org/jpos/gl/GLSession.java @@ -1151,10 +1151,9 @@ else if (acct.isFinalAccount()) { checkPermission (GLPermission.READ, journal); BigDecimal balance[] = { ZERO, Z }; BalanceCache bcache = null; - if (date != null) { - select.append(", transacc as txn\n"); - } - else if (!ignoreBalanceCache) { + select.append(", transacc as txn\n"); + + if (!ignoreBalanceCache) { short[] layersCopy = Arrays.copyOf(layers,layers.length); bcache = getBalanceCache(journal, acct, layersCopy); if (maxId > 0 && bcache != null && bcache.getRef() > maxId) @@ -1180,8 +1179,8 @@ else if (acct.isChart()) { where(qs, "entry.account = acct.id"); where(qs, "acct.code like :code"); } + where(qs, "(entry.transaction = txn.id and txn.journal = :journal)\n"); if (date != null) { - where(qs, "entry.transaction = txn.id\n"); where(qs, "txn.postDate < :date"); } where(qs, "entry.layer in"); @@ -1197,6 +1196,7 @@ else if (acct.isChart()) { else { q.setParameter("code", acct.getCode() + "%"); } + q.setParameter("journal", journal.getId()); if (date != null) { q.setParameter("date", inclusive ? Util.tomorrow(date) : date); }