[OLINGO-694] Minor code clean up in tutorials
This commit is contained in:
parent
93999d510e
commit
431938c1e6
|
@ -38,25 +38,13 @@ import org.apache.olingo.server.api.uri.UriResourceEntitySet;
|
|||
|
||||
public class Util {
|
||||
|
||||
public static EdmEntitySet getEdmEntitySet(UriInfoResource uriInfo) throws ODataApplicationException {
|
||||
List<UriResource> resourcePaths = uriInfo.getUriResourceParts();
|
||||
// To get the entity set we have to interpret all URI segments
|
||||
if (!(resourcePaths.get(0) instanceof UriResourceEntitySet)) {
|
||||
// Here we should interpret the whole URI but in this example we do not support navigation so we throw an exception
|
||||
throw new ODataApplicationException("Invalid resource type for first segment.", HttpStatusCode.NOT_IMPLEMENTED.getStatusCode(),Locale.ENGLISH);
|
||||
}
|
||||
|
||||
UriResourceEntitySet uriResource = (UriResourceEntitySet) resourcePaths.get(0);
|
||||
|
||||
return uriResource.getEntitySet();
|
||||
}
|
||||
|
||||
|
||||
public static Entity findEntity(EdmEntityType edmEntityType, EntityCollection entitySet, List<UriParameter> keyParams) throws ODataApplicationException {
|
||||
public static Entity findEntity(EdmEntityType edmEntityType, EntityCollection entitySet,
|
||||
List<UriParameter> keyParams) throws ODataApplicationException {
|
||||
|
||||
List<Entity> entityList = entitySet.getEntities();
|
||||
|
||||
// loop over all entities in order to find that one that matches all keys in request e.g. contacts(ContactID=1, CompanyID=1)
|
||||
// loop over all entities in order to find that one that matches all keys in request
|
||||
// e.g. contacts(ContactID=1, CompanyID=1)
|
||||
for (Entity entity: entityList) {
|
||||
boolean foundEntity = entityMatchesAllKeys(edmEntityType, entity, keyParams);
|
||||
if (foundEntity) {
|
||||
|
@ -67,9 +55,7 @@ public class Util {
|
|||
return null;
|
||||
}
|
||||
|
||||
|
||||
public static boolean
|
||||
entityMatchesAllKeys(EdmEntityType edmEntityType, Entity rt_entity, List<UriParameter> keyParams)
|
||||
public static boolean entityMatchesAllKeys(EdmEntityType edmEntityType, Entity entity, List<UriParameter> keyParams)
|
||||
throws ODataApplicationException {
|
||||
|
||||
// loop over all keys
|
||||
|
@ -87,21 +73,20 @@ public class Util {
|
|||
Integer scale = edmKeyProperty.getScale();
|
||||
// get the EdmType in order to compare
|
||||
EdmType edmType = edmKeyProperty.getType();
|
||||
// if(EdmType instanceof EdmPrimitiveType) // do we need this?
|
||||
EdmPrimitiveType edmPrimitiveType = (EdmPrimitiveType) edmType;
|
||||
|
||||
// Runtime data: the value of the current entity
|
||||
// don't need to check for null, this is done in olingo library
|
||||
Object valueObject = rt_entity.getProperty(keyName).getValue();
|
||||
Object valueObject = entity.getProperty(keyName).getValue();
|
||||
|
||||
// now need to compare the valueObject with the keyText String
|
||||
// this is done using type.valueToString
|
||||
String valueAsString = null;
|
||||
// this is done using the type.valueToString
|
||||
String valueAsString;
|
||||
try {
|
||||
valueAsString = edmPrimitiveType.valueToString(valueObject, isNullable, maxLength, precision, scale, isUnicode);
|
||||
} catch (EdmPrimitiveTypeException e) {
|
||||
throw new ODataApplicationException("Failed to retrieve String value",
|
||||
HttpStatusCode.INTERNAL_SERVER_ERROR.getStatusCode(), Locale.ENGLISH, e);
|
||||
throw new ODataApplicationException("Failed to retrieve String value", HttpStatusCode.INTERNAL_SERVER_ERROR
|
||||
.getStatusCode(), Locale.ENGLISH, e);
|
||||
}
|
||||
|
||||
if (valueAsString == null) {
|
||||
|
|
|
@ -38,21 +38,15 @@ import java.util.Locale;
|
|||
|
||||
public class Storage {
|
||||
|
||||
|
||||
private List<Entity> productList;
|
||||
|
||||
|
||||
public Storage() {
|
||||
|
||||
productList = new ArrayList<Entity>();
|
||||
initSampleData();
|
||||
}
|
||||
|
||||
|
||||
|
||||
/* PUBLIC FACADE */
|
||||
|
||||
|
||||
public EntityCollection readEntitySetData(EdmEntitySet edmEntitySet) throws ODataApplicationException {
|
||||
|
||||
// actually, this is only required if we have more than one Entity Sets
|
||||
|
@ -63,8 +57,8 @@ public class Storage {
|
|||
return null;
|
||||
}
|
||||
|
||||
|
||||
public Entity readEntityData(EdmEntitySet edmEntitySet, List<UriParameter> keyParams) throws ODataApplicationException{
|
||||
public Entity readEntityData(EdmEntitySet edmEntitySet, List<UriParameter> keyParams)
|
||||
throws ODataApplicationException {
|
||||
|
||||
EdmEntityType edmEntityType = edmEntitySet.getEntityType();
|
||||
|
||||
|
@ -76,7 +70,6 @@ public class Storage {
|
|||
return null;
|
||||
}
|
||||
|
||||
|
||||
public Entity createEntityData(EdmEntitySet edmEntitySet, Entity entityToCreate) {
|
||||
|
||||
EdmEntityType edmEntityType = edmEntitySet.getEntityType();
|
||||
|
@ -89,11 +82,11 @@ public class Storage {
|
|||
return null;
|
||||
}
|
||||
|
||||
|
||||
/**
|
||||
* This method is invoked for PATCH or PUT requests
|
||||
* */
|
||||
public void updateEntityData(EdmEntitySet edmEntitySet, List<UriParameter> keyParams, Entity updateEntity, HttpMethod httpMethod) throws ODataApplicationException{
|
||||
public void updateEntityData(EdmEntitySet edmEntitySet, List<UriParameter> keyParams, Entity updateEntity,
|
||||
HttpMethod httpMethod) throws ODataApplicationException {
|
||||
|
||||
EdmEntityType edmEntityType = edmEntitySet.getEntityType();
|
||||
|
||||
|
@ -103,8 +96,8 @@ public class Storage {
|
|||
}
|
||||
}
|
||||
|
||||
|
||||
public void deleteEntityData(EdmEntitySet edmEntitySet, List<UriParameter> keyParams) throws ODataApplicationException{
|
||||
public void deleteEntityData(EdmEntitySet edmEntitySet, List<UriParameter> keyParams)
|
||||
throws ODataApplicationException {
|
||||
|
||||
EdmEntityType edmEntityType = edmEntitySet.getEntityType();
|
||||
|
||||
|
@ -114,8 +107,6 @@ public class Storage {
|
|||
}
|
||||
}
|
||||
|
||||
|
||||
|
||||
/* INTERNAL */
|
||||
|
||||
private EntityCollection getProducts() {
|
||||
|
@ -128,8 +119,8 @@ public class Storage {
|
|||
return retEntitySet;
|
||||
}
|
||||
|
||||
|
||||
private Entity getProduct(EdmEntityType edmEntityType, List<UriParameter> keyParams) throws ODataApplicationException{
|
||||
private Entity getProduct(EdmEntityType edmEntityType, List<UriParameter> keyParams)
|
||||
throws ODataApplicationException {
|
||||
|
||||
// the list of entities at runtime
|
||||
EntityCollection entitySet = getProducts();
|
||||
|
@ -137,7 +128,6 @@ public class Storage {
|
|||
/* generic approach to find the requested entity */
|
||||
Entity requestedEntity = Util.findEntity(edmEntityType, entitySet, keyParams);
|
||||
|
||||
|
||||
if (requestedEntity == null) {
|
||||
// this variable is null if our data doesn't contain an entity for the requested key
|
||||
// Throw suitable exception
|
||||
|
@ -148,7 +138,6 @@ public class Storage {
|
|||
return requestedEntity;
|
||||
}
|
||||
|
||||
|
||||
private Entity createProduct(EdmEntityType edmEntityType, Entity entity) {
|
||||
|
||||
// the ID of the newly created product entity is generated automatically
|
||||
|
@ -171,7 +160,6 @@ public class Storage {
|
|||
|
||||
}
|
||||
|
||||
|
||||
private boolean productIdExists(int id) {
|
||||
|
||||
for (Entity entity : this.productList) {
|
||||
|
@ -184,8 +172,8 @@ public class Storage {
|
|||
return false;
|
||||
}
|
||||
|
||||
|
||||
private void updateProduct(EdmEntityType edmEntityType, List<UriParameter> keyParams, Entity entity, HttpMethod httpMethod) throws ODataApplicationException{
|
||||
private void updateProduct(EdmEntityType edmEntityType, List<UriParameter> keyParams, Entity entity,
|
||||
HttpMethod httpMethod) throws ODataApplicationException {
|
||||
|
||||
Entity productEntity = getProduct(edmEntityType, keyParams);
|
||||
if (productEntity == null) {
|
||||
|
@ -223,7 +211,8 @@ public class Storage {
|
|||
}
|
||||
}
|
||||
|
||||
private void deleteProduct(EdmEntityType edmEntityType, List<UriParameter> keyParams) throws ODataApplicationException{
|
||||
private void deleteProduct(EdmEntityType edmEntityType, List<UriParameter> keyParams)
|
||||
throws ODataApplicationException {
|
||||
|
||||
Entity productEntity = getProduct(edmEntityType, keyParams);
|
||||
if (productEntity == null) {
|
||||
|
@ -233,11 +222,8 @@ public class Storage {
|
|||
this.productList.remove(productEntity);
|
||||
}
|
||||
|
||||
|
||||
|
||||
/* HELPER */
|
||||
|
||||
|
||||
private boolean isKey(EdmEntityType edmEntityType, String propertyName) {
|
||||
List<EdmKeyPropertyRef> keyPropertyRefs = edmEntityType.getKeyPropertyRefs();
|
||||
for (EdmKeyPropertyRef propRef : keyPropertyRefs) {
|
||||
|
@ -249,24 +235,29 @@ public class Storage {
|
|||
return false;
|
||||
}
|
||||
|
||||
|
||||
private void initSampleData() {
|
||||
|
||||
// add some sample product entities
|
||||
productList.add(new Entity()
|
||||
.addProperty(new Property(null, "ID", ValueType.PRIMITIVE, 1))
|
||||
.addProperty(new Property(null, "Name", ValueType.PRIMITIVE, "Notebook Basic 15"))
|
||||
.addProperty(new Property(null, "Description", ValueType.PRIMITIVE, "Notebook Basic, 1.7GHz - 15 XGA - 1024MB DDR2 SDRAM - 40GB")));
|
||||
.addProperty(
|
||||
new Property(null, "Description", ValueType.PRIMITIVE,
|
||||
"Notebook Basic, 1.7GHz - 15 XGA - 1024MB DDR2 SDRAM - 40GB")));
|
||||
|
||||
productList.add(new Entity()
|
||||
.addProperty(new Property(null, "ID", ValueType.PRIMITIVE, 2))
|
||||
.addProperty(new Property(null, "Name", ValueType.PRIMITIVE, "1UMTS PDA"))
|
||||
.addProperty(new Property(null, "Description", ValueType.PRIMITIVE, "Ultrafast 3G UMTS/HSDPA Pocket PC, supports GSM network")));
|
||||
.addProperty(
|
||||
new Property(null, "Description", ValueType.PRIMITIVE,
|
||||
"Ultrafast 3G UMTS/HSDPA Pocket PC, supports GSM network")));
|
||||
|
||||
productList.add(new Entity()
|
||||
.addProperty(new Property(null, "ID", ValueType.PRIMITIVE, 3))
|
||||
.addProperty(new Property(null, "Name", ValueType.PRIMITIVE, "Ergo Screen"))
|
||||
.addProperty(new Property(null, "Description", ValueType.PRIMITIVE, "19 Optimum Resolution 1024 x 768 @ 85Hz, resolution 1280 x 960")));
|
||||
.addProperty(
|
||||
new Property(null, "Description", ValueType.PRIMITIVE,
|
||||
"19 Optimum Resolution 1024 x 768 @ 85Hz, resolution 1280 x 960")));
|
||||
|
||||
}
|
||||
}
|
||||
|
|
|
@ -42,7 +42,6 @@ import org.apache.olingo.commons.api.edm.provider.CsdlSchema;
|
|||
*/
|
||||
public class DemoEdmProvider extends CsdlAbstractEdmProvider {
|
||||
|
||||
|
||||
// Service Namespace
|
||||
public static final String NAMESPACE = "OData.Demo";
|
||||
|
||||
|
@ -87,9 +86,12 @@ public class DemoEdmProvider extends CsdlAbstractEdmProvider {
|
|||
if(entityTypeName.equals(ET_PRODUCT_FQN)){
|
||||
|
||||
//create EntityType properties
|
||||
CsdlProperty id = new CsdlProperty().setName("ID").setType(EdmPrimitiveTypeKind.Int32.getFullQualifiedName());
|
||||
CsdlProperty name = new CsdlProperty().setName("Name").setType(EdmPrimitiveTypeKind.String.getFullQualifiedName());
|
||||
CsdlProperty description = new CsdlProperty().setName("Description").setType(EdmPrimitiveTypeKind.String.getFullQualifiedName());
|
||||
CsdlProperty id = new CsdlProperty().setName("ID")
|
||||
.setType(EdmPrimitiveTypeKind.Int32.getFullQualifiedName());
|
||||
CsdlProperty name = new CsdlProperty().setName("Name")
|
||||
.setType(EdmPrimitiveTypeKind.String.getFullQualifiedName());
|
||||
CsdlProperty description = new CsdlProperty().setName("Description")
|
||||
.setType(EdmPrimitiveTypeKind.String.getFullQualifiedName());
|
||||
|
||||
// create CsdlPropertyRef for Key element
|
||||
CsdlPropertyRef propertyRef = new CsdlPropertyRef();
|
||||
|
|
|
@ -57,12 +57,10 @@ public class DemoEntityProcessor implements EntityProcessor {
|
|||
private Storage storage;
|
||||
private ServiceMetadata serviceMetadata;
|
||||
|
||||
|
||||
public DemoEntityProcessor(Storage storage) {
|
||||
this.storage = storage;
|
||||
}
|
||||
|
||||
|
||||
public void init(OData odata, ServiceMetadata serviceMetadata) {
|
||||
this.odata = odata;
|
||||
this.serviceMetadata = serviceMetadata;
|
||||
|
@ -111,7 +109,8 @@ public class DemoEntityProcessor implements EntityProcessor {
|
|||
"Description":"17 Optimum Resolution 1024 x 768 @ 85Hz, resolution 1280 x 960"
|
||||
}
|
||||
* */
|
||||
public void createEntity(ODataRequest request, ODataResponse response, UriInfo uriInfo, ContentType requestFormat, ContentType responseFormat)
|
||||
public void createEntity(ODataRequest request, ODataResponse response, UriInfo uriInfo,
|
||||
ContentType requestFormat, ContentType responseFormat)
|
||||
throws ODataApplicationException, DeserializerException, SerializerException {
|
||||
|
||||
// 1. Retrieve the entity type from the URI
|
||||
|
@ -143,7 +142,8 @@ public class DemoEntityProcessor implements EntityProcessor {
|
|||
}
|
||||
|
||||
|
||||
public void updateEntity(ODataRequest request, ODataResponse response, UriInfo uriInfo, ContentType requestFormat, ContentType responseFormat)
|
||||
public void updateEntity(ODataRequest request, ODataResponse response, UriInfo uriInfo,
|
||||
ContentType requestFormat, ContentType responseFormat)
|
||||
throws ODataApplicationException, DeserializerException, SerializerException {
|
||||
|
||||
// 1. Retrieve the entity set which belongs to the requested entity
|
||||
|
@ -171,7 +171,8 @@ public class DemoEntityProcessor implements EntityProcessor {
|
|||
}
|
||||
|
||||
|
||||
public void deleteEntity(ODataRequest request, ODataResponse response, UriInfo uriInfo) throws ODataApplicationException {
|
||||
public void deleteEntity(ODataRequest request, ODataResponse response, UriInfo uriInfo)
|
||||
throws ODataApplicationException {
|
||||
|
||||
// 1. Retrieve the entity set which belongs to the requested entity
|
||||
List<UriResource> resourcePaths = uriInfo.getUriResourceParts();
|
||||
|
|
|
@ -63,7 +63,6 @@ public class DemoPrimitiveProcessor implements PrimitiveProcessor {
|
|||
this.odata = odata;
|
||||
}
|
||||
|
||||
|
||||
/*
|
||||
* In our example, the URL would be: http://localhost:8080/DemoService/DemoService.svc/Products(1)/Name
|
||||
* and the response:
|
||||
|
@ -97,13 +96,15 @@ public class DemoPrimitiveProcessor implements PrimitiveProcessor {
|
|||
// 2.1. retrieve the entity data, for which the property has to be read
|
||||
Entity entity = storage.readEntityData(edmEntitySet, keyPredicates);
|
||||
if (entity == null) { // Bad request
|
||||
throw new ODataApplicationException("Entity not found", HttpStatusCode.NOT_FOUND.getStatusCode(), Locale.ENGLISH);
|
||||
throw new ODataApplicationException("Entity not found",
|
||||
HttpStatusCode.NOT_FOUND.getStatusCode(), Locale.ENGLISH);
|
||||
}
|
||||
|
||||
// 2.2. retrieve the property data from the entity
|
||||
Property property = entity.getProperty(edmPropertyName);
|
||||
if (property == null) {
|
||||
throw new ODataApplicationException("Property not found", HttpStatusCode.NOT_FOUND.getStatusCode(), Locale.ENGLISH);
|
||||
throw new ODataApplicationException("Property not found",
|
||||
HttpStatusCode.NOT_FOUND.getStatusCode(), Locale.ENGLISH);
|
||||
}
|
||||
|
||||
// 3. serialize
|
||||
|
@ -132,12 +133,14 @@ public class DemoPrimitiveProcessor implements PrimitiveProcessor {
|
|||
* These processor methods are not handled in this tutorial
|
||||
*
|
||||
* */
|
||||
public void updatePrimitive(ODataRequest request, ODataResponse response, UriInfo uriInfo, ContentType requestFormat, ContentType responseFormat)
|
||||
public void updatePrimitive(ODataRequest request, ODataResponse response, UriInfo uriInfo,
|
||||
ContentType requestFormat, ContentType responseFormat)
|
||||
throws ODataApplicationException, DeserializerException, SerializerException {
|
||||
throw new ODataApplicationException("Not supported.", HttpStatusCode.NOT_IMPLEMENTED.getStatusCode(), Locale.ROOT);
|
||||
}
|
||||
|
||||
public void deletePrimitive(ODataRequest request, ODataResponse response, UriInfo uriInfo) throws ODataApplicationException {
|
||||
public void deletePrimitive(ODataRequest request, ODataResponse response, UriInfo uriInfo)
|
||||
throws ODataApplicationException {
|
||||
throw new ODataApplicationException("Not supported.", HttpStatusCode.NOT_IMPLEMENTED.getStatusCode(), Locale.ROOT);
|
||||
}
|
||||
}
|
||||
|
|
|
@ -71,8 +71,7 @@ public class Util {
|
|||
return null;
|
||||
}
|
||||
|
||||
public static boolean
|
||||
entityMatchesAllKeys(EdmEntityType edmEntityType, Entity entity, List<UriParameter> keyParams)
|
||||
public static boolean entityMatchesAllKeys(EdmEntityType edmEntityType, Entity entity, List<UriParameter> keyParams)
|
||||
throws ODataApplicationException {
|
||||
|
||||
// loop over all keys
|
||||
|
|
Loading…
Reference in New Issue