[OLINGO-1159] Enhancements to Bound Actions in V4
This commit is contained in:
parent
38f77daa5c
commit
d4f1b73875
|
@ -0,0 +1,273 @@
|
|||
/*
|
||||
* 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.fit.tecsvc.http;
|
||||
|
||||
import static org.junit.Assert.assertEquals;
|
||||
import static org.junit.Assert.assertNotNull;
|
||||
import static org.junit.Assert.assertTrue;
|
||||
|
||||
import java.io.OutputStreamWriter;
|
||||
import java.net.HttpURLConnection;
|
||||
import java.net.URL;
|
||||
import java.util.HashMap;
|
||||
import java.util.Iterator;
|
||||
import java.util.Map;
|
||||
|
||||
import org.apache.commons.io.IOUtils;
|
||||
import org.apache.olingo.client.api.ODataClient;
|
||||
import org.apache.olingo.client.api.communication.request.invoke.ODataInvokeRequest;
|
||||
import org.apache.olingo.client.api.domain.ClientCollectionValue;
|
||||
import org.apache.olingo.client.api.domain.ClientComplexValue;
|
||||
import org.apache.olingo.client.api.domain.ClientEntity;
|
||||
import org.apache.olingo.client.api.domain.ClientPrimitiveValue;
|
||||
import org.apache.olingo.client.api.domain.ClientProperty;
|
||||
import org.apache.olingo.client.api.domain.ClientValue;
|
||||
import org.apache.olingo.client.api.uri.URIBuilder;
|
||||
import org.apache.olingo.client.core.ODataClientFactory;
|
||||
import org.apache.olingo.commons.api.format.ContentType;
|
||||
import org.apache.olingo.commons.api.http.HttpHeader;
|
||||
import org.apache.olingo.commons.api.http.HttpMethod;
|
||||
import org.apache.olingo.commons.api.http.HttpStatusCode;
|
||||
import org.junit.Test;
|
||||
|
||||
public class BasicBoundActionsITCase {
|
||||
|
||||
private static final String SERVICE_URI = "http://localhost:8083/odata-server-tecsvc/odata.svc/";
|
||||
protected static final ODataClient client = ODataClientFactory.getClient();
|
||||
|
||||
@Test
|
||||
public void boundActionReturningBaseType() throws Exception {
|
||||
URL url = new URL(SERVICE_URI + "ESTwoBaseTwoKeyNav(PropertyInt16=1,PropertyString='1')/"
|
||||
+ "olingo.odata.test1.BAETTwoBaseTwoKeyNavRTETBaseTwoKeyNav");
|
||||
|
||||
HttpURLConnection connection = (HttpURLConnection) url.openConnection();
|
||||
connection.setRequestMethod(HttpMethod.POST.name());
|
||||
connection.setRequestProperty(HttpHeader.ACCEPT, "application/json");
|
||||
connection.setRequestProperty(HttpHeader.CONTENT_TYPE, "application/json");
|
||||
connection.connect();
|
||||
|
||||
assertEquals(HttpStatusCode.CREATED.getStatusCode(), connection.getResponseCode());
|
||||
|
||||
final String content = IOUtils.toString(connection.getInputStream());
|
||||
final String expected = "\"PropertyInt16\":1,\"PropertyString\":\"1\","
|
||||
+ "\"PropertyComp\":{\"PropertyInt16\":11,"
|
||||
+ "\"PropertyComp\":{\"PropertyString\":\"StringValue\","
|
||||
+ "\"PropertyBinary\":\"ASNFZ4mrze8=\",\"PropertyBoolean\":true,"
|
||||
+ "\"PropertyByte\":255,\"PropertyDate\":\"2012-12-03\","
|
||||
+ "\"PropertyDateTimeOffset\":null,\"PropertyDecimal\":34,"
|
||||
+ "\"PropertySingle\":1.79E20,\"PropertyDouble\":-1.79E20,"
|
||||
+ "\"PropertyDuration\":\"PT6S\",\"PropertyGuid\":\"01234567-89ab-cdef-0123-456789abcdef\","
|
||||
+ "\"PropertyInt16\":32767,\"PropertyInt32\":2147483647,\"PropertyInt64\":9223372036854775807,"
|
||||
+ "\"PropertySByte\":127,\"PropertyTimeOfDay\":\"21:05:59\"}},"
|
||||
+ "\"PropertyCompNav\":{\"PropertyInt16\":1,\"PropertyComp\":"
|
||||
+ "{\"PropertyString\":\"First Resource - positive values\","
|
||||
+ "\"PropertyBinary\":\"ASNFZ4mrze8=\",\"PropertyBoolean\":true,"
|
||||
+ "\"PropertyByte\":255,\"PropertyDate\":\"2012-12-03\","
|
||||
+ "\"PropertyDateTimeOffset\":\"2012-12-03T07:16:23Z\","
|
||||
+ "\"PropertyDecimal\":34,\"PropertySingle\":1.79E20,"
|
||||
+ "\"PropertyDouble\":-1.79E20,\"PropertyDuration\":\"PT6S\","
|
||||
+ "\"PropertyGuid\":\"01234567-89ab-cdef-0123-456789abcdef\","
|
||||
+ "\"PropertyInt16\":32767,\"PropertyInt32\":2147483647,"
|
||||
+ "\"PropertyInt64\":9223372036854775807,\"PropertySByte\":127,"
|
||||
+ "\"PropertyTimeOfDay\":\"21:05:59\"}},\"CollPropertyComp\":[],"
|
||||
+ "\"CollPropertyCompNav\":[{\"PropertyInt16\":1}],"
|
||||
+ "\"CollPropertyString\":[\"1\",\"2\"],\"PropertyCompTwoPrim\":"
|
||||
+ "{\"PropertyInt16\":11,\"PropertyString\":\"11\"},\"PropertyDate\":\"2013-12-12\"}";
|
||||
assertTrue(content.contains(expected));
|
||||
}
|
||||
|
||||
@Test
|
||||
public void boundActionReturningEntityWithNavigationSegInAction() throws Exception {
|
||||
URL url = new URL(SERVICE_URI + "ESTwoKeyNav(PropertyInt16=1,PropertyString='1')/"
|
||||
+ "NavPropertyETTwoKeyNavOne/olingo.odata.test1.BAETTwoKeyNavRTETTwoKeyNavParam");
|
||||
|
||||
HttpURLConnection connection = (HttpURLConnection) url.openConnection();
|
||||
connection.setRequestMethod(HttpMethod.POST.name());
|
||||
connection.setRequestProperty(HttpHeader.ACCEPT, "application/json");
|
||||
connection.setRequestProperty(HttpHeader.CONTENT_TYPE, "application/json");
|
||||
connection.setDoOutput(true);
|
||||
final OutputStreamWriter writer = new OutputStreamWriter(connection.getOutputStream());
|
||||
writer.append("{\"PropertyComp\" : {\"PropertyInt16\" : 30}}");
|
||||
writer.close();
|
||||
connection.connect();
|
||||
|
||||
assertEquals(HttpStatusCode.OK.getStatusCode(), connection.getResponseCode());
|
||||
|
||||
final String content = IOUtils.toString(connection.getInputStream());
|
||||
final String expected = "\"PropertyInt16\":1,\"PropertyString\":\"1\","
|
||||
+ "\"PropertyComp\":{\"PropertyInt16\":30,\"PropertyComp\":"
|
||||
+ "{\"PropertyString\":\"StringValue\",\"PropertyBinary\":\"ASNFZ4mrze8=\","
|
||||
+ "\"PropertyBoolean\":true,\"PropertyByte\":255,\"PropertyDate\":\"2012-12-03\","
|
||||
+ "\"PropertyDateTimeOffset\":null,\"PropertyDecimal\":34,\"PropertySingle\":1.79E20,"
|
||||
+ "\"PropertyDouble\":-1.79E20,\"PropertyDuration\":\"PT6S\","
|
||||
+ "\"PropertyGuid\":\"01234567-89ab-cdef-0123-456789abcdef\",\"PropertyInt16\":32767,"
|
||||
+ "\"PropertyInt32\":2147483647,\"PropertyInt64\":9223372036854775807,"
|
||||
+ "\"PropertySByte\":127,\"PropertyTimeOfDay\":\"21:05:59\"}},"
|
||||
+ "\"PropertyCompNav\":{\"PropertyInt16\":1,\"PropertyComp\":"
|
||||
+ "{\"PropertyString\":\"First Resource - positive values\","
|
||||
+ "\"PropertyBinary\":\"ASNFZ4mrze8=\",\"PropertyBoolean\":true,"
|
||||
+ "\"PropertyByte\":255,\"PropertyDate\":\"2012-12-03\","
|
||||
+ "\"PropertyDateTimeOffset\":\"2012-12-03T07:16:23Z\","
|
||||
+ "\"PropertyDecimal\":34,\"PropertySingle\":1.79E20,\"PropertyDouble\":-1.79E20,"
|
||||
+ "\"PropertyDuration\":\"PT6S\",\"PropertyGuid\":"
|
||||
+ "\"01234567-89ab-cdef-0123-456789abcdef\",\"PropertyInt16\":32767,"
|
||||
+ "\"PropertyInt32\":2147483647,\"PropertyInt64\":9223372036854775807,"
|
||||
+ "\"PropertySByte\":127,\"PropertyTimeOfDay\":\"21:05:59\"}},\"CollPropertyComp\":[],"
|
||||
+ "\"CollPropertyCompNav\":[{\"PropertyInt16\":1}],\"CollPropertyString\":[\"1\",\"2\"],"
|
||||
+ "\"PropertyCompTwoPrim\":{\"PropertyInt16\":11,\"PropertyString\":\"11\"}}";
|
||||
assertTrue(content.contains(expected));
|
||||
}
|
||||
|
||||
@Test
|
||||
public void boundActionReturningDerivedTypeWithTypeCastSegInAction() throws Exception {
|
||||
URIBuilder builder = client.newURIBuilder(SERVICE_URI).appendEntitySetSegment("ESBase").
|
||||
appendKeySegment(111).appendDerivedEntityTypeSegment("olingo.odata.test1.ETTwoBase").
|
||||
appendActionCallSegment("olingo.odata.test1.BAETBaseETTwoBaseRTETTwoBase");
|
||||
Map<String, ClientValue> parameters = new HashMap<String, ClientValue>();
|
||||
final ClientPrimitiveValue propStrValue =
|
||||
client.getObjectFactory().newPrimitiveValueBuilder().buildString("NewStrValue");
|
||||
parameters.put("PropertyString", propStrValue);
|
||||
|
||||
final ClientPrimitiveValue addPropStr1 =
|
||||
client.getObjectFactory().newPrimitiveValueBuilder().buildString("AddStrProp_5");
|
||||
parameters.put("AdditionalPropertyString_5", addPropStr1);
|
||||
|
||||
final ClientPrimitiveValue addPropStr2 =
|
||||
client.getObjectFactory().newPrimitiveValueBuilder().buildString("AddStrProp_6");
|
||||
parameters.put("AdditionalPropertyString_6", addPropStr2);
|
||||
|
||||
final ODataInvokeRequest<ClientEntity> req =
|
||||
client.getInvokeRequestFactory().getActionInvokeRequest(builder.build(), ClientEntity.class, parameters);
|
||||
req.setFormat(ContentType.JSON_FULL_METADATA);
|
||||
req.setContentType(ContentType.APPLICATION_JSON.toContentTypeString() + ";odata.metadata=full");
|
||||
ClientEntity entity = req.execute().getBody();
|
||||
assertNotNull(entity);
|
||||
assertEquals(entity.getProperties().size(), 4);
|
||||
assertEquals(entity.getTypeName().getFullQualifiedNameAsString(), "olingo.odata.test1.ETTwoBase");
|
||||
}
|
||||
|
||||
@Test
|
||||
public void boundActionReturningColComplexTypeWithComplexTypeSegInAction() throws Exception {
|
||||
URIBuilder builder = client.newURIBuilder(SERVICE_URI).appendEntitySetSegment("ESMixPrimCollComp").
|
||||
appendKeySegment(32767).appendPropertySegment("CollPropertyComp").
|
||||
appendActionCallSegment("olingo.odata.test1.BAETMixPrimCollCompCTTWOPrimCompRTCollCTTwoPrim");
|
||||
final ClientComplexValue propertyComp = client.getObjectFactory().
|
||||
newComplexValue("olingo.odata.test1.CTTwoPrim");
|
||||
propertyComp.add(client.getObjectFactory().newPrimitiveProperty("PropertyInt16",
|
||||
client.getObjectFactory().newPrimitiveValueBuilder().buildInt16((short) 111)));
|
||||
propertyComp.add(client.getObjectFactory().newPrimitiveProperty("PropertyString",
|
||||
client.getObjectFactory().newPrimitiveValueBuilder().buildString("ABC")));
|
||||
|
||||
Map<String, ClientValue> parameters = new HashMap<String, ClientValue>();
|
||||
parameters.put("PropertyComp", propertyComp);
|
||||
|
||||
final ODataInvokeRequest<ClientProperty> req =
|
||||
client.getInvokeRequestFactory().getActionInvokeRequest(builder.build(), ClientProperty.class, parameters);
|
||||
req.setFormat(ContentType.JSON_FULL_METADATA);
|
||||
req.setContentType(ContentType.APPLICATION_JSON.toContentTypeString() + ";odata.metadata=full");
|
||||
ClientProperty prop = req.execute().getBody();
|
||||
assertNotNull(prop);
|
||||
assertNotNull(prop.getCollectionValue());
|
||||
assertEquals(prop.getCollectionValue().asCollection().size(), 1);
|
||||
assertEquals(prop.getCollectionValue().getTypeName(), "Collection(olingo.odata.test1.CTTwoPrim)");
|
||||
}
|
||||
|
||||
@Test
|
||||
public void boundActionReturningComplexDerivedTypeWithComplexTypeSegInAction() throws Exception {
|
||||
Map<String, Object> segmentValues = new HashMap<String, Object>();
|
||||
segmentValues.put("PropertyInt16", 1);
|
||||
segmentValues.put("PropertyString", "1");
|
||||
URIBuilder builder = client.newURIBuilder(SERVICE_URI).appendEntitySetSegment("ESTwoKeyNav").
|
||||
appendKeySegment(segmentValues).appendPropertySegment("PropertyCompNav").
|
||||
appendDerivedEntityTypeSegment("olingo.odata.test1.CTTwoBasePrimCompNav").
|
||||
appendActionCallSegment("olingo.odata.test1."
|
||||
+ "BAETTwoKeyNavCTBasePrimCompNavCTTwoBasePrimCompNavRTCTTwoBasePrimCompNav");
|
||||
|
||||
Map<String, ClientValue> parameters = new HashMap<String, ClientValue>();
|
||||
|
||||
final ODataInvokeRequest<ClientEntity> req =
|
||||
client.getInvokeRequestFactory().getActionInvokeRequest(builder.build(), ClientEntity.class, parameters);
|
||||
req.setFormat(ContentType.JSON_FULL_METADATA);
|
||||
req.setContentType(ContentType.APPLICATION_JSON.toContentTypeString() + ";odata.metadata=full");
|
||||
ClientEntity entity = req.execute().getBody();
|
||||
assertNotNull(entity);
|
||||
assertEquals(entity.getProperties().size(), 2);
|
||||
assertEquals(entity.getTypeName().getFullQualifiedNameAsString(),
|
||||
"olingo.odata.test1.CTTwoBasePrimCompNav");
|
||||
}
|
||||
|
||||
@Test
|
||||
public void boundActionReturningCollComplexTypeWithMixedTypes() throws Exception {
|
||||
URIBuilder builder = client.newURIBuilder(SERVICE_URI).appendEntitySetSegment("ESMixPrimCollComp").
|
||||
appendKeySegment(32767).
|
||||
appendActionCallSegment("olingo.odata.test1.BAETMixPrimCollCompRTCTTwoPrim");
|
||||
|
||||
final ClientCollectionValue<ClientValue> colPropertyComp =
|
||||
client.getObjectFactory().
|
||||
newCollectionValue("Collection(olingo.odata.test1.CTTwoPrim)");
|
||||
|
||||
final ClientComplexValue property1 = client.getObjectFactory().
|
||||
newComplexValue("olingo.odata.test1.CTTwoPrim");
|
||||
property1.add(client.getObjectFactory().newPrimitiveProperty("PropertyInt16",
|
||||
client.getObjectFactory().newPrimitiveValueBuilder().buildInt16((short) 111)));
|
||||
property1.add(client.getObjectFactory().newPrimitiveProperty("PropertyString",
|
||||
client.getObjectFactory().newPrimitiveValueBuilder().buildString("ABC")));
|
||||
colPropertyComp.add(property1);
|
||||
|
||||
final ClientComplexValue property2 = client.getObjectFactory().
|
||||
newComplexValue("olingo.odata.test1.CTTwoPrim");
|
||||
property2.add(client.getObjectFactory().newPrimitiveProperty("PropertyInt16",
|
||||
client.getObjectFactory().newPrimitiveValueBuilder().buildInt16((short) 222)));
|
||||
property2.add(client.getObjectFactory().newPrimitiveProperty("PropertyString",
|
||||
client.getObjectFactory().newPrimitiveValueBuilder().buildString("DEF")));
|
||||
colPropertyComp.add(property2);
|
||||
|
||||
final ClientComplexValue property3 = client.getObjectFactory().
|
||||
newComplexValue("olingo.odata.test1.CTBase");
|
||||
property3.add(client.getObjectFactory().newPrimitiveProperty("PropertyInt16",
|
||||
client.getObjectFactory().newPrimitiveValueBuilder().buildInt16((short) 333)));
|
||||
property3.add(client.getObjectFactory().newPrimitiveProperty("PropertyString",
|
||||
client.getObjectFactory().newPrimitiveValueBuilder().buildString("GHI")));
|
||||
colPropertyComp.add(property3);
|
||||
|
||||
Map<String, ClientValue> parameters = new HashMap<String, ClientValue>();
|
||||
parameters.put("CollPropertyComp", colPropertyComp);
|
||||
|
||||
final ODataInvokeRequest<ClientProperty> req =
|
||||
client.getInvokeRequestFactory().getActionInvokeRequest(builder.build(), ClientProperty.class, parameters);
|
||||
req.setFormat(ContentType.JSON_FULL_METADATA);
|
||||
req.setContentType(ContentType.APPLICATION_JSON.toContentTypeString() + ";odata.metadata=full");
|
||||
ClientProperty prop = req.execute().getBody();
|
||||
assertNotNull(prop);
|
||||
assertEquals(prop.getCollectionValue().getTypeName(),
|
||||
"Collection(olingo.odata.test1.CTTwoPrim)");
|
||||
assertEquals(prop.getCollectionValue().asCollection().size(), 3);
|
||||
Iterator<ClientValue> itr = prop.getCollectionValue().asCollection().iterator();
|
||||
int i = 0;
|
||||
while (itr.hasNext()) {
|
||||
ClientValue value = itr.next();
|
||||
if (i == 2) {
|
||||
assertEquals(value.asComplex().getTypeName(), "#olingo.odata.test1.CTBase");
|
||||
} else {
|
||||
assertEquals(value.asComplex().getTypeName(), "#olingo.odata.test1.CTTwoPrim");
|
||||
}
|
||||
i++;
|
||||
}
|
||||
}
|
||||
}
|
|
@ -188,7 +188,7 @@ public class DerivedAndMixedTypeTestITCase extends AbstractBaseTestITCase {
|
|||
ContentType.create(connection.getHeaderField(HttpHeader.CONTENT_TYPE)));
|
||||
|
||||
final String content = IOUtils.toString(connection.getInputStream());
|
||||
assertTrue(content.contains("\"value\":"
|
||||
final String actualContent = "\"value\":"
|
||||
+ "[{\"@odata.type\":\"#olingo.odata.test1.ETMixPrimCollComp\","
|
||||
+ "\"@odata.id\":\"ESMixPrimCollComp(32767)\","
|
||||
+ "\"PropertyInt16@odata.type\":\"#Int16\","
|
||||
|
@ -214,7 +214,10 @@ public class DerivedAndMixedTypeTestITCase extends AbstractBaseTestITCase {
|
|||
+ "\"PropertyInt16@odata.type\":\"#Int16\","
|
||||
+ "\"PropertyInt16\":789,"
|
||||
+ "\"PropertyString\":\"TEST 3\","
|
||||
+ "\"AdditionalPropString\":\"ADD TEST\"}]},"
|
||||
+ "\"AdditionalPropString\":\"ADD TEST\"}],"
|
||||
+ "\"#olingo.odata.test1.BAETMixPrimCollCompRTCTTwoPrim\":"
|
||||
+ "{\"title\":\"olingo.odata.test1.BAETMixPrimCollCompRTCTTwoPrim\","
|
||||
+ "\"target\":\"ESMixPrimCollComp(32767)/olingo.odata.test1.BAETMixPrimCollCompRTCTTwoPrim\"}},"
|
||||
+ "{\"@odata.type\":\"#olingo.odata.test1.ETMixPrimCollComp\","
|
||||
+ "\"@odata.id\":\"ESMixPrimCollComp(7)\","
|
||||
+ "\"PropertyInt16@odata.type\":\"#Int16\","
|
||||
|
@ -230,7 +233,11 @@ public class DerivedAndMixedTypeTestITCase extends AbstractBaseTestITCase {
|
|||
+ "{\"@odata.type\":\"#olingo.odata.test1.CTTwoPrim\",\"PropertyInt16@odata.type\":\"#Int16\","
|
||||
+ "\"PropertyInt16\":456,\"PropertyString\":\"TEST 2\"},{\"@odata.type\":\"#olingo.odata.test1.CTBase\","
|
||||
+ "\"PropertyInt16@odata.type\":\"#Int16\",\"PropertyInt16\":789,\"PropertyString\":\"TEST 3\","
|
||||
+ "\"AdditionalPropString\":\"ADD TEST\"}]},{\"@odata.type\":\"#olingo.odata.test1.ETMixPrimCollComp\","
|
||||
+ "\"AdditionalPropString\":\"ADD TEST\"}],"
|
||||
+ "\"#olingo.odata.test1.BAETMixPrimCollCompRTCTTwoPrim\":"
|
||||
+ "{\"title\":\"olingo.odata.test1.BAETMixPrimCollCompRTCTTwoPrim\","
|
||||
+ "\"target\":\"ESMixPrimCollComp(7)/olingo.odata.test1.BAETMixPrimCollCompRTCTTwoPrim\"}},"
|
||||
+ "{\"@odata.type\":\"#olingo.odata.test1.ETMixPrimCollComp\","
|
||||
+ "\"@odata.id\":\"ESMixPrimCollComp(0)\",\"PropertyInt16@odata.type\":\"#Int16\",\"PropertyInt16\":0,"
|
||||
+ "\"CollPropertyString@odata.type\":\"#Collection(String)\",\"CollPropertyString\":"
|
||||
+ "[\"Employee1@company.example\",\"Employee2@company.example\",\"Employee3@company.example\"],"
|
||||
|
@ -244,7 +251,11 @@ public class DerivedAndMixedTypeTestITCase extends AbstractBaseTestITCase {
|
|||
+ "\"PropertyInt16@odata.type\":\"#Int16\",\"PropertyInt16\":456,\"PropertyString\":\"TEST 2\"},"
|
||||
+ "{\"@odata.type\":\"#olingo.odata.test1.CTBase\","
|
||||
+ "\"PropertyInt16@odata.type\":\"#Int16\",\"PropertyInt16\":789,\"PropertyString\":\"TEST 3\","
|
||||
+ "\"AdditionalPropString\":\"ADD TEST\"}]}]"));
|
||||
+ "\"AdditionalPropString\":\"ADD TEST\"}],"
|
||||
+ "\"#olingo.odata.test1.BAETMixPrimCollCompRTCTTwoPrim\":"
|
||||
+ "{\"title\":\"olingo.odata.test1.BAETMixPrimCollCompRTCTTwoPrim\","
|
||||
+ "\"target\":\"ESMixPrimCollComp(0)/olingo.odata.test1.BAETMixPrimCollCompRTCTTwoPrim\"}}]";
|
||||
assertTrue(content.contains(actualContent));
|
||||
}
|
||||
|
||||
@Test
|
||||
|
@ -338,7 +349,10 @@ public class DerivedAndMixedTypeTestITCase extends AbstractBaseTestITCase {
|
|||
+ "\"PropertyInt16@odata.type\":\"#Int16\","
|
||||
+ "\"PropertyInt16\":111,"
|
||||
+ "\"PropertyString\":\"TEST A\","
|
||||
+ "\"AdditionalPropertyString_5\":\"TEST A 0815\"}]"));
|
||||
+ "\"AdditionalPropertyString_5\":\"TEST A 0815\""
|
||||
+ ",\"#olingo.odata.test1.BAETBaseETTwoBaseRTETTwoBase\":"
|
||||
+ "{\"title\":\"olingo.odata.test1.BAETBaseETTwoBaseRTETTwoBase\","
|
||||
+ "\"target\":\"ESBase(111)/olingo.odata.test1.BAETBaseETTwoBaseRTETTwoBase\"}}]"));
|
||||
}
|
||||
|
||||
@Test
|
||||
|
|
|
@ -47,6 +47,7 @@ import org.apache.olingo.commons.api.edm.provider.CsdlEntityType;
|
|||
import org.apache.olingo.commons.api.edm.provider.CsdlEnumType;
|
||||
import org.apache.olingo.commons.api.edm.provider.CsdlFunction;
|
||||
import org.apache.olingo.commons.api.edm.provider.CsdlParameter;
|
||||
import org.apache.olingo.commons.api.edm.provider.CsdlProperty;
|
||||
import org.apache.olingo.commons.api.edm.provider.CsdlSchema;
|
||||
import org.apache.olingo.commons.api.edm.provider.CsdlTerm;
|
||||
import org.apache.olingo.commons.api.edm.provider.CsdlTypeDefinition;
|
||||
|
@ -154,7 +155,10 @@ public class EdmProviderImpl extends AbstractEdm {
|
|||
if (action.isBound()) {
|
||||
final List<CsdlParameter> parameters = action.getParameters();
|
||||
final CsdlParameter parameter = parameters.get(0);
|
||||
if (bindingParameterTypeName.equals(parameter.getTypeFQN())
|
||||
if ((bindingParameterTypeName.equals(parameter.getTypeFQN()) ||
|
||||
isEntityPreviousTypeCompatibleToBindingParam(bindingParameterTypeName, parameter) ||
|
||||
isComplexPreviousTypeCompatibleToBindingParam(bindingParameterTypeName, parameter,
|
||||
isBindingParameterCollection))
|
||||
&& isBindingParameterCollection.booleanValue() == parameter.isCollection()) {
|
||||
|
||||
return new EdmActionImpl(this, actionName, action);
|
||||
|
@ -168,6 +172,44 @@ public class EdmProviderImpl extends AbstractEdm {
|
|||
}
|
||||
}
|
||||
|
||||
/**
|
||||
* @param bindingParameterTypeName
|
||||
* @param parameter
|
||||
* @param isBindingParameterCollection
|
||||
* @return
|
||||
* @throws ODataException
|
||||
*/
|
||||
private boolean isComplexPreviousTypeCompatibleToBindingParam(
|
||||
final FullQualifiedName bindingParameterTypeName, final CsdlParameter parameter,
|
||||
Boolean isBindingParameterCollection)
|
||||
throws ODataException {
|
||||
CsdlComplexType complexType = provider.getComplexType(bindingParameterTypeName);
|
||||
List<CsdlProperty> properties = provider.getEntityType(parameter.getTypeFQN()).getProperties();
|
||||
for (CsdlProperty property : properties) {
|
||||
String paramPropertyTypeName = property.getTypeAsFQNObject().getFullQualifiedNameAsString();
|
||||
if ((complexType != null && complexType.getBaseType() != null &&
|
||||
complexType.getBaseTypeFQN().getFullQualifiedNameAsString().equals(paramPropertyTypeName)) ||
|
||||
paramPropertyTypeName.equals(bindingParameterTypeName.getFullQualifiedNameAsString()) &&
|
||||
isBindingParameterCollection.booleanValue() == property.isCollection()) {
|
||||
return true;
|
||||
}
|
||||
}
|
||||
return false;
|
||||
}
|
||||
|
||||
/**
|
||||
* @param bindingParameterTypeName
|
||||
* @param parameter
|
||||
* @return
|
||||
* @throws ODataException
|
||||
*/
|
||||
private boolean isEntityPreviousTypeCompatibleToBindingParam(final FullQualifiedName bindingParameterTypeName,
|
||||
final CsdlParameter parameter) throws ODataException {
|
||||
return provider.getEntityType(bindingParameterTypeName) != null &&
|
||||
provider.getEntityType(bindingParameterTypeName).getBaseTypeFQN() != null &&
|
||||
provider.getEntityType(bindingParameterTypeName).getBaseTypeFQN().equals(parameter.getTypeFQN());
|
||||
}
|
||||
|
||||
@Override
|
||||
public EdmFunction createBoundFunction(final FullQualifiedName functionName,
|
||||
final FullQualifiedName bindingParameterTypeName, final Boolean isBindingParameterCollection,
|
||||
|
|
|
@ -23,22 +23,32 @@ import java.net.URI;
|
|||
import java.util.ArrayList;
|
||||
import java.util.Arrays;
|
||||
import java.util.Calendar;
|
||||
import java.util.Iterator;
|
||||
import java.util.List;
|
||||
import java.util.Map;
|
||||
import java.util.UUID;
|
||||
|
||||
import org.apache.olingo.commons.api.Constants;
|
||||
import org.apache.olingo.commons.api.data.ComplexValue;
|
||||
import org.apache.olingo.commons.api.data.Entity;
|
||||
import org.apache.olingo.commons.api.data.EntityCollection;
|
||||
import org.apache.olingo.commons.api.data.Link;
|
||||
import org.apache.olingo.commons.api.data.Parameter;
|
||||
import org.apache.olingo.commons.api.data.Property;
|
||||
import org.apache.olingo.commons.api.data.ValueType;
|
||||
import org.apache.olingo.commons.api.edm.Edm;
|
||||
import org.apache.olingo.commons.api.edm.EdmEntitySet;
|
||||
import org.apache.olingo.commons.api.edm.EdmEntityType;
|
||||
import org.apache.olingo.commons.api.edm.EdmKeyPropertyRef;
|
||||
import org.apache.olingo.commons.api.edm.EdmNavigationProperty;
|
||||
import org.apache.olingo.commons.api.edm.EdmPrimitiveType;
|
||||
import org.apache.olingo.commons.api.edm.EdmPrimitiveTypeException;
|
||||
import org.apache.olingo.commons.api.edm.EdmPrimitiveTypeKind;
|
||||
import org.apache.olingo.commons.api.edm.EdmProperty;
|
||||
import org.apache.olingo.commons.api.http.HttpStatusCode;
|
||||
import org.apache.olingo.server.api.OData;
|
||||
import org.apache.olingo.server.api.serializer.SerializerException;
|
||||
import org.apache.olingo.server.api.uri.UriParameter;
|
||||
import org.apache.olingo.server.tecsvc.data.DataProvider.DataProviderException;
|
||||
import org.apache.olingo.server.tecsvc.provider.ComplexTypeProvider;
|
||||
|
||||
|
@ -67,6 +77,25 @@ public class ActionData {
|
|||
HttpStatusCode.NOT_IMPLEMENTED);
|
||||
}
|
||||
|
||||
|
||||
protected static Property primitiveBoundAction(final String name, final Map<String, Parameter> parameters,
|
||||
final Map<String, EntityCollection> data, final EdmEntitySet edmEntitySet, final List<UriParameter> keyList)
|
||||
throws DataProviderException {
|
||||
List<Object> keyPropertyValues = new ArrayList<Object>();
|
||||
List<String> keyPropertyNames = new ArrayList<String>();
|
||||
if ("BAETTwoPrimRTString".equals(name)) {
|
||||
if (!keyList.isEmpty()) {
|
||||
setBindingPropertyKeyNameAndValue(keyList, edmEntitySet, keyPropertyValues, keyPropertyNames);
|
||||
EntityCollection entityCollection = data.get(edmEntitySet.getName());
|
||||
Entity entity = getSpecificEntity1(entityCollection, keyPropertyValues, keyPropertyNames);
|
||||
Property property = entity.getProperty("PropertyString");
|
||||
return property;
|
||||
}
|
||||
}
|
||||
throw new DataProviderException("Action " + name + " is not yet implemented.",
|
||||
HttpStatusCode.NOT_IMPLEMENTED);
|
||||
}
|
||||
|
||||
protected static Property primitiveCollectionAction(final String name, final Map<String, Parameter> parameters,
|
||||
final OData oData) throws DataProviderException {
|
||||
if ("UARTCollStringTwoParam".equals(name)) {
|
||||
|
@ -104,6 +133,26 @@ public class ActionData {
|
|||
HttpStatusCode.NOT_IMPLEMENTED);
|
||||
}
|
||||
|
||||
protected static Property primitiveCollectionBoundAction(final String name, final Map<String, Parameter> parameters,
|
||||
final Map<String, EntityCollection> data,
|
||||
EdmEntitySet edmEntitySet, List<UriParameter> keyList, final OData oData) throws DataProviderException {
|
||||
List<Object> collectionValues = new ArrayList<Object>();
|
||||
if ("BAETTwoPrimRTCollString".equals(name)) {
|
||||
EdmPrimitiveType strType = oData.createPrimitiveTypeInstance(EdmPrimitiveTypeKind.String);
|
||||
try {
|
||||
String strValue1 = strType.valueToString("ABC", false, 100, null, null, false);
|
||||
collectionValues.add(strValue1);
|
||||
String strValue2 = strType.valueToString("XYZ", false, 100, null, null, false);
|
||||
collectionValues.add(strValue2);
|
||||
} catch (EdmPrimitiveTypeException e) {
|
||||
throw new DataProviderException("EdmPrimitiveTypeException", HttpStatusCode.BAD_REQUEST, e);
|
||||
}
|
||||
return new Property(null, name, ValueType.COLLECTION_PRIMITIVE, collectionValues);
|
||||
}
|
||||
throw new DataProviderException("Action " + name + " is not yet implemented.",
|
||||
HttpStatusCode.NOT_IMPLEMENTED);
|
||||
}
|
||||
|
||||
private static String valueAsString(final Parameter parameter, final EdmPrimitiveTypeKind kind, final OData oData)
|
||||
throws EdmPrimitiveTypeException {
|
||||
return parameter == null ? "null" :
|
||||
|
@ -124,6 +173,22 @@ public class ActionData {
|
|||
HttpStatusCode.NOT_IMPLEMENTED);
|
||||
}
|
||||
|
||||
protected static Property complexBoundAction(final String name, final Map<String, Parameter> parameters,
|
||||
final Map<String, EntityCollection> data,
|
||||
EdmEntitySet edmEntitySet, List<UriParameter> keyList)
|
||||
throws DataProviderException {
|
||||
if ("BAETTwoKeyNavCTBasePrimCompNavCTTwoBasePrimCompNavRTCTTwoBasePrimCompNav".equals(name)) {
|
||||
if (!keyList.isEmpty()) {
|
||||
return DataCreator.createComplex(name,
|
||||
ComplexTypeProvider.nameCTTwoBasePrimCompNav.getFullQualifiedNameAsString(),
|
||||
DataCreator.createPrimitive("PropertyInt16", 10),
|
||||
createKeyNavAllPrimComplexValue("PropertyComp"));
|
||||
}
|
||||
}
|
||||
throw new DataProviderException("Action " + name + " is not yet implemented.",
|
||||
HttpStatusCode.NOT_IMPLEMENTED);
|
||||
}
|
||||
|
||||
private static Property createCTTwoPrimComplexProperty(final String name, final Short number, final String text) {
|
||||
return DataCreator.createComplex(name,
|
||||
ComplexTypeProvider.nameCTTwoPrim.getFullQualifiedNameAsString(),
|
||||
|
@ -152,6 +217,57 @@ public class ActionData {
|
|||
HttpStatusCode.NOT_IMPLEMENTED);
|
||||
}
|
||||
|
||||
@SuppressWarnings("unchecked")
|
||||
protected static Property complexCollectionBoundAction(final String name,
|
||||
final Map<String, Parameter> parameters, final Map<String, EntityCollection> data,
|
||||
EdmEntitySet edmEntitySet, List<UriParameter> keyList)
|
||||
throws DataProviderException {
|
||||
List<Object> keyPropertyValues = new ArrayList<Object>();
|
||||
List<String> keyPropertyNames = new ArrayList<String>();
|
||||
if ("BAETMixPrimCollCompRTCTTwoPrim".equals(name)) {
|
||||
if (!keyList.isEmpty()) {
|
||||
setBindingPropertyKeyNameAndValue(keyList, edmEntitySet, keyPropertyValues, keyPropertyNames);
|
||||
EntityCollection entityCollection = data.get(edmEntitySet.getName());
|
||||
Entity entity = getSpecificEntity1(entityCollection, keyPropertyValues, keyPropertyNames);
|
||||
List<ComplexValue> complexProperties = (List<ComplexValue>) entity.getProperty("CollPropertyComp").
|
||||
asCollection();
|
||||
List<ComplexValue> complexParameters = (List<ComplexValue>) parameters.get("CollPropertyComp").
|
||||
asCollection();
|
||||
for (int i = 0; i < complexProperties.size() && i < complexParameters.size(); i++) {
|
||||
List<Property> values = complexProperties.get(i).getValue();
|
||||
List<Property> paramValues = complexParameters.get(i).getValue();
|
||||
for (int j = 0; j < values.size() && j < paramValues.size(); j++) {
|
||||
values.get(j).setValue(values.get(j).getValueType(), paramValues.get(j).asPrimitive());
|
||||
}
|
||||
}
|
||||
return new Property(entity.getProperty("CollPropertyComp").getType(),
|
||||
entity.getProperty("CollPropertyComp").getName(),
|
||||
entity.getProperty("CollPropertyComp").getValueType(), complexProperties);
|
||||
}
|
||||
} else if ("BAETMixPrimCollCompCTTWOPrimCompRTCollCTTwoPrim".equals(name)) {
|
||||
List<ComplexValue> complexCollection = new ArrayList<ComplexValue>();
|
||||
if (!keyList.isEmpty()) {
|
||||
setBindingPropertyKeyNameAndValue(keyList, edmEntitySet, keyPropertyValues, keyPropertyNames);
|
||||
EntityCollection entityCollection = data.get(edmEntitySet.getName());
|
||||
Entity entity = getSpecificEntity1(entityCollection, keyPropertyValues, keyPropertyNames);
|
||||
ComplexValue complexValue = entity.getProperty("PropertyComp").asComplex();
|
||||
ComplexValue paramComplexValue = parameters.get("PropertyComp").asComplex();
|
||||
List<Property> complexProperties = complexValue.getValue();
|
||||
List<Property> paramProperties = paramComplexValue.getValue();
|
||||
for (int i = 0; i < complexProperties.size() && i < paramProperties.size(); i++) {
|
||||
complexProperties.get(i).setValue(complexProperties.get(i).getValueType(),
|
||||
paramProperties.get(i).asPrimitive());
|
||||
}
|
||||
complexCollection.add(complexValue);
|
||||
return new Property(entity.getProperty("PropertyComp").getType(),
|
||||
entity.getProperty("PropertyComp").getName(),
|
||||
ValueType.COLLECTION_COMPLEX, complexCollection);
|
||||
}
|
||||
}
|
||||
throw new DataProviderException("Action " + name + " is not yet implemented.",
|
||||
HttpStatusCode.NOT_IMPLEMENTED);
|
||||
}
|
||||
|
||||
protected static EntityActionResult entityAction(final String name, final Map<String, Parameter> parameters,
|
||||
final Map<String, EntityCollection> data, final OData oData, final Edm edm) throws DataProviderException {
|
||||
if ("UARTETTwoKeyTwoPrimParam".equals(name)) {
|
||||
|
@ -196,6 +312,154 @@ public class ActionData {
|
|||
HttpStatusCode.NOT_IMPLEMENTED);
|
||||
}
|
||||
|
||||
protected static EntityActionResult entityBoundAction(final String name, final Map<String, Parameter> parameters,
|
||||
final Map<String, EntityCollection> data, final OData oData, final Edm edm,
|
||||
List<UriParameter> keyList, EdmEntitySet edmEntitySet) throws DataProviderException {
|
||||
List<Object> keyPropertyValues = new ArrayList<Object>();
|
||||
List<String> keyPropertyNames = new ArrayList<String>();
|
||||
if ("BA_RTETTwoKeyNav".equals(name)) {
|
||||
if (!keyList.isEmpty()) {
|
||||
setBindingPropertyKeyNameAndValue(keyList, edmEntitySet, keyPropertyValues, keyPropertyNames);
|
||||
EntityCollection entityCollection = data.get(edmEntitySet.getName());
|
||||
Entity entity = null;
|
||||
if (edmEntitySet.getName().equals("ESKeyNav")) {
|
||||
entity = getSpecificEntity1(entityCollection, keyPropertyValues, keyPropertyNames);
|
||||
Entity etTwoKeyNavEntity =
|
||||
createETTwoKeyNav((short)100, "String1", oData, edm);
|
||||
Link link = new Link();
|
||||
link.setRel(Constants.NS_NAVIGATION_LINK_REL + "NavPropertyETTwoKeyNavOne");
|
||||
link.setType(Constants.ENTITY_NAVIGATION_LINK_TYPE);
|
||||
link.setTitle("NavPropertyETTwoKeyNavOne");
|
||||
link.setHref(etTwoKeyNavEntity.getId().toASCIIString());
|
||||
link.setInlineEntity(etTwoKeyNavEntity);
|
||||
entity.getNavigationLinks().add(link);
|
||||
return new EntityActionResult().setEntity(etTwoKeyNavEntity);
|
||||
} else {
|
||||
entity = getSpecificEntity(entityCollection, keyPropertyValues, keyPropertyNames);
|
||||
return new EntityActionResult().setEntity(entity);
|
||||
}
|
||||
}
|
||||
} else if ("BAETTwoBaseTwoKeyNavRTETBaseTwoKeyNav".equals(name)) {
|
||||
if (!keyList.isEmpty()) {
|
||||
setBindingPropertyKeyNameAndValue(keyList, edmEntitySet, keyPropertyValues, keyPropertyNames);
|
||||
EdmEntityType entityTypeFqn = edmEntitySet.getEntityType().getBaseType();
|
||||
List<EdmEntitySet> entitySets = edm.getEntityContainer().getEntitySets();
|
||||
for (EdmEntitySet entitySet : entitySets) {
|
||||
if (entitySet.getEntityType().getFullQualifiedName().getFullQualifiedNameAsString().equals
|
||||
(entityTypeFqn.getFullQualifiedName().getFullQualifiedNameAsString())) {
|
||||
edmEntitySet = entitySet;
|
||||
break;
|
||||
}
|
||||
}
|
||||
EntityCollection entityCollection = data.get(edmEntitySet.getName());
|
||||
Entity entity = getSpecificEntity(entityCollection, keyPropertyValues, keyPropertyNames);
|
||||
return new EntityActionResult().setEntity(entity).setCreated(true);
|
||||
}
|
||||
} else if ("BAETBaseETTwoBaseRTETTwoBase".equals(name)) {
|
||||
if (!keyList.isEmpty()) {
|
||||
setBindingPropertyKeyNameAndValue(keyList, edmEntitySet, keyPropertyValues, keyPropertyNames);
|
||||
EntityCollection entityCollection = data.get(edmEntitySet.getName());
|
||||
Entity entity = getSpecificEntity1(entityCollection, keyPropertyValues, keyPropertyNames);
|
||||
Property property1 = entity.getProperty("PropertyString");
|
||||
property1.setValue(property1.getValueType(), parameters.get("PropertyString").asPrimitive());
|
||||
|
||||
Property property2 = entity.getProperty("AdditionalPropertyString_5");
|
||||
property2.setValue(property2.getValueType(), parameters.get("AdditionalPropertyString_5").asPrimitive());
|
||||
|
||||
Property property3 = entity.getProperty("AdditionalPropertyString_6");
|
||||
property3.setValue(property3.getValueType(), parameters.get("AdditionalPropertyString_6").asPrimitive());
|
||||
|
||||
return new EntityActionResult().setEntity(entity).setCreated(true);
|
||||
}
|
||||
}
|
||||
throw new DataProviderException("Action " + name + " is not yet implemented.",
|
||||
HttpStatusCode.NOT_IMPLEMENTED);
|
||||
}
|
||||
|
||||
protected static EntityActionResult entityBoundActionWithNavigation(final String name,
|
||||
final Map<String, Parameter> parameters,
|
||||
final Map<String, EntityCollection> data, List<UriParameter> keyList,
|
||||
EdmEntitySet edmEntitySet, EdmNavigationProperty navProperty)
|
||||
throws DataProviderException {
|
||||
List<Object> keyPropertyValues = new ArrayList<Object>();
|
||||
List<String> keyPropertyNames = new ArrayList<String>();
|
||||
if ("BAETTwoKeyNavRTETTwoKeyNavParam".equals(name)) {
|
||||
if (!keyList.isEmpty()) {
|
||||
setBindingPropertyKeyNameAndValue(keyList, edmEntitySet, keyPropertyValues, keyPropertyNames);
|
||||
EntityCollection entityCollection = data.get(edmEntitySet.getName());
|
||||
Entity entity = getSpecificEntity(entityCollection, keyPropertyValues, keyPropertyNames);
|
||||
|
||||
Link link = entity.getNavigationLink(navProperty.getName());
|
||||
Entity inlineEntity = link.getInlineEntity();
|
||||
ComplexValue complexValue = inlineEntity.getProperty("PropertyComp").asComplex();
|
||||
List<Property> complexProperties = complexValue.getValue();
|
||||
Iterator<Property> itr = complexProperties.iterator();
|
||||
Parameter actionParam = parameters.get("PropertyComp");
|
||||
Property actionProp = actionParam.asComplex().getValue().get(0);
|
||||
while (itr.hasNext()) {
|
||||
Property property = itr.next();
|
||||
if (property.getName().equals(actionProp.getName())) {
|
||||
property.setValue(actionProp.getValueType(), actionProp.getValue());
|
||||
break;
|
||||
}
|
||||
}
|
||||
return new EntityActionResult().setEntity(inlineEntity);
|
||||
}
|
||||
}
|
||||
throw new DataProviderException("Action " + name + " is not yet implemented.",
|
||||
HttpStatusCode.NOT_IMPLEMENTED);
|
||||
}
|
||||
|
||||
private static Entity getSpecificEntity(EntityCollection entityCollection, List<Object> values,
|
||||
List<String> propertyNames) throws DataProviderException {
|
||||
for (Entity entity : entityCollection.getEntities()) {
|
||||
Object asPrimitive1 = entity.getProperty(propertyNames.get(0)).asPrimitive();
|
||||
Object asPrimitive2 = entity.getProperty(propertyNames.get(1)).asPrimitive();
|
||||
if (values.get(0).equals(String.valueOf(asPrimitive1)) &&
|
||||
values.get(1).equals(String.valueOf(asPrimitive2))) {
|
||||
return entity;
|
||||
}
|
||||
}
|
||||
// Entity Not found
|
||||
throw new DataProviderException("Entity not found with key: " + values.get(0) +
|
||||
"," + values.get(1), HttpStatusCode.NOT_FOUND);
|
||||
}
|
||||
|
||||
private static Entity getSpecificEntity1(EntityCollection entityCollection, List<Object> values,
|
||||
List<String> propertyNames) throws DataProviderException {
|
||||
for (Entity entity : entityCollection.getEntities()) {
|
||||
Object asPrimitive1 = entity.getProperty(propertyNames.get(0)).asPrimitive();
|
||||
if (values.get(0).equals(String.valueOf(asPrimitive1))) {
|
||||
return entity;
|
||||
}
|
||||
}
|
||||
// Entity Not found
|
||||
throw new DataProviderException("Entity not found with key: " + values.get(0),
|
||||
HttpStatusCode.NOT_FOUND);
|
||||
}
|
||||
|
||||
/**
|
||||
* @param keyList
|
||||
* @param edmEntitySet
|
||||
* @param values
|
||||
* @param propertyNames
|
||||
* @throws DataProviderException
|
||||
*/
|
||||
private static void setBindingPropertyKeyNameAndValue(List<UriParameter> keyList, EdmEntitySet edmEntitySet,
|
||||
List<Object> values, List<String> propertyNames) throws DataProviderException {
|
||||
for (final UriParameter key : keyList) {
|
||||
EdmKeyPropertyRef refType = edmEntitySet.getEntityType().getKeyPropertyRef(key.getName());
|
||||
final EdmProperty property = refType.getProperty();
|
||||
final EdmPrimitiveType type = (EdmPrimitiveType) property.getType();
|
||||
try {
|
||||
values.add(type.fromUriLiteral(key.getText()));
|
||||
} catch (EdmPrimitiveTypeException e) {
|
||||
throw new DataProviderException("Wrong key!", HttpStatusCode.BAD_REQUEST, e);
|
||||
}
|
||||
propertyNames.add(key.getName());
|
||||
}
|
||||
}
|
||||
|
||||
private static Entity createAllPrimEntity(final Short key, final String val, final Calendar date,
|
||||
final OData oData, final Edm edm) throws DataProviderException {
|
||||
Entity entity = new Entity().addProperty(DataCreator.createPrimitive("PropertyInt16", key))
|
||||
|
@ -247,6 +511,73 @@ public class ActionData {
|
|||
HttpStatusCode.NOT_IMPLEMENTED);
|
||||
}
|
||||
|
||||
protected static EntityCollection entityCollectionBoundAction(final String name,
|
||||
final Map<String, Parameter> parameters,
|
||||
Map<String, EntityCollection> data, final OData oData, final Edm edm, EdmEntitySet edmEntitySet)
|
||||
throws DataProviderException {
|
||||
if ("BAESTwoKeyNavRTESTwoKeyNav".equals(name)) {
|
||||
EntityCollection collection = data.get(edmEntitySet.getName());
|
||||
collection.getEntities().add(createETTwoKeyNav((short)111, "newValue", oData, edm));
|
||||
return collection;
|
||||
}
|
||||
throw new DataProviderException("Action " + name + " is not yet implemented.",
|
||||
HttpStatusCode.NOT_IMPLEMENTED);
|
||||
}
|
||||
|
||||
protected static EntityCollection entityCollectionBoundActionWithNav(final String name,
|
||||
final Map<String, Parameter> parameters, Map<String, EntityCollection> data,
|
||||
final OData oData, final Edm edm, EdmEntitySet edmEntitySet, EdmNavigationProperty navProperty)
|
||||
throws DataProviderException {
|
||||
throw new DataProviderException("Action " + name + " is not yet implemented.",
|
||||
HttpStatusCode.NOT_IMPLEMENTED);
|
||||
}
|
||||
|
||||
@SuppressWarnings("unchecked")
|
||||
private static Entity createETTwoKeyNav (final short number, final String value, final OData oData,
|
||||
final Edm edm) throws DataProviderException {
|
||||
Entity entity = new Entity()
|
||||
.addProperty(DataCreator.createPrimitive("PropertyInt16", number))
|
||||
.addProperty(DataCreator.createPrimitive("PropertyString", value))
|
||||
.addProperty(DataCreator.createComplex("PropertyComp",
|
||||
ComplexTypeProvider.nameCTPrimComp.getFullQualifiedNameAsString(),
|
||||
DataCreator.createPrimitive("PropertyInt16", 11),
|
||||
DataCreator.createComplex("PropertyComp",
|
||||
ComplexTypeProvider.nameCTAllPrim.getFullQualifiedNameAsString(),
|
||||
DataCreator.createPrimitive("PropertyString", "StringValue"),
|
||||
DataCreator.createPrimitive("PropertyBinary", new byte[] { 1, 35, 69, 103, -119, -85, -51, -17 }),
|
||||
DataCreator.createPrimitive("PropertyBoolean", true),
|
||||
DataCreator.createPrimitive("PropertyByte", (short) 255),
|
||||
DataCreator.createPrimitive("PropertyDate", null),
|
||||
DataCreator.createPrimitive("PropertyDecimal", BigDecimal.valueOf(34)),
|
||||
DataCreator.createPrimitive("PropertySingle", (float) 179000000000000000000D),
|
||||
DataCreator.createPrimitive("PropertyDouble", -179000000000000000000D),
|
||||
DataCreator.createPrimitive("PropertyDuration", BigDecimal.valueOf(6)),
|
||||
DataCreator.createPrimitive("PropertyGuid", UUID.fromString("01234567-89ab-cdef-0123-456789abcdef")),
|
||||
DataCreator.createPrimitive("PropertyInt16", Short.MAX_VALUE),
|
||||
DataCreator.createPrimitive("PropertyInt32", Integer.MAX_VALUE),
|
||||
DataCreator.createPrimitive("PropertyInt64", Long.MAX_VALUE),
|
||||
DataCreator.createPrimitive("PropertySByte", Byte.MAX_VALUE),
|
||||
DataCreator.createPrimitive("PropertyTimeOfDay", null))))
|
||||
.addProperty(DataCreator.createComplex("PropertyCompNav",
|
||||
ComplexTypeProvider.nameCTBasePrimCompNav.getFullQualifiedNameAsString(),
|
||||
DataCreator.createPrimitive("PropertyInt16", (short) 1),
|
||||
createKeyNavAllPrimComplexValue("PropertyComp")))
|
||||
.addProperty(DataCreator.createComplexCollection("CollPropertyComp", null))
|
||||
.addProperty(DataCreator.createComplexCollection("CollPropertyCompNav",
|
||||
ComplexTypeProvider.nameCTNavFiveProp.getFullQualifiedNameAsString(),
|
||||
Arrays.asList(
|
||||
DataCreator.createPrimitive("PropertyInt16", (short) 1))))
|
||||
.addProperty(DataCreator.createPrimitiveCollection("CollPropertyString",
|
||||
"1",
|
||||
"2"))
|
||||
.addProperty(DataCreator.createComplex("PropertyCompTwoPrim",
|
||||
ComplexTypeProvider.nameCTTwoPrim.getFullQualifiedNameAsString(),
|
||||
DataCreator.createPrimitive("PropertyInt16", (short) 11),
|
||||
DataCreator.createPrimitive("PropertyString", "11")));
|
||||
setEntityId(entity, "ESTwoKeyNav", oData, edm);
|
||||
return entity;
|
||||
}
|
||||
|
||||
@SuppressWarnings("unchecked")
|
||||
private static Entity createETKeyNavEntity(final Short number, final OData oData, final Edm edm)
|
||||
throws DataProviderException {
|
||||
|
|
|
@ -664,31 +664,84 @@ public class DataProvider {
|
|||
return ActionData.primitiveAction(name, actionParameters);
|
||||
}
|
||||
|
||||
public Property processBoundActionPrimitive(final String name, final Map<String, Parameter> actionParameters,
|
||||
final EdmEntitySet edmEntitySet, final List<UriParameter> keyList)
|
||||
throws DataProviderException {
|
||||
return ActionData.primitiveBoundAction(name, actionParameters, data, edmEntitySet, keyList);
|
||||
}
|
||||
|
||||
public Property processActionComplex(final String name, final Map<String, Parameter> actionParameters)
|
||||
throws DataProviderException {
|
||||
return ActionData.complexAction(name, actionParameters);
|
||||
}
|
||||
|
||||
public Property processBoundActionComplex(final String name, final Map<String, Parameter> actionParameters,
|
||||
final EdmEntitySet edmEntitySet,
|
||||
final List<UriParameter> keyList)
|
||||
throws DataProviderException {
|
||||
return ActionData.complexBoundAction(name, actionParameters, data, edmEntitySet, keyList);
|
||||
}
|
||||
|
||||
public Property processActionComplexCollection(final String name, final Map<String, Parameter> actionParameters)
|
||||
throws DataProviderException {
|
||||
return ActionData.complexCollectionAction(name, actionParameters);
|
||||
}
|
||||
|
||||
public Property processBoundActionComplexCollection(final String name,
|
||||
final Map<String, Parameter> actionParameters, final EdmEntitySet edmEntitySet,
|
||||
final List<UriParameter> keyList)
|
||||
throws DataProviderException {
|
||||
return ActionData.complexCollectionBoundAction(name, actionParameters, data, edmEntitySet, keyList);
|
||||
}
|
||||
|
||||
public Property processActionPrimitiveCollection(final String name, final Map<String, Parameter> actionParameters)
|
||||
throws DataProviderException {
|
||||
return ActionData.primitiveCollectionAction(name, actionParameters, odata);
|
||||
}
|
||||
|
||||
public Property processBoundActionPrimitiveCollection(final String name,
|
||||
final Map<String, Parameter> actionParameters, final EdmEntitySet edmEntitySet,
|
||||
final List<UriParameter> keyList)
|
||||
throws DataProviderException {
|
||||
return ActionData.primitiveCollectionBoundAction(name, actionParameters, data, edmEntitySet, keyList, odata);
|
||||
}
|
||||
|
||||
public EntityActionResult processActionEntity(final String name, final Map<String, Parameter> actionParameters)
|
||||
throws DataProviderException {
|
||||
return ActionData.entityAction(name, actionParameters, data, odata, edm);
|
||||
}
|
||||
|
||||
public EntityActionResult processBoundActionEntity(final String name, final Map<String, Parameter> actionParameters,
|
||||
List<UriParameter> keyList, EdmEntitySet edmEntitySet)
|
||||
throws DataProviderException {
|
||||
return ActionData.entityBoundAction(name, actionParameters, data, odata, edm, keyList, edmEntitySet);
|
||||
}
|
||||
|
||||
public EntityActionResult processBoundActionWithNavigationEntity(final String name,
|
||||
final Map<String, Parameter> actionParameters,
|
||||
List<UriParameter> keyList, EdmEntitySet edmEntitySet, EdmNavigationProperty navProperty)
|
||||
throws DataProviderException {
|
||||
return ActionData.entityBoundActionWithNavigation(name, actionParameters, data, keyList,
|
||||
edmEntitySet, navProperty);
|
||||
}
|
||||
|
||||
public EntityCollection processActionEntityCollection(final String name,
|
||||
final Map<String, Parameter> actionParameters) throws DataProviderException {
|
||||
return ActionData.entityCollectionAction(name, actionParameters, odata, edm);
|
||||
}
|
||||
|
||||
public EntityCollection processBoundActionEntityCollection(final String name,
|
||||
final Map<String, Parameter> actionParameters, EdmEntitySet edmEntitySet) throws DataProviderException {
|
||||
return ActionData.entityCollectionBoundAction(name, actionParameters, data, odata, edm, edmEntitySet);
|
||||
}
|
||||
|
||||
public EntityCollection processBoundActionWithNavEntityCollection(final String name,
|
||||
final Map<String, Parameter> actionParameters, EdmEntitySet edmEntitySet, EdmNavigationProperty navProperty)
|
||||
throws DataProviderException {
|
||||
return ActionData.entityCollectionBoundActionWithNav(name, actionParameters, data, odata, edm,
|
||||
edmEntitySet, navProperty);
|
||||
}
|
||||
|
||||
public void createReference(final Entity entity, final EdmNavigationProperty navigationProperty, final URI entityId,
|
||||
final String rawServiceRoot) throws DataProviderException {
|
||||
setLink(navigationProperty, entity, getEntityByReference(entityId.toASCIIString(), rawServiceRoot));
|
||||
|
|
|
@ -20,6 +20,8 @@ package org.apache.olingo.server.tecsvc.processor;
|
|||
|
||||
import java.io.InputStream;
|
||||
import java.util.Collections;
|
||||
import java.util.HashMap;
|
||||
import java.util.List;
|
||||
import java.util.Locale;
|
||||
import java.util.Map;
|
||||
|
||||
|
@ -31,8 +33,10 @@ import org.apache.olingo.commons.api.data.Parameter;
|
|||
import org.apache.olingo.commons.api.data.Property;
|
||||
import org.apache.olingo.commons.api.edm.EdmAction;
|
||||
import org.apache.olingo.commons.api.edm.EdmComplexType;
|
||||
import org.apache.olingo.commons.api.edm.EdmEntityContainer;
|
||||
import org.apache.olingo.commons.api.edm.EdmEntitySet;
|
||||
import org.apache.olingo.commons.api.edm.EdmEntityType;
|
||||
import org.apache.olingo.commons.api.edm.EdmNavigationProperty;
|
||||
import org.apache.olingo.commons.api.edm.EdmPrimitiveType;
|
||||
import org.apache.olingo.commons.api.format.ContentType;
|
||||
import org.apache.olingo.commons.api.http.HttpHeader;
|
||||
|
@ -58,7 +62,10 @@ import org.apache.olingo.server.api.serializer.EntitySerializerOptions;
|
|||
import org.apache.olingo.server.api.serializer.PrimitiveSerializerOptions;
|
||||
import org.apache.olingo.server.api.serializer.SerializerResult;
|
||||
import org.apache.olingo.server.api.uri.UriInfo;
|
||||
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.UriResourceNavigation;
|
||||
import org.apache.olingo.server.tecsvc.data.DataProvider;
|
||||
import org.apache.olingo.server.tecsvc.data.EntityActionResult;
|
||||
|
||||
|
@ -79,13 +86,36 @@ public class TechnicalActionProcessor extends TechnicalProcessor
|
|||
public void processActionEntityCollection(final ODataRequest request, final ODataResponse response,
|
||||
final UriInfo uriInfo, final ContentType requestFormat, final ContentType responseFormat)
|
||||
throws ODataApplicationException, ODataLibraryException {
|
||||
blockBoundActions(uriInfo);
|
||||
final EdmAction action = ((UriResourceAction) uriInfo.asUriInfoResource().getUriResourceParts().get(0))
|
||||
Map<String, Parameter> parameters = new HashMap<String, Parameter>();
|
||||
EdmAction action = null;
|
||||
EntityCollection collection = null;
|
||||
List<UriResource> resourcePaths = uriInfo.asUriInfoResource().getUriResourceParts();
|
||||
if (resourcePaths.size() > 1) {
|
||||
UriResourceEntitySet boundEntityCollection = (UriResourceEntitySet) resourcePaths.get(0);
|
||||
if (resourcePaths.get(1) instanceof UriResourceNavigation) {
|
||||
UriResourceNavigation navResource = (UriResourceNavigation) resourcePaths.get(1);
|
||||
EdmNavigationProperty navProperty = navResource.getProperty();
|
||||
action = ((UriResourceAction) resourcePaths.get(2))
|
||||
.getAction();
|
||||
final Map<String, Parameter> parameters = readParameters(action, request.getBody(), requestFormat);
|
||||
EntityCollection collection =
|
||||
parameters = readParameters(action, request.getBody(), requestFormat);
|
||||
collection =
|
||||
dataProvider.processBoundActionWithNavEntityCollection(action.getName(), parameters,
|
||||
boundEntityCollection.getEntitySet(), navProperty);
|
||||
} else if (resourcePaths.get(0) instanceof UriResourceEntitySet) {
|
||||
action = ((UriResourceAction) resourcePaths.get(1))
|
||||
.getAction();
|
||||
parameters = readParameters(action, request.getBody(), requestFormat);
|
||||
collection =
|
||||
dataProvider.processBoundActionEntityCollection(action.getName(), parameters,
|
||||
boundEntityCollection.getEntitySet());
|
||||
}
|
||||
} else {
|
||||
action = ((UriResourceAction) resourcePaths.get(0))
|
||||
.getAction();
|
||||
parameters = readParameters(action, request.getBody(), requestFormat);
|
||||
collection =
|
||||
dataProvider.processActionEntityCollection(action.getName(), parameters);
|
||||
|
||||
}
|
||||
// Collections must never be null.
|
||||
// Not nullable return types must not contain a null value.
|
||||
if (collection == null
|
||||
|
@ -118,15 +148,57 @@ public class TechnicalActionProcessor extends TechnicalProcessor
|
|||
public void processActionEntity(final ODataRequest request, final ODataResponse response, final UriInfo uriInfo,
|
||||
final ContentType requestFormat, final ContentType responseFormat)
|
||||
throws ODataApplicationException, ODataLibraryException {
|
||||
blockBoundActions(uriInfo);
|
||||
final EdmAction action = ((UriResourceAction) uriInfo.asUriInfoResource().getUriResourceParts().get(0))
|
||||
EdmAction action = null;
|
||||
Map<String, Parameter> parameters = new HashMap<String, Parameter>();
|
||||
EntityActionResult entityResult = null;
|
||||
|
||||
final List<UriResource> resourcePaths = uriInfo.asUriInfoResource().getUriResourceParts();
|
||||
if (resourcePaths.size() > 1) {
|
||||
UriResourceEntitySet boundEntity = (UriResourceEntitySet) resourcePaths.get(0);
|
||||
EdmEntitySet entitySet = boundEntity.getEntitySet();
|
||||
if (resourcePaths.get(1) instanceof UriResourceNavigation) {
|
||||
UriResourceNavigation navEntity = (UriResourceNavigation) resourcePaths.get(1);
|
||||
action = ((UriResourceAction) resourcePaths.get(2))
|
||||
.getAction();
|
||||
parameters = readParameters(action, request.getBody(), requestFormat);
|
||||
if (navEntity.getTypeFilterOnEntry() != null) {
|
||||
EdmEntityType edmEntityType = (EdmEntityType) navEntity.
|
||||
getTypeFilterOnEntry();
|
||||
entitySet = getTypeCastedEntitySet(entitySet, edmEntityType);
|
||||
entityResult =
|
||||
dataProvider.processBoundActionEntity(action.getName(), parameters, boundEntity.getKeyPredicates(),
|
||||
entitySet);
|
||||
} else {
|
||||
EdmNavigationProperty navProperty = navEntity.getProperty();
|
||||
entityResult =
|
||||
dataProvider.processBoundActionWithNavigationEntity(action.getName(),
|
||||
parameters, boundEntity.getKeyPredicates(),
|
||||
entitySet, navProperty);
|
||||
}
|
||||
} else if (resourcePaths.get(0) instanceof UriResourceEntitySet) {
|
||||
UriResourceEntitySet uriResourceEntitySet = (UriResourceEntitySet) resourcePaths.get(0);
|
||||
action = ((UriResourceAction) resourcePaths.get(1))
|
||||
.getAction();
|
||||
if (uriResourceEntitySet.getTypeFilterOnEntry() != null) {
|
||||
EdmEntityType edmEntityType = (EdmEntityType) uriResourceEntitySet.
|
||||
getTypeFilterOnEntry();
|
||||
entitySet = getTypeCastedEntitySet(entitySet, edmEntityType);
|
||||
}
|
||||
parameters = readParameters(action, request.getBody(), requestFormat);
|
||||
entityResult =
|
||||
dataProvider.processBoundActionEntity(action.getName(), parameters, boundEntity.getKeyPredicates(),
|
||||
entitySet);
|
||||
}
|
||||
} else {
|
||||
action = ((UriResourceAction) uriInfo.asUriInfoResource().getUriResourceParts().get(0))
|
||||
.getAction();
|
||||
parameters = readParameters(action, request.getBody(), requestFormat);
|
||||
entityResult =
|
||||
dataProvider.processActionEntity(action.getName(), parameters);
|
||||
}
|
||||
final EdmEntitySet edmEntitySet = getEdmEntitySet(uriInfo.asUriInfoResource());
|
||||
final EdmEntityType type = (EdmEntityType) action.getReturnType().getType();
|
||||
|
||||
final Map<String, Parameter> parameters = readParameters(action, request.getBody(), requestFormat);
|
||||
final EntityActionResult entityResult =
|
||||
dataProvider.processActionEntity(action.getName(), parameters);
|
||||
if (entityResult == null || entityResult.getEntity() == null) {
|
||||
if (action.getReturnType().isNullable()) {
|
||||
response.setStatusCode(HttpStatusCode.NO_CONTENT.getStatusCode());
|
||||
|
@ -170,16 +242,46 @@ public class TechnicalActionProcessor extends TechnicalProcessor
|
|||
}
|
||||
}
|
||||
|
||||
/**
|
||||
* @param entitySet
|
||||
* @param edmType
|
||||
* @param edmEntityType
|
||||
* @return
|
||||
*/
|
||||
private EdmEntitySet getTypeCastedEntitySet(EdmEntitySet entitySet, EdmEntityType edmEntityType) {
|
||||
EdmEntityContainer container = serviceMetadata.getEdm().getEntityContainer();
|
||||
List<EdmEntitySet> entitySets = container.getEntitySets();
|
||||
for (EdmEntitySet enSet : entitySets) {
|
||||
if (enSet.getEntityType().getFullQualifiedName().getFullQualifiedNameAsString().equals
|
||||
(edmEntityType.getFullQualifiedName().getFullQualifiedNameAsString())) {
|
||||
entitySet = enSet;
|
||||
break;
|
||||
}
|
||||
}
|
||||
return entitySet;
|
||||
}
|
||||
|
||||
@Override
|
||||
public void processActionPrimitiveCollection(final ODataRequest request, ODataResponse response,
|
||||
final UriInfo uriInfo, final ContentType requestFormat, final ContentType responseFormat)
|
||||
throws ODataApplicationException, ODataLibraryException {
|
||||
blockBoundActions(uriInfo);
|
||||
final EdmAction action = ((UriResourceAction) uriInfo.asUriInfoResource().getUriResourceParts().get(0))
|
||||
EdmAction action = null;
|
||||
Map<String, Parameter> parameters = null;
|
||||
List<UriResource> uriResource = uriInfo.asUriInfoResource().getUriResourceParts();
|
||||
Property property = null;
|
||||
if (uriResource.size() > 1) {
|
||||
UriResourceEntitySet uriResourceEntitySet = (UriResourceEntitySet) uriResource.get(0);
|
||||
action = ((UriResourceAction) uriResource.get(uriResource.size() - 1)).getAction();
|
||||
parameters = readParameters(action, request.getBody(), requestFormat);
|
||||
property = dataProvider.processBoundActionPrimitiveCollection(action.getName(), parameters,
|
||||
uriResourceEntitySet.getEntitySet(), uriResourceEntitySet.getKeyPredicates());
|
||||
} else {
|
||||
action = ((UriResourceAction) uriResource.get(0))
|
||||
.getAction();
|
||||
final Map<String, Parameter> parameters = readParameters(action, request.getBody(), requestFormat);
|
||||
Property property =
|
||||
parameters = readParameters(action, request.getBody(), requestFormat);
|
||||
property =
|
||||
dataProvider.processActionPrimitiveCollection(action.getName(), parameters);
|
||||
}
|
||||
|
||||
if (property == null || property.isNull()) {
|
||||
// Collection Propertys must never be null
|
||||
|
@ -214,11 +316,23 @@ public class TechnicalActionProcessor extends TechnicalProcessor
|
|||
public void processActionPrimitive(final ODataRequest request, ODataResponse response,
|
||||
final UriInfo uriInfo, final ContentType requestFormat, final ContentType responseFormat)
|
||||
throws ODataApplicationException, ODataLibraryException {
|
||||
blockBoundActions(uriInfo);
|
||||
final EdmAction action = ((UriResourceAction) uriInfo.asUriInfoResource().getUriResourceParts().get(0))
|
||||
EdmAction action = null;
|
||||
Map<String, Parameter> parameters = null;
|
||||
List<UriResource> uriResource = uriInfo.asUriInfoResource().getUriResourceParts();
|
||||
Property property = null;
|
||||
if (uriResource.size() > 1) {
|
||||
UriResourceEntitySet uriResourceEntitySet = (UriResourceEntitySet) uriResource.get(0);
|
||||
action = ((UriResourceAction) uriResource.get(uriResource.size() - 1)).getAction();
|
||||
parameters = readParameters(action, request.getBody(), requestFormat);
|
||||
property = dataProvider.processBoundActionPrimitive(action.getName(), parameters,
|
||||
uriResourceEntitySet.getEntitySet(), uriResourceEntitySet.getKeyPredicates());
|
||||
} else {
|
||||
action = ((UriResourceAction) uriResource.get(0))
|
||||
.getAction();
|
||||
final Map<String, Parameter> parameters = readParameters(action, request.getBody(), requestFormat);
|
||||
Property property = dataProvider.processActionPrimitive(action.getName(), parameters);
|
||||
parameters = readParameters(action, request.getBody(), requestFormat);
|
||||
property = dataProvider.processActionPrimitive(action.getName(), parameters);
|
||||
}
|
||||
|
||||
EdmPrimitiveType type = (EdmPrimitiveType) action.getReturnType().getType();
|
||||
if (property == null || property.isNull()) {
|
||||
if (action.getReturnType().isNullable()) {
|
||||
|
@ -252,12 +366,28 @@ public class TechnicalActionProcessor extends TechnicalProcessor
|
|||
public void processActionComplexCollection(final ODataRequest request, ODataResponse response,
|
||||
final UriInfo uriInfo, final ContentType requestFormat, final ContentType responseFormat)
|
||||
throws ODataApplicationException, ODataLibraryException {
|
||||
blockBoundActions(uriInfo);
|
||||
final EdmAction action = ((UriResourceAction) uriInfo.asUriInfoResource().getUriResourceParts().get(0))
|
||||
EdmAction action = null;
|
||||
Map<String, Parameter> parameters = null;
|
||||
Property property = null;
|
||||
final List<UriResource> resourcePaths = uriInfo.asUriInfoResource().getUriResourceParts();
|
||||
if (resourcePaths.size() > 1) {
|
||||
if (resourcePaths.get(0) instanceof UriResourceEntitySet) {
|
||||
UriResourceEntitySet uriResourceEntitySet = (UriResourceEntitySet) resourcePaths.get(0);
|
||||
EdmEntitySet entitySet = uriResourceEntitySet.getEntitySet();
|
||||
action = ((UriResourceAction) resourcePaths.get(resourcePaths.size() - 1))
|
||||
.getAction();
|
||||
final Map<String, Parameter> parameters = readParameters(action, request.getBody(), requestFormat);
|
||||
Property property =
|
||||
parameters = readParameters(action, request.getBody(), requestFormat);
|
||||
property =
|
||||
dataProvider.processBoundActionComplexCollection(action.getName(), parameters, entitySet,
|
||||
uriResourceEntitySet.getKeyPredicates());
|
||||
}
|
||||
} else {
|
||||
action = ((UriResourceAction) resourcePaths.get(0))
|
||||
.getAction();
|
||||
parameters = readParameters(action, request.getBody(), requestFormat);
|
||||
property =
|
||||
dataProvider.processActionComplexCollection(action.getName(), parameters);
|
||||
}
|
||||
|
||||
if (property == null || property.isNull()) {
|
||||
// Collection Propertys must never be null
|
||||
|
@ -291,11 +421,28 @@ public class TechnicalActionProcessor extends TechnicalProcessor
|
|||
public void processActionComplex(final ODataRequest request, ODataResponse response, final UriInfo uriInfo,
|
||||
final ContentType requestFormat, final ContentType responseFormat)
|
||||
throws ODataApplicationException, ODataLibraryException {
|
||||
blockBoundActions(uriInfo);
|
||||
final EdmAction action = ((UriResourceAction) uriInfo.asUriInfoResource().getUriResourceParts().get(0))
|
||||
EdmAction action = null;
|
||||
Map<String, Parameter> parameters = null;
|
||||
Property property = null;
|
||||
final List<UriResource> resourcePaths = uriInfo.asUriInfoResource().getUriResourceParts();
|
||||
if (resourcePaths.size() > 1) {
|
||||
if (resourcePaths.get(0) instanceof UriResourceEntitySet) {
|
||||
UriResourceEntitySet uriResourceEntitySet = (UriResourceEntitySet) resourcePaths.get(0);
|
||||
EdmEntitySet entitySet = uriResourceEntitySet.getEntitySet();
|
||||
action = ((UriResourceAction) resourcePaths.get(resourcePaths.size() - 1))
|
||||
.getAction();
|
||||
final Map<String, Parameter> parameters = readParameters(action, request.getBody(), requestFormat);
|
||||
Property property = dataProvider.processActionComplex(action.getName(), parameters);
|
||||
parameters = readParameters(action, request.getBody(), requestFormat);
|
||||
property =
|
||||
dataProvider.processBoundActionComplex(action.getName(), parameters, entitySet,
|
||||
uriResourceEntitySet.getKeyPredicates());
|
||||
}
|
||||
} else {
|
||||
action = ((UriResourceAction) resourcePaths.get(0))
|
||||
.getAction();
|
||||
parameters = readParameters(action, request.getBody(), requestFormat);
|
||||
property = dataProvider.processActionComplex(action.getName(), parameters);
|
||||
}
|
||||
|
||||
EdmComplexType type = (EdmComplexType) action.getReturnType().getType();
|
||||
if (property == null || property.isNull()) {
|
||||
if (action.getReturnType().isNullable()) {
|
||||
|
@ -339,7 +486,8 @@ public class TechnicalActionProcessor extends TechnicalProcessor
|
|||
final ContentType requestFormat) throws ODataApplicationException, DeserializerException {
|
||||
if (action.getParameterNames().size() - (action.isBound() ? 1 : 0) > 0) {
|
||||
checkRequestFormat(requestFormat);
|
||||
return odata.createDeserializer(requestFormat).actionParameters(body, action).getActionParameters();
|
||||
return odata.createDeserializer(requestFormat, serviceMetadata).
|
||||
actionParameters(body, action).getActionParameters();
|
||||
}
|
||||
return Collections.<String, Parameter> emptyMap();
|
||||
}
|
||||
|
|
|
@ -74,6 +74,25 @@ public class ActionProvider {
|
|||
public static final FullQualifiedName nameBAETTwoKeyNavRTETTwoKeyNavParam =
|
||||
new FullQualifiedName(SchemaProvider.NAMESPACE, "BAETTwoKeyNavRTETTwoKeyNavParam");
|
||||
|
||||
public static final FullQualifiedName nameBAETBaseETTwoBaseRTETTwoBase =
|
||||
new FullQualifiedName(SchemaProvider.NAMESPACE, "BAETBaseETTwoBaseRTETTwoBase");
|
||||
|
||||
public static final FullQualifiedName nameBAETMixPrimCollCompRTCTTwoPrim =
|
||||
new FullQualifiedName(SchemaProvider.NAMESPACE, "BAETMixPrimCollCompRTCTTwoPrim");
|
||||
|
||||
public static final FullQualifiedName nameBAETMixPrimCollCompCTTwoPrimRTCTTwoPrim =
|
||||
new FullQualifiedName(SchemaProvider.NAMESPACE, "BAETMixPrimCollCompCTTwoPrimRTCTTwoPrim");
|
||||
|
||||
public static final FullQualifiedName nameBAETMixPrimCollCompCTTWOPrimCompRTCTTwoPrim =
|
||||
new FullQualifiedName(SchemaProvider.NAMESPACE, "BAETMixPrimCollCompCTTWOPrimCompRTCTTwoPrim");
|
||||
|
||||
public static final FullQualifiedName nameBAETMixPrimCollCompCTTWOPrimCompRTCollCTTwoPrim =
|
||||
new FullQualifiedName(SchemaProvider.NAMESPACE, "BAETMixPrimCollCompCTTWOPrimCompRTCollCTTwoPrim");
|
||||
|
||||
public static final FullQualifiedName
|
||||
nameBAETTwoKeyNavCTBasePrimCompNavCTTwoBasePrimCompNavRTCTTwoBasePrimCompNav =
|
||||
new FullQualifiedName(SchemaProvider.NAMESPACE,
|
||||
"BAETTwoKeyNavCTBasePrimCompNavCTTwoBasePrimCompNavRTCTTwoBasePrimCompNav");
|
||||
// Unknown Actions
|
||||
public static final FullQualifiedName name_A_RTTimeOfDay_ =
|
||||
new FullQualifiedName(SchemaProvider.NAMESPACE, "_A_RTTimeOfDay_");
|
||||
|
@ -109,7 +128,7 @@ public class ActionProvider {
|
|||
nameBAETTwoBaseTwoKeyNavRTETBaseTwoKeyNav, nameBA_RTETTwoKeyNav,nameBAESAllPrimRT,
|
||||
nameBAETAllPrimRT, nameBAETTwoPrimRTString, nameBAETTwoPrimRTCollString, nameBAETTwoPrimRTCTAllPrim,
|
||||
nameBAETTwoPrimRTCollCTAllPrim, nameBAETCompAllPrimRTETCompAllPrim, nameBAETTwoKeyNavRTETTwoKeyNavParam,
|
||||
name_A_RTTimeOfDay_ };
|
||||
nameBAETBaseETTwoBaseRTETTwoBase, nameBAETMixPrimCollCompRTCTTwoPrim, name_A_RTTimeOfDay_ };
|
||||
|
||||
List<CsdlAction> actions = new ArrayList<CsdlAction>();
|
||||
for (FullQualifiedName fqn:actionNames) {
|
||||
|
@ -404,9 +423,66 @@ public class ActionProvider {
|
|||
.setParameters(Arrays.asList(
|
||||
new CsdlParameter().setName("BindingParam").setType(EntityTypeProvider.nameETTwoKeyNav)
|
||||
.setNullable(false),
|
||||
new CsdlParameter().setName("ParameterInt16").setType(PropertyProvider.nameInt16)
|
||||
new CsdlParameter().setName("PropertyComp").setType(ComplexTypeProvider.nameCTPrimComp)
|
||||
.setNullable(false)))
|
||||
.setReturnType(new CsdlReturnType().setType(EntityTypeProvider.nameETTwoKeyNav)));
|
||||
} else if (actionName.equals(nameBAETBaseETTwoBaseRTETTwoBase)) {
|
||||
return Collections.singletonList(
|
||||
new CsdlAction().setName(nameBAETBaseETTwoBaseRTETTwoBase.getName())
|
||||
.setBound(true)
|
||||
.setEntitySetPath("BindingParam/olingo.odata.test1.ETTwoBase")
|
||||
.setParameters(Arrays.asList(
|
||||
new CsdlParameter().setName("BindingParam").setType(EntityTypeProvider.nameETBase)
|
||||
.setNullable(false),
|
||||
new CsdlParameter().setName("PropertyString").setType(PropertyProvider.nameString)
|
||||
.setNullable(false),
|
||||
new CsdlParameter().setName("AdditionalPropertyString_5").setType(PropertyProvider.nameString)
|
||||
.setNullable(false),
|
||||
new CsdlParameter().setName("AdditionalPropertyString_6").setType(PropertyProvider.nameString)
|
||||
.setNullable(false)))
|
||||
.setReturnType(new CsdlReturnType().setType(EntityTypeProvider.nameETTwoBase)));
|
||||
} else if (actionName.equals(nameBAETMixPrimCollCompRTCTTwoPrim)) {
|
||||
return Collections.singletonList(
|
||||
new CsdlAction().setName(nameBAETMixPrimCollCompRTCTTwoPrim.getName())
|
||||
.setBound(true)
|
||||
.setParameters(Arrays.asList(
|
||||
new CsdlParameter().setName("BindingParam").setType(EntityTypeProvider.nameETMixPrimCollComp)
|
||||
.setNullable(false),
|
||||
new CsdlParameter().setName("CollPropertyComp").setType(ComplexTypeProvider.nameCTTwoPrim)
|
||||
.setNullable(false).setCollection(true)))
|
||||
.setReturnType(new CsdlReturnType().setType(ComplexTypeProvider.nameCTTwoPrim).setCollection(true)));
|
||||
} else if (actionName.equals(nameBAETMixPrimCollCompCTTWOPrimCompRTCTTwoPrim)) {
|
||||
return Collections.singletonList(
|
||||
new CsdlAction().setName(nameBAETMixPrimCollCompCTTWOPrimCompRTCTTwoPrim.getName())
|
||||
.setBound(true)
|
||||
.setEntitySetPath("BindingParam")
|
||||
.setParameters(Arrays.asList(
|
||||
new CsdlParameter().setName("BindingParam").setType(EntityTypeProvider.nameETMixPrimCollComp)
|
||||
.setNullable(false),
|
||||
new CsdlParameter().setName("PropertyComp").setType(ComplexTypeProvider.nameCTTwoPrim)
|
||||
.setNullable(false)))
|
||||
.setReturnType(new CsdlReturnType().setType(ComplexTypeProvider.nameCTTwoPrim)));
|
||||
} else if (actionName.equals(nameBAETMixPrimCollCompCTTWOPrimCompRTCollCTTwoPrim)) {
|
||||
return Collections.singletonList(
|
||||
new CsdlAction().setName(nameBAETMixPrimCollCompCTTWOPrimCompRTCollCTTwoPrim.getName())
|
||||
.setBound(true)
|
||||
.setEntitySetPath("BindingParam/CollPropertyComp")
|
||||
.setParameters(Arrays.asList(
|
||||
new CsdlParameter().setName("BindingParam").setType(EntityTypeProvider.nameETMixPrimCollComp)
|
||||
.setNullable(false).setCollection(true),
|
||||
new CsdlParameter().setName("PropertyComp").setType(ComplexTypeProvider.nameCTTwoPrim)
|
||||
.setNullable(false)))
|
||||
.setReturnType(new CsdlReturnType().setType(ComplexTypeProvider.nameCTTwoPrim).setCollection(true)));
|
||||
} else if (actionName.equals(nameBAETTwoKeyNavCTBasePrimCompNavCTTwoBasePrimCompNavRTCTTwoBasePrimCompNav)) {
|
||||
return Collections.singletonList(
|
||||
new CsdlAction().setName(
|
||||
nameBAETTwoKeyNavCTBasePrimCompNavCTTwoBasePrimCompNavRTCTTwoBasePrimCompNav.getName())
|
||||
.setBound(true)
|
||||
.setEntitySetPath("BindingParam/PropertyCompNav/olingo.odata.test1.CTTwoBasePrimCompNav")
|
||||
.setParameters(Arrays.asList(
|
||||
new CsdlParameter().setName("BindingParam").setType(EntityTypeProvider.nameETTwoKeyNav)
|
||||
.setNullable(false)))
|
||||
.setReturnType(new CsdlReturnType().setType(ComplexTypeProvider.nameCTTwoBasePrimCompNav)));
|
||||
}
|
||||
return null;
|
||||
}
|
||||
|
|
|
@ -128,6 +128,12 @@ public class SchemaProvider {
|
|||
actions.addAll(prov.getActions(ActionProvider.nameBAETTwoPrimRTCollCTAllPrim));
|
||||
actions.addAll(prov.getActions(ActionProvider.nameBAETCompAllPrimRTETCompAllPrim));
|
||||
actions.addAll(prov.getActions(ActionProvider.nameBAETTwoKeyNavRTETTwoKeyNavParam));
|
||||
actions.addAll(prov.getActions(ActionProvider.nameBAETMixPrimCollCompRTCTTwoPrim));
|
||||
actions.addAll(prov.getActions(ActionProvider.nameBAETBaseETTwoBaseRTETTwoBase));
|
||||
actions.addAll(prov.getActions(ActionProvider.nameBAETMixPrimCollCompCTTWOPrimCompRTCollCTTwoPrim));
|
||||
actions.addAll(prov.getActions(ActionProvider.nameBAETMixPrimCollCompCTTWOPrimCompRTCTTwoPrim));
|
||||
actions.addAll(prov.getActions(ActionProvider.
|
||||
nameBAETTwoKeyNavCTBasePrimCompNavCTTwoBasePrimCompNavRTCTTwoBasePrimCompNav));
|
||||
actions.addAll(prov.getActions(ActionProvider.nameUARTString));
|
||||
actions.addAll(prov.getActions(ActionProvider.nameUARTCollStringTwoParam));
|
||||
actions.addAll(prov.getActions(ActionProvider.nameUARTCTTwoPrimParam));
|
||||
|
|
|
@ -678,6 +678,9 @@ public class ODataXmlSerializerTest {
|
|||
" </d:CollPropertyComp>\n" +
|
||||
" </m:properties>\n" +
|
||||
" </a:content>\n" +
|
||||
" <m:action metadata=\"#olingo.odata.test1.BAETMixPrimCollCompRTCTTwoPrim\" "
|
||||
+ "title=\"olingo.odata.test1.BAETMixPrimCollCompRTCTTwoPrim\" "
|
||||
+ "target=\"ESMixPrimCollComp(32767)/olingo.odata.test1.BAETMixPrimCollCompRTCTTwoPrim\"/>\n" +
|
||||
"</a:entry>\n";
|
||||
checkXMLEqual(expectedResult, resultString);
|
||||
}
|
||||
|
@ -718,6 +721,9 @@ public class ODataXmlSerializerTest {
|
|||
" <d:CollPropertyComp m:null=\"true\" />\n" +
|
||||
" </m:properties>\n" +
|
||||
" </a:content>\n" +
|
||||
" <m:action metadata=\"#olingo.odata.test1.BAETMixPrimCollCompRTCTTwoPrim\" "
|
||||
+ "title=\"olingo.odata.test1.BAETMixPrimCollCompRTCTTwoPrim\" "
|
||||
+ "target=\"ESMixPrimCollComp(32767)/olingo.odata.test1.BAETMixPrimCollCompRTCTTwoPrim\"/>\n" +
|
||||
"</a:entry>";
|
||||
checkXMLEqual(expectedResult, resultString);
|
||||
}
|
||||
|
@ -2350,6 +2356,9 @@ public class ODataXmlSerializerTest {
|
|||
" <d:AdditionalPropertyString_5>TEST A 0815</d:AdditionalPropertyString_5>\n "+
|
||||
" </m:properties>\n "+
|
||||
" </a:content>\n "+
|
||||
" <m:action metadata=\"#olingo.odata.test1.BAETBaseETTwoBaseRTETTwoBase\" "
|
||||
+ "title=\"olingo.odata.test1.BAETBaseETTwoBaseRTETTwoBase\" "
|
||||
+ "target=\"ESBase(111)/olingo.odata.test1.BAETBaseETTwoBaseRTETTwoBase\"/>\n" +
|
||||
" </a:entry>\n "+
|
||||
" </m:inline>\n "+
|
||||
" </a:link>" +
|
||||
|
|
Loading…
Reference in New Issue