Tech Servlet

Signed-off-by: Christian Amend <chrisam@apache.org>
This commit is contained in:
Christian Holzer 2014-10-28 16:55:57 +01:00 committed by Christian Amend
parent 32247295fc
commit 15bd15267a
22 changed files with 535 additions and 22 deletions

View File

@ -16,7 +16,7 @@
* specific language governing permissions and limitations * specific language governing permissions and limitations
* under the License. * under the License.
*/ */
package org.apache.olingo.server.core.batch; package org.apache.olingo.server.api.batch;
import org.apache.olingo.server.api.ODataTranslatedException; import org.apache.olingo.server.api.ODataTranslatedException;
@ -40,7 +40,7 @@ public class BatchException extends ODataTranslatedException {
MISSING_CONTENT_ID, MISSING_CONTENT_ID,
MISSING_CONTENT_TRANSFER_ENCODING, MISSING_CONTENT_TRANSFER_ENCODING,
MISSING_CONTENT_TYPE, MISSING_CONTENT_TYPE,
MISSING_MANDATORY_HEADER, FORBIDDEN_HEADER; MISSING_MANDATORY_HEADER, FORBIDDEN_HEADER, INVALID_CONTENT_ID;
@Override @Override
public String getKey() { public String getKey() {

View File

@ -0,0 +1,36 @@
/*
* Licensed to the Apache Software Foundation (ASF) under one
* or more contributor license agreements. See the NOTICE file
* distributed with this work for additional information
* regarding copyright ownership. The ASF licenses this file
* to you 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.apache.olingo.server.api.batch;
import java.io.IOException;
import java.io.InputStream;
import java.util.List;
import org.apache.olingo.server.api.ODataRequest;
import org.apache.olingo.server.api.ODataResponse;
public interface BatchOperation {
public List<BatchRequestPart> parseBatchRequest(InputStream in) throws BatchException;
public ODataResponse handleODataRequest(ODataRequest request);
public ODataResponsePart handleBatchRequest(BatchRequestPart request);
public void writeResponseParts(List<ODataResponsePart> batchResponses, ODataResponse response) throws BatchException,
IOException;
}

View File

@ -0,0 +1,31 @@
/*
* Licensed to the Apache Software Foundation (ASF) under one
* or more contributor license agreements. See the NOTICE file
* distributed with this work for additional information
* regarding copyright ownership. The ASF licenses this file
* to you 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.apache.olingo.server.api.processor;
import java.util.List;
import org.apache.olingo.server.api.ODataRequest;
import org.apache.olingo.server.api.ODataResponse;
import org.apache.olingo.server.api.batch.BatchOperation;
public interface BatchProcessor extends Processor {
void executeBatch(BatchOperation operation, ODataRequest requst, ODataResponse response);
List<ODataResponse> executeChangeSet(BatchOperation operation, List<ODataRequest> requests);
}

View File

@ -35,6 +35,8 @@ import org.apache.olingo.server.api.ODataRequest;
import org.apache.olingo.server.api.ODataResponse; import org.apache.olingo.server.api.ODataResponse;
import org.apache.olingo.server.api.ODataServerError; import org.apache.olingo.server.api.ODataServerError;
import org.apache.olingo.server.api.ServiceMetadata; import org.apache.olingo.server.api.ServiceMetadata;
import org.apache.olingo.server.api.batch.BatchException;
import org.apache.olingo.server.api.processor.BatchProcessor;
import org.apache.olingo.server.api.processor.DefaultProcessor; import org.apache.olingo.server.api.processor.DefaultProcessor;
import org.apache.olingo.server.api.processor.EntitySetProcessor; import org.apache.olingo.server.api.processor.EntitySetProcessor;
import org.apache.olingo.server.api.processor.EntityProcessor; import org.apache.olingo.server.api.processor.EntityProcessor;
@ -52,6 +54,7 @@ import org.apache.olingo.server.api.uri.UriResourceKind;
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.UriResourceProperty; import org.apache.olingo.server.api.uri.UriResourceProperty;
import org.apache.olingo.server.core.batch.handler.BatchHandler;
import org.apache.olingo.server.core.uri.parser.Parser; import org.apache.olingo.server.core.uri.parser.Parser;
import org.apache.olingo.server.core.uri.parser.UriParserException; import org.apache.olingo.server.core.uri.parser.UriParserException;
import org.apache.olingo.server.core.uri.parser.UriParserSemanticException; import org.apache.olingo.server.core.uri.parser.UriParserSemanticException;
@ -115,7 +118,7 @@ public class ODataHandler {
private void processInternal(final ODataRequest request, final ODataResponse response) private void processInternal(final ODataRequest request, final ODataResponse response)
throws ODataHandlerException, UriParserException, UriValidationException, ContentNegotiatorException, throws ODataHandlerException, UriParserException, UriValidationException, ContentNegotiatorException,
ODataApplicationException, SerializerException { ODataApplicationException, SerializerException, BatchException {
validateODataVersion(request, response); validateODataVersion(request, response);
uriInfo = new Parser().parseUri(request.getRawODataPath(), request.getRawQueryPath(), null, uriInfo = new Parser().parseUri(request.getRawODataPath(), request.getRawQueryPath(), null,
@ -157,6 +160,13 @@ public class ODataHandler {
break; break;
case resource: case resource:
handleResourceDispatching(request, response); handleResourceDispatching(request, response);
break;
case batch:
BatchProcessor bp = selectProcessor(BatchProcessor.class);
final BatchHandler handler = new BatchHandler(this, request, bp, true);
handler.process(response);
break; break;
default: default:
throw new ODataHandlerException("not implemented", throw new ODataHandlerException("not implemented",

View File

@ -0,0 +1,145 @@
/*
* Licensed to the Apache Software Foundation (ASF) under one
* or more contributor license agreements. See the NOTICE file
* distributed with this work for additional information
* regarding copyright ownership. The ASF licenses this file
* to you 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.apache.olingo.server.core.batch.handler;
import java.util.ArrayList;
import java.util.HashMap;
import java.util.HashSet;
import java.util.List;
import java.util.Map;
import java.util.Set;
import java.util.regex.Matcher;
import java.util.regex.Pattern;
import org.apache.olingo.server.api.ODataRequest;
import org.apache.olingo.server.api.batch.BatchException;
import org.apache.olingo.server.api.batch.BatchException.MessageKeys;
import org.apache.olingo.server.core.batch.parser.BatchParserCommon;
public class BatchChangeSetSorter {
private static final String REG_EX_REFERENCE = "\\$(.*)(/.*)?";
final List<ODataRequest> orderdList = new ArrayList<ODataRequest>();
private static Pattern referencePattern = Pattern.compile(REG_EX_REFERENCE);
private Set<String> knownContentId = new HashSet<String>();
private Map<String, List<ODataRequest>> requestContentIdMapping = new HashMap<String, List<ODataRequest>>();
public BatchChangeSetSorter(List<ODataRequest> requests) throws BatchException {
sort(requests);
}
public List<ODataRequest> getOrderdRequests() {
return orderdList;
}
private List<ODataRequest> sort(final List<ODataRequest> requests) throws BatchException {
extractUrlContentId(requests);
orderdList.addAll(getRequestsWithoutReferences());
boolean areRequestsProcessed = true;
while (requestsToProcessAvailable() && areRequestsProcessed) {
areRequestsProcessed = processRemainingRequests(orderdList);
}
if (requestsToProcessAvailable()) {
throw new BatchException("Invalid content id", MessageKeys.INVALID_CONTENT_ID, 0);
}
return orderdList;
}
private boolean requestsToProcessAvailable() {
return requestContentIdMapping.keySet().size() != 0;
}
private boolean processRemainingRequests(List<ODataRequest> orderdList) {
final List<ODataRequest> addedRequests = getRemainingRequestsWithKownContentId();
addRequestsToKnownContentIds(addedRequests);
orderdList.addAll(addedRequests);
return addedRequests.size() != 0;
}
private List<ODataRequest> getRemainingRequestsWithKownContentId() {
List<ODataRequest> result = new ArrayList<ODataRequest>();
for (String contextId : knownContentId) {
List<ODataRequest> processedRequests = requestContentIdMapping.get(contextId);
if (processedRequests != null && processedRequests.size() != 0) {
result.addAll(processedRequests);
requestContentIdMapping.remove(contextId);
}
}
return result;
}
private List<ODataRequest> getRequestsWithoutReferences() {
final List<ODataRequest> requestsWithoutReference = requestContentIdMapping.get(null);
requestContentIdMapping.remove(null);
addRequestsToKnownContentIds(requestsWithoutReference);
return requestsWithoutReference;
}
private void addRequestsToKnownContentIds(List<ODataRequest> requestsWithoutReference) {
for (ODataRequest request : requestsWithoutReference) {
final String contentId = getContentIdFromHeader(request);
if (contentId != null) {
knownContentId.add(contentId);
}
}
}
private String getContentIdFromHeader(ODataRequest request) {
return request.getHeader(BatchParserCommon.HTTP_CONTENT_ID);
}
private void extractUrlContentId(List<ODataRequest> requests) {
for (ODataRequest request : requests) {
final String reference = getReferenceInURI(request);
addRequestToMapping(reference, request);
}
}
private void addRequestToMapping(final String reference, final ODataRequest request) {
List<ODataRequest> requestList = requestContentIdMapping.get(reference);
requestList = (requestList == null) ? new ArrayList<ODataRequest>() : requestList;
requestList.add(request);
requestContentIdMapping.put(reference, requestList);
}
public static String getReferenceInURI(ODataRequest request) {
Matcher matcher = referencePattern.matcher(removeFollingPathSegments(request.getRawODataPath()));
return (matcher.matches()) ? matcher.group(1) : null;
}
private static String removeFollingPathSegments(String rawODataPath) {
final int indexOfSlash = rawODataPath.indexOf("/");
return (indexOfSlash != -1) ? rawODataPath.substring(0, indexOfSlash) : rawODataPath;
}
public static void replaceContentIdReference(ODataRequest request, String contentId, String resourceUri) {
final String newUri = request.getRawODataPath().replace("$" + contentId, resourceUri);
request.setRawODataPath(newUri);
request.setRawRequestUri(request.getRawBaseUri() + "/" + newUri);
}
}

View File

@ -0,0 +1,68 @@
/*
* Licensed to the Apache Software Foundation (ASF) under one
* or more contributor license agreements. See the NOTICE file
* distributed with this work for additional information
* regarding copyright ownership. The ASF licenses this file
* to you 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.apache.olingo.server.core.batch.handler;
import org.apache.olingo.commons.api.http.HttpHeader;
import org.apache.olingo.commons.api.http.HttpMethod;
import org.apache.olingo.server.api.ODataRequest;
import org.apache.olingo.server.api.ODataResponse;
import org.apache.olingo.server.api.batch.BatchException;
import org.apache.olingo.server.api.batch.BatchOperation;
import org.apache.olingo.server.api.batch.BatchException.MessageKeys;
import org.apache.olingo.server.api.processor.BatchProcessor;
import org.apache.olingo.server.core.ODataHandler;
import org.apache.olingo.server.core.batch.parser.BatchParserCommon;
public class BatchHandler {
private final BatchOperation operation;
private final BatchProcessor batchProcessor;
private ODataRequest request;
public BatchHandler(final ODataHandler oDataHandler, final ODataRequest request, final BatchProcessor batchProcessor,
final boolean isStrict) {
this.request = request;
this.batchProcessor = batchProcessor;
operation = new BatchOperationImpl(oDataHandler, request, batchProcessor, isStrict);
}
public void process(ODataResponse response) throws BatchException {
validateRequest();
batchProcessor.executeBatch(operation, request, response);
}
private void validateRequest() throws BatchException {
validateHttpMethod();
validateContentType();
}
private void validateContentType() throws BatchException {
final String contentType = request.getHeader(HttpHeader.CONTENT_TYPE);
if(contentType == null || !BatchParserCommon.PATTERN_MULTIPART_BOUNDARY.matcher(contentType).matches()) {
throw new BatchException("Invalid content type", MessageKeys.INVALID_CONTENT_TYPE, 0);
}
}
private void validateHttpMethod() throws BatchException {
if(request.getMethod() != HttpMethod.POST) {
throw new BatchException("Invalid HTTP method", MessageKeys.INVALID_METHOD, 0);
}
}
}

View File

@ -0,0 +1,74 @@
/*
* Licensed to the Apache Software Foundation (ASF) under one
* or more contributor license agreements. See the NOTICE file
* distributed with this work for additional information
* regarding copyright ownership. The ASF licenses this file
* to you 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.apache.olingo.server.core.batch.handler;
import java.io.IOException;
import java.io.InputStream;
import java.util.List;
import org.apache.olingo.commons.api.http.HttpHeader;
import org.apache.olingo.server.api.ODataRequest;
import org.apache.olingo.server.api.ODataResponse;
import org.apache.olingo.server.api.batch.BatchException;
import org.apache.olingo.server.api.batch.BatchOperation;
import org.apache.olingo.server.api.batch.BatchRequestPart;
import org.apache.olingo.server.api.batch.ODataResponsePart;
import org.apache.olingo.server.api.processor.BatchProcessor;
import org.apache.olingo.server.core.ODataHandler;
import org.apache.olingo.server.core.batch.parser.BatchParser;
import org.apache.olingo.server.core.batch.writer.BatchResponseWriter;
public class BatchOperationImpl implements BatchOperation {
private final BatchPartHandler partHandler;
private final BatchResponseWriter writer;
private final BatchParser parser;
public BatchOperationImpl(ODataHandler oDataHandler, ODataRequest request, BatchProcessor batchProcessor,
final boolean isStrict) {
partHandler = new BatchPartHandler(oDataHandler, batchProcessor, this);
writer = new BatchResponseWriter();
parser = new BatchParser(getContentType(request), request.getRawBaseUri(),
request.getRawServiceResolutionUri(), isStrict);
}
@Override
public List<BatchRequestPart> parseBatchRequest(InputStream in) throws BatchException {
return parser.parseBatchRequest(in);
}
@Override
public ODataResponse handleODataRequest(ODataRequest request) {
return partHandler.handleODataRequest(request);
}
@Override
public ODataResponsePart handleBatchRequest(BatchRequestPart request) {
return partHandler.handleBatchRequest(request);
}
@Override
public void writeResponseParts(List<ODataResponsePart> batchResponses, ODataResponse response) throws BatchException,
IOException {
writer.toODataResponse(batchResponses, response);
}
private String getContentType(ODataRequest request) {
return request.getHeader(HttpHeader.CONTENT_TYPE);
}
}

View File

@ -0,0 +1,66 @@
/*
* Licensed to the Apache Software Foundation (ASF) under one
* or more contributor license agreements. See the NOTICE file
* distributed with this work for additional information
* regarding copyright ownership. The ASF licenses this file
* to you 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.apache.olingo.server.core.batch.handler;
import java.util.ArrayList;
import java.util.List;
import org.apache.olingo.commons.api.http.HttpHeader;
import org.apache.olingo.server.api.ODataRequest;
import org.apache.olingo.server.api.ODataResponse;
import org.apache.olingo.server.api.batch.BatchOperation;
import org.apache.olingo.server.api.batch.BatchRequestPart;
import org.apache.olingo.server.api.batch.ODataResponsePart;
import org.apache.olingo.server.api.processor.BatchProcessor;
import org.apache.olingo.server.core.ODataHandler;
import org.apache.olingo.server.core.batch.parser.BatchParserCommon;
public class BatchPartHandler {
private ODataHandler oDataHandler;
private BatchProcessor batchProcessor;
private BatchOperation batchOperation;
public BatchPartHandler(final ODataHandler oDataHandler, final BatchProcessor processor,
final BatchOperation batchOperation) {
this.oDataHandler = oDataHandler;
this.batchProcessor = processor;
this.batchOperation = batchOperation;
}
public ODataResponse handleODataRequest(ODataRequest request) {
final ODataResponse response = oDataHandler.process(request);
response.setHeader(BatchParserCommon.HTTP_CONTENT_ID, request.getHeader(BatchParserCommon.HTTP_CONTENT_ID));
return response;
}
public ODataResponsePart handleBatchRequest(BatchRequestPart request) {
final List<ODataResponse> responses = new ArrayList<ODataResponse>();
if (request.isChangeSet()) {
responses.addAll(batchProcessor.executeChangeSet(batchOperation, request.getRequests()));
return new ODataResponsePartImpl(responses, true);
} else {
responses.add(handleODataRequest(request.getRequests().get(0)));
return new ODataResponsePartImpl(responses, false);
}
}
}

View File

@ -0,0 +1,44 @@
/*
* Licensed to the Apache Software Foundation (ASF) under one
* or more contributor license agreements. See the NOTICE file
* distributed with this work for additional information
* regarding copyright ownership. The ASF licenses this file
* to you 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.apache.olingo.server.core.batch.handler;
import java.util.List;
import org.apache.olingo.server.api.ODataResponse;
import org.apache.olingo.server.api.batch.ODataResponsePart;
public class ODataResponsePartImpl implements ODataResponsePart {
private List<ODataResponse> responses;
private boolean isChangeSet;
public ODataResponsePartImpl(List<ODataResponse> responses, boolean isChangeSet) {
this.responses = responses;
this.isChangeSet = isChangeSet;
}
@Override
public List<ODataResponse> getResponses() {
return responses;
}
@Override
public boolean isChangeSet() {
return isChangeSet;
}
}

View File

@ -22,7 +22,7 @@ import java.util.LinkedList;
import java.util.List; import java.util.List;
import org.apache.olingo.commons.api.http.HttpHeader; import org.apache.olingo.commons.api.http.HttpHeader;
import org.apache.olingo.server.core.batch.BatchException; import org.apache.olingo.server.api.batch.BatchException;
import org.apache.olingo.server.core.batch.parser.BufferedReaderIncludingLineEndings.Line; import org.apache.olingo.server.core.batch.parser.BufferedReaderIncludingLineEndings.Line;
public class BatchBodyPart implements BatchPart { public class BatchBodyPart implements BatchPart {

View File

@ -20,7 +20,7 @@ package org.apache.olingo.server.core.batch.parser;
import java.util.List; import java.util.List;
import org.apache.olingo.server.core.batch.BatchException; import org.apache.olingo.server.api.batch.BatchException;
import org.apache.olingo.server.core.batch.parser.BufferedReaderIncludingLineEndings.Line; import org.apache.olingo.server.core.batch.parser.BufferedReaderIncludingLineEndings.Line;
public class BatchChangeSetPart extends BatchQueryOperation { public class BatchChangeSetPart extends BatchQueryOperation {

View File

@ -25,9 +25,9 @@ import java.util.LinkedList;
import java.util.List; import java.util.List;
import org.apache.olingo.commons.api.ODataRuntimeException; import org.apache.olingo.commons.api.ODataRuntimeException;
import org.apache.olingo.server.api.batch.BatchException;
import org.apache.olingo.server.api.batch.BatchParserResult; import org.apache.olingo.server.api.batch.BatchParserResult;
import org.apache.olingo.server.api.batch.BatchRequestPart; import org.apache.olingo.server.api.batch.BatchRequestPart;
import org.apache.olingo.server.core.batch.BatchException;
import org.apache.olingo.server.core.batch.parser.BufferedReaderIncludingLineEndings.Line; import org.apache.olingo.server.core.batch.parser.BufferedReaderIncludingLineEndings.Line;
import org.apache.olingo.server.core.batch.transformator.BatchRequestTransformator; import org.apache.olingo.server.core.batch.transformator.BatchRequestTransformator;

View File

@ -29,7 +29,7 @@ import java.util.regex.Matcher;
import java.util.regex.Pattern; import java.util.regex.Pattern;
import org.apache.olingo.commons.api.http.HttpContentType; import org.apache.olingo.commons.api.http.HttpContentType;
import org.apache.olingo.server.core.batch.BatchException; import org.apache.olingo.server.api.batch.BatchException;
import org.apache.olingo.server.core.batch.parser.BufferedReaderIncludingLineEndings.Line; import org.apache.olingo.server.core.batch.parser.BufferedReaderIncludingLineEndings.Line;
public class BatchParserCommon { public class BatchParserCommon {
@ -186,7 +186,8 @@ public class BatchParserCommon {
} }
public static void consumeBlankLine(final List<Line> remainingMessage, final boolean isStrict) throws BatchException { public static void consumeBlankLine(final List<Line> remainingMessage, final boolean isStrict) throws BatchException {
if (remainingMessage.size() > 0 && remainingMessage.get(0).toString().matches("\\s*\r\n\\s*")) { //TODO is \r\n to strict?
if (remainingMessage.size() > 0 && remainingMessage.get(0).toString().matches("\\s*(\r\n|\n)\\s*")) {
remainingMessage.remove(0); remainingMessage.remove(0);
} else { } else {
if (isStrict) { if (isStrict) {

View File

@ -20,7 +20,7 @@ package org.apache.olingo.server.core.batch.parser;
import java.util.List; import java.util.List;
import org.apache.olingo.server.core.batch.BatchException; import org.apache.olingo.server.api.batch.BatchException;
import org.apache.olingo.server.core.batch.parser.BufferedReaderIncludingLineEndings.Line; import org.apache.olingo.server.core.batch.parser.BufferedReaderIncludingLineEndings.Line;
public class BatchQueryOperation implements BatchPart { public class BatchQueryOperation implements BatchPart {

View File

@ -27,9 +27,9 @@ import java.util.List;
import org.apache.olingo.commons.api.http.HttpHeader; import org.apache.olingo.commons.api.http.HttpHeader;
import org.apache.olingo.commons.api.http.HttpMethod; import org.apache.olingo.commons.api.http.HttpMethod;
import org.apache.olingo.server.api.ODataRequest; import org.apache.olingo.server.api.ODataRequest;
import org.apache.olingo.server.api.batch.BatchException;
import org.apache.olingo.server.api.batch.BatchParserResult; import org.apache.olingo.server.api.batch.BatchParserResult;
import org.apache.olingo.server.core.batch.BatchException; import org.apache.olingo.server.api.batch.BatchException.MessageKeys;
import org.apache.olingo.server.core.batch.BatchException.MessageKeys;
import org.apache.olingo.server.core.batch.parser.BatchBodyPart; import org.apache.olingo.server.core.batch.parser.BatchBodyPart;
import org.apache.olingo.server.core.batch.parser.BatchChangeSetPart; import org.apache.olingo.server.core.batch.parser.BatchChangeSetPart;
import org.apache.olingo.server.core.batch.parser.BatchParserCommon; import org.apache.olingo.server.core.batch.parser.BatchParserCommon;
@ -84,7 +84,7 @@ public class BatchRequestTransformator implements BatchTransformator {
final HeaderField contentIdRequest = getContentId(request); final HeaderField contentIdRequest = getContentId(request);
if (contentIdChangeRequestPart == null && contentIdRequest == null) { if (contentIdChangeRequestPart == null && contentIdRequest == null) {
throw new BatchException("Missing content type", MessageKeys.MISSING_CONTENT_ID, changeRequestPart.getHeaders() throw new BatchException("Missing content id", MessageKeys.MISSING_CONTENT_ID, changeRequestPart.getHeaders()
.getLineNumber()); .getLineNumber());
} else if (contentIdChangeRequestPart != null) { } else if (contentIdChangeRequestPart != null) {
request.getHeaders().replaceHeaderField(contentIdChangeRequestPart); request.getHeaders().replaceHeaderField(contentIdChangeRequestPart);

View File

@ -20,8 +20,8 @@ package org.apache.olingo.server.core.batch.transformator;
import java.util.List; import java.util.List;
import org.apache.olingo.server.api.batch.BatchException;
import org.apache.olingo.server.api.batch.BatchParserResult; import org.apache.olingo.server.api.batch.BatchParserResult;
import org.apache.olingo.server.core.batch.BatchException;
import org.apache.olingo.server.core.batch.parser.BatchBodyPart; import org.apache.olingo.server.core.batch.parser.BatchBodyPart;
public interface BatchTransformator { public interface BatchTransformator {

View File

@ -28,8 +28,8 @@ import java.util.regex.Pattern;
import org.apache.olingo.commons.api.http.HttpContentType; import org.apache.olingo.commons.api.http.HttpContentType;
import org.apache.olingo.commons.api.http.HttpHeader; import org.apache.olingo.commons.api.http.HttpHeader;
import org.apache.olingo.commons.api.http.HttpMethod; import org.apache.olingo.commons.api.http.HttpMethod;
import org.apache.olingo.server.core.batch.BatchException; import org.apache.olingo.server.api.batch.BatchException;
import org.apache.olingo.server.core.batch.BatchException.MessageKeys; import org.apache.olingo.server.api.batch.BatchException.MessageKeys;
import org.apache.olingo.server.core.batch.parser.BatchParserCommon; import org.apache.olingo.server.core.batch.parser.BatchParserCommon;
import org.apache.olingo.server.core.batch.parser.BufferedReaderIncludingLineEndings.Line; import org.apache.olingo.server.core.batch.parser.BufferedReaderIncludingLineEndings.Line;
import org.apache.olingo.server.core.batch.parser.Header; import org.apache.olingo.server.core.batch.parser.Header;

View File

@ -31,9 +31,9 @@ import org.apache.olingo.commons.api.http.HttpContentType;
import org.apache.olingo.commons.api.http.HttpHeader; import org.apache.olingo.commons.api.http.HttpHeader;
import org.apache.olingo.commons.api.http.HttpStatusCode; import org.apache.olingo.commons.api.http.HttpStatusCode;
import org.apache.olingo.server.api.ODataResponse; import org.apache.olingo.server.api.ODataResponse;
import org.apache.olingo.server.api.batch.BatchException;
import org.apache.olingo.server.api.batch.ODataResponsePart; import org.apache.olingo.server.api.batch.ODataResponsePart;
import org.apache.olingo.server.core.batch.BatchException; import org.apache.olingo.server.api.batch.BatchException.MessageKeys;
import org.apache.olingo.server.core.batch.BatchException.MessageKeys;
import org.apache.olingo.server.core.batch.parser.BatchParserCommon; import org.apache.olingo.server.core.batch.parser.BatchParserCommon;
import org.apache.olingo.server.core.serializer.utils.CircleStreamBuffer; import org.apache.olingo.server.core.serializer.utils.CircleStreamBuffer;

View File

@ -33,8 +33,9 @@ import java.util.List;
import org.apache.olingo.commons.api.http.HttpHeader; import org.apache.olingo.commons.api.http.HttpHeader;
import org.apache.olingo.commons.api.http.HttpMethod; import org.apache.olingo.commons.api.http.HttpMethod;
import org.apache.olingo.server.api.ODataRequest; import org.apache.olingo.server.api.ODataRequest;
import org.apache.olingo.server.api.batch.BatchException;
import org.apache.olingo.server.api.batch.BatchRequestPart; import org.apache.olingo.server.api.batch.BatchRequestPart;
import org.apache.olingo.server.core.batch.BatchException.MessageKeys; import org.apache.olingo.server.api.batch.BatchException.MessageKeys;
import org.apache.olingo.server.core.batch.parser.BatchParser; import org.apache.olingo.server.core.batch.parser.BatchParser;
import org.apache.olingo.server.core.batch.parser.BatchParserCommon; import org.apache.olingo.server.core.batch.parser.BatchParserCommon;
import org.junit.Test; import org.junit.Test;

View File

@ -24,7 +24,7 @@ import java.util.ArrayList;
import java.util.List; import java.util.List;
import org.apache.olingo.commons.api.http.HttpHeader; import org.apache.olingo.commons.api.http.HttpHeader;
import org.apache.olingo.server.core.batch.BatchException; import org.apache.olingo.server.api.batch.BatchException;
import org.apache.olingo.server.core.batch.parser.BatchParserCommon; import org.apache.olingo.server.core.batch.parser.BatchParserCommon;
import org.apache.olingo.server.core.batch.parser.BufferedReaderIncludingLineEndings.Line; import org.apache.olingo.server.core.batch.parser.BufferedReaderIncludingLineEndings.Line;
import org.apache.olingo.server.core.batch.parser.Header; import org.apache.olingo.server.core.batch.parser.Header;

View File

@ -30,8 +30,8 @@ import java.util.List;
import org.apache.olingo.commons.api.http.HttpHeader; import org.apache.olingo.commons.api.http.HttpHeader;
import org.apache.olingo.commons.api.http.HttpStatusCode; import org.apache.olingo.commons.api.http.HttpStatusCode;
import org.apache.olingo.server.api.ODataResponse; import org.apache.olingo.server.api.ODataResponse;
import org.apache.olingo.server.api.batch.BatchException;
import org.apache.olingo.server.api.batch.ODataResponsePart; import org.apache.olingo.server.api.batch.ODataResponsePart;
import org.apache.olingo.server.core.batch.BatchException;
import org.apache.olingo.server.core.batch.StringUtil; import org.apache.olingo.server.core.batch.StringUtil;
import org.apache.olingo.server.core.batch.parser.BatchParserCommon; import org.apache.olingo.server.core.batch.parser.BatchParserCommon;
import org.apache.olingo.server.core.batch.parser.BufferedReaderIncludingLineEndings; import org.apache.olingo.server.core.batch.parser.BufferedReaderIncludingLineEndings;

View File

@ -19,11 +19,14 @@
package org.apache.olingo.server.tecsvc.processor; package org.apache.olingo.server.tecsvc.processor;
import java.io.ByteArrayInputStream; import java.io.ByteArrayInputStream;
import java.io.IOException;
import java.io.UnsupportedEncodingException; import java.io.UnsupportedEncodingException;
import java.util.ArrayList;
import java.util.LinkedList; import java.util.LinkedList;
import java.util.List; import java.util.List;
import java.util.Locale; import java.util.Locale;
import org.apache.olingo.commons.api.ODataRuntimeException;
import org.apache.olingo.commons.api.data.ContextURL; import org.apache.olingo.commons.api.data.ContextURL;
import org.apache.olingo.commons.api.data.ContextURL.Suffix; import org.apache.olingo.commons.api.data.ContextURL.Suffix;
import org.apache.olingo.commons.api.data.Entity; import org.apache.olingo.commons.api.data.Entity;
@ -46,6 +49,11 @@ import org.apache.olingo.server.api.ODataApplicationException;
import org.apache.olingo.server.api.ODataRequest; import org.apache.olingo.server.api.ODataRequest;
import org.apache.olingo.server.api.ODataResponse; import org.apache.olingo.server.api.ODataResponse;
import org.apache.olingo.server.api.ServiceMetadata; import org.apache.olingo.server.api.ServiceMetadata;
import org.apache.olingo.server.api.batch.BatchException;
import org.apache.olingo.server.api.batch.BatchOperation;
import org.apache.olingo.server.api.batch.BatchRequestPart;
import org.apache.olingo.server.api.batch.ODataResponsePart;
import org.apache.olingo.server.api.processor.BatchProcessor;
import org.apache.olingo.server.api.processor.EntityProcessor; import org.apache.olingo.server.api.processor.EntityProcessor;
import org.apache.olingo.server.api.processor.EntitySetProcessor; import org.apache.olingo.server.api.processor.EntitySetProcessor;
import org.apache.olingo.server.api.processor.PropertyProcessor; import org.apache.olingo.server.api.processor.PropertyProcessor;
@ -66,7 +74,7 @@ import org.apache.olingo.server.tecsvc.data.DataProvider;
/** /**
* Technical Processor which provides currently implemented processor functionality. * Technical Processor which provides currently implemented processor functionality.
*/ */
public class TechnicalProcessor implements EntitySetProcessor, EntityProcessor, PropertyProcessor { public class TechnicalProcessor implements EntitySetProcessor, EntityProcessor, PropertyProcessor, BatchProcessor {
private OData odata; private OData odata;
private DataProvider dataProvider; private DataProvider dataProvider;
@ -326,4 +334,33 @@ public class TechnicalProcessor implements EntitySetProcessor, EntityProcessor,
} }
} }
} }
@Override
public void executeBatch(BatchOperation operation, ODataRequest requst, ODataResponse response) {
try {
final List<BatchRequestPart> parts = operation.parseBatchRequest(requst.getBody());
final List<ODataResponsePart> responseParts = new ArrayList<ODataResponsePart>();
for(BatchRequestPart part : parts) {
responseParts.add(operation.handleBatchRequest(part));
}
operation.writeResponseParts(responseParts, response);
} catch (BatchException e) {
throw new ODataRuntimeException(e);
} catch (IOException e) {
throw new ODataRuntimeException(e);
}
}
@Override
public List<ODataResponse> executeChangeSet(BatchOperation operation, List<ODataRequest> requests) {
List<ODataResponse> responses = new ArrayList<ODataResponse>();
for(ODataRequest request : requests) {
responses.add(operation.handleODataRequest(request));
}
return responses;
}
} }