camille frappin - 2011-09-05

Hi, i'm getting the following error when serializing domain object:

GWT20
Hibernate: select this_.id as id1_0_, this_.id_data_profil as id2_1_0_, this_.id_table_data_profil as id3_1_0_, this_.name as name1_0_, this_.surname as surname1_0_, this_.email as email1_0_, this_.password as password1_0_, this_.sex as sex1_0_, this_.birthday as birthday1_0_, this_.join_date as join10_1_0_, this_.registration_confirmation as registr11_1_0_, this_.registration_confirmed as registr12_1_0_, this_.time_last_connection_attempt as time13_1_0_, this_.connection_attempt as connection14_1_0_ from treenk.iuser this_ where this_.email=? and this_.registration_confirmed=? and connection_attempt < 15
Hibernate: select profildata0_.fk_iuser as fk2_1_, profildata0_.id as id1_, profildata0_.id as id5_0_, profildata0_.fk_iuser as fk2_5_0_, profildata0_.fk_field_structure as fk3_5_0_, profildata0_.data as data5_0_ from treenk.profil_data_1 profildata0_ where profildata0_.fk_iuser=?
user founded - 6 ProfilData1 entries
Starting Jetty on port 8888
   [WARN] Exception while dispatching incoming RPC call
java.lang.AbstractMethodError: net.sf.gilead.core.hibernate.HibernateUtil.serializePersistentCollection(Ljava/lang/Object;)Ljava/util/Map;
    at net.sf.gilead.core.beanlib.clone.ClonePropertyFilter.propagate(ClonePropertyFilter.java:188)
    at net.sf.beanlib.provider.BeanPopulator.doit(BeanPopulator.java:186)
    at net.sf.beanlib.provider.BeanPopulator.processSetterMethod(BeanPopulator.java:172)
    at net.sf.beanlib.provider.BeanPopulator.populate(BeanPopulator.java:269)
    at net.sf.beanlib.provider.replicator.ReplicatorTemplate.populateBean(ReplicatorTemplate.java:190)
    at net.sf.beanlib.provider.replicator.BeanReplicator.replicateBean(BeanReplicator.java:187)
    at net.sf.beanlib.hibernate3.Hibernate3JavaBeanReplicator.replicateBean(Hibernate3JavaBeanReplicator.java:71)
    at net.sf.gilead.core.beanlib.clone.CloneClassBeanReplicator.replicateBean(CloneClassBeanReplicator.java:129)
    at net.sf.beanlib.provider.replicator.ReplicatorTemplate.replicateByBeanReplicatable(ReplicatorTemplate.java:140)
    at net.sf.beanlib.provider.replicator.ReplicatorTemplate.replicate(ReplicatorTemplate.java:135)
    at net.sf.beanlib.provider.BeanTransformer.transform(BeanTransformer.java:231)
    at net.sf.beanlib.hibernate.HibernateBeanReplicator.copy(HibernateBeanReplicator.java:134)
    at net.sf.gilead.core.LazyKiller.clone(LazyKiller.java:237)
    at net.sf.gilead.core.LazyKiller.detach(LazyKiller.java:191)
    at net.sf.gilead.core.PersistentBeanManager.clonePojo(PersistentBeanManager.java:376)
    at net.sf.gilead.core.PersistentBeanManager.clone(PersistentBeanManager.java:248)
    at net.sf.gilead.gwt.GileadRPCHelper.parseReturnValue(GileadRPCHelper.java:126)
    at net.sf.gilead.gwt.PersistentRemoteService.processCall(PersistentRemoteService.java:153)
    at com.google.gwt.user.server.rpc.RemoteServiceServlet.processPost(RemoteServiceServlet.java:248)
    at com.google.gwt.user.server.rpc.AbstractRemoteServiceServlet.doPost(AbstractRemoteServiceServlet.java:62)
    at javax.servlet.http.HttpServlet.service(HttpServlet.java:637)
    at javax.servlet.http.HttpServlet.service(HttpServlet.java:717)
    at org.mortbay.jetty.servlet.ServletHolder.handle(ServletHolder.java:487)
    at org.mortbay.jetty.servlet.ServletHandler.handle(ServletHandler.java:362)
    at org.mortbay.jetty.security.SecurityHandler.handle(SecurityHandler.java:216)
    at org.mortbay.jetty.servlet.SessionHandler.handle(SessionHandler.java:181)
    at org.mortbay.jetty.handler.ContextHandler.handle(ContextHandler.java:729)
    at org.mortbay.jetty.webapp.WebAppContext.handle(WebAppContext.java:405)
    at org.mortbay.jetty.handler.HandlerWrapper.handle(HandlerWrapper.java:152)
    at org.mortbay.jetty.handler.RequestLogHandler.handle(RequestLogHandler.java:49)
    at org.mortbay.jetty.handler.HandlerWrapper.handle(HandlerWrapper.java:152)
    at org.mortbay.jetty.Server.handle(Server.java:324)
    at org.mortbay.jetty.HttpConnection.handleRequest(HttpConnection.java:505)
    at org.mortbay.jetty.HttpConnection$RequestHandler.content(HttpConnection.java:843)
    at org.mortbay.jetty.HttpParser.parseNext(HttpParser.java:647)
    at org.mortbay.jetty.HttpParser.parseAvailable(HttpParser.java:211)
    at org.mortbay.jetty.HttpConnection.handle(HttpConnection.java:380)
    at org.mortbay.io.nio.SelectChannelEndPoint.run(SelectChannelEndPoint.java:395)
    at org.mortbay.thread.QueuedThreadPool$PoolThread.run(QueuedThreadPool.java:488)

