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

com.nimbusds.jose.crypto.impl.HMAC Maven / Gradle / Ivy

/*
 * nimbus-jose-jwt
 *
 * Copyright 2012-2023, Connect2id Ltd and contributors.
 *
 * 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 com.nimbusds.jose.crypto.impl;


import com.nimbusds.jose.JOSEException;
import net.jcip.annotations.ThreadSafe;

import javax.crypto.Mac;
import javax.crypto.SecretKey;
import javax.crypto.spec.SecretKeySpec;
import java.security.InvalidKeyException;
import java.security.NoSuchAlgorithmException;
import java.security.Provider;


/**
 * Static methods for Hash-based Message Authentication Codes (HMAC). This
 * class is thread-safe.
 *
 * @author Axel Nennker
 * @author Vladimir Dzhuvinov
 * @author Ulrich Winter
 * @version 2023-09-14
 */
@ThreadSafe
public class HMAC {


	/**
	 * Gets an initialised Message Authentication Code (MAC) service
	 * instance.
	 *
	 * @param secretKey The secret key, with the appropriate HMAC
	 *                  algorithm. Must not be {@code null}.
	 * @param provider  The JCA provider, {@code null} to use the default.
	 *
	 * @return The MAC service instance.
	 *
	 * @throws JOSEException If the algorithm is not supported or the
	 *                       MAC secret key is invalid.
	 */
	public static Mac getInitMac(final SecretKey secretKey, final Provider provider)
		throws JOSEException {

		return getInitMac(secretKey.getAlgorithm(), secretKey, provider);
	}


	/**
	 * Gets an initialised Message Authentication Code (MAC) service
	 * instance.
	 *
	 * @param alg       The Java Cryptography Architecture (JCA) HMAC
	 * 	            algorithm name. Must not be {@code null}.
	 * @param secretKey The secret key. Its algorithm name is ignored.
	 *                  Must not be {@code null}.
	 * @param provider  The JCA provider, {@code null} to use the default.
	 *
	 * @return The MAC service instance.
	 *
	 * @throws JOSEException If the algorithm is not supported or the
	 *                       MAC secret key is invalid.
	 */
	public static Mac getInitMac(final String alg,
				     final SecretKey secretKey,
				     final Provider provider)
		throws JOSEException {

		Mac mac;
		try {
			if (provider != null) {
				mac = Mac.getInstance(alg, provider);
			} else {
				mac = Mac.getInstance(alg);
			}

			mac.init(secretKey);

		} catch (NoSuchAlgorithmException e) {
			throw new JOSEException("Unsupported HMAC algorithm: " + e.getMessage(), e);
		} catch (InvalidKeyException e) {
			throw new JOSEException("Invalid HMAC key: " + e.getMessage(), e);
		}

		return mac;
	}


	/**
	 * Computes a Hash-based Message Authentication Code (HMAC) for the
	 * specified secret and message.
	 *
	 * @param alg      The Java Cryptography Architecture (JCA) HMAC
	 *                 algorithm name. Must not be {@code null}.
	 * @param secret   The secret. Must not be {@code null}.
	 * @param message  The message. Must not be {@code null}.
	 * @param provider The JCA provider, {@code null} to use the default.
	 *
	 * @return The computed HMAC.
	 *
	 * @throws JOSEException If the algorithm is not supported or the
	 *                       MAC secret key is invalid.
	 */
	@Deprecated
	public static byte[] compute(final String alg,
				     final byte[] secret,
				     final byte[] message,
				     final Provider provider)
		throws JOSEException {

		return compute(alg, new SecretKeySpec(secret, alg), message, provider);
	}


	/**
	 * Computes a Hash-based Message Authentication Code (HMAC) for the
	 * specified secret key and message.
	 *
	 * @param alg       The Java Cryptography Architecture (JCA) HMAC
	 *                  algorithm name. Must not be {@code null}.
	 * @param secretKey The secret key. Its algorithm name is ignored.
	 *                  Must not be {@code null}.
	 * @param message   The message. Must not be {@code null}.
	 * @param provider  The JCA provider, {@code null} to use the default.
	 *
	 * @return The computed HMAC.
	 *
	 * @throws JOSEException If the algorithm is not supported or the MAC
	 *                       secret key is invalid.
	 */
	public static byte[] compute(final String alg,
				     final SecretKey secretKey,
				     final byte[] message,
				     final Provider provider)
			throws JOSEException {

		Mac mac = getInitMac(alg, secretKey, provider);
		mac.update(message);
		return mac.doFinal();
	}

	/**
	 * Computes a Hash-based Message Authentication Code (HMAC) for the
	 * specified secret key and message.
	 *
	 * @param secretKey The secret key, with the appropriate HMAC
	 *                  algorithm. Must not be {@code null}.
	 * @param message   The message. Must not be {@code null}.
	 * @param provider  The JCA provider, or {@code null} to use the
	 *                  default one.
	 *
	 * @return A MAC service instance.
	 *
	 * @throws JOSEException If the algorithm is not supported or the MAC
	 *                       secret key is invalid.
	 */
	public static byte[] compute(final SecretKey secretKey,
				     final byte[] message,
				     final Provider provider)
			throws JOSEException {

		return compute(secretKey.getAlgorithm(), secretKey, message, provider);
	}
}




© 2015 - 2025 Weber Informatics LLC | Privacy Policy