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

com.torodb.backend.BackendConnectionImpl Maven / Gradle / Ivy

There is a newer version: 0.50.3
Show newest version
/*
 * ToroDB
 * Copyright © 2014 8Kdata Technology (www.8kdata.com)
 *
 * This program is free software: you can redistribute it and/or modify
 * it under the terms of the GNU Affero General Public License as published by
 * the Free Software Foundation, either version 3 of the License, or
 * (at your option) any later version.
 *
 * This program is distributed in the hope that it will be useful,
 * but WITHOUT ANY WARRANTY; without even the implied warranty of
 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
 * GNU Affero General Public License for more details.
 *
 * You should have received a copy of the GNU Affero General Public License
 * along with this program. If not, see .
 */

package com.torodb.backend;

import com.google.common.base.Preconditions;
import com.torodb.backend.meta.SchemaUpdater;
import com.torodb.core.TableRefFactory;
import com.torodb.core.backend.BackendConnection;
import com.torodb.core.backend.BackendTransaction;
import com.torodb.core.backend.ExclusiveWriteBackendTransaction;
import com.torodb.core.backend.ReadOnlyBackendTransaction;
import com.torodb.core.backend.SharedWriteBackendTransaction;
import com.torodb.core.d2r.IdentifierFactory;
import com.torodb.core.d2r.ReservedIdGenerator;
import org.apache.logging.log4j.Logger;

/**
 *
 */
public class BackendConnectionImpl implements BackendConnection {

  private static final Logger LOGGER = BackendLoggerFactory.get(BackendConnectionImpl.class);
  private final BackendServiceImpl backend;
  private final SqlInterface sqlInterface;
  private boolean closed = false;
  private final TableRefFactory tableRefFactory;
  private final IdentifierFactory identifierFactory;
  private final ReservedIdGenerator ridGenerator;
  private BackendTransaction currentTransaction;

  public BackendConnectionImpl(BackendServiceImpl backend,
      SqlInterface sqlInterface, ReservedIdGenerator ridGenerator,
      TableRefFactory tableRefFactory, IdentifierFactory identifierFactory) {
    this.backend = backend;
    this.sqlInterface = sqlInterface;
    this.tableRefFactory = tableRefFactory;
    this.identifierFactory = identifierFactory;
    this.ridGenerator = ridGenerator;
  }

  @Override
  public ReadOnlyBackendTransaction openReadOnlyTransaction() {
    Preconditions.checkState(!closed, "This connection is closed");
    Preconditions.checkState(currentTransaction == null,
        "Another transaction is currently under execution. Transaction is " + currentTransaction);

    ReadOnlyBackendTransactionImpl transaction = new ReadOnlyBackendTransactionImpl(sqlInterface,
        this);
    currentTransaction = transaction;

    return transaction;
  }

  @Override
  public SharedWriteBackendTransaction openSharedWriteTransaction() {
    Preconditions.checkState(!closed, "This connection is closed");
    Preconditions.checkState(currentTransaction == null,
        "Another transaction is currently under execution. Transaction is " + currentTransaction);

    SharedWriteBackendTransactionImpl transaction = new SharedWriteBackendTransactionImpl(
        sqlInterface, this, tableRefFactory, identifierFactory);
    currentTransaction = transaction;

    return transaction;
  }

  @Override
  public ExclusiveWriteBackendTransaction openExclusiveWriteTransaction() {
    Preconditions.checkState(!closed, "This connection is closed");
    Preconditions.checkState(currentTransaction == null,
        "Another transaction is currently under execution. Transaction is " + currentTransaction);

    ExclusiveWriteBackendTransactionImpl transaction = new ExclusiveWriteBackendTransactionImpl(
        sqlInterface, this, tableRefFactory, identifierFactory, ridGenerator);
    currentTransaction = transaction;

    return transaction;
  }

  KvMetainfoHandler getMetaInfoHandler() {
    return backend.getMetaInfoHandler();
  }

  SchemaUpdater getSchemaUpdater() {
    return backend.getSchemaUpdater();
  }

  @Override
  public void close() {
    if (!closed) {
      closed = true;
      if (currentTransaction != null) {
        currentTransaction.close();
      }
      assert currentTransaction == null;
      backend.onConnectionClosed(this);
    }
  }

  void onTransactionClosed(BackendTransaction transaction) {
    if (currentTransaction == null) {
      LOGGER.debug(
          "Recived an on transaction close notification, but there is no current transaction");
      return;
    }
    if (currentTransaction != transaction) {
      LOGGER.debug("Recived an on transaction close notification, but the recived transaction is "
          + "not the same as the current one");
      return;
    }
    currentTransaction = null;
  }

}




© 2015 - 2024 Weber Informatics LLC | Privacy Policy