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

org.bouncycastle.pqc.crypto.xmss.DefaultXMSSMTOid 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 Java 1.5 and later with debug enabled.

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

import java.util.Collections;
import java.util.HashMap;
import java.util.Map;

/**
 * XMSSOid^MT class.
 *
 */
public final class DefaultXMSSMTOid implements XMSSOid {

	/**
	 * XMSS^MT OID lookup table.
	 */
	private static final Map oidLookupTable;

	static {
		Map map = new HashMap();
		map.put(createKey("SHA-256", 32, 16, 67, 20, 2),
				new DefaultXMSSMTOid(0x01000001, "XMSSMT_SHA2-256_W16_H20_D2"));
		map.put(createKey("SHA-256", 32, 16, 67, 20, 4),
				new DefaultXMSSMTOid(0x01000001, "XMSSMT_SHA2-256_W16_H20_D4"));
		map.put(createKey("SHA-256", 32, 16, 67, 40, 2),
				new DefaultXMSSMTOid(0x01000001, "XMSSMT_SHA2-256_W16_H40_D2"));
		map.put(createKey("SHA-256", 32, 16, 67, 40, 2),
				new DefaultXMSSMTOid(0x01000001, "XMSSMT_SHA2-256_W16_H40_D4"));
		map.put(createKey("SHA-256", 32, 16, 67, 40, 4),
				new DefaultXMSSMTOid(0x01000001, "XMSSMT_SHA2-256_W16_H40_D8"));
		map.put(createKey("SHA-256", 32, 16, 67, 60, 8),
				new DefaultXMSSMTOid(0x01000001, "XMSSMT_SHA2-256_W16_H60_D3"));
		map.put(createKey("SHA-256", 32, 16, 67, 60, 6),
				new DefaultXMSSMTOid(0x01000001, "XMSSMT_SHA2-256_W16_H60_D6"));
		map.put(createKey("SHA-256", 32, 16, 67, 60, 12),
				new DefaultXMSSMTOid(0x01000001, "XMSSMT_SHA2-256_W16_H60_D12"));
		map.put(createKey("SHA2-512", 64, 16, 131, 20, 2),
				new DefaultXMSSMTOid(0x01000001, "XMSSMT_SHA2-512_W16_H20_D2"));
		map.put(createKey("SHA2-512", 64, 16, 131, 20, 4),
				new DefaultXMSSMTOid(0x01000001, "XMSSMT_SHA2-512_W16_H20_D4"));
		map.put(createKey("SHA2-512", 64, 16, 131, 40, 2),
				new DefaultXMSSMTOid(0x01000001, "XMSSMT_SHA2-512_W16_H40_D2"));
		map.put(createKey("SHA2-512", 64, 16, 131, 40, 4),
				new DefaultXMSSMTOid(0x01000001, "XMSSMT_SHA2-512_W16_H40_D4"));
		map.put(createKey("SHA2-512", 64, 16, 131, 40, 8),
				new DefaultXMSSMTOid(0x01000001, "XMSSMT_SHA2-512_W16_H40_D8"));
		map.put(createKey("SHA2-512", 64, 16, 131, 60, 3),
				new DefaultXMSSMTOid(0x01000001, "XMSSMT_SHA2-512_W16_H60_D3"));
		map.put(createKey("SHA2-512", 64, 16, 131, 60, 6),
				new DefaultXMSSMTOid(0x01000001, "XMSSMT_SHA2-512_W16_H60_D6"));
		map.put(createKey("SHA2-512", 64, 16, 131, 60, 12),
				new DefaultXMSSMTOid(0x01000001, "XMSSMT_SHA2-512_W16_H60_D12"));
		map.put(createKey("SHAKE128", 32, 16, 67, 20, 2),
				new DefaultXMSSMTOid(0x01000001, "XMSSMT_SHAKE128_W16_H20_D2"));
		map.put(createKey("SHAKE128", 32, 16, 67, 20, 4),
				new DefaultXMSSMTOid(0x01000001, "XMSSMT_SHAKE128_W16_H20_D4"));
		map.put(createKey("SHAKE128", 32, 16, 67, 40, 2),
				new DefaultXMSSMTOid(0x01000001, "XMSSMT_SHAKE128_W16_H40_D2"));
		map.put(createKey("SHAKE128", 32, 16, 67, 40, 4),
				new DefaultXMSSMTOid(0x01000001, "XMSSMT_SHAKE128_W16_H40_D4"));
		map.put(createKey("SHAKE128", 32, 16, 67, 40, 8),
				new DefaultXMSSMTOid(0x01000001, "XMSSMT_SHAKE128_W16_H40_D8"));
		map.put(createKey("SHAKE128", 32, 16, 67, 60, 3),
				new DefaultXMSSMTOid(0x01000001, "XMSSMT_SHAKE128_W16_H60_D3"));
		map.put(createKey("SHAKE128", 32, 16, 67, 60, 6),
				new DefaultXMSSMTOid(0x01000001, "XMSSMT_SHAKE128_W16_H60_D6"));
		map.put(createKey("SHAKE128", 32, 16, 67, 60, 12),
				new DefaultXMSSMTOid(0x01000001, "XMSSMT_SHAKE128_W16_H60_D12"));
		map.put(createKey("SHAKE256", 64, 16, 131, 20, 2),
				new DefaultXMSSMTOid(0x01000001, "XMSSMT_SHAKE256_W16_H20_D2"));
		map.put(createKey("SHAKE256", 64, 16, 131, 20, 4),
				new DefaultXMSSMTOid(0x01000001, "XMSSMT_SHAKE256_W16_H20_D4"));
		map.put(createKey("SHAKE256", 64, 16, 131, 40, 2),
				new DefaultXMSSMTOid(0x01000001, "XMSSMT_SHAKE256_W16_H40_D2"));
		map.put(createKey("SHAKE256", 64, 16, 131, 40, 4),
				new DefaultXMSSMTOid(0x01000001, "XMSSMT_SHAKE256_W16_H40_D4"));
		map.put(createKey("SHAKE256", 64, 16, 131, 40, 8),
				new DefaultXMSSMTOid(0x01000001, "XMSSMT_SHAKE256_W16_H40_D8"));
		map.put(createKey("SHAKE256", 64, 16, 131, 60, 3),
				new DefaultXMSSMTOid(0x01000001, "XMSSMT_SHAKE256_W16_H60_D3"));
		map.put(createKey("SHAKE256", 64, 16, 131, 60, 6),
				new DefaultXMSSMTOid(0x01000001, "XMSSMT_SHAKE256_W16_H60_D6"));
		map.put(createKey("SHAKE256", 64, 16, 131, 60, 12),
				new DefaultXMSSMTOid(0x01000001, "XMSSMT_SHAKE256_W16_H60_D12"));
		oidLookupTable = Collections.unmodifiableMap(map);
	}

