Removed old total fetch method.
This commit is contained in:
parent
5bbd8e4ef3
commit
e14b484ca5
|
@ -23,9 +23,10 @@
|
||||||
package net.forwardfire.vasc.backend;
|
package net.forwardfire.vasc.backend;
|
||||||
|
|
||||||
import java.io.Serializable;
|
import java.io.Serializable;
|
||||||
import java.util.Map;
|
|
||||||
|
|
||||||
/**
|
/**
|
||||||
|
* AbstractVascBackend.
|
||||||
|
*
|
||||||
*
|
*
|
||||||
* @author Willem Cazander
|
* @author Willem Cazander
|
||||||
* @version 1.0 Aug 2, 2007
|
* @version 1.0 Aug 2, 2007
|
||||||
|
@ -83,14 +84,6 @@ abstract public class AbstractVascBackend<DATA_OBJECT extends Serializable> impl
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
|
||||||
* @see net.forwardfire.vasc.backend.VascBackend#fetchTotalExecuteSize(VascBackendState state)
|
|
||||||
*/
|
|
||||||
@Override
|
|
||||||
public long fetchTotalExecuteSize(VascBackendState state) {
|
|
||||||
return 0;
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* @see net.forwardfire.vasc.backend.VascBackend#isSearchable()
|
* @see net.forwardfire.vasc.backend.VascBackend#isSearchable()
|
||||||
*/
|
*/
|
||||||
|
@ -131,22 +124,6 @@ abstract public class AbstractVascBackend<DATA_OBJECT extends Serializable> impl
|
||||||
return 0l;
|
return 0l;
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
|
||||||
* @see net.forwardfire.vasc.backend.VascBackend#executePageSummary()
|
|
||||||
*/
|
|
||||||
@Override
|
|
||||||
public Map<String, Object> executePageSummary() {
|
|
||||||
return null;
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* @see net.forwardfire.vasc.backend.VascBackend#executeTotalSummary()
|
|
||||||
*/
|
|
||||||
@Override
|
|
||||||
public Map<String, Object> executeTotalSummary() {
|
|
||||||
return null;
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* @see net.forwardfire.vasc.backend.VascBackend#hasPageSummary()
|
* @see net.forwardfire.vasc.backend.VascBackend#hasPageSummary()
|
||||||
*/
|
*/
|
||||||
|
|
|
@ -35,7 +35,11 @@ import java.util.Map;
|
||||||
public final class DefaultVascBackendResult<DATA_OBJECT extends Serializable> extends AbstractVascBackendResult<DATA_OBJECT> {
|
public final class DefaultVascBackendResult<DATA_OBJECT extends Serializable> extends AbstractVascBackendResult<DATA_OBJECT> {
|
||||||
|
|
||||||
public DefaultVascBackendResult(List<DATA_OBJECT> pageData) {
|
public DefaultVascBackendResult(List<DATA_OBJECT> pageData) {
|
||||||
this(pageData,-1,null,null);
|
this(pageData,-1);
|
||||||
|
}
|
||||||
|
|
||||||
|
public DefaultVascBackendResult(List<DATA_OBJECT> pageData,long totalSize) {
|
||||||
|
this(pageData,totalSize,null,null);
|
||||||
}
|
}
|
||||||
|
|
||||||
public DefaultVascBackendResult(List<DATA_OBJECT> pageData, long totalSize,
|
public DefaultVascBackendResult(List<DATA_OBJECT> pageData, long totalSize,
|
||||||
|
|
|
@ -78,12 +78,6 @@ public interface VascBackend<DATA_OBJECT extends Serializable> {
|
||||||
*/
|
*/
|
||||||
public boolean isPageable();
|
public boolean isPageable();
|
||||||
|
|
||||||
/**
|
|
||||||
* Returns the total amount of records.
|
|
||||||
* @return
|
|
||||||
*/
|
|
||||||
public long fetchTotalExecuteSize(VascBackendState state);
|
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Defines if the backend supports pageing
|
* Defines if the backend supports pageing
|
||||||
* @return
|
* @return
|
||||||
|
@ -100,8 +94,6 @@ public interface VascBackend<DATA_OBJECT extends Serializable> {
|
||||||
|
|
||||||
|
|
||||||
public boolean hasPageSummary();
|
public boolean hasPageSummary();
|
||||||
public Map<String,Object> executePageSummary();
|
|
||||||
|
|
||||||
public boolean hasTotalSummary();
|
public boolean hasTotalSummary();
|
||||||
public Map<String,Object> executeTotalSummary();
|
|
||||||
}
|
}
|
||||||
|
|
|
@ -76,10 +76,12 @@ public class XpqlHibernateVascBackend<DATA_OBJECT extends Serializable> extends
|
||||||
return hibernateSessionProvider.getHibernateSession();
|
return hibernateSessionProvider.getHibernateSession();
|
||||||
}
|
}
|
||||||
|
|
||||||
@SuppressWarnings("unchecked")
|
|
||||||
@Override
|
@Override
|
||||||
public VascBackendResult<DATA_OBJECT> execute(VascBackendState state) throws VascBackendException {
|
public VascBackendResult<DATA_OBJECT> execute(VascBackendState state) throws VascBackendException {
|
||||||
|
return new DefaultVascBackendResult<DATA_OBJECT>(executeList(state),fetchTotalExecuteSize(state));
|
||||||
|
}
|
||||||
|
|
||||||
|
private List<DATA_OBJECT> executeList(VascBackendState state) throws VascBackendException {
|
||||||
// Copy parameters
|
// Copy parameters
|
||||||
for (String key:state.getDataParameterKeys()) {
|
for (String key:state.getDataParameterKeys()) {
|
||||||
Object value = state.getDataParameter(key);
|
Object value = state.getDataParameter(key);
|
||||||
|
@ -111,7 +113,7 @@ public class XpqlHibernateVascBackend<DATA_OBJECT extends Serializable> extends
|
||||||
List<DATA_OBJECT> data = q.list();
|
List<DATA_OBJECT> data = q.list();
|
||||||
s.getTransaction().commit();
|
s.getTransaction().commit();
|
||||||
|
|
||||||
return new DefaultVascBackendResult<DATA_OBJECT>(data);
|
return data;
|
||||||
} finally {
|
} finally {
|
||||||
if (s!=null) {
|
if (s!=null) {
|
||||||
//em.close();
|
//em.close();
|
||||||
|
@ -203,11 +205,7 @@ public class XpqlHibernateVascBackend<DATA_OBJECT extends Serializable> extends
|
||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
private long fetchTotalExecuteSize(VascBackendState state) {
|
||||||
* @see net.forwardfire.vasc.backend.VascBackend#fetchTotalExecuteSize(VascBackendState state)
|
|
||||||
*/
|
|
||||||
@Override
|
|
||||||
public long fetchTotalExecuteSize(VascBackendState state) {
|
|
||||||
Session s = getHibernateSession();
|
Session s = getHibernateSession();
|
||||||
try {
|
try {
|
||||||
s.getTransaction().begin();
|
s.getTransaction().begin();
|
||||||
|
|
|
@ -76,9 +76,13 @@ public class XpqlPersistanceVascBackend<DATA_OBJECT extends Serializable> extend
|
||||||
return entityManagerProvider.getEntityManager();
|
return entityManagerProvider.getEntityManager();
|
||||||
}
|
}
|
||||||
|
|
||||||
@SuppressWarnings("unchecked")
|
|
||||||
@Override
|
@Override
|
||||||
public VascBackendResult<DATA_OBJECT> execute(VascBackendState state) throws VascBackendException {
|
public VascBackendResult<DATA_OBJECT> execute(VascBackendState state) throws VascBackendException {
|
||||||
|
return new DefaultVascBackendResult<DATA_OBJECT>(executeList(state),fetchTotalExecuteSize(state));
|
||||||
|
}
|
||||||
|
|
||||||
|
@SuppressWarnings("unchecked")
|
||||||
|
private List<DATA_OBJECT> executeList(VascBackendState state) throws VascBackendException {
|
||||||
|
|
||||||
// Copy parameters
|
// Copy parameters
|
||||||
for (String key:state.getDataParameterKeys()) {
|
for (String key:state.getDataParameterKeys()) {
|
||||||
|
@ -112,8 +116,7 @@ public class XpqlPersistanceVascBackend<DATA_OBJECT extends Serializable> extend
|
||||||
if (emTransaction) {
|
if (emTransaction) {
|
||||||
em.getTransaction().commit();
|
em.getTransaction().commit();
|
||||||
}
|
}
|
||||||
VascBackendResult<DATA_OBJECT> result = new DefaultVascBackendResult<DATA_OBJECT>(data);
|
return data;
|
||||||
return result;
|
|
||||||
} finally {
|
} finally {
|
||||||
if (em!=null) {
|
if (em!=null) {
|
||||||
//em.close();
|
//em.close();
|
||||||
|
@ -206,11 +209,7 @@ public class XpqlPersistanceVascBackend<DATA_OBJECT extends Serializable> extend
|
||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
private long fetchTotalExecuteSize(VascBackendState state) {
|
||||||
* @see net.forwardfire.vasc.backend.VascBackend#fetchTotalExecuteSize(VascBackendState state)
|
|
||||||
*/
|
|
||||||
@Override
|
|
||||||
public long fetchTotalExecuteSize(VascBackendState state) {
|
|
||||||
EntityManager em = getEntityManager();
|
EntityManager em = getEntityManager();
|
||||||
try {
|
try {
|
||||||
Query q = em.createQuery(queryTotal.toPreparedSQL(queryTotal));
|
Query q = em.createQuery(queryTotal.toPreparedSQL(queryTotal));
|
||||||
|
|
|
@ -141,11 +141,7 @@ public class MetaModelVascBackend extends AbstractVascBackend<Row> {
|
||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
private long fetchTotalExecuteSize(VascBackendState state) {
|
||||||
* @see net.forwardfire.vasc.backend.AbstractVascBackend#fetchTotalExecuteSize(net.forwardfire.vasc.backend.VascBackendState)
|
|
||||||
*/
|
|
||||||
@Override
|
|
||||||
public long fetchTotalExecuteSize(VascBackendState state) {
|
|
||||||
Schema schema = dataContext.getDefaultSchema();
|
Schema schema = dataContext.getDefaultSchema();
|
||||||
Table t = schema.getTableByName(table);
|
Table t = schema.getTableByName(table);
|
||||||
Query q = createFilterQuery(state,t,true);
|
Query q = createFilterQuery(state,t,true);
|
||||||
|
@ -213,6 +209,10 @@ public class MetaModelVascBackend extends AbstractVascBackend<Row> {
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public VascBackendResult<Row> execute(VascBackendState state) throws VascBackendException {
|
public VascBackendResult<Row> execute(VascBackendState state) throws VascBackendException {
|
||||||
|
return new DefaultVascBackendResult<Row>(executeList(state),fetchTotalExecuteSize(state));
|
||||||
|
}
|
||||||
|
|
||||||
|
private List<Row> executeList(VascBackendState state) throws VascBackendException {
|
||||||
Schema schema = dataContext.getDefaultSchema();
|
Schema schema = dataContext.getDefaultSchema();
|
||||||
Table t = schema.getTableByName(table);
|
Table t = schema.getTableByName(table);
|
||||||
if (t==null) {
|
if (t==null) {
|
||||||
|
@ -243,7 +243,7 @@ public class MetaModelVascBackend extends AbstractVascBackend<Row> {
|
||||||
DataSet ds = crudDataContext.executeQuery(q);
|
DataSet ds = crudDataContext.executeQuery(q);
|
||||||
result.addAll(ds.toRows());
|
result.addAll(ds.toRows());
|
||||||
ds.close();
|
ds.close();
|
||||||
return new DefaultVascBackendResult<Row>(result);
|
return result;
|
||||||
}
|
}
|
||||||
|
|
||||||
DataSet ds = dataContext.executeQuery(q);
|
DataSet ds = dataContext.executeQuery(q);
|
||||||
|
@ -261,7 +261,7 @@ public class MetaModelVascBackend extends AbstractVascBackend<Row> {
|
||||||
}
|
}
|
||||||
ds.close();
|
ds.close();
|
||||||
|
|
||||||
return new DefaultVascBackendResult<Row>(result);
|
return result;
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
|
|
|
@ -85,11 +85,7 @@ public class MongodbVascBackend extends AbstractVascBackend<BasicDBObject> {
|
||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
private long fetchTotalExecuteSize(VascBackendState state) {
|
||||||
* @see net.forwardfire.vasc.backend.AbstractVascBackend#fetchTotalExecuteSize(net.forwardfire.vasc.backend.VascBackendState)
|
|
||||||
*/
|
|
||||||
@Override
|
|
||||||
public long fetchTotalExecuteSize(VascBackendState state) {
|
|
||||||
DBCollection coll = getDBCollection();
|
DBCollection coll = getDBCollection();
|
||||||
DBObject query = createFilterQuery(state);
|
DBObject query = createFilterQuery(state);
|
||||||
long result = coll.count(query);
|
long result = coll.count(query);
|
||||||
|
@ -108,6 +104,10 @@ public class MongodbVascBackend extends AbstractVascBackend<BasicDBObject> {
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public VascBackendResult<BasicDBObject> execute(VascBackendState state) throws VascBackendException {
|
public VascBackendResult<BasicDBObject> execute(VascBackendState state) throws VascBackendException {
|
||||||
|
return new DefaultVascBackendResult<BasicDBObject>(executeList(state),fetchTotalExecuteSize(state));
|
||||||
|
}
|
||||||
|
|
||||||
|
private List<BasicDBObject> executeList(VascBackendState state) throws VascBackendException {
|
||||||
DBCollection coll = getDBCollection();
|
DBCollection coll = getDBCollection();
|
||||||
DBObject query = createFilterQuery(state);
|
DBObject query = createFilterQuery(state);
|
||||||
DBCursor cur = coll.find(query);
|
DBCursor cur = coll.find(query);
|
||||||
|
@ -120,7 +120,7 @@ public class MongodbVascBackend extends AbstractVascBackend<BasicDBObject> {
|
||||||
DBObject row = cur.next();
|
DBObject row = cur.next();
|
||||||
result.add((BasicDBObject)row);
|
result.add((BasicDBObject)row);
|
||||||
}
|
}
|
||||||
return new DefaultVascBackendResult<BasicDBObject>(result);
|
return result;
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
|
|
|
@ -23,7 +23,6 @@
|
||||||
package net.forwardfire.vasc.backend.proxy;
|
package net.forwardfire.vasc.backend.proxy;
|
||||||
|
|
||||||
import java.io.Serializable;
|
import java.io.Serializable;
|
||||||
import java.util.Map;
|
|
||||||
|
|
||||||
import net.forwardfire.vasc.backend.VascBackend;
|
import net.forwardfire.vasc.backend.VascBackend;
|
||||||
import net.forwardfire.vasc.backend.VascBackendException;
|
import net.forwardfire.vasc.backend.VascBackendException;
|
||||||
|
@ -94,14 +93,6 @@ abstract public class AbstractVascBackendProxy implements VascBackendProxy {
|
||||||
return backend.isReadOnly();
|
return backend.isReadOnly();
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
|
||||||
* @see net.forwardfire.vasc.backend.VascBackend#fetchTotalExecuteSize(VascBackendState state)
|
|
||||||
*/
|
|
||||||
@Override
|
|
||||||
public long fetchTotalExecuteSize(VascBackendState state) {
|
|
||||||
return backend.fetchTotalExecuteSize(state);
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* @see net.forwardfire.vasc.backend.VascBackend#isSortable()
|
* @see net.forwardfire.vasc.backend.VascBackend#isSortable()
|
||||||
*/
|
*/
|
||||||
|
@ -215,22 +206,6 @@ abstract public class AbstractVascBackendProxy implements VascBackendProxy {
|
||||||
return backend.isRecordMoveable();
|
return backend.isRecordMoveable();
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
|
||||||
* @see net.forwardfire.vasc.backend.VascBackend#executePageSummary()
|
|
||||||
*/
|
|
||||||
@Override
|
|
||||||
public Map<String, Object> executePageSummary() {
|
|
||||||
return backend.executePageSummary();
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* @see net.forwardfire.vasc.backend.VascBackend#executeTotalSummary()
|
|
||||||
*/
|
|
||||||
@Override
|
|
||||||
public Map<String, Object> executeTotalSummary() {
|
|
||||||
return backend.executeTotalSummary();
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* @see net.forwardfire.vasc.backend.VascBackend#hasPageSummary()
|
* @see net.forwardfire.vasc.backend.VascBackend#hasPageSummary()
|
||||||
*/
|
*/
|
||||||
|
|
|
@ -38,7 +38,6 @@ import net.forwardfire.vasc.backend.VascBackendState;
|
||||||
*/
|
*/
|
||||||
public class VascBackendProxyCache extends AbstractVascBackendProxy {
|
public class VascBackendProxyCache extends AbstractVascBackendProxy {
|
||||||
|
|
||||||
private Long records = null;
|
|
||||||
private VascBackendResult<Serializable> data = null;
|
private VascBackendResult<Serializable> data = null;
|
||||||
private String searchString = null;
|
private String searchString = null;
|
||||||
private Map<String,Object> dataState = null;
|
private Map<String,Object> dataState = null;
|
||||||
|
@ -139,15 +138,6 @@ public class VascBackendProxyCache extends AbstractVascBackendProxy {
|
||||||
return data;
|
return data;
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
|
||||||
public long fetchTotalExecuteSize(VascBackendState state) {
|
|
||||||
boolean changed = isStateChanged(state);
|
|
||||||
if (records==null | changed) {
|
|
||||||
records = backend.fetchTotalExecuteSize(state);
|
|
||||||
}
|
|
||||||
return records;
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* @see net.forwardfire.vasc.backend.proxy.AbstractVascBackendProxy#delete(java.lang.Object)
|
* @see net.forwardfire.vasc.backend.proxy.AbstractVascBackendProxy#delete(java.lang.Object)
|
||||||
*/
|
*/
|
||||||
|
|
|
@ -147,17 +147,6 @@ public class VascBackendProxyEventExecutor extends AbstractVascBackendProxy {
|
||||||
return result;
|
return result;
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
|
||||||
* @see net.forwardfire.vasc.backend.proxy.AbstractVascBackendProxy#fetchTotalExecuteSize(net.forwardfire.vasc.backend.VascBackendState)
|
|
||||||
*/
|
|
||||||
@Override
|
|
||||||
public long fetchTotalExecuteSize(VascBackendState state) {
|
|
||||||
fireVascEvent(VascBackendEventType.PRE_TOTAL_EXECUTE_SIZE,state);
|
|
||||||
Long result = super.fetchTotalExecuteSize(state);
|
|
||||||
fireVascEvent(VascBackendEventType.POST_TOTAL_EXECUTE_SIZE,result);
|
|
||||||
return result;
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* @see net.forwardfire.vasc.backend.proxy.AbstractVascBackendProxy#merge(java.lang.Object)
|
* @see net.forwardfire.vasc.backend.proxy.AbstractVascBackendProxy#merge(java.lang.Object)
|
||||||
*/
|
*/
|
||||||
|
|
|
@ -41,7 +41,6 @@ import net.forwardfire.vasc.core.VascEntry;
|
||||||
*/
|
*/
|
||||||
public class VascBackendProxyFilter extends AbstractVascBackendProxy {
|
public class VascBackendProxyFilter extends AbstractVascBackendProxy {
|
||||||
|
|
||||||
private long records = 0;
|
|
||||||
private List<VascProxyFilter> filters = null;
|
private List<VascProxyFilter> filters = null;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
|
@ -97,12 +96,6 @@ public class VascBackendProxyFilter extends AbstractVascBackendProxy {
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
records = search.size();
|
return new DefaultVascBackendResult<Serializable>(search,search.size());
|
||||||
return new DefaultVascBackendResult<Serializable>(search);
|
|
||||||
}
|
|
||||||
|
|
||||||
@Override
|
|
||||||
public long fetchTotalExecuteSize(VascBackendState state) {
|
|
||||||
return records;
|
|
||||||
}
|
}
|
||||||
}
|
}
|
|
@ -39,8 +39,6 @@ import net.forwardfire.vasc.backend.VascBackendState;
|
||||||
*/
|
*/
|
||||||
public class VascBackendProxyPaged extends AbstractVascBackendProxy {
|
public class VascBackendProxyPaged extends AbstractVascBackendProxy {
|
||||||
|
|
||||||
private long records = 0;
|
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* @see java.lang.Object#clone()
|
* @see java.lang.Object#clone()
|
||||||
*/
|
*/
|
||||||
|
@ -77,7 +75,6 @@ public class VascBackendProxyPaged extends AbstractVascBackendProxy {
|
||||||
VascBackendResult<Serializable> allData = backend.execute(state);
|
VascBackendResult<Serializable> allData = backend.execute(state);
|
||||||
int pageSize = state.getPageSize();
|
int pageSize = state.getPageSize();
|
||||||
if (pageSize==0) {
|
if (pageSize==0) {
|
||||||
records = allData.getPageData().size();
|
|
||||||
return allData;
|
return allData;
|
||||||
}
|
}
|
||||||
List<Serializable> paged = new ArrayList<Serializable>(state.getPageSize());
|
List<Serializable> paged = new ArrayList<Serializable>(state.getPageSize());
|
||||||
|
@ -90,12 +87,6 @@ public class VascBackendProxyPaged extends AbstractVascBackendProxy {
|
||||||
Serializable o = allData.getPageData().get(i);
|
Serializable o = allData.getPageData().get(i);
|
||||||
paged.add(o);
|
paged.add(o);
|
||||||
}
|
}
|
||||||
records = allData.getPageData().size();
|
return new DefaultVascBackendResult<Serializable>(paged,allData.getPageData().size());
|
||||||
return new DefaultVascBackendResult<Serializable>(paged);
|
|
||||||
}
|
|
||||||
|
|
||||||
@Override
|
|
||||||
public long fetchTotalExecuteSize(VascBackendState state) {
|
|
||||||
return records;
|
|
||||||
}
|
}
|
||||||
}
|
}
|
|
@ -137,9 +137,4 @@ public class VascBackendProxySearch extends AbstractVascBackendProxy {
|
||||||
//records = search.size();
|
//records = search.size();
|
||||||
return new DefaultVascBackendResult<Serializable>(search);
|
return new DefaultVascBackendResult<Serializable>(search);
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
|
||||||
public long fetchTotalExecuteSize(VascBackendState state) {
|
|
||||||
return backend.fetchTotalExecuteSize(state);
|
|
||||||
}
|
|
||||||
}
|
}
|
|
@ -69,17 +69,6 @@ public class VascBackendProxyTimerLogger extends AbstractVascBackendProxy {
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
|
||||||
public long fetchTotalExecuteSize(VascBackendState state) {
|
|
||||||
long t1 = System.currentTimeMillis();
|
|
||||||
try {
|
|
||||||
return backend.fetchTotalExecuteSize(state);
|
|
||||||
} finally {
|
|
||||||
long t2 = System.currentTimeMillis();
|
|
||||||
logger.log(logLevel,"vasc-fetchTotalExecuteSize backend: "+getId()+" in "+(t2-t1)+" ms");
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* @see net.forwardfire.vasc.backend.proxy.AbstractVascBackendProxy#doRecordMoveDownById(net.forwardfire.vasc.backend.VascBackendState, java.lang.Object)
|
* @see net.forwardfire.vasc.backend.proxy.AbstractVascBackendProxy#doRecordMoveDownById(net.forwardfire.vasc.backend.VascBackendState, java.lang.Object)
|
||||||
*/
|
*/
|
||||||
|
|
|
@ -42,7 +42,6 @@ public interface VascEntryBackendEventListener extends Serializable {
|
||||||
PRE_DELETE,
|
PRE_DELETE,
|
||||||
PRE_PROVIDE_FIELD_VALUE,
|
PRE_PROVIDE_FIELD_VALUE,
|
||||||
PRE_PROVIDE_RECORD_CREATOR,
|
PRE_PROVIDE_RECORD_CREATOR,
|
||||||
PRE_TOTAL_EXECUTE_SIZE,
|
|
||||||
PRE_MOVE_DOWN,
|
PRE_MOVE_DOWN,
|
||||||
PRE_MOVE_UP,
|
PRE_MOVE_UP,
|
||||||
|
|
||||||
|
@ -52,7 +51,6 @@ public interface VascEntryBackendEventListener extends Serializable {
|
||||||
POST_DELETE,
|
POST_DELETE,
|
||||||
POST_PROVIDE_FIELD_VALUE,
|
POST_PROVIDE_FIELD_VALUE,
|
||||||
POST_PROVIDE_RECORD_CREATOR,
|
POST_PROVIDE_RECORD_CREATOR,
|
||||||
POST_TOTAL_EXECUTE_SIZE,
|
|
||||||
POST_MOVE_DOWN,
|
POST_MOVE_DOWN,
|
||||||
POST_MOVE_UP
|
POST_MOVE_UP
|
||||||
}
|
}
|
||||||
|
|
|
@ -65,8 +65,7 @@ public class SetParameterBackendListener implements VascEntryBackendEventListene
|
||||||
VascBackendEventType.PRE_MERGE,
|
VascBackendEventType.PRE_MERGE,
|
||||||
VascBackendEventType.PRE_MOVE_DOWN,
|
VascBackendEventType.PRE_MOVE_DOWN,
|
||||||
VascBackendEventType.PRE_MOVE_UP,
|
VascBackendEventType.PRE_MOVE_UP,
|
||||||
VascBackendEventType.PRE_PERSIST,
|
VascBackendEventType.PRE_PERSIST
|
||||||
VascBackendEventType.PRE_TOTAL_EXECUTE_SIZE
|
|
||||||
};
|
};
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -27,6 +27,7 @@ import java.util.Date;
|
||||||
import java.util.logging.Logger;
|
import java.util.logging.Logger;
|
||||||
|
|
||||||
import net.forwardfire.vasc.backend.VascBackendException;
|
import net.forwardfire.vasc.backend.VascBackendException;
|
||||||
|
import net.forwardfire.vasc.backend.VascBackendResult;
|
||||||
import net.forwardfire.vasc.backend.VascBackendState;
|
import net.forwardfire.vasc.backend.VascBackendState;
|
||||||
import net.forwardfire.vasc.backend.proxy.VascProxyFilter;
|
import net.forwardfire.vasc.backend.proxy.VascProxyFilter;
|
||||||
import net.forwardfire.vasc.core.VascEntry;
|
import net.forwardfire.vasc.core.VascEntry;
|
||||||
|
@ -225,25 +226,25 @@ public class DefaultVascFrontendActions implements VascFrontendActions {
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
// Always update total records
|
VascBackendResult<Serializable> result;
|
||||||
Long total = entry.getVascFrontendController().getVascEntryState().getVascBackend().fetchTotalExecuteSize(backendState);
|
try {
|
||||||
entry.getVascFrontendController().getVascEntryState().setTotalBackendRecords(total);
|
result = entry.getVascFrontendController().getVascEntryState().getVascBackend().execute(backendState);
|
||||||
|
} catch (VascBackendException ve) {
|
||||||
|
throw new VascFrontendException(ve);
|
||||||
|
}
|
||||||
|
|
||||||
|
// Set data in frontend
|
||||||
|
entry.getVascFrontendController().getVascEntryState().setEntryDataList(result.getPageData());
|
||||||
|
entry.getVascFrontendController().getVascEntryState().setTotalBackendRecords(result.getTotalSize());
|
||||||
|
|
||||||
// check if we need to change the current page if table size if changed in between
|
// check if we need to change the current page if table size if changed in between
|
||||||
int pages = new Long(total/backendState.getPageSize()).intValue();
|
int pages = new Long(result.getTotalSize()/backendState.getPageSize()).intValue();
|
||||||
if (backendState.getPageIndex() > pages) {
|
if (backendState.getPageIndex() > pages) {
|
||||||
backendState.setPageIndex(pages);
|
backendState.setPageIndex(pages);
|
||||||
}
|
}
|
||||||
|
|
||||||
try {
|
// Fire event post read
|
||||||
// Execute to get data.
|
entry.getVascFrontendController().fireVascFrontendEvent(entry,VascEntryFrontendEventListener.VascFrontendEventType.POST_READ, null);
|
||||||
entry.getVascFrontendController().getVascEntryState().setEntryDataList(entry.getVascFrontendController().getVascEntryState().getVascBackend().execute(backendState).getPageData());
|
|
||||||
|
|
||||||
// Fire event post read
|
|
||||||
entry.getVascFrontendController().fireVascFrontendEvent(entry,VascEntryFrontendEventListener.VascFrontendEventType.POST_READ, null);
|
|
||||||
} catch (VascBackendException ve) {
|
|
||||||
throw new VascFrontendException(ve);
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
|
|
|
@ -174,9 +174,6 @@ public class VascExportServlet extends HttpServlet {
|
||||||
VascEntryLocal ve = (VascEntryLocal)vc.getVascEntryConfigController().configVascEntry(vc, entryId);
|
VascEntryLocal ve = (VascEntryLocal)vc.getVascEntryConfigController().configVascEntry(vc, entryId);
|
||||||
vc.getVascEntryConfigController().configVascFrontendController(vc, ve);
|
vc.getVascEntryConfigController().configVascFrontendController(vc, ve);
|
||||||
|
|
||||||
// Update total every time first
|
|
||||||
Long total = ve.getVascFrontendController().getVascEntryState().getVascBackend().fetchTotalExecuteSize(ve.getVascFrontendController().getVascEntryState().getVascBackendState());
|
|
||||||
ve.getVascFrontendController().getVascEntryState().setTotalBackendRecords(total);
|
|
||||||
VascEntryExport ex = vc.getVascEntryConfigController().getVascEntryExporterById(exportId);
|
VascEntryExport ex = vc.getVascEntryConfigController().getVascEntryExporterById(exportId);
|
||||||
VascEntryExportWriter exw = ex.createExportWriter();
|
VascEntryExportWriter exw = ex.createExportWriter();
|
||||||
exw.doInit(ex, ve);
|
exw.doInit(ex, ve);
|
||||||
|
|
Loading…
Reference in a new issue