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

com.scalar.dl.client.tool.FunctionsRegistration Maven / Gradle / Ivy

package com.scalar.dl.client.tool;

import com.google.common.annotations.VisibleForTesting;
import com.moandjiezana.toml.Toml;
import com.moandjiezana.toml.TomlWriter;
import com.scalar.dl.client.config.ClientConfig;
import com.scalar.dl.client.config.GatewayClientConfig;
import com.scalar.dl.client.exception.ClientException;
import com.scalar.dl.client.service.ClientService;
import com.scalar.dl.client.service.ClientServiceFactory;
import java.io.File;
import java.io.FileOutputStream;
import java.io.OutputStreamWriter;
import java.nio.charset.StandardCharsets;
import java.util.ArrayList;
import java.util.List;
import java.util.concurrent.Callable;
import picocli.CommandLine;
import picocli.CommandLine.Command;

@Command(name = "register-functions", description = "Register specified functions.")
public class FunctionsRegistration extends CommonOptions implements Callable {
  static final String REGISTRATION_FAILED_FUNCTIONS_TOML_FILE =
      "registration-failed-functions.toml";
  static final String TOML_TABLES_NAME = "functions";

  @CommandLine.Option(
      names = {"--functions-file"},
      required = true,
      paramLabel = "FUNCTIONS_FILE",
      description = "A file including functions to register in TOML format.")
  private String functionsFile;

  public static void main(String[] args) {
    int exitCode =
        new CommandLine(new com.scalar.dl.client.tool.FunctionsRegistration()).execute(args);
    System.exit(exitCode);
  }

  @Override
  public Integer call() throws Exception {
    ClientServiceFactory factory = new ClientServiceFactory();
    File functionsFileObj = new File(functionsFile);
    return call(factory, functionsFileObj);
  }

  @VisibleForTesting
  Integer call(ClientServiceFactory factory, File functionsFile) throws Exception {
    ClientService service =
        useGateway
            ? factory.create(new GatewayClientConfig(new File(properties)))
            : factory.create(new ClientConfig(new File(properties)));
    return call(factory, service, functionsFile);
  }

  @VisibleForTesting
  Integer call(ClientServiceFactory factory, ClientService service, File functionsFile)
      throws Exception {
    List succeeded = new ArrayList();
    List failed = new ArrayList();

    try {
      new Toml()
          .read(functionsFile)
          .getTables(TOML_TABLES_NAME)
          .forEach(
              each -> {
                String id = each.getString("function-id");
                String binaryName = each.getString("function-binary-name");
                String classFile = each.getString("function-class-file");

                // All of them are required values to register a function.
                // Thus, the malformed table is skipped if one of them doesn't exist.
                if (id == null || binaryName == null || classFile == null) {
                  failed.add(each);
                  return;
                }

                try {
                  System.out.printf("Register function %s as %s%n", binaryName, id);
                  service.registerFunction(id, binaryName, classFile);
                  Common.printOutput(null);
                  succeeded.add(each);
                } catch (ClientException e) {
                  Common.printError(e);
                  printStackTrace(e);
                  failed.add(each);
                }
              });
    } finally {
      factory.close();
    }

    System.out.printf("Registration succeeded: %d%n", succeeded.size());
    System.out.printf("Registration failed: %d%n", failed.size());

    if (!failed.isEmpty()) {
      try (OutputStreamWriter fileWriter =
          new OutputStreamWriter(
              new FileOutputStream(REGISTRATION_FAILED_FUNCTIONS_TOML_FILE),
              StandardCharsets.UTF_8)) {
        TomlWriter tomlWriter = new TomlWriter();

        for (Toml toml : failed) {
          fileWriter.write(String.format("[[%s]]%n", TOML_TABLES_NAME));
          tomlWriter.write(toml.toMap(), fileWriter);
        }
      }

      System.out.printf(
          "%nFunctions that failed to be registered are written to %s.%n",
          REGISTRATION_FAILED_FUNCTIONS_TOML_FILE);

      return 1;
    }

    return 0;
  }
}




© 2015 - 2025 Weber Informatics LLC | Privacy Policy