data:image/s3,"s3://crabby-images/02ace/02ace956f9868cf2a1a780bd2c0a517cd3a46077" alt="JAR search and dependency download from the Maven repository"
com.constantcontact.webhooks.helper.WebHookValidator Maven / Gradle / Ivy
The newest version!
package com.constantcontact.webhooks.helper;
import org.apache.commons.codec.binary.Base64;
import javax.crypto.Mac;
import javax.crypto.spec.SecretKeySpec;
import java.security.InvalidKeyException;
import java.security.NoSuchAlgorithmException;
/**
* Represents a helper class that validates a Webhook.
*
* @author ConstantContact
* @see com.constantcontact.webhooks.CTCTWebhookUtil
*/
public class WebHookValidator {
/**
* The x-ctct-hmac-sha256 header value
*/
private String ctctHttpHeader;
/**
* The body message containg the JSON message
*/
private String body;
/**
* The client secret associated with the api key
*/
private String sharedSecret;
public WebHookValidator(String xCtctHmacSHA256, String body, String sharedSecret) {
this.ctctHttpHeader = xCtctHmacSHA256;
this.body = body;
this.sharedSecret = sharedSecret;
}
/**
* To verify that the request came from Constant Contact, compute the HMAC digest and compare it to the value in the x-ctct-hmac-sha256 header.
* If they match, you can be sure that the webhook was sent by Constant Contact and the message has not been compromised.
*
* @return true if webhook is valid; false otherwise.
*
* @throws NoSuchAlgorithmException Thrown when the encryption algorithm used for validation is not available. (Should not happen.)
*/
public boolean isValid() throws NoSuchAlgorithmException {
Mac macGenerator = Mac.getInstance("HmacSHA256");
SecretKeySpec encryptedKey = new SecretKeySpec(sharedSecret.getBytes(), "SHA-256");
try {
macGenerator.init(encryptedKey);
} catch (InvalidKeyException e) {
throw new IllegalStateException("Cannot initialize Mac Generator", e);
}
byte[] output = macGenerator.doFinal(body.getBytes());
return Base64.encodeBase64String(output).compareToIgnoreCase(ctctHttpHeader) == 0;
}
}
© 2015 - 2025 Weber Informatics LLC | Privacy Policy