org.odata4j.producer.jpa
Class JPAProducer

java.lang.Object
  extended by org.odata4j.producer.jpa.JPAProducer
All Implemented Interfaces:
OExtensible<ODataProducer>, ODataProducer

public class JPAProducer
extends Object
implements ODataProducer


Nested Class Summary
static class JPAProducer.CommandType
           
 
Constructor Summary
JPAProducer(EntityManagerFactory emf, EdmDataServices metadata, int maxResults)
           
JPAProducer(EntityManagerFactory emf, EdmDataServices metadata, int maxResults, EdmDecorator metadataDecorator)
           
JPAProducer(EntityManagerFactory emf, EdmDataServices metadata, int maxResults, EdmDecorator metadataDecorator, JPAProducerBehavior producerBehavior)
           
JPAProducer(EntityManagerFactory emf, String namespace, int maxResults)
           
 
Method Summary
 BaseResponse callFunction(EdmFunctionImport name, Map<String,OFunctionParameter> params, QueryInfo queryInfo)
          Calls a function (aka Service Operation).
 void close()
          Releases any resources managed by this producer.
 EntityResponse createEntity(String entitySetName, OEntity entity)
          Creates a new OData entity.
 EntityResponse createEntity(String entitySetName, OEntityKey entityKey, String navProp, OEntity entity)
          Creates a new OData entity as a reference of an existing entity, implicitly linked to the existing entity by a navigation property.
 void createLink(OEntityId sourceEntity, String targetNavProp, OEntityId targetEntity)
          Creates a link between two entities.
 void deleteEntity(String entitySetName, OEntityKey entityKey)
          Deletes an existing entity.
 void deleteLink(OEntityId sourceEntity, String targetNavProp, OEntityKey targetEntityKey)
          Deletes an existing link between two entities.
<TExtension extends OExtension<ODataProducer>>
TExtension
findExtension(Class<TExtension> clazz)
          Finds an extension instance given an interface, if one exists.
 EntitiesResponse getEntities(String entitySetName, QueryInfo queryInfo)
          Gets all the entities for a given set matching the query information.
 CountResponse getEntitiesCount(String entitySetName, QueryInfo queryInfo)
          Gets the count of all the entities for a given set matching the query information.
 EntityResponse getEntity(String entitySetName, OEntityKey entityKey, EntityQueryInfo queryInfo)
          Obtains a single entity based on its type and key.
 EntityIdResponse getLinks(OEntityId sourceEntity, String targetNavProp)
          Returns the value of an entity's navigation property as a collection of entity links (or a single link if the association cardinality is 1).
 EdmDataServices getMetadata()
          Obtains the service metadata for this producer.
 MetadataProducer getMetadataProducer()
          Obtains the ODataProducer implementation that serves the metadata as OData EDM constructs.
 BaseResponse getNavProperty(String entitySetName, OEntityKey entityKey, String navProp, QueryInfo queryInfo)
          Given a specific entity, follow one of its navigation properties, applying constraints as appropriate.
 CountResponse getNavPropertyCount(String entitySetName, OEntityKey entityKey, String navProp, QueryInfo queryInfo)
          Given a specific entity, follow one of its navigation properties, applying constraints as appropriate.
protected  void initCommandChains()
           
 void mergeEntity(String entitySetName, OEntity entity)
          Modifies an existing entity using merge semantics.
 void updateEntity(String entitySetName, OEntity entity)
          Modifies an existing entity using update semantics.
 void updateLink(OEntityId sourceEntity, String targetNavProp, OEntityKey oldTargetEntityKey, OEntityId newTargetEntity)
          Replaces an existing link between two entities.
 
Methods inherited from class java.lang.Object
clone, equals, finalize, getClass, hashCode, notify, notifyAll, toString, wait, wait, wait
 

Constructor Detail

JPAProducer

public JPAProducer(EntityManagerFactory emf,
                   EdmDataServices metadata,
                   int maxResults)

JPAProducer

public JPAProducer(EntityManagerFactory emf,
                   EdmDataServices metadata,
                   int maxResults,
                   EdmDecorator metadataDecorator)

JPAProducer

public JPAProducer(EntityManagerFactory emf,
                   EdmDataServices metadata,
                   int maxResults,
                   EdmDecorator metadataDecorator,
                   JPAProducerBehavior producerBehavior)

JPAProducer

