X-Git-Url: https://git.argeo.org/?a=blobdiff_plain;f=server%2Fruntime%2Forg.argeo.server.hibernate%2Fsrc%2Fmain%2Fjava%2Forg%2Fargeo%2Fserver%2Fhibernate%2FLightDaoInterceptor.java;h=1cd1150e6483bce283b356d778b038d8156ae455;hb=490d9907457c43acfa965e7979ce5974bc1ba6ca;hp=9f3ba093d1497af291a970e7d35320b930bb8a28;hpb=a5ecc57e5fdbb6af2064388be16813a2b4d8517d;p=lgpl%2Fargeo-commons.git diff --git a/server/runtime/org.argeo.server.hibernate/src/main/java/org/argeo/server/hibernate/LightDaoInterceptor.java b/server/runtime/org.argeo.server.hibernate/src/main/java/org/argeo/server/hibernate/LightDaoInterceptor.java index 9f3ba093d..1cd1150e6 100644 --- a/server/runtime/org.argeo.server.hibernate/src/main/java/org/argeo/server/hibernate/LightDaoInterceptor.java +++ b/server/runtime/org.argeo.server.hibernate/src/main/java/org/argeo/server/hibernate/LightDaoInterceptor.java @@ -1,5 +1,22 @@ +/* + * Copyright (C) 2010 Mathieu Baudier + * + * Licensed under the Apache License, Version 2.0 (the "License"); + * you may not use this file except in compliance with the License. + * You may obtain a copy of the License at + * + * http://www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an "AS IS" BASIS, + * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the License for the specific language governing permissions and + * limitations under the License. + */ + package org.argeo.server.hibernate; +import java.beans.PropertyDescriptor; import java.io.Serializable; import java.util.ArrayList; import java.util.HashMap; @@ -35,15 +52,24 @@ public class LightDaoInterceptor extends EmptyInterceptor { @Override public Object getEntity(String entityName, Serializable id) { Class clss = findSupportingClass(entityName); + Object res = null; if (clss != null) { - if (businessIdFields.containsKey(clss)) - return lightDaoSupport.getByField(clss, businessIdFields - .get(clss), bidMappings.get(clss).get(id)); - else - return lightDaoSupport.getByKey(clss, id); + if (businessIdFields.containsKey(clss)) { + String field = businessIdFields.get(clss); + Object value = bidMappings.get(clss).get(id); + res = lightDaoSupport.getByField(clss, field, value); + if (log.isTraceEnabled()) + log.debug("Got entity " + clss + " (" + field + "=" + value + + ")"); + } else { + res = lightDaoSupport.getByKey(clss, id); + if (log.isTraceEnabled()) + log.debug("Got entity " + clss + " (id=" + id + ")"); + } } else { - return super.getEntity(entityName, id); + res = super.getEntity(entityName, id); } + return res; } @Override @@ -66,7 +92,7 @@ public class LightDaoInterceptor extends EmptyInterceptor { BeanWrapper bw = new BeanWrapperImpl(entity); Object bid = bw.getPropertyValue(businessIdFields.get(clss)); bidMappings.get(clss).put(id, bid); - if (log.isDebugEnabled()) + if (log.isTraceEnabled()) log.debug("Mapped tid " + id + " with bid " + bid + " for " + clss); } @@ -74,6 +100,48 @@ public class LightDaoInterceptor extends EmptyInterceptor { return super.onSave(entity, id, state, propertyNames, types); } + @Override + public boolean onLoad(Object entity, Serializable id, Object[] state, + String[] propertyNames, Type[] types) { + Class clss = entity.getClass(); + Object source = null; + if (lightDaoSupport.getSupportedClasses().contains(clss)) { + if (businessIdFields.containsKey(clss)) { + String field = businessIdFields.get(clss); + Object value = bidMappings.get(clss).get(id); + source = lightDaoSupport.getByField(clss, field, value); + if (log.isTraceEnabled()) + log.debug("Loading entity " + clss + " (" + field + "=" + + value + ")"); + } else { + source = lightDaoSupport.getByKey(clss, id); + if (log.isTraceEnabled()) + log.debug("Loading entity " + clss + " (id=" + id + ")"); + } + } + + if (source != null) { + BeanWrapper bwTarget = new BeanWrapperImpl(entity); + BeanWrapper bwSource = new BeanWrapperImpl(source); + for (PropertyDescriptor pd : bwTarget.getPropertyDescriptors()) { + String propName = pd.getName(); + if (bwSource.isReadableProperty(propName) + && bwTarget.isWritableProperty(propName)) { + bwTarget.setPropertyValue(propName, bwSource + .getPropertyValue(propName)); + if (log.isTraceEnabled()) + log.debug("Loaded property " + propName + " for class " + + clss + " (id=" + id + ")"); + } + } + + return true; + } else { + // res = super.getEntity(entityName, id); + return super.onLoad(entity, id, state, propertyNames, types); + } + } + protected Boolean supports(Object object) { if (classes.contains(object.getClass())) return lightDaoSupport.getSupportedClasses().contains(