All Downloads are FREE. Search and download functionalities are using the official Maven repository.

com.yahoo.elide.datastores.multiplex.MultiplexManager Maven / Gradle / Ivy

/*
 * Copyright 2015, Yahoo Inc.
 * Licensed under the Apache License, Version 2.0
 * See LICENSE file in project root for terms.
 */
package com.yahoo.elide.datastores.multiplex;

import com.yahoo.elide.core.DataStore;
import com.yahoo.elide.core.DataStoreTransaction;
import com.yahoo.elide.core.EntityDictionary;

import java.util.Arrays;
import java.util.List;
import java.util.concurrent.ConcurrentHashMap;

/**
 * Allows multiple database handlers to each process their own beans while keeping the main
 * commit in sync across all managers.
 *
 * 

WARNING If a subordinate commit fails, attempts are made to reverse the previous * commits. If these reversals fail, the databases can be left out of sync. *

* For example, a Multiplex of two databases DB1, DB2 might do: *

    *
  • Save to DB1 and DB2 *
  • Commit DB1 successfully *
  • Commit DB2 fails *
  • Attempt to reverse DB1 commit fails *
*/ public class MultiplexManager implements DataStore { protected final List dataStores; protected final ConcurrentHashMap, DataStore> dataStoreMap = new ConcurrentHashMap<>(); private EntityDictionary dictionary; /** * Create a single DataStore to handle provided managers within a single transaction. * @param dataStores list of sub-managers */ public MultiplexManager(DataStore... dataStores) { this.dataStores = Arrays.asList(dataStores); } @Override public void populateEntityDictionary(EntityDictionary dictionary) { this.dictionary = dictionary; for (DataStore dataStore : dataStores) { EntityDictionary subordinateDictionary = new EntityDictionary(); dataStore.populateEntityDictionary(subordinateDictionary); for (Class cls : subordinateDictionary.getBindings()) { // route class to this database manager this.dataStoreMap.put(cls, dataStore); // bind to multiplex dictionary dictionary.bindEntity(cls); } } } @Override public DataStoreTransaction beginTransaction() { return new MultiplexWriteTransaction(this); } @Override public DataStoreTransaction beginReadTransaction() { return new MultiplexReadTransaction(this); } public EntityDictionary getDictionary() { return dictionary; } /** * Lookup subordinate database manager for provided entity class. * @param cls provided class * @return database manager handling this entity */ protected DataStore getSubManager(Class cls) { // Follow for this class or super-class for Entity annotation Class type = (Class) dictionary.lookupEntityClass(cls); return dataStoreMap.get(type); } }




© 2015 - 2025 Weber Informatics LLC | Privacy Policy