public JPAProducer(EntityManagerFactory emf,
                   String namespace,
                   int maxResults)
Method Detail

callFunction

public BaseResponse callFunction(EdmFunctionImport name,
                                 Map<String,OFunctionParameter> params,
                                 QueryInfo queryInfo)
Description copied from interface: ODataProducer
Calls a function (aka Service Operation).

Specified by:
callFunction in interface ODataProducer
Parameters:
name - the name of the function
params - the parameters to the function
queryInfo - additional query parameters to apply to collection-valued results
Returns:
a BaseResponse appropriately typed to hold the function results From the spec:
    The return type of <Function> MUST be one of the following:
        An EDMSimpleType or collection of EDMSimpleTypes.
        An entity type or collection of entity types.
        A complex type or collection of complex types.
        A row type or collection of row types.
        <ReturnType> can contain a maximum of one <CollectionType> element.
        <ReturnType> can contain a maximum of one <ReferenceType> element.
        <ReturnType> can contain a maximum of one <RowType> element.
        A ref type or collection of ref types.

close

public void close()
Description copied from interface: ODataProducer
Releases any resources managed by this producer.

Specified by:
close in interface ODataProducer

createEntity

public EntityResponse createEntity(String entitySetName,
                                   OEntity entity)
Description copied from interface: ODataProducer
Creates a new OData entity.

Specified by:
createEntity in interface ODataProducer
Parameters:
entitySetName - the entity-set name
entity - the request entity sent from the client
Returns:
the newly-created entity, fully populated with the key and default properties
See Also:
[odata.org] Creating new Entries

createEntity

public EntityResponse createEntity(String entitySetName,
                                   OEntityKey entityKey,
                                   String navProp,
                                   OEntity entity)
Description copied from interface: ODataProducer
Creates a new OData entity as a reference of an existing entity, implicitly linked to the existing entity by a navigation property.

Specified by:
createEntity in interface ODataProducer
Parameters:
entitySetName - the entity-set name of the existing entity
entityKey - the entity-key of the existing entity
navProp - the navigation property off of the existing entity
entity - the request entity sent from the client
Returns:
the newly-created entity, fully populated with the key and default properties, and linked to the existing entity
See Also:
[odata.org] Creating new Entries

createLink

public void createLink(OEntityId sourceEntity,
                       String targetNavProp,
                       OEntityId targetEntity)
Description copied from interface: ODataProducer
Creates a link between two entities.

Specified by:
createLink in interface ODataProducer
Parameters:
sourceEntity - an entity with at least one navigation property
targetNavProp - the navigation property
targetEntity - the link target entity
See Also:
[odata.org] Creating Links between Entries

deleteEntity

public void deleteEntity(String entitySetName,
                         OEntityKey entityKey)
Description copied from interface: ODataProducer
Deletes an existing entity.

Specified by:
deleteEntity in interface ODataProducer
Parameters:
entitySetName - the entity-set name of the entity
entityKey - the entity-key of the entity
See Also:
[odata.org] Deleting Entries

deleteLink

public void deleteLink(OEntityId sourceEntity,
                       String targetNavProp,
                       OEntityKey targetEntityKey)
Description copied from interface: ODataProducer
Deletes an existing link between two entities.

Specified by:
deleteLink in interface ODataProducer
Parameters:
sourceEntity - an entity with at least one navigation property
targetNavProp - the navigation property
targetEntityKey - if the navigation property represents a set, the key identifying the target entity within the set, else n/a

findExtension

public <TExtension extends OExtension<ODataProducer>> TExtension findExtension(Class<TExtension> clazz)
Description copied from interface: OExtensible
Finds an extension instance given an interface, if one exists.

Specified by:
findExtension in interface OExtensible<ODataProducer>
Type Parameters:
TExtension - type of extension
Parameters:
clazz - the extension interface
Returns:
the extension instance, or null if no extension exists for this type

getEntities

public EntitiesResponse getEntities(String entitySetName,
                                    QueryInfo queryInfo)
Description copied from interface: ODataProducer
Gets all the entities for a given set matching the query information.

Specified by:
getEntities in interface ODataProducer
Parameters:
entitySetName - the entity-set name for entities to return
queryInfo - the additional constraints to apply to the entities
Returns:
a packaged collection of entities to pass back to the client

getEntitiesCount

public CountResponse getEntitiesCount(String entitySetName,
                                      QueryInfo queryInfo)
