 
                        
        
                        
        com.launchdarkly.sdk.server.interfaces.DataStore Maven / Gradle / Ivy
package com.launchdarkly.sdk.server.interfaces;
import com.launchdarkly.sdk.server.interfaces.DataStoreStatusProvider.CacheStats;
import com.launchdarkly.sdk.server.interfaces.DataStoreTypes.DataKind;
import com.launchdarkly.sdk.server.interfaces.DataStoreTypes.FullDataSet;
import com.launchdarkly.sdk.server.interfaces.DataStoreTypes.ItemDescriptor;
import com.launchdarkly.sdk.server.interfaces.DataStoreTypes.KeyedItems;
import java.io.Closeable;
/**
 * Interface for a data store that holds feature flags and related data received by the SDK.
 * 
 * Ordinarily, the only implementations of this interface are the default in-memory implementation,
 * which holds references to actual SDK data model objects, and the persistent data store
 * implementation that delegates to a {@link PersistentDataStore}.
 * 
 
 * All implementations must permit concurrent access and updates.
 *
 * @since 5.0.0
 */
public interface DataStore extends Closeable {
  /**
   * Overwrites the store's contents with a set of items for each collection.
   * 
   * All previous data should be discarded, regardless of versioning.
   * 
   * The update should be done atomically. If it cannot be done atomically, then the store
   * must first add or update each item in the same order that they are given in the input
   * data, and then delete any previously stored items that were not in the input data.
   * 
   * @param allData a list of {@link DataStoreTypes.DataKind} instances and their corresponding data sets
   */
  void init(FullDataSet allData);
  
  /**
   * Retrieves an item from the specified collection, if available.
   * 
   * If the item has been deleted and the store contains a placeholder, it should
   * return that placeholder rather than null.
   * 
   * @param kind specifies which collection to use
   * @param key the unique key of the item within that collection
   * @return a versioned item that contains the stored data (or placeholder for deleted data);
   *   null if the key is unknown
   */
  ItemDescriptor get(DataKind kind, String key);
  
  /**
   * Retrieves all items from the specified collection.
   * 
   * If the store contains placeholders for deleted items, it should include them in
   * the results, not filter them out.
   * 
   * @param kind specifies which collection to use
   * @return a collection of key-value pairs; the ordering is not significant
   */
  KeyedItems getAll(DataKind kind);
  
  /**
   * Updates or inserts an item in the specified collection. For updates, the object will only be
   * updated if the existing version is less than the new version.
   * 
   * The SDK may pass an {@link ItemDescriptor} that contains a null, to represent a placeholder
   * for a deleted item. In that case, assuming the version is greater than any existing version of
   * that item, the store should retain that placeholder rather than simply not storing anything.
   * 
   * @param kind specifies which collection to use
   * @param key the unique key for the item within that collection
   * @param item the item to insert or update
   * @return true if the item was updated; false if it was not updated because the store contains
   *   an equal or greater version
   */
  boolean upsert(DataKind kind, String key, ItemDescriptor item);
  
  /**
   * Checks whether this store has been initialized with any data yet.
   *
   * @return true if the store contains data
   */
  boolean isInitialized();
  
  /**
   * Returns true if this data store implementation supports status monitoring.
   * 
   * This is normally only true for persistent data stores created with
   * {@link com.launchdarkly.sdk.server.Components#persistentDataStore(PersistentDataStoreFactory)},
   * but it could also be true for any custom {@link DataStore} implementation that makes use of the
   * {@code statusUpdater} parameter provided to {@link DataStoreFactory#createDataStore(ClientContext, DataStoreUpdates)}.
   * Returning true means that the store guarantees that if it ever enters an invalid state (that is, an
   * operation has failed or it knows that operations cannot succeed at the moment), it will publish a
   * status update, and will then publish another status update once it has returned to a valid state.
   * 
   * The same value will be returned from {@link DataStoreStatusProvider#isStatusMonitoringEnabled()}.
   * 
   * @return true if status monitoring is enabled
   */
  boolean isStatusMonitoringEnabled();
  
  /**
   * Returns statistics about cache usage, if this data store implementation supports caching.
   * 
   * @return a cache statistics object, or null if not applicable
   */
  CacheStats getCacheStats();
}