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