Class DynamoDbPersistenceProvider<V extends DigitalTwinBase>
- java.lang.Object
- 
- com.scaleoutsoftware.digitaltwin.persistentstorage.PersistentStorage<V>
- 
- com.scaleoutsoftware.digitaltwin.persistentstorage.DynamoDbPersistenceProvider<V>
 
 
- 
- Type Parameters:
- V- the type of the digital twin
 - All Implemented Interfaces:
- com.scaleout.client.ighosting.InvocationGridSignalHandler,- PersistenceProvider,- java.lang.AutoCloseable
 
 public class DynamoDbPersistenceProvider<V extends DigitalTwinBase> extends PersistentStorage<V> implements PersistenceProvider, java.lang.AutoCloseable DynamoDB persistent storage - transparently store and load digital twins to and from a DynamoDB deployment.
- 
- 
Field Summary- 
Fields inherited from class com.scaleoutsoftware.digitaltwin.persistentstorage.PersistentStorage_connection
 
- 
 - 
Constructor SummaryConstructors Constructor Description DynamoDbPersistenceProvider(com.scaleout.client.GridConnection connection, java.lang.String model, java.lang.Class<V> clazz)
 - 
Method SummaryModifier and Type Method Description voidclose()java.lang.StringgetInstance(java.lang.String modelName, java.lang.String instanceId)Retrieves an instance or null if it doesn't exist.java.util.concurrent.CompletableFuture<java.lang.String>getInstanceAsync(java.lang.String modelName, java.lang.String instanceId)Retrieves a future that when complete will return an instance or null if it doesn't exist.java.util.List<java.lang.String>getInstanceIds(java.lang.String modelName)Retrieves the instance IDs stored in a container, or an empty list if no instances exist.java.util.concurrent.CompletableFuture<java.util.List<java.lang.String>>getInstanceIdsAsync(java.lang.String modelName)Retrieves a future that when complete will return the instance IDs stored in a container, or an empty list if no instances exist.bytegetPersistencePolicy()<T> TgetProperty(java.lang.String modelName, java.lang.String instanceId, java.lang.String propertyName, java.lang.Class<T> aClass)Retrieves a property or null if the property does not exist.<T> java.util.concurrent.CompletableFuture<T>getPropertyAsync(java.lang.String modelName, java.lang.String instanceId, java.lang.String propertyName, java.lang.Class<T> aClass)Retrieves a future that will return a property or null if the property does not exist.java.util.Map<java.lang.String,java.lang.String>getPropertyMap(java.lang.String s)Retrieves a map of property names to property types, or an empty map.java.util.concurrent.CompletableFuture<java.util.Map<java.lang.String,java.lang.String>>getPropertyMapAsync(java.lang.String s)Retrieves a future that will return a map of property names to property, or an empty map.PersistenceProviderTypegetProviderType()Retrieves this persistence providers type.<T> TgetRtdtProperty(java.lang.String instanceId, java.lang.String propertyName, java.lang.Class<T> aClass)Retrieves a property for a RTDT instance or null if the property does not exist.<T> java.util.concurrent.CompletableFuture<T>getRtdtPropertyAsync(java.lang.String instanceId, java.lang.String propertyName, java.lang.Class<T> aClass)Retrieves a future that will return a property value for a RTDT instance or null if the property doesn't exist.java.lang.StringgetTableName()voidinitialize(java.util.HashMap<java.lang.String,java.lang.String> conf)voidinitializeDynamoDbConnection()booleanisActive()Returns true if this PersistenceProvider is active, false otherwise.Vload(java.lang.String id)voidonSignal(com.scaleout.client.ighosting.InvocationGridSignal invocationGridSignal, java.lang.Object o)voidstore(V instance)java.lang.StringtoString()voidupdateProperty(java.lang.String modelName, java.lang.String instanceId, java.lang.String propertyName, java.lang.Object propertyValue)Updates a property for the provided instance id in the provided container specified by the property name and property value.java.util.concurrent.CompletableFuture<java.lang.Void>updatePropertyAsync(java.lang.String modelName, java.lang.String instanceId, java.lang.String propertyName, java.lang.Object propertyValue)Retrieves a future that will complete exceptionally or return void if the instance's property was successfully updated.voidupdateRtdtProperty(java.lang.String instanceId, java.lang.String propertyName, java.lang.Object propertyValue)Updates a RTDT property for the provided instance id specified by the property name and property value.java.util.concurrent.CompletableFuture<java.lang.Void>updateRtdtPropertyAsync(java.lang.String instanceId, java.lang.String propertyName, java.lang.Object propertyValue)Retrieves a future that will complete exceptionally or return void if the RTDT's property was successfully updated.
 