	/**
	 * OID.
	 */
	private final int oid;
	/**
	 * String representation of OID.
	 */
	private final String stringRepresentation;

	/**
	 * Constructor...
	 *
	 * @param oid
	 *            OID.
	 * @param stringRepresentation
	 *            String representation of OID.
	 */
	private DefaultXMSSMTOid(int oid, String stringRepresentation) {
		super();
		this.oid = oid;
		this.stringRepresentation = stringRepresentation;
	}

	/**
	 * Lookup OID.
	 *
	 * @param algorithmName
	 *            Algorithm name.
	 * @param winternitzParameter
	 *            Winternitz parameter.
	 * @param height
	 *            Binary tree height.
	 * @return XMSS OID if parameters were found, null else.
	 */
	public static DefaultXMSSMTOid lookup(String algorithmName, int digestSize, int winternitzParameter, int len,
			int height, int layers) {
		if (algorithmName == null) {
			throw new NullPointerException("algorithmName == null");
		}
		return oidLookupTable.get(createKey(algorithmName, digestSize, winternitzParameter, len, height, layers));
	}

	/**
	 * Create a key based on parameters.
	 *
	 * @param algorithmName
	 *            Algorithm name.
	 * @param winternitzParameter
	 *            Winternitz Parameter.
	 * @param height
	 *            Binary tree height.
	 * @return String representation of parameters for lookup table.
	 */
	private static String createKey(String algorithmName, int digestSize, int winternitzParameter, int len, int height,
			int layers) {
		if (algorithmName == null) {
			throw new NullPointerException("algorithmName == null");
		}
		return algorithmName + "-" + digestSize + "-" + winternitzParameter + "-" + len + "-" + height + "-" + layers;
	}

	/**
	 * Getter OID.
	 *
	 * @return OID.
	 */
	public int getOid() {
		return oid;
	}

	public String toString() {
		return stringRepresentation;
	}
}




© 2015 - 2025 Weber Informatics LLC | Privacy Policy