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

org.hyperledger.fabric.sdk.idemix.NonRevocationVerifier Maven / Gradle / Ivy

There is a newer version: 2.2.26
Show newest version
/*
 *
 *  Copyright 2017, 2018 IBM Corp. All Rights Reserved.
 *
 *  Licensed under the Apache License, Version 2.0 (the "License");
 *  you may not use this file except in compliance with the License.
 *  You may obtain a copy of the License at
 *     http://www.apache.org/licenses/LICENSE-2.0
 *  Unless required by applicable law or agreed to in writing, software
 *  distributed under the License is distributed on an "AS IS" BASIS,
 *  WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
 *  See the License for the specific language governing permissions and
 *  limitations under the License.
 *
 */

package org.hyperledger.fabric.sdk.idemix;

import org.apache.milagro.amcl.FP256BN.BIG;
import org.apache.milagro.amcl.FP256BN.ECP2;
import org.hyperledger.fabric.protos.idemix.Idemix;

/**
 * A NonRevocationProver is a prover that can prove that an identity mixer credential is not revoked.
 * For every RevocationAlgorithm, there will be an instantiation of NonRevocationProver.
 */
interface NonRevocationVerifier {
    /**
     * This method provides a non-revocation verifier depending on the Revocation algorithm
     *
     * @param algorithm Revocation mechanism to use
     * @return NonRevocationVerifier or null if not allowed
     */
    static NonRevocationVerifier getNonRevocationVerifier(RevocationAlgorithm algorithm) {
        if (algorithm == null) {
            throw new IllegalArgumentException("Revocation algorithm cannot be null");
        }
        switch (algorithm) {
            case ALG_NO_REVOCATION:
                return new NopNonRevocationVerifier();
            default:
                // Revocation algorithm not supported
                throw new Error("Revocation algorithm " + algorithm.name() + " not supported");
        }
    }

    /**
     * recomputeFSContribution verifies a non-revocation proof by recomputing the Fiat-Shamir contribution.
     *
     * @param proof     Non revocation proof
     * @param challenge Challenge
     * @param epochPK   Epoch PK
     * @param proofSRh  Proof of revocation handle
     * @return The recomputed FSContribution
     */
    byte[] recomputeFSContribution(Idemix.NonRevocationProof proof, BIG challenge, ECP2 epochPK, BIG proofSRh);
}




© 2015 - 2024 Weber Informatics LLC | Privacy Policy