2
0
Fork 0

Split backend to backend api.

This commit is contained in:
Willem Cazander 2014-03-02 19:45:22 +01:00
parent 4bd244f4e5
commit a13719f008
116 changed files with 1029 additions and 815 deletions

View file

@ -34,6 +34,7 @@
<module>vasc-core-ejb3-client</module> <module>vasc-core-ejb3-client</module>
<module>vasc-core-ejb3-server</module> <module>vasc-core-ejb3-server</module>
<module>vasc-export</module> <module>vasc-export</module>
<module>vasc-opt</module>
</modules> </modules>
<properties> <properties>
<project.build.sourceEncoding>UTF-8</project.build.sourceEncoding> <project.build.sourceEncoding>UTF-8</project.build.sourceEncoding>

View file

@ -6,6 +6,7 @@
<version>0.4.2-SNAPSHOT</version> <version>0.4.2-SNAPSHOT</version>
</parent> </parent>
<artifactId>vasc-backend</artifactId> <artifactId>vasc-backend</artifactId>
<groupId>net.forwardfire.vasc.backend</groupId>
<packaging>pom</packaging> <packaging>pom</packaging>
<name>vasc-backend</name> <name>vasc-backend</name>
<description>vasc-backend</description> <description>vasc-backend</description>
@ -15,5 +16,6 @@
<module>vasc-backend-mongodb</module> <module>vasc-backend-mongodb</module>
<module>vasc-backend-jdbc</module> <module>vasc-backend-jdbc</module>
<module>vasc-backend-metamodel</module> <module>vasc-backend-metamodel</module>
<module>vasc-backend-api</module>
</modules> </modules>
</project> </project>

View file

@ -0,0 +1,23 @@
<?xml version="1.0" encoding="UTF-8"?>
<projectDescription>
<name>vasc-backend-api</name>
<comment></comment>
<projects>
</projects>
<buildSpec>
<buildCommand>
<name>org.eclipse.jdt.core.javabuilder</name>
<arguments>
</arguments>
</buildCommand>
<buildCommand>
<name>org.eclipse.m2e.core.maven2Builder</name>
<arguments>
</arguments>
</buildCommand>
</buildSpec>
<natures>
<nature>org.eclipse.jdt.core.javanature</nature>
<nature>org.eclipse.m2e.core.maven2Nature</nature>
</natures>
</projectDescription>

View file

@ -0,0 +1,18 @@
<project xmlns="http://maven.apache.org/POM/4.0.0" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsd">
<modelVersion>4.0.0</modelVersion>
<parent>
<groupId>net.forwardfire.vasc.backend</groupId>
<artifactId>vasc-backend</artifactId>
<version>0.4.2-SNAPSHOT</version>
</parent>
<artifactId>vasc-backend-api</artifactId>
<name>vasc-backend-api</name>
<description>vasc-backend-api</description>
<dependencies>
<dependency>
<groupId>org.x4o</groupId>
<artifactId>x4o-driver</artifactId>
<version>${x4o.version}</version>
</dependency>
</dependencies>
</project>

View file

@ -24,9 +24,6 @@ package net.forwardfire.vasc.backend;
import java.util.Map; import java.util.Map;
import net.forwardfire.vasc.core.VascException;
/** /**
* *
* @author Willem Cazander * @author Willem Cazander
@ -110,14 +107,14 @@ abstract public class AbstractVascBackend implements VascBackend {
/** /**
* @see net.forwardfire.vasc.backend.VascBackend#doRecordMoveDownById(java.lang.Object) * @see net.forwardfire.vasc.backend.VascBackend#doRecordMoveDownById(java.lang.Object)
*/ */
public long doRecordMoveDownById(VascBackendState state,Object primaryId) throws VascException { public long doRecordMoveDownById(VascBackendState state,Object primaryId) throws VascBackendException {
return 0l; return 0l;
} }
/** /**
* @see net.forwardfire.vasc.backend.VascBackend#doRecordMoveUpById(java.lang.Object) * @see net.forwardfire.vasc.backend.VascBackend#doRecordMoveUpById(java.lang.Object)
*/ */
public long doRecordMoveUpById(VascBackendState state,Object primaryId) throws VascException { public long doRecordMoveUpById(VascBackendState state,Object primaryId) throws VascBackendException {
return 0l; return 0l;
} }

View file

@ -20,9 +20,8 @@
* SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. * SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
*/ */
package net.forwardfire.vasc.impl; package net.forwardfire.vasc.backend;
import net.forwardfire.vasc.backend.AbstractVascBackendControllerLocal;
/** /**
* DefaultVascBackendController stores the vasc backends. * DefaultVascBackendController stores the vasc backends.

View file

@ -20,9 +20,8 @@
* SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. * SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
*/ */
package net.forwardfire.vasc.impl; package net.forwardfire.vasc.backend;
import net.forwardfire.vasc.backend.AbstractVascBackendState;
/** /**
* Holds the state for the backend * Holds the state for the backend

View file

@ -25,13 +25,6 @@ package net.forwardfire.vasc.backend;
import java.util.List; import java.util.List;
import java.util.Map; import java.util.Map;
import net.forwardfire.vasc.core.VascEntry;
import net.forwardfire.vasc.core.VascEntryField;
import net.forwardfire.vasc.core.entry.VascEntryFieldValue;
import net.forwardfire.vasc.core.entry.VascEntryRecordCreator;
import net.forwardfire.vasc.core.VascException;
/** /**
* *
* @author Willem Cazander * @author Willem Cazander
@ -45,32 +38,30 @@ public interface VascBackend {
public void startBackend(); public void startBackend();
public void stopBackend(); public void stopBackend();
public List<Object> execute(VascBackendState state) throws VascException; public List<Object> execute(VascBackendState state) throws VascBackendException;
public boolean isReadOnly(); public boolean isReadOnly();
public void persist(Object object) throws VascException; public void persist(Object object) throws VascBackendException;
public Object merge(Object object) throws VascException; public Object merge(Object object) throws VascBackendException;
public void delete(Object object) throws VascException; public void delete(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.
* 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.
* @param field
* @return * @return
*/ */
public VascEntryFieldValue provideVascEntryFieldValue(VascEntryField field); public VascEntryFieldValue provideVascEntryFieldValue();
/** /**
* Creates a new RecordCreater obj the the given entry. * Creates a new RecordCreater obj the the given entry.
* 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.
* @param vascEntry
* @return * @return
*/ */
public VascEntryRecordCreator provideVascEntryRecordCreator(VascEntry vascEntry); public VascEntryRecordCreator provideVascEntryRecordCreator();
/** /**
* Defines if the backend supports sorting * Defines if the backend supports sorting
@ -101,8 +92,8 @@ public interface VascBackend {
* @return * @return
*/ */
public boolean isRecordMoveable(); public boolean isRecordMoveable();
public long doRecordMoveUpById(VascBackendState state,Object primaryId) throws VascException; public long doRecordMoveUpById(VascBackendState state,Object primaryId) throws VascBackendException;
public long doRecordMoveDownById(VascBackendState state,Object primaryId) throws VascException; public long doRecordMoveDownById(VascBackendState state,Object primaryId) throws VascBackendException;
public boolean isPageSummary(); public boolean isPageSummary();

View file

@ -20,44 +20,32 @@
* SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. * SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
*/ */
package net.forwardfire.vasc.impl.entry; package net.forwardfire.vasc.backend;
import net.forwardfire.vasc.core.VascEntry;
import net.forwardfire.vasc.core.entry.VascEntryRecordCreator;
import net.forwardfire.vasc.core.VascException;
/** /**
* BeanVascEntryRecordCreator creates an new instance Object from a defined objectClass. * VascBackendException wraps the backend exception.
* *
* @author Willem Cazander * @author Willem Cazander
* @version 1.0 Mar 21, 2007 * @version 1.0 Nov 22, 2013
*/ */
public class BeanVascEntryRecordCreator implements VascEntryRecordCreator { @SuppressWarnings("serial")
public class VascBackendException extends Exception {
private static final long serialVersionUID = 1L;
private Class<?> objectClass = null;
public BeanVascEntryRecordCreator() { public VascBackendException() {
} }
public BeanVascEntryRecordCreator(Class<?> objectClass) { public VascBackendException(String message) {
setObjectClass(objectClass); super(message);
} }
public Object newRecord(VascEntry entry) throws VascException { public VascBackendException(Exception e) {
try { super(e);
return objectClass.newInstance();
} catch (InstantiationException e) {
throw new VascException(e);
} catch (IllegalAccessException e) {
throw new VascException(e);
}
} }
public Class<?> getObjectClass() { public VascBackendException(String message,Exception e) {
return objectClass; super(message,e);
}
public void setObjectClass(Class<?> objectClass) {
this.objectClass=objectClass;
} }
} }

View file

@ -20,13 +20,10 @@
* SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. * SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
*/ */
package net.forwardfire.vasc.core.entry; package net.forwardfire.vasc.backend;
import java.io.Serializable; import java.io.Serializable;
import net.forwardfire.vasc.core.VascEntryField;
import net.forwardfire.vasc.core.VascException;
/** /**
* VascEntryFieldValue * VascEntryFieldValue
@ -36,9 +33,9 @@ import net.forwardfire.vasc.core.VascException;
*/ */
public interface VascEntryFieldValue extends Serializable { public interface VascEntryFieldValue extends Serializable {
public Object getValue(VascEntryField field,Object record) throws VascException; public Object getValue(String backendName,Object record) throws VascBackendException;
public String getDisplayValue(VascEntryField field,Object record) throws VascException; public String getDisplayValue(String backendName,Object record) throws VascBackendException;
public void setValue(VascEntryField field,Object record,Object value) throws VascException; public void setValue(String backendName,Object record,Object value) throws VascBackendException;
} }

View file

@ -20,14 +20,10 @@
* SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. * SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
*/ */
package net.forwardfire.vasc.core.entry; package net.forwardfire.vasc.backend;
import java.io.Serializable; import java.io.Serializable;
import net.forwardfire.vasc.core.VascEntry;
import net.forwardfire.vasc.core.VascException;
/** /**
* *
@ -36,7 +32,7 @@ import net.forwardfire.vasc.core.VascException;
*/ */
public interface VascEntryRecordCreator extends Serializable { public interface VascEntryRecordCreator extends Serializable {
public Object newRecord(VascEntry entry) throws VascException; public Object newRecord() throws VascBackendException;
public Class<?> getObjectClass(); public Class<?> getObjectClass();
} }

View file

@ -22,9 +22,9 @@
package net.forwardfire.vasc.backend.data; package net.forwardfire.vasc.backend.data;
import net.forwardfire.vasc.core.VascEntryField;
import net.forwardfire.vasc.core.entry.VascEntryFieldValue; import net.forwardfire.vasc.backend.VascBackendException;
import net.forwardfire.vasc.core.VascException; import net.forwardfire.vasc.backend.VascEntryFieldValue;
import org.x4o.xml.element.DefaultElementObjectPropertyValue; import org.x4o.xml.element.DefaultElementObjectPropertyValue;
@ -40,34 +40,34 @@ public class BeanVascEntryFieldValue implements VascEntryFieldValue {
private DefaultElementObjectPropertyValue bean = new DefaultElementObjectPropertyValue(); private DefaultElementObjectPropertyValue bean = new DefaultElementObjectPropertyValue();
/** /**
* @see net.forwardfire.vasc.core.entry.VascEntryFieldValue#getValue(net.forwardfire.vasc.core.VascEntryField, java.lang.Object) * @see net.forwardfire.vasc.core.entry.VascEntryFieldValue#getValue(java.lang.String, java.lang.Object)
*/ */
public Object getValue(VascEntryField field, Object record) throws VascException { public Object getValue(String backendName, Object record) throws VascBackendException {
if (field==null) { if (backendName==null) {
throw new NullPointerException("Can't get value of null field."); throw new NullPointerException("Can't get value of null backendName.");
}
if (field.getBackendName()==null) {
throw new NullPointerException("Can't get value of null backendName field.");
} }
if (record==null) { if (record==null) {
throw new NullPointerException("Can't get value of null object."); throw new NullPointerException("Can't get value of null object.");
} }
try { try {
Object o = bean.getProperty(record,field.getBackendName()); Object o = bean.getProperty(record,backendName);
return o; return o;
} catch (Exception e) { } catch (Exception e) {
throw new VascException(e); throw new VascBackendException(e);
} }
} }
/** /**
* @see net.forwardfire.vasc.core.entry.VascEntryFieldValue#getDisplayValue(net.forwardfire.vasc.core.VascEntryField, java.lang.Object) * @see net.forwardfire.vasc.core.entry.VascEntryFieldValue#getDisplayValue(java.lang.String, java.lang.Object)
*/ */
public String getDisplayValue(VascEntryField field, Object record) throws VascException { public String getDisplayValue(String backendName, Object record) throws VascBackendException {
Object value = getValue(field,record); Object value = getValue(backendName,record);
if (value==null) { if (value==null) {
return ""; return "";
} }
return value.toString();
/* TODO: move
if (field.getDisplayName()==null) { if (field.getDisplayName()==null) {
if (value instanceof String) { if (value instanceof String) {
return (String)value; return (String)value;
@ -81,27 +81,25 @@ public class BeanVascEntryFieldValue implements VascEntryFieldValue {
} }
return ""+result; return ""+result;
} catch (Exception e) { } catch (Exception e) {
throw new VascException(e); throw new VascBackendException(e);
} }
*/
} }
/** /**
* @see net.forwardfire.vasc.core.entry.VascEntryFieldValue#setValue(net.forwardfire.vasc.core.VascEntryField, java.lang.Object, java.lang.Object) * @see net.forwardfire.vasc.core.entry.VascEntryFieldValue#setValue(java.lang.String, java.lang.Object, java.lang.Object)
*/ */
public void setValue(VascEntryField field, Object record,Object value) throws VascException { public void setValue(String backendName, Object record,Object value) throws VascBackendException {
if (field==null) { if (backendName==null) {
throw new NullPointerException("Can't set value of null field."); throw new NullPointerException("Can't set value of null backendName.");
}
if (field.getBackendName()==null) {
throw new NullPointerException("Can't set value of null backendName field.");
} }
if (record==null) { if (record==null) {
throw new NullPointerException("Can't set value of null object."); throw new NullPointerException("Can't set value of null object.");
} }
try { try {
bean.setProperty(record, field.getBackendName(), value); bean.setProperty(record, backendName, value);
} catch (Exception e) { } catch (Exception e) {
throw new VascException(e); throw new VascBackendException(e);
} }
} }
} }

View file

@ -22,9 +22,9 @@
package net.forwardfire.vasc.backend.data; package net.forwardfire.vasc.backend.data;
import net.forwardfire.vasc.core.VascEntry; import net.forwardfire.vasc.backend.VascBackendException;
import net.forwardfire.vasc.core.entry.VascEntryRecordCreator; import net.forwardfire.vasc.backend.VascEntryRecordCreator;
import net.forwardfire.vasc.core.VascException;
/** /**
* BeanVascEntryRecordCreator creates a new backend record based on class object. * BeanVascEntryRecordCreator creates a new backend record based on class object.
@ -48,13 +48,13 @@ public class BeanVascEntryRecordCreator implements VascEntryRecordCreator {
return resultClass; return resultClass;
} }
public Object newRecord(VascEntry entry) throws VascException { public Object newRecord() throws VascBackendException {
try { try {
return resultClass.newInstance(); return resultClass.newInstance();
} catch (InstantiationException e) { } catch (InstantiationException e) {
throw new VascException(e); throw new VascBackendException(e);
} catch (IllegalAccessException e) { } catch (IllegalAccessException e) {
throw new VascException(e); throw new VascBackendException(e);
} }
} }
} }

View file

@ -24,9 +24,9 @@ package net.forwardfire.vasc.backend.data;
import java.util.Map; import java.util.Map;
import net.forwardfire.vasc.core.VascEntryField; import net.forwardfire.vasc.backend.VascBackendException;
import net.forwardfire.vasc.core.entry.VascEntryFieldValue; import net.forwardfire.vasc.backend.VascEntryFieldValue;
import net.forwardfire.vasc.core.VascException;
/** /**
* MapVascEntryFieldValue provides get/set support on Map record object. * MapVascEntryFieldValue provides get/set support on Map record object.
@ -39,28 +39,25 @@ public class MapVascEntryFieldValue implements VascEntryFieldValue {
private static final long serialVersionUID = 1L; private static final long serialVersionUID = 1L;
/** /**
* @see net.forwardfire.vasc.core.entry.VascEntryFieldValue#getValue(net.forwardfire.vasc.core.VascEntryField, java.lang.Object) * @see net.forwardfire.vasc.core.entry.VascEntryFieldValue#getValue(java.lang.String, java.lang.Object)
*/ */
@SuppressWarnings("unchecked") @SuppressWarnings("unchecked")
public Object getValue(VascEntryField field, Object record) throws VascException { public Object getValue(String backendName, Object record) throws VascBackendException {
if (field==null) { if (backendName==null) {
throw new NullPointerException("Can't get value of null field.");
}
if (field.getBackendName()==null) {
throw new NullPointerException("Can't get value of null backendName field."); throw new NullPointerException("Can't get value of null backendName field.");
} }
if (record==null) { if (record==null) {
throw new NullPointerException("Can't get value of null object."); throw new NullPointerException("Can't get value of null object.");
} }
Map<String,Object> map = (Map<String,Object>)record; Map<String,Object> map = (Map<String,Object>)record;
Object fieldValue = map.get(field.getBackendName()); Object fieldValue = map.get(backendName);
return fieldValue; return fieldValue;
} }
/** /**
* @see net.forwardfire.vasc.core.entry.VascEntryFieldValue#getDisplayValue(net.forwardfire.vasc.core.VascEntryField, java.lang.Object) * @see net.forwardfire.vasc.core.entry.VascEntryFieldValue#getDisplayValue(net.forwardfire.vasc.core.VascEntryField, java.lang.Object)
*/ */
public String getDisplayValue(VascEntryField field, Object record) throws VascException { public String getDisplayValue(String field, Object record) throws VascBackendException {
Object fieldValue = getValue(field,record); Object fieldValue = getValue(field,record);
if (fieldValue==null) { if (fieldValue==null) {
fieldValue = ""; fieldValue = "";
@ -69,12 +66,12 @@ public class MapVascEntryFieldValue implements VascEntryFieldValue {
} }
/** /**
* @see net.forwardfire.vasc.core.entry.VascEntryFieldValue#setValue(net.forwardfire.vasc.core.VascEntryField, java.lang.Object, java.lang.Object) * @see net.forwardfire.vasc.core.entry.VascEntryFieldValue#setValue(java.lang.String, java.lang.Object, java.lang.Object)
*/ */
@SuppressWarnings("unchecked") @SuppressWarnings("unchecked")
public void setValue(VascEntryField field, Object record,Object value) throws VascException { public void setValue(String backendName, Object record,Object value) throws VascBackendException {
Map<String,Object> map = (Map<String,Object>)record; Map<String,Object> map = (Map<String,Object>)record;
map.put(field.getBackendName(), value); map.put(backendName, value);
} }
} }

View file

@ -25,9 +25,9 @@ package net.forwardfire.vasc.backend.data;
import java.util.HashMap; import java.util.HashMap;
import java.util.Map; import java.util.Map;
import net.forwardfire.vasc.core.VascEntry; import net.forwardfire.vasc.backend.VascBackendException;
import net.forwardfire.vasc.core.entry.VascEntryRecordCreator; import net.forwardfire.vasc.backend.VascEntryRecordCreator;
import net.forwardfire.vasc.core.VascException;
/** /**
* MapVascEntryRecordCreator creates a new HashMap for Map based record backends. * MapVascEntryRecordCreator creates a new HashMap for Map based record backends.
@ -43,7 +43,7 @@ public class MapVascEntryRecordCreator implements VascEntryRecordCreator {
return Map.class; return Map.class;
} }
public Object newRecord(VascEntry entry) throws VascException { public Object newRecord() throws VascBackendException {
return new HashMap<String,Object>(10); return new HashMap<String,Object>(10);
} }
} }

View file

@ -2,7 +2,7 @@
<modelVersion>4.0.0</modelVersion> <modelVersion>4.0.0</modelVersion>
<parent> <parent>
<artifactId>vasc-backend</artifactId> <artifactId>vasc-backend</artifactId>
<groupId>net.forwardfire.vasc</groupId> <groupId>net.forwardfire.vasc.backend</groupId>
<version>0.4.2-SNAPSHOT</version> <version>0.4.2-SNAPSHOT</version>
<relativePath>..</relativePath> <relativePath>..</relativePath>
</parent> </parent>
@ -11,8 +11,13 @@
<description>vasc-backend-jdbc</description> <description>vasc-backend-jdbc</description>
<dependencies> <dependencies>
<dependency> <dependency>
<groupId>net.forwardfire.vasc</groupId> <groupId>net.forwardfire.vasc.backend</groupId>
<artifactId>vasc-core</artifactId> <artifactId>vasc-backend-api</artifactId>
<version>${project.version}</version>
</dependency>
<dependency>
<groupId>net.forwardfire.vasc.lib</groupId>
<artifactId>vasc-lib-xpql</artifactId>
<version>${project.version}</version> <version>${project.version}</version>
</dependency> </dependency>
</dependencies> </dependencies>

View file

@ -31,15 +31,12 @@ import java.util.List;
import java.util.Map; 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.VascBackendState; import net.forwardfire.vasc.backend.VascBackendState;
import net.forwardfire.vasc.backend.VascEntryFieldValue;
import net.forwardfire.vasc.backend.VascEntryRecordCreator;
import net.forwardfire.vasc.backend.data.MapVascEntryFieldValue; import net.forwardfire.vasc.backend.data.MapVascEntryFieldValue;
import net.forwardfire.vasc.backend.data.MapVascEntryRecordCreator; import net.forwardfire.vasc.backend.data.MapVascEntryRecordCreator;
import net.forwardfire.vasc.core.VascEntry;
import net.forwardfire.vasc.core.VascEntryField;
import net.forwardfire.vasc.core.entry.VascEntryFieldValue;
import net.forwardfire.vasc.core.entry.VascEntryRecordCreator;
import net.forwardfire.vasc.core.VascException;
/** /**
@ -83,7 +80,7 @@ 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 VascException { public List<Object> execute(VascBackendState state) throws VascBackendException {
JdbcConnectionProvider prov = getJdbcConnectionProvider(); JdbcConnectionProvider prov = getJdbcConnectionProvider();
List<Object> result = new ArrayList<Object>(50); List<Object> result = new ArrayList<Object>(50);
Connection connection = null; Connection connection = null;
@ -103,7 +100,7 @@ public class JdbcVascBackend extends AbstractVascBackend {
result.add(map); result.add(map);
} }
} catch (Exception e) { } catch (Exception e) {
throw new VascException(e); throw new VascBackendException(e);
} finally { } finally {
if (connection!=null) { if (connection!=null) {
try { try {
@ -118,33 +115,33 @@ 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 VascException { public Object merge(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 VascException { public void persist(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 VascException { public void delete(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(VascEntryField field) { public VascEntryFieldValue provideVascEntryFieldValue() {
return new MapVascEntryFieldValue(); return new MapVascEntryFieldValue();
} }
/** /**
* @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(VascEntry vascEntry) { public VascEntryRecordCreator provideVascEntryRecordCreator() {
return new MapVascEntryRecordCreator(); return new MapVascEntryRecordCreator();
} }

View file

@ -31,14 +31,12 @@ import java.util.List;
import java.util.Map; 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.VascBackendState; import net.forwardfire.vasc.backend.VascBackendState;
import net.forwardfire.vasc.backend.VascEntryFieldValue;
import net.forwardfire.vasc.backend.VascEntryRecordCreator;
import net.forwardfire.vasc.backend.data.MapVascEntryFieldValue; import net.forwardfire.vasc.backend.data.MapVascEntryFieldValue;
import net.forwardfire.vasc.backend.data.MapVascEntryRecordCreator; import net.forwardfire.vasc.backend.data.MapVascEntryRecordCreator;
import net.forwardfire.vasc.core.VascEntry;
import net.forwardfire.vasc.core.VascEntryField;
import net.forwardfire.vasc.core.entry.VascEntryFieldValue;
import net.forwardfire.vasc.core.entry.VascEntryRecordCreator;
import net.forwardfire.vasc.core.VascException;
import net.forwardfire.vasc.xpql.query.QueryParameterValue; import net.forwardfire.vasc.xpql.query.QueryParameterValue;
@ -94,7 +92,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 VascException { public List<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);
@ -126,7 +124,7 @@ public class JdbcVascBackendXpql extends AbstractVascBackend {
} }
return result; return result;
} catch (Exception e) { } catch (Exception e) {
throw new VascException(e); throw new VascBackendException(e);
} finally { } finally {
if (c!=null) { if (c!=null) {
try { try {
@ -140,33 +138,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 VascException { public Object merge(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 VascException { public void persist(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 VascException { public void delete(Object object) throws VascBackendException {
} }
/** /**
* @see net.forwardfire.vasc.backend.VascBackend#provideVascEntryFieldValue(net.forwardfire.vasc.core.VascEntryField) * @see net.forwardfire.vasc.backend.VascBackend#provideVascEntryFieldValue()
*/ */
public VascEntryFieldValue provideVascEntryFieldValue(VascEntryField field) { public VascEntryFieldValue provideVascEntryFieldValue() {
return new MapVascEntryFieldValue(); return new MapVascEntryFieldValue();
} }
/** /**
* @see net.forwardfire.vasc.backend.VascBackend#provideVascEntryRecordCreator(net.forwardfire.vasc.core.VascEntry) * @see net.forwardfire.vasc.backend.VascBackend#provideVascEntryRecordCreator()
*/ */
public VascEntryRecordCreator provideVascEntryRecordCreator(VascEntry vascEntry) { public VascEntryRecordCreator provideVascEntryRecordCreator() {
return new MapVascEntryRecordCreator(); return new MapVascEntryRecordCreator();
} }
} }

