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