/* GRANITE DATA SERVICES Copyright (C) 2013 GRANITE DATA SERVICES S.A.S. This file is part of Granite Data Services. Granite Data Services is free software; you can redistribute it and/or modify it under the terms of the GNU Library General Public License as published by the Free Software Foundation; either version 2 of the License, or (at your option) any later version. Granite Data Services is distributed in the hope that it will be useful, but WITHOUT ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU Library General Public License for more details. You should have received a copy of the GNU Library General Public License along with this library; if not, see <http://www.gnu.org/licenses/>. */ package org.granite.client.messaging.jmf.ext; import java.io.IOException; import java.lang.reflect.InvocationTargetException; import java.util.ArrayList; import java.util.List; import org.granite.client.persistence.Entity; import org.granite.client.persistence.Persistence; import org.granite.client.platform.Platform; import org.granite.messaging.jmf.ExtendedObjectInput; import org.granite.messaging.jmf.ExtendedObjectOutput; import org.granite.messaging.jmf.codec.ExtendedObjectCodec; import org.granite.messaging.reflect.Property; /** * @author Franck WOLFF */ public class ClientEntityCodec implements ExtendedObjectCodec { public boolean canEncode(ExtendedObjectOutput out, Object v) { return v.getClass().isAnnotationPresent(Entity.class); } public String getEncodedClassName(ExtendedObjectOutput out, Object v) { return out.getAlias(v.getClass().getName()); } public void encode(ExtendedObjectOutput out, Object v) throws IOException, IllegalAccessException, InvocationTargetException { Persistence persistence = Platform.persistence(); boolean initialized = persistence.isInitialized(v); out.writeBoolean(initialized); out.writeUTF(persistence.getDetachedState(v)); if (!initialized) out.writeObject(persistence.getId(v)); else { List<Property> properties = new ArrayList<Property>(out.getReflection().findSerializableProperties(v.getClass())); properties.remove(persistence.getInitializedProperty(v.getClass())); properties.remove(persistence.getDetachedStateProperty(v.getClass())); for (Property property : properties) out.getAndWriteProperty(v, property); } } public boolean canDecode(ExtendedObjectInput in, String className) throws ClassNotFoundException { String alias = in.getAlias(className); Class<?> cls = in.getReflection().loadClass(alias); return cls.isAnnotationPresent(Entity.class); } public String getDecodedClassName(ExtendedObjectInput in, String className) { return in.getAlias(className); } public Object newInstance(ExtendedObjectInput in, String className) throws IOException, ClassNotFoundException, InstantiationException, IllegalAccessException, InvocationTargetException, SecurityException, NoSuchMethodException, IOException { Class<?> cls = in.getReflection().loadClass(className); return in.getReflection().newInstance(cls); } public void decode(ExtendedObjectInput in, Object v) throws IOException, ClassNotFoundException, IllegalAccessException, InvocationTargetException { Persistence persistence = Platform.persistence(); boolean initialized = in.readBoolean(); String detachedState = in.readUTF(); persistence.setInitialized(v, initialized); persistence.setDetachedState(v, detachedState); if (!initialized) persistence.setId(v, in.readObject()); else { List<Property> properties = new ArrayList<Property>(in.getReflection().findSerializableProperties(v.getClass())); properties.remove(persistence.getInitializedProperty(v.getClass())); properties.remove(persistence.getDetachedStateProperty(v.getClass())); for (Property property : properties) in.readAndSetProperty(v, property); } } }