/* * #%L * ===================================================== * _____ _ ____ _ _ _ _ * |_ _|_ __ _ _ ___| |_ / __ \| | | | ___ | | | | * | | | '__| | | / __| __|/ / _` | |_| |/ __|| |_| | * | | | | | |_| \__ \ |_| | (_| | _ |\__ \| _ | * |_| |_| \__,_|___/\__|\ \__,_|_| |_||___/|_| |_| * \____/ * * ===================================================== * * Hochschule Hannover * (University of Applied Sciences and Arts, Hannover) * Faculty IV, Dept. of Computer Science * Ricklinger Stadtweg 118, 30459 Hannover, Germany * * Email: trust@f4-i.fh-hannover.de * Website: http://trust.f4.hs-hannover.de/ * * This file is part of visitmeta-dataservice, version 0.6.0, * implemented by the Trust@HsH research group at the Hochschule Hannover. * %% * Copyright (C) 2012 - 2016 Trust@HsH * %% * Licensed under the Apache License, Version 2.0 (the "License"); * you may not use this file except in compliance with the License. * You may obtain a copy of the License at * * http://www.apache.org/licenses/LICENSE-2.0 * * Unless required by applicable law or agreed to in writing, software * distributed under the License is distributed on an "AS IS" BASIS, * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. * See the License for the specific language governing permissions and * limitations under the License. * #L% */ /** * */ package de.hshannover.f4.trust.visitmeta.persistence.neo4j; import java.util.List; import java.util.concurrent.locks.Lock; import java.util.concurrent.locks.ReentrantLock; import org.apache.log4j.Logger; import org.neo4j.graphdb.Transaction; import de.hshannover.f4.trust.visitmeta.dataservice.internalDatatypes.InternalMetadata; import de.hshannover.f4.trust.visitmeta.persistence.AbstractWriter; /** * Neo4J extension of AbstractWriter. Basically only adds transactions to the * methods of the superclass. * * @author rosso * */ public class Neo4JWriter extends AbstractWriter { private static Logger log = Logger.getLogger(Neo4JWriter.class); private Transaction mTransaction; private Lock mLock; private Neo4JConnection mConnection; private Long mLastTimestamp; public Neo4JWriter(Neo4JRepository graph, Neo4JConnection connection, String connectionName) { mRepo = graph; mLock = new ReentrantLock(); mConnection = connection; mConnectionName = connectionName; } @Override public void finishTransaction() { log.trace("Finishing transaction ..."); mTransaction.success(); mTransaction.close(); mLock.unlock(); } @Override public void beginTransaction() { mLock.lock(); mLastTimestamp = mConnection.getTimestampManager().getCurrentTime(); log.trace("Beginning transaction ..."); mTransaction = ((Neo4JRepository) mRepo).beginTx(); } @Override protected void submitUpdate(List<InternalMetadata> meta) { for (InternalMetadata m : meta) { mConnection.getTimestampManager().incrementCounter( m.getPublishTimestamp()); this.savePrexif(m); } } @Override protected void submitDelete(int n) { for (int i = 0; i < n; i++) { mConnection.getTimestampManager().incrementCounter(mLastTimestamp); } } }