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

com.scalar.dl.client.service.ClientServiceFactory Maven / Gradle / Ivy

There is a newer version: 3.10.0
Show newest version
package com.scalar.dl.client.service;

import com.google.common.annotations.VisibleForTesting;
import com.scalar.dl.client.config.ClientConfig;
import com.scalar.dl.client.config.IdentityConfig;
import com.scalar.dl.client.util.RequestSigner;
import com.scalar.dl.ledger.config.TargetConfig;
import com.scalar.dl.ledger.crypto.SignatureSigner;
import java.util.Map;
import java.util.concurrent.ConcurrentHashMap;
import javax.annotation.concurrent.ThreadSafe;

/**
 * A factory class to instantiate {@link ClientService}. {@code ClientServiceFactory} creates a new
 * {@link ClientService} for each create method call but reuses objects such as clients and
 * connections as much as possible on the basis of a give configuration. So, {@code
 * ClientServiceFactory} object should always be reused. Please see the javadoc of {@link
 * ClientService} for how to use this.
 */
@ThreadSafe
public class ClientServiceFactory {
  private ClientConfig config;
  private final Map ledgerClients = new ConcurrentHashMap<>();
  private final Map auditorClients = new ConcurrentHashMap<>();
  private final Map signers = new ConcurrentHashMap<>();

  /**
   * @param config a client config.
   * @deprecated This method will be removed in release 5.0.0.
   */
  @Deprecated
  public ClientServiceFactory(ClientConfig config) {
    this.config = config;
  }

  public ClientServiceFactory() {}

  /**
   * Returns a {@link ClientService} instance.
   *
   * @return a {@link ClientService} instance
   * @deprecated This method will be removed in release 5.0.0.
   */
  @Deprecated
  public ClientService getClientService() {
    return create(config);
  }

  /**
   * Returns a {@link ClientService} instance.
   *
   * @param config a client config
   * @return a {@link ClientService} instance
   */
  public ClientService create(ClientConfig config) {
    // LedgerClient is reused if the specified target is the same
    AbstractLedgerClient ledgerClient =
        ledgerClients.computeIfAbsent(config.getLedgerTargetConfig(), this::createLedgerClient);

    // AuditorClient is reused if the specified target is the same
    AbstractAuditorClient auditorClient = null;
    if (config.isAuditorEnabled()) {
      auditorClient =
          auditorClients.computeIfAbsent(
              config.getAuditorTargetConfig(), this::createAuditorClient);
    }

    // RequestSigner is reused if the specified identity is the same
    RequestSigner signer =
        signers.computeIfAbsent(config.getIdentityConfig(), this::createRequestSigner);

    return new ClientService(config, ledgerClient, auditorClient, signer);
  }

  /**
   * Cleans up all the resources managed by the factory. This must be called after finishing up all
   * the interactions with the {@link ClientService}s that it creates.
   */
  public void close() {
    ledgerClients.values().forEach(Client::shutdown);
    auditorClients.values().forEach(Client::shutdown);
  }

  @VisibleForTesting
  AbstractLedgerClient createLedgerClient(TargetConfig config) {
    return new LedgerClient(config);
  }

  @VisibleForTesting
  AbstractAuditorClient createAuditorClient(TargetConfig config) {
    return new AuditorClient(config);
  }

  @VisibleForTesting
  RequestSigner createRequestSigner(IdentityConfig config) {
    if (config.getPrivateKey() == null) {
      return null;
    }
    return new RequestSigner(new SignatureSigner(config.getPrivateKey()));
  }
}




© 2015 - 2025 Weber Informatics LLC | Privacy Policy