domain class with getters/setters omitted:

public class Iuser extends LightEntity implements java.io.Serializable, IsSerializable {
    private static final long serialVersionUID = 1L;
    private Integer id;
    private int idDataProfil;
    private int idTableDataProfil;
    private String name;
    private String surname;
    private String email;
    private String password;
    private String sex;
    private Date birthday;
    private Date joinDate;
    private String registrationConfirmation;
    private int registrationConfirmed;
    private Date timeLastConnectionAttempt;
    private int connectionAttempt;
    private Set<ProfilData1> profilData1s = new HashSet<ProfilData1>(0);

service implementation:

@RemoteServiceRelativePath("login")
public class LoginServiceImpl extends PersistentRemoteService implements LoginService {
    private static final long serialVersionUID = 1L;
    private static final Integer MAX_CONNECTION_ATTEMPT_AUTHORIZED_BY_DAY = 15;
    private static final Integer OK = 0;
    private static final Integer NOK = 1;

    /**
      * Constructor
      */    
    public LoginServiceImpl() {

        GwtConfigurationHelper.initGwtStatelessBeanManager(new HibernateUtil(HibernateContext.getSessionFactory()));
        /* 
        HibernateUtil gileadHibernateUtil = new HibernateUtil();
        gileadHibernateUtil.setSessionFactory(HibernateContext.getSessionFactory());
        
        PersistentBeanManager persistentBeanManager = new PersistentBeanManager();
        persistentBeanManager.setPersistenceUtil(gileadHibernateUtil);
        
        StatelessProxyStore proxyStore = new StatelessProxyStore();
        proxyStore.setProxySerializer(new GwtProxySerialization());
        
        persistentBeanManager.setProxyStore(proxyStore);
        setBeanManager(persistentBeanManager);
        */
    }
    public Iuser TestWithServerIfLoginAndPasswordIsCorrect(String login, String password) {

        Session session = null;
        Transaction transaction = null;
        try {
            session = HibernateContext.getSessionFactory().openSession();
            transaction = session.beginTransaction();
            Iuser iuser = (Iuser) session.createCriteria(Iuser.class).add(Restrictions.eq("email", login))
                                                                     .add(Restrictions.eq("registrationConfirmed", 1))
                                                                     .add(Restrictions.sqlRestriction("connection_attempt < " + MAX_CONNECTION_ATTEMPT_AUTHORIZED_BY_DAY )) 
                                                                     .uniqueResult();
            if (iuser != null) {
                System.out.println("user founded - " + iuser.getProfilData1s().size() + " entries");
                boolean passwordIsValid = false;
                passwordIsValid = BCrypt.checkpw(password, iuser.getPassword());
                
                if (passwordIsValid) {
                    // Initialisation Session utilisateur
                    HttpSession sessionHTTP = this.getThreadLocalRequest().getSession();
                    sessionHTTP.setAttribute("isAuthenticated", "true");
                    sessionHTTP.setAttribute("idUser", iuser.getId().toString());
                    sessionHTTP.setAttribute("user", iuser.getSurname());
                    return (iuser);
                }
                else {
                    iuser.setConnectionAttempt(iuser.getConnectionAttempt() + 1);
                    Date date = new Date();
                    date.setTime(date.getTime() + 1000 * 60 * 15);
                    iuser.setTimeLastConnectionAttempt(date);
                    session.update(iuser);
                    transaction.commit();
                }   
            }
        }
        catch (RuntimeException e) {
            if (transaction != null) 
                transaction.rollback();
            throw e;
        }
        finally {
            if (session != null)
                session.close();
        }
        return null;
    }

All seems to work fine on server side. In the stacktrace, i can count how many ProfilData my Iuser got.
But it fails at serialization step.

English isn't my native language and i apologize for that.
Thanks in advance for any advice and please let me know what additional information I can provide.
Camille