[OLINGO-507] (First) Changes for Function/Action support
This commit is contained in:
parent
6b0d6d2544
commit
b441a524b6
|
@ -63,6 +63,20 @@ public interface ComplexCollectionProcessor extends Processor {
|
||||||
ContentType requestFormat, ContentType responseFormat)
|
ContentType requestFormat, ContentType responseFormat)
|
||||||
throws ODataApplicationException, DeserializerException, SerializerException;
|
throws ODataApplicationException, DeserializerException, SerializerException;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Process an action which has as return type a complex-type collection.
|
||||||
|
* @param request OData request object containing raw HTTP information
|
||||||
|
* @param response OData response object for collecting response data
|
||||||
|
* @param uriInfo information of a parsed OData URI
|
||||||
|
* @param requestFormat content type of body sent with request
|
||||||
|
* @param responseFormat requested content type after content negotiation
|
||||||
|
* @throws ODataApplicationException if the service implementation encounters a failure
|
||||||
|
* @throws DeserializerException if deserialization failed
|
||||||
|
* @throws SerializerException if serialization failed
|
||||||
|
*/
|
||||||
|
void processComplexCollection(ODataRequest request, ODataResponse response, UriInfo uriInfo,
|
||||||
|
ContentType requestFormat, ContentType responseFormat)
|
||||||
|
throws ODataApplicationException, DeserializerException, SerializerException;
|
||||||
/**
|
/**
|
||||||
* Deletes complex-type collection from an entity and puts the status into the response.
|
* Deletes complex-type collection from an entity and puts the status into the response.
|
||||||
* Deletion for complex-type collection is equal to
|
* Deletion for complex-type collection is equal to
|
||||||
|
|
|
@ -43,6 +43,7 @@ public interface ComplexProcessor extends Processor {
|
||||||
*/
|
*/
|
||||||
void readComplex(ODataRequest request, ODataResponse response, UriInfo uriInfo, ContentType responseFormat)
|
void readComplex(ODataRequest request, ODataResponse response, UriInfo uriInfo, ContentType responseFormat)
|
||||||
throws ODataApplicationException, SerializerException;
|
throws ODataApplicationException, SerializerException;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Update complex-type instance with send data in the persistence and
|
* Update complex-type instance with send data in the persistence and
|
||||||
* puts content, status, and Location into the response.
|
* puts content, status, and Location into the response.
|
||||||
|
@ -59,6 +60,21 @@ public interface ComplexProcessor extends Processor {
|
||||||
ContentType requestFormat, ContentType responseFormat)
|
ContentType requestFormat, ContentType responseFormat)
|
||||||
throws ODataApplicationException, DeserializerException, SerializerException;
|
throws ODataApplicationException, DeserializerException, SerializerException;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Process an action which has as return type a complex-type.
|
||||||
|
* @param request OData request object containing raw HTTP information
|
||||||
|
* @param response OData response object for collecting response data
|
||||||
|
* @param uriInfo information of a parsed OData URI
|
||||||
|
* @param requestFormat content type of body sent with request
|
||||||
|
* @param responseFormat requested content type after content negotiation
|
||||||
|
* @throws ODataApplicationException if the service implementation encounters a failure
|
||||||
|
* @throws DeserializerException if deserialization failed
|
||||||
|
* @throws SerializerException if serialization failed
|
||||||
|
*/
|
||||||
|
void processComplex(ODataRequest request, ODataResponse response, UriInfo uriInfo, ContentType requestFormat,
|
||||||
|
ContentType responseFormat)
|
||||||
|
throws ODataApplicationException, DeserializerException, SerializerException;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Deletes complex-type value from an entity and puts the status into the response.
|
* Deletes complex-type value from an entity and puts the status into the response.
|
||||||
* Deletion for complex-type values is equal to
|
* Deletion for complex-type values is equal to
|
||||||
|
|
|
@ -75,4 +75,20 @@ public interface PrimitiveCollectionProcessor extends Processor {
|
||||||
*/
|
*/
|
||||||
void deletePrimitiveCollection(ODataRequest request, ODataResponse response, UriInfo uriInfo)
|
void deletePrimitiveCollection(ODataRequest request, ODataResponse response, UriInfo uriInfo)
|
||||||
throws ODataApplicationException;
|
throws ODataApplicationException;
|
||||||
|
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Process an action which has as return type a primitive-type collection.
|
||||||
|
* @param request OData request object containing raw HTTP information
|
||||||
|
* @param response OData response object for collecting response data
|
||||||
|
* @param uriInfo information of a parsed OData URI
|
||||||
|
* @param requestFormat content type of body sent with request
|
||||||
|
* @param responseFormat requested content type after content negotiation
|
||||||
|
* @throws ODataApplicationException if the service implementation encounters a failure
|
||||||
|
* @throws DeserializerException if deserialization failed
|
||||||
|
* @throws SerializerException if serialization failed
|
||||||
|
*/
|
||||||
|
void processPrimitiveCollection(ODataRequest request, ODataResponse response, UriInfo uriInfo,
|
||||||
|
ContentType requestFormat, ContentType responseFormat)
|
||||||
|
throws ODataApplicationException, DeserializerException, SerializerException;
|
||||||
}
|
}
|
|
@ -72,4 +72,19 @@ public interface PrimitiveProcessor extends Processor {
|
||||||
*/
|
*/
|
||||||
void deletePrimitive(ODataRequest request, ODataResponse response, UriInfo uriInfo)
|
void deletePrimitive(ODataRequest request, ODataResponse response, UriInfo uriInfo)
|
||||||
throws ODataApplicationException;
|
throws ODataApplicationException;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Process an action which has as return type a primitive-type.
|
||||||
|
* @param request OData request object containing raw HTTP information
|
||||||
|
* @param response OData response object for collecting response data
|
||||||
|
* @param uriInfo information of a parsed OData URI
|
||||||
|
* @param requestFormat content type of body sent with request
|
||||||
|
* @param responseFormat requested content type after content negotiation
|
||||||
|
* @throws ODataApplicationException if the service implementation encounters a failure
|
||||||
|
* @throws DeserializerException if deserialization failed
|
||||||
|
* @throws SerializerException if serialization failed
|
||||||
|
*/
|
||||||
|
void processPrimitive(ODataRequest request, ODataResponse response, UriInfo uriInfo,
|
||||||
|
ContentType requestFormat, ContentType responseFormat)
|
||||||
|
throws ODataApplicationException, DeserializerException, SerializerException;
|
||||||
}
|
}
|
|
@ -21,8 +21,13 @@ package org.apache.olingo.server.core;
|
||||||
import java.util.LinkedList;
|
import java.util.LinkedList;
|
||||||
import java.util.List;
|
import java.util.List;
|
||||||
|
|
||||||
|
import org.apache.olingo.commons.api.edm.EdmAction;
|
||||||
|
import org.apache.olingo.commons.api.edm.EdmActionImport;
|
||||||
import org.apache.olingo.commons.api.edm.EdmEntityType;
|
import org.apache.olingo.commons.api.edm.EdmEntityType;
|
||||||
|
import org.apache.olingo.commons.api.edm.EdmFunction;
|
||||||
|
import org.apache.olingo.commons.api.edm.EdmFunctionImport;
|
||||||
import org.apache.olingo.commons.api.edm.EdmPrimitiveTypeKind;
|
import org.apache.olingo.commons.api.edm.EdmPrimitiveTypeKind;
|
||||||
|
import org.apache.olingo.commons.api.edm.EdmReturnType;
|
||||||
import org.apache.olingo.commons.api.edm.constants.ODataServiceVersion;
|
import org.apache.olingo.commons.api.edm.constants.ODataServiceVersion;
|
||||||
import org.apache.olingo.commons.api.format.ContentType;
|
import org.apache.olingo.commons.api.format.ContentType;
|
||||||
import org.apache.olingo.commons.api.format.ODataFormat;
|
import org.apache.olingo.commons.api.format.ODataFormat;
|
||||||
|
@ -61,7 +66,9 @@ import org.apache.olingo.server.api.serializer.RepresentationType;
|
||||||
import org.apache.olingo.server.api.serializer.SerializerException;
|
import org.apache.olingo.server.api.serializer.SerializerException;
|
||||||
import org.apache.olingo.server.api.uri.UriInfo;
|
import org.apache.olingo.server.api.uri.UriInfo;
|
||||||
import org.apache.olingo.server.api.uri.UriResource;
|
import org.apache.olingo.server.api.uri.UriResource;
|
||||||
|
import org.apache.olingo.server.api.uri.UriResourceAction;
|
||||||
import org.apache.olingo.server.api.uri.UriResourceEntitySet;
|
import org.apache.olingo.server.api.uri.UriResourceEntitySet;
|
||||||
|
import org.apache.olingo.server.api.uri.UriResourceFunction;
|
||||||
import org.apache.olingo.server.api.uri.UriResourceNavigation;
|
import org.apache.olingo.server.api.uri.UriResourceNavigation;
|
||||||
import org.apache.olingo.server.api.uri.UriResourcePartTyped;
|
import org.apache.olingo.server.api.uri.UriResourcePartTyped;
|
||||||
import org.apache.olingo.server.api.uri.UriResourcePrimitiveProperty;
|
import org.apache.olingo.server.api.uri.UriResourcePrimitiveProperty;
|
||||||
|
@ -221,34 +228,43 @@ public class ODataHandler {
|
||||||
throws ODataHandlerException, ContentNegotiatorException, ODataApplicationException,
|
throws ODataHandlerException, ContentNegotiatorException, ODataApplicationException,
|
||||||
SerializerException, DeserializerException {
|
SerializerException, DeserializerException {
|
||||||
|
|
||||||
final HttpMethod method = request.getMethod();
|
|
||||||
final int lastPathSegmentIndex = uriInfo.getUriResourceParts().size() - 1;
|
final int lastPathSegmentIndex = uriInfo.getUriResourceParts().size() - 1;
|
||||||
final UriResource lastPathSegment = uriInfo.getUriResourceParts().get(lastPathSegmentIndex);
|
final UriResource lastPathSegment = uriInfo.getUriResourceParts().get(lastPathSegmentIndex);
|
||||||
|
|
||||||
switch (lastPathSegment.getKind()) {
|
switch (lastPathSegment.getKind()) {
|
||||||
|
case action:
|
||||||
|
handleActionDispatching(request, response, (UriResourceAction) lastPathSegment);
|
||||||
|
break;
|
||||||
|
|
||||||
|
case function:
|
||||||
|
handleFunctionDispatching(request, response, (UriResourceFunction) lastPathSegment);
|
||||||
|
break;
|
||||||
|
|
||||||
case entitySet:
|
case entitySet:
|
||||||
case navigationProperty:
|
case navigationProperty:
|
||||||
handleEntityDispatching(request, response, method, (UriResourcePartTyped) lastPathSegment);
|
handleEntityDispatching(request, response, (UriResourcePartTyped) lastPathSegment);
|
||||||
break;
|
break;
|
||||||
|
|
||||||
case count:
|
case count:
|
||||||
handleCountDispatching(request, response, method, lastPathSegmentIndex);
|
handleCountDispatching(request, response, lastPathSegmentIndex);
|
||||||
break;
|
break;
|
||||||
|
|
||||||
case primitiveProperty:
|
case primitiveProperty:
|
||||||
handlePrimitivePropertyDispatching(request, response, method, (UriResourceProperty) lastPathSegment);
|
handlePrimitivePropertyDispatching(request, response, false,
|
||||||
|
((UriResourceProperty) lastPathSegment).isCollection());
|
||||||
break;
|
break;
|
||||||
|
|
||||||
case complexProperty:
|
case complexProperty:
|
||||||
handleComplexPropertyDispatching(request, response, method, (UriResourceProperty) lastPathSegment);
|
handleComplexPropertyDispatching(request, response, false,
|
||||||
|
((UriResourceProperty) lastPathSegment).isCollection());
|
||||||
break;
|
break;
|
||||||
|
|
||||||
case value:
|
case value:
|
||||||
handleValueDispatching(request, response, method, lastPathSegmentIndex);
|
handleValueDispatching(request, response, lastPathSegmentIndex);
|
||||||
break;
|
break;
|
||||||
|
|
||||||
case ref:
|
case ref:
|
||||||
handleReferenceDispatching(request, response, method, lastPathSegmentIndex);
|
handleReferenceDispatching(request, response, lastPathSegmentIndex);
|
||||||
break;
|
break;
|
||||||
|
|
||||||
default:
|
default:
|
||||||
|
@ -257,10 +273,88 @@ public class ODataHandler {
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
private void handleFunctionDispatching(ODataRequest request, ODataResponse response,
|
||||||
|
UriResourceFunction uriResourceFunction)
|
||||||
|
throws ODataHandlerException, SerializerException, ContentNegotiatorException,
|
||||||
|
ODataApplicationException, DeserializerException {
|
||||||
|
final HttpMethod method = request.getMethod();
|
||||||
|
if(method != HttpMethod.GET) {
|
||||||
|
throw new ODataHandlerException("HTTP method " + method + " is not allowed.",
|
||||||
|
ODataHandlerException.MessageKeys.HTTP_METHOD_NOT_ALLOWED, method.toString());
|
||||||
|
}
|
||||||
|
|
||||||
|
EdmFunctionImport functionImport = uriResourceFunction.getFunctionImport();
|
||||||
|
// could be null for bound functions
|
||||||
|
if(functionImport == null) {
|
||||||
|
throw new ODataHandlerException("not implemented",
|
||||||
|
ODataHandlerException.MessageKeys.FUNCTIONALITY_NOT_IMPLEMENTED);
|
||||||
|
}
|
||||||
|
//
|
||||||
|
|
||||||
|
List<EdmFunction> unboundFunctions = functionImport.getUnboundFunctions();
|
||||||
|
if(unboundFunctions == null || unboundFunctions.isEmpty()) {
|
||||||
|
throw new ODataHandlerException("No unbound function defined for function import",
|
||||||
|
ODataHandlerException.MessageKeys.FUNCTIONALITY_NOT_IMPLEMENTED);
|
||||||
|
}
|
||||||
|
EdmReturnType returnType = unboundFunctions.get(0).getReturnType();
|
||||||
|
handleOperationDispatching(request, response, uriResourceFunction, false, returnType);
|
||||||
|
}
|
||||||
|
|
||||||
|
private void handleActionDispatching(ODataRequest request, ODataResponse response,
|
||||||
|
UriResourceAction uriResourceAction)
|
||||||
|
throws ODataHandlerException, SerializerException, ContentNegotiatorException,
|
||||||
|
ODataApplicationException, DeserializerException {
|
||||||
|
|
||||||
|
final HttpMethod method = request.getMethod();
|
||||||
|
if(request.getMethod() != HttpMethod.POST) {
|
||||||
|
throw new ODataHandlerException("HTTP method " + method + " is not allowed.",
|
||||||
|
ODataHandlerException.MessageKeys.HTTP_METHOD_NOT_ALLOWED, method.toString());
|
||||||
|
}
|
||||||
|
|
||||||
|
EdmActionImport functionImport = uriResourceAction.getActionImport();
|
||||||
|
// could be null for bound functions
|
||||||
|
if(functionImport == null) {
|
||||||
|
throw new ODataHandlerException("not implemented",
|
||||||
|
ODataHandlerException.MessageKeys.FUNCTIONALITY_NOT_IMPLEMENTED);
|
||||||
|
}
|
||||||
|
//
|
||||||
|
|
||||||
|
EdmAction unboundFunctions = functionImport.getUnboundAction();
|
||||||
|
if(unboundFunctions == null) {
|
||||||
|
throw new ODataHandlerException("No unbound function defined for function import",
|
||||||
|
ODataHandlerException.MessageKeys.FUNCTIONALITY_NOT_IMPLEMENTED);
|
||||||
|
}
|
||||||
|
EdmReturnType returnType = unboundFunctions.getReturnType();
|
||||||
|
handleOperationDispatching(request, response, uriResourceAction, true, returnType);
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
private void handleOperationDispatching(ODataRequest request, ODataResponse response,
|
||||||
|
UriResourcePartTyped uriResource,
|
||||||
|
boolean isAction, EdmReturnType edmReturnTypeKind)
|
||||||
|
throws ODataHandlerException, SerializerException, ContentNegotiatorException,
|
||||||
|
ODataApplicationException, DeserializerException {
|
||||||
|
|
||||||
|
switch (edmReturnTypeKind.getType().getKind()) {
|
||||||
|
case ENTITY:
|
||||||
|
handleEntityDispatching(request, response, uriResource);
|
||||||
|
break;
|
||||||
|
case PRIMITIVE:
|
||||||
|
handlePrimitivePropertyDispatching(request, response, isAction, edmReturnTypeKind.isCollection());
|
||||||
|
break;
|
||||||
|
default:
|
||||||
|
throw new ODataHandlerException("not implemented",
|
||||||
|
ODataHandlerException.MessageKeys.FUNCTIONALITY_NOT_IMPLEMENTED);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
private void handleReferenceDispatching(final ODataRequest request, final ODataResponse response,
|
private void handleReferenceDispatching(final ODataRequest request, final ODataResponse response,
|
||||||
final HttpMethod method, final int lastPathSegmentIndex)
|
final int lastPathSegmentIndex)
|
||||||
throws ContentNegotiatorException, ODataApplicationException, SerializerException, ODataHandlerException,
|
throws ContentNegotiatorException, ODataApplicationException, SerializerException, ODataHandlerException,
|
||||||
DeserializerException {
|
DeserializerException {
|
||||||
|
final HttpMethod method = request.getMethod();
|
||||||
if (((UriResourcePartTyped) uriInfo.getUriResourceParts().get(lastPathSegmentIndex - 1)).isCollection()) {
|
if (((UriResourcePartTyped) uriInfo.getUriResourceParts().get(lastPathSegmentIndex - 1)).isCollection()) {
|
||||||
if (method == HttpMethod.GET) {
|
if (method == HttpMethod.GET) {
|
||||||
final ContentType responseFormat = ContentNegotiator.doContentNegotiation(uriInfo.getFormatOption(),
|
final ContentType responseFormat = ContentNegotiator.doContentNegotiation(uriInfo.getFormatOption(),
|
||||||
|
@ -297,9 +391,10 @@ public class ODataHandler {
|
||||||
}
|
}
|
||||||
|
|
||||||
private void handleValueDispatching(final ODataRequest request, final ODataResponse response,
|
private void handleValueDispatching(final ODataRequest request, final ODataResponse response,
|
||||||
final HttpMethod method, final int lastPathSegmentIndex)
|
final int lastPathSegmentIndex)
|
||||||
throws ContentNegotiatorException, ODataApplicationException, SerializerException, ODataHandlerException,
|
throws ContentNegotiatorException, ODataApplicationException, SerializerException, ODataHandlerException,
|
||||||
DeserializerException {
|
DeserializerException {
|
||||||
|
final HttpMethod method = request.getMethod();
|
||||||
final UriResource resource = uriInfo.getUriResourceParts().get(lastPathSegmentIndex - 1);
|
final UriResource resource = uriInfo.getUriResourceParts().get(lastPathSegmentIndex - 1);
|
||||||
if (resource instanceof UriResourceProperty) {
|
if (resource instanceof UriResourceProperty) {
|
||||||
final RepresentationType valueRepresentationType =
|
final RepresentationType valueRepresentationType =
|
||||||
|
@ -347,12 +442,12 @@ public class ODataHandler {
|
||||||
}
|
}
|
||||||
|
|
||||||
private void handleComplexPropertyDispatching(final ODataRequest request, final ODataResponse response,
|
private void handleComplexPropertyDispatching(final ODataRequest request, final ODataResponse response,
|
||||||
final HttpMethod method,
|
final boolean isAction, final boolean isCollection)
|
||||||
final UriResourceProperty complexPropertyResource)
|
|
||||||
throws ContentNegotiatorException, ODataApplicationException, SerializerException, ODataHandlerException,
|
throws ContentNegotiatorException, ODataApplicationException, SerializerException, ODataHandlerException,
|
||||||
DeserializerException {
|
DeserializerException {
|
||||||
|
|
||||||
final RepresentationType complexRepresentationType = complexPropertyResource.isCollection() ?
|
final HttpMethod method = request.getMethod();
|
||||||
|
final RepresentationType complexRepresentationType = isCollection ?
|
||||||
RepresentationType.COLLECTION_COMPLEX : RepresentationType.COMPLEX;
|
RepresentationType.COLLECTION_COMPLEX : RepresentationType.COMPLEX;
|
||||||
if (method == HttpMethod.GET) {
|
if (method == HttpMethod.GET) {
|
||||||
final ContentType requestedContentType = ContentNegotiator.doContentNegotiation(uriInfo.getFormatOption(),
|
final ContentType requestedContentType = ContentNegotiator.doContentNegotiation(uriInfo.getFormatOption(),
|
||||||
|
@ -376,6 +471,18 @@ public class ODataHandler {
|
||||||
selectProcessor(ComplexCollectionProcessor.class)
|
selectProcessor(ComplexCollectionProcessor.class)
|
||||||
.updateComplexCollection(request, response, uriInfo, requestFormat, responseFormat);
|
.updateComplexCollection(request, response, uriInfo, requestFormat, responseFormat);
|
||||||
}
|
}
|
||||||
|
} else if (method == HttpMethod.POST && isAction) {
|
||||||
|
final ContentType requestFormat = ContentType.parse(request.getHeader(HttpHeader.CONTENT_TYPE));
|
||||||
|
checkContentTypeSupport(requestFormat, complexRepresentationType);
|
||||||
|
final ContentType responseFormat = ContentNegotiator.doContentNegotiation(uriInfo.getFormatOption(),
|
||||||
|
request, customContentTypeSupport, complexRepresentationType);
|
||||||
|
if (complexRepresentationType == RepresentationType.COMPLEX) {
|
||||||
|
selectProcessor(ComplexProcessor.class)
|
||||||
|
.processComplex(request, response, uriInfo, requestFormat, responseFormat);
|
||||||
|
} else {
|
||||||
|
selectProcessor(ComplexCollectionProcessor.class)
|
||||||
|
.updateComplexCollection(request, response, uriInfo, requestFormat, responseFormat);
|
||||||
|
}
|
||||||
} else if (method == HttpMethod.DELETE) {
|
} else if (method == HttpMethod.DELETE) {
|
||||||
if (complexRepresentationType == RepresentationType.COMPLEX) {
|
if (complexRepresentationType == RepresentationType.COMPLEX) {
|
||||||
selectProcessor(ComplexProcessor.class).deleteComplex(request, response, uriInfo);
|
selectProcessor(ComplexProcessor.class).deleteComplex(request, response, uriInfo);
|
||||||
|
@ -389,10 +496,12 @@ public class ODataHandler {
|
||||||
}
|
}
|
||||||
|
|
||||||
private void handlePrimitivePropertyDispatching(final ODataRequest request, final ODataResponse response,
|
private void handlePrimitivePropertyDispatching(final ODataRequest request, final ODataResponse response,
|
||||||
final HttpMethod method, final UriResourceProperty propertyResource)
|
boolean isAction, final boolean isCollection)
|
||||||
throws ContentNegotiatorException, ODataApplicationException, SerializerException, ODataHandlerException,
|
throws ContentNegotiatorException, ODataApplicationException, SerializerException, ODataHandlerException,
|
||||||
DeserializerException {
|
DeserializerException {
|
||||||
final RepresentationType representationType = propertyResource.isCollection() ?
|
|
||||||
|
final HttpMethod method = request.getMethod();
|
||||||
|
final RepresentationType representationType = isCollection ?
|
||||||
RepresentationType.COLLECTION_PRIMITIVE : RepresentationType.PRIMITIVE;
|
RepresentationType.COLLECTION_PRIMITIVE : RepresentationType.PRIMITIVE;
|
||||||
if (method == HttpMethod.GET) {
|
if (method == HttpMethod.GET) {
|
||||||
final ContentType requestedContentType = ContentNegotiator.doContentNegotiation(uriInfo.getFormatOption(),
|
final ContentType requestedContentType = ContentNegotiator.doContentNegotiation(uriInfo.getFormatOption(),
|
||||||
|
@ -421,6 +530,18 @@ public class ODataHandler {
|
||||||
} else {
|
} else {
|
||||||
selectProcessor(PrimitiveCollectionProcessor.class).deletePrimitiveCollection(request, response, uriInfo);
|
selectProcessor(PrimitiveCollectionProcessor.class).deletePrimitiveCollection(request, response, uriInfo);
|
||||||
}
|
}
|
||||||
|
} else if (method == HttpMethod.POST && isAction) {
|
||||||
|
final ContentType requestFormat = ContentType.parse(request.getHeader(HttpHeader.CONTENT_TYPE));
|
||||||
|
checkContentTypeSupport(requestFormat, representationType);
|
||||||
|
final ContentType responseFormat = ContentNegotiator.doContentNegotiation(uriInfo.getFormatOption(),
|
||||||
|
request, customContentTypeSupport, representationType);
|
||||||
|
if (representationType == RepresentationType.PRIMITIVE) {
|
||||||
|
selectProcessor(PrimitiveProcessor.class)
|
||||||
|
.processPrimitive(request, response, uriInfo, requestFormat, responseFormat);
|
||||||
|
} else {
|
||||||
|
selectProcessor(PrimitiveCollectionProcessor.class)
|
||||||
|
.processPrimitiveCollection(request, response, uriInfo, requestFormat, responseFormat);
|
||||||
|
}
|
||||||
} else {
|
} else {
|
||||||
throw new ODataHandlerException("HTTP method " + method + " is not allowed.",
|
throw new ODataHandlerException("HTTP method " + method + " is not allowed.",
|
||||||
ODataHandlerException.MessageKeys.HTTP_METHOD_NOT_ALLOWED, method.toString());
|
ODataHandlerException.MessageKeys.HTTP_METHOD_NOT_ALLOWED, method.toString());
|
||||||
|
@ -428,9 +549,10 @@ public class ODataHandler {
|
||||||
}
|
}
|
||||||
|
|
||||||
private void handleCountDispatching(final ODataRequest request, final ODataResponse response,
|
private void handleCountDispatching(final ODataRequest request, final ODataResponse response,
|
||||||
final HttpMethod method, final int lastPathSegmentIndex)
|
final int lastPathSegmentIndex)
|
||||||
throws ODataApplicationException, SerializerException, ODataHandlerException {
|
throws ODataApplicationException, SerializerException, ODataHandlerException {
|
||||||
|
|
||||||
|
final HttpMethod method = request.getMethod();
|
||||||
if (method == HttpMethod.GET) {
|
if (method == HttpMethod.GET) {
|
||||||
final UriResource resource = uriInfo.getUriResourceParts().get(lastPathSegmentIndex - 1);
|
final UriResource resource = uriInfo.getUriResourceParts().get(lastPathSegmentIndex - 1);
|
||||||
if (resource instanceof UriResourceEntitySet || resource instanceof UriResourceNavigation) {
|
if (resource instanceof UriResourceEntitySet || resource instanceof UriResourceNavigation) {
|
||||||
|
@ -450,11 +572,11 @@ public class ODataHandler {
|
||||||
}
|
}
|
||||||
|
|
||||||
private void handleEntityDispatching(final ODataRequest request, final ODataResponse response,
|
private void handleEntityDispatching(final ODataRequest request, final ODataResponse response,
|
||||||
final HttpMethod method,
|
|
||||||
final UriResourcePartTyped uriResourcePart)
|
final UriResourcePartTyped uriResourcePart)
|
||||||
throws ContentNegotiatorException, ODataApplicationException, SerializerException, ODataHandlerException,
|
throws ContentNegotiatorException, ODataApplicationException, SerializerException, ODataHandlerException,
|
||||||
DeserializerException {
|
DeserializerException {
|
||||||
|
|
||||||
|
final HttpMethod method = request.getMethod();
|
||||||
if (uriResourcePart.isCollection()) {
|
if (uriResourcePart.isCollection()) {
|
||||||
if (method == HttpMethod.GET) {
|
if (method == HttpMethod.GET) {
|
||||||
final ContentType requestedContentType = ContentNegotiator.doContentNegotiation(uriInfo.getFormatOption(),
|
final ContentType requestedContentType = ContentNegotiator.doContentNegotiation(uriInfo.getFormatOption(),
|
||||||
|
|
|
@ -95,6 +95,14 @@ public class TechnicalPrimitiveComplexProcessor extends TechnicalProcessor
|
||||||
deleteProperty(response, uriInfo);
|
deleteProperty(response, uriInfo);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public void processPrimitive(ODataRequest request, ODataResponse response, UriInfo uriInfo,
|
||||||
|
ContentType requestFormat, ContentType responseFormat)
|
||||||
|
throws ODataApplicationException, DeserializerException, SerializerException {
|
||||||
|
throw new ODataApplicationException("Not supported yet.",
|
||||||
|
HttpStatusCode.NOT_IMPLEMENTED.getStatusCode(), Locale.ROOT);
|
||||||
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public void readPrimitiveCollection(final ODataRequest request, ODataResponse response, final UriInfo uriInfo,
|
public void readPrimitiveCollection(final ODataRequest request, ODataResponse response, final UriInfo uriInfo,
|
||||||
final ContentType contentType) throws ODataApplicationException, SerializerException {
|
final ContentType contentType) throws ODataApplicationException, SerializerException {
|
||||||
|
@ -115,6 +123,14 @@ public class TechnicalPrimitiveComplexProcessor extends TechnicalProcessor
|
||||||
deleteProperty(response, uriInfo);
|
deleteProperty(response, uriInfo);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public void processPrimitiveCollection(ODataRequest request, ODataResponse response, UriInfo uriInfo, ContentType
|
||||||
|
requestFormat, ContentType responseFormat) throws ODataApplicationException, DeserializerException,
|
||||||
|
SerializerException {
|
||||||
|
throw new ODataApplicationException("Not supported yet.",
|
||||||
|
HttpStatusCode.NOT_IMPLEMENTED.getStatusCode(), Locale.ROOT);
|
||||||
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public void readComplex(final ODataRequest request, ODataResponse response, final UriInfo uriInfo,
|
public void readComplex(final ODataRequest request, ODataResponse response, final UriInfo uriInfo,
|
||||||
final ContentType contentType) throws ODataApplicationException, SerializerException {
|
final ContentType contentType) throws ODataApplicationException, SerializerException {
|
||||||
|
@ -129,6 +145,14 @@ public class TechnicalPrimitiveComplexProcessor extends TechnicalProcessor
|
||||||
HttpStatusCode.NOT_IMPLEMENTED.getStatusCode(), Locale.ROOT);
|
HttpStatusCode.NOT_IMPLEMENTED.getStatusCode(), Locale.ROOT);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public void processComplex(ODataRequest request, ODataResponse response, UriInfo uriInfo, ContentType
|
||||||
|
requestFormat, ContentType responseFormat) throws ODataApplicationException, DeserializerException,
|
||||||
|
SerializerException {
|
||||||
|
throw new ODataApplicationException("Not supported yet.",
|
||||||
|
HttpStatusCode.NOT_IMPLEMENTED.getStatusCode(), Locale.ROOT);
|
||||||
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public void deleteComplex(final ODataRequest request, final ODataResponse response, final UriInfo uriInfo)
|
public void deleteComplex(final ODataRequest request, final ODataResponse response, final UriInfo uriInfo)
|
||||||
throws ODataApplicationException {
|
throws ODataApplicationException {
|
||||||
|
@ -149,6 +173,14 @@ public class TechnicalPrimitiveComplexProcessor extends TechnicalProcessor
|
||||||
HttpStatusCode.NOT_IMPLEMENTED.getStatusCode(), Locale.ROOT);
|
HttpStatusCode.NOT_IMPLEMENTED.getStatusCode(), Locale.ROOT);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public void processComplexCollection(ODataRequest request, ODataResponse response, UriInfo uriInfo, ContentType
|
||||||
|
requestFormat, ContentType responseFormat) throws ODataApplicationException, DeserializerException,
|
||||||
|
SerializerException {
|
||||||
|
throw new ODataApplicationException("Not supported yet.",
|
||||||
|
HttpStatusCode.NOT_IMPLEMENTED.getStatusCode(), Locale.ROOT);
|
||||||
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public void deleteComplexCollection(final ODataRequest request, ODataResponse response, final UriInfo uriInfo)
|
public void deleteComplexCollection(final ODataRequest request, ODataResponse response, final UriInfo uriInfo)
|
||||||
throws ODataApplicationException {
|
throws ODataApplicationException {
|
||||||
|
|
|
@ -46,6 +46,8 @@ public class ActionProvider {
|
||||||
new FullQualifiedName(SchemaProvider.NAMESPACE, "BAETTwoKeyNavRTETTwoKeyNav");
|
new FullQualifiedName(SchemaProvider.NAMESPACE, "BAETTwoKeyNavRTETTwoKeyNav");
|
||||||
|
|
||||||
// Unbound Actions
|
// Unbound Actions
|
||||||
|
public static final FullQualifiedName nameUARTString = new FullQualifiedName(SchemaProvider.NAMESPACE,
|
||||||
|
"UARTString");
|
||||||
public static final FullQualifiedName nameUARTCompCollParam = new FullQualifiedName(SchemaProvider.NAMESPACE,
|
public static final FullQualifiedName nameUARTCompCollParam = new FullQualifiedName(SchemaProvider.NAMESPACE,
|
||||||
"UARTCompCollParam");
|
"UARTCompCollParam");
|
||||||
public static final FullQualifiedName nameUARTCompParam = new FullQualifiedName(SchemaProvider.NAMESPACE,
|
public static final FullQualifiedName nameUARTCompParam = new FullQualifiedName(SchemaProvider.NAMESPACE,
|
||||||
|
@ -62,7 +64,12 @@ public class ActionProvider {
|
||||||
"UARTPrimCollParam");
|
"UARTPrimCollParam");
|
||||||
|
|
||||||
public List<Action> getActions(final FullQualifiedName actionName) throws ODataException {
|
public List<Action> getActions(final FullQualifiedName actionName) throws ODataException {
|
||||||
if (actionName.equals(nameUARTPrimParam)) {
|
if (actionName.equals(nameUARTString)) {
|
||||||
|
return Arrays.asList(
|
||||||
|
new Action().setName(nameUARTString.getName())
|
||||||
|
.setReturnType(new ReturnType().setType(PropertyProvider.nameString))
|
||||||
|
);
|
||||||
|
} else if (actionName.equals(nameUARTPrimParam)) {
|
||||||
return Arrays.asList(
|
return Arrays.asList(
|
||||||
new Action().setName("UARTPrimParam")
|
new Action().setName("UARTPrimParam")
|
||||||
.setParameters(Arrays.asList(
|
.setParameters(Arrays.asList(
|
||||||
|
|
|
@ -98,6 +98,7 @@ public class ContainerProvider {
|
||||||
// ActionImports
|
// ActionImports
|
||||||
List<ActionImport> actionImports = new ArrayList<ActionImport>();
|
List<ActionImport> actionImports = new ArrayList<ActionImport>();
|
||||||
container.setActionImports(actionImports);
|
container.setActionImports(actionImports);
|
||||||
|
actionImports.add(prov.getActionImport(ContainerProvider.nameContainer, "AIRTString"));
|
||||||
actionImports.add(prov.getActionImport(ContainerProvider.nameContainer, "AIRTPrimParam"));
|
actionImports.add(prov.getActionImport(ContainerProvider.nameContainer, "AIRTPrimParam"));
|
||||||
actionImports.add(prov.getActionImport(ContainerProvider.nameContainer, "AIRTPrimCollParam"));
|
actionImports.add(prov.getActionImport(ContainerProvider.nameContainer, "AIRTPrimCollParam"));
|
||||||
actionImports.add(prov.getActionImport(ContainerProvider.nameContainer, "AIRTCompParam"));
|
actionImports.add(prov.getActionImport(ContainerProvider.nameContainer, "AIRTCompParam"));
|
||||||
|
@ -261,7 +262,12 @@ public class ContainerProvider {
|
||||||
public ActionImport getActionImport(final FullQualifiedName entityContainer, final String name) throws ODataException
|
public ActionImport getActionImport(final FullQualifiedName entityContainer, final String name) throws ODataException
|
||||||
{
|
{
|
||||||
if (entityContainer.equals(nameContainer)) {
|
if (entityContainer.equals(nameContainer)) {
|
||||||
if (name.equals("AIRTPrimParam")) {
|
if (name.equals("AIRTString")) {
|
||||||
|
return new ActionImport()
|
||||||
|
.setName("AIRTString")
|
||||||
|
.setAction(ActionProvider.nameUARTString);
|
||||||
|
|
||||||
|
} else if (name.equals("AIRTPrimParam")) {
|
||||||
return new ActionImport()
|
return new ActionImport()
|
||||||
.setName("AIRTPrimParam")
|
.setName("AIRTPrimParam")
|
||||||
.setAction(ActionProvider.nameUARTPrimParam);
|
.setAction(ActionProvider.nameUARTPrimParam);
|
||||||
|
|
|
@ -107,6 +107,7 @@ public class SchemaProvider {
|
||||||
actions.addAll(prov.getActions(ActionProvider.nameBAESTwoKeyNavRTESTwoKeyNav));
|
actions.addAll(prov.getActions(ActionProvider.nameBAESTwoKeyNavRTESTwoKeyNav));
|
||||||
actions.addAll(prov.getActions(ActionProvider.nameBAETBaseTwoKeyNavRTETBaseTwoKeyNav));
|
actions.addAll(prov.getActions(ActionProvider.nameBAETBaseTwoKeyNavRTETBaseTwoKeyNav));
|
||||||
actions.addAll(prov.getActions(ActionProvider.nameBAETTwoBaseTwoKeyNavRTETBaseTwoKeyNav));
|
actions.addAll(prov.getActions(ActionProvider.nameBAETTwoBaseTwoKeyNavRTETBaseTwoKeyNav));
|
||||||
|
actions.addAll(prov.getActions(ActionProvider.nameUARTString));
|
||||||
actions.addAll(prov.getActions(ActionProvider.nameUARTPrimParam));
|
actions.addAll(prov.getActions(ActionProvider.nameUARTPrimParam));
|
||||||
actions.addAll(prov.getActions(ActionProvider.nameUARTPrimCollParam));
|
actions.addAll(prov.getActions(ActionProvider.nameUARTPrimCollParam));
|
||||||
actions.addAll(prov.getActions(ActionProvider.nameUARTCompParam));
|
actions.addAll(prov.getActions(ActionProvider.nameUARTCompParam));
|
||||||
|
|
|
@ -278,6 +278,40 @@ public class ODataHandlerTest {
|
||||||
any(ODataRequest.class), any(ODataResponse.class), any(UriInfo.class));
|
any(ODataRequest.class), any(ODataResponse.class), any(UriInfo.class));
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@Test
|
||||||
|
public void dispatchFunction() throws Exception {
|
||||||
|
final String uri = "FICRTCollString()";
|
||||||
|
final PrimitiveCollectionProcessor processor = mock(PrimitiveCollectionProcessor.class);
|
||||||
|
|
||||||
|
dispatch(HttpMethod.GET, uri, processor);
|
||||||
|
verify(processor).readPrimitiveCollection(
|
||||||
|
any(ODataRequest.class), any(ODataResponse.class), any(UriInfo.class), any(ContentType.class));
|
||||||
|
|
||||||
|
// dispatch(HttpMethod.GET, uri, processor);
|
||||||
|
// verify(processor).readEntity(
|
||||||
|
// any(ODataRequest.class), any(ODataResponse.class), any(UriInfo.class), any(ContentType.class));
|
||||||
|
|
||||||
|
dispatchMethodNotAllowed(HttpMethod.POST, uri, processor);
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
@Test
|
||||||
|
public void dispatchAction() throws Exception {
|
||||||
|
final String uri = "AIRTString";
|
||||||
|
|
||||||
|
PrimitiveProcessor processor = mock(PrimitiveProcessor.class);
|
||||||
|
dispatch(HttpMethod.POST, uri, processor);
|
||||||
|
verify(processor).processPrimitive(
|
||||||
|
any(ODataRequest.class), any(ODataResponse.class), any(UriInfo.class),
|
||||||
|
any(ContentType.class), any(ContentType.class));
|
||||||
|
|
||||||
|
// dispatch(HttpMethod.POST, uri, processor);
|
||||||
|
// verify(processor).readEntity(
|
||||||
|
// any(ODataRequest.class), any(ODataResponse.class), any(UriInfo.class), any(ContentType.class));
|
||||||
|
|
||||||
|
dispatchMethodNotAllowed(HttpMethod.GET, uri, processor);
|
||||||
|
}
|
||||||
|
|
||||||
@Test
|
@Test
|
||||||
public void dispatchEntity() throws Exception {
|
public void dispatchEntity() throws Exception {
|
||||||
final String uri = "ESAllPrim(0)";
|
final String uri = "ESAllPrim(0)";
|
||||||
|
|
Loading…
Reference in New Issue