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

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

There is a newer version: 3.10.0
Show newest version
/*
 * This file is part of the Scalar DL client SDK.
 * Copyright (c) 2019 Scalar, Inc.
 *
 * 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 .
 *
 * You can be released from the requirements of the license by purchasing
 * a commercial license. For more information, please contact Scalar, Inc.
 */
package com.scalar.dl.client.tool;

import com.scalar.dl.client.config.ClientConfig;
import com.scalar.dl.client.exception.ClientException;
import com.scalar.dl.client.service.ClientService;
import com.scalar.dl.client.service.ClientServiceFactory;
import com.scalar.dl.ledger.asset.AssetProof;
import com.scalar.dl.ledger.model.LedgersValidationResult;
import java.io.File;
import java.util.Base64;
import java.util.List;
import java.util.concurrent.Callable;
import javax.json.Json;
import javax.json.JsonValue;
import picocli.CommandLine;
import picocli.CommandLine.Command;

@Command(name = "validate-ledgers", description = "Validate a specified asset in multiple ledgers.")
public class MultiLedgersValidation implements Callable {

  @CommandLine.Option(
      names = {"--properties", "--config"},
      required = true,
      paramLabel = "PROPERTIES_FILE",
      description = "A configuration file in properties format.")
  private String properties;

  @CommandLine.Option(
      names = {"--asset-id"},
      required = true,
      paramLabel = "ASSET_ID",
      description = "The ID of an asset.")
  private List assetIds;

  @CommandLine.Option(
      names = {"-h", "--help"},
      usageHelp = true,
      description = "display the help message.")
  boolean helpRequested;

  public static void main(String[] args) {
    int exitCode = new CommandLine(new MultiLedgersValidation()).execute(args);
    System.exit(exitCode);
  }

  @Override
  public Integer call() throws Exception {
    ClientServiceFactory factory = new ClientServiceFactory(new ClientConfig(new File(properties)));

    try (ClientService service = factory.getClientService()) {
      assetIds.forEach(
          assetId -> {
            LedgersValidationResult result = service.validateLedgers(assetId);
            System.out.println(result.getCode());
            result
                .getProofs()
                .forEach(
                    (k, v) -> {
                      System.out.println(k + ":");
                      System.out.println(getJsonProof(v));
                    });
          });
      return 0;
    } catch (ClientException e) {
      Common.printError(e);
      return 1;
    }
  }

  private JsonValue getJsonProof(AssetProof proof) {
    return Json.createObjectBuilder()
        .add("id", proof.getId())
        .add("age", proof.getAge())
        .add("nonce", proof.getNonce())
        .add("hash", Base64.getEncoder().encodeToString(proof.getHash()))
        .add("signature", Base64.getEncoder().encodeToString(proof.getSignature()))
        .build();
  }
}




© 2015 - 2025 Weber Informatics LLC | Privacy Policy