2
0
Fork 0

Upgraded backend api with generics.

This commit is contained in:
Willem Cazander 2014-05-28 14:16:03 +02:00
parent 9a6227be5b
commit 1b3e65fa83
53 changed files with 282 additions and 256 deletions

View file

@ -22,6 +22,7 @@
package net.forwardfire.vasc.backend; package net.forwardfire.vasc.backend;
import java.io.Serializable;
import java.util.Map; import java.util.Map;
/** /**
@ -29,7 +30,7 @@ import java.util.Map;
* @author Willem Cazander * @author Willem Cazander
* @version 1.0 Aug 2, 2007 * @version 1.0 Aug 2, 2007
*/ */
abstract public class AbstractVascBackend implements VascBackend { abstract public class AbstractVascBackend<DATA_OBJECT extends Serializable> implements VascBackend<DATA_OBJECT> {
private String id = null; private String id = null;

View file

@ -22,6 +22,7 @@
package net.forwardfire.vasc.backend; package net.forwardfire.vasc.backend;
import java.io.Serializable;
import java.util.List; import java.util.List;
import java.util.Map; import java.util.Map;
@ -31,7 +32,7 @@ import java.util.Map;
* @author Willem Cazander * @author Willem Cazander
* @version 1.0 Mar 21, 2007 * @version 1.0 Mar 21, 2007
*/ */
public interface VascBackend { public interface VascBackend<DATA_OBJECT extends Serializable> {
public String getId(); public String getId();
public void setId(String id); public void setId(String id);
@ -39,15 +40,15 @@ public interface VascBackend {
public void startBackend(); public void startBackend();
public void stopBackend(); public void stopBackend();
public List<Object> execute(VascBackendState state) throws VascBackendException; public List<DATA_OBJECT> execute(VascBackendState state) throws VascBackendException;
public boolean isReadOnly(); public boolean isReadOnly();
public void persist(Object object) throws VascBackendException; public void persist(DATA_OBJECT object) throws VascBackendException;
public Object merge(Object object) throws VascBackendException; public DATA_OBJECT merge(DATA_OBJECT object) throws VascBackendException;
public void delete(Object object) throws VascBackendException; public void delete(DATA_OBJECT object) throws VascBackendException;
/** /**
* Creates a new Field acces obj the the given field entry. * Creates a new Field acces obj the the given field entry.
@ -61,7 +62,7 @@ public interface VascBackend {
* note: Do not use inline class here because it needs to be seriabable and the backend is not seriabbzle. * note: Do not use inline class here because it needs to be seriabable and the backend is not seriabbzle.
* @return * @return
*/ */
public VascEntryRecordCreator provideVascEntryRecordCreator(); public VascEntryRecordCreator<DATA_OBJECT> provideVascEntryRecordCreator();
/** /**
* Defines if the backend supports sorting * Defines if the backend supports sorting

View file

@ -30,9 +30,7 @@ import java.io.Serializable;
* @author Willem Cazander * @author Willem Cazander
* @version 1.0 Mar 21, 2007 * @version 1.0 Mar 21, 2007
*/ */
public interface VascEntryRecordCreator extends Serializable { public interface VascEntryRecordCreator<DATA_OBJECT extends Serializable> extends Serializable {
public Object newRecord() throws VascBackendException; public DATA_OBJECT newRecord() throws VascBackendException;
public Class<?> getObjectClass();
} }

View file

@ -22,6 +22,8 @@
package net.forwardfire.vasc.backend.data; package net.forwardfire.vasc.backend.data;
import java.io.Serializable;
import net.forwardfire.vasc.backend.VascBackendException; import net.forwardfire.vasc.backend.VascBackendException;
import net.forwardfire.vasc.backend.VascEntryRecordCreator; import net.forwardfire.vasc.backend.VascEntryRecordCreator;
@ -32,7 +34,7 @@ import net.forwardfire.vasc.backend.VascEntryRecordCreator;
* @author Willem Cazander * @author Willem Cazander
* @version 1.0 Dec 05, 2009 * @version 1.0 Dec 05, 2009
*/ */
public class BeanVascEntryRecordCreator implements VascEntryRecordCreator { public class BeanVascEntryRecordCreator<DATA_OBJECT extends Serializable> implements VascEntryRecordCreator<DATA_OBJECT> {
private static final long serialVersionUID = 1L; private static final long serialVersionUID = 1L;
private Class<?> resultClass = null; private Class<?> resultClass = null;
@ -44,13 +46,10 @@ public class BeanVascEntryRecordCreator implements VascEntryRecordCreator {
this.resultClass=resultClass; this.resultClass=resultClass;
} }
public Class<?> getObjectClass() { @SuppressWarnings("unchecked")
return resultClass; public DATA_OBJECT newRecord() throws VascBackendException {
}
public Object newRecord() throws VascBackendException {
try { try {
return resultClass.newInstance(); return (DATA_OBJECT)resultClass.newInstance();
} catch (InstantiationException e) { } catch (InstantiationException e) {
throw new VascBackendException(e); throw new VascBackendException(e);
} catch (IllegalAccessException e) { } catch (IllegalAccessException e) {

View file

@ -34,7 +34,7 @@ import net.forwardfire.vasc.backend.VascEntryFieldValue;
* @author Willem Cazander * @author Willem Cazander
* @version 1.0 Dec 05, 2009 * @version 1.0 Dec 05, 2009
*/ */
public class MapVascEntryFieldValue implements VascEntryFieldValue { public class HashMapVascEntryFieldValue implements VascEntryFieldValue {
private static final long serialVersionUID = 1L; private static final long serialVersionUID = 1L;

View file

@ -23,27 +23,21 @@
package net.forwardfire.vasc.backend.data; package net.forwardfire.vasc.backend.data;
import java.util.HashMap; import java.util.HashMap;
import java.util.Map;
import net.forwardfire.vasc.backend.VascBackendException; import net.forwardfire.vasc.backend.VascBackendException;
import net.forwardfire.vasc.backend.VascEntryRecordCreator; import net.forwardfire.vasc.backend.VascEntryRecordCreator;
/** /**
* MapVascEntryRecordCreator creates a new HashMap for Map based record backends. * MapVascEntryRecordCreator creates a new HashMap for Map based record backends.
* *
* @author Willem Cazander * @author Willem Cazander
* @version 1.0 Dec 05, 2009 * @version 1.0 Dec 05, 2009
*/ */
public class MapVascEntryRecordCreator implements VascEntryRecordCreator { public class HashMapVascEntryRecordCreator implements VascEntryRecordCreator<HashMap<String,Object>> {
private static final long serialVersionUID = 1L; private static final long serialVersionUID = 1L;
public Class<?> getObjectClass() { public HashMap<String,Object> newRecord() throws VascBackendException {
return Map.class;
}
public Object newRecord() throws VascBackendException {
return new HashMap<String,Object>(10); return new HashMap<String,Object>(10);
} }
} }

View file

@ -24,20 +24,19 @@ package net.forwardfire.vasc.backend.jdbc;
import java.sql.Connection; import java.sql.Connection;
import java.sql.ResultSet; import java.sql.ResultSet;
import java.sql.SQLException;
import java.sql.Statement; import java.sql.Statement;
import java.util.ArrayList; import java.util.ArrayList;
import java.util.HashMap; import java.util.HashMap;
import java.util.List; import java.util.List;
import java.util.Map;
import net.forwardfire.vasc.backend.AbstractVascBackend; import net.forwardfire.vasc.backend.AbstractVascBackend;
import net.forwardfire.vasc.backend.VascBackendException; import net.forwardfire.vasc.backend.VascBackendException;
import net.forwardfire.vasc.backend.VascBackendState; import net.forwardfire.vasc.backend.VascBackendState;
import net.forwardfire.vasc.backend.VascEntryFieldValue; import net.forwardfire.vasc.backend.VascEntryFieldValue;
import net.forwardfire.vasc.backend.VascEntryRecordCreator; import net.forwardfire.vasc.backend.VascEntryRecordCreator;
import net.forwardfire.vasc.backend.data.MapVascEntryFieldValue; import net.forwardfire.vasc.backend.data.HashMapVascEntryFieldValue;
import net.forwardfire.vasc.backend.data.MapVascEntryRecordCreator; import net.forwardfire.vasc.backend.data.HashMapVascEntryRecordCreator;
/** /**
* JdbcVascBackend Simple jdbc vasc backend. * JdbcVascBackend Simple jdbc vasc backend.
@ -45,7 +44,7 @@ import net.forwardfire.vasc.backend.data.MapVascEntryRecordCreator;
* @author Willem Cazander * @author Willem Cazander
* @version 1.0 Sep 5, 2008 * @version 1.0 Sep 5, 2008
*/ */
public class JdbcVascBackend extends AbstractVascBackend { public class JdbcVascBackend extends AbstractVascBackend<HashMap<String,Object>> {
private JdbcConnectionProvider jdbcConnectionProvider = null; private JdbcConnectionProvider jdbcConnectionProvider = null;
private String sqlList = null; private String sqlList = null;
@ -80,9 +79,9 @@ public class JdbcVascBackend extends AbstractVascBackend {
/** /**
* @see net.forwardfire.vasc.backend.VascBackend#execute(VascBackendState state) * @see net.forwardfire.vasc.backend.VascBackend#execute(VascBackendState state)
*/ */
public List<Object> execute(VascBackendState state) throws VascBackendException { public List<HashMap<String,Object>> execute(VascBackendState state) throws VascBackendException {
JdbcConnectionProvider prov = getJdbcConnectionProvider(); JdbcConnectionProvider prov = getJdbcConnectionProvider();
List<Object> result = new ArrayList<Object>(50); List<HashMap<String,Object>> result = new ArrayList<HashMap<String,Object>>(50);
Connection connection = null; Connection connection = null;
try { try {
connection = prov.getJdbcConnection(); connection = prov.getJdbcConnection();
@ -91,7 +90,7 @@ public class JdbcVascBackend extends AbstractVascBackend {
ResultSet rs = s.getResultSet(); ResultSet rs = s.getResultSet();
int cols = rs.getMetaData().getColumnCount(); int cols = rs.getMetaData().getColumnCount();
while (rs.next()) { while (rs.next()) {
Map<String,Object> map = new HashMap<String,Object>(cols); HashMap<String,Object> map = new HashMap<String,Object>(cols);
for (int i=1;i<=cols;i++) { for (int i=1;i<=cols;i++) {
String columnName = rs.getMetaData().getColumnName(i); String columnName = rs.getMetaData().getColumnName(i);
Object columnObject = rs.getObject(i); Object columnObject = rs.getObject(i);
@ -99,7 +98,7 @@ public class JdbcVascBackend extends AbstractVascBackend {
} }
result.add(map); result.add(map);
} }
} catch (Exception e) { } catch (SQLException e) {
throw new VascBackendException(e); throw new VascBackendException(e);
} finally { } finally {
if (connection!=null) { if (connection!=null) {
@ -115,34 +114,34 @@ public class JdbcVascBackend extends AbstractVascBackend {
/** /**
* @see net.forwardfire.vasc.backend.VascBackend#merge(java.lang.Object) * @see net.forwardfire.vasc.backend.VascBackend#merge(java.lang.Object)
*/ */
public Object merge(Object object) throws VascBackendException { public HashMap<String,Object> merge(HashMap<String,Object> object) throws VascBackendException {
return object; return object;
} }
/** /**
* @see net.forwardfire.vasc.backend.VascBackend#persist(java.lang.Object) * @see net.forwardfire.vasc.backend.VascBackend#persist(java.lang.Object)
*/ */
public void persist(Object object) throws VascBackendException { public void persist(HashMap<String,Object> object) throws VascBackendException {
} }
/** /**
* @see net.forwardfire.vasc.backend.VascBackend#delete(java.lang.Object) * @see net.forwardfire.vasc.backend.VascBackend#delete(java.lang.Object)
*/ */
public void delete(Object object) throws VascBackendException { public void delete(HashMap<String,Object> object) throws VascBackendException {
} }
/** /**
* @see net.forwardfire.vasc.backend.VascBackend#provideVascEntryFieldValue(net.forwardfire.vasc.core.VascEntryField) * @see net.forwardfire.vasc.backend.VascBackend#provideVascEntryFieldValue(net.forwardfire.vasc.core.VascEntryField)
*/ */
public VascEntryFieldValue provideVascEntryFieldValue() { public VascEntryFieldValue provideVascEntryFieldValue() {
return new MapVascEntryFieldValue(); return new HashMapVascEntryFieldValue();
} }
/** /**
* @see net.forwardfire.vasc.backend.VascBackend#provideVascEntryRecordCreator(net.forwardfire.vasc.core.VascEntry) * @see net.forwardfire.vasc.backend.VascBackend#provideVascEntryRecordCreator(net.forwardfire.vasc.core.VascEntry)
*/ */
public VascEntryRecordCreator provideVascEntryRecordCreator() { public VascEntryRecordCreator provideVascEntryRecordCreator() {
return new MapVascEntryRecordCreator(); return new HashMapVascEntryRecordCreator();
} }
/** /**

View file

@ -25,29 +25,27 @@ package net.forwardfire.vasc.backend.jdbc;
import java.sql.Connection; import java.sql.Connection;
import java.sql.PreparedStatement; import java.sql.PreparedStatement;
import java.sql.ResultSet; import java.sql.ResultSet;
import java.sql.SQLException;
import java.util.ArrayList; import java.util.ArrayList;
import java.util.HashMap; import java.util.HashMap;
import java.util.List; import java.util.List;
import java.util.Map;
import net.forwardfire.vasc.backend.AbstractVascBackend; import net.forwardfire.vasc.backend.AbstractVascBackend;
import net.forwardfire.vasc.backend.VascBackendException; import net.forwardfire.vasc.backend.VascBackendException;
import net.forwardfire.vasc.backend.VascBackendState; import net.forwardfire.vasc.backend.VascBackendState;
import net.forwardfire.vasc.backend.VascEntryFieldValue; import net.forwardfire.vasc.backend.VascEntryFieldValue;
import net.forwardfire.vasc.backend.VascEntryRecordCreator; import net.forwardfire.vasc.backend.VascEntryRecordCreator;
import net.forwardfire.vasc.backend.data.MapVascEntryFieldValue; import net.forwardfire.vasc.backend.data.HashMapVascEntryFieldValue;
import net.forwardfire.vasc.backend.data.MapVascEntryRecordCreator; import net.forwardfire.vasc.backend.data.HashMapVascEntryRecordCreator;
import net.forwardfire.vasc.xpql.query.QueryParameterValue; import net.forwardfire.vasc.xpql.query.QueryParameterValue;
/** /**
* JdbcVascBackendXpql jdbc vasc backend with xpql query support. * JdbcVascBackendXpql jdbc vasc backend with xpql query support.
* *
* @author Willem Cazander * @author Willem Cazander
* @version 1.0 Sep 5, 2008 * @version 1.0 Sep 5, 2008
*/ */
public class JdbcVascBackendXpql extends AbstractVascBackend { public class JdbcVascBackendXpql extends AbstractVascBackend<HashMap<String,Object>> {
private JdbcConnectionProvider jdbcConnectionProvider = null; private JdbcConnectionProvider jdbcConnectionProvider = null;
@ -92,7 +90,7 @@ public class JdbcVascBackendXpql extends AbstractVascBackend {
/** /**
* @see net.forwardfire.vasc.backend.VascBackend#execute(VascBackendState state) * @see net.forwardfire.vasc.backend.VascBackend#execute(VascBackendState state)
*/ */
public List<Object> execute(VascBackendState state) throws VascBackendException { public List<HashMap<String,Object>> execute(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);
@ -112,9 +110,9 @@ public class JdbcVascBackendXpql extends AbstractVascBackend {
q.execute(); q.execute();
ResultSet rs = q.getResultSet(); ResultSet rs = q.getResultSet();
int cols = rs.getMetaData().getColumnCount(); int cols = rs.getMetaData().getColumnCount();
List<Object> result = new ArrayList<Object>(50); List<HashMap<String,Object>> result = new ArrayList<HashMap<String,Object>>(50);
while (rs.next()) { while (rs.next()) {
Map<String,Object> map = new HashMap<String,Object>(cols); HashMap<String,Object> map = new HashMap<String,Object>(cols);
for (int i=1;i<=cols;i++) { for (int i=1;i<=cols;i++) {
String columnName = rs.getMetaData().getColumnName(i); String columnName = rs.getMetaData().getColumnName(i);
Object columnObject = rs.getObject(i); Object columnObject = rs.getObject(i);
@ -123,7 +121,7 @@ public class JdbcVascBackendXpql extends AbstractVascBackend {
result.add(map); result.add(map);
} }
return result; return result;
} catch (Exception e) { } catch (SQLException e) {
throw new VascBackendException(e); throw new VascBackendException(e);
} finally { } finally {
if (c!=null) { if (c!=null) {
@ -138,33 +136,33 @@ public class JdbcVascBackendXpql extends AbstractVascBackend {
/** /**
* @see net.forwardfire.vasc.backend.VascBackend#merge(java.lang.Object) * @see net.forwardfire.vasc.backend.VascBackend#merge(java.lang.Object)
*/ */
public Object merge(Object object) throws VascBackendException { public HashMap<String,Object> merge(HashMap<String,Object> object) throws VascBackendException {
return object; return object;
} }
/** /**
* @see net.forwardfire.vasc.backend.VascBackend#persist(java.lang.Object) * @see net.forwardfire.vasc.backend.VascBackend#persist(java.lang.Object)
*/ */
public void persist(Object object) throws VascBackendException { public void persist(HashMap<String,Object> object) throws VascBackendException {
} }
/** /**
* @see net.forwardfire.vasc.backend.VascBackend#delete(java.lang.Object) * @see net.forwardfire.vasc.backend.VascBackend#delete(java.lang.Object)
*/ */
public void delete(Object object) throws VascBackendException { public void delete(HashMap<String,Object> object) throws VascBackendException {
} }
/** /**
* @see net.forwardfire.vasc.backend.VascBackend#provideVascEntryFieldValue() * @see net.forwardfire.vasc.backend.VascBackend#provideVascEntryFieldValue()
*/ */
public VascEntryFieldValue provideVascEntryFieldValue() { public VascEntryFieldValue provideVascEntryFieldValue() {
return new MapVascEntryFieldValue(); return new HashMapVascEntryFieldValue();
} }
/** /**
* @see net.forwardfire.vasc.backend.VascBackend#provideVascEntryRecordCreator() * @see net.forwardfire.vasc.backend.VascBackend#provideVascEntryRecordCreator()
*/ */
public VascEntryRecordCreator provideVascEntryRecordCreator() { public VascEntryRecordCreator provideVascEntryRecordCreator() {
return new MapVascEntryRecordCreator(); return new HashMapVascEntryRecordCreator();
} }
} }

View file

@ -22,6 +22,8 @@
package net.forwardfire.vasc.backends.jpa; package net.forwardfire.vasc.backends.jpa;
import java.io.Serializable;
import net.forwardfire.vasc.backend.AbstractVascBackend; import net.forwardfire.vasc.backend.AbstractVascBackend;
import net.forwardfire.vasc.backend.VascBackendException; import net.forwardfire.vasc.backend.VascBackendException;
@ -33,7 +35,7 @@ import org.hibernate.Session;
* @author Willem Cazander * @author Willem Cazander
* @version 1.0 Mar 21, 2007 * @version 1.0 Mar 21, 2007
*/ */
abstract public class AbstractHibernateVascBackend extends AbstractVascBackend { abstract public class AbstractHibernateVascBackend<DATA_OBJECT extends Serializable> extends AbstractVascBackend<DATA_OBJECT> {
/** /**
* Provides a hibernate session which is closed !! when transaction is compleeted. * Provides a hibernate session which is closed !! when transaction is compleeted.
@ -41,7 +43,7 @@ abstract public class AbstractHibernateVascBackend extends AbstractVascBackend
*/ */
abstract Session getHibernateSession(); abstract Session getHibernateSession();
public void persist(Object object) throws VascBackendException { public void persist(DATA_OBJECT object) throws VascBackendException {
Session s = getHibernateSession(); Session s = getHibernateSession();
try { try {
s.getTransaction().begin(); s.getTransaction().begin();
@ -57,11 +59,11 @@ abstract public class AbstractHibernateVascBackend extends AbstractVascBackend
} }
} }
public Object merge(Object object) throws VascBackendException { public DATA_OBJECT merge(DATA_OBJECT object) throws VascBackendException {
Session s = getHibernateSession(); Session s = getHibernateSession();
try { try {
s.getTransaction().begin(); s.getTransaction().begin();
Object result = s.merge(object); DATA_OBJECT result = (DATA_OBJECT)s.merge(object);
s.getTransaction().commit(); s.getTransaction().commit();
return result; return result;
} finally { } finally {
@ -74,7 +76,7 @@ abstract public class AbstractHibernateVascBackend extends AbstractVascBackend
} }
} }
public void delete(Object object) throws VascBackendException { public void delete(DATA_OBJECT object) throws VascBackendException {
Session s = getHibernateSession(); Session s = getHibernateSession();
try { try {
s.getTransaction().begin(); s.getTransaction().begin();

View file

@ -22,6 +22,8 @@
package net.forwardfire.vasc.backends.jpa; package net.forwardfire.vasc.backends.jpa;
import java.io.Serializable;
import javax.persistence.EntityManager; import javax.persistence.EntityManager;
import net.forwardfire.vasc.backend.AbstractVascBackend; import net.forwardfire.vasc.backend.AbstractVascBackend;
@ -32,13 +34,13 @@ import net.forwardfire.vasc.backend.VascBackendException;
* @author Willem Cazander * @author Willem Cazander
* @version 1.0 Mar 21, 2007 * @version 1.0 Mar 21, 2007
*/ */
abstract public class AbstractPersistenceVascBackend extends AbstractVascBackend { abstract public class AbstractPersistenceVascBackend<DATA_OBJECT extends Serializable> extends AbstractVascBackend<DATA_OBJECT> {
protected boolean emTransaction = true; protected boolean emTransaction = true;
abstract EntityManager getEntityManager(); abstract EntityManager getEntityManager();
public void persist(Object object) throws VascBackendException { public void persist(DATA_OBJECT object) throws VascBackendException {
EntityManager s = getEntityManager(); EntityManager s = getEntityManager();
try { try {
if (emTransaction) { if (emTransaction) {
@ -55,13 +57,13 @@ abstract public class AbstractPersistenceVascBackend extends AbstractVascBackend
} }
} }
public Object merge(Object object) throws VascBackendException { public DATA_OBJECT merge(DATA_OBJECT object) throws VascBackendException {
EntityManager s = getEntityManager(); EntityManager s = getEntityManager();
try { try {
if (emTransaction) { if (emTransaction) {
s.getTransaction().begin(); s.getTransaction().begin();
} }
Object result = s.merge(object); DATA_OBJECT result = (DATA_OBJECT)s.merge(object);
if (emTransaction) { if (emTransaction) {
s.getTransaction().commit(); s.getTransaction().commit();
} }
@ -73,7 +75,7 @@ abstract public class AbstractPersistenceVascBackend extends AbstractVascBackend
} }
} }
public void delete(Object object) throws VascBackendException { public void delete(DATA_OBJECT object) throws VascBackendException {
EntityManager s = getEntityManager(); EntityManager s = getEntityManager();
try { try {
if (emTransaction) { if (emTransaction) {

View file

@ -22,6 +22,7 @@
package net.forwardfire.vasc.backends.jpa; package net.forwardfire.vasc.backends.jpa;
import java.io.Serializable;
import java.util.List; import java.util.List;
import net.forwardfire.vasc.backend.VascBackendException; import net.forwardfire.vasc.backend.VascBackendException;
@ -43,7 +44,7 @@ import org.hibernate.Session;
* @author Willem Cazander * @author Willem Cazander
* @version 1.0 Mar 17, 2009 * @version 1.0 Mar 17, 2009
*/ */
public class XpqlHibernateVascBackend extends AbstractHibernateVascBackend { public class XpqlHibernateVascBackend<DATA_OBJECT extends Serializable> extends AbstractHibernateVascBackend<DATA_OBJECT> {
private HibernateSessionProvider hibernateSessionProvider = null; private HibernateSessionProvider hibernateSessionProvider = null;
@ -73,7 +74,7 @@ public class XpqlHibernateVascBackend extends AbstractHibernateVascBackend {
} }
@SuppressWarnings("unchecked") @SuppressWarnings("unchecked")
public List<Object> execute(VascBackendState state) throws VascBackendException { public List<DATA_OBJECT> execute(VascBackendState state) throws VascBackendException {
// Copy parameters // Copy parameters
for (String key:state.getDataParameterKeys()) { for (String key:state.getDataParameterKeys()) {
@ -103,7 +104,7 @@ public class XpqlHibernateVascBackend extends AbstractHibernateVascBackend {
q.setFirstResult(state.getPageIndex()*state.getPageSize()); q.setFirstResult(state.getPageIndex()*state.getPageSize());
q.setMaxResults(state.getPageSize()); q.setMaxResults(state.getPageSize());
} }
List<Object> data = q.list(); List<DATA_OBJECT> data = q.list();
s.getTransaction().commit(); s.getTransaction().commit();
return data; return data;
} finally { } finally {

View file

@ -22,6 +22,7 @@
package net.forwardfire.vasc.backends.jpa; package net.forwardfire.vasc.backends.jpa;
import java.io.Serializable;
import java.util.List; import java.util.List;
import javax.persistence.EntityManager; import javax.persistence.EntityManager;
@ -43,7 +44,7 @@ import net.forwardfire.vasc.xpql.query.QueryParameterValue;
* @author Willem Cazander * @author Willem Cazander
* @version 1.0 Mar 17, 2009 * @version 1.0 Mar 17, 2009
*/ */
public class XpqlPersistanceVascBackend extends AbstractPersistenceVascBackend { public class XpqlPersistanceVascBackend<DATA_OBJECT extends Serializable> extends AbstractPersistenceVascBackend<DATA_OBJECT> {
private EntityManagerProvider entityManagerProvider = null; private EntityManagerProvider entityManagerProvider = null;
@ -76,7 +77,7 @@ public class XpqlPersistanceVascBackend extends AbstractPersistenceVascBackend
@SuppressWarnings("unchecked") @SuppressWarnings("unchecked")
public List<Object> execute(VascBackendState state) throws VascBackendException { public List<DATA_OBJECT> execute(VascBackendState state) throws VascBackendException {
// Copy parameters // Copy parameters
for (String key:state.getDataParameterKeys()) { for (String key:state.getDataParameterKeys()) {
@ -106,7 +107,7 @@ public class XpqlPersistanceVascBackend extends AbstractPersistenceVascBackend
if (emTransaction) { if (emTransaction) {
em.getTransaction().begin(); em.getTransaction().begin();
} }
List<Object> data = q.getResultList(); List<DATA_OBJECT> data = q.getResultList();
if (emTransaction) { if (emTransaction) {
em.getTransaction().commit(); em.getTransaction().commit();
} }

View file

@ -34,8 +34,8 @@ import net.forwardfire.vasc.backend.VascBackendException;
import net.forwardfire.vasc.backend.VascBackendState; import net.forwardfire.vasc.backend.VascBackendState;
import net.forwardfire.vasc.backend.VascEntryFieldValue; import net.forwardfire.vasc.backend.VascEntryFieldValue;
import net.forwardfire.vasc.backend.VascEntryRecordCreator; import net.forwardfire.vasc.backend.VascEntryRecordCreator;
import net.forwardfire.vasc.backend.data.MapVascEntryFieldValue; import net.forwardfire.vasc.backend.data.HashMapVascEntryFieldValue;
import net.forwardfire.vasc.backend.data.MapVascEntryRecordCreator; import net.forwardfire.vasc.backend.data.HashMapVascEntryRecordCreator;
import com.novell.ldap.LDAPAttribute; import com.novell.ldap.LDAPAttribute;
import com.novell.ldap.LDAPAttributeSet; import com.novell.ldap.LDAPAttributeSet;
@ -52,7 +52,7 @@ import com.novell.ldap.LDAPSearchResults;
* @author Willem Cazander * @author Willem Cazander
* @version 1.0 Sep 4, 2008 * @version 1.0 Sep 4, 2008
*/ */
public class LdapVascBackend extends AbstractVascBackend { public class LdapVascBackend extends AbstractVascBackend<HashMap<String,Object>> {
private Logger logger = Logger.getLogger(LdapVascBackend.class.getName()); private Logger logger = Logger.getLogger(LdapVascBackend.class.getName());
private LdapConnectionProvider ldapConnectionProvider = null; private LdapConnectionProvider ldapConnectionProvider = null;
@ -80,10 +80,10 @@ public class LdapVascBackend extends AbstractVascBackend {
/** /**
* @see net.forwardfire.vasc.backend.VascBackend#execute() * @see net.forwardfire.vasc.backend.VascBackend#execute()
*/ */
public List<Object> execute(VascBackendState state) throws VascBackendException { public List<HashMap<String,Object>> execute(VascBackendState state) throws VascBackendException {
LdapConnectionProvider prov = getLdapConnectionProvider(); LdapConnectionProvider prov = getLdapConnectionProvider();
LDAPConnection connection = prov.getLdapConnection(); LDAPConnection connection = prov.getLdapConnection();
List<Object> result = new ArrayList<Object>(50); List<HashMap<String,Object>> result = new ArrayList<HashMap<String,Object>>(50);
try { try {
LDAPSearchConstraints cons = new LDAPSearchConstraints(); LDAPSearchConstraints cons = new LDAPSearchConstraints();
@ -104,7 +104,7 @@ public class LdapVascBackend extends AbstractVascBackend {
while (searchResults.hasMore()) { while (searchResults.hasMore()) {
LDAPEntry entry = searchResults.next(); LDAPEntry entry = searchResults.next();
Map<String,Object> map = new HashMap<String,Object>(10); HashMap<String,Object> map = new HashMap<String,Object>(10);
LDAPAttributeSet attributeSet = entry.getAttributeSet(); LDAPAttributeSet attributeSet = entry.getAttributeSet();
Iterator<LDAPAttribute> i = attributeSet.iterator(); Iterator<LDAPAttribute> i = attributeSet.iterator();
@ -134,11 +134,10 @@ public class LdapVascBackend extends AbstractVascBackend {
/** /**
* @see net.forwardfire.vasc.backend.VascBackend#merge(java.lang.Object) * @see net.forwardfire.vasc.backend.VascBackend#merge(java.lang.Object)
*/ */
public Object merge(Object object) throws VascBackendException { public HashMap<String,Object> merge(HashMap<String,Object> map) throws VascBackendException {
LdapConnectionProvider prov = getLdapConnectionProvider(); LdapConnectionProvider prov = getLdapConnectionProvider();
LDAPConnection connection = prov.getLdapConnection(); LDAPConnection connection = prov.getLdapConnection();
try { try {
Map<String,Object> map = (Map)object;
String keyValue = (String)map.get(keyAttribute); String keyValue = (String)map.get(keyAttribute);
LDAPSearchConstraints cons = new LDAPSearchConstraints(); LDAPSearchConstraints cons = new LDAPSearchConstraints();
cons.setBatchSize( 0 ); cons.setBatchSize( 0 );
@ -157,7 +156,7 @@ public class LdapVascBackend extends AbstractVascBackend {
if (searchResults.hasMore()==false) { if (searchResults.hasMore()==false) {
// no result to mod // no result to mod
return object; return map;
} }
LDAPEntry entry = searchResults.next(); LDAPEntry entry = searchResults.next();
List<LDAPModification> mods = new ArrayList<LDAPModification>(20); List<LDAPModification> mods = new ArrayList<LDAPModification>(20);
@ -204,7 +203,7 @@ public class LdapVascBackend extends AbstractVascBackend {
m = mods.toArray(m); m = mods.toArray(m);
connection.modify(entry.getDN(), m); connection.modify(entry.getDN(), m);
return object; return map;
} catch (LDAPException e) { } catch (LDAPException e) {
throw new VascBackendException(e); throw new VascBackendException(e);
} finally { } finally {
@ -215,8 +214,7 @@ public class LdapVascBackend extends AbstractVascBackend {
/** /**
* @see net.forwardfire.vasc.backend.VascBackend#persist(java.lang.Object) * @see net.forwardfire.vasc.backend.VascBackend#persist(java.lang.Object)
*/ */
public void persist(Object object) throws VascBackendException { public void persist(HashMap<String,Object> map) throws VascBackendException {
Map<String,Object> map = (Map)object;
LdapConnectionProvider prov = getLdapConnectionProvider(); LdapConnectionProvider prov = getLdapConnectionProvider();
LDAPConnection connection = prov.getLdapConnection(); LDAPConnection connection = prov.getLdapConnection();
try { try {
@ -250,11 +248,10 @@ public class LdapVascBackend extends AbstractVascBackend {
/** /**
* @see net.forwardfire.vasc.backend.VascBackend#delete(java.lang.Object) * @see net.forwardfire.vasc.backend.VascBackend#delete(java.lang.Object)
*/ */
public void delete(Object object) throws VascBackendException { public void delete(HashMap<String,Object> map) throws VascBackendException {
LdapConnectionProvider prov = getLdapConnectionProvider(); LdapConnectionProvider prov = getLdapConnectionProvider();
LDAPConnection connection = prov.getLdapConnection(); LDAPConnection connection = prov.getLdapConnection();
try { try {
Map<String,Object> map = (Map)object;
String keyValue = (String)map.get(keyAttribute); String keyValue = (String)map.get(keyAttribute);
int searchScope = LDAPConnection.SCOPE_ONE; int searchScope = LDAPConnection.SCOPE_ONE;
String searchBase = baseDN; String searchBase = baseDN;
@ -294,14 +291,14 @@ public class LdapVascBackend extends AbstractVascBackend {
* @see net.forwardfire.vasc.backend.VascBackend#provideVascEntryRecordCreator() * @see net.forwardfire.vasc.backend.VascBackend#provideVascEntryRecordCreator()
*/ */
public VascEntryRecordCreator provideVascEntryRecordCreator() { public VascEntryRecordCreator provideVascEntryRecordCreator() {
return new MapVascEntryRecordCreator(); return new HashMapVascEntryRecordCreator();
} }
/** /**
* @see net.forwardfire.vasc.backend.VascBackend#provideVascEntryFieldValue() * @see net.forwardfire.vasc.backend.VascBackend#provideVascEntryFieldValue()
*/ */
public VascEntryFieldValue provideVascEntryFieldValue() { public VascEntryFieldValue provideVascEntryFieldValue() {
return new MapVascEntryFieldValue(); return new HashMapVascEntryFieldValue();
} }
/** /**

View file

@ -58,7 +58,7 @@ import net.forwardfire.vasc.backend.metamodel.crud.UpdateableRowMapImpl;
* @author Willem Cazander * @author Willem Cazander
* @version 1.0 Dec 31, 2011 * @version 1.0 Dec 31, 2011
*/ */
public class MetaModelVascBackend extends AbstractVascBackend { public class MetaModelVascBackend extends AbstractVascBackend<Row> {
private Logger logger = Logger.getLogger(MetaModelVascBackend.class.getName()); private Logger logger = Logger.getLogger(MetaModelVascBackend.class.getName());
private MetaModelDataContextProvider dataContextProvider = null; private MetaModelDataContextProvider dataContextProvider = null;
@ -210,7 +210,7 @@ public class MetaModelVascBackend extends AbstractVascBackend {
return q; return q;
} }
public List<Object> execute(VascBackendState state) throws VascBackendException { public List<Row> execute(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) {
@ -236,16 +236,15 @@ public class MetaModelVascBackend extends AbstractVascBackend {
} }
q.setMaxRows(state.getPageSize()); q.setMaxRows(state.getPageSize());
} }
List<Row> result = new ArrayList<Row>(50);
if (crudDataContext!=null) { if (crudDataContext!=null) {
DataSet ds = crudDataContext.executeQuery(q); DataSet ds = crudDataContext.executeQuery(q);
List<Object> result = new ArrayList<Object>(50);
result.addAll(ds.toRows()); result.addAll(ds.toRows());
ds.close(); ds.close();
return result; return result;
} }
DataSet ds = dataContext.executeQuery(q); DataSet ds = dataContext.executeQuery(q);
List<Object> result = new ArrayList<Object>(50);
while (ds.next()) { while (ds.next()) {
Row row = ds.getRow(); Row row = ds.getRow();
SelectItem[] cols = row.getSelectItems(); SelectItem[] cols = row.getSelectItems();
@ -263,21 +262,21 @@ public class MetaModelVascBackend extends AbstractVascBackend {
return result; return result;
} }
public void persist(Object object) throws VascBackendException { public void persist(Row object) throws VascBackendException {
if (crudDataContext==null) { if (crudDataContext==null) {
return; return;
} }
crudDataContext.persist((UpdateableRow) object); crudDataContext.persist((UpdateableRow) object);
} }
public Object merge(Object object) throws VascBackendException { public Row merge(Row object) throws VascBackendException {
if (crudDataContext==null) { if (crudDataContext==null) {
return object; return object;
} }
return crudDataContext.merge((UpdateableRow) object); return crudDataContext.merge((UpdateableRow) object);
} }
public void delete(Object object) throws VascBackendException { public void delete(Row object) throws VascBackendException {
if (crudDataContext==null) { if (crudDataContext==null) {
return; return;
} }
@ -288,7 +287,7 @@ public class MetaModelVascBackend extends AbstractVascBackend {
return new RowVascEntryFieldValue(); return new RowVascEntryFieldValue();
} }
public VascEntryRecordCreator provideVascEntryRecordCreator() { public VascEntryRecordCreator<Row> provideVascEntryRecordCreator() {
return new RowVascEntryRecordCreator(crudDataContext,crudDataContext.getDefaultSchema().getTableByName(table)); return new RowVascEntryRecordCreator(crudDataContext,crudDataContext.getDefaultSchema().getTableByName(table));
} }

View file

@ -1,13 +1,13 @@
package net.forwardfire.vasc.backend.metamodel; package net.forwardfire.vasc.backend.metamodel;
import org.eobjects.metamodel.data.Row;
import org.eobjects.metamodel.schema.Table; import org.eobjects.metamodel.schema.Table;
import net.forwardfire.vasc.backend.VascBackendException; import net.forwardfire.vasc.backend.VascBackendException;
import net.forwardfire.vasc.backend.VascEntryRecordCreator; import net.forwardfire.vasc.backend.VascEntryRecordCreator;
import net.forwardfire.vasc.backend.metamodel.crud.CrudDataContext; import net.forwardfire.vasc.backend.metamodel.crud.CrudDataContext;
import net.forwardfire.vasc.backend.metamodel.crud.UpdateableRow;
public class RowVascEntryRecordCreator implements VascEntryRecordCreator { public class RowVascEntryRecordCreator implements VascEntryRecordCreator<Row> {
private static final long serialVersionUID = -1182678362367989090L; private static final long serialVersionUID = -1182678362367989090L;
private CrudDataContext dataContext = null; private CrudDataContext dataContext = null;
@ -18,11 +18,7 @@ public class RowVascEntryRecordCreator implements VascEntryRecordCreator {
this.table=table; this.table=table;
} }
public Class<?> getObjectClass() { public Row newRecord() throws VascBackendException {
return UpdateableRow.class;
}
public Object newRecord() throws VascBackendException {
return dataContext.createRow(table); return dataContext.createRow(table);
} }
} }

View file

@ -48,6 +48,9 @@ abstract public class AbstractCrudDataContext implements CrudDataContext {
RowInsertionBuilder query = backendImpl.insertInto(row.getTable()); RowInsertionBuilder query = backendImpl.insertInto(row.getTable());
for (int i=0;i<row.size();i++) { for (int i=0;i<row.size();i++) {
SelectItem si = row.getSelectItem(i); SelectItem si = row.getSelectItem(i);
if (si.getColumn().isPrimaryKey()) {
continue; // insert null will only work with correct default sequence attacted to column.
}
Object value = row.getValue(i); Object value = row.getValue(i);
query.value(si.getColumn(), value); query.value(si.getColumn(), value);
} }
@ -56,7 +59,7 @@ abstract public class AbstractCrudDataContext implements CrudDataContext {
}); });
} }
public Object merge(final UpdateableRow row) { public UpdateableRow merge(final UpdateableRow row) {
for (String column:row.getPrimaryKeys()) { for (String column:row.getPrimaryKeys()) {
if (row.getValue(column)==null) { if (row.getValue(column)==null) {
throw new IllegalStateException("Can't update row where primary key: "+column+" value is null."); throw new IllegalStateException("Can't update row where primary key: "+column+" value is null.");

View file

@ -26,7 +26,7 @@ public interface CrudDataContext extends UpdateableDataContext {
/** /**
* Merges row with table. * Merges row with table.
*/ */
public Object merge(UpdateableRow row); public UpdateableRow merge(UpdateableRow row);
/** /**
* Deletes row from table. * Deletes row from table.

View file

@ -46,7 +46,7 @@ import com.mongodb.WriteResult;
* @author Willem Cazander * @author Willem Cazander
* @version 1.0 Dec 30, 2011 * @version 1.0 Dec 30, 2011
*/ */
public class MongodbVascBackend extends AbstractVascBackend { public class MongodbVascBackend extends AbstractVascBackend<BasicDBObject> {
private Logger logger = null; private Logger logger = null;
private MongodbConnectionProvider connectionProvider = null; private MongodbConnectionProvider connectionProvider = null;
@ -105,7 +105,7 @@ public class MongodbVascBackend extends AbstractVascBackend {
return query; return query;
} }
public List<Object> execute(VascBackendState state) throws VascBackendException { public List<BasicDBObject> execute(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);
@ -113,33 +113,32 @@ public class MongodbVascBackend extends AbstractVascBackend {
cur.limit(state.getPageSize()); cur.limit(state.getPageSize());
cur.skip(state.getPageIndex()); cur.skip(state.getPageIndex());
} }
List<Object> result = new ArrayList<Object>(cur.count()); List<BasicDBObject> result = new ArrayList<BasicDBObject>(cur.count());
while (cur.hasNext()) { while (cur.hasNext()) {
DBObject row = cur.next(); DBObject row = cur.next();
result.add(row); result.add((BasicDBObject)row);
} }
return result; return result;
} }
public void persist(Object object) throws VascBackendException { public void persist(BasicDBObject object) throws VascBackendException {
DBCollection coll = getDBCollection(); DBCollection coll = getDBCollection();
coll.insert((DBObject)object); coll.insert(object);
} }
public Object merge(Object object) throws VascBackendException { public BasicDBObject merge(BasicDBObject row) throws VascBackendException {
DBCollection coll = getDBCollection(); DBCollection coll = getDBCollection();
DBObject row = (DBObject)object;
DBObject query = new BasicDBObject(); DBObject query = new BasicDBObject();
query.put("_id",row.get("_id")); query.put("_id",row.get("_id"));
WriteResult wr = coll.update(query,row,false,false,WriteConcern.SAFE); WriteResult wr = coll.update(query,row,false,false,WriteConcern.SAFE);
logger.info("WriteResult: "+wr); logger.info("WriteResult: "+wr);
return object; return row;
} }
public void delete(Object object) throws VascBackendException { public void delete(BasicDBObject object) throws VascBackendException {
DBCollection coll = getDBCollection(); DBCollection coll = getDBCollection();
DBObject query = new BasicDBObject(); DBObject query = new BasicDBObject();
query.put("_id",((DBObject)object).get("_id")); query.put("_id",object.get("_id"));
coll.remove(query); // remove by _id coll.remove(query); // remove by _id
} }
@ -147,7 +146,7 @@ public class MongodbVascBackend extends AbstractVascBackend {
return new MongodbVascEntryFieldValue(); return new MongodbVascEntryFieldValue();
} }
public VascEntryRecordCreator provideVascEntryRecordCreator() { public VascEntryRecordCreator<BasicDBObject> provideVascEntryRecordCreator() {
return new MongodbVascEntryRecordCreator(); return new MongodbVascEntryRecordCreator();
} }

View file

@ -34,15 +34,11 @@ import com.mongodb.BasicDBObject;
* @author Willem Cazander * @author Willem Cazander
* @version 1.0 Dec 30, 2011 * @version 1.0 Dec 30, 2011
*/ */
public class MongodbVascEntryRecordCreator implements VascEntryRecordCreator { public class MongodbVascEntryRecordCreator implements VascEntryRecordCreator<BasicDBObject> {
private static final long serialVersionUID = -9213830731796787384L; private static final long serialVersionUID = -9213830731796787384L;
public Object newRecord() throws VascBackendException { public BasicDBObject newRecord() throws VascBackendException {
return new BasicDBObject(); return new BasicDBObject();
} }
public Class<?> getObjectClass() {
return BasicDBObject.class;
}
} }

View file

@ -22,6 +22,7 @@
package net.forwardfire.vasc.ejb3; package net.forwardfire.vasc.ejb3;
import java.io.Serializable;
import java.util.List; import java.util.List;
import java.util.Map; import java.util.Map;
@ -37,7 +38,7 @@ import net.forwardfire.vasc.backend.VascEntryRecordCreator;
* @author Willem Cazander * @author Willem Cazander
* @version 1.0 18 Nov 2012 * @version 1.0 18 Nov 2012
*/ */
public class VascServiceRemoteBackend implements VascBackend { public class VascServiceRemoteBackend<DATA_OBJECT extends Serializable> implements VascBackend<DATA_OBJECT> {
private String backendId = null; private String backendId = null;
private VascServiceManager vascManager = null; private VascServiceManager vascManager = null;
@ -66,7 +67,7 @@ public class VascServiceRemoteBackend implements VascBackend {
// we cant change id // we cant change id
} }
public void delete(Object object) throws VascBackendException { public void delete(DATA_OBJECT object) throws VascBackendException {
Object[] args = new Object[1]; Object[] args = new Object[1];
args[0]=object; args[0]=object;
vascManager.invokeBackendMethod(backendId, "delete", args); vascManager.invokeBackendMethod(backendId, "delete", args);
@ -89,11 +90,11 @@ public class VascServiceRemoteBackend implements VascBackend {
} }
@SuppressWarnings("unchecked") @SuppressWarnings("unchecked")
public List<Object> execute(VascBackendState state) throws VascBackendException { public List<DATA_OBJECT> execute(VascBackendState state) throws VascBackendException {
Object[] args = new Object[1]; Object[] args = new Object[1];
args[0]=state; args[0]=state;
Object result = vascManager.invokeBackendMethod(backendId, "execute", args); Object result = vascManager.invokeBackendMethod(backendId, "execute", args);
return (List<Object>)result; return (List<DATA_OBJECT>)result;
} }
public long fetchTotalExecuteSize(VascBackendState state) { public long fetchTotalExecuteSize(VascBackendState state) {
@ -127,14 +128,15 @@ public class VascServiceRemoteBackend implements VascBackend {
return (Boolean)result; return (Boolean)result;
} }
public Object merge(Object object) throws VascBackendException { @SuppressWarnings("unchecked")
public DATA_OBJECT merge(DATA_OBJECT object) throws VascBackendException {
Object[] args = new Object[1]; Object[] args = new Object[1];
args[0]=object; args[0]=object;
Object result = vascManager.invokeBackendMethod(backendId, "merge", args); Object result = vascManager.invokeBackendMethod(backendId, "merge", args);
return result; return (DATA_OBJECT)result;
} }
public void persist(Object object) throws VascBackendException { public void persist(DATA_OBJECT object) throws VascBackendException {
Object[] args = new Object[1]; Object[] args = new Object[1];
args[0]=object; args[0]=object;
vascManager.invokeBackendMethod(backendId, "delete", args); vascManager.invokeBackendMethod(backendId, "delete", args);

View file

@ -22,6 +22,7 @@
package net.forwardfire.vasc.backend.proxy; package net.forwardfire.vasc.backend.proxy;
import java.io.Serializable;
import java.util.List; import java.util.List;
import java.util.Map; import java.util.Map;
@ -40,7 +41,7 @@ import net.forwardfire.vasc.core.VascEntry;
*/ */
abstract public class AbstractVascBackendProxy implements VascBackendProxy { abstract public class AbstractVascBackendProxy implements VascBackendProxy {
protected VascBackend backend = null; protected VascBackend<Serializable> backend = null;
protected VascEntry entry = null; protected VascEntry entry = null;
abstract public VascBackendProxy clone() throws CloneNotSupportedException; abstract public VascBackendProxy clone() throws CloneNotSupportedException;
@ -48,7 +49,7 @@ abstract public class AbstractVascBackendProxy implements VascBackendProxy {
/** /**
* @see net.forwardfire.vasc.backend.proxy.VascBackendProxy#initProxy(net.forwardfire.vasc.backend.VascBackend, net.forwardfire.vasc.core.VascEntry) * @see net.forwardfire.vasc.backend.proxy.VascBackendProxy#initProxy(net.forwardfire.vasc.backend.VascBackend, net.forwardfire.vasc.core.VascEntry)
*/ */
public void initProxy(VascBackend backend, VascEntry entry) { public void initProxy(VascBackend<Serializable> backend, VascEntry entry) {
if (backend==null) { if (backend==null) {
throw new NullPointerException("backend object may not be null."); throw new NullPointerException("backend object may not be null.");
} }
@ -105,14 +106,14 @@ abstract public class AbstractVascBackendProxy implements VascBackendProxy {
* @throws Exception * @throws Exception
* @see net.forwardfire.vasc.backend.VascBackend#execute(VascBackendState state) * @see net.forwardfire.vasc.backend.VascBackend#execute(VascBackendState state)
*/ */
public List<Object> execute(VascBackendState state) throws VascBackendException { public List<Serializable> execute(VascBackendState state) throws VascBackendException {
return backend.execute(state); return backend.execute(state);
} }
/** /**
* @see net.forwardfire.vasc.backend.VascBackend#delete(java.lang.Object) * @see net.forwardfire.vasc.backend.VascBackend#delete(java.lang.Object)
*/ */
public void delete(Object object) throws VascBackendException { public void delete(Serializable object) throws VascBackendException {
backend.delete(object); backend.delete(object);
} }
@ -133,14 +134,14 @@ abstract public class AbstractVascBackendProxy implements VascBackendProxy {
/** /**
* @see net.forwardfire.vasc.backend.VascBackend#merge(java.lang.Object) * @see net.forwardfire.vasc.backend.VascBackend#merge(java.lang.Object)
*/ */
public Object merge(Object object) throws VascBackendException { public Serializable merge(Serializable object) throws VascBackendException {
return backend.merge(object); return backend.merge(object);
} }
/** /**
* @see net.forwardfire.vasc.backend.VascBackend#persist(java.lang.Object) * @see net.forwardfire.vasc.backend.VascBackend#persist(java.lang.Object)
*/ */
public void persist(Object object) throws VascBackendException { public void persist(Serializable object) throws VascBackendException {
backend.persist(object); backend.persist(object);
} }
@ -154,7 +155,7 @@ abstract public class AbstractVascBackendProxy implements VascBackendProxy {
/** /**
* @see net.forwardfire.vasc.backend.VascBackend#provideVascEntryRecordCreator() * @see net.forwardfire.vasc.backend.VascBackend#provideVascEntryRecordCreator()
*/ */
public VascEntryRecordCreator provideVascEntryRecordCreator() { public VascEntryRecordCreator<Serializable> provideVascEntryRecordCreator() {
return backend.provideVascEntryRecordCreator(); return backend.provideVascEntryRecordCreator();
} }

View file

@ -22,6 +22,8 @@
package net.forwardfire.vasc.backend.proxy; package net.forwardfire.vasc.backend.proxy;
import java.io.Serializable;
import net.forwardfire.vasc.backend.VascBackend; import net.forwardfire.vasc.backend.VascBackend;
import net.forwardfire.vasc.core.VascEntry; import net.forwardfire.vasc.core.VascEntry;
@ -31,9 +33,9 @@ import net.forwardfire.vasc.core.VascEntry;
* @author Willem Cazander * @author Willem Cazander
* @version 1.0 May 9, 2012 * @version 1.0 May 9, 2012
*/ */
public interface VascBackendProxy extends VascBackend,Cloneable { public interface VascBackendProxy extends VascBackend<Serializable>,Cloneable {
public void initProxy(VascBackend backend,VascEntry entry); public void initProxy(VascBackend<Serializable> backend,VascEntry entry);
public boolean isProxyNeeded(); public boolean isProxyNeeded();

View file

@ -22,6 +22,7 @@
package net.forwardfire.vasc.backend.proxy; package net.forwardfire.vasc.backend.proxy;
import java.io.Serializable;
import java.util.HashMap; import java.util.HashMap;
import java.util.List; import java.util.List;
import java.util.Map; import java.util.Map;
@ -38,7 +39,7 @@ import net.forwardfire.vasc.backend.VascBackendState;
public class VascBackendProxyCache extends AbstractVascBackendProxy { public class VascBackendProxyCache extends AbstractVascBackendProxy {
private Long records = null; private Long records = null;
private List<Object> data = null; private List<Serializable> data = null;
private String searchString = null; private String searchString = null;
private Map<String,Object> dataState = null; private Map<String,Object> dataState = null;
private int pageIndex = 0; private int pageIndex = 0;
@ -130,7 +131,7 @@ public class VascBackendProxyCache extends AbstractVascBackendProxy {
* @see net.forwardfire.vasc.backend.VascBackend#execute(VascBackendState state) * @see net.forwardfire.vasc.backend.VascBackend#execute(VascBackendState state)
*/ */
@Override @Override
public List<Object> execute(VascBackendState state) throws VascBackendException { public List<Serializable> execute(VascBackendState state) throws VascBackendException {
boolean changed = isStateChanged(state); boolean changed = isStateChanged(state);
if (data==null | changed) { if (data==null | changed) {
data = backend.execute(state); data = backend.execute(state);
@ -151,7 +152,7 @@ public class VascBackendProxyCache extends AbstractVascBackendProxy {
* @see net.forwardfire.vasc.backend.proxy.AbstractVascBackendProxy#delete(java.lang.Object) * @see net.forwardfire.vasc.backend.proxy.AbstractVascBackendProxy#delete(java.lang.Object)
*/ */
@Override @Override
public void delete(Object object) throws VascBackendException { public void delete(Serializable object) throws VascBackendException {
requestFlush = true; requestFlush = true;
super.delete(object); super.delete(object);
} }
@ -160,7 +161,7 @@ public class VascBackendProxyCache extends AbstractVascBackendProxy {
* @see net.forwardfire.vasc.backend.proxy.AbstractVascBackendProxy#merge(java.lang.Object) * @see net.forwardfire.vasc.backend.proxy.AbstractVascBackendProxy#merge(java.lang.Object)
*/ */
@Override @Override
public Object merge(Object object) throws VascBackendException { public Serializable merge(Serializable object) throws VascBackendException {
requestFlush = true; requestFlush = true;
return super.merge(object); return super.merge(object);
} }
@ -169,7 +170,7 @@ public class VascBackendProxyCache extends AbstractVascBackendProxy {
* @see net.forwardfire.vasc.backend.proxy.AbstractVascBackendProxy#persist(java.lang.Object) * @see net.forwardfire.vasc.backend.proxy.AbstractVascBackendProxy#persist(java.lang.Object)
*/ */
@Override @Override
public void persist(Object object) throws VascBackendException { public void persist(Serializable object) throws VascBackendException {
requestFlush = true; requestFlush = true;
super.persist(object); super.persist(object);
} }

View file

@ -22,6 +22,7 @@
package net.forwardfire.vasc.backend.proxy; package net.forwardfire.vasc.backend.proxy;
import java.io.Serializable;
import java.util.ArrayList; import java.util.ArrayList;
import java.util.List; import java.util.List;
@ -51,7 +52,7 @@ public class VascBackendProxyEventExecutor extends AbstractVascBackendProxy {
return result; return result;
} }
public void initProxy(VascBackend backend,VascEntry entry) { public void initProxy(VascBackend<Serializable> backend,VascEntry entry) {
super.initProxy(backend, entry); super.initProxy(backend, entry);
this.entry=entry; this.entry=entry;
this.listeners=new ArrayList<VascEntryBackendEventListener>(10); this.listeners=new ArrayList<VascEntryBackendEventListener>(10);
@ -105,7 +106,7 @@ public class VascBackendProxyEventExecutor extends AbstractVascBackendProxy {
* @see net.forwardfire.vasc.backend.proxy.AbstractVascBackendProxy#delete(java.lang.Object) * @see net.forwardfire.vasc.backend.proxy.AbstractVascBackendProxy#delete(java.lang.Object)
*/ */
@Override @Override
public void delete(Object object) throws VascBackendException { public void delete(Serializable object) throws VascBackendException {
fireVascEvent(VascBackendEventType.PRE_DELETE,object); fireVascEvent(VascBackendEventType.PRE_DELETE,object);
super.delete(object); super.delete(object);
fireVascEvent(VascBackendEventType.POST_DELETE,object); fireVascEvent(VascBackendEventType.POST_DELETE,object);
@ -137,9 +138,9 @@ public class VascBackendProxyEventExecutor extends AbstractVascBackendProxy {
* @see net.forwardfire.vasc.backend.proxy.AbstractVascBackendProxy#execute(net.forwardfire.vasc.backend.VascBackendState) * @see net.forwardfire.vasc.backend.proxy.AbstractVascBackendProxy#execute(net.forwardfire.vasc.backend.VascBackendState)
*/ */
@Override @Override
public List<Object> execute(VascBackendState state) throws VascBackendException { public List<Serializable> execute(VascBackendState state) throws VascBackendException {
fireVascEvent(VascBackendEventType.PRE_EXECUTE,state); fireVascEvent(VascBackendEventType.PRE_EXECUTE,state);
List<Object> result = super.execute(state); List<Serializable> result = super.execute(state);
fireVascEvent(VascBackendEventType.POST_EXECUTE,result); fireVascEvent(VascBackendEventType.POST_EXECUTE,result);
return result; return result;
} }
@ -159,9 +160,9 @@ public class VascBackendProxyEventExecutor extends AbstractVascBackendProxy {
* @see net.forwardfire.vasc.backend.proxy.AbstractVascBackendProxy#merge(java.lang.Object) * @see net.forwardfire.vasc.backend.proxy.AbstractVascBackendProxy#merge(java.lang.Object)
*/ */
@Override @Override
public Object merge(Object object) throws VascBackendException { public Serializable merge(Serializable object) throws VascBackendException {
fireVascEvent(VascBackendEventType.PRE_MERGE,object); fireVascEvent(VascBackendEventType.PRE_MERGE,object);
Object result = super.merge(object); Serializable result = super.merge(object);
fireVascEvent(VascBackendEventType.POST_MERGE,result); fireVascEvent(VascBackendEventType.POST_MERGE,result);
return result; return result;
} }
@ -170,7 +171,7 @@ public class VascBackendProxyEventExecutor extends AbstractVascBackendProxy {
* @see net.forwardfire.vasc.backend.proxy.AbstractVascBackendProxy#persist(java.lang.Object) * @see net.forwardfire.vasc.backend.proxy.AbstractVascBackendProxy#persist(java.lang.Object)
*/ */
@Override @Override
public void persist(Object object) throws VascBackendException { public void persist(Serializable object) throws VascBackendException {
fireVascEvent(VascBackendEventType.PRE_PERSIST,object); fireVascEvent(VascBackendEventType.PRE_PERSIST,object);
super.persist(object); super.persist(object);
fireVascEvent(VascBackendEventType.POST_PERSIST,object); fireVascEvent(VascBackendEventType.POST_PERSIST,object);

View file

@ -22,6 +22,7 @@
package net.forwardfire.vasc.backend.proxy; package net.forwardfire.vasc.backend.proxy;
import java.io.Serializable;
import java.util.ArrayList; import java.util.ArrayList;
import java.util.List; import java.util.List;
@ -53,7 +54,7 @@ public class VascBackendProxyFilter extends AbstractVascBackendProxy {
/** /**
* @see net.forwardfire.vasc.backend.proxy.VascBackendProxy#initProxy(net.forwardfire.vasc.backend.VascBackend, net.forwardfire.vasc.core.VascEntry) * @see net.forwardfire.vasc.backend.proxy.VascBackendProxy#initProxy(net.forwardfire.vasc.backend.VascBackend, net.forwardfire.vasc.core.VascEntry)
*/ */
public void initProxy(VascBackend backend, VascEntry entry) { public void initProxy(VascBackend<Serializable> backend, VascEntry entry) {
super.initProxy(backend,entry); super.initProxy(backend,entry);
filters = entry.getVascBackendFilters(); filters = entry.getVascBackendFilters();
for (VascProxyFilter filter:filters) { for (VascProxyFilter filter:filters) {
@ -76,18 +77,18 @@ public class VascBackendProxyFilter extends AbstractVascBackendProxy {
* @see net.forwardfire.vasc.backend.VascBackend#execute(VascBackendState state) * @see net.forwardfire.vasc.backend.VascBackend#execute(VascBackendState state)
*/ */
@Override @Override
public List<Object> execute(VascBackendState state) throws VascBackendException { public List<Serializable> execute(VascBackendState state) throws VascBackendException {
List<Object> result = backend.execute(state); List<Serializable> result = backend.execute(state);
if (filters==null) { if (filters==null) {
return result; return result;
} }
if (filters.isEmpty()) { if (filters.isEmpty()) {
return result; return result;
} }
List<Object> search = new ArrayList<Object>(result.size()/2); List<Serializable> search = new ArrayList<Serializable>(result.size()/2);
for (Object o:result) { for (Serializable o:result) {
for (VascProxyFilter filter:filters) { for (VascProxyFilter filter:filters) {
Object r = filter.filterObject(o); Serializable r = filter.filterObject(o);
if (r!=null) { if (r!=null) {
search.add(r); search.add(r);
} }

View file

@ -22,6 +22,7 @@
package net.forwardfire.vasc.backend.proxy; package net.forwardfire.vasc.backend.proxy;
import java.io.Serializable;
import java.util.ArrayList; import java.util.ArrayList;
import java.util.List; import java.util.List;
@ -70,21 +71,21 @@ public class VascBackendProxyPaged extends AbstractVascBackendProxy {
* @see net.forwardfire.vasc.backend.VascBackend#execute(VascBackendState state) * @see net.forwardfire.vasc.backend.VascBackend#execute(VascBackendState state)
*/ */
@Override @Override
public List<Object> execute(VascBackendState state) throws VascBackendException { public List<Serializable> execute(VascBackendState state) throws VascBackendException {
List<Object> allData = backend.execute(state); List<Serializable> allData = backend.execute(state);
int pageSize = state.getPageSize(); int pageSize = state.getPageSize();
if (pageSize==0) { if (pageSize==0) {
records = allData.size(); records = allData.size();
return allData; return allData;
} }
List<Object> paged = new ArrayList<Object>(state.getPageSize()); List<Serializable> paged = new ArrayList<Serializable>(state.getPageSize());
int off = state.getPageIndex()*pageSize; int off = state.getPageIndex()*pageSize;
int offMax = off+state.getPageSize(); int offMax = off+state.getPageSize();
for (int i=off;i<offMax;i++) { for (int i=off;i<offMax;i++) {
if (i>=allData.size()) { if (i>=allData.size()) {
break; break;
} }
Object o = allData.get(i); Serializable o = allData.get(i);
paged.add(o); paged.add(o);
} }
records = allData.size(); records = allData.size();

View file

@ -22,6 +22,7 @@
package net.forwardfire.vasc.backend.proxy; package net.forwardfire.vasc.backend.proxy;
import java.io.Serializable;
import java.util.ArrayList; import java.util.ArrayList;
import java.util.List; import java.util.List;
@ -70,8 +71,8 @@ public class VascBackendProxySearch extends AbstractVascBackendProxy {
* @see net.forwardfire.vasc.backend.VascBackend#execute(VascBackendState state) * @see net.forwardfire.vasc.backend.VascBackend#execute(VascBackendState state)
*/ */
@Override @Override
public List<Object> execute(VascBackendState state) throws VascBackendException { public List<Serializable> execute(VascBackendState state) throws VascBackendException {
List<Object> result = backend.execute(state); List<Serializable> result = backend.execute(state);
if (state.getSearchString()==null) { if (state.getSearchString()==null) {
return result; return result;
} }
@ -79,8 +80,8 @@ public class VascBackendProxySearch extends AbstractVascBackendProxy {
return result; return result;
} }
String searchString = state.getSearchString().toLowerCase(); String searchString = state.getSearchString().toLowerCase();
List<Object> search = new ArrayList<Object>(result.size()/4); List<Serializable> search = new ArrayList<Serializable>(result.size()/4);
for (Object record:result) { for (Serializable record:result) {
for (VascEntryField field:entry.getVascEntryFields()) { for (VascEntryField field:entry.getVascEntryFields()) {
VascEntryFieldValue fieldValue = backend.provideVascEntryFieldValue(); VascEntryFieldValue fieldValue = backend.provideVascEntryFieldValue();
Object value = fieldValue.getValue(field.getBackendName(), record); Object value = fieldValue.getValue(field.getBackendName(), record);

View file

@ -22,6 +22,7 @@
package net.forwardfire.vasc.backend.proxy; package net.forwardfire.vasc.backend.proxy;
import java.io.Serializable;
import java.util.Collections; import java.util.Collections;
import java.util.Comparator; import java.util.Comparator;
import java.util.List; import java.util.List;
@ -73,8 +74,8 @@ public class VascBackendProxySort extends AbstractVascBackendProxy {
*/ */
@SuppressWarnings("unchecked") @SuppressWarnings("unchecked")
@Override @Override
public List<Object> execute(final VascBackendState state) throws VascBackendException { public List<Serializable> execute(final VascBackendState state) throws VascBackendException {
List<Object> result = backend.execute(state); List<Serializable> result = backend.execute(state);
if (state.getSortField()==null) { if (state.getSortField()==null) {
return result; return result;
} }

View file

@ -22,6 +22,7 @@
package net.forwardfire.vasc.backend.proxy; package net.forwardfire.vasc.backend.proxy;
import java.io.Serializable;
import java.util.List; import java.util.List;
import java.util.logging.Level; import java.util.logging.Level;
import java.util.logging.Logger; import java.util.logging.Logger;
@ -58,7 +59,7 @@ public class VascBackendProxyTimerLogger extends AbstractVascBackendProxy {
* @see net.forwardfire.vasc.backend.VascBackend#execute(VascBackendState state) * @see net.forwardfire.vasc.backend.VascBackend#execute(VascBackendState state)
*/ */
@Override @Override
public List<Object> execute(VascBackendState state) throws VascBackendException { public List<Serializable> execute(VascBackendState state) throws VascBackendException {
long t1 = System.currentTimeMillis(); long t1 = System.currentTimeMillis();
try { try {
return backend.execute(state); return backend.execute(state);
@ -111,7 +112,7 @@ public class VascBackendProxyTimerLogger extends AbstractVascBackendProxy {
* @see net.forwardfire.vasc.backend.proxy.AbstractVascBackendProxy#delete(java.lang.Object) * @see net.forwardfire.vasc.backend.proxy.AbstractVascBackendProxy#delete(java.lang.Object)
*/ */
@Override @Override
public void delete(Object object) throws VascBackendException { public void delete(Serializable object) throws VascBackendException {
long t1 = System.currentTimeMillis(); long t1 = System.currentTimeMillis();
try { try {
backend.delete(object); backend.delete(object);
@ -125,7 +126,7 @@ public class VascBackendProxyTimerLogger extends AbstractVascBackendProxy {
* @see net.forwardfire.vasc.backend.proxy.AbstractVascBackendProxy#merge(java.lang.Object) * @see net.forwardfire.vasc.backend.proxy.AbstractVascBackendProxy#merge(java.lang.Object)
*/ */
@Override @Override
public Object merge(Object object) throws VascBackendException { public Serializable merge(Serializable object) throws VascBackendException {
long t1 = System.currentTimeMillis(); long t1 = System.currentTimeMillis();
try { try {
return backend.merge(object); return backend.merge(object);
@ -139,7 +140,7 @@ public class VascBackendProxyTimerLogger extends AbstractVascBackendProxy {
* @see net.forwardfire.vasc.backend.proxy.AbstractVascBackendProxy#persist(java.lang.Object) * @see net.forwardfire.vasc.backend.proxy.AbstractVascBackendProxy#persist(java.lang.Object)
*/ */
@Override @Override
public void persist(Object object) throws VascBackendException { public void persist(Serializable object) throws VascBackendException {
long t1 = System.currentTimeMillis(); long t1 = System.currentTimeMillis();
try { try {
backend.persist(object); backend.persist(object);

View file

@ -22,6 +22,8 @@
package net.forwardfire.vasc.backend.proxy; package net.forwardfire.vasc.backend.proxy;
import java.io.Serializable;
import net.forwardfire.vasc.core.VascEntry; import net.forwardfire.vasc.core.VascEntry;
@ -41,7 +43,7 @@ public interface VascProxyFilter {
/** /**
* Only filters 1 object. * Only filters 1 object.
*/ */
public Object filterObject(Object object); public Serializable filterObject(Serializable object);
/** /**
* Force impl to have public clone methode * Force impl to have public clone methode

View file

@ -22,6 +22,7 @@
package net.forwardfire.vasc.core; package net.forwardfire.vasc.core;
import java.io.Serializable;
import java.util.ArrayList; import java.util.ArrayList;
import java.util.HashMap; import java.util.HashMap;
import java.util.List; import java.util.List;
@ -39,46 +40,46 @@ import net.forwardfire.vasc.backend.VascBackendState;
@SuppressWarnings("serial") @SuppressWarnings("serial")
abstract public class AbstractVascEntryState implements VascEntryState { abstract public class AbstractVascEntryState implements VascEntryState {
private List<Object> entryDataList = null; private List<Serializable> entryDataList = null;
private Object entryDataObject = null; private Serializable entryDataObject = null;
private Long totalBackendRecords = null; private Long totalBackendRecords = null;
private VascBackendState vascBackendState = null; private VascBackendState vascBackendState = null;
private VascEntryState state = null; private VascEntryState state = null;
private Map<Integer,Boolean> multiActionSelection = null; private Map<Integer,Boolean> multiActionSelection = null;
private boolean isEditCreate = false; private boolean isEditCreate = false;
private VascBackend vascBackend = null; private VascBackend<Serializable> vascBackend = null;
private VascEntry vascEntry = null; private VascEntry vascEntry = null;
public AbstractVascEntryState() { public AbstractVascEntryState() {
entryDataList = new ArrayList<Object>(0); entryDataList = new ArrayList<Serializable>(0);
multiActionSelection = new HashMap<Integer,Boolean>(200); multiActionSelection = new HashMap<Integer,Boolean>(200);
} }
/** /**
* @return the entryDataList * @return the entryDataList
*/ */
public List<Object> getEntryDataList() { public List<Serializable> getEntryDataList() {
return entryDataList; return entryDataList;
} }
/** /**
* @param entryDataList the entryDataList to set * @param entryDataList the entryDataList to set
*/ */
public void setEntryDataList(List<Object> entryDataList) { public void setEntryDataList(List<Serializable> entryDataList) {
this.entryDataList = entryDataList; this.entryDataList = entryDataList;
} }
/** /**
* @return the entryDataObject * @return the entryDataObject
*/ */
public Object getEntryDataObject() { public Serializable getEntryDataObject() {
return entryDataObject; return entryDataObject;
} }
/** /**
* @param entryDataObject the entryDataObject to set * @param entryDataObject the entryDataObject to set
*/ */
public void setEntryDataObject(Object entryDataObject) { public void setEntryDataObject(Serializable entryDataObject) {
this.entryDataObject = entryDataObject; this.entryDataObject = entryDataObject;
} }
@ -128,14 +129,14 @@ abstract public class AbstractVascEntryState implements VascEntryState {
/** /**
* @return the vascBackend * @return the vascBackend
*/ */
public VascBackend getVascBackend() { public VascBackend<Serializable> getVascBackend() {
return vascBackend; return vascBackend;
} }
/** /**
* @param vascBackend the vascBackend to set * @param vascBackend the vascBackend to set
*/ */
public void setVascBackend(VascBackend vascBackend) { public void setVascBackend(VascBackend<Serializable> vascBackend) {
this.vascBackend = vascBackend; this.vascBackend = vascBackend;
} }

View file

@ -22,6 +22,7 @@
package net.forwardfire.vasc.core; package net.forwardfire.vasc.core;
import java.io.Serializable;
import java.util.List; import java.util.List;
import net.forwardfire.vasc.backend.VascBackend; import net.forwardfire.vasc.backend.VascBackend;
@ -45,9 +46,9 @@ public interface VascEntryConfigController {
public void configVascEntry(VascController vascController,VascEntryLocal vascEntry) throws VascException; public void configVascEntry(VascController vascController,VascEntryLocal vascEntry) throws VascException;
public VascBackend configVascBackendProxied(VascController vascController,VascEntry vascEntry) throws VascException; public VascBackend<Serializable> configVascBackendProxied(VascController vascController,VascEntry vascEntry) throws VascException;
public VascBackend configVascBackendProxied(VascController vascController,VascEntry vascEntry,VascBackend realBackend) throws VascException; public VascBackend<Serializable> configVascBackendProxied(VascController vascController,VascEntry vascEntry,VascBackend<Serializable> realBackend) throws VascException;
public List<String> getVascEntryExporterIds(); public List<String> getVascEntryExporterIds();

View file

@ -41,22 +41,22 @@ public interface VascEntryState extends Serializable {
/** /**
* @return the entryDataList * @return the entryDataList
*/ */
public List<Object> getEntryDataList(); public List<Serializable> getEntryDataList();
/** /**
* @param entryDataList the entryDataList to set * @param entryDataList the entryDataList to set
*/ */
public void setEntryDataList(List<Object> entryDataList); public void setEntryDataList(List<Serializable> entryDataList);
/** /**
* @return the entryDataObject * @return the entryDataObject
*/ */
public Object getEntryDataObject(); public Serializable getEntryDataObject();
/** /**
* @param entryDataObject the entryDataObject to set * @param entryDataObject the entryDataObject to set
*/ */
public void setEntryDataObject(Object entryDataObject); public void setEntryDataObject(Serializable entryDataObject);
/** /**
* @return the vascBackendState * @return the vascBackendState
@ -97,12 +97,12 @@ public interface VascEntryState extends Serializable {
/** /**
* @return the vascBackend * @return the vascBackend
*/ */
public VascBackend getVascBackend(); public VascBackend<Serializable> getVascBackend();
/** /**
* @param vascBackend the vascBackend to set * @param vascBackend the vascBackend to set
*/ */
public void setVascBackend(VascBackend vascBackend); public void setVascBackend(VascBackend<Serializable> vascBackend);
/** /**
* @return the isEditCreate * @return the isEditCreate

View file

@ -22,6 +22,8 @@
package net.forwardfire.vasc.core.actions; package net.forwardfire.vasc.core.actions;
import java.io.Serializable;
import net.forwardfire.vasc.core.VascEntry; import net.forwardfire.vasc.core.VascEntry;
import net.forwardfire.vasc.core.VascException; import net.forwardfire.vasc.core.VascException;
@ -34,6 +36,6 @@ public interface RowVascAction extends VascAction {
public boolean isMultiRowAction(); public boolean isMultiRowAction();
public void doRowAction(VascEntry vascEntry,Object rowObject) throws VascException; public void doRowAction(VascEntry vascEntry,Serializable rowObject) throws VascException;
} }

View file

@ -22,6 +22,8 @@
package net.forwardfire.vasc.frontend; package net.forwardfire.vasc.frontend;
import java.io.Serializable;
import net.forwardfire.vasc.core.VascEntryField; import net.forwardfire.vasc.core.VascEntryField;
/** /**
@ -34,7 +36,7 @@ public interface VascFrontendActions extends VascFrontendEntry {
public void refreshData() throws VascFrontendException; public void refreshData() throws VascFrontendException;
public Object createObject() throws VascFrontendException; public Serializable createObject() throws VascFrontendException;
public void deleteObject() throws VascFrontendException; public void deleteObject() throws VascFrontendException;

View file

@ -22,6 +22,8 @@
package net.forwardfire.vasc.impl.actions; package net.forwardfire.vasc.impl.actions;
import java.io.Serializable;
import net.forwardfire.vasc.core.VascEntry; import net.forwardfire.vasc.core.VascEntry;
import net.forwardfire.vasc.core.VascException; import net.forwardfire.vasc.core.VascException;
import net.forwardfire.vasc.core.actions.AbstractVascRowActionLocal; import net.forwardfire.vasc.core.actions.AbstractVascRowActionLocal;
@ -42,9 +44,9 @@ public class AddRowAction extends AbstractVascRowActionLocal {
} }
public void doRowAction(VascEntry entry,Object rowObject) throws VascException { public void doRowAction(VascEntry entry,Serializable rowObject) throws VascException {
entry.getVascFrontendController().getVascEntryState().setEditCreate(true); entry.getVascFrontendController().getVascEntryState().setEditCreate(true);
Object object = entry.getVascFrontendController().getVascFrontendActions().createObject(); Serializable object = entry.getVascFrontendController().getVascFrontendActions().createObject();
entry.getVascFrontendController().getVascEntryState().setEntryDataObject(object); entry.getVascFrontendController().getVascEntryState().setEntryDataObject(object);
entry.getVascFrontendController().getVascFrontend().renderEdit(); entry.getVascFrontendController().getVascFrontend().renderEdit();
} }

View file

@ -22,6 +22,8 @@
package net.forwardfire.vasc.impl.actions; package net.forwardfire.vasc.impl.actions;
import java.io.Serializable;
import net.forwardfire.vasc.core.VascEntry; import net.forwardfire.vasc.core.VascEntry;
import net.forwardfire.vasc.core.VascException; import net.forwardfire.vasc.core.VascException;
import net.forwardfire.vasc.core.actions.AbstractVascRowActionLocal; import net.forwardfire.vasc.core.actions.AbstractVascRowActionLocal;
@ -41,7 +43,7 @@ public class DeleteRowAction extends AbstractVascRowActionLocal {
return ACTION_ID; return ACTION_ID;
} }
public void doRowAction(VascEntry entry,Object rowObject) throws VascException { public void doRowAction(VascEntry entry,Serializable rowObject) throws VascException {
if (rowObject==null) { if (rowObject==null) {
return; // nothing selected return; // nothing selected
} }

View file

@ -22,6 +22,8 @@
package net.forwardfire.vasc.impl.actions; package net.forwardfire.vasc.impl.actions;
import java.io.Serializable;
import net.forwardfire.vasc.core.VascEntry; import net.forwardfire.vasc.core.VascEntry;
import net.forwardfire.vasc.core.VascException; import net.forwardfire.vasc.core.VascException;
import net.forwardfire.vasc.core.actions.AbstractVascRowActionLocal; import net.forwardfire.vasc.core.actions.AbstractVascRowActionLocal;
@ -43,7 +45,7 @@ public class EditRowAction extends AbstractVascRowActionLocal {
} }
public void doRowAction(VascEntry entry,Object rowObject) throws VascException { public void doRowAction(VascEntry entry,Serializable rowObject) throws VascException {
if (rowObject==null) { if (rowObject==null) {
return; // nothing selected return; // nothing selected
} }

View file

@ -22,6 +22,7 @@
package net.forwardfire.vasc.impl.frontend; package net.forwardfire.vasc.impl.frontend;
import java.io.Serializable;
import java.util.Date; import java.util.Date;
import java.util.logging.Logger; import java.util.logging.Logger;
@ -55,9 +56,9 @@ public class DefaultVascFrontendActions implements VascFrontendActions {
/** /**
* @see net.forwardfire.vasc.frontend.VascFrontendHelper#initEditObject(net.forwardfire.vasc.core.VascEntry) * @see net.forwardfire.vasc.frontend.VascFrontendHelper#initEditObject(net.forwardfire.vasc.core.VascEntry)
*/ */
public Object createObject() throws VascFrontendException { public Serializable createObject() throws VascFrontendException {
entry.getVascFrontendController().fireVascFrontendEvent(entry,VascEntryFrontendEventListener.VascFrontendEventType.PRE_CREATE, null); entry.getVascFrontendController().fireVascFrontendEvent(entry,VascEntryFrontendEventListener.VascFrontendEventType.PRE_CREATE, null);
Object object; Serializable object;
try { try {
object = entry.getVascFrontendController().getVascEntryState().getVascBackend().provideVascEntryRecordCreator().newRecord(); object = entry.getVascFrontendController().getVascEntryState().getVascBackend().provideVascEntryRecordCreator().newRecord();
} catch (VascBackendException e) { } catch (VascBackendException e) {
@ -146,8 +147,8 @@ public class DefaultVascFrontendActions implements VascFrontendActions {
protected Object saveObject(boolean persist) throws VascException { protected Object saveObject(boolean persist) throws VascException {
try { try {
Object object = entry.getVascFrontendController().getVascEntryState().getEntryDataObject(); Serializable object = entry.getVascFrontendController().getVascEntryState().getEntryDataObject();
Object result = null; Serializable result = null;
entry.getVascFrontendController().fireVascFrontendEvent(entry,VascEntryFrontendEventListener.VascFrontendEventType.PRE_UPDATE,object); entry.getVascFrontendController().fireVascFrontendEvent(entry,VascEntryFrontendEventListener.VascFrontendEventType.PRE_UPDATE,object);
int index = removeObjectFromDataList(object); int index = removeObjectFromDataList(object);
@ -183,7 +184,7 @@ public class DefaultVascFrontendActions implements VascFrontendActions {
*/ */
public void deleteObject() throws VascFrontendException { public void deleteObject() throws VascFrontendException {
try { try {
Object object = entry.getVascFrontendController().getVascEntryState().getEntryDataObject(); Serializable object = entry.getVascFrontendController().getVascEntryState().getEntryDataObject();
entry.getVascFrontendController().fireVascFrontendEvent(entry,VascEntryFrontendEventListener.VascFrontendEventType.PRE_DELETE, object); entry.getVascFrontendController().fireVascFrontendEvent(entry,VascEntryFrontendEventListener.VascFrontendEventType.PRE_DELETE, object);
entry.getVascFrontendController().getVascEntryState().getVascBackend().delete(object); entry.getVascFrontendController().getVascEntryState().getVascBackend().delete(object);

View file

@ -156,7 +156,11 @@ public class VascControllerService {
@Override @Override
public void controllerEvent(VascEventControllerType type,Object eventObject) { public void controllerEvent(VascEventControllerType type,Object eventObject) {
if (bootDone > 0) {
generateRequest = System.currentTimeMillis(); generateRequest = System.currentTimeMillis();
} else {
generateBundle();
}
} }
public void generateBundle() { public void generateBundle() {

View file

@ -27,6 +27,7 @@ import java.awt.FlowLayout;
import java.awt.Font; import java.awt.Font;
import java.awt.event.ActionEvent; import java.awt.event.ActionEvent;
import java.awt.event.ActionListener; import java.awt.event.ActionListener;
import java.io.Serializable;
import javax.swing.BoxLayout; import javax.swing.BoxLayout;
import javax.swing.JButton; import javax.swing.JButton;
@ -56,14 +57,14 @@ public class SwingVascEditDialog extends JPanel {
private static final long serialVersionUID = 10L; private static final long serialVersionUID = 10L;
private String headerText = null; private String headerText = null;
private String headerTextValue = null; private String headerTextValue = null;
private Object result = null; private Serializable result = null;
private Object bean = null; private Serializable bean = null;
private VascEntry entry = null; private VascEntry entry = null;
private SwingVascFrontend swingFrontend = null; private SwingVascFrontend swingFrontend = null;
private SwingPanelIntegration panels = null; private SwingPanelIntegration panels = null;
private JPanel editView = null; private JPanel editView = null;
public SwingVascEditDialog(SwingVascFrontend swingFrontend,JPanel editView,VascEntry entry,Object bean,String beanValue,SwingPanelIntegration panels) throws VascException { public SwingVascEditDialog(SwingVascFrontend swingFrontend,JPanel editView,VascEntry entry,Serializable bean,String beanValue,SwingPanelIntegration panels) throws VascException {
super(); super();
this.headerText = "vasc.dialog.edit.message"; this.headerText = "vasc.dialog.edit.message";
this.headerTextValue = beanValue; this.headerTextValue = beanValue;

View file

@ -33,6 +33,7 @@ import java.awt.event.MouseEvent;
import java.io.FileOutputStream; import java.io.FileOutputStream;
import java.io.IOException; import java.io.IOException;
import java.io.OutputStream; import java.io.OutputStream;
import java.io.Serializable;
import java.util.HashMap; import java.util.HashMap;
import java.util.Map; import java.util.Map;
import java.util.logging.Logger; import java.util.logging.Logger;
@ -156,7 +157,7 @@ public class SwingVascFrontend extends AbstractVascFrontend {
public void renderEdit() throws VascFrontendException { public void renderEdit() throws VascFrontendException {
logger.fine("Rending Edit View"); logger.fine("Rending Edit View");
try { try {
Object rowBean = entry.getVascFrontendController().getVascEntryState().getEntryDataObject(); Serializable rowBean = entry.getVascFrontendController().getVascEntryState().getEntryDataObject();
String beanValue = rowBean.toString(); String beanValue = rowBean.toString();
if (entry.getDisplayNameFieldId()!=null) { if (entry.getDisplayNameFieldId()!=null) {
VascEntryField v = entry.getVascEntryFieldById(entry.getDisplayNameFieldId()); VascEntryField v = entry.getVascEntryFieldById(entry.getDisplayNameFieldId());
@ -503,7 +504,7 @@ public class SwingVascFrontend extends AbstractVascFrontend {
if (rowIndex!=-1) { if (rowIndex!=-1) {
// temp; gets index by sorter // temp; gets index by sorter
//rowIndex = tableSorter.modelIndex(rowIndex); //rowIndex = tableSorter.modelIndex(rowIndex);
Object data = entry.getVascFrontendController().getVascEntryState().getEntryDataList().get(rowIndex); Serializable data = entry.getVascFrontendController().getVascEntryState().getEntryDataList().get(rowIndex);
entry.getVascFrontendController().getVascEntryState().setEntryDataObject(data); entry.getVascFrontendController().getVascEntryState().setEntryDataObject(data);
} else { } else {
entry.getVascFrontendController().getVascEntryState().setEntryDataObject(null); entry.getVascFrontendController().getVascEntryState().setEntryDataObject(null);

View file

@ -45,19 +45,19 @@
<scope>test</scope> <scope>test</scope>
</dependency> </dependency>
<dependency> <dependency>
<groupId>net.forwardfire.vasc</groupId> <groupId>net.forwardfire.vasc.backend</groupId>
<artifactId>vasc-backend-ldap</artifactId> <artifactId>vasc-backend-ldap</artifactId>
<version>${project.version}</version> <version>${project.version}</version>
<scope>test</scope> <scope>test</scope>
</dependency> </dependency>
<dependency> <dependency>
<groupId>net.forwardfire.vasc</groupId> <groupId>net.forwardfire.vasc.backend</groupId>
<artifactId>vasc-backend-mongodb</artifactId> <artifactId>vasc-backend-mongodb</artifactId>
<version>${project.version}</version> <version>${project.version}</version>
<scope>test</scope> <scope>test</scope>
</dependency> </dependency>
<dependency> <dependency>
<groupId>net.forwardfire.vasc</groupId> <groupId>net.forwardfire.vasc.backend</groupId>
<artifactId>vasc-backend-jdbc</artifactId> <artifactId>vasc-backend-jdbc</artifactId>
<version>${project.version}</version> <version>${project.version}</version>
<scope>test</scope> <scope>test</scope>

View file

@ -25,6 +25,7 @@ package net.forwardfire.vasc.frontend.swt;
import java.io.FileOutputStream; import java.io.FileOutputStream;
import java.io.IOException; import java.io.IOException;
import java.io.OutputStream; import java.io.OutputStream;
import java.io.Serializable;
import java.util.logging.Level; import java.util.logging.Level;
import java.util.logging.Logger; import java.util.logging.Logger;
@ -440,7 +441,7 @@ public class SwtVascFrontend extends AbstractVascFrontend {
* @see org.eclipse.swt.events.SelectionListener#widgetSelected(org.eclipse.swt.events.SelectionEvent) * @see org.eclipse.swt.events.SelectionListener#widgetSelected(org.eclipse.swt.events.SelectionEvent)
*/ */
public void widgetSelected(SelectionEvent e) { public void widgetSelected(SelectionEvent e) {
Object data = e.item.getData(); Serializable data = (Serializable) e.item.getData();
logger.fine("Slecting data: "+data); logger.fine("Slecting data: "+data);
entry.getVascFrontendController().getVascEntryState().setEntryDataObject(data); entry.getVascFrontendController().getVascEntryState().setEntryDataObject(data);
} }

View file

@ -22,6 +22,7 @@
package net.forwardfire.vasc.frontend.web.jsf; package net.forwardfire.vasc.frontend.web.jsf;
import java.io.Serializable;
import java.util.List; import java.util.List;
import java.util.Map; import java.util.Map;
@ -50,7 +51,7 @@ public abstract class AbstractJSFVascFacesControllerBase {
/** /**
* *
*/ */
public List<Object> executeVascList(String entryId,Map<String,Object> para) { public List<Serializable> executeVascList(String entryId,Map<String,Object> para) {
try { try {
// plug all object // plug all object
VascEntryLocal entry = (VascEntryLocal)getVascController().getVascEntryController().getVascEntryById(entryId); VascEntryLocal entry = (VascEntryLocal)getVascController().getVascEntryController().getVascEntryById(entryId);

View file

@ -22,6 +22,7 @@
package net.forwardfire.vasc.frontend.web.jsf; package net.forwardfire.vasc.frontend.web.jsf;
import java.io.Serializable;
import java.util.ArrayList; import java.util.ArrayList;
import java.util.List; import java.util.List;
@ -78,10 +79,10 @@ public class JSFVascEntryEventListener implements VascEntryFrontendEventListener
throw new RuntimeException(e); throw new RuntimeException(e);
} }
*/ */
List<Object> data = entry.getVascFrontendController().getVascEntryState().getEntryDataList(); List<Serializable> data = entry.getVascFrontendController().getVascEntryState().getEntryDataList();
List<Object> result = new ArrayList<Object>(data.size()); List<Object> result = new ArrayList<Object>(data.size());
int index = 0; int index = 0;
for (Object o:data) { for (Serializable o:data) {
VascDataBackendBean b = new VascDataBackendBean(entry,o,index); VascDataBackendBean b = new VascDataBackendBean(entry,o,index);
result.add(b); result.add(b);
index++; index++;

View file

@ -318,7 +318,7 @@ public class JSFVascEntrySupportBean implements Serializable {
VascEntry parent = entry.getVascFrontendController().getVascEntryState().getParent().getVascEntry(); VascEntry parent = entry.getVascFrontendController().getVascEntryState().getParent().getVascEntry();
RowVascAction action = parent.getRowActionById(actionIdString); RowVascAction action = parent.getRowActionById(actionIdString);
Object parentSelected = entry.getVascFrontendController().getVascEntryState().getParent().getEntryDataObject(); Serializable parentSelected = entry.getVascFrontendController().getVascEntryState().getParent().getEntryDataObject();
logger.fine("parentCustomRowaction do on: "+action+" parentSelection: "+parentSelected); logger.fine("parentCustomRowaction do on: "+action+" parentSelection: "+parentSelected);
try { try {
action.doRowAction(parent,parentSelected); action.doRowAction(parent,parentSelected);
@ -401,7 +401,7 @@ public class JSFVascEntrySupportBean implements Serializable {
Boolean value = state.getMultiActionSelection().get(rowId); Boolean value = state.getMultiActionSelection().get(rowId);
logger.fine("multiRow selected: "+rowId+" value: "+value); logger.fine("multiRow selected: "+rowId+" value: "+value);
if (value!=null && value==true) { if (value!=null && value==true) {
Object row = state.getEntryDataList().get(rowId); Serializable row = state.getEntryDataList().get(rowId);
logger.finer("row: "+row); logger.finer("row: "+row);
action.doRowAction(vascEntry, row); action.doRowAction(vascEntry, row);
if (action.getId().equals(DeleteRowAction.ACTION_ID)) { if (action.getId().equals(DeleteRowAction.ACTION_ID)) {
@ -468,7 +468,7 @@ public class JSFVascEntrySupportBean implements Serializable {
VascEntry entry = getVascEntry(); VascEntry entry = getVascEntry();
// select record to edit // select record to edit
Object rowObject = entry.getVascFrontendController().getVascEntryState().getParent().getEntryDataObject(); Serializable rowObject = entry.getVascFrontendController().getVascEntryState().getParent().getEntryDataObject();
comp.initGoto(entry.getVascFrontendController().getVascEntryState().getParent(),rowObject); comp.initGoto(entry.getVascFrontendController().getVascEntryState().getParent(),rowObject);
} }
@ -613,7 +613,7 @@ public class JSFVascEntrySupportBean implements Serializable {
VascEntryLink link = comp.getVascEntry().getVascFrontendController().getVascEntryState().getParent().getVascEntry().getVascEntryLinkById(linkId); VascEntryLink link = comp.getVascEntry().getVascFrontendController().getVascEntryState().getParent().getVascEntry().getVascEntryLinkById(linkId);
comp.initGoto(link,comp.getVascEntry().getVascFrontendController().getVascEntryState().getParent()); comp.initGoto(link,comp.getVascEntry().getVascFrontendController().getVascEntryState().getParent());
Object o = comp.getVascEntry().getVascFrontendController().getVascEntryState().getParent().getEntryDataObject(); Serializable o = comp.getVascEntry().getVascFrontendController().getVascEntryState().getParent().getEntryDataObject();
int index = comp.getVascEntry().getVascFrontendController().getVascEntryState().getParent().getEntryDataList().indexOf(o); int index = comp.getVascEntry().getVascFrontendController().getVascEntryState().getParent().getEntryDataList().indexOf(o);
VascDataBackendBean selected = new VascDataBackendBean(entry,o,index); VascDataBackendBean selected = new VascDataBackendBean(entry,o,index);
this.selected=selected; this.selected=selected;
@ -668,17 +668,17 @@ public class JSFVascEntrySupportBean implements Serializable {
VascEntry entry = comp.getVascEntry(); VascEntry entry = comp.getVascEntry();
VascEntryState state = entry.getVascFrontendController().getVascEntryState(); VascEntryState state = entry.getVascFrontendController().getVascEntryState();
List<Object> sels = new ArrayList<Object>(5); List<Serializable> sels = new ArrayList<Serializable>(5);
for (Integer rowId:state.getMultiActionSelection().keySet()) { for (Integer rowId:state.getMultiActionSelection().keySet()) {
Boolean value = state.getMultiActionSelection().get(rowId); Boolean value = state.getMultiActionSelection().get(rowId);
logger.fine("multiRow delete: "+rowId+" value: "+value); logger.fine("multiRow delete: "+rowId+" value: "+value);
if (value!=null && value==true) { if (value!=null && value==true) {
Object row = state.getEntryDataList().get(rowId); Serializable row = state.getEntryDataList().get(rowId);
sels.add(row); sels.add(row);
} }
} }
if (sels.isEmpty()==false) { if (sels.isEmpty()==false) {
for (Object row:sels) { for (Serializable row:sels) {
entry.getVascFrontendController().getVascEntryState().setEntryDataObject(row); entry.getVascFrontendController().getVascEntryState().setEntryDataObject(row);
entry.getVascFrontendController().getVascFrontendActions().deleteObject(); entry.getVascFrontendController().getVascFrontendActions().deleteObject();
} }

View file

@ -23,6 +23,7 @@
package net.forwardfire.vasc.frontend.web.jsf; package net.forwardfire.vasc.frontend.web.jsf;
import java.io.IOException; import java.io.IOException;
import java.io.Serializable;
import java.util.ArrayList; import java.util.ArrayList;
import java.util.Iterator; import java.util.Iterator;
import java.util.List; import java.util.List;
@ -72,7 +73,7 @@ public class JSFVascUIComponent extends UIComponentBase {
private VascEntryLink link = null; private VascEntryLink link = null;
private VascEntryState linkState = null; private VascEntryState linkState = null;
private VascEntryState state = null; private VascEntryState state = null;
private Object stateEditId = null; private Serializable stateEditId = null;
private Logger logger = null; private Logger logger = null;
private Boolean initClear = null; private Boolean initClear = null;
private String injectTableOptionOnChange = null; private String injectTableOptionOnChange = null;
@ -182,7 +183,7 @@ public class JSFVascUIComponent extends UIComponentBase {
this.state=state; this.state=state;
} }
protected void initGoto(VascEntryState state,Object stateEditId) { protected void initGoto(VascEntryState state,Serializable stateEditId) {
logger.fine("init goto "+state); logger.fine("init goto "+state);
this.state=state; this.state=state;
this.stateEditId=stateEditId; this.stateEditId=stateEditId;
@ -218,7 +219,7 @@ public class JSFVascUIComponent extends UIComponentBase {
} }
if (stateEditId!=null) { if (stateEditId!=null) {
Object rowObject = stateEditId; Serializable rowObject = stateEditId;
// setup for renderEdit() of frontend // setup for renderEdit() of frontend
List<Object> list = new ArrayList<Object>(1); List<Object> list = new ArrayList<Object>(1);

View file

@ -29,11 +29,8 @@ import net.forwardfire.vasc.backend.VascBackendException;
import net.forwardfire.vasc.backend.VascEntryFieldValue; import net.forwardfire.vasc.backend.VascEntryFieldValue;
import net.forwardfire.vasc.core.VascEntry; import net.forwardfire.vasc.core.VascEntry;
import net.forwardfire.vasc.core.VascEntryField; import net.forwardfire.vasc.core.VascEntryField;
import net.forwardfire.vasc.core.VascException;
import net.forwardfire.vasc.frontend.VascFrontendDataSelector.EntryFieldSelectType; import net.forwardfire.vasc.frontend.VascFrontendDataSelector.EntryFieldSelectType;
/** /**
* *
* *
@ -44,11 +41,11 @@ public class VascDataBackendBean implements Serializable {
private static final long serialVersionUID = 3881688974089760074L; private static final long serialVersionUID = 3881688974089760074L;
private VascEntry entry = null; private VascEntry entry = null;
private Object record = null; private Serializable record = null;
private boolean realValue = false; private boolean realValue = false;
private int recordId = 0; private int recordId = 0;
public VascDataBackendBean(VascEntry entry,Object record,int recordId) { public VascDataBackendBean(VascEntry entry,Serializable record,int recordId) {
this.entry=entry; this.entry=entry;
this.record=record; this.record=record;
this.recordId=recordId; this.recordId=recordId;
@ -102,7 +99,7 @@ public class VascDataBackendBean implements Serializable {
} }
} }
public Object getRecord() { public Serializable getRecord() {
return record; return record;
} }

View file

@ -1,5 +1,6 @@
package net.forwardfire.vasc.opt.editor; package net.forwardfire.vasc.opt.editor;
import java.io.Serializable;
import java.util.ArrayList; import java.util.ArrayList;
import java.util.List; import java.util.List;
@ -27,14 +28,14 @@ import net.forwardfire.vasc.impl.DefaultVascEntryField;
import net.forwardfire.vasc.impl.DefaultVascEntryFieldSet; import net.forwardfire.vasc.impl.DefaultVascEntryFieldSet;
import net.forwardfire.vasc.impl.DefaultVascEntryLink; import net.forwardfire.vasc.impl.DefaultVascEntryLink;
public class VirtualVascBackend extends AbstractVascBackend { public class VirtualVascBackend extends AbstractVascBackend<Serializable> {
private VascController vascController = null; private VascController vascController = null;
private String vascType = "entry"; private String vascType = "entry";
private String entryId = null; private String entryId = null;
public List<Object> execute(VascBackendState state) throws VascBackendException { public List<Serializable> execute(VascBackendState state) throws VascBackendException {
List<Object> result = new ArrayList<Object>(100); List<Serializable> result = new ArrayList<Serializable>(100);
entryId = (String)state.getDataParameter("entry_id"); entryId = (String)state.getDataParameter("entry_id");
if ("entry".equals(vascType)) { if ("entry".equals(vascType)) {
for (String id:vascController.getVascEntryController().getVascEntryIds()) { for (String id:vascController.getVascEntryController().getVascEntryIds()) {
@ -65,19 +66,19 @@ public class VirtualVascBackend extends AbstractVascBackend {
return result; return result;
} }
public void persist(Object object) throws VascBackendException { public void persist(Serializable object) throws VascBackendException {
edit(object,false,true); edit(object,false,true);
} }
public Object merge(Object object) throws VascBackendException { public Serializable merge(Serializable object) throws VascBackendException {
return edit(object,true,true); return edit(object,true,true);
} }
public void delete(Object object) throws VascBackendException { public void delete(Serializable object) throws VascBackendException {
edit(object,true,false); edit(object,true,false);
} }
public Object edit(Object object,boolean removeReal,boolean addEdit) throws VascBackendException { public Serializable edit(Serializable object,boolean removeReal,boolean addEdit) throws VascBackendException {
if (object instanceof VascEntry) { if (object instanceof VascEntry) {
entryId = ((VascEntry)object).getId(); entryId = ((VascEntry)object).getId();

View file

@ -23,6 +23,7 @@
package net.forwardfire.vasc.test.frontend.data; package net.forwardfire.vasc.test.frontend.data;
import java.io.Serializable;
import java.util.Date; import java.util.Date;
import net.forwardfire.vasc.annotations.VascDefaultValue; import net.forwardfire.vasc.annotations.VascDefaultValue;
@ -41,8 +42,9 @@ import net.forwardfire.vasc.validators.VascStringLength;
* @author Willem Cazander * @author Willem Cazander
* @version 1.0 Mar 28, 2007 * @version 1.0 Mar 28, 2007
*/ */
@SuppressWarnings("serial")
@VascEntry(headerName="En een tooltip op het model") @VascEntry(headerName="En een tooltip op het model")
public class TestModelOrder { public class TestModelOrder implements Serializable {
private Integer id = null; private Integer id = null;
private String name = null; private String name = null;

View file

@ -23,6 +23,7 @@
package net.forwardfire.vasc.test.frontend.data; package net.forwardfire.vasc.test.frontend.data;
import java.io.Serializable;
import java.util.Date; import java.util.Date;
import net.forwardfire.vasc.annotations.VascDefaultValue; import net.forwardfire.vasc.annotations.VascDefaultValue;
@ -41,8 +42,9 @@ import net.forwardfire.vasc.validators.VascStringLength;
* @author Willem Cazander * @author Willem Cazander
* @version 1.0 Feb 7, 2012 * @version 1.0 Feb 7, 2012
*/ */
@SuppressWarnings("serial")
@VascEntry(headerName="OrderLine") @VascEntry(headerName="OrderLine")
public class TestModelOrderLine { public class TestModelOrderLine implements Serializable {
private TestModelOrder order = null; private TestModelOrder order = null;
private String name = null; private String name = null;

View file

@ -22,6 +22,7 @@
package net.forwardfire.vasc.test.frontend.data; package net.forwardfire.vasc.test.frontend.data;
import java.io.Serializable;
import java.util.ArrayList; import java.util.ArrayList;
import java.util.Date; import java.util.Date;
import java.util.List; import java.util.List;
@ -45,8 +46,8 @@ import net.forwardfire.vasc.backend.data.BeanVascEntryRecordCreator;
public class TestModelVascDataSource { public class TestModelVascDataSource {
//private List<TestModelOrder> testModels = null; //private List<TestModelOrder> testModels = null;
public ListObjectVascDataSource orderModel = null; public ListObjectVascDataSource<TestModelOrder> orderModel = null;
public ListObjectVascDataSource orderLineModel = null; public ListObjectVascDataSource<TestModelOrderLine> orderLineModel = null;
public TestModelVascDataSource() { public TestModelVascDataSource() {
this(new ArrayList<TestModelOrder>(200),new ArrayList<TestModelOrderLine>(200)); this(new ArrayList<TestModelOrder>(200),new ArrayList<TestModelOrderLine>(200));
@ -86,26 +87,26 @@ public class TestModelVascDataSource {
} }
} }
class ListObjectVascDataSource extends AbstractVascBackend { class ListObjectVascDataSource<DATA_OBJECT extends Serializable> extends AbstractVascBackend<DATA_OBJECT> {
private Class<?> modelClass = null; private Class<?> modelClass = null;
private List<Object> modelList = null; private List<DATA_OBJECT> modelList = null;
private String nullLabel = null; private String nullLabel = null;
private String nullKeyValue = null; private String nullKeyValue = null;
public ListObjectVascDataSource(Class<?> modelClass,List<Object> modelList) { public ListObjectVascDataSource(Class<?> modelClass,List<DATA_OBJECT> modelList) {
this.modelClass=modelClass; this.modelClass=modelClass;
this.modelList=modelList; this.modelList=modelList;
} }
public List<Object> getObjectList() { public List<DATA_OBJECT> getObjectList() {
return modelList; return modelList;
} }
public List<Object> execute(VascBackendState state) throws VascBackendException { public List<DATA_OBJECT> execute(VascBackendState state) throws VascBackendException {
if (state.getDataParameterKeys().isEmpty()==false) { if (state.getDataParameterKeys().isEmpty()==false) {
List<Object> result = new ArrayList<Object>(modelList.size()/2); List<DATA_OBJECT> result = new ArrayList<DATA_OBJECT>(modelList.size()/2);
DefaultElementObjectPropertyValue helper = new DefaultElementObjectPropertyValue(); DefaultElementObjectPropertyValue helper = new DefaultElementObjectPropertyValue();
for (Object row:modelList) { for (DATA_OBJECT row:modelList) {
boolean addRow = true; boolean addRow = true;
for (String key:state.getDataParameterKeys()) { for (String key:state.getDataParameterKeys()) {
Object keyValue = state.getDataParameter(key); Object keyValue = state.getDataParameter(key);
@ -129,26 +130,26 @@ public class TestModelVascDataSource {
} }
return result; return result;
} else { } else {
List<Object> result = new ArrayList<Object>(modelList.size()); List<DATA_OBJECT> result = new ArrayList<DATA_OBJECT>(modelList.size());
for (Object row:modelList) { for (DATA_OBJECT row:modelList) {
result.add(row); result.add(row);
} }
return result; return result;
} }
} }
public void persist(Object object) throws VascBackendException { public void persist(DATA_OBJECT object) throws VascBackendException {
modelList.add(object); modelList.add(object);
} }
public Object merge(Object object) throws VascBackendException { public DATA_OBJECT merge(DATA_OBJECT object) throws VascBackendException {
if(modelList.contains(object)==false) { if(modelList.contains(object)==false) {
modelList.add(object); modelList.add(object);
} }
return object; return object;
} }
public void delete(Object object) throws VascBackendException { public void delete(DATA_OBJECT object) throws VascBackendException {
modelList.remove(object); modelList.remove(object);
} }