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

org.bouncycastle.tsp.ers.ERSRootNodeCalculator Maven / Gradle / Ivy

Go to download

The Bouncy Castle Java APIs for CMS, PKCS, EAC, TSP, CMP, CRMF, OCSP, and certificate generation. This jar contains APIs for JDK 1.8 and up. The APIs are designed primarily to be used in conjunction with the BC LTS provider but may also be used with other providers providing cryptographic services.

There is a newer version: 2.73.7
Show newest version
package org.bouncycastle.tsp.ers;

import org.bouncycastle.asn1.tsp.PartialHashtree;
import org.bouncycastle.operator.DigestCalculator;

/**
 * Base interface for an implementation that calculates the root hash
 * contained in the time-stamp from the Merkle tree based on the partial
 * hash-tree nodes.
 */
public interface ERSRootNodeCalculator
{
    /**
     * Calculate the root hash of the Merkle tree from the partial hash-tree nodes.
     *
     * @param digCalc the digest calculator to use.
     * @param nodes the partial hash-trees forming the basis of the Merkle tree.
     * @return the root hash of the Merkle tree.
     */
    byte[] computeRootHash(DigestCalculator digCalc, PartialHashtree[] nodes);

    /**
     * Calculate a path from the leaf node to the root of the last computed Merkle tree.
     * 
     * @param digCalc the digest calculator to use.
     * @param node the leaf node at the start of the path.
     * @param index the index of the node in the original list of partial hash trees.
     * @return
     */
    PartialHashtree[] computePathToRoot(DigestCalculator digCalc, PartialHashtree node, int index);

    /**
     * Recover the root hash from a path made up of PartialHashtrees.
     *
     * @param digCalc the digest calculator to use.
     * @param nodes the partial hash-trees forming a path from a leaf to the root of the Merkle tree.
     * @return the root hash of the Merkle tree.
     */
    byte[] recoverRootHash(DigestCalculator digCalc, PartialHashtree[] nodes);
}




© 2015 - 2025 Weber Informatics LLC | Privacy Policy