com.scalar.dl.client.tool.MultiLedgersValidation Maven / Gradle / Ivy
Go to download
Show more of this group Show more artifacts with this name
Show all versions of scalardl-java-client-sdk Show documentation
Show all versions of scalardl-java-client-sdk Show documentation
A client-side Java library to interact with Scalar DL network.
/*
* 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