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

com.scalar.database.service.StorageService Maven / Gradle / Ivy

Go to download

A universal transaction manager that achieves database-agnostic transactions and distributed transactions that span multiple databases

There is a newer version: 3.14.0-alpha.1
Show newest version
package com.scalar.database.service;

import com.google.inject.Inject;
import com.scalar.database.api.Delete;
import com.scalar.database.api.DistributedStorage;
import com.scalar.database.api.Get;
import com.scalar.database.api.Mutation;
import com.scalar.database.api.Put;
import com.scalar.database.api.Result;
import com.scalar.database.api.Scan;
import com.scalar.database.api.Scanner;
import com.scalar.database.exception.storage.ExecutionException;
import java.util.List;
import java.util.Optional;
import javax.annotation.concurrent.Immutable;
import org.slf4j.Logger;
import org.slf4j.LoggerFactory;

@Immutable
public class StorageService implements DistributedStorage {
  private static final Logger LOGGER = LoggerFactory.getLogger(StorageService.class);
  private final DistributedStorage storage;

  @Inject
  public StorageService(DistributedStorage storage) {
    this.storage = storage;
  }

  @Override
  public void with(String namespace, String tableName) {
    storage.with(namespace, tableName);
  }

  @Override
  public Optional get(Get get) throws ExecutionException {
    return storage.get(get);
  }

  @Override
  public Scanner scan(Scan scan) throws ExecutionException {
    return storage.scan(scan);
  }

  @Override
  public void put(Put put) throws ExecutionException {
    storage.put(put);
  }

  @Override
  public void put(List puts) throws ExecutionException {
    storage.put(puts);
  }

  @Override
  public void delete(Delete delete) throws ExecutionException {
    storage.delete(delete);
  }

  @Override
  public void delete(List deletes) throws ExecutionException {
    storage.delete(deletes);
  }

  @Override
  public void mutate(List mutations) throws ExecutionException {
    storage.mutate(mutations);
  }

  @Override
  public void close() {
    storage.close();
  }
}




© 2015 - 2024 Weber Informatics LLC | Privacy Policy