View file

@ -2,7 +2,7 @@
<modelVersion>4.0.0</modelVersion> <modelVersion>4.0.0</modelVersion>
<parent> <parent>
<artifactId>vasc-backend</artifactId> <artifactId>vasc-backend</artifactId>
<groupId>net.forwardfire.vasc</groupId> <groupId>net.forwardfire.vasc.backend</groupId>
<version>0.4.2-SNAPSHOT</version> <version>0.4.2-SNAPSHOT</version>
</parent> </parent>
<artifactId>vasc-backend-jpa</artifactId> <artifactId>vasc-backend-jpa</artifactId>
@ -10,8 +10,13 @@
<description>vasc-backend-jpa</description> <description>vasc-backend-jpa</description>
<dependencies> <dependencies>
<dependency> <dependency>
<groupId>net.forwardfire.vasc</groupId> <groupId>net.forwardfire.vasc.backend</groupId>
<artifactId>vasc-core</artifactId> <artifactId>vasc-backend-api</artifactId>
<version>${project.version}</version>
</dependency>
<dependency>
<groupId>net.forwardfire.vasc.lib</groupId>
<artifactId>vasc-lib-xpql</artifactId>
<version>${project.version}</version> <version>${project.version}</version>
</dependency> </dependency>
<dependency> <dependency>

View file

