blob: fbb9513d51fdf0c06288f4b3d3b3a47b10423bcd [file] [log] [blame]
/*******************************************************************************
* Copyright (c) 2013-2016 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 v1.0
* which accompanies this distribution, and is available at
* http://www.eclipse.org/legal/epl-v10.html
*
* 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.nblocking;
import java.math.BigInteger;
import java.util.concurrent.ExecutorService;
import java.util.concurrent.Executors;
import org.apache.commons.logging.Log;
import org.apache.commons.logging.LogFactory;
import org.eclipse.om2m.commons.constants.Constants;
import org.eclipse.om2m.commons.constants.MimeMediaType;
import org.eclipse.om2m.commons.constants.RequestStatus;
import org.eclipse.om2m.commons.constants.ResourceType;
import org.eclipse.om2m.commons.constants.ResponseStatusCode;
import org.eclipse.om2m.commons.constants.ResultContent;
import org.eclipse.om2m.commons.constants.ShortName;
import org.eclipse.om2m.commons.entities.CSEBaseEntity;
import org.eclipse.om2m.commons.entities.MetaInformation;
import org.eclipse.om2m.commons.entities.RequestEntity;
import org.eclipse.om2m.commons.exceptions.BadRequestException;
import org.eclipse.om2m.commons.resource.Request;
import org.eclipse.om2m.commons.resource.RequestPrimitive;
import org.eclipse.om2m.commons.resource.ResponsePrimitive;
import org.eclipse.om2m.commons.utils.Util.DateUtil;
import org.eclipse.om2m.core.controller.Controller;
import org.eclipse.om2m.core.datamapper.DataMapperSelector;
import org.eclipse.om2m.core.entitymapper.EntityMapperFactory;
import org.eclipse.om2m.core.persistence.PersistenceService;
import org.eclipse.om2m.core.urimapper.UriMapper;
import org.eclipse.om2m.persistence.service.DBService;
import org.eclipse.om2m.persistence.service.DBTransaction;
public class NonBlockingHandler {
/** Private constructor to avoir creation of this object */
private NonBlockingHandler(){}
private static ExecutorService poolThread = Executors.newFixedThreadPool(10);
private static Log LOGGER = LogFactory.getLog(NonBlockingHandler.class);
public static ResponsePrimitive handle(RequestPrimitive request){
LOGGER.info("Non blocking request received, building request object...");
DBService dbs = PersistenceService.getInstance().getDbService();
DBTransaction transaction = dbs.getDbTransaction();
transaction.open();
CSEBaseEntity cseBaseEntity = dbs.getDAOFactory().getCSEBaseDAO().find(transaction, "/" + Constants.CSE_ID);
ResponsePrimitive response = new ResponsePrimitive(request);
RequestEntity requestEntity = new RequestEntity();
try {
if(request.getContent() != null){
if(request.getRequestContentType().equals(MimeMediaType.OBJ)){
requestEntity.setContent(DataMapperSelector.getDataMapperList().get(MimeMediaType.JSON).objToString(request.getContent()));
requestEntity.setRequestContentType(MimeMediaType.JSON);
} else if(!request.getRequestContentType().equals(MimeMediaType.JSON)){
Object resource = DataMapperSelector.getDataMapperList().
get(request.getReturnContentType()).stringToObj((String)request.getContent());
requestEntity.setContent(DataMapperSelector.getDataMapperList().get(MimeMediaType.JSON).objToString(resource));
requestEntity.setRequestContentType(request.getRequestContentType());
} else {
requestEntity.setContent((String) request.getContent());
requestEntity.setRequestContentType(request.getRequestContentType());
}
}
} catch (Exception e){
throw new BadRequestException("Error in provided content");
}
requestEntity.setCreationTime(DateUtil.now());
String requestIdentifier = Controller.generateId();
requestEntity.setName(ShortName.REQ + "_" + requestIdentifier);
requestEntity.setHierarchicalURI(cseBaseEntity.getHierarchicalURI() + "/" + requestEntity.getName());
requestEntity.setResourceID("/" + Constants.CSE_ID + "/" + ShortName.REQ + Constants.PREFIX_SEPERATOR + requestIdentifier);
requestEntity.setLastModifiedTime(DateUtil.now());
MetaInformation metaInf = new MetaInformation();
metaInf.setDeliveryAggregation(request.isDeliveryAggregation());
metaInf.setDiscoveryResultType(request.getDiscoveryResultType());
// TODO EventCat nblock handler
metaInf.setGroupRequestIdentifier(request.getGroupRequestIdentifier());
metaInf.setName(request.getName());
metaInf.setOperationalExecutionTime(request.getOperationExecutionTime());
metaInf.setOriginatingTimestamp(request.getOriginatingTimestamp());
metaInf.setRequestExpirationTimestamp(request.getResultExpirationTimestamp());
metaInf.setResourceType(request.getResourceType());
metaInf.setResponseType(request.getResponseTypeInfo().getResponseType());
metaInf.setResultContent(request.getResultContent());
metaInf.setResultExpirationTimestamp(request.getResultExpirationTimestamp());
if(request.getResultPersistence() != null){
metaInf.setResultPersistence(request.getResultPersistence().toString());
}
requestEntity.setMetaInformation(metaInf);
requestEntity.setOperation(request.getOperation());
requestEntity.setOriginator(request.getFrom());
requestEntity.setParentID(cseBaseEntity.getResourceID());
requestEntity.setResourceType(ResourceType.REQUEST);
requestEntity.setReturnContentType(request.getReturnContentType());
requestEntity.setStateTag(BigInteger.valueOf(0));
requestEntity.setTarget(request.getTo());
requestEntity.setRequestID(requestIdentifier);
requestEntity.setRequestStatus(RequestStatus.PENDING);
UriMapper.addNewUri(requestEntity.getHierarchicalURI(), requestEntity.getResourceID(), ResourceType.REQUEST);
dbs.getDAOFactory().getRequestEntityDAO().create(transaction, requestEntity);
RequestEntity requestDb = dbs.getDAOFactory().getRequestEntityDAO().find(transaction, requestEntity.getResourceID());
cseBaseEntity.getChildReq().add(requestDb);
dbs.getDAOFactory().getCSEBaseDAO().update(transaction, cseBaseEntity);
transaction.commit();
Request requestResource = EntityMapperFactory.getRequestMapper().mapEntityToResource(requestEntity, ResultContent.ATTRIBUTES);
response.setContent(requestResource.getResourceID());
response.setResponseStatusCode(ResponseStatusCode.ACCEPTED);
response.setLocation(requestDb.getResourceID());
poolThread.execute(new NonBlockingWorker(requestEntity.getResourceID(),request));
transaction.close();
return response;
}
}