- 
- 
- 
Constructor Detail- 
DynamoDbPersistenceProviderpublic DynamoDbPersistenceProvider(com.scaleout.client.GridConnection connection, java.lang.String model, java.lang.Class<V> clazz)
 
- 
 - 
Method Detail- 
getTableNamepublic java.lang.String getTableName() 
 - 
isActivepublic boolean isActive() Description copied from interface:PersistenceProviderReturns true if this PersistenceProvider is active, false otherwise.- Specified by:
- isActivein interface- PersistenceProvider
- Specified by:
- isActivein class- PersistentStorage<V extends DigitalTwinBase>
- Returns:
- true if this PersistenceProvider is active, false otherwise.
 
 - 
storepublic void store(V instance) - Specified by:
- storein class- PersistentStorage<V extends DigitalTwinBase>
 
 - 
loadpublic V load(java.lang.String id) - Specified by:
- loadin class- PersistentStorage<V extends DigitalTwinBase>
 
 - 
getPersistencePolicypublic byte getPersistencePolicy() - Specified by:
- getPersistencePolicyin class- PersistentStorage<V extends DigitalTwinBase>
 
 - 
initializepublic void initialize(java.util.HashMap<java.lang.String,java.lang.String> conf) - Specified by:
- initializein class- PersistentStorage<V extends DigitalTwinBase>
 
 - 
initializeDynamoDbConnectionpublic void initializeDynamoDbConnection() 
 - 
getProviderTypepublic PersistenceProviderType getProviderType() Description copied from interface:PersistenceProviderRetrieves this persistence providers type. Currently supported provider types: AzureDigitalTwins.- Specified by:
- getProviderTypein interface- PersistenceProvider
- Returns:
- the persistence provider type.
 
 - 
getInstanceIdsAsyncpublic java.util.concurrent.CompletableFuture<java.util.List<java.lang.String>> getInstanceIdsAsync(java.lang.String modelName) Description copied from interface:PersistenceProviderRetrieves a future that when complete will return the instance IDs stored in a container, or an empty list if no instances exist.- Specified by:
- getInstanceIdsAsyncin interface- PersistenceProvider
- Parameters:
- modelName- the container name.
- Returns:
- a future that will return a list of instances.
 
 - 
getInstanceIdspublic java.util.List<java.lang.String> getInstanceIds(java.lang.String modelName) Description copied from interface:PersistenceProviderRetrieves the instance IDs stored in a container, or an empty list if no instances exist.- Specified by:
- getInstanceIdsin interface- PersistenceProvider
- Parameters:
- modelName- the container name.
- Returns:
- a list of instances.
 
 - 
getInstanceAsyncpublic java.util.concurrent.CompletableFuture<java.lang.String> getInstanceAsync(java.lang.String modelName, java.lang.String instanceId)Description copied from interface:PersistenceProviderRetrieves a future that when complete will return an instance or null if it doesn't exist.- Specified by:
- getInstanceAsyncin interface- PersistenceProvider
- Parameters:
- modelName- the container name.
- instanceId- the instance identifier.
- Returns:
- a future that will return an instance or null.
 
 - 
getInstancepublic java.lang.String getInstance(java.lang.String modelName, java.lang.String instanceId)Description copied from interface:PersistenceProviderRetrieves an instance or null if it doesn't exist.- Specified by:
- getInstancein interface- PersistenceProvider
- Parameters:
- modelName- the container name
- instanceId- the instance identifier
- Returns:
- the instance or null.
 
 - 
getPropertyMapAsyncpublic java.util.concurrent.CompletableFuture<java.util.Map<java.lang.String,java.lang.String>> getPropertyMapAsync(java.lang.String s) Description copied from interface:PersistenceProviderRetrieves a future that will return a map of property names to property, or an empty map.- Specified by:
- getPropertyMapAsyncin interface- PersistenceProvider
- Parameters:
- s- the container name.
- Returns:
- a future that will return a map of property names to property types.
 
 - 
getPropertyMappublic java.util.Map<java.lang.String,java.lang.String> getPropertyMap(java.lang.String s) Description copied from interface:PersistenceProviderRetrieves a map of property names to property types, or an empty map.- Specified by:
- getPropertyMapin interface- PersistenceProvider
- Parameters:
- s- the container name.
- Returns:
- a map of property names to property types.
 
 - 
updatePropertyAsyncpublic java.util.concurrent.CompletableFuture<java.lang.Void> updatePropertyAsync(java.lang.String modelName, java.lang.String instanceId, java.lang.String propertyName, java.lang.Object propertyValue)Description copied from interface:PersistenceProviderRetrieves a future that will complete exceptionally or return void if the instance's property was successfully updated. Updates a property for the provided instance id in the provided container specified by the property name and property value.- Specified by:
- updatePropertyAsyncin interface- PersistenceProvider
- Parameters:
- modelName- the container name.
- instanceId- the instance id.
- propertyName- the property name.
- propertyValue- the property value.
- Returns:
- a future that will complete exceptionally or return void.
 
 - 
