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

org.bouncycastle.pqc.crypto.saber.SABERKEMExtractor Maven / Gradle / Ivy

package org.bouncycastle.pqc.crypto.saber;

import org.bouncycastle.crypto.EncapsulatedSecretExtractor;

public class SABERKEMExtractor
    implements EncapsulatedSecretExtractor
{
    private SABEREngine engine;

    private SABERKeyParameters key;

    public SABERKEMExtractor(SABERKeyParameters privParams)
    {
        this.key = privParams;
        initCipher(key.getParameters());
    }
    private void initCipher(SABERParameters param)
    {
        engine = param.getEngine();
    }

    public byte[] extractSecret(byte[] encapsulation)
    {
        byte[] session_key = new byte[engine.getSessionKeySize()];
        engine.crypto_kem_dec(session_key, encapsulation, ((SABERPrivateKeyParameters)key).getPrivateKey());
        return session_key;
    }
    public int getInputSize()
    {
        return engine.getCipherTextSize();
    }
}




© 2015 - 2024 Weber Informatics LLC | Privacy Policy