blob: afb8f9bcac64f94f8d2146938c95a0bbc57f1c5a [file] [log] [blame]
package net.onrc.onos.util;
import java.util.Set;
import org.slf4j.Logger;
import org.slf4j.LoggerFactory;
import com.thinkaurelius.titan.core.TitanFactory;
import com.thinkaurelius.titan.core.TitanGraph;
import com.tinkerpop.blueprints.TransactionalGraph;
import com.tinkerpop.blueprints.Vertex;
import com.tinkerpop.blueprints.util.wrappers.event.EventTransactionalGraph;
import com.tinkerpop.frames.FramedGraph;
public class GraphDBConnection implements IDBConnection {
public enum Transaction {
COMMIT, ROLLBACK
}
public enum GenerateEvent {
TRUE, FALSE
}
class TransactionHandle {
protected TransactionalGraph tr;
public void create() {
tr = graph.newTransaction();
}
}
protected static Logger log = LoggerFactory
.getLogger(GraphDBConnection.class);
private static GraphDBConnection singleton = new GraphDBConnection();
private static TitanGraph graph;
private static EventTransactionalGraph<TitanGraph> eg;
private static GraphDBOperation utils;
private static String configFile;
/*
* A private Constructor prevents any other class from instantiating.
*/
private GraphDBConnection() {
}
/* Static 'instance' method */
public static synchronized GraphDBConnection getInstance(final String conf) {
if (GraphDBConnection.configFile == null
|| GraphDBConnection.configFile.isEmpty()) {
GraphDBConnection.configFile = conf;
log.debug("GraphDBConnection::Setting Config File {}",
GraphDBConnection.configFile);
}
if (!GraphDBConnection.configFile.isEmpty()
&& (graph == null || graph.isOpen() == Boolean.FALSE)) {
graph = TitanFactory.open(GraphDBConnection.configFile);
// FIXME: Creation on Indexes should be done only once
Set<String> s = graph.getIndexedKeys(Vertex.class);
if (!s.contains("dpid")) {
graph.createKeyIndex("dpid", Vertex.class);
}
if (!s.contains("type")) {
graph.createKeyIndex("type", Vertex.class);
}
if (!s.contains("dl_address")) {
graph.createKeyIndex("dl_address", Vertex.class);
}
if (!s.contains("flow_id")) {
graph.createKeyIndex("flow_id", Vertex.class);
}
if (!s.contains("flow_entry_id")) {
graph.createKeyIndex("flow_entry_id", Vertex.class);
}
if (!s.contains("switch_state")) {
graph.createKeyIndex("switch_state", Vertex.class);
}
graph.commit();
eg = new EventTransactionalGraph<TitanGraph>(graph);
}
return singleton;
}
public FramedGraph<TitanGraph> getFramedGraph() {
if (isValid()) {
FramedGraph<TitanGraph> fg = new FramedGraph<TitanGraph>(graph);
return fg;
} else {
log.error("new FramedGraph failed");
return null;
}
}
protected EventTransactionalGraph<TitanGraph> getEventGraph() {
if (isValid()) {
return eg;
} else {
return null;
}
}
public void addEventListener(final LocalGraphChangedListener listener) {
EventTransactionalGraph<TitanGraph> eg = this.getEventGraph();
eg.addListener(listener);
log.debug("Registered listener {}", listener.getClass());
}
public Boolean isValid() {
return (graph != null || graph.isOpen());
}
public void startTx() {
}
public void endTx(Transaction tx) {
try {
switch (tx) {
case COMMIT:
graph.commit();
case ROLLBACK:
graph.rollback();
}
} catch (Exception e) {
// TODO Auto-generated catch block
log.error("{}", e.toString());
}
}
public void endTx(TransactionHandle tr, Transaction tx) {
switch (tx) {
case COMMIT:
if (tr != null && tr.tr != null) {
tr.tr.commit();
} else {
graph.commit();
}
case ROLLBACK:
if (tr != null && tr.tr != null) {
tr.tr.rollback();
} else {
graph.rollback();
}
}
}
public void endTx(Transaction tx, GenerateEvent fire) {
try {
if (fire.equals(GenerateEvent.TRUE)) {
switch (tx) {
case COMMIT:
eg.commit();
case ROLLBACK:
eg.rollback();
}
} else {
endTx(tx);
}
} catch (Exception e) {
// TODO Auto-generated catch block
e.printStackTrace();
}
}
public void close() {
endTx(Transaction.COMMIT);
}
}