Description copied from interface: ODataProducer
Gets the count of all the entities for a given set matching the query information.

Specified by:
getEntitiesCount in interface ODataProducer
Parameters:
entitySetName - the entity-set name for entities whose count is returned
queryInfo - the additional constraints to apply to the entities
Returns:
count of the entities

getEntity

public EntityResponse getEntity(String entitySetName,
                                OEntityKey entityKey,
                                EntityQueryInfo queryInfo)
Description copied from interface: ODataProducer
Obtains a single entity based on its type and key.

Specified by:
getEntity in interface ODataProducer
Parameters:
entitySetName - the entity-set name for entities to return
entityKey - the unique entity-key of the entity to start with
queryInfo - the additional constraints applicable to single-entity queries
Returns:
the resulting entity

getLinks

public EntityIdResponse getLinks(OEntityId sourceEntity,
                                 String targetNavProp)
Description copied from interface: ODataProducer
Returns the value of an entity's navigation property as a collection of entity links (or a single link if the association cardinality is 1).

Specified by:
getLinks in interface ODataProducer
Parameters:
sourceEntity - an entity with at least one navigation property
targetNavProp - the navigation property
Returns:
a collection of entity links (or a single link if the association cardinality is 1)

getMetadata

public EdmDataServices getMetadata()
Description copied from interface: ODataProducer
Obtains the service metadata for this producer.

Specified by:
getMetadata in interface ODataProducer
Returns:
a fully-constructed metadata object

getMetadataProducer

public MetadataProducer getMetadataProducer()
Description copied from interface: ODataProducer
Obtains the ODataProducer implementation that serves the metadata as OData EDM constructs.

Specified by:
getMetadataProducer in interface ODataProducer
Returns:
the MetadataProducer object

getNavProperty

public BaseResponse getNavProperty(String entitySetName,
                                   OEntityKey entityKey,
                                   String navProp,
                                   QueryInfo queryInfo)
Description copied from interface: ODataProducer
Given a specific entity, follow one of its navigation properties, applying constraints as appropriate. Return the resulting entity, entities, or property value.

Specified by:
getNavProperty in interface ODataProducer
Parameters:
entitySetName - the entity-set of the entity to start with
entityKey - the unique entity-key of the entity to start with
navProp - the navigation property to follow
queryInfo - additional constraints to apply to the result
Returns:
the resulting entity, entities, or property value

getNavPropertyCount

public CountResponse getNavPropertyCount(String entitySetName,
                                         OEntityKey entityKey,
                                         String navProp,
                                         QueryInfo queryInfo)
Description copied from interface: ODataProducer
Given a specific entity, follow one of its navigation properties, applying constraints as appropriate. Return the count of the resulting entities.

Specified by:
getNavPropertyCount in interface ODataProducer
Parameters:
entitySetName - the entity-set of the entity to start with
entityKey - the unique entity-key of the entity to start with
navProp - the navigation property to follow
queryInfo - additional constraints to apply to the result
Returns:
the count of the resulting entities

initCommandChains

protected void initCommandChains()

mergeEntity

public void mergeEntity(String entitySetName,
                        OEntity entity)
Description copied from interface: ODataProducer
Modifies an existing entity using merge semantics.

Specified by:
mergeEntity in interface ODataProducer
Parameters:
entitySetName - the entity-set name
entity - the entity modifications sent from the client
See Also:
[odata.org] Updating Entries

updateEntity

public void updateEntity(String entitySetName,
                         OEntity entity)
Description copied from interface: ODataProducer
Modifies an existing entity using update semantics.

Specified by:
updateEntity in interface ODataProducer
Parameters:
entitySetName - the entity-set name
entity - the entity modifications sent from the client
See Also:
[odata.org] Updating Entries

updateLink

public void updateLink(OEntityId sourceEntity,
                       String targetNavProp,
                       OEntityKey oldTargetEntityKey,
                       OEntityId newTargetEntity)
Description copied from interface: ODataProducer
Replaces an existing link between two entities.

Specified by:
updateLink in interface ODataProducer
Parameters:
sourceEntity - an entity with at least one navigation property
targetNavProp - the navigation property
oldTargetEntityKey - if the navigation property represents a set, the key identifying the old target entity within the set, else n/a
newTargetEntity - the new link target entity
See Also:
[odata.org] Replacing Links between Entries


http://odata4j.org