blob: 0fb317fc83951365664b7a3ec70b7d28e48fc034 [file] [log] [blame]
/*******************************************************************************
* Copyright (c) 2013-2020 LAAS-CNRS (www.laas.fr)
* 7 Colonel Roche 31077 Toulouse - France
*
* All rights reserved. This program and the accompanying materials
* are made available under the terms of the Eclipse Public License 2.0
* which accompanies this distribution, and is available at
* https://www.eclipse.org/legal/epl-2.0/
*
* Initial Contributors:
* Thierry Monteil : Project manager, technical co-manager
* Mahdi Ben Alaya : Technical co-manager
* Samir Medjiah : Technical co-manager
* Khalil Drira : Strategy expert
* Guillaume Garzone : Developer
* François Aïssaoui : Developer
*
* New contributors :
*******************************************************************************/
package org.eclipse.om2m.core.entitymapper;
import java.math.BigInteger;
import java.util.List;
import org.eclipse.om2m.commons.constants.Operation;
import org.eclipse.om2m.commons.constants.ResultContent;
import org.eclipse.om2m.commons.entities.LabelEntity;
import org.eclipse.om2m.commons.entities.ResourceEntity;
import org.eclipse.om2m.commons.resource.ChildResourceRef;
import org.eclipse.om2m.commons.resource.RequestPrimitive;
import org.eclipse.om2m.commons.resource.Resource;
/**
* Generic entity mapper
*
* @param <E>
* type of the Entity
* @param <R>
* type of the Resource
*/
public abstract class EntityMapper<E extends ResourceEntity, R extends Resource> {
/**
* Method used to map generic attributes to resource object
*
* @param entity
* @param resource
*/
private void mapGenericAttributes(E entity, R resource, int level, int offset) {
if (level < 0) {
return;
}
resource.setCreationTime(entity.getCreationTime());
resource.setLastModifiedTime(entity.getLastModifiedTime());
resource.setName(entity.getName());
resource.setParentID(entity.getParentID());
resource.setResourceID(entity.getResourceID());
resource.setResourceType(entity.getResourceType());
for (LabelEntity lbl : entity.getLabelsEntities()) {
resource.getLabels().add(lbl.getLabel());
}
}
/**
* Main method that use the ResultContent from the RequestPrimitive
*
* @param entity
* to map
* @param request
* currently performing
* @return the mapped serializable resource
*/
public R mapEntityToResource(E entity, RequestPrimitive request) {
BigInteger resultContent = request.getResultContent();
BigInteger level = null;
BigInteger offset = null;
if (request.getFilterCriteria() != null) {
level = request.getFilterCriteria().getLevel();
offset = request.getFilterCriteria().getOffset();
}
// default value for level = 1000 => all possible levels
int levelInt = 1000;
int offsetInt = 0;
if (level != null) {
levelInt = level.intValue();
}
if (offset != null) {
offsetInt = offset.intValue();
}
if (resultContent == null) {
resultContent = ResultContent.ATTRIBUTES;
} else {
if (request.getOperation().equals(Operation.CREATE)) {
resultContent = ResultContent.ATTRIBUTES;
}
}
return mapEntityToResource(entity, resultContent, levelInt, offsetInt);
}
/**
* Aux method to map entity using a specific resultContent
*
* @param entity
* to map
* @param resultContent
* to use
* @return the mapped serializable resource
*/
public R mapEntityToResource(E entity, BigInteger resultContent, int level, int offset) {
R result = createResource(entity);
if (resultContent.equals(ResultContent.ATTRIBUTES)
|| resultContent.equals(ResultContent.ATTRIBUTES_AND_CHILD_REF)
|| resultContent.equals(ResultContent.ATTRIBUTES_AND_CHILD_RES)
|| resultContent.equals(ResultContent.HIERARCHICAL_ADRESS)
|| resultContent.equals(ResultContent.HIERARCHICAL_AND_ATTRIBUTES)
|| resultContent.equals(ResultContent.ORIGINAL_RES)) {
mapGenericAttributes(entity, result, level, offset);
mapAttributes(entity, result, level, offset);
}
if (resultContent.equals(ResultContent.ATTRIBUTES_AND_CHILD_REF)
|| resultContent.equals(ResultContent.CHILD_REF)) {
mapChildResourceRef(entity, result, level, offset);
}
if (resultContent.equals(ResultContent.ATTRIBUTES_AND_CHILD_RES)) {
mapChildResources(entity, result, level, offset);
}
return result;
}
/**
* Map main attributes of a resource (not the generic attributes)
*
* @param entity
* to map
* @param resource
* result
*/
protected abstract void mapAttributes(E entity, R resource, int level, int offset);
/**
* Map child resource references of the resource
*
* @param entity
* to map
* @param resource
* resource
*/
protected abstract void mapChildResourceRef(E entity, R resource, int level, int offset);
/**
*
* @param entity
* @return
*/
protected abstract List<ChildResourceRef> getChildResourceRef(E entity, int level, int offset);
/**
* Map child reosurces using their attributes
*
* @param entity
* to map
* @param resource
*/
protected abstract void mapChildResources(E entity, R resource, int level, int offset);
/**
* Method use to create the object to return corresponding to the R type.
*
* @return the created empty resource
*/
protected R createResource(E entity) {
return createResource();
}
/**
* Method use to create the object to return corresponding to the R type.
*
* @return the created empty resource
*/
protected abstract R createResource();
}