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

org.bouncycastle.pqc.crypto.ExchangePair Maven / Gradle / Ivy

Go to download

The Bouncy Castle Crypto package is a Java implementation of cryptographic algorithms. This jar contains JCE provider and lightweight API for the Bouncy Castle Cryptography APIs for JDK 1.8 and up.

There is a newer version: 1.78.1
Show newest version
package org.bouncycastle.pqc.crypto;

import org.bouncycastle.crypto.params.AsymmetricKeyParameter;
import org.bouncycastle.util.Arrays;

/**
 * Pair for a value exchange algorithm where the responding party has no private key, such as NewHope.
 */
public class ExchangePair
{
    private final AsymmetricKeyParameter publicKey;
    private final byte[] shared;

    /**
     * Base constructor.
     *
     * @param publicKey The responding party's public key.
     * @param shared the calculated shared value.
     */
    public ExchangePair(AsymmetricKeyParameter publicKey, byte[] shared)
    {
        this.publicKey = publicKey;
        this.shared = Arrays.clone(shared);
    }

    /**
     * Return the responding party's public key.
     *
     * @return the public key calculated for the exchange.
     */
    public AsymmetricKeyParameter getPublicKey()
    {
        return publicKey;
    }

    /**
     * Return the shared value calculated with public key.
     *
     * @return the shared value.
     */
    public byte[] getSharedValue()
    {
        return Arrays.clone(shared);
    }
}




© 2015 - 2024 Weber Informatics LLC | Privacy Policy