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

io.vertx.redis.client.impl.BaseRedisClient Maven / Gradle / Ivy

There is a newer version: 5.0.0.CR3
Show newest version
package io.vertx.redis.client.impl;

import io.vertx.codegen.annotations.Nullable;
import io.vertx.core.Future;
import io.vertx.core.Promise;
import io.vertx.core.Vertx;
import io.vertx.core.impl.VertxInternal;
import io.vertx.core.impl.logging.Logger;
import io.vertx.core.impl.logging.LoggerFactory;
import io.vertx.redis.client.Redis;
import io.vertx.redis.client.RedisOptions;
import io.vertx.redis.client.Request;
import io.vertx.redis.client.Response;

import java.util.Collections;
import java.util.List;

public abstract class BaseRedisClient implements Redis {

  private static final Logger LOG = LoggerFactory.getLogger(BaseRedisClient.class);

  protected final VertxInternal vertx;
  protected final RedisConnectionManager connectionManager;

  public BaseRedisClient(Vertx vertx, RedisOptions options) {
    this.vertx = (VertxInternal) vertx;
    this.connectionManager = new RedisConnectionManager(this.vertx, options);
    this.connectionManager.start();
  }

  @Override
  public void close() {
    this.connectionManager.close();
  }

  @Override
  public Future<@Nullable Response> send(Request command) {
    final Promise promise = vertx.promise();

    if (command.command().isPubSub()) {
      // mixing pubSub cannot be used on a one-shot operation
      promise.fail("PubSub command in connection-less mode not allowed");
      return promise.future();
    }

    connect()
      .onFailure(promise::fail)
      .onSuccess(conn -> conn.send(command)
        .onComplete(send -> {
          try {
            promise.handle(send);
          } finally {
            // regardless of the result, return the connection to the pool
            conn.close().onFailure(LOG::warn);
          }
        }));

    return promise.future();
  }

  @Override
  public Future> batch(List commands) {
    final Promise> promise = vertx.promise();

    if (commands.isEmpty()) {
      LOG.debug("Empty batch");
      promise.complete(Collections.emptyList());
    } else {
      for (Request req : commands) {
        if (req.command().isPubSub()) {
          // mixing pubSub cannot be used on a one-shot operation
          promise.fail("PubSub command in connection-less batch not allowed");
          return promise.future();
        }
      }

      connect()
        .onFailure(promise::fail)
        .onSuccess(conn ->
          conn.batch(commands)
            .onSuccess(responses -> {
              try {
                promise.complete(responses);
              } finally {
                // regardless of the result, return the connection to the pool
                conn.close().onFailure(LOG::warn);
              }
            })
            .onFailure(err -> {
              try {
                promise.fail(err);
              } finally {
                // regardless of the result, return the connection to the pool
                conn.close().onFailure(LOG::warn);
              }
            }));
    }

    return promise.future();
  }
}




© 2015 - 2025 Weber Informatics LLC | Privacy Policy