
com.inspiresoftware.lib.dto.geda.DTOSupport Maven / Gradle / Ivy
Go to download
Show more of this group Show more artifacts with this name
Show all versions of geda.spring-integration Show documentation
Show all versions of geda.spring-integration Show documentation
Provides GeDA core integration for Spring framework
/*
* This code is distributed under The GNU Lesser General Public License (LGPLv3)
* Please visit GNU site for LGPLv3 http://www.gnu.org/copyleft/lesser.html
*
* Copyright Denis Pavlov 2009
* Web: http://www.inspire-software.com
* SVN: https://geda-genericdto.svn.sourceforge.net/svnroot/geda-genericdto
*/
package com.inspiresoftware.lib.dto.geda;
import java.util.Collection;
/**
* Facade for working with DTO to entity conversion that is application aware and
* uses the GeDA assembler.
*
* User: denispavlov
* Date: Sep 27, 2011
* Time: 8:29:02 AM
*/
public interface DTOSupport extends GeDAInfrastructure {
/**
* Assemble dto from entity object
*
* @param dto dto (must not be null)
* @param entity entity (must not be null)
* @param context transfer context
*
* @return convenience return object (same as dto param). Used for the
* following: final DTO dto = support.assembleDto(new DTO(), entity);
*/
T assembleDto(T dto, Object entity, String context);
/**
* Assemble new dto from entity object
*
* @param dtoKey dto key (must not be null)
* @param entity entity (must not be null)
* @param context transfer context
*
* @return DTO object with data
*/
T assembleDtoByKey(String dtoKey, Object entity, String context);
/**
* Assemble dto from entity object
*
* @param dtoFilter specify the class level (can be used as a filter if there are DTO hierarchies)
* @param dto dto (must not be null)
* @param entity entity (must not be null)
* @param context transfer context
*
* @return convenience return object (same as dto param). Used for the
* following: final DTO dto = support.assembleDto(new DTO(), entity);
*/
T assembleDto(String dtoFilter, T dto, Object entity, String context);
/**
* Assemble dto from entity object
*
* @param dtoFilter specify the class level (can be used as a filter if there are DTO hierarchies)
* @param dtoKey dto key (must not be null)
* @param entity entity (must not be null)
* @param context transfer context
*
* @return DTO object with data
*/
T assembleDtoByKey(String dtoFilter, String dtoKey, Object entity, String context);
/**
* Assemble dto from entity object
*
* @param dtoKey dto object key
* @param dtos dto collection (must not be null)
* @param entities entities collection (must not be null)
* @param context transfer context
*/
void assembleDtos(String dtoKey, Collection dtos, Collection entities, String context);
/**
* Assemble dto from entity object
*
* @param dtoFilter specify the class level (can be used as a filter if there are DTO hierarchies)
* @param dtoKey dto object key
* @param dtos dto collection (must not be null)
* @param entities entities collection (must not be null)
* @param context transfer context
*/
void assembleDtos(String dtoFilter, String dtoKey, Collection dtos, Collection entities, String context);
/**
* Assemble entity from dto object
*
* @param dto dto (must not be null)
* @param entity entity (must not be null)
* @param context transfer context
*
* @return convenience return object (same as entity param). Used for the
* following: final Object dto = support.assembleEntity(dto, new Object());
*/
T assembleEntity(Object dto, T entity, String context);
/**
* Assemble entity from dto object
*
* @param dto dto (must not be null)
* @param entityKey entity key (must not be null)
* @param context transfer context
*
* @return new entity
*/
T assembleEntityByKey(Object dto, String entityKey, String context);
/**
* Assemble entity from dto object
*
* @param dtoFilter specify the class level
* @param dto dto (must not be null)
* @param entity entity (must not be null)
* @param context transfer context
*
* @return convenience return object (same as entity param). Used for the
* following: final Object dto = support.assembleEntity(dto, new Object());
*/
T assembleEntity(String dtoFilter, Object dto, T entity, String context);
/**
* Assemble entity from dto object
*
* @param dtoFilter specify the class level
* @param dto dto (must not be null)
* @param entityKey entity key (must not be null)
* @param context transfer context
*
* @return new entity
*/
T assembleEntityByKey(String dtoFilter, Object dto, String entityKey, String context);
/**
* Assemble entities from dto objects
*
* @param entityKey entity object key
* @param dtos dto collection (must not be null)
* @param entities entities collection (must not be null)
* @param context transfer context
*/
void assembleEntities(String entityKey, Collection dtos, Collection entities, String context);
/**
* Assemble entities from dto objects
*
* @param dtoFilter specify the class level
* @param entityKey entity object key
* @param dtos dto collection (must not be null)
* @param entities entities collection (must not be null)
* @param context transfer context
*/
void assembleEntities(String dtoFilter, String entityKey, Collection dtos, Collection entities, String context);
/**
* Enhance runtime DTO converters runtime model. This method is intended to be used in
* service bean constructors that need to provide additional implementation specific
* conversions (such as retrievers for example).
*
* @param key converter key (as provided in DTO mapping annotations)
* @param converter either converter of a retriever.
*/
void registerAdapter(final String key, final Object converter);
}
© 2015 - 2025 Weber Informatics LLC | Privacy Policy