updatePropertypublic void updateProperty(java.lang.String modelName, java.lang.String instanceId, java.lang.String propertyName, java.lang.Object propertyValue)Description copied from interface:PersistenceProviderUpdates a property for the provided instance id in the provided container specified by the property name and property value.- Specified by:
- updatePropertyin interface- PersistenceProvider
- Parameters:
- modelName- the container name.
- instanceId- the instance id.
- propertyName- the property name.
- propertyValue- the property value.
 
 - 
getPropertyAsyncpublic <T> java.util.concurrent.CompletableFuture<T> getPropertyAsync(java.lang.String modelName, java.lang.String instanceId, java.lang.String propertyName, java.lang.Class<T> aClass)Description copied from interface:PersistenceProviderRetrieves a future that will return a property or null if the property does not exist.- Specified by:
- getPropertyAsyncin interface- PersistenceProvider
- Type Parameters:
- T- the type of the property to return
- Parameters:
- modelName- the container name.
- instanceId- the instance id.
- propertyName- the property name.
- aClass- the class representing the property.
- Returns:
- the property or null if the property does not exist.
 
 - 
getPropertypublic <T> T getProperty(java.lang.String modelName, java.lang.String instanceId, java.lang.String propertyName, java.lang.Class<T> aClass)Description copied from interface:PersistenceProviderRetrieves a property or null if the property does not exist.- Specified by:
- getPropertyin interface- PersistenceProvider
- Type Parameters:
- T- the type of the property to return.
- Parameters:
- modelName- the container name.
- instanceId- the instance id.
- propertyName- the property name
- aClass- the class representing the property.
- Returns:
- the property or null if the property does not exist.
 
 - 
updateRtdtPropertyAsyncpublic java.util.concurrent.CompletableFuture<java.lang.Void> updateRtdtPropertyAsync(java.lang.String instanceId, java.lang.String propertyName, java.lang.Object propertyValue)Description copied from interface:PersistenceProviderRetrieves a future that will complete exceptionally or return void if the RTDT's property was successfully updated. Updates a RTDT property for the provided instance id specified by the property name and property value.- Specified by:
- updateRtdtPropertyAsyncin interface- PersistenceProvider
- Parameters:
- instanceId- the instance id.
- propertyName- the property name.
- propertyValue- the property value.
- Returns:
- a future that will complete exceptionally or return void.
 
 - 
updateRtdtPropertypublic void updateRtdtProperty(java.lang.String instanceId, java.lang.String propertyName, java.lang.Object propertyValue)Description copied from interface:PersistenceProviderUpdates a RTDT property for the provided instance id specified by the property name and property value.- Specified by:
- updateRtdtPropertyin interface- PersistenceProvider
- Parameters:
- instanceId- the instance id.
- propertyName- the property name.
- propertyValue- the property value.
 
 - 
getRtdtPropertyAsyncpublic <T> java.util.concurrent.CompletableFuture<T> getRtdtPropertyAsync(java.lang.String instanceId, java.lang.String propertyName, java.lang.Class<T> aClass)Description copied from interface:PersistenceProviderRetrieves a future that will return a property value for a RTDT instance or null if the property doesn't exist.- Specified by:
- getRtdtPropertyAsyncin interface- PersistenceProvider
- Type Parameters:
- T- the type of the property to return.
- Parameters:
- instanceId- the instance id.
- propertyName- the property name.
- aClass- the class of the property type
- Returns:
- a future that will return a property value for a RTDT instance.
 
 - 
getRtdtPropertypublic <T> T getRtdtProperty(java.lang.String instanceId, java.lang.String propertyName, java.lang.Class<T> aClass)Description copied from interface:PersistenceProviderRetrieves a property for a RTDT instance or null if the property does not exist.- Specified by:
- getRtdtPropertyin interface- PersistenceProvider
- Type Parameters:
- T- the type of the property to return.
- Parameters:
- instanceId- the instance id.
- propertyName- the property name.
- aClass- the class of the property type.
- Returns:
- the property value.
 
 - 
closepublic void close() throws java.lang.Exception- Specified by:
- closein interface- java.lang.AutoCloseable
- Throws:
- java.lang.Exception
 
 - 
toStringpublic java.lang.String toString() - Overrides:
- toStringin class- java.lang.Object
 
 - 
onSignalpublic void onSignal(com.scaleout.client.ighosting.InvocationGridSignal invocationGridSignal, java.lang.Object o)- Specified by:
- onSignalin interface- com.scaleout.client.ighosting.InvocationGridSignalHandler
 
 
- 
 
-