@ -23,7 +23,7 @@
package net.forwardfire.vasc.backends.jpa; package net.forwardfire.vasc.backends.jpa;
import net.forwardfire.vasc.backend.AbstractVascBackend; import net.forwardfire.vasc.backend.AbstractVascBackend;
import net.forwardfire.vasc.core.VascException; import net.forwardfire.vasc.backend.VascBackendException;
import org.hibernate.Session; import org.hibernate.Session;
@ -41,7 +41,7 @@ abstract public class AbstractHibernateVascBackend extends AbstractVascBackend
*/ */
abstract Session getHibernateSession(); abstract Session getHibernateSession();
public void persist(Object object) throws VascException { public void persist(Object object) throws VascBackendException {
Session s = getHibernateSession(); Session s = getHibernateSession();
try { try {
s.getTransaction().begin(); s.getTransaction().begin();
@ -57,7 +57,7 @@ abstract public class AbstractHibernateVascBackend extends AbstractVascBackend
} }
} }
public Object merge(Object object) throws VascException { public Object merge(Object object) throws VascBackendException {
Session s = getHibernateSession(); Session s = getHibernateSession();
try { try {
s.getTransaction().begin(); s.getTransaction().begin();
@ -74,7 +74,7 @@ abstract public class AbstractHibernateVascBackend extends AbstractVascBackend
} }
} }
public void delete(Object object) throws VascException { public void delete(Object object) throws VascBackendException {
Session s = getHibernateSession(); Session s = getHibernateSession();
try { try {
s.getTransaction().begin(); s.getTransaction().begin();

View file

@ -22,13 +22,10 @@
package net.forwardfire.vasc.backends.jpa; package net.forwardfire.vasc.backends.jpa;
import java.lang.reflect.Method;
import javax.persistence.EntityManager; import javax.persistence.EntityManager;
import net.forwardfire.vasc.backend.AbstractVascBackend; import net.forwardfire.vasc.backend.AbstractVascBackend;
import net.forwardfire.vasc.core.VascException; import net.forwardfire.vasc.backend.VascBackendException;
/** /**
* *
@ -41,7 +38,7 @@ abstract public class AbstractPersistenceVascBackend extends AbstractVascBackend
abstract EntityManager getEntityManager(); abstract EntityManager getEntityManager();
public void persist(Object object) throws VascException { public void persist(Object object) throws VascBackendException {
EntityManager s = getEntityManager(); EntityManager s = getEntityManager();
try { try {
if (emTransaction) { if (emTransaction) {
@ -58,7 +55,7 @@ abstract public class AbstractPersistenceVascBackend extends AbstractVascBackend
} }
} }
public Object merge(Object object) throws VascException { public Object merge(Object object) throws VascBackendException {
EntityManager s = getEntityManager(); EntityManager s = getEntityManager();
try { try {
if (emTransaction) { if (emTransaction) {
@ -76,7 +73,7 @@ abstract public class AbstractPersistenceVascBackend extends AbstractVascBackend
} }
} }
public void delete(Object object) throws VascException { public void delete(Object object) throws VascBackendException {
EntityManager s = getEntityManager(); EntityManager s = getEntityManager();
try { try {
if (emTransaction) { if (emTransaction) {

View file

@ -24,14 +24,12 @@ package net.forwardfire.vasc.backends.jpa;
import java.util.List; import java.util.List;
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.VascEntryRecordCreator;
import net.forwardfire.vasc.backend.data.BeanVascEntryFieldValue; import net.forwardfire.vasc.backend.data.BeanVascEntryFieldValue;
import net.forwardfire.vasc.backend.data.BeanVascEntryRecordCreator; import net.forwardfire.vasc.backend.data.BeanVascEntryRecordCreator;
import net.forwardfire.vasc.core.VascEntry;
import net.forwardfire.vasc.core.VascEntryField;
import net.forwardfire.vasc.core.entry.VascEntryFieldValue;
import net.forwardfire.vasc.core.entry.VascEntryRecordCreator;
import net.forwardfire.vasc.core.VascException;
import net.forwardfire.vasc.xpql.query.QueryParameterValue; import net.forwardfire.vasc.xpql.query.QueryParameterValue;
import org.hibernate.Hibernate; import org.hibernate.Hibernate;
@ -75,7 +73,7 @@ public class XpqlHibernateVascBackend extends AbstractHibernateVascBackend {
} }
@SuppressWarnings("unchecked") @SuppressWarnings("unchecked")
public List<Object> execute(VascBackendState state) throws VascException { public List<Object> execute(VascBackendState state) throws VascBackendException {
// Copy parameters // Copy parameters
for (String key:state.getDataParameterKeys()) { for (String key:state.getDataParameterKeys()) {
@ -116,17 +114,17 @@ public class XpqlHibernateVascBackend extends AbstractHibernateVascBackend {
} }
/** /**
* @see net.forwardfire.vasc.backend.VascBackend#provideVascEntryFieldValue(net.forwardfire.vasc.core.VascEntryField) * @see net.forwardfire.vasc.backend.VascBackend#provideVascEntryFieldValue()
*/ */
public VascEntryFieldValue provideVascEntryFieldValue(VascEntryField field) { public VascEntryFieldValue provideVascEntryFieldValue() {
BeanVascEntryFieldValue result = new BeanVascEntryFieldValue(); BeanVascEntryFieldValue result = new BeanVascEntryFieldValue();
return result; return result;
} }
/** /**
* @see net.forwardfire.vasc.backend.VascBackend#provideVascEntryRecordCreator(net.forwardfire.vasc.core.VascEntry) * @see net.forwardfire.vasc.backend.VascBackend#provideVascEntryRecordCreator()
*/ */
public VascEntryRecordCreator provideVascEntryRecordCreator(VascEntry vascEntry) { public VascEntryRecordCreator provideVascEntryRecordCreator() {
return new BeanVascEntryRecordCreator(resultClass); return new BeanVascEntryRecordCreator(resultClass);
} }
@ -230,7 +228,7 @@ public class XpqlHibernateVascBackend extends AbstractHibernateVascBackend {
* @see net.forwardfire.vasc.backend.AbstractVascBackend#doRecordMoveDownById(java.lang.Object) * @see net.forwardfire.vasc.backend.AbstractVascBackend#doRecordMoveDownById(java.lang.Object)
*/ */
@Override @Override
public long doRecordMoveDownById(VascBackendState state,Object primaryId) throws VascException { public long doRecordMoveDownById(VascBackendState state,Object primaryId) throws VascBackendException {
long result = 0l; long result = 0l;
if (queryMoveDown!=null) { if (queryMoveDown!=null) {
Session s = getHibernateSession(); Session s = getHibernateSession();
@ -299,7 +297,7 @@ public class XpqlHibernateVascBackend extends AbstractHibernateVascBackend {
* @see net.forwardfire.vasc.backend.AbstractVascBackend#doRecordMoveUpById(java.lang.Object) * @see net.forwardfire.vasc.backend.AbstractVascBackend#doRecordMoveUpById(java.lang.Object)
*/ */
@Override @Override
public long doRecordMoveUpById(VascBackendState state,Object primaryId) throws VascException { public long doRecordMoveUpById(VascBackendState state,Object primaryId) throws VascBackendException {
long result = 0l; long result = 0l;
if (queryMoveUp!=null) { if (queryMoveUp!=null) {
Session s = getHibernateSession(); Session s = getHibernateSession();

View file

@ -27,14 +27,12 @@ import java.util.List;
import javax.persistence.EntityManager; import javax.persistence.EntityManager;
import javax.persistence.Query; import javax.persistence.Query;
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.VascEntryRecordCreator;
import net.forwardfire.vasc.backend.data.BeanVascEntryFieldValue; import net.forwardfire.vasc.backend.data.BeanVascEntryFieldValue;
import net.forwardfire.vasc.backend.data.BeanVascEntryRecordCreator; import net.forwardfire.vasc.backend.data.BeanVascEntryRecordCreator;
import net.forwardfire.vasc.core.VascEntry;
import net.forwardfire.vasc.core.VascEntryField;
import net.forwardfire.vasc.core.entry.VascEntryFieldValue;
import net.forwardfire.vasc.core.entry.VascEntryRecordCreator;
import net.forwardfire.vasc.core.VascException;
import net.forwardfire.vasc.xpql.query.QueryParameterValue; import net.forwardfire.vasc.xpql.query.QueryParameterValue;
@ -78,7 +76,7 @@ public class XpqlPersistanceVascBackend extends AbstractPersistenceVascBackend
@SuppressWarnings("unchecked") @SuppressWarnings("unchecked")
public List<Object> execute(VascBackendState state) throws VascException { public List<Object> execute(VascBackendState state) throws VascBackendException {
// Copy parameters // Copy parameters
for (String key:state.getDataParameterKeys()) { for (String key:state.getDataParameterKeys()) {
@ -121,17 +119,17 @@ public class XpqlPersistanceVascBackend extends AbstractPersistenceVascBackend
} }
/** /**
* @see net.forwardfire.vasc.backend.VascBackend#provideVascEntryFieldValue(net.forwardfire.vasc.core.VascEntryField) * @see net.forwardfire.vasc.backend.VascBackend#provideVascEntryFieldValue()
*/ */
public VascEntryFieldValue provideVascEntryFieldValue(VascEntryField field) { public VascEntryFieldValue provideVascEntryFieldValue() {
VascEntryFieldValue result = new BeanVascEntryFieldValue(); VascEntryFieldValue result = new BeanVascEntryFieldValue();
return result; return result;
} }
/** /**
* @see net.forwardfire.vasc.backend.VascBackend#provideVascEntryRecordCreator(net.forwardfire.vasc.core.VascEntry) * @see net.forwardfire.vasc.backend.VascBackend#provideVascEntryRecordCreator()
*/ */
public VascEntryRecordCreator provideVascEntryRecordCreator(VascEntry vascEntry) { public VascEntryRecordCreator provideVascEntryRecordCreator() {
VascEntryRecordCreator result = new BeanVascEntryRecordCreator(resultClass); VascEntryRecordCreator result = new BeanVascEntryRecordCreator(resultClass);
return result; return result;
} }
@ -236,7 +234,7 @@ public class XpqlPersistanceVascBackend extends AbstractPersistenceVascBackend
* @see net.forwardfire.vasc.core.AbstractVascBackend#doRecordMoveDownById(VascBackendState state,java.lang.Object) * @see net.forwardfire.vasc.core.AbstractVascBackend#doRecordMoveDownById(VascBackendState state,java.lang.Object)
*/ */
@Override @Override
public long doRecordMoveDownById(VascBackendState state,Object primaryId) throws VascException { public long doRecordMoveDownById(VascBackendState state,Object primaryId) throws VascBackendException {
long result = 0l; long result = 0l;
if (queryMoveDown!=null) { if (queryMoveDown!=null) {
EntityManager em = getEntityManager(); EntityManager em = getEntityManager();
@ -299,7 +297,7 @@ public class XpqlPersistanceVascBackend extends AbstractPersistenceVascBackend
* @see net.forwardfire.vasc.core.AbstractVascBackend#doRecordMoveUpById(VascBackendState state,java.lang.Object) * @see net.forwardfire.vasc.core.AbstractVascBackend#doRecordMoveUpById(VascBackendState state,java.lang.Object)
*/ */
@Override @Override
public long doRecordMoveUpById(VascBackendState state,Object primaryId) throws VascException { public long doRecordMoveUpById(VascBackendState state,Object primaryId) throws VascBackendException {
long result = 0l; long result = 0l;
if (queryMoveUp!=null) { if (queryMoveUp!=null) {
EntityManager em = getEntityManager(); EntityManager em = getEntityManager();

View file

@ -2,7 +2,7 @@
<modelVersion>4.0.0</modelVersion> <modelVersion>4.0.0</modelVersion>
<parent> <parent>
<artifactId>vasc-backend</artifactId> <artifactId>vasc-backend</artifactId>
<groupId>net.forwardfire.vasc</groupId> <groupId>net.forwardfire.vasc.backend</groupId>
<version>0.4.2-SNAPSHOT</version> <version>0.4.2-SNAPSHOT</version>
</parent> </parent>
<artifactId>vasc-backend-ldap</artifactId> <artifactId>vasc-backend-ldap</artifactId>
@ -10,8 +10,8 @@
<description>vasc-backend-ldap</description> <description>vasc-backend-ldap</description>
<dependencies> <dependencies>
<dependency> <dependency>
<groupId>net.forwardfire.vasc</groupId> <groupId>net.forwardfire.vasc.backend</groupId>
<artifactId>vasc-core</artifactId> <artifactId>vasc-backend-api</artifactId>
<version>${project.version}</version> <version>${project.version}</version>
</dependency> </dependency>
<dependency> <dependency>

View file

@ -29,15 +29,12 @@ import java.util.List;
import java.util.Map; 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.VascBackendState; import net.forwardfire.vasc.backend.VascBackendState;
import net.forwardfire.vasc.backend.VascEntryFieldValue;
import net.forwardfire.vasc.backend.VascEntryRecordCreator;
import net.forwardfire.vasc.backend.data.MapVascEntryFieldValue; import net.forwardfire.vasc.backend.data.MapVascEntryFieldValue;
import net.forwardfire.vasc.backend.data.MapVascEntryRecordCreator; import net.forwardfire.vasc.backend.data.MapVascEntryRecordCreator;
import net.forwardfire.vasc.core.VascEntry;
import net.forwardfire.vasc.core.VascEntryField;
import net.forwardfire.vasc.core.entry.VascEntryFieldValue;
import net.forwardfire.vasc.core.entry.VascEntryRecordCreator;
import net.forwardfire.vasc.core.VascException;
import com.novell.ldap.LDAPAttribute; import com.novell.ldap.LDAPAttribute;
import com.novell.ldap.LDAPAttributeSet; import com.novell.ldap.LDAPAttributeSet;
@ -53,7 +50,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 {
private LdapConnectionProvider ldapConnectionProvider = null; private LdapConnectionProvider ldapConnectionProvider = null;
@ -81,7 +78,7 @@ 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 VascException { public List<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<Object> result = new ArrayList<Object>(50);
@ -125,7 +122,7 @@ public class LdapVascBackend extends AbstractVascBackend {
result.add(map); result.add(map);
} }
} catch (Exception e) { } catch (Exception e) {
throw new VascException(e); throw new VascBackendException(e);
} finally { } finally {
if (connection!=null) { if (connection!=null) {
connection.clone(); connection.clone();
@ -137,7 +134,7 @@ 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 VascException { public Object merge(Object object) throws VascBackendException {
LdapConnectionProvider prov = getLdapConnectionProvider(); LdapConnectionProvider prov = getLdapConnectionProvider();
LDAPConnection connection = prov.getLdapConnection(); LDAPConnection connection = prov.getLdapConnection();
try { try {
@ -209,7 +206,7 @@ public class LdapVascBackend extends AbstractVascBackend {
return object; return object;
} catch (Exception e) { } catch (Exception e) {
throw new VascException(e); throw new VascBackendException(e);
} finally { } finally {
if (connection!=null) { if (connection!=null) {
connection.clone(); connection.clone();
@ -220,7 +217,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 VascException { public void persist(Object object) throws VascBackendException {
Map<String,Object> map = (Map)object; Map<String,Object> map = (Map)object;
LdapConnectionProvider prov = getLdapConnectionProvider(); LdapConnectionProvider prov = getLdapConnectionProvider();
LDAPConnection connection = prov.getLdapConnection(); LDAPConnection connection = prov.getLdapConnection();
@ -246,7 +243,7 @@ public class LdapVascBackend extends AbstractVascBackend {
} }
connection.add(entry); connection.add(entry);
} catch (Exception e) { } catch (Exception e) {
throw new VascException(e); throw new VascBackendException(e);
} finally { } finally {
if (connection!=null) { if (connection!=null) {
connection.clone(); connection.clone();
@ -257,7 +254,7 @@ 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 VascException { public void delete(Object object) throws VascBackendException {
LdapConnectionProvider prov = getLdapConnectionProvider(); LdapConnectionProvider prov = getLdapConnectionProvider();
LDAPConnection connection = prov.getLdapConnection(); LDAPConnection connection = prov.getLdapConnection();
try { try {
@ -280,7 +277,7 @@ public class LdapVascBackend extends AbstractVascBackend {
LDAPEntry entry = searchResults.next(); LDAPEntry entry = searchResults.next();
connection.delete(entry.getDN()); connection.delete(entry.getDN());
} catch (Exception e) { } catch (Exception e) {
throw new VascException(e); throw new VascBackendException(e);
} finally { } finally {
if (connection!=null) { if (connection!=null) {
connection.clone(); connection.clone();
@ -289,16 +286,16 @@ public class LdapVascBackend extends AbstractVascBackend {
} }
/** /**
* @see net.forwardfire.vasc.backend.VascBackend#provideVascEntryRecordCreator(net.forwardfire.vasc.core.VascEntry) * @see net.forwardfire.vasc.backend.VascBackend#provideVascEntryRecordCreator()
*/ */
public VascEntryRecordCreator provideVascEntryRecordCreator(VascEntry vascEntry) { public VascEntryRecordCreator provideVascEntryRecordCreator() {
return new MapVascEntryRecordCreator(); return new MapVascEntryRecordCreator();
} }
/** /**
* @see net.forwardfire.vasc.backend.VascBackend#provideVascEntryFieldValue(net.forwardfire.vasc.core.VascEntryField) * @see net.forwardfire.vasc.backend.VascBackend#provideVascEntryFieldValue()
*/ */
public VascEntryFieldValue provideVascEntryFieldValue(VascEntryField field) { public VascEntryFieldValue provideVascEntryFieldValue() {
return new MapVascEntryFieldValue(); return new MapVascEntryFieldValue();
} }

View file

@ -2,7 +2,7 @@
<modelVersion>4.0.0</modelVersion> <modelVersion>4.0.0</modelVersion>
<parent> <parent>
<artifactId>vasc-backend</artifactId> <artifactId>vasc-backend</artifactId>
<groupId>net.forwardfire.vasc</groupId> <groupId>net.forwardfire.vasc.backend</groupId>
<version>0.4.2-SNAPSHOT</version> <version>0.4.2-SNAPSHOT</version>
<relativePath>..</relativePath> <relativePath>..</relativePath>
</parent> </parent>
@ -11,8 +11,8 @@
<description>vasc-backend-metamodel</description> <description>vasc-backend-metamodel</description>
<dependencies> <dependencies>
<dependency> <dependency>
<groupId>net.forwardfire.vasc</groupId> <groupId>net.forwardfire.vasc.backend</groupId>
<artifactId>vasc-core</artifactId> <artifactId>vasc-backend-api</artifactId>
<version>${project.version}</version> <version>${project.version}</version>
</dependency> </dependency>
<dependency> <dependency>

View file

@ -43,16 +43,14 @@ import org.eobjects.metamodel.schema.Schema;
import org.eobjects.metamodel.schema.Table; import org.eobjects.metamodel.schema.Table;
import net.forwardfire.vasc.backend.AbstractVascBackend; import net.forwardfire.vasc.backend.AbstractVascBackend;
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.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; import net.forwardfire.vasc.backend.metamodel.crud.UpdateableRow;
import net.forwardfire.vasc.backend.metamodel.crud.CrudDataContextImpl; import net.forwardfire.vasc.backend.metamodel.crud.CrudDataContextImpl;
import net.forwardfire.vasc.backend.metamodel.crud.UpdateableRowMapImpl; import net.forwardfire.vasc.backend.metamodel.crud.UpdateableRowMapImpl;
import net.forwardfire.vasc.core.VascEntry;
import net.forwardfire.vasc.core.VascEntryField;
import net.forwardfire.vasc.core.entry.VascEntryFieldValue;
import net.forwardfire.vasc.core.entry.VascEntryRecordCreator;
import net.forwardfire.vasc.core.VascException;
/** /**
* MetaModelVascBackend provides vasc backend for metamodel. * MetaModelVascBackend provides vasc backend for metamodel.
@ -212,11 +210,11 @@ public class MetaModelVascBackend extends AbstractVascBackend {
return q; return q;
} }
public List<Object> execute(VascBackendState state) throws VascException { public List<Object> 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) {
throw new VascException("Could not get meta table for: '"+table+"'."); throw new VascBackendException("Could not get meta table for: '"+table+"'.");
} }
Query q = createFilterQuery(state,t,false); Query q = createFilterQuery(state,t,false);
if (isSortable() && state.getSortField() != null) { if (isSortable() && state.getSortField() != null) {
@ -265,32 +263,32 @@ public class MetaModelVascBackend extends AbstractVascBackend {
return result; return result;
} }
public void persist(Object object) throws VascException { public void persist(Object 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 VascException { public Object merge(Object 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 VascException { public void delete(Object object) throws VascBackendException {
if (crudDataContext==null) { if (crudDataContext==null) {
return; return;
} }
crudDataContext.delete((UpdateableRow) object); crudDataContext.delete((UpdateableRow) object);
} }
public VascEntryFieldValue provideVascEntryFieldValue(VascEntryField field) { public VascEntryFieldValue provideVascEntryFieldValue() {
return new RowVascEntryFieldValue(); return new RowVascEntryFieldValue();
} }
public VascEntryRecordCreator provideVascEntryRecordCreator(VascEntry vascEntry) { public VascEntryRecordCreator provideVascEntryRecordCreator() {
return new RowVascEntryRecordCreator(crudDataContext,crudDataContext.getDefaultSchema().getTableByName(table)); return new RowVascEntryRecordCreator(crudDataContext,crudDataContext.getDefaultSchema().getTableByName(table));
} }

View file

@ -3,34 +3,30 @@ package net.forwardfire.vasc.backend.metamodel;
import org.eobjects.metamodel.data.Row; import org.eobjects.metamodel.data.Row;
import org.eobjects.metamodel.query.SelectItem; import org.eobjects.metamodel.query.SelectItem;
import net.forwardfire.vasc.backend.VascBackendException;
import net.forwardfire.vasc.backend.VascEntryFieldValue;
import net.forwardfire.vasc.backend.metamodel.crud.UpdateableRow; import net.forwardfire.vasc.backend.metamodel.crud.UpdateableRow;
import net.forwardfire.vasc.core.VascEntryField;
import net.forwardfire.vasc.core.entry.VascEntryFieldValue;
import net.forwardfire.vasc.core.VascException;
public class RowVascEntryFieldValue implements VascEntryFieldValue { public class RowVascEntryFieldValue implements VascEntryFieldValue {
private static final long serialVersionUID = -806674640688182132L; private static final long serialVersionUID = -806674640688182132L;
/** /**
* @see net.forwardfire.vasc.core.entry.VascEntryFieldValue#getValue(net.forwardfire.vasc.core.VascEntryField, java.lang.Object) * @see net.forwardfire.vasc.backend.VascEntryFieldValue#getValue(java.lang.String, java.lang.Object)
*/ */
public Object getValue(VascEntryField field, Object record) throws VascException { public Object getValue(String backendName, Object record) throws VascBackendException {
if (field==null) { if (backendName==null) {
throw new NullPointerException("Can't get value of null field."); throw new NullPointerException("Can't get value of null backendName.");
}
if (field.getBackendName()==null) {
throw new NullPointerException("Can't get value of null backendName field.");
} }
if (record==null) { if (record==null) {
throw new NullPointerException("Can't get value of null object."); throw new NullPointerException("Can't get value of null object.");
} }
if (record instanceof UpdateableRow) { if (record instanceof UpdateableRow) {
UpdateableRow row = (UpdateableRow)record; UpdateableRow row = (UpdateableRow)record;
return row.getValue(field.getBackendName()); return row.getValue(backendName);
} }
Row row = (Row)record; Row row = (Row)record;
Object fieldValue = row.getValue(indexOf(field.getBackendName(),row)); Object fieldValue = row.getValue(indexOf(backendName,row));
return fieldValue; return fieldValue;
} }
@ -49,10 +45,10 @@ public class RowVascEntryFieldValue implements VascEntryFieldValue {
} }
/** /**
* @see net.forwardfire.vasc.core.entry.VascEntryFieldValue#getDisplayValue(net.forwardfire.vasc.core.VascEntryField, java.lang.Object) * @see net.forwardfire.vasc.backend.VascEntryFieldValue#getDisplayValue(java.lang.String, java.lang.Object)
*/ */
public String getDisplayValue(VascEntryField field, Object record) throws VascException { public String getDisplayValue(String backendName, Object record) throws VascBackendException {
Object fieldValue = getValue(field,record); Object fieldValue = getValue(backendName,record);
if (fieldValue==null) { if (fieldValue==null) {
fieldValue = ""; fieldValue = "";
} }
@ -60,12 +56,12 @@ public class RowVascEntryFieldValue implements VascEntryFieldValue {
} }
/** /**
* @see net.forwardfire.vasc.core.entry.VascEntryFieldValue#setValue(net.forwardfire.vasc.core.VascEntryField, java.lang.Object, java.lang.Object) * @see net.forwardfire.vasc.backend.VascEntryFieldValue#setValue(java.lang.String, java.lang.Object, java.lang.Object)
*/ */
public void setValue(VascEntryField field, Object record,Object value) throws VascException { public void setValue(String backendName, Object record,Object value) throws VascBackendException {
if (record instanceof UpdateableRow) { if (record instanceof UpdateableRow) {
UpdateableRow row = (UpdateableRow)record; UpdateableRow row = (UpdateableRow)record;
row.setValue(field.getBackendName(), value); row.setValue(backendName, value);
} }
} }
} }

View file

@ -2,11 +2,10 @@ package net.forwardfire.vasc.backend.metamodel;
import org.eobjects.metamodel.schema.Table; import org.eobjects.metamodel.schema.Table;
import net.forwardfire.vasc.backend.VascBackendException;
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; import net.forwardfire.vasc.backend.metamodel.crud.UpdateableRow;
import net.forwardfire.vasc.core.VascEntry;
import net.forwardfire.vasc.core.entry.VascEntryRecordCreator;
import net.forwardfire.vasc.core.VascException;
public class RowVascEntryRecordCreator implements VascEntryRecordCreator { public class RowVascEntryRecordCreator implements VascEntryRecordCreator {
@ -23,7 +22,7 @@ public class RowVascEntryRecordCreator implements VascEntryRecordCreator {
return UpdateableRow.class; return UpdateableRow.class;
} }
public Object newRecord(VascEntry entry) throws VascException { public Object newRecord() throws VascBackendException {
return dataContext.createRow(table); return dataContext.createRow(table);
} }
} }

View file

@ -30,10 +30,5 @@
<element tag="xmlDomDataContext" objectClass="net.forwardfire.vasc.backend.metamodel.MetaModelDataContextXmlDom"/> <element tag="xmlDomDataContext" objectClass="net.forwardfire.vasc.backend.metamodel.MetaModelDataContextXmlDom"/>
<element tag="jndiDataContext" objectClass="net.forwardfire.vasc.backend.metamodel.MetaModelDataContextJndiDataContext"/> <element tag="jndiDataContext" objectClass="net.forwardfire.vasc.backend.metamodel.MetaModelDataContextJndiDataContext"/>
<element tag="schemaAutoEntry" objectClass="net.forwardfire.vasc.backend.metamodel.MetaModelSchemaAutoEntry">
<configurator id="schemaAutoEntry-SchemaAutoEntryElementConfigurator" bean.class="net.forwardfire.vasc.backend.metamodel.x4o.SchemaAutoEntryElementConfigurator" configAction="true"/>
</element>
</namespace> </namespace>
</root:module> </root:module>

View file

@ -2,7 +2,7 @@
<modelVersion>4.0.0</modelVersion> <modelVersion>4.0.0</modelVersion>
<parent> <parent>
<artifactId>vasc-backend</artifactId> <artifactId>vasc-backend</artifactId>
<groupId>net.forwardfire.vasc</groupId> <groupId>net.forwardfire.vasc.backend</groupId>
<version>0.4.2-SNAPSHOT</version> <version>0.4.2-SNAPSHOT</version>
<relativePath>..</relativePath> <relativePath>..</relativePath>
</parent> </parent>
@ -11,8 +11,8 @@
<description>vasc-backend-mongodb</description> <description>vasc-backend-mongodb</description>
<dependencies> <dependencies>
<dependency> <dependency>
<groupId>net.forwardfire.vasc</groupId> <groupId>net.forwardfire.vasc.backend</groupId>
<artifactId>vasc-core</artifactId> <artifactId>vasc-backend-api</artifactId>
<version>${project.version}</version> <version>${project.version}</version>
</dependency> </dependency>
<dependency> <dependency>

View file

@ -27,13 +27,10 @@ import java.util.List;
import java.util.logging.Logger; import java.util.logging.Logger;
import net.forwardfire.vasc.backend.AbstractVascBackend; import net.forwardfire.vasc.backend.AbstractVascBackend;
import net.forwardfire.vasc.backend.VascBackendException;
import net.forwardfire.vasc.backend.VascBackendState; import net.forwardfire.vasc.backend.VascBackendState;
import net.forwardfire.vasc.core.VascEntry; import net.forwardfire.vasc.backend.VascEntryFieldValue;
import net.forwardfire.vasc.core.VascEntryField; import net.forwardfire.vasc.backend.VascEntryRecordCreator;
import net.forwardfire.vasc.core.entry.VascEntryFieldValue;
import net.forwardfire.vasc.core.entry.VascEntryRecordCreator;
import net.forwardfire.vasc.core.VascException;
import com.mongodb.DB; import com.mongodb.DB;
import com.mongodb.DBCollection; import com.mongodb.DBCollection;
@ -108,7 +105,7 @@ public class MongodbVascBackend extends AbstractVascBackend {
return query; return query;
} }
public List<Object> execute(VascBackendState state) throws VascException { public List<Object> 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);
@ -124,12 +121,12 @@ public class MongodbVascBackend extends AbstractVascBackend {
return result; return result;
} }
public void persist(Object object) throws VascException { public void persist(Object object) throws VascBackendException {
DBCollection coll = getDBCollection(); DBCollection coll = getDBCollection();
coll.insert((DBObject)object); coll.insert((DBObject)object);
} }
public Object merge(Object object) throws VascException { public Object merge(Object object) throws VascBackendException {
DBCollection coll = getDBCollection(); DBCollection coll = getDBCollection();
DBObject row = (DBObject)object; DBObject row = (DBObject)object;
DBObject query = new BasicDBObject(); DBObject query = new BasicDBObject();
@ -139,18 +136,18 @@ public class MongodbVascBackend extends AbstractVascBackend {
return object; return object;
} }
public void delete(Object object) throws VascException { public void delete(Object 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",((DBObject)object).get("_id"));
coll.remove(query); // remove by _id coll.remove(query); // remove by _id
} }
public VascEntryFieldValue provideVascEntryFieldValue(VascEntryField field) { public VascEntryFieldValue provideVascEntryFieldValue() {
return new MongodbVascEntryFieldValue(); return new MongodbVascEntryFieldValue();
} }
public VascEntryRecordCreator provideVascEntryRecordCreator(VascEntry vascEntry) { public VascEntryRecordCreator provideVascEntryRecordCreator() {
return new MongodbVascEntryRecordCreator(); return new MongodbVascEntryRecordCreator();
} }

View file

@ -22,10 +22,8 @@
package net.forwardfire.vasc.backend.mongodb; package net.forwardfire.vasc.backend.mongodb;
import net.forwardfire.vasc.core.VascEntryField; import net.forwardfire.vasc.backend.VascBackendException;
import net.forwardfire.vasc.core.entry.VascEntryFieldValue; import net.forwardfire.vasc.backend.VascEntryFieldValue;
import net.forwardfire.vasc.core.VascException;
import com.mongodb.BasicDBObject; import com.mongodb.BasicDBObject;
@ -39,18 +37,18 @@ public class MongodbVascEntryFieldValue implements VascEntryFieldValue {
private static final long serialVersionUID = -7371273796529818557L; private static final long serialVersionUID = -7371273796529818557L;
public Object getValue(VascEntryField field, Object record) throws VascException { public Object getValue(String backendName, Object record) throws VascBackendException {
BasicDBObject row = (BasicDBObject)record; BasicDBObject row = (BasicDBObject)record;
Object data = row.get(field.getBackendName()); Object data = row.get(backendName);
return data; return data;
} }
public String getDisplayValue(VascEntryField field, Object record) throws VascException { public String getDisplayValue(String field, Object record) throws VascBackendException {
return ""+getValue(field,record); return ""+getValue(field,record);
} }
public void setValue(VascEntryField field, Object record, Object value) throws VascException { public void setValue(String backendName, Object record, Object value) throws VascBackendException {
BasicDBObject row = (BasicDBObject)record; BasicDBObject row = (BasicDBObject)record;
row.put(field.getBackendName(), value); row.put(backendName, value);
} }
} }

View file

@ -23,10 +23,8 @@
package net.forwardfire.vasc.backend.mongodb; package net.forwardfire.vasc.backend.mongodb;
import net.forwardfire.vasc.core.VascEntry; import net.forwardfire.vasc.backend.VascBackendException;
import net.forwardfire.vasc.core.entry.VascEntryRecordCreator; import net.forwardfire.vasc.backend.VascEntryRecordCreator;
import net.forwardfire.vasc.core.VascException;
import com.mongodb.BasicDBObject; import com.mongodb.BasicDBObject;
@ -40,7 +38,7 @@ public class MongodbVascEntryRecordCreator implements VascEntryRecordCreator {
private static final long serialVersionUID = -9213830731796787384L; private static final long serialVersionUID = -9213830731796787384L;
public Object newRecord(VascEntry entry) throws VascException { public Object newRecord() throws VascBackendException {
return new BasicDBObject(); return new BasicDBObject();
} }

View file

@ -22,21 +22,14 @@
package net.forwardfire.vasc.ejb3; package net.forwardfire.vasc.ejb3;
import java.io.ByteArrayOutputStream;
import java.io.IOException;
import java.io.ObjectOutputStream;
import java.util.List; import java.util.List;
import java.util.Map; import java.util.Map;
import net.forwardfire.vasc.backend.VascBackend; import net.forwardfire.vasc.backend.VascBackend;
import net.forwardfire.vasc.backend.VascBackendException;
import net.forwardfire.vasc.backend.VascBackendState; import net.forwardfire.vasc.backend.VascBackendState;
import net.forwardfire.vasc.core.VascEntry; import net.forwardfire.vasc.backend.VascEntryFieldValue;
import net.forwardfire.vasc.core.VascEntryField; import net.forwardfire.vasc.backend.VascEntryRecordCreator;
import net.forwardfire.vasc.core.VascEntryFieldLocal;
import net.forwardfire.vasc.core.VascEntryLocal;
import net.forwardfire.vasc.core.VascException;
import net.forwardfire.vasc.core.entry.VascEntryFieldValue;
import net.forwardfire.vasc.core.entry.VascEntryRecordCreator;
/** /**
* VascServiceRemoteBackend wraps VascBasckend to the ejb3 context. * VascServiceRemoteBackend wraps VascBasckend to the ejb3 context.
@ -58,7 +51,6 @@ public class VascServiceRemoteBackend implements VascBackend {
} }
this.vascManager=vascManager; this.vascManager=vascManager;
this.backendId=backendId; this.backendId=backendId;
} }
public void startBackend() { public void startBackend() {
@ -74,13 +66,13 @@ public class VascServiceRemoteBackend implements VascBackend {
// we cant change id // we cant change id
} }
public void delete(Object object) throws VascException { public void delete(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);
} }
public long doRecordMoveDownById(VascBackendState state,Object primaryId) throws VascException { public long doRecordMoveDownById(VascBackendState state,Object primaryId) throws VascBackendException {
Object[] args = new Object[2]; Object[] args = new Object[2];
args[0]=state; args[0]=state;
args[1]=primaryId; args[1]=primaryId;
@ -88,7 +80,7 @@ public class VascServiceRemoteBackend implements VascBackend {
return (Long)result; return (Long)result;
} }
public long doRecordMoveUpById(VascBackendState state, Object primaryId) throws VascException { public long doRecordMoveUpById(VascBackendState state, Object primaryId) throws VascBackendException {
Object[] args = new Object[2]; Object[] args = new Object[2];
args[0]=state; args[0]=state;
args[1]=primaryId; args[1]=primaryId;
@ -97,7 +89,7 @@ public class VascServiceRemoteBackend implements VascBackend {
} }
@SuppressWarnings("unchecked") @SuppressWarnings("unchecked")
public List<Object> execute(VascBackendState state) throws VascException { public List<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);
@ -135,60 +127,29 @@ public class VascServiceRemoteBackend implements VascBackend {
return (Boolean)result; return (Boolean)result;
} }
public Object merge(Object object) throws VascException { public Object merge(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 result;
} }
public void persist(Object object) throws VascException { public void persist(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);
} }
public VascEntryFieldValue provideVascEntryFieldValue(VascEntryField field) { @Override
try { public VascEntryFieldValue provideVascEntryFieldValue() {
field = ((VascEntryFieldLocal)field).clone(); // RM... Object[] args = new Object[0];
ByteArrayOutputStream dataArray = new ByteArrayOutputStream(256); // it grows when needed
ObjectOutputStream objOutstream = new ObjectOutputStream(dataArray);
objOutstream.writeObject(field);
objOutstream.close();
int objectSize = dataArray.size();
System.out.println("Writing obj to field: "+objectSize);
} catch (Exception e) {
throw new RuntimeException(e);
}
Object[] args = new Object[1];
args[0]=field;
Object result = vascManager.invokeBackendMethod(backendId, "provideVascEntryFieldValue", args); Object result = vascManager.invokeBackendMethod(backendId, "provideVascEntryFieldValue", args);
return (VascEntryFieldValue)result; return (VascEntryFieldValue)result;
} }
public VascEntryRecordCreator provideVascEntryRecordCreator(VascEntry vascEntry) { @Override
VascEntryLocal clone = null; public VascEntryRecordCreator provideVascEntryRecordCreator() {
try { Object[] args = new Object[0];
clone = ((VascEntryLocal)vascEntry).clone();
clone.setVascFrontendController(null);
clone.setVascEntryFieldEventChannel(null);
} catch (CloneNotSupportedException e) {
// TODO Auto-generated catch block
e.printStackTrace();
}
try {
ByteArrayOutputStream dataArray = new ByteArrayOutputStream(256); // it grows when needed
ObjectOutputStream objOutstream = new ObjectOutputStream(dataArray);
objOutstream.writeObject(clone);
objOutstream.close();
//int objectSize = dataArray.size();
//System.out.println("Writing obj to entry: "+objectSize);
} catch (IOException e) {
throw new RuntimeException(e);
}
Object[] args = new Object[1];
args[0]=clone;
Object result = vascManager.invokeBackendMethod(backendId, "provideVascEntryRecordCreator", args); Object result = vascManager.invokeBackendMethod(backendId, "provideVascEntryRecordCreator", args);
return (VascEntryRecordCreator)result; return (VascEntryRecordCreator)result;
} }

View file

@ -15,7 +15,7 @@
<version>${project.version}</version> <version>${project.version}</version>
</dependency> </dependency>
<dependency> <dependency>
<groupId>net.forwardfire.vasc</groupId> <groupId>net.forwardfire.vasc.backend</groupId>
<artifactId>vasc-backend-jpa</artifactId> <artifactId>vasc-backend-jpa</artifactId>
<version>${project.version}</version> <version>${project.version}</version>
</dependency> </dependency>

View file

@ -20,8 +20,8 @@
<version>${x4o.version}</version> <version>${x4o.version}</version>
</dependency> </dependency>
<dependency> <dependency>
<groupId>net.forwardfire.vasc.lib</groupId> <groupId>net.forwardfire.vasc.backend</groupId>
<artifactId>vasc-lib-xpql</artifactId> <artifactId>vasc-backend-api</artifactId>
<version>${project.version}</version> <version>${project.version}</version>
</dependency> </dependency>
<dependency> <dependency>

View file

@ -26,13 +26,11 @@ import java.util.List;
import java.util.Map; import java.util.Map;
import net.forwardfire.vasc.backend.VascBackend; import net.forwardfire.vasc.backend.VascBackend;
import net.forwardfire.vasc.backend.VascBackendException;
import net.forwardfire.vasc.backend.VascBackendState; import net.forwardfire.vasc.backend.VascBackendState;
import net.forwardfire.vasc.backend.VascEntryFieldValue;
import net.forwardfire.vasc.backend.VascEntryRecordCreator;
import net.forwardfire.vasc.core.VascEntry; import net.forwardfire.vasc.core.VascEntry;
import net.forwardfire.vasc.core.VascEntryField;
import net.forwardfire.vasc.core.entry.VascEntryFieldValue;
import net.forwardfire.vasc.core.entry.VascEntryRecordCreator;
import net.forwardfire.vasc.core.VascException;
/** /**
* VascBackendProxy to implement missing features of the backend. * VascBackendProxy to implement missing features of the backend.
@ -107,14 +105,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 VascException { public List<Object> 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 VascException { public void delete(Object object) throws VascBackendException {
backend.delete(object); backend.delete(object);
} }
@ -135,29 +133,29 @@ 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 VascException { public Object merge(Object 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 VascException { public void persist(Object object) throws VascBackendException {
backend.persist(object); backend.persist(object);
} }
/** /**
* @see net.forwardfire.vasc.backend.VascBackend#provideVascEntryFieldValue(net.forwardfire.vasc.core.VascEntryField) * @see net.forwardfire.vasc.backend.VascBackend#provideVascEntryFieldValue()
*/ */
public VascEntryFieldValue provideVascEntryFieldValue(VascEntryField field) { public VascEntryFieldValue provideVascEntryFieldValue() {
return backend.provideVascEntryFieldValue(field); return backend.provideVascEntryFieldValue();
} }
/** /**
* @see net.forwardfire.vasc.backend.VascBackend#provideVascEntryRecordCreator(net.forwardfire.vasc.core.VascEntry) * @see net.forwardfire.vasc.backend.VascBackend#provideVascEntryRecordCreator()
*/ */
public VascEntryRecordCreator provideVascEntryRecordCreator(VascEntry vascEntry) { public VascEntryRecordCreator provideVascEntryRecordCreator() {
return backend.provideVascEntryRecordCreator(vascEntry); return backend.provideVascEntryRecordCreator();
} }
/** /**
@ -177,14 +175,14 @@ abstract public class AbstractVascBackendProxy implements VascBackendProxy {
/** /**
* @see net.forwardfire.vasc.core.VascBackend#doRecordMoveDownById(VascBackendState state,java.lang.Object) * @see net.forwardfire.vasc.core.VascBackend#doRecordMoveDownById(VascBackendState state,java.lang.Object)
*/ */
public long doRecordMoveDownById(VascBackendState state,Object primaryId) throws VascException { public long doRecordMoveDownById(VascBackendState state,Object primaryId) throws VascBackendException {
return backend.doRecordMoveDownById(state,primaryId); return backend.doRecordMoveDownById(state,primaryId);
} }
/** /**
* @see net.forwardfire.vasc.core.VascBackend#doRecordMoveUpById(VascBackendState state,java.lang.Object) * @see net.forwardfire.vasc.core.VascBackend#doRecordMoveUpById(VascBackendState state,java.lang.Object)
*/ */
public long doRecordMoveUpById(VascBackendState state,Object primaryId) throws VascException { public long doRecordMoveUpById(VascBackendState state,Object primaryId) throws VascBackendException {
return backend.doRecordMoveUpById(state,primaryId); return backend.doRecordMoveUpById(state,primaryId);
} }

View file

@ -26,8 +26,8 @@ import java.util.HashMap;
import java.util.List; import java.util.List;
import java.util.Map; import java.util.Map;
import net.forwardfire.vasc.backend.VascBackendException;
import net.forwardfire.vasc.backend.VascBackendState; import net.forwardfire.vasc.backend.VascBackendState;
import net.forwardfire.vasc.core.VascException;
/** /**
* Does simple caching for the data. * Does simple caching for the data.
@ -130,7 +130,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 VascException { public List<Object> 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 +151,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 VascException { public void delete(Object object) throws VascBackendException {
requestFlush = true; requestFlush = true;
super.delete(object); super.delete(object);
} }
@ -160,7 +160,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 VascException { public Object merge(Object object) throws VascBackendException {
requestFlush = true; requestFlush = true;
return super.merge(object); return super.merge(object);
} }
@ -169,7 +169,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 VascException { public void persist(Object object) throws VascBackendException {
requestFlush = true; requestFlush = true;
super.persist(object); super.persist(object);
} }

View file

@ -26,11 +26,11 @@ import java.util.ArrayList;
import java.util.List; import java.util.List;
import net.forwardfire.vasc.backend.VascBackend; import net.forwardfire.vasc.backend.VascBackend;
import net.forwardfire.vasc.backend.VascBackendException;
import net.forwardfire.vasc.backend.VascBackendState; import net.forwardfire.vasc.backend.VascBackendState;
import net.forwardfire.vasc.core.VascEntry; import net.forwardfire.vasc.core.VascEntry;
import net.forwardfire.vasc.core.entry.VascEntryBackendEventListener; import net.forwardfire.vasc.core.entry.VascEntryBackendEventListener;
import net.forwardfire.vasc.core.entry.VascEntryBackendEventListener.VascBackendEventType; import net.forwardfire.vasc.core.entry.VascEntryBackendEventListener.VascBackendEventType;
import net.forwardfire.vasc.core.VascException;
/** /**
* Holds !! and fires the backend event listeners. * Holds !! and fires the backend event listeners.
@ -105,7 +105,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 VascException { public void delete(Object 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);
@ -115,7 +115,7 @@ public class VascBackendProxyEventExecutor extends AbstractVascBackendProxy {
* @see net.forwardfire.vasc.backend.proxy.AbstractVascBackendProxy#doRecordMoveDownById(net.forwardfire.vasc.backend.VascBackendState, java.lang.Object) * @see net.forwardfire.vasc.backend.proxy.AbstractVascBackendProxy#doRecordMoveDownById(net.forwardfire.vasc.backend.VascBackendState, java.lang.Object)
*/ */
@Override @Override
public long doRecordMoveDownById(VascBackendState state, Object primaryId) throws VascException { public long doRecordMoveDownById(VascBackendState state, Object primaryId) throws VascBackendException {
fireVascEvent(VascBackendEventType.PRE_MOVE_DOWN,primaryId); fireVascEvent(VascBackendEventType.PRE_MOVE_DOWN,primaryId);
Long result = super.doRecordMoveDownById(state, primaryId); Long result = super.doRecordMoveDownById(state, primaryId);
fireVascEvent(VascBackendEventType.POST_MOVE_DOWN,result); fireVascEvent(VascBackendEventType.POST_MOVE_DOWN,result);
@ -126,7 +126,7 @@ public class VascBackendProxyEventExecutor extends AbstractVascBackendProxy {
* @see net.forwardfire.vasc.backend.proxy.AbstractVascBackendProxy#doRecordMoveUpById(net.forwardfire.vasc.backend.VascBackendState, java.lang.Object) * @see net.forwardfire.vasc.backend.proxy.AbstractVascBackendProxy#doRecordMoveUpById(net.forwardfire.vasc.backend.VascBackendState, java.lang.Object)
*/ */
@Override @Override
public long doRecordMoveUpById(VascBackendState state, Object primaryId) throws VascException { public long doRecordMoveUpById(VascBackendState state, Object primaryId) throws VascBackendException {
fireVascEvent(VascBackendEventType.PRE_MOVE_UP,primaryId); fireVascEvent(VascBackendEventType.PRE_MOVE_UP,primaryId);
Long result = super.doRecordMoveUpById(state, primaryId); Long result = super.doRecordMoveUpById(state, primaryId);
fireVascEvent(VascBackendEventType.POST_MOVE_UP,result); fireVascEvent(VascBackendEventType.POST_MOVE_UP,result);
@ -137,7 +137,7 @@ 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 VascException { public List<Object> execute(VascBackendState state) throws VascBackendException {
fireVascEvent(VascBackendEventType.PRE_EXECUTE,state); fireVascEvent(VascBackendEventType.PRE_EXECUTE,state);
List<Object> result = super.execute(state); List<Object> result = super.execute(state);
fireVascEvent(VascBackendEventType.POST_EXECUTE,result); fireVascEvent(VascBackendEventType.POST_EXECUTE,result);
@ -159,7 +159,7 @@ 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 VascException { public Object merge(Object object) throws VascBackendException {
fireVascEvent(VascBackendEventType.PRE_MERGE,object); fireVascEvent(VascBackendEventType.PRE_MERGE,object);
Object result = super.merge(object); Object result = super.merge(object);
fireVascEvent(VascBackendEventType.POST_MERGE,result); fireVascEvent(VascBackendEventType.POST_MERGE,result);
@ -170,7 +170,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 VascException { public void persist(Object 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

@ -26,12 +26,9 @@ import java.util.ArrayList;
import java.util.List; import java.util.List;
import net.forwardfire.vasc.backend.VascBackend; import net.forwardfire.vasc.backend.VascBackend;
import net.forwardfire.vasc.backend.VascBackendFilter; import net.forwardfire.vasc.backend.VascBackendException;
import net.forwardfire.vasc.backend.VascBackendState; import net.forwardfire.vasc.backend.VascBackendState;
import net.forwardfire.vasc.core.VascEntry; import net.forwardfire.vasc.core.VascEntry;
import net.forwardfire.vasc.core.VascException;
/** /**
* Simple filter support * Simple filter support
@ -42,7 +39,7 @@ import net.forwardfire.vasc.core.VascException;
public class VascBackendProxyFilter extends AbstractVascBackendProxy { public class VascBackendProxyFilter extends AbstractVascBackendProxy {
private long records = 0; private long records = 0;
private List<VascBackendFilter> filters = null; private List<VascProxyFilter> filters = null;
/** /**
* @see java.lang.Object#clone() * @see java.lang.Object#clone()
@ -59,7 +56,7 @@ public class VascBackendProxyFilter extends AbstractVascBackendProxy {
public void initProxy(VascBackend backend, VascEntry entry) { public void initProxy(VascBackend backend, VascEntry entry) {
super.initProxy(backend,entry); super.initProxy(backend,entry);
filters = entry.getVascBackendFilters(); filters = entry.getVascBackendFilters();
for (VascBackendFilter filter:filters) { for (VascProxyFilter filter:filters) {
filter.initFilter(entry); filter.initFilter(entry);
} }
} }
@ -79,7 +76,7 @@ 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 VascException { public List<Object> execute(VascBackendState state) throws VascBackendException {
List<Object> result = backend.execute(state); List<Object> result = backend.execute(state);
if (filters==null) { if (filters==null) {
return result; return result;
@ -89,7 +86,7 @@ public class VascBackendProxyFilter extends AbstractVascBackendProxy {
} }
List<Object> search = new ArrayList<Object>(result.size()/2); List<Object> search = new ArrayList<Object>(result.size()/2);
for (Object o:result) { for (Object o:result) {
for (VascBackendFilter filter:filters) { for (VascProxyFilter filter:filters) {
Object r = filter.filterObject(o); Object r = filter.filterObject(o);
if (r!=null) { if (r!=null) {
search.add(r); search.add(r);

View file

@ -25,8 +25,8 @@ package net.forwardfire.vasc.backend.proxy;
import java.util.ArrayList; import java.util.ArrayList;
import java.util.List; import java.util.List;
import net.forwardfire.vasc.backend.VascBackendException;
import net.forwardfire.vasc.backend.VascBackendState; import net.forwardfire.vasc.backend.VascBackendState;
import net.forwardfire.vasc.core.VascException;
/** /**
* Simulates a real pages backend. * Simulates a real pages backend.
@ -70,7 +70,7 @@ 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 VascException { public List<Object> execute(VascBackendState state) throws VascBackendException {
List<Object> allData = backend.execute(state); List<Object> allData = backend.execute(state);
int pageSize = state.getPageSize(); int pageSize = state.getPageSize();
if (pageSize==0) { if (pageSize==0) {

View file

@ -25,10 +25,10 @@ package net.forwardfire.vasc.backend.proxy;
import java.util.ArrayList; import java.util.ArrayList;
import java.util.List; import java.util.List;
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.core.VascEntryField; import net.forwardfire.vasc.core.VascEntryField;
import net.forwardfire.vasc.core.entry.VascEntryFieldValue;
import net.forwardfire.vasc.core.VascException;
/** /**
* Simple text search * Simple text search
@ -70,7 +70,7 @@ 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 VascException { public List<Object> execute(VascBackendState state) throws VascBackendException {
List<Object> result = backend.execute(state); List<Object> result = backend.execute(state);
if (state.getSearchString()==null) { if (state.getSearchString()==null) {
return result; return result;
@ -82,8 +82,8 @@ public class VascBackendProxySearch extends AbstractVascBackendProxy {
List<Object> search = new ArrayList<Object>(result.size()/4); List<Object> search = new ArrayList<Object>(result.size()/4);
for (Object record:result) { for (Object record:result) {
for (VascEntryField field:entry.getVascEntryFields()) { for (VascEntryField field:entry.getVascEntryFields()) {
VascEntryFieldValue fieldValue = backend.provideVascEntryFieldValue(field); VascEntryFieldValue fieldValue = backend.provideVascEntryFieldValue();
Object value = fieldValue.getValue(field, record); Object value = fieldValue.getValue(field.getBackendName(), record);
if (value==null) { if (value==null) {
continue; // can't search null values. continue; // can't search null values.
} }

View file

@ -26,11 +26,10 @@ import java.util.Collections;
import java.util.Comparator; import java.util.Comparator;
import java.util.List; import java.util.List;
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.core.VascEntryField; import net.forwardfire.vasc.core.VascEntryField;
import net.forwardfire.vasc.core.VascEntryFieldLocal;
import net.forwardfire.vasc.core.entry.VascEntryFieldValue;
import net.forwardfire.vasc.core.VascException;
/** /**
* Add an sortware sort an a backend * Add an sortware sort an a backend
@ -74,14 +73,13 @@ public class VascBackendProxySort extends AbstractVascBackendProxy {
*/ */
@SuppressWarnings("unchecked") @SuppressWarnings("unchecked")
@Override @Override
public List<Object> execute(final VascBackendState state) throws VascException { public List<Object> execute(final VascBackendState state) throws VascBackendException {
List<Object> result = backend.execute(state); List<Object> result = backend.execute(state);
if (state.getSortField()==null) { if (state.getSortField()==null) {
return result; return result;
} }
try { final VascEntryField field = getVascEntryFieldByBackendName(state.getSortField());
final VascEntryField field = getVascEntryFieldByBackendName(state.getSortField()); final VascEntryFieldValue fieldValue = backend.provideVascEntryFieldValue();
final VascEntryFieldValue fieldValue = backend.provideVascEntryFieldValue(((VascEntryFieldLocal)field).clone()); // TODO fixme
Collections.sort(result, new Comparator<Object>() { Collections.sort(result, new Comparator<Object>() {
@SuppressWarnings("rawtypes") @SuppressWarnings("rawtypes")
public int compare(Object o1, Object o2) { public int compare(Object o1, Object o2) {
@ -89,11 +87,11 @@ public class VascBackendProxySort extends AbstractVascBackendProxy {
Comparable c1 = null; Comparable c1 = null;
Comparable c2 = null; Comparable c2 = null;
if (field.getDisplayName()!=null) { if (field.getDisplayName()!=null) {
c1 = fieldValue.getDisplayValue(field, o1); c1 = fieldValue.getDisplayValue(field.getBackendName(), o1);
c2 = fieldValue.getDisplayValue(field, o2); c2 = fieldValue.getDisplayValue(field.getBackendName(), o2);
} else { } else {
c1 = (Comparable)fieldValue.getValue(field, o1); c1 = (Comparable)fieldValue.getValue(field.getBackendName(), o1);
c2 = (Comparable)fieldValue.getValue(field, o2); c2 = (Comparable)fieldValue.getValue(field.getBackendName(), o2);
} }
if (c1==null & c2==null) { if (c1==null & c2==null) {
return 0; return 0;
@ -122,20 +120,12 @@ public class VascBackendProxySort extends AbstractVascBackendProxy {
} else { } else {
return c2.compareTo(c1); return c2.compareTo(c1);
} }
} catch (VascException e) { } catch (VascBackendException e) {
e.printStackTrace(); e.printStackTrace();
return 0; return 0;
} }
} }
}); });
} catch (CloneNotSupportedException e1) {
throw new VascException(e1);
} // TODO: check serialable stuff again
return result; return result;
} }
} }

View file

@ -26,8 +26,8 @@ import java.util.List;
import java.util.logging.Level; import java.util.logging.Level;
import java.util.logging.Logger; import java.util.logging.Logger;
import net.forwardfire.vasc.backend.VascBackendException;
import net.forwardfire.vasc.backend.VascBackendState; import net.forwardfire.vasc.backend.VascBackendState;
import net.forwardfire.vasc.core.VascException;
/** /**
* Does simple timer logging for the backend actions. * Does simple timer logging for the backend actions.
@ -58,7 +58,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 VascException { public List<Object> execute(VascBackendState state) throws VascBackendException {
long t1 = System.currentTimeMillis(); long t1 = System.currentTimeMillis();
try { try {
return backend.execute(state); return backend.execute(state);
@ -83,7 +83,7 @@ public class VascBackendProxyTimerLogger extends AbstractVascBackendProxy {
* @see net.forwardfire.vasc.backend.proxy.AbstractVascBackendProxy#doRecordMoveDownById(net.forwardfire.vasc.backend.VascBackendState, java.lang.Object) * @see net.forwardfire.vasc.backend.proxy.AbstractVascBackendProxy#doRecordMoveDownById(net.forwardfire.vasc.backend.VascBackendState, java.lang.Object)
*/ */
@Override @Override
public long doRecordMoveDownById(VascBackendState state, Object primaryId) throws VascException { public long doRecordMoveDownById(VascBackendState state, Object primaryId) throws VascBackendException {
long t1 = System.currentTimeMillis(); long t1 = System.currentTimeMillis();
try { try {
return backend.doRecordMoveDownById(state, primaryId); return backend.doRecordMoveDownById(state, primaryId);
@ -97,7 +97,7 @@ public class VascBackendProxyTimerLogger extends AbstractVascBackendProxy {
* @see net.forwardfire.vasc.backend.proxy.AbstractVascBackendProxy#doRecordMoveUpById(net.forwardfire.vasc.backend.VascBackendState, java.lang.Object) * @see net.forwardfire.vasc.backend.proxy.AbstractVascBackendProxy#doRecordMoveUpById(net.forwardfire.vasc.backend.VascBackendState, java.lang.Object)
*/ */
@Override @Override
public long doRecordMoveUpById(VascBackendState state, Object primaryId) throws VascException { public long doRecordMoveUpById(VascBackendState state, Object primaryId) throws VascBackendException {
long t1 = System.currentTimeMillis(); long t1 = System.currentTimeMillis();
try { try {
return backend.doRecordMoveUpById(state, primaryId); return backend.doRecordMoveUpById(state, primaryId);
@ -111,7 +111,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 VascException { public void delete(Object object) throws VascBackendException {
long t1 = System.currentTimeMillis(); long t1 = System.currentTimeMillis();
try { try {
backend.delete(object); backend.delete(object);
@ -125,7 +125,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 VascException { public Object merge(Object object) throws VascBackendException {
long t1 = System.currentTimeMillis(); long t1 = System.currentTimeMillis();
try { try {
return backend.merge(object); return backend.merge(object);
@ -139,7 +139,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 VascException { public void persist(Object object) throws VascBackendException {
long t1 = System.currentTimeMillis(); long t1 = System.currentTimeMillis();
try { try {
backend.persist(object); backend.persist(object);

View file

@ -20,7 +20,7 @@
* SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. * SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
*/ */
package net.forwardfire.vasc.backend; package net.forwardfire.vasc.backend.proxy;
import net.forwardfire.vasc.core.VascEntry; import net.forwardfire.vasc.core.VascEntry;
@ -31,7 +31,7 @@ import net.forwardfire.vasc.core.VascEntry;
* @author Willem Cazander * @author Willem Cazander
* @version 1.0 Apr 28, 2009 * @version 1.0 Apr 28, 2009
*/ */
public interface VascBackendFilter { public interface VascProxyFilter {
/** /**
* Inits the filter * Inits the filter
@ -48,5 +48,5 @@ public interface VascBackendFilter {
* @return * @return
* @throws CloneNotSupportedException * @throws CloneNotSupportedException
*/ */
public VascBackendFilter clone() throws CloneNotSupportedException; public VascProxyFilter clone() throws CloneNotSupportedException;
} }

View file

@ -25,8 +25,8 @@ package net.forwardfire.vasc.core;
import java.util.ArrayList; import java.util.ArrayList;
import java.util.List; import java.util.List;
import net.forwardfire.vasc.backend.VascEntryFieldValue;
import net.forwardfire.vasc.core.base.AbstractVascBaseIdRoleCrudOrderMetaLocal; import net.forwardfire.vasc.core.base.AbstractVascBaseIdRoleCrudOrderMetaLocal;
import net.forwardfire.vasc.core.entry.VascEntryFieldValue;
import net.forwardfire.vasc.validators.VascValidator; import net.forwardfire.vasc.validators.VascValidator;
/** /**

View file

@ -28,7 +28,7 @@ import java.util.HashMap;
import java.util.List; import java.util.List;
import java.util.Map; import java.util.Map;
import net.forwardfire.vasc.backend.VascBackendFilter; import net.forwardfire.vasc.backend.proxy.VascProxyFilter;
import net.forwardfire.vasc.core.actions.ColumnVascAction; import net.forwardfire.vasc.core.actions.ColumnVascAction;
import net.forwardfire.vasc.core.actions.ColumnVascActionLocal; import net.forwardfire.vasc.core.actions.ColumnVascActionLocal;
import net.forwardfire.vasc.core.actions.GlobalVascAction; import net.forwardfire.vasc.core.actions.GlobalVascAction;
@ -82,7 +82,7 @@ abstract public class AbstractVascEntryLocal extends AbstractVascBaseIdRoleCrudL
private Map<String,List<String>> eventEntryFrontendEventListeners = null; private Map<String,List<String>> eventEntryFrontendEventListeners = null;
private List<String> eventEntryBackendEventListeners = null; private List<String> eventEntryBackendEventListeners = null;
private List<VascEntryListOptionLocal> vascEntryListOptions = null; private List<VascEntryListOptionLocal> vascEntryListOptions = null;
private List<VascBackendFilter> backendFilters = null; private List<VascProxyFilter> backendFilters = null;
private Map<String,List<String>> eventEntryFrontendActions = null; private Map<String,List<String>> eventEntryFrontendActions = null;
private String backendId = null; private String backendId = null;
@ -105,7 +105,7 @@ abstract public class AbstractVascEntryLocal extends AbstractVascBaseIdRoleCrudL
eventEntryFrontendEventListeners = new HashMap<String,List<String>>(10); eventEntryFrontendEventListeners = new HashMap<String,List<String>>(10);
eventEntryBackendEventListeners = new ArrayList<String>(10); eventEntryBackendEventListeners = new ArrayList<String>(10);
vascEntryListOptions = new ArrayList<VascEntryListOptionLocal>(10); vascEntryListOptions = new ArrayList<VascEntryListOptionLocal>(10);
backendFilters = new ArrayList<VascBackendFilter>(3); backendFilters = new ArrayList<VascProxyFilter>(3);
} }
@Override @Override
@ -175,7 +175,7 @@ abstract public class AbstractVascEntryLocal extends AbstractVascBaseIdRoleCrudL
optionClone.setVascEntry(clone); optionClone.setVascEntry(clone);
clone.addVascEntryListOption(optionClone); clone.addVascEntryListOption(optionClone);
} }
for (VascBackendFilter filter:backendFilters) { for (VascProxyFilter filter:backendFilters) {
clone.addVascBackendFilter(filter.clone()); clone.addVascBackendFilter(filter.clone());
} }
for (String key:eventEntryFrontendActions.keySet()) { for (String key:eventEntryFrontendActions.keySet()) {
@ -883,11 +883,11 @@ abstract public class AbstractVascEntryLocal extends AbstractVascBaseIdRoleCrudL
} }
public void addVascBackendFilter(VascBackendFilter filter) { public void addVascBackendFilter(VascProxyFilter filter) {
backendFilters.add(filter); backendFilters.add(filter);
} }
public List<VascBackendFilter> getVascBackendFilters() { public List<VascProxyFilter> getVascBackendFilters() {
return backendFilters; return backendFilters;
} }

View file

@ -25,7 +25,7 @@ package net.forwardfire.vasc.core;
import java.util.Collection; import java.util.Collection;
import java.util.List; import java.util.List;
import net.forwardfire.vasc.backend.VascBackendFilter; import net.forwardfire.vasc.backend.proxy.VascProxyFilter;
import net.forwardfire.vasc.core.actions.ColumnVascAction; import net.forwardfire.vasc.core.actions.ColumnVascAction;
import net.forwardfire.vasc.core.actions.GlobalVascAction; import net.forwardfire.vasc.core.actions.GlobalVascAction;
import net.forwardfire.vasc.core.actions.RowVascAction; import net.forwardfire.vasc.core.actions.RowVascAction;
@ -229,7 +229,7 @@ public interface VascEntry extends VascBaseIdRoleCrud {
public VascEntryListOption getVascEntryListOptionById(String listOptionId); public VascEntryListOption getVascEntryListOptionById(String listOptionId);
public List<VascBackendFilter> getVascBackendFilters(); public List<VascProxyFilter> getVascBackendFilters();
public List<String> getVascEntryFrontendActionsByType(String frontendType); public List<String> getVascEntryFrontendActionsByType(String frontendType);
} }

View file

@ -24,8 +24,8 @@ package net.forwardfire.vasc.core;
import java.util.List; import java.util.List;
import net.forwardfire.vasc.backend.VascEntryFieldValue;
import net.forwardfire.vasc.core.base.VascBaseIdRoleCrudOrderMeta; import net.forwardfire.vasc.core.base.VascBaseIdRoleCrudOrderMeta;
import net.forwardfire.vasc.core.entry.VascEntryFieldValue;
import net.forwardfire.vasc.validators.VascValidator; import net.forwardfire.vasc.validators.VascValidator;
/** /**

View file

@ -22,8 +22,8 @@
package net.forwardfire.vasc.core; package net.forwardfire.vasc.core;
import net.forwardfire.vasc.backend.VascEntryFieldValue;
import net.forwardfire.vasc.core.base.VascBaseIdRoleCrudOrderMetaLocal; import net.forwardfire.vasc.core.base.VascBaseIdRoleCrudOrderMetaLocal;
import net.forwardfire.vasc.core.entry.VascEntryFieldValue;
import net.forwardfire.vasc.validators.VascValidator; import net.forwardfire.vasc.validators.VascValidator;
/** /**

View file

@ -24,7 +24,7 @@ package net.forwardfire.vasc.core;
import java.util.Collection; import java.util.Collection;
import net.forwardfire.vasc.backend.VascBackendFilter; import net.forwardfire.vasc.backend.proxy.VascProxyFilter;
import net.forwardfire.vasc.core.actions.ColumnVascActionLocal; import net.forwardfire.vasc.core.actions.ColumnVascActionLocal;
import net.forwardfire.vasc.core.actions.GlobalVascActionLocal; import net.forwardfire.vasc.core.actions.GlobalVascActionLocal;
import net.forwardfire.vasc.core.actions.RowVascActionLocal; import net.forwardfire.vasc.core.actions.RowVascActionLocal;
@ -260,7 +260,7 @@ public interface VascEntryLocal extends VascEntry,VascBaseIdRoleCrudLocal {
public Collection<VascEntryListOptionLocal> getVascEntryListOptionsLocal(); public Collection<VascEntryListOptionLocal> getVascEntryListOptionsLocal();
public void addVascBackendFilter(VascBackendFilter filter); public void addVascBackendFilter(VascProxyFilter filter);
public void addVascEntryFrontendAction(String actionClass,String frontendType); public void addVascEntryFrontendAction(String actionClass,String frontendType);

View file

@ -4,7 +4,7 @@ import net.forwardfire.vasc.backend.VascBackendState;
import net.forwardfire.vasc.frontend.VascFrontendActions; import net.forwardfire.vasc.frontend.VascFrontendActions;
import net.forwardfire.vasc.frontend.VascFrontendControllerLocal; import net.forwardfire.vasc.frontend.VascFrontendControllerLocal;
import net.forwardfire.vasc.frontend.VascFrontendDataSelector; import net.forwardfire.vasc.frontend.VascFrontendDataSelector;
import net.forwardfire.vasc.frontend.VascFrontendPager; import net.forwardfire.vasc.frontend.VascFrontendPageInfo;
import net.forwardfire.vasc.frontend.VascFrontendUserController; import net.forwardfire.vasc.frontend.VascFrontendUserController;
import net.forwardfire.vasc.frontend.VascFrontendUserSettingController; import net.forwardfire.vasc.frontend.VascFrontendUserSettingController;
@ -24,7 +24,7 @@ public interface VascInterfaceLoader {
public VascFrontendPager createVascFrontendPagerImpl(VascEntry entry); public VascFrontendPageInfo createVascFrontendPagerImpl(VascEntry entry);
public VascFrontendActions createVascFrontendActionsImpl(VascEntry entry); public VascFrontendActions createVascFrontendActionsImpl(VascEntry entry);
public VascFrontendDataSelector createVascFrontendDataSelectorImpl(VascEntry entry); public VascFrontendDataSelector createVascFrontendDataSelectorImpl(VascEntry entry);
public VascFrontendUserController createVascFrontendUserControllerImpl(VascEntry entry); public VascFrontendUserController createVascFrontendUserControllerImpl(VascEntry entry);

View file

@ -22,6 +22,7 @@
package net.forwardfire.vasc.core.ui; package net.forwardfire.vasc.core.ui;
import net.forwardfire.vasc.backend.VascBackendException;
import net.forwardfire.vasc.core.VascEntryField; import net.forwardfire.vasc.core.VascEntryField;
import net.forwardfire.vasc.core.VascException; import net.forwardfire.vasc.core.VascException;
@ -45,7 +46,11 @@ public class VascColumnValueModelListener implements VascValueModelListener {
} }
public void valueUpdate(VascValueModel model) throws VascException { public void valueUpdate(VascValueModel model) throws VascException {
vascEntryField.getVascEntryFieldValue().setValue(vascEntryField, bean, model.getValue()); try {
vascEntryField.getVascEntryFieldValue().setValue(vascEntryField.getBackendName(), bean, model.getValue());
} catch (VascBackendException e) {
throw new VascException(e);
}
} }
/** /**

View file

@ -27,8 +27,6 @@ import java.util.EventListener;
import net.forwardfire.vasc.core.VascException; import net.forwardfire.vasc.core.VascException;
/** /**
* *
* @author Willem Cazander * @author Willem Cazander

View file

@ -65,9 +65,9 @@ public interface VascFrontendController {
public VascFrontendActions getVascFrontendActions(); public VascFrontendActions getVascFrontendActions();
/** /**
* @return the vascFrontendPager * @return the vascFrontendPageInfo
*/ */
public VascFrontendPager getVascFrontendPager(); public VascFrontendPageInfo getVascFrontendPageInfo();
/** /**
* @return the VascFrontendHelper * @return the VascFrontendHelper

View file

@ -41,9 +41,9 @@ public interface VascFrontendControllerLocal extends VascFrontendController {
public void setVascFrontendActions(VascFrontendActions vascFrontendActions); public void setVascFrontendActions(VascFrontendActions vascFrontendActions);
/** /**
* @param vascFrontendPager the vascFrontendPager to set * @param vascFrontendPageInfo the vascFrontendPageInfo to set
*/ */
public void setVascFrontendPager(VascFrontendPager vascFrontendPager); public void setVascFrontendPageInfo(VascFrontendPageInfo vascFrontendPager);
/** /**
* @param vascEntryResourceResolver the vascEntryResourceResolver to set * @param vascEntryResourceResolver the vascEntryResourceResolver to set

View file

@ -24,17 +24,15 @@ package net.forwardfire.vasc.frontend;
import java.util.List; import java.util.List;
import net.forwardfire.vasc.backend.VascBackendPageNumber;
/** /**
* VascFrontendPager has some info about the pageing data models * VascFrontendPager has some info about the pageing data models
* *
* note all the get properties for different el parsers. * TODO: fix all the get properties for different el parsers.
* *
* @author Willem Cazander * @author Willem Cazander
* @version 1.0 Jan 22, 2012 * @version 1.0 Jan 22, 2012
*/ */
public interface VascFrontendPager extends VascFrontendEntry { public interface VascFrontendPageInfo extends VascFrontendEntry {
public long getPageStartCount(); public long getPageStartCount();
public long getPageStopCount(); public long getPageStopCount();
@ -47,9 +45,9 @@ public interface VascFrontendPager extends VascFrontendEntry {
public boolean getHasExtendedPageMode(); public boolean getHasExtendedPageMode();
public boolean getHasExtendedPageModeCenter(); public boolean getHasExtendedPageModeCenter();
public List<VascBackendPageNumber> getTablePagesFromBackend(); public List<VascFrontendPageInfoNumber> getTablePagesFromBackend();
public List<VascBackendPageNumber> getTablePagesNormal(); public List<VascFrontendPageInfoNumber> getTablePagesNormal();
public List<VascBackendPageNumber> getTablePagesExtendedBegin(); public List<VascFrontendPageInfoNumber> getTablePagesExtendedBegin();
public List<VascBackendPageNumber> getTablePagesExtendedCenter(); public List<VascFrontendPageInfoNumber> getTablePagesExtendedCenter();
public List<VascBackendPageNumber> getTablePagesExtendedEnd(); public List<VascFrontendPageInfoNumber> getTablePagesExtendedEnd();
} }

View file

@ -20,25 +20,40 @@
* SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. * SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
*/ */
package net.forwardfire.vasc.backend; package net.forwardfire.vasc.frontend;
import java.io.Serializable; import java.io.Serializable;
/** /**
* Small class to wrap page number and the selected page number. * Small class to wrap page number and the selected page number. note: this can
* note: this can be removed when JSF has the combined EL. * be removed when JSF has the combined EL.
* *
* @author Willem Cazander * @author Willem Cazander
* @version 1.0 Apr 25, 2006 * @version 1.0 Apr 25, 2006
*/ */
public class VascBackendPageNumber implements Serializable { public class VascFrontendPageInfoNumber implements Serializable {
private static final long serialVersionUID = 1L; private static final long serialVersionUID = 1L;
private Integer pageNumber = null; private Integer pageNumber = null;
private Boolean selected = false; private Boolean selected = false;
public VascBackendPageNumber(Integer pageNumber) { this.pageNumber=pageNumber; }
public Integer getPageNumber() { return pageNumber; } public VascFrontendPageInfoNumber(Integer pageNumber) {
public Boolean getSelected() { return selected; } this.pageNumber = pageNumber;
public Boolean getNotSelected() { return !selected; } }
public void setSelected(Boolean selected) { this.selected=selected; }
public Integer getPageNumber() {
return pageNumber;
}
public Boolean getSelected() {
return selected;
}
public Boolean getNotSelected() {
return !selected;
}
public void setSelected(Boolean selected) {
this.selected = selected;
}
} }

View file

@ -29,8 +29,10 @@ import java.util.Locale;
import java.util.Map; import java.util.Map;
import java.util.ResourceBundle; import java.util.ResourceBundle;
import net.forwardfire.vasc.backend.DefaultVascBackendState;
import net.forwardfire.vasc.backend.VascBackend; import net.forwardfire.vasc.backend.VascBackend;
import net.forwardfire.vasc.backend.VascBackendState; import net.forwardfire.vasc.backend.VascBackendState;
import net.forwardfire.vasc.backend.VascEntryFieldValue;
import net.forwardfire.vasc.backend.proxy.VascBackendProxy; import net.forwardfire.vasc.backend.proxy.VascBackendProxy;
import net.forwardfire.vasc.core.VascController; import net.forwardfire.vasc.core.VascController;
import net.forwardfire.vasc.core.VascEntry; import net.forwardfire.vasc.core.VascEntry;
@ -45,7 +47,6 @@ import net.forwardfire.vasc.core.VascInterfaceKeyFrontend;
import net.forwardfire.vasc.core.VascInterfaceLoader; import net.forwardfire.vasc.core.VascInterfaceLoader;
import net.forwardfire.vasc.core.entry.VascEntryExport; import net.forwardfire.vasc.core.entry.VascEntryExport;
import net.forwardfire.vasc.core.entry.VascEntryFieldValidatorService; import net.forwardfire.vasc.core.entry.VascEntryFieldValidatorService;
import net.forwardfire.vasc.core.entry.VascEntryFieldValue;
import net.forwardfire.vasc.core.VascException; import net.forwardfire.vasc.core.VascException;
import net.forwardfire.vasc.frontend.VascFrontendControllerLocal; import net.forwardfire.vasc.frontend.VascFrontendControllerLocal;
import net.forwardfire.vasc.frontend.VascFrontendEntry; import net.forwardfire.vasc.frontend.VascFrontendEntry;
@ -216,7 +217,7 @@ public class DefaultVascEntryConfigController implements VascEntryConfigControll
entry.setVascFrontendController(controller); // <------ This is the end result. entry.setVascFrontendController(controller); // <------ This is the end result.
// Add some generic frontend impl code. // Add some generic frontend impl code.
controller.setVascFrontendPager( loader.createVascFrontendPagerImpl(entry)); controller.setVascFrontendPageInfo( loader.createVascFrontendPagerImpl(entry));
controller.setVascFrontendActions( loader.createVascFrontendActionsImpl(entry)); controller.setVascFrontendActions( loader.createVascFrontendActionsImpl(entry));
controller.setVascFrontendDataSelector( loader.createVascFrontendDataSelectorImpl(entry)); controller.setVascFrontendDataSelector( loader.createVascFrontendDataSelectorImpl(entry));
controller.setVascFrontendUserController( loader.createVascFrontendUserControllerImpl(entry)); controller.setVascFrontendUserController( loader.createVascFrontendUserControllerImpl(entry));
@ -253,7 +254,7 @@ public class DefaultVascEntryConfigController implements VascEntryConfigControll
// Fetch all data field value impl for this backend. // Fetch all data field value impl for this backend.
for (VascEntryField field:entry.getVascEntryFields()) { for (VascEntryField field:entry.getVascEntryFields()) {
if (field.getVascEntryFieldValue()==null) { if (field.getVascEntryFieldValue()==null) {
VascEntryFieldValue v = backend.provideVascEntryFieldValue(field); VascEntryFieldValue v = backend.provideVascEntryFieldValue();
((VascEntryFieldLocal)field).setVascEntryFieldValue(v); ((VascEntryFieldLocal)field).setVascEntryFieldValue(v);
} }
} }

View file

@ -22,6 +22,8 @@
package net.forwardfire.vasc.impl; package net.forwardfire.vasc.impl;
import net.forwardfire.vasc.backend.DefaultVascBackendController;
import net.forwardfire.vasc.backend.DefaultVascBackendState;
import net.forwardfire.vasc.backend.proxy.VascBackendProxyCache; import net.forwardfire.vasc.backend.proxy.VascBackendProxyCache;
import net.forwardfire.vasc.backend.proxy.VascBackendProxyEventExecutor; import net.forwardfire.vasc.backend.proxy.VascBackendProxyEventExecutor;
import net.forwardfire.vasc.backend.proxy.VascBackendProxyFilter; import net.forwardfire.vasc.backend.proxy.VascBackendProxyFilter;

View file

@ -36,7 +36,7 @@ import net.forwardfire.vasc.core.VascInterfaceLoader;
import net.forwardfire.vasc.frontend.VascFrontendActions; import net.forwardfire.vasc.frontend.VascFrontendActions;
import net.forwardfire.vasc.frontend.VascFrontendControllerLocal; import net.forwardfire.vasc.frontend.VascFrontendControllerLocal;
import net.forwardfire.vasc.frontend.VascFrontendDataSelector; import net.forwardfire.vasc.frontend.VascFrontendDataSelector;
import net.forwardfire.vasc.frontend.VascFrontendPager; import net.forwardfire.vasc.frontend.VascFrontendPageInfo;
import net.forwardfire.vasc.frontend.VascFrontendUserController; import net.forwardfire.vasc.frontend.VascFrontendUserController;
import net.forwardfire.vasc.frontend.VascFrontendUserSettingController; import net.forwardfire.vasc.frontend.VascFrontendUserSettingController;
@ -121,8 +121,8 @@ public class DefaultVascInterfaceLoader implements VascInterfaceLoader {
/** /**
* @see net.forwardfire.vasc.core.VascInterfaceLoader#createVascFrontendPagerImpl() * @see net.forwardfire.vasc.core.VascInterfaceLoader#createVascFrontendPagerImpl()
*/ */
public VascFrontendPager createVascFrontendPagerImpl(VascEntry entry) { public VascFrontendPageInfo createVascFrontendPagerImpl(VascEntry entry) {
return (VascFrontendPager)createImpl(VascInterfaceKeyFrontend.VASC_FRONTEND_PAGER,entry); return (VascFrontendPageInfo)createImpl(VascInterfaceKeyFrontend.VASC_FRONTEND_PAGER,entry);
} }
/** /**

View file

@ -1,108 +0,0 @@
/*
* Copyright 2007-2012 forwardfire.net All rights reserved.
*
* Redistribution and use in source and binary forms, with or without modification, are permitted provided
* that the following conditions are met:
*
* * Redistributions of source code must retain the above copyright notice, this list of conditions and the
* following disclaimer.
* * Redistributions in binary form must reproduce the above copyright notice, this list of conditions and
* the following disclaimer in the documentation and/or other materials provided with the distribution.
*
* THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS" AND ANY
* EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES OF
* MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL
* THE COPYRIGHT HOLDER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL,
* SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT
* OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION)
* HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR
* TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS
* SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
*/
package net.forwardfire.vasc.impl.entry;
import net.forwardfire.vasc.core.VascEntryField;
import net.forwardfire.vasc.core.entry.VascEntryFieldValue;
import net.forwardfire.vasc.core.VascException;
import org.x4o.xml.element.DefaultElementObjectPropertyValue;
/**
*
* @author Willem Cazander
* @version 1.0 Mar 21, 2007
*/
public class BeanPropertyVascEntryFieldValue implements VascEntryFieldValue {
private static final long serialVersionUID = 1L;
private String property = null;
private DefaultElementObjectPropertyValue helper = null;
public BeanPropertyVascEntryFieldValue() {
helper = new DefaultElementObjectPropertyValue();
}
public BeanPropertyVascEntryFieldValue(String property) {
this();
setProperty(property);
}
/**
* @see net.forwardfire.vasc.core.column.VascColumnValue#getValue(net.forwardfire.vasc.core.column.VascTableColumn, java.lang.Object)
*/
public Object getValue(VascEntryField column,Object record) throws VascException {
if(getProperty()==null) {
return null;
}
if(getProperty().equals("")) {
return "";
}
try {
return helper.getProperty(record, getProperty());
} catch (Exception e) {
throw new VascException(e);
}
}
/**
* @see net.forwardfire.vasc.core.entry.VascEntryFieldValue#getDisplayValue(net.forwardfire.vasc.core.VascEntryField, java.lang.Object)
*/
public String getDisplayValue(VascEntryField field, Object record) throws VascException {
return ""+getValue(field,record); // not supported
}
/**
* @see net.forwardfire.vasc.core.column.VascColumnValue#setValue(net.forwardfire.vasc.core.column.VascTableColumn, java.lang.Object, java.lang.Object)
*/
public void setValue(VascEntryField column, Object record,Object value) throws VascException {
if(getProperty()==null) {
return;
}
if(getProperty().equals("")) {
return;
}
try {
helper.setProperty(record, getProperty(),value);
} catch (Exception e) {
throw new VascException(e);
}
}
/**
* @return the property
*/
public String getProperty() {
return property;
}
/**
* @param property the property to set
*/
public void setProperty(String property) {
this.property = property;
}
}

View file

@ -25,8 +25,9 @@ package net.forwardfire.vasc.impl.frontend;
import java.util.Date; import java.util.Date;
import java.util.logging.Logger; import java.util.logging.Logger;
import net.forwardfire.vasc.backend.VascBackendFilter; import net.forwardfire.vasc.backend.VascBackendException;
import net.forwardfire.vasc.backend.VascBackendState; import net.forwardfire.vasc.backend.VascBackendState;
import net.forwardfire.vasc.backend.proxy.VascProxyFilter;
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.VascEntryLocal; import net.forwardfire.vasc.core.VascEntryLocal;
@ -58,10 +59,8 @@ public class DefaultVascFrontendActions implements VascFrontendActions {
entry.getVascFrontendController().fireVascFrontendEvent(entry,VascEntryFrontendEventListener.VascFrontendEventType.PRE_CREATE, null); entry.getVascFrontendController().fireVascFrontendEvent(entry,VascEntryFrontendEventListener.VascFrontendEventType.PRE_CREATE, null);
Object object; Object object;
try { try {
object = entry.getVascFrontendController().getVascEntryState().getVascBackend().provideVascEntryRecordCreator(((VascEntryLocal)entry).clone()).newRecord(entry); object = entry.getVascFrontendController().getVascEntryState().getVascBackend().provideVascEntryRecordCreator().newRecord();
} catch (CloneNotSupportedException e) { } catch (VascBackendException e) {
throw new VascFrontendException(e);
} catch (VascException e) {
throw new VascFrontendException(e); throw new VascFrontendException(e);
} }
if (object==null) { if (object==null) {
@ -72,7 +71,7 @@ public class DefaultVascFrontendActions implements VascFrontendActions {
continue; // no default value to set. continue; // no default value to set.
} }
try { try {
Object value = field.getVascEntryFieldValue().getValue(field, object); Object value = field.getVascEntryFieldValue().getValue(field.getBackendName(), object);
if (value!=null) { if (value!=null) {
continue; // value is already set by backend creator. continue; // value is already set by backend creator.
} }
@ -84,8 +83,8 @@ public class DefaultVascFrontendActions implements VascFrontendActions {
} }
} }
logger.finer("Setting default value for: "+field.getName()+" def: "+defaultValue); logger.finer("Setting default value for: "+field.getName()+" def: "+defaultValue);
field.getVascEntryFieldValue().setValue(field, object, defaultValue); field.getVascEntryFieldValue().setValue(field.getBackendName(), object, defaultValue);
} catch (VascException ve) { } catch (VascBackendException ve) {
throw new VascFrontendException(ve); throw new VascFrontendException(ve);
} }
} }
@ -93,7 +92,7 @@ public class DefaultVascFrontendActions implements VascFrontendActions {
return object; return object;
} }
protected int removeObjectFromDataList(Object object) throws VascException { protected int removeObjectFromDataList(Object object) throws VascBackendException {
int indexOld = entry.getVascFrontendController().getVascEntryState().getEntryDataList().indexOf(object); int indexOld = entry.getVascFrontendController().getVascEntryState().getEntryDataList().indexOf(object);
if (entry.getVascFrontendController().getVascEntryState().getEntryDataList().remove(object)) { if (entry.getVascFrontendController().getVascEntryState().getEntryDataList().remove(object)) {
return indexOld; // java worked well for use return indexOld; // java worked well for use
@ -102,14 +101,14 @@ public class DefaultVascFrontendActions implements VascFrontendActions {
// remove only work on (jpa)beans with an overrided equals method. // remove only work on (jpa)beans with an overrided equals method.
// we lets do the search ourselfs here because we should know the primary key value // we lets do the search ourselfs here because we should know the primary key value
VascEntryField field = entry.getVascEntryFieldById(entry.getPrimaryKeyFieldId()); VascEntryField field = entry.getVascEntryFieldById(entry.getPrimaryKeyFieldId());
Object idObject = field.getVascEntryFieldValue().getValue(field, object); Object idObject = field.getVascEntryFieldValue().getValue(field.getBackendName(), object);
// is only null when creating objects // is only null when creating objects
if (idObject!=null) { if (idObject!=null) {
int index = 0; int index = 0;
for (Object o:entry.getVascFrontendController().getVascEntryState().getEntryDataList()) { for (Object o:entry.getVascFrontendController().getVascEntryState().getEntryDataList()) {
field = entry.getVascEntryFieldById(entry.getPrimaryKeyFieldId()); field = entry.getVascEntryFieldById(entry.getPrimaryKeyFieldId());
Object id = field.getVascEntryFieldValue().getValue(field, o); Object id = field.getVascEntryFieldValue().getValue(field.getBackendName(), o);
if (idObject.equals(id)) { if (idObject.equals(id)) {
break; break;
} }
@ -146,32 +145,35 @@ public class DefaultVascFrontendActions implements VascFrontendActions {
} }
protected Object saveObject(boolean persist) throws VascException { protected Object saveObject(boolean persist) throws VascException {
Object object = entry.getVascFrontendController().getVascEntryState().getEntryDataObject(); try {
Object result = null; Object object = entry.getVascFrontendController().getVascEntryState().getEntryDataObject();
Object 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);
// save object on backend // save object on backend
if (persist) { if (persist) {
entry.getVascFrontendController().getVascEntryState().getVascBackend().persist(object); entry.getVascFrontendController().getVascEntryState().getVascBackend().persist(object);
result = object; // TODO: fix persist result = object; // TODO: fix persist
entry.getVascFrontendController().getVascEntryState().setTotalBackendRecords(1+entry.getVascFrontendController().getVascEntryState().getTotalBackendRecords()); entry.getVascFrontendController().getVascEntryState().setTotalBackendRecords(1+entry.getVascFrontendController().getVascEntryState().getTotalBackendRecords());
} else { } else {
result = entry.getVascFrontendController().getVascEntryState().getVascBackend().merge(object); result = entry.getVascFrontendController().getVascEntryState().getVascBackend().merge(object);
}
// put object thrue the filters
for (VascProxyFilter filter:entry.getVascBackendFilters()) {
result = filter.filterObject(result);
}
// put object back in list
entry.getVascFrontendController().getVascEntryState().getEntryDataList().add(index, result);
entry.getVascFrontendController().getVascEntryState().setEntryDataObject(null);
entry.getVascFrontendController().fireVascFrontendEvent(entry,VascEntryFrontendEventListener.VascFrontendEventType.POST_UPDATE,result);
return result;
} catch (VascBackendException e) {
throw new VascException(e);
} }
// put object thrue the filters
for (VascBackendFilter filter:entry.getVascBackendFilters()) {
result = filter.filterObject(result);
}
// put object back in list
entry.getVascFrontendController().getVascEntryState().getEntryDataList().add(index, result);
entry.getVascFrontendController().getVascEntryState().setEntryDataObject(null);
entry.getVascFrontendController().fireVascFrontendEvent(entry,VascEntryFrontendEventListener.VascFrontendEventType.POST_UPDATE,result);
return result;
} }
/** /**
@ -189,7 +191,7 @@ public class DefaultVascFrontendActions implements VascFrontendActions {
entry.getVascFrontendController().getVascEntryState().setEntryDataObject(null); entry.getVascFrontendController().getVascEntryState().setEntryDataObject(null);
entry.getVascFrontendController().getVascEntryState().setTotalBackendRecords(entry.getVascFrontendController().getVascEntryState().getTotalBackendRecords()-1); entry.getVascFrontendController().getVascEntryState().setTotalBackendRecords(entry.getVascFrontendController().getVascEntryState().getTotalBackendRecords()-1);
entry.getVascFrontendController().fireVascFrontendEvent(entry,VascEntryFrontendEventListener.VascFrontendEventType.POST_DELETE, object); entry.getVascFrontendController().fireVascFrontendEvent(entry,VascEntryFrontendEventListener.VascFrontendEventType.POST_DELETE, object);
} catch (VascException ve) { } catch (VascBackendException ve) {
throw new VascFrontendException(ve); throw new VascFrontendException(ve);
} }
} }
@ -234,7 +236,7 @@ public class DefaultVascFrontendActions implements VascFrontendActions {
// Fire event post read // Fire event post read
entry.getVascFrontendController().fireVascFrontendEvent(entry,VascEntryFrontendEventListener.VascFrontendEventType.POST_READ, null); entry.getVascFrontendController().fireVascFrontendEvent(entry,VascEntryFrontendEventListener.VascFrontendEventType.POST_READ, null);
} catch (VascException ve) { } catch (VascBackendException ve) {
throw new VascFrontendException(ve); throw new VascFrontendException(ve);
} }
} }
@ -285,9 +287,9 @@ public class DefaultVascFrontendActions implements VascFrontendActions {
if (entry.getVascFrontendController().getVascEntryState().getVascBackend().isRecordMoveable()) { if (entry.getVascFrontendController().getVascEntryState().getVascBackend().isRecordMoveable()) {
try { try {
VascEntryField p = entry.getVascEntryFieldById(entry.getPrimaryKeyFieldId()); VascEntryField p = entry.getVascEntryFieldById(entry.getPrimaryKeyFieldId());
Object primaryId = p.getVascEntryFieldValue().getValue(p, record); Object primaryId = p.getVascEntryFieldValue().getValue(p.getBackendName(), record);
entry.getVascFrontendController().getVascEntryState().getVascBackend().doRecordMoveUpById(entry.getVascFrontendController().getVascEntryState().getVascBackendState(),primaryId); entry.getVascFrontendController().getVascEntryState().getVascBackend().doRecordMoveUpById(entry.getVascFrontendController().getVascEntryState().getVascBackendState(),primaryId);
} catch (VascException ve) { } catch (VascBackendException ve) {
throw new VascFrontendException(ve); throw new VascFrontendException(ve);
} }
@ -303,9 +305,9 @@ public class DefaultVascFrontendActions implements VascFrontendActions {
try { try {
VascEntryField p = entry.getVascEntryFieldById(entry.getPrimaryKeyFieldId()); VascEntryField p = entry.getVascEntryFieldById(entry.getPrimaryKeyFieldId());
Object primaryId = p.getVascEntryFieldValue().getValue(p, record); Object primaryId = p.getVascEntryFieldValue().getValue(p.getBackendName(), record);
entry.getVascFrontendController().getVascEntryState().getVascBackend().doRecordMoveDownById(entry.getVascFrontendController().getVascEntryState().getVascBackendState(),primaryId); entry.getVascFrontendController().getVascEntryState().getVascBackend().doRecordMoveDownById(entry.getVascFrontendController().getVascEntryState().getVascBackendState(),primaryId);
} catch (VascException ve) { } catch (VascBackendException ve) {
throw new VascFrontendException(ve); throw new VascFrontendException(ve);
} }

View file

@ -49,7 +49,7 @@ import net.forwardfire.vasc.frontend.VascFrontendActions;
import net.forwardfire.vasc.frontend.VascFrontendControllerLocal; import net.forwardfire.vasc.frontend.VascFrontendControllerLocal;
import net.forwardfire.vasc.frontend.VascFrontendDataSelector; import net.forwardfire.vasc.frontend.VascFrontendDataSelector;
import net.forwardfire.vasc.frontend.VascFrontendHelper; import net.forwardfire.vasc.frontend.VascFrontendHelper;
import net.forwardfire.vasc.frontend.VascFrontendPager; import net.forwardfire.vasc.frontend.VascFrontendPageInfo;
import net.forwardfire.vasc.frontend.VascFrontendUserController; import net.forwardfire.vasc.frontend.VascFrontendUserController;
import net.forwardfire.vasc.frontend.VascFrontendUserSettingController; import net.forwardfire.vasc.frontend.VascFrontendUserSettingController;
@ -64,7 +64,7 @@ public class DefaultVascFrontendController implements VascFrontendControllerLoca
private VascFrontend vascFrontend = null; private VascFrontend vascFrontend = null;
private VascFrontendActions vascFrontendActions = null; private VascFrontendActions vascFrontendActions = null;
private VascFrontendPager vascFrontendPager = null; private VascFrontendPageInfo vascFrontendPageInfo = null;
private VascEntryConfigFinalizer vascEntryFinalizer = null; private VascEntryConfigFinalizer vascEntryFinalizer = null;
private VascFrontendHelper vascFrontendHelper = null; private VascFrontendHelper vascFrontendHelper = null;
private VascEntryResourceResolver vascEntryResourceResolver = null; private VascEntryResourceResolver vascEntryResourceResolver = null;
@ -121,15 +121,15 @@ public class DefaultVascFrontendController implements VascFrontendControllerLoca
/** /**
* @return the vascFrontendPager * @return the vascFrontendPager
*/ */
public VascFrontendPager getVascFrontendPager() { public VascFrontendPageInfo getVascFrontendPageInfo() {
return vascFrontendPager; return vascFrontendPageInfo;
} }
/** /**
* @param vascFrontendPager the vascFrontendPager to set * @param vascFrontendPager the vascFrontendPager to set
*/ */
public void setVascFrontendPager(VascFrontendPager vascFrontendPager) { public void setVascFrontendPageInfo(VascFrontendPageInfo vascFrontendPageInfo) {
this.vascFrontendPager = vascFrontendPager; this.vascFrontendPageInfo = vascFrontendPageInfo;
} }
/** /**

View file

@ -26,13 +26,14 @@ import java.util.ArrayList;
import java.util.List; import java.util.List;
import java.util.logging.Logger; import java.util.logging.Logger;
import net.forwardfire.vasc.backend.VascBackendException;
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.VascEntryLink; import net.forwardfire.vasc.core.VascEntryLink;
import net.forwardfire.vasc.core.VascEntryLinkType; import net.forwardfire.vasc.core.VascEntryLinkType;
import net.forwardfire.vasc.core.actions.RowVascAction; import net.forwardfire.vasc.core.actions.RowVascAction;
import net.forwardfire.vasc.core.entry.VascEntryFieldValidatorService; import net.forwardfire.vasc.core.entry.VascEntryFieldValidatorService;
import net.forwardfire.vasc.core.entry.VascEntryFieldValue;
import net.forwardfire.vasc.core.ui.VascUIComponent; import net.forwardfire.vasc.core.ui.VascUIComponent;
import net.forwardfire.vasc.core.VascException; import net.forwardfire.vasc.core.VascException;
import net.forwardfire.vasc.frontend.VascFrontendHelper; import net.forwardfire.vasc.frontend.VascFrontendHelper;
@ -107,11 +108,15 @@ public class DefaultVascFrontendHelper implements VascFrontendHelper {
} }
Object objectSelected = entry.getVascFrontendController().getVascEntryState().getEntryDataObject(); Object objectSelected = entry.getVascFrontendController().getVascEntryState().getEntryDataObject();
Object objectValue = field.getVascEntryFieldValue().getValue(field, objectSelected); try {
for (VascEntryFieldValidatorService s:entry.getVascFrontendController().getVascValidatorServices()) { Object objectValue = field.getVascEntryFieldValue().getValue(field.getBackendName(), objectSelected);
error.addAll(s.validateObjectField(field, objectSelected, objectValue)); for (VascEntryFieldValidatorService s:entry.getVascFrontendController().getVascValidatorServices()) {
error.addAll(s.validateObjectField(field, objectSelected, objectValue));
}
return error;
} catch (VascBackendException e) {
throw new VascException(e);
} }
return error;
} }
/** /**
@ -192,8 +197,8 @@ public class DefaultVascFrontendHelper implements VascFrontendHelper {
VascEntryFieldValue ve = v.getVascEntryFieldValue(); VascEntryFieldValue ve = v.getVascEntryFieldValue();
String result = "no-data"; String result = "no-data";
try { try {
result = ve.getDisplayValue(v, row); result = ve.getDisplayValue(v.getBackendName(), row);
} catch (VascException e) { } catch (VascBackendException e) {
throw new RuntimeException("Could not get selected name DisplayValue: "+e.getMessage(),e); throw new RuntimeException("Could not get selected name DisplayValue: "+e.getMessage(),e);
} }
return result; return result;
@ -213,8 +218,8 @@ public class DefaultVascFrontendHelper implements VascFrontendHelper {
VascEntryFieldValue ve = v.getVascEntryFieldValue(); VascEntryFieldValue ve = v.getVascEntryFieldValue();
String result = "no-data"; String result = "no-data";
try { try {
result = ve.getDisplayValue(v, row); result = ve.getDisplayValue(v.getBackendName(), row);
} catch (VascException e) { } catch (VascBackendException e) {
throw new RuntimeException("Could not get parent name DisplayValue: "+e.getMessage(),e); throw new RuntimeException("Could not get parent name DisplayValue: "+e.getMessage(),e);
} }
return result; return result;

View file

@ -25,11 +25,11 @@ package net.forwardfire.vasc.impl.frontend;
import java.util.ArrayList; import java.util.ArrayList;
import java.util.List; import java.util.List;
import net.forwardfire.vasc.backend.VascBackendPageNumber;
import net.forwardfire.vasc.backend.VascBackendState; import net.forwardfire.vasc.backend.VascBackendState;
import net.forwardfire.vasc.core.VascEntry; import net.forwardfire.vasc.core.VascEntry;
import net.forwardfire.vasc.core.entry.VascEntryFrontendEventListener; import net.forwardfire.vasc.core.entry.VascEntryFrontendEventListener;
import net.forwardfire.vasc.frontend.VascFrontendPager; import net.forwardfire.vasc.frontend.VascFrontendPageInfoNumber;
import net.forwardfire.vasc.frontend.VascFrontendPageInfo;
/** /**
@ -38,15 +38,15 @@ import net.forwardfire.vasc.frontend.VascFrontendPager;
* @author Willem Cazander * @author Willem Cazander
* @version 1.0 Jan 22, 2012 * @version 1.0 Jan 22, 2012
*/ */
public class DefaultVascFrontendPager implements VascFrontendPager { public class DefaultVascFrontendPager implements VascFrontendPageInfo {
//private Logger logger = Logger.getLogger(DefaultVascFrontendPager.class.getName()); //private Logger logger = Logger.getLogger(DefaultVascFrontendPager.class.getName());
private VascEntry entry = null; private VascEntry entry = null;
private List<VascBackendPageNumber> pagesAll = null; private List<VascFrontendPageInfoNumber> pagesAll = null;
public void init(VascEntry entry) { public void init(VascEntry entry) {
this.entry=entry; this.entry=entry;
pagesAll = new ArrayList<VascBackendPageNumber>(0); pagesAll = new ArrayList<VascFrontendPageInfoNumber>(0);
entry.getVascFrontendController().addVascEntryFrontendEventListener(new DefaultVascFrontendPagerEventListener()); entry.getVascFrontendController().addVascEntryFrontendEventListener(new DefaultVascFrontendPagerEventListener());
} }
@ -138,8 +138,8 @@ public class DefaultVascFrontendPager implements VascFrontendPager {
return true; return true;
} }
public List<VascBackendPageNumber> getTablePagesFromBackend() { public List<VascFrontendPageInfoNumber> getTablePagesFromBackend() {
List<VascBackendPageNumber> result = new ArrayList<VascBackendPageNumber>(30); List<VascFrontendPageInfoNumber> result = new ArrayList<VascFrontendPageInfoNumber>(30);
VascBackendState state = entry.getVascFrontendController().getVascEntryState().getVascBackendState(); VascBackendState state = entry.getVascFrontendController().getVascEntryState().getVascBackendState();
if (state.getPageSize()==0) { if (state.getPageSize()==0) {
return result; // paging disabled return result; // paging disabled
@ -150,7 +150,7 @@ public class DefaultVascFrontendPager implements VascFrontendPager {
} }
int pages = new Long(total/state.getPageSize()).intValue(); int pages = new Long(total/state.getPageSize()).intValue();
for (int i=0;i<=pages;i++) { for (int i=0;i<=pages;i++) {
VascBackendPageNumber pn = new VascBackendPageNumber(i); VascFrontendPageInfoNumber pn = new VascFrontendPageInfoNumber(i);
if (state.getPageIndex()==i) { if (state.getPageIndex()==i) {
pn.setSelected(true); pn.setSelected(true);
} }
@ -159,16 +159,16 @@ public class DefaultVascFrontendPager implements VascFrontendPager {
return result; return result;
} }
public List<VascBackendPageNumber> getTablePagesNormal() { public List<VascFrontendPageInfoNumber> getTablePagesNormal() {
if (getHasExtendedPageMode()) { if (getHasExtendedPageMode()) {
return new ArrayList<VascBackendPageNumber>(0); return new ArrayList<VascFrontendPageInfoNumber>(0);
} else { } else {
return pagesAll; return pagesAll;
} }
} }
public List<VascBackendPageNumber> getTablePagesExtendedBegin() { public List<VascFrontendPageInfoNumber> getTablePagesExtendedBegin() {
List<VascBackendPageNumber> result = new ArrayList<VascBackendPageNumber>(6); List<VascFrontendPageInfoNumber> result = new ArrayList<VascFrontendPageInfoNumber>(6);
if (pagesAll.size()>0) { if (pagesAll.size()>0) {
result.add(pagesAll.get(0)); result.add(pagesAll.get(0));
} }
@ -200,8 +200,8 @@ public class DefaultVascFrontendPager implements VascFrontendPager {
return result; return result;
} }
public List<VascBackendPageNumber> getTablePagesExtendedEnd() { public List<VascFrontendPageInfoNumber> getTablePagesExtendedEnd() {
List<VascBackendPageNumber> result = new ArrayList<VascBackendPageNumber>(6); List<VascFrontendPageInfoNumber> result = new ArrayList<VascFrontendPageInfoNumber>(6);
int pages = pagesAll.size(); int pages = pagesAll.size();
int page = entry.getVascFrontendController().getVascEntryState().getVascBackendState().getPageIndex(); int page = entry.getVascFrontendController().getVascEntryState().getVascBackendState().getPageIndex();
int off = pages-page; int off = pages-page;
@ -224,8 +224,8 @@ public class DefaultVascFrontendPager implements VascFrontendPager {
return result; return result;
} }
public List<VascBackendPageNumber> getTablePagesExtendedCenter() { public List<VascFrontendPageInfoNumber> getTablePagesExtendedCenter() {
List<VascBackendPageNumber> result = new ArrayList<VascBackendPageNumber>(3); List<VascFrontendPageInfoNumber> result = new ArrayList<VascFrontendPageInfoNumber>(3);
int page = entry.getVascFrontendController().getVascEntryState().getVascBackendState().getPageIndex(); int page = entry.getVascFrontendController().getVascEntryState().getVascBackendState().getPageIndex();
if (page>0 && pagesAll.size() > page-1) { if (page>0 && pagesAll.size() > page-1) {
result.add(pagesAll.get(page-1)); result.add(pagesAll.get(page-1));

View file

@ -27,17 +27,17 @@ import java.util.HashMap;
import java.util.List; import java.util.List;
import java.util.Map; import java.util.Map;
import net.forwardfire.vasc.backend.DefaultVascBackendState;
import net.forwardfire.vasc.backend.VascBackend; import net.forwardfire.vasc.backend.VascBackend;
import net.forwardfire.vasc.backend.VascBackendState; import net.forwardfire.vasc.backend.VascBackendState;
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.VascEntryFieldLocal; import net.forwardfire.vasc.core.VascEntryFieldLocal;
import net.forwardfire.vasc.core.VascEntryLocal; import net.forwardfire.vasc.core.VascEntryLocal;
import net.forwardfire.vasc.core.entry.VascEntryFieldValue;
import net.forwardfire.vasc.core.ui.VascSelectItem; import net.forwardfire.vasc.core.ui.VascSelectItem;
import net.forwardfire.vasc.core.ui.VascSelectItemModel; import net.forwardfire.vasc.core.ui.VascSelectItemModel;
import net.forwardfire.vasc.core.VascException; import net.forwardfire.vasc.core.VascException;
import net.forwardfire.vasc.impl.DefaultVascBackendState;
/** /**
* The DefaultVascSelectItemModel * The DefaultVascSelectItemModel
@ -135,14 +135,14 @@ public class VascSelectItemModelEntry implements VascSelectItemModel {
} }
VascEntryField field = fieldOrg.clone(); VascEntryField field = fieldOrg.clone();
field.getVascValidators().clear(); field.getVascValidators().clear();
VascEntryFieldValue v = fieldEntry.getVascFrontendController().getVascEntryState().getVascBackend().provideVascEntryFieldValue(field); VascEntryFieldValue v = fieldEntry.getVascFrontendController().getVascEntryState().getVascBackend().provideVascEntryFieldValue();
Object record = fieldEntry.getVascFrontendController().getVascEntryState().getEntryDataObject(); Object record = fieldEntry.getVascFrontendController().getVascEntryState().getEntryDataObject();
if (record==null) { if (record==null) {
//System.out.println("could not get selected records from state."); //System.out.println("could not get selected records from state.");
continue; continue;
} }
Object value = v.getValue(fieldOrg, record); Object value = v.getValue(fieldOrg.getBackendName(), record);
//System.out.println("Set entry paras name: "+paraName+" value: "+value+" class: "+value.getClass().getName()); //System.out.println("Set entry paras name: "+paraName+" value: "+value+" class: "+value.getClass().getName());
state.setDataParameter(paraName, value); state.setDataParameter(paraName, value);
@ -155,7 +155,7 @@ public class VascSelectItemModelEntry implements VascSelectItemModel {
VascEntryField fieldClone = key.clone(); VascEntryField fieldClone = key.clone();
fieldClone.getVascValidators().clear(); fieldClone.getVascValidators().clear();
VascEntryFieldValue v = currentEntry.getVascFrontendController().getVascEntryState().getVascBackend().provideVascEntryFieldValue(fieldClone); VascEntryFieldValue v = currentEntry.getVascFrontendController().getVascEntryState().getVascBackend().provideVascEntryFieldValue();
key.setVascEntryFieldValue(v); key.setVascEntryFieldValue(v);
} }
if (dis.getVascEntryFieldValue()==null) { if (dis.getVascEntryFieldValue()==null) {
@ -163,15 +163,15 @@ public class VascSelectItemModelEntry implements VascSelectItemModel {
VascEntryField fieldClone = dis.clone(); VascEntryField fieldClone = dis.clone();
fieldClone.getVascValidators().clear(); fieldClone.getVascValidators().clear();
VascEntryFieldValue v = currentEntry.getVascFrontendController().getVascEntryState().getVascBackend().provideVascEntryFieldValue(fieldClone); VascEntryFieldValue v = currentEntry.getVascFrontendController().getVascEntryState().getVascBackend().provideVascEntryFieldValue();
dis.setVascEntryFieldValue(v); dis.setVascEntryFieldValue(v);
} }
// execute // execute
for (Object o:back.execute(state)) { for (Object o:back.execute(state)) {
Object keyId = key.getVascEntryFieldValue().getValue(key, o); Object keyId = key.getVascEntryFieldValue().getValue(key.getBackendName(), o);
String nameId = dis.getVascEntryFieldValue().getDisplayValue(dis, o); String nameId = dis.getVascEntryFieldValue().getDisplayValue(dis.getBackendName(), o);
if (returnKeyValue!=null && false==returnKeyValue) { if (returnKeyValue!=null && false==returnKeyValue) {
VascSelectItem item = new VascSelectItem(nameId,o,""+keyId); VascSelectItem item = new VascSelectItem(nameId,o,""+keyId);
result.add(item); result.add(item);

View file

@ -17,10 +17,11 @@
parentClass="net.forwardfire.vasc.core.VascEntryLocal" childClass="net.forwardfire.vasc.core.VascEntryLinkLocal" parentClass="net.forwardfire.vasc.core.VascEntryLocal" childClass="net.forwardfire.vasc.core.VascEntryLinkLocal"
addMethod="addVascEntryLink" getMethod="getVascEntryLinksLocal" addMethod="addVascEntryLink" getMethod="getVascEntryLinksLocal"
/> />
<!--
<eld:classBindingHandler id="VascEntryLocal-VascBackendFilter" <eld:classBindingHandler id="VascEntryLocal-VascBackendFilter"
parentClass="net.forwardfire.vasc.core.VascEntryLocal" childClass="net.forwardfire.vasc.backend.VascBackendFilter" parentClass="net.forwardfire.vasc.core.VascEntryLocal" childClass="net.forwardfire.vasc.backend.VascBackendFilter"
addMethod="addVascBackendFilter" getMethod="getVascBackendFilters" addMethod="addVascBackendFilter" getMethod="getVascBackendFilters"
/> /> -->
<eld:classBindingHandler id="VascEntryLocal-GlobalVascAction" <eld:classBindingHandler id="VascEntryLocal-GlobalVascAction"
parentClass="net.forwardfire.vasc.core.VascEntryLocal" childClass="net.forwardfire.vasc.core.actions.GlobalVascAction" parentClass="net.forwardfire.vasc.core.VascEntryLocal" childClass="net.forwardfire.vasc.core.actions.GlobalVascAction"
addMethod="addGlobalAction" getMethod="getGlobalActionsLocal" addMethod="addGlobalAction" getMethod="getGlobalActionsLocal"
@ -139,11 +140,5 @@
<eld:element tag="stringRegexValidator" objectClass="net.forwardfire.vasc.validators.VascStringRegexValidator"/> <eld:element tag="stringRegexValidator" objectClass="net.forwardfire.vasc.validators.VascStringRegexValidator"/>
<eld:element tag="stringZipCodeValidator" objectClass="net.forwardfire.vasc.validators.VascStringZipCodeValidator"/> <eld:element tag="stringZipCodeValidator" objectClass="net.forwardfire.vasc.validators.VascStringZipCodeValidator"/>
<eld:element tag="virtualVascBackend" objectClass="net.forwardfire.vasc.backend.VirtualVascBackend">
<eld:configurator id="virtualVascBackend-VascBackendElementConfigurator" bean.class="net.forwardfire.vasc.impl.x4o.VascBackendElementConfigurator" configAction="true"/>
<eld:elementParent tag="root" uri="http://vasc.forwardfire.net/xml/ns/vasc-root"/>
</eld:element>
</eld:namespace> </eld:namespace>
</root:module> </root:module>

View file

@ -2,6 +2,7 @@
<vasc:root xmlns:vasc="http://vasc.forwardfire.net/xml/ns/vasc-root" <vasc:root xmlns:vasc="http://vasc.forwardfire.net/xml/ns/vasc-root"
xmlns:v="http://vasc.forwardfire.net/xml/ns/vasc-lang" xmlns:v="http://vasc.forwardfire.net/xml/ns/vasc-lang"
xmlns:mm="http://vasc.forwardfire.net/xml/ns/vasc-backend-metamodel" xmlns:mm="http://vasc.forwardfire.net/xml/ns/vasc-backend-metamodel"
xmlns:omm="http://vasc.forwardfire.net/xml/ns/vasc-opt-metamodel"
xmlns:td="http://vasc.forwardfire.net/xml/ns/vasc-tech-demo" xmlns:td="http://vasc.forwardfire.net/xml/ns/vasc-tech-demo"
> >
@ -40,10 +41,10 @@
<mm:jndiDataContext el.id="mmdc5" jndiName="java:mmdc/server/conf/web.xml"/> <mm:jndiDataContext el.id="mmdc5" jndiName="java:mmdc/server/conf/web.xml"/>
<!-- Auto config schema from MetaModel backends. --> <!-- Auto config schema from MetaModel backends. -->
<mm:schemaAutoEntry vascGroupId="tech-server" dataContextProvider="${mmdc1}" entryPrefix="AdminConfServer" /> <omm:schemaAutoEntry vascGroupId="tech-server" dataContextProvider="${mmdc1}" entryPrefix="AdminConfServer" />
<mm:schemaAutoEntry vascGroupId="tech-server" dataContextProvider="${mmdc2}" entryPrefix="AdminConfLogServer" /> <omm:schemaAutoEntry vascGroupId="tech-server" dataContextProvider="${mmdc2}" entryPrefix="AdminConfLogServer" />
<mm:schemaAutoEntry vascGroupId="tech-server" dataContextProvider="${mmdc3}" entryPrefix="AdminConfLogAccess" /> <omm:schemaAutoEntry vascGroupId="tech-server" dataContextProvider="${mmdc3}" entryPrefix="AdminConfLogAccess" />
<mm:schemaAutoEntry vascGroupId="tech-server" dataContextProvider="${mmdc4}" entryPrefix="AdminConfConfig" /> <omm:schemaAutoEntry vascGroupId="tech-server" dataContextProvider="${mmdc4}" entryPrefix="AdminConfConfig" />
<mm:schemaAutoEntry vascGroupId="tech-server" dataContextProvider="${mmdc5}" entryPrefix="AdminConfWeb" /> <omm:schemaAutoEntry vascGroupId="tech-server" dataContextProvider="${mmdc5}" entryPrefix="AdminConfWeb" />
</vasc:root> </vasc:root>

View file

@ -14,7 +14,7 @@
<version>${project.version}</version> <version>${project.version}</version>
</dependency> </dependency>
<dependency> <dependency>
<groupId>net.forwardfire.vasc</groupId> <groupId>net.forwardfire.vasc.backend</groupId>
<artifactId>vasc-backend-metamodel</artifactId> <artifactId>vasc-backend-metamodel</artifactId>
<version>${project.version}</version> <version>${project.version}</version>
</dependency> </dependency>

View file

@ -103,22 +103,22 @@
<version>${project.version}</version> <version>${project.version}</version>
</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>
</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>
</dependency> </dependency>
<dependency> <dependency>
<groupId>net.forwardfire.vasc</groupId> <groupId>net.forwardfire.vasc.backend</groupId>
<artifactId>vasc-backend-metamodel</artifactId> <artifactId>vasc-backend-metamodel</artifactId>
<version>${project.version}</version> <version>${project.version}</version>
</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>
</dependency> </dependency>
@ -138,8 +138,13 @@
<version>${project.version}</version> <version>${project.version}</version>
</dependency> </dependency>
<dependency> <dependency>
<groupId>net.forwardfire.vasc.lib</groupId> <groupId>net.forwardfire.vasc.opt</groupId>
<artifactId>vasc-lib-editor</artifactId> <artifactId>vasc-opt-editor</artifactId>
<version>${project.version}</version>
</dependency>
<dependency>
<groupId>net.forwardfire.vasc.opt</groupId>
<artifactId>vasc-opt-metamodel</artifactId>
<version>${project.version}</version> <version>${project.version}</version>
</dependency> </dependency>
<dependency> <dependency>

View file

@ -45,8 +45,9 @@ import net.forwardfire.vasc.demo.server.tomcat.TomcatService;
* @author Willem Cazander * @author Willem Cazander
* @version 1.0 May 3, 2012 * @version 1.0 May 3, 2012
*/ */
public class VascTechDemoStartup { public enum VascTechDemoStartup {
INSTANCE;
private Logger logger = null; private Logger logger = null;
private ServerConfigService serverConfigService = null; private ServerConfigService serverConfigService = null;
private DatabaseService databaseService = null; private DatabaseService databaseService = null;
@ -54,16 +55,15 @@ public class VascTechDemoStartup {
private VascControllerService vascControllerService = null; private VascControllerService vascControllerService = null;
private ServerGuiService swingGuiService = null; private ServerGuiService swingGuiService = null;
private VascTechDemoBuildInfo buildInfo = null; private VascTechDemoBuildInfo buildInfo = null;
static private VascTechDemoStartup instance = null; private volatile boolean shutdownOnce = false;
/** /**
* Starts this VascTechDemo instance * Starts this VascTechDemo instance
* @param args * @param args
*/ */
static public void main(String[] args) { static public void main(String[] args) {
instance = new VascTechDemoStartup(); INSTANCE.initialize(args);
instance.initialize(args); INSTANCE.startup();
instance.startup();
} }
/** /**
@ -220,10 +220,10 @@ public class VascTechDemoStartup {
} }
public void shutdown() { public void shutdown() {
if (instance==null) { if (shutdownOnce) {
return; return;
} }
shutdownOnce = true;
Thread t = new Thread(new Runnable() { Thread t = new Thread(new Runnable() {
public void run() { public void run() {
try { try {
@ -238,8 +238,6 @@ public class VascTechDemoStartup {
} catch (Exception e) { } catch (Exception e) {
e.printStackTrace(); e.printStackTrace();
System.exit(1); System.exit(1);
} finally {
instance = null;
} }
} }
}); });
@ -248,7 +246,7 @@ public class VascTechDemoStartup {
} }
static public VascTechDemoStartup getInstance() { static public VascTechDemoStartup getInstance() {
return instance; return INSTANCE;
} }
public boolean isMavenRun() { public boolean isMavenRun() {

View file

@ -105,7 +105,7 @@ public class VascControllerService {
VascDriver driver = VascDriver.getInstance(); VascDriver driver = VascDriver.getInstance();
X4OReader<VascController> reader = driver.createReader(); X4OReader<VascController> reader = driver.createReader();
driver.addVascController(reader, vascController); driver.addVascController(reader, vascController);
reader.readResource("net/forwardfire/vasc/lib/editor/vasc-edit.xml"); reader.readResource("net/forwardfire/vasc/opt/editor/vasc-editor.xml");
DefaultVascFactory.fillVascControllerLocalEntries((VascEntryControllerLocal) vascController.getVascEntryController(), vascController); DefaultVascFactory.fillVascControllerLocalEntries((VascEntryControllerLocal) vascController.getVascEntryController(), vascController);
vascController.getVascEventChannelController().fireEvent(VascEventControllerType.LOAD_ENTRIES_AFTER, vascController); vascController.getVascEventChannelController().fireEvent(VascEventControllerType.LOAD_ENTRIES_AFTER, vascController);

View file

@ -36,7 +36,7 @@ import javax.swing.JLabel;
import javax.swing.JPanel; import javax.swing.JPanel;
import net.forwardfire.vasc.backend.metamodel.MetaModelDataContextCsv; import net.forwardfire.vasc.backend.metamodel.MetaModelDataContextCsv;
import net.forwardfire.vasc.backend.metamodel.MetaModelSchemaAutoEntry; import net.forwardfire.vasc.opt.metamodel.MetaModelSchemaAutoEntry;
/** /**
* JDialogMetaCsv Add and runs MetaModel Schema Auto Entry code. * JDialogMetaCsv Add and runs MetaModel Schema Auto Entry code.

View file

@ -24,7 +24,6 @@ package net.forwardfire.vasc.demo.server.ui.load;
import net.forwardfire.vasc.backend.metamodel.MetaModelDataContextJdbc; import net.forwardfire.vasc.backend.metamodel.MetaModelDataContextJdbc;
import net.forwardfire.vasc.backend.metamodel.MetaModelDataContextMongodb; import net.forwardfire.vasc.backend.metamodel.MetaModelDataContextMongodb;
import net.forwardfire.vasc.backend.metamodel.MetaModelSchemaAutoEntry;
import net.forwardfire.vasc.backend.metamodel.MetaModelVascBackend; import net.forwardfire.vasc.backend.metamodel.MetaModelVascBackend;
import net.forwardfire.vasc.core.VascController; import net.forwardfire.vasc.core.VascController;
import net.forwardfire.vasc.core.VascEntry; import net.forwardfire.vasc.core.VascEntry;
@ -33,6 +32,7 @@ import net.forwardfire.vasc.core.VascEntryFieldType;
import net.forwardfire.vasc.core.VascEntryLink; import net.forwardfire.vasc.core.VascEntryLink;
import net.forwardfire.vasc.core.VascEntryLinkType; import net.forwardfire.vasc.core.VascEntryLinkType;
import net.forwardfire.vasc.impl.ui.VascSelectItemModelEntry; import net.forwardfire.vasc.impl.ui.VascSelectItemModelEntry;
import net.forwardfire.vasc.opt.metamodel.MetaModelSchemaAutoEntry;
import org.x4o.xml.io.sax.ext.ContentWriterXml; import org.x4o.xml.io.sax.ext.ContentWriterXml;
import org.xml.sax.SAXException; import org.xml.sax.SAXException;
@ -68,7 +68,6 @@ public class LoadVascXmlWriter {
autoEntry.setEntryPrefix(model.name); autoEntry.setEntryPrefix(model.name);
autoEntry.setDataContextProvider(model.dcProvider); autoEntry.setDataContextProvider(model.dcProvider);
autoEntry.getTables().addAll(model.tables); autoEntry.getTables().addAll(model.tables);
autoEntry.autoFillResult(vc); autoEntry.autoFillResult(vc);
xmlWriter.startDocument(); xmlWriter.startDocument();

View file

@ -28,7 +28,7 @@
<scope>provided</scope> <scope>provided</scope>
</dependency> </dependency>
<dependency> <dependency>
<groupId>net.forwardfire.vasc</groupId> <groupId>net.forwardfire.vasc.backend</groupId>
<artifactId>vasc-backend-metamodel</artifactId> <artifactId>vasc-backend-metamodel</artifactId>
<version>${project.version}</version> <version>${project.version}</version>
<scope>provided</scope> <scope>provided</scope>

View file

@ -27,6 +27,7 @@ import java.io.OutputStream;
import java.util.ArrayList; import java.util.ArrayList;
import java.util.List; import java.util.List;
import net.forwardfire.vasc.backend.VascBackendException;
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.entry.VascEntryExport; import net.forwardfire.vasc.core.entry.VascEntryExport;
@ -67,7 +68,11 @@ abstract public class AbstractVascEntryExportWriter implements VascEntryExportWr
for (int dataIndex=0;dataIndex<dataSize;dataIndex++) { for (int dataIndex=0;dataIndex<dataSize;dataIndex++) {
Object o = entry.getVascFrontendController().getVascEntryState().getEntryDataList().get(dataIndex); Object o = entry.getVascFrontendController().getVascEntryState().getEntryDataList().get(dataIndex);
doExportRowStart(o); doExportRowStart(o);
doExportRowFields(o); try {
doExportRowFields(o);
} catch (VascBackendException e) {
throw new VascException(e);
}
doExportRowEnd(o,(dataIndex==dataSize-1)); doExportRowEnd(o,(dataIndex==dataSize-1));
} }
} }
@ -94,7 +99,7 @@ abstract public class AbstractVascEntryExportWriter implements VascEntryExportWr
abstract protected void doExportRowStart(Object row) throws IOException; abstract protected void doExportRowStart(Object row) throws IOException;
abstract protected void doExportRowEnd(Object row,boolean isLast) throws IOException; abstract protected void doExportRowEnd(Object row,boolean isLast) throws IOException;
protected void doExportRowFields(Object row) throws IOException,VascException { protected void doExportRowFields(Object row) throws IOException,VascBackendException {
// todo: rm me and use data selector // todo: rm me and use data selector
List<VascEntryField> fieldList = new ArrayList<VascEntryField>(getVascEntry().getVascEntryFields()); List<VascEntryField> fieldList = new ArrayList<VascEntryField>(getVascEntry().getVascEntryFields());
int fields = fieldList.size(); int fields = fieldList.size();
@ -104,5 +109,5 @@ abstract public class AbstractVascEntryExportWriter implements VascEntryExportWr
} }
} }
abstract protected void doExportRowField(Object row,VascEntryField field,boolean isLast) throws IOException,VascException; abstract protected void doExportRowField(Object row,VascEntryField field,boolean isLast) throws IOException,VascBackendException;
} }

View file

@ -25,8 +25,8 @@ package net.forwardfire.vasc.export.generic;
import java.io.OutputStream; import java.io.OutputStream;
import java.io.PrintWriter; import java.io.PrintWriter;
import net.forwardfire.vasc.backend.VascBackendException;
import net.forwardfire.vasc.core.VascEntryField; import net.forwardfire.vasc.core.VascEntryField;
import net.forwardfire.vasc.core.VascException;
/** /**
* VascEntryExporterCsv writes data to csv output format. * VascEntryExporterCsv writes data to csv output format.
@ -132,9 +132,9 @@ public class VascEntryExportWriterCsv extends AbstractVascEntryExportWriter {
} }
@Override @Override
protected void doExportRowField(Object o, VascEntryField c,boolean isLast) throws VascException { protected void doExportRowField(Object o, VascEntryField c,boolean isLast) throws VascBackendException {
p.write(quoteChar.toCharType()); p.write(quoteChar.toCharType());
p.write(c.getVascEntryFieldValue().getDisplayValue(c, o)); p.write(c.getVascEntryFieldValue().getDisplayValue(c.getBackendName(), o));
p.write(quoteChar.toCharType()); p.write(quoteChar.toCharType());
if (isLast==false) { if (isLast==false) {
p.write(separatorChar.toCharType()); p.write(separatorChar.toCharType());

View file

@ -25,8 +25,8 @@ package net.forwardfire.vasc.export.generic;
import java.io.OutputStream; import java.io.OutputStream;
import java.io.PrintWriter; import java.io.PrintWriter;
import net.forwardfire.vasc.backend.VascBackendException;
import net.forwardfire.vasc.core.VascEntryField; import net.forwardfire.vasc.core.VascEntryField;
import net.forwardfire.vasc.core.VascException;
/** /**
* VascEntryExportWriterXml writes entry data to xml format. * VascEntryExportWriterXml writes entry data to xml format.
@ -74,14 +74,14 @@ public class VascEntryExportWriterXml extends AbstractVascEntryExportWriter {
} }
@Override @Override
protected void doExportRowField(Object o, VascEntryField c,boolean isLast) throws VascException { protected void doExportRowField(Object o, VascEntryField c,boolean isLast) throws VascBackendException {
if (xmlTree) { if (xmlTree) {
p.write("\t\t<"+c.getId()+"><![CDATA["); p.write("\t\t<"+c.getId()+"><![CDATA[");
p.write(""+c.getVascEntryFieldValue().getDisplayValue(c, o)); p.write(""+c.getVascEntryFieldValue().getDisplayValue(c.getBackendName(), o));
p.write("]]></"+c.getId()+">\n"); p.write("]]></"+c.getId()+">\n");
} else { } else {
p.write("\t\t<column name=\""+c.getId()+"\"><![CDATA["); p.write("\t\t<column name=\""+c.getId()+"\"><![CDATA[");
p.write(""+c.getVascEntryFieldValue().getDisplayValue(c, o)); p.write(""+c.getVascEntryFieldValue().getDisplayValue(c.getBackendName(), o));
p.write("]]></column>\n"); p.write("]]></column>\n");
} }
} }

View file

@ -27,9 +27,9 @@ import java.util.HashMap;
import java.util.List; import java.util.List;
import java.util.Map; import java.util.Map;
import net.forwardfire.vasc.backend.VascBackendException;
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;
import net.forwardfire.vasc.lib.jr4o.data.AbstractJRDynamicDataSource; import net.forwardfire.vasc.lib.jr4o.data.AbstractJRDynamicDataSource;
import net.sf.jasperreports.engine.JRException; import net.sf.jasperreports.engine.JRException;
@ -75,13 +75,13 @@ public class JRDynamicDataSourceVascEntry extends AbstractJRDynamicDataSource {
for (Object o:vascEntry.getVascFrontendController().getVascEntryState().getEntryDataList()) { for (Object o:vascEntry.getVascFrontendController().getVascEntryState().getEntryDataList()) {
List<String> row = new ArrayList<String>(30); List<String> row = new ArrayList<String>(30);
for (VascEntryField c:fields) { for (VascEntryField c:fields) {
row.add(c.getVascEntryFieldValue().getDisplayValue(c, o)); row.add(c.getVascEntryFieldValue().getDisplayValue(c.getBackendName(), o));
} }
data.add(row); data.add(row);
} }
} }
} catch (VascException ve) { } catch (VascBackendException ve) {
throw new RuntimeException(ve); throw new RuntimeException(ve); // TODO: replace me
} }
} }

View file

@ -31,8 +31,8 @@ import java.util.Map;
import org.json.simple.JSONObject; import org.json.simple.JSONObject;
import org.json.simple.JSONValue; import org.json.simple.JSONValue;
import net.forwardfire.vasc.backend.VascBackendException;
import net.forwardfire.vasc.core.VascEntryField; import net.forwardfire.vasc.core.VascEntryField;
import net.forwardfire.vasc.core.VascException;
import net.forwardfire.vasc.export.generic.AbstractVascEntryExportWriter; import net.forwardfire.vasc.export.generic.AbstractVascEntryExportWriter;
/** /**
@ -107,9 +107,9 @@ public class VascEntryExportWriterJson extends AbstractVascEntryExportWriter {
} }
@Override @Override
protected void doExportRowField(Object row, VascEntryField field,boolean isLast) throws VascException { protected void doExportRowField(Object row, VascEntryField field,boolean isLast) throws VascBackendException {
String key = field.getId(); String key = field.getId();
Object data = field.getVascEntryFieldValue().getValue(field, row); Object data = field.getVascEntryFieldValue().getValue(field.getBackendName(), row);
rowData.put(key, data); rowData.put(key, data);
} }
} }

View file

@ -34,11 +34,11 @@ import javax.swing.JPanel;
import javax.swing.JTextField; import javax.swing.JTextField;
import javax.swing.ListCellRenderer; import javax.swing.ListCellRenderer;
import net.forwardfire.vasc.backend.VascBackendPageNumber;
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.GlobalVascAction; import net.forwardfire.vasc.core.actions.GlobalVascAction;
import net.forwardfire.vasc.core.entry.VascEntryFrontendEventListener; import net.forwardfire.vasc.core.entry.VascEntryFrontendEventListener;
import net.forwardfire.vasc.frontend.VascFrontendPageInfoNumber;
import net.forwardfire.vasc.frontend.VascFrontendException; import net.forwardfire.vasc.frontend.VascFrontendException;
/** /**
@ -162,10 +162,10 @@ public class SwingActionPanel extends JPanel implements VascEntryFrontendEventLi
init = true; init = true;
long pageSize = entry.getVascFrontendController().getVascFrontendPager().getPageSize(); long pageSize = entry.getVascFrontendController().getVascFrontendPageInfo().getPageSize();
long pageStart = entry.getVascFrontendController().getVascFrontendPager().getPageStartCount(); long pageStart = entry.getVascFrontendController().getVascFrontendPageInfo().getPageStartCount();
long pageStop = entry.getVascFrontendController().getVascFrontendPager().getPageStopCount(); long pageStop = entry.getVascFrontendController().getVascFrontendPageInfo().getPageStopCount();
long pageTotalCount = entry.getVascFrontendController().getVascFrontendPager().getPageTotalRecordCount(); long pageTotalCount = entry.getVascFrontendController().getVascFrontendPageInfo().getPageTotalRecordCount();
String format = "Results %1$d-%2$d from %3$d rows"; String format = "Results %1$d-%2$d from %3$d rows";
resultLabel.setText(String.format(format, pageStart, pageStop, pageTotalCount)); resultLabel.setText(String.format(format, pageStart, pageStop, pageTotalCount));
rowNumberField.setText(""+pageSize); rowNumberField.setText(""+pageSize);
@ -173,9 +173,9 @@ public class SwingActionPanel extends JPanel implements VascEntryFrontendEventLi
gotoDirectPage.removeAllItems(); gotoDirectPage.removeAllItems();
gotoDirectPage.addItem("Goto..."); gotoDirectPage.addItem("Goto...");
List<VascBackendPageNumber> pages = vascEntry.getVascFrontendController().getVascFrontendPager().getTablePagesFromBackend(); List<VascFrontendPageInfoNumber> pages = vascEntry.getVascFrontendController().getVascFrontendPageInfo().getTablePagesFromBackend();
int i=0; int i=0;
for (VascBackendPageNumber page:pages) { for (VascFrontendPageInfoNumber page:pages) {
//pages.setRowIndex(i); //pages.setRowIndex(i);
//VascBackendPageNumber page = (VascBackendPageNumber)getTablePagesDataModel().getRowData(); //VascBackendPageNumber page = (VascBackendPageNumber)getTablePagesDataModel().getRowData();
// = new SelectItem(); // = new SelectItem();

View file

@ -31,9 +31,9 @@ import javax.swing.JButton;
import javax.swing.JLabel; import javax.swing.JLabel;
import javax.swing.JPanel; import javax.swing.JPanel;
import net.forwardfire.vasc.backend.VascBackendPageNumber;
import net.forwardfire.vasc.core.VascEntry; import net.forwardfire.vasc.core.VascEntry;
import net.forwardfire.vasc.core.entry.VascEntryFrontendEventListener; import net.forwardfire.vasc.core.entry.VascEntryFrontendEventListener;
import net.forwardfire.vasc.frontend.VascFrontendPageInfoNumber;
/** /**
* SwingPagerPanel renders dynamic pager for swing. * SwingPagerPanel renders dynamic pager for swing.
@ -70,11 +70,11 @@ public class SwingPagerPanel extends JPanel implements VascEntryFrontendEventLis
public void actionPerformed(ActionEvent e) { public void actionPerformed(ActionEvent e) {
int pageIndex = vascEntry.getVascFrontendController().getVascEntryState().getVascBackendState().getPageIndex(); int pageIndex = vascEntry.getVascFrontendController().getVascEntryState().getVascBackendState().getPageIndex();
if (next) { if (next) {
if (vascEntry.getVascFrontendController().getVascFrontendPager().getHasPageNextAction()) { if (vascEntry.getVascFrontendController().getVascFrontendPageInfo().getHasPageNextAction()) {
vascEntry.getVascFrontendController().getVascFrontendActions().pageAction(pageIndex+1); vascEntry.getVascFrontendController().getVascFrontendActions().pageAction(pageIndex+1);
} }
} else { } else {
if (vascEntry.getVascFrontendController().getVascFrontendPager().getHasPagePreviousAction()) { if (vascEntry.getVascFrontendController().getVascFrontendPageInfo().getHasPagePreviousAction()) {
vascEntry.getVascFrontendController().getVascFrontendActions().pageAction(pageIndex-1); vascEntry.getVascFrontendController().getVascFrontendActions().pageAction(pageIndex-1);
} }
} }
@ -91,13 +91,13 @@ public class SwingPagerPanel extends JPanel implements VascEntryFrontendEventLis
result.removeAll(); result.removeAll();
if (entry.getVascFrontendController().getVascFrontendPager().getHasExtendedPageMode()) { if (entry.getVascFrontendController().getVascFrontendPageInfo().getHasExtendedPageMode()) {
JButton prev = new JButton("Previous"); JButton prev = new JButton("Previous");
prev.addActionListener(new NextAction(false)); prev.addActionListener(new NextAction(false));
prev.setEnabled(entry.getVascFrontendController().getVascFrontendPager().getHasPagePreviousAction()); prev.setEnabled(entry.getVascFrontendController().getVascFrontendPageInfo().getHasPagePreviousAction());
result.add(prev); result.add(prev);
List<VascBackendPageNumber> pages = entry.getVascFrontendController().getVascFrontendPager().getTablePagesExtendedBegin(); List<VascFrontendPageInfoNumber> pages = entry.getVascFrontendController().getVascFrontendPageInfo().getTablePagesExtendedBegin();
for(VascBackendPageNumber page:pages) { for(VascFrontendPageInfoNumber page:pages) {
JButton but = new JButton(""+page.getPageNumber()); JButton but = new JButton(""+page.getPageNumber());
but.addActionListener(this); but.addActionListener(this);
if (page.getSelected()!=null && page.getSelected()) { if (page.getSelected()!=null && page.getSelected()) {
@ -106,9 +106,9 @@ public class SwingPagerPanel extends JPanel implements VascEntryFrontendEventLis
result.add(but); result.add(but);
} }
result.add(new JLabel("...")); result.add(new JLabel("..."));
if (entry.getVascFrontendController().getVascFrontendPager().getHasExtendedPageModeCenter()) { if (entry.getVascFrontendController().getVascFrontendPageInfo().getHasExtendedPageModeCenter()) {
pages = entry.getVascFrontendController().getVascFrontendPager().getTablePagesExtendedCenter(); pages = entry.getVascFrontendController().getVascFrontendPageInfo().getTablePagesExtendedCenter();
for(VascBackendPageNumber page:pages) { for(VascFrontendPageInfoNumber page:pages) {
JButton but = new JButton(""+page.getPageNumber()); JButton but = new JButton(""+page.getPageNumber());
but.addActionListener(this); but.addActionListener(this);
if (page.getSelected()!=null && page.getSelected()) { if (page.getSelected()!=null && page.getSelected()) {
@ -118,8 +118,8 @@ public class SwingPagerPanel extends JPanel implements VascEntryFrontendEventLis
} }
result.add(new JLabel("...")); result.add(new JLabel("..."));
} }
pages = entry.getVascFrontendController().getVascFrontendPager().getTablePagesExtendedEnd(); pages = entry.getVascFrontendController().getVascFrontendPageInfo().getTablePagesExtendedEnd();
for(VascBackendPageNumber page:pages) { for(VascFrontendPageInfoNumber page:pages) {
JButton but = new JButton(""+page.getPageNumber()); JButton but = new JButton(""+page.getPageNumber());
but.addActionListener(this); but.addActionListener(this);
if (page.getSelected()!=null && page.getSelected()) { if (page.getSelected()!=null && page.getSelected()) {
@ -128,16 +128,16 @@ public class SwingPagerPanel extends JPanel implements VascEntryFrontendEventLis
result.add(but); result.add(but);
} }
JButton next = new JButton("Next"); JButton next = new JButton("Next");
next.setEnabled(entry.getVascFrontendController().getVascFrontendPager().getHasPageNextAction()); next.setEnabled(entry.getVascFrontendController().getVascFrontendPageInfo().getHasPageNextAction());
next.addActionListener(new NextAction(true)); next.addActionListener(new NextAction(true));
result.add(next); result.add(next);
} else { } else {
JButton prev = new JButton("Previous"); JButton prev = new JButton("Previous");
prev.addActionListener(new NextAction(false)); prev.addActionListener(new NextAction(false));
prev.setEnabled(entry.getVascFrontendController().getVascFrontendPager().getHasPagePreviousAction()); prev.setEnabled(entry.getVascFrontendController().getVascFrontendPageInfo().getHasPagePreviousAction());
result.add(prev); result.add(prev);
List<VascBackendPageNumber> pages = entry.getVascFrontendController().getVascFrontendPager().getTablePagesNormal(); List<VascFrontendPageInfoNumber> pages = entry.getVascFrontendController().getVascFrontendPageInfo().getTablePagesNormal();
for(VascBackendPageNumber page:pages) { for(VascFrontendPageInfoNumber page:pages) {
JButton but = new JButton(""+page.getPageNumber()); JButton but = new JButton(""+page.getPageNumber());
but.addActionListener(this); but.addActionListener(this);
if (page.getSelected()!=null && page.getSelected()) { if (page.getSelected()!=null && page.getSelected()) {
@ -146,7 +146,7 @@ public class SwingPagerPanel extends JPanel implements VascEntryFrontendEventLis
result.add(but); result.add(but);
} }
JButton next = new JButton("Next"); JButton next = new JButton("Next");
next.setEnabled(entry.getVascFrontendController().getVascFrontendPager().getHasPageNextAction()); next.setEnabled(entry.getVascFrontendController().getVascFrontendPageInfo().getHasPageNextAction());
next.addActionListener(new NextAction(true)); next.addActionListener(new NextAction(true));
result.add(next); result.add(next);
} }

View file

@ -34,6 +34,7 @@ import javax.swing.JLabel;
import javax.swing.JPanel; import javax.swing.JPanel;
import javax.swing.SpringLayout; import javax.swing.SpringLayout;
import net.forwardfire.vasc.backend.VascBackendException;
import net.forwardfire.vasc.core.VascController; import net.forwardfire.vasc.core.VascController;
import net.forwardfire.vasc.core.VascEntry; import net.forwardfire.vasc.core.VascEntry;
import net.forwardfire.vasc.core.VascEntryField; import net.forwardfire.vasc.core.VascEntryField;
@ -115,7 +116,7 @@ public class SwingVascEditDialog extends JPanel {
//System.out.println("Could not get VascEntryFieldValue for fieldID: "+fieldId); //System.out.println("Could not get VascEntryFieldValue for fieldID: "+fieldId);
continue; continue;
} }
Object selectedValue = v.getVascEntryFieldValue().getValue(v, selected); Object selectedValue = v.getVascEntryFieldValue().getValue(v.getBackendName(), selected);
// set data parameter on new vasc entry // set data parameter on new vasc entry
ee.getVascFrontendController().getVascEntryState().getVascBackendState().setDataParameter(parameterName, selectedValue); ee.getVascFrontendController().getVascEntryState().getVascBackendState().setDataParameter(parameterName, selectedValue);
@ -127,7 +128,7 @@ public class SwingVascEditDialog extends JPanel {
Object selectedValue = selected; Object selectedValue = selected;
if (selectedfieldId!=null) { if (selectedfieldId!=null) {
VascEntryField v = ee.getVascEntryFieldById(selectedfieldId); VascEntryField v = ee.getVascEntryFieldById(selectedfieldId);
selectedValue = v.getVascEntryFieldValue().getValue(v, selected); selectedValue = v.getVascEntryFieldValue().getValue(v.getBackendName(), selected);
} }
// create listener for new objects // create listener for new objects
@ -172,7 +173,11 @@ public class SwingVascEditDialog extends JPanel {
VascUIComponent editor = c.getVascEntryFieldType().provideEditorUIComponent(i,c); VascUIComponent editor = c.getVascEntryFieldType().provideEditorUIComponent(i,c);
model = new VascValueModel(c.getVascEntryFieldType().provideEditorVascValueModel(i,c)); model = new VascValueModel(c.getVascEntryFieldType().provideEditorVascValueModel(i,c));
model.setValue(c.getVascEntryFieldValue().getValue(c, bean)); try {
model.setValue(c.getVascEntryFieldValue().getValue(c.getBackendName(), bean));
} catch (VascBackendException e) {
throw new VascException(e);
}
model.addListener(new VascColumnValueModelListener(c,bean)); model.addListener(new VascColumnValueModelListener(c,bean));
Object g = editor.createComponent(entry,c,model,body); Object g = editor.createComponent(entry,c,model,body);

View file

@ -61,6 +61,7 @@ import javax.swing.table.TableCellRenderer;
import javax.swing.table.TableColumn; import javax.swing.table.TableColumn;
import javax.swing.table.TableColumnModel; import javax.swing.table.TableColumnModel;
import net.forwardfire.vasc.backend.VascBackendException;
import net.forwardfire.vasc.core.VascEntryField; import net.forwardfire.vasc.core.VascEntryField;
import net.forwardfire.vasc.core.VascEntryListOption; import net.forwardfire.vasc.core.VascEntryListOption;
import net.forwardfire.vasc.core.actions.GlobalVascAction; import net.forwardfire.vasc.core.actions.GlobalVascAction;
@ -71,7 +72,6 @@ import net.forwardfire.vasc.core.ui.VascOptionValueModelListener;
import net.forwardfire.vasc.core.ui.VascUIComponent; import net.forwardfire.vasc.core.ui.VascUIComponent;
import net.forwardfire.vasc.core.ui.VascValueModel; import net.forwardfire.vasc.core.ui.VascValueModel;
import net.forwardfire.vasc.core.VascException; import net.forwardfire.vasc.core.VascException;
import net.forwardfire.vasc.frontend.AbstractVascFrontend; import net.forwardfire.vasc.frontend.AbstractVascFrontend;
import net.forwardfire.vasc.frontend.VascFrontendController; import net.forwardfire.vasc.frontend.VascFrontendController;
import net.forwardfire.vasc.frontend.VascFrontendException; import net.forwardfire.vasc.frontend.VascFrontendException;
@ -161,7 +161,7 @@ public class SwingVascFrontend extends AbstractVascFrontend {
if (entry.getDisplayNameFieldId()!=null) { if (entry.getDisplayNameFieldId()!=null) {
VascEntryField v = entry.getVascEntryFieldById(entry.getDisplayNameFieldId()); VascEntryField v = entry.getVascEntryFieldById(entry.getDisplayNameFieldId());
Object vv = v.getVascEntryFieldValue().getValue(v, rowBean); Object vv = v.getVascEntryFieldValue().getValue(v.getBackendName(), rowBean);
if (vv==null) { if (vv==null) {
beanValue=""; beanValue="";
} else { } else {
@ -178,6 +178,8 @@ public class SwingVascFrontend extends AbstractVascFrontend {
entry.getVascFrontendController().getVascFrontendHelper().editReadOnlyUIComponents(entry); entry.getVascFrontendController().getVascFrontendHelper().editReadOnlyUIComponents(entry);
panels.openVascView(editPanel,entry); panels.openVascView(editPanel,entry);
} catch (VascBackendException ve) {
throw new VascFrontendException(ve);
} catch (VascException ve) { } catch (VascException ve) {
throw new VascFrontendException(ve); throw new VascFrontendException(ve);
} }
@ -189,11 +191,11 @@ public class SwingVascFrontend extends AbstractVascFrontend {
try { try {
VascEntryField v = entry.getVascEntryFieldById(entry.getDisplayNameFieldId()); VascEntryField v = entry.getVascEntryFieldById(entry.getDisplayNameFieldId());
beanValue = ""+v.getVascEntryFieldValue().getValue(v, rowBean); beanValue = ""+v.getVascEntryFieldValue().getValue(v.getBackendName(), rowBean);
if (beanValue.length()>30) { if (beanValue.length()>30) {
beanValue=beanValue.substring(0, 30); beanValue=beanValue.substring(0, 30);
} }
} catch (VascException ve) { } catch (VascBackendException ve) {
throw new VascFrontendException(ve); throw new VascFrontendException(ve);
} }

View file

@ -96,7 +96,7 @@ public class SwingVascTableModel extends AbstractTableModel implements VascEntry
//if (vtc.getVascColumnRenderer()!=null) { //if (vtc.getVascColumnRenderer()!=null) {
// return vtc.getVascColumnRenderer().rendererColumn(vtc,bean); // return vtc.getVascColumnRenderer().rendererColumn(vtc,bean);
//} else { //} else {
return ""+vtc.getVascEntryFieldValue().getValue(vtc,bean); return ""+vtc.getVascEntryFieldValue().getValue(vtc.getBackendName(),bean);
// } // }
} catch (Exception e) { } catch (Exception e) {
return "Error"; return "Error";

View file

@ -24,11 +24,11 @@ package net.forwardfire.vasc.frontend.swt;
import java.util.List; import java.util.List;
import net.forwardfire.vasc.backend.VascBackendPageNumber;
import net.forwardfire.vasc.core.VascEntry; import net.forwardfire.vasc.core.VascEntry;
import net.forwardfire.vasc.core.actions.GlobalVascAction; import net.forwardfire.vasc.core.actions.GlobalVascAction;
import net.forwardfire.vasc.core.entry.VascEntryFrontendEventListener; import net.forwardfire.vasc.core.entry.VascEntryFrontendEventListener;
import net.forwardfire.vasc.core.ui.VascSelectItem; import net.forwardfire.vasc.core.ui.VascSelectItem;
import net.forwardfire.vasc.frontend.VascFrontendPageInfoNumber;
import org.eclipse.swt.SWT; import org.eclipse.swt.SWT;
import org.eclipse.swt.events.ModifyEvent; import org.eclipse.swt.events.ModifyEvent;
@ -128,10 +128,10 @@ public class SwtActionPanel implements VascEntryFrontendEventListener {
public void vascEvent(VascEntry entry,Object dataNotUsed) { public void vascEvent(VascEntry entry,Object dataNotUsed) {
vascEvent = true; vascEvent = true;
long pageSize = entry.getVascFrontendController().getVascFrontendPager().getPageSize(); long pageSize = entry.getVascFrontendController().getVascFrontendPageInfo().getPageSize();
long pageStart = entry.getVascFrontendController().getVascFrontendPager().getPageStartCount(); long pageStart = entry.getVascFrontendController().getVascFrontendPageInfo().getPageStartCount();
long pageStop = entry.getVascFrontendController().getVascFrontendPager().getPageStopCount(); long pageStop = entry.getVascFrontendController().getVascFrontendPageInfo().getPageStopCount();
long pageTotalCount = entry.getVascFrontendController().getVascFrontendPager().getPageTotalRecordCount(); long pageTotalCount = entry.getVascFrontendController().getVascFrontendPageInfo().getPageTotalRecordCount();
String format = "Results %1$d-%2$d from %3$d rows"; String format = "Results %1$d-%2$d from %3$d rows";
resultLabel.setText(String.format(format, pageStart, pageStop, pageTotalCount)); resultLabel.setText(String.format(format, pageStart, pageStop, pageTotalCount));
resultLabel.redraw(); resultLabel.redraw();
@ -140,9 +140,9 @@ public class SwtActionPanel implements VascEntryFrontendEventListener {
pageBox.removeAll(); pageBox.removeAll();
pageBox.add("Goto..."); pageBox.add("Goto...");
List<VascBackendPageNumber> pages = entry.getVascFrontendController().getVascFrontendPager().getTablePagesFromBackend(); List<VascFrontendPageInfoNumber> pages = entry.getVascFrontendController().getVascFrontendPageInfo().getTablePagesFromBackend();
int i=0; int i=0;
for (VascBackendPageNumber page:pages) { for (VascFrontendPageInfoNumber page:pages) {
pageBox.add("page: "+page.getPageNumber()+" "+(i*pageSize)+"-"+((i*pageSize)+pageSize)); pageBox.add("page: "+page.getPageNumber()+" "+(i*pageSize)+"-"+((i*pageSize)+pageSize));
i++; i++;
} }

View file

@ -24,11 +24,11 @@ package net.forwardfire.vasc.frontend.swt;
import java.util.List; import java.util.List;
import net.forwardfire.vasc.backend.VascBackendPageNumber;
import net.forwardfire.vasc.core.VascEntry; import net.forwardfire.vasc.core.VascEntry;
import net.forwardfire.vasc.core.actions.GlobalVascAction; import net.forwardfire.vasc.core.actions.GlobalVascAction;
import net.forwardfire.vasc.core.entry.VascEntryFrontendEventListener; import net.forwardfire.vasc.core.entry.VascEntryFrontendEventListener;
import net.forwardfire.vasc.core.entry.VascEntryFrontendEventListener.VascFrontendEventType; import net.forwardfire.vasc.core.entry.VascEntryFrontendEventListener.VascFrontendEventType;
import net.forwardfire.vasc.frontend.VascFrontendPageInfoNumber;
import org.eclipse.swt.SWT; import org.eclipse.swt.SWT;
import org.eclipse.swt.layout.GridData; import org.eclipse.swt.layout.GridData;

View file

@ -22,6 +22,7 @@
package net.forwardfire.vasc.frontend.swt; package net.forwardfire.vasc.frontend.swt;
import net.forwardfire.vasc.backend.VascBackendException;
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.ui.VascColumnValueModelListener; import net.forwardfire.vasc.core.ui.VascColumnValueModelListener;
@ -125,8 +126,8 @@ public class SwtVascEditDialog extends Dialog {
String name = null; String name = null;
try { try {
Object bean = entry.getVascFrontendController().getVascEntryState().getEntryDataObject(); Object bean = entry.getVascFrontendController().getVascEntryState().getEntryDataObject();
name = dis.getVascEntryFieldValue().getDisplayValue(dis, bean); name = dis.getVascEntryFieldValue().getDisplayValue(dis.getBackendName(), bean);
} catch (VascException e) { } catch (VascBackendException e) {
throw new RuntimeException("Could not display value from "+entry.getId(),e); throw new RuntimeException("Could not display value from "+entry.getId(),e);
} }
@ -174,7 +175,11 @@ public class SwtVascEditDialog extends Dialog {
VascUIComponent editor = c.getVascEntryFieldType().provideEditorUIComponent(i,c); VascUIComponent editor = c.getVascEntryFieldType().provideEditorUIComponent(i,c);
model = new VascValueModel(c.getVascEntryFieldType().provideEditorVascValueModel(i,c)); model = new VascValueModel(c.getVascEntryFieldType().provideEditorVascValueModel(i,c));
model.setValue(c.getVascEntryFieldValue().getValue(c, bean)); try {
model.setValue(c.getVascEntryFieldValue().getValue(c.getBackendName(), bean));
} catch (VascBackendException e) {
throw new VascException(e);
}
model.addListener(new VascColumnValueModelListener(c,bean)); model.addListener(new VascColumnValueModelListener(c,bean));
Control edit = (Control )editor.createComponent(entry,c,model,body); Control edit = (Control )editor.createComponent(entry,c,model,body);

View file

@ -28,6 +28,7 @@ import java.io.OutputStream;
import java.util.logging.Level; import java.util.logging.Level;
import java.util.logging.Logger; import java.util.logging.Logger;
import net.forwardfire.vasc.backend.VascBackendException;
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.VascEntryListOption; import net.forwardfire.vasc.core.VascEntryListOption;
@ -636,7 +637,7 @@ public class SwtVascFrontend extends AbstractVascFrontend {
//if (vtc.getVascColumnRenderer()==null) { //if (vtc.getVascColumnRenderer()==null) {
try { try {
return vtc.getVascEntryFieldValue().getDisplayValue(vtc,bean); return vtc.getVascEntryFieldValue().getDisplayValue(vtc.getBackendName(),bean);
} catch (Exception e) { } catch (Exception e) {
logger.log(Level.WARNING,"Error in get value: '"+vtc.getVascEntryFieldValue()+"' error: "+e.getMessage(),e); logger.log(Level.WARNING,"Error in get value: '"+vtc.getVascEntryFieldValue()+"' error: "+e.getMessage(),e);
return "Err"; return "Err";

View file

@ -90,6 +90,6 @@ public class JSFVascEntryEventListener implements VascEntryFrontendEventListener
ValueExpression ve2 = FacesContext.getCurrentInstance().getApplication().getExpressionFactory().createValueExpression(FacesContext.getCurrentInstance().getELContext(), "#{"+entrySupportVar+".tableDataModel.wrappedData}", Object.class); ValueExpression ve2 = FacesContext.getCurrentInstance().getApplication().getExpressionFactory().createValueExpression(FacesContext.getCurrentInstance().getELContext(), "#{"+entrySupportVar+".tableDataModel.wrappedData}", Object.class);
ve2.setValue(FacesContext.getCurrentInstance().getELContext(), result); ve2.setValue(FacesContext.getCurrentInstance().getELContext(), result);
ValueExpression ve3 = FacesContext.getCurrentInstance().getApplication().getExpressionFactory().createValueExpression(FacesContext.getCurrentInstance().getELContext(), "#{"+entrySupportVar+".tablePagesDataModel.wrappedData}", Object.class); ValueExpression ve3 = FacesContext.getCurrentInstance().getApplication().getExpressionFactory().createValueExpression(FacesContext.getCurrentInstance().getELContext(), "#{"+entrySupportVar+".tablePagesDataModel.wrappedData}", Object.class);
ve3.setValue(FacesContext.getCurrentInstance().getELContext(), entry.getVascFrontendController().getVascFrontendPager().getTablePagesFromBackend()); ve3.setValue(FacesContext.getCurrentInstance().getELContext(), entry.getVascFrontendController().getVascFrontendPageInfo().getTablePagesFromBackend());
} }
} }

View file

@ -49,7 +49,6 @@ import javax.servlet.ServletOutputStream;
import javax.servlet.http.HttpServletResponse; import javax.servlet.http.HttpServletResponse;
import net.forwardfire.vasc.backend.VascBackend; import net.forwardfire.vasc.backend.VascBackend;
import net.forwardfire.vasc.backend.VascBackendPageNumber;
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.VascEntryState; import net.forwardfire.vasc.core.VascEntryState;
@ -60,6 +59,7 @@ import net.forwardfire.vasc.core.actions.GlobalVascAction;
import net.forwardfire.vasc.core.actions.RowVascAction; import net.forwardfire.vasc.core.actions.RowVascAction;
import net.forwardfire.vasc.core.entry.VascEntryExport; import net.forwardfire.vasc.core.entry.VascEntryExport;
import net.forwardfire.vasc.core.entry.VascEntryExportWriter; import net.forwardfire.vasc.core.entry.VascEntryExportWriter;
import net.forwardfire.vasc.frontend.VascFrontendPageInfoNumber;
import net.forwardfire.vasc.frontend.VascFrontendException; import net.forwardfire.vasc.frontend.VascFrontendException;
import net.forwardfire.vasc.impl.actions.AddRowAction; import net.forwardfire.vasc.impl.actions.AddRowAction;
import net.forwardfire.vasc.impl.actions.DeleteRowAction; import net.forwardfire.vasc.impl.actions.DeleteRowAction;
@ -198,14 +198,14 @@ public class JSFVascEntrySupportBean implements Serializable {
public long getPageTotalRecordCount() { public long getPageTotalRecordCount() {
return entry.getVascFrontendController().getVascFrontendPager().getPageTotalRecordCount(); return entry.getVascFrontendController().getVascFrontendPageInfo().getPageTotalRecordCount();
} }
public long getPageStartCount() { public long getPageStartCount() {
return entry.getVascFrontendController().getVascFrontendPager().getPageStartCount(); return entry.getVascFrontendController().getVascFrontendPageInfo().getPageStartCount();
} }
public long getPageStopCount() { public long getPageStopCount() {
return entry.getVascFrontendController().getVascFrontendPager().getPageStopCount(); return entry.getVascFrontendController().getVascFrontendPageInfo().getPageStopCount();
} }
public List<SelectItem> getGlobalExportItems() { public List<SelectItem> getGlobalExportItems() {
@ -237,7 +237,7 @@ public class JSFVascEntrySupportBean implements Serializable {
int pageSize = getVascEntry().getVascFrontendController().getVascEntryState().getVascBackendState().getPageSize(); int pageSize = getVascEntry().getVascFrontendController().getVascEntryState().getVascBackendState().getPageSize();
for (int i=0;i<getTablePagesDataModel().getRowCount();i++) { for (int i=0;i<getTablePagesDataModel().getRowCount();i++) {
getTablePagesDataModel().setRowIndex(i); getTablePagesDataModel().setRowIndex(i);
VascBackendPageNumber page = (VascBackendPageNumber)getTablePagesDataModel().getRowData(); VascFrontendPageInfoNumber page = (VascFrontendPageInfoNumber)getTablePagesDataModel().getRowData();
s = new SelectItem(); s = new SelectItem();
String name = i18nMap.get("generic.vasc.jsf.table.page.name"); String name = i18nMap.get("generic.vasc.jsf.table.page.name");
String description = i18nMap.get("generic.vasc.jsf.table.page.description"); String description = i18nMap.get("generic.vasc.jsf.table.page.description");
@ -251,27 +251,27 @@ public class JSFVascEntrySupportBean implements Serializable {
} }
public boolean getHasOnlySinglePage() { public boolean getHasOnlySinglePage() {
return entry.getVascFrontendController().getVascFrontendPager().getHasOnlySinglePage(); return entry.getVascFrontendController().getVascFrontendPageInfo().getHasOnlySinglePage();
} }
public boolean getHasExtendedPageMode() { public boolean getHasExtendedPageMode() {
return entry.getVascFrontendController().getVascFrontendPager().getHasExtendedPageMode(); return entry.getVascFrontendController().getVascFrontendPageInfo().getHasExtendedPageMode();
} }
public boolean getHasExtendedPageModeCenter() { public boolean getHasExtendedPageModeCenter() {
return entry.getVascFrontendController().getVascFrontendPager().getHasExtendedPageModeCenter(); return entry.getVascFrontendController().getVascFrontendPageInfo().getHasExtendedPageModeCenter();
} }
public List<VascBackendPageNumber> getTablePagesExtendedBegin() { public List<VascFrontendPageInfoNumber> getTablePagesExtendedBegin() {
return entry.getVascFrontendController().getVascFrontendPager().getTablePagesExtendedBegin(); return entry.getVascFrontendController().getVascFrontendPageInfo().getTablePagesExtendedBegin();
} }
public List<VascBackendPageNumber> getTablePagesExtendedEnd() { public List<VascFrontendPageInfoNumber> getTablePagesExtendedEnd() {
return entry.getVascFrontendController().getVascFrontendPager().getTablePagesExtendedEnd(); return entry.getVascFrontendController().getVascFrontendPageInfo().getTablePagesExtendedEnd();
} }
public List<VascBackendPageNumber> getTablePagesExtendedCenter() { public List<VascFrontendPageInfoNumber> getTablePagesExtendedCenter() {
return entry.getVascFrontendController().getVascFrontendPager().getTablePagesExtendedCenter(); return entry.getVascFrontendController().getVascFrontendPageInfo().getTablePagesExtendedCenter();
} }
private String getComponentType(UIComponent comp) { private String getComponentType(UIComponent comp) {
@ -507,11 +507,11 @@ public class JSFVascEntrySupportBean implements Serializable {
} }
public boolean getHasPageNextAction() { public boolean getHasPageNextAction() {
return entry.getVascFrontendController().getVascFrontendPager().getHasPageNextAction(); return entry.getVascFrontendController().getVascFrontendPageInfo().getHasPageNextAction();
} }
public boolean getHasPagePreviousAction() { public boolean getHasPagePreviousAction() {
return entry.getVascFrontendController().getVascFrontendPager().getHasPagePreviousAction(); return entry.getVascFrontendController().getVascFrontendPageInfo().getHasPagePreviousAction();
} }

View file

@ -33,6 +33,7 @@ import javax.faces.component.UIComponent;
import javax.faces.component.UIComponentBase; import javax.faces.component.UIComponentBase;
import javax.faces.context.FacesContext; import javax.faces.context.FacesContext;
import net.forwardfire.vasc.backend.VascBackendException;
import net.forwardfire.vasc.core.VascController; import net.forwardfire.vasc.core.VascController;
import net.forwardfire.vasc.core.VascEntry; import net.forwardfire.vasc.core.VascEntry;
import net.forwardfire.vasc.core.VascEntryField; import net.forwardfire.vasc.core.VascEntryField;
@ -349,7 +350,7 @@ public class JSFVascUIComponent extends UIComponentBase {
logger.warning("Could not get VascEntryFieldValue for fieldID: "+fieldId); logger.warning("Could not get VascEntryFieldValue for fieldID: "+fieldId);
continue; continue;
} }
Object selectedValue = v.getVascEntryFieldValue().getValue(v, selected); Object selectedValue = v.getVascEntryFieldValue().getValue(v.getBackendName(), selected);
// set data parameter on new vasc entry // set data parameter on new vasc entry
//was; entry.getVascFrontendController().getVascEntryState().getVascBackendState().setDataParameter(parameterName, selectedValue); //was; entry.getVascFrontendController().getVascEntryState().getVascBackendState().setDataParameter(parameterName, selectedValue);
@ -362,7 +363,7 @@ public class JSFVascUIComponent extends UIComponentBase {
Object selectedValue = selected; Object selectedValue = selected;
if (selectedfieldId!=null) { if (selectedfieldId!=null) {
VascEntryField v = getVascEntry().getVascEntryFieldById(selectedfieldId); VascEntryField v = getVascEntry().getVascEntryFieldById(selectedfieldId);
selectedValue = v.getVascEntryFieldValue().getValue(v, selected); selectedValue = v.getVascEntryFieldValue().getValue(v.getBackendName(), selected);
} }
// create listener for new objects // create listener for new objects
@ -398,8 +399,8 @@ public class JSFVascUIComponent extends UIComponentBase {
public void vascEvent(VascEntry entry,Object data) { public void vascEvent(VascEntry entry,Object data) {
VascEntryField field = entry.getVascEntryFieldById(fieldId); VascEntryField field = entry.getVascEntryFieldById(fieldId);
try { try {
field.getVascEntryFieldValue().setValue(field, data, value); field.getVascEntryFieldValue().setValue(field.getBackendName(), data, value);
} catch (VascException e) { } catch (VascBackendException e) {
throw new VascFrontendException(e); throw new VascFrontendException(e);
} }
} }

View file

@ -25,9 +25,10 @@ package net.forwardfire.vasc.frontend.web.jsf;
import java.io.Serializable; import java.io.Serializable;
import net.forwardfire.vasc.backend.VascBackendException;
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.entry.VascEntryFieldValue;
import net.forwardfire.vasc.core.VascException; import net.forwardfire.vasc.core.VascException;
import net.forwardfire.vasc.frontend.VascFrontendDataSelector.EntryFieldSelectType; import net.forwardfire.vasc.frontend.VascFrontendDataSelector.EntryFieldSelectType;
@ -83,10 +84,10 @@ public class VascDataBackendBean implements Serializable {
VascEntryField field = getFieldIdByIndex(entry,index); VascEntryField field = getFieldIdByIndex(entry,index);
VascEntryFieldValue value = field.getVascEntryFieldValue(); VascEntryFieldValue value = field.getVascEntryFieldValue();
if (isRealValue()) { if (isRealValue()) {
return value.getValue(field, record); return value.getValue(field.getBackendName(), record);
} }
return value.getDisplayValue(field, record); return value.getDisplayValue(field.getBackendName(), record);
} catch (VascException e) { } catch (Exception e) {
return "Error: "+e.getMessage(); return "Error: "+e.getMessage();
} }
} }
@ -95,8 +96,8 @@ public class VascDataBackendBean implements Serializable {
try { try {
VascEntryField field = getFieldIdByIndex(entry,index); VascEntryField field = getFieldIdByIndex(entry,index);
VascEntryFieldValue value = field.getVascEntryFieldValue(); VascEntryFieldValue value = field.getVascEntryFieldValue();
value.setValue(field, record,valueObject); value.setValue(field.getBackendName(), record,valueObject);
} catch (VascException e) { } catch (VascBackendException e) {
throw new RuntimeException("Could not set value on record.",e); throw new RuntimeException("Could not set value on record.",e);
} }
} }

Some files were not shown because too many files have changed in this diff Show more