Skip to content

Commit

Permalink
feat: rename Webhook class to WebhookValidation
Browse files Browse the repository at this point in the history
  • Loading branch information
ilfa committed Nov 22, 2024
1 parent 0812c43 commit 817b444
Show file tree
Hide file tree
Showing 6 changed files with 20 additions and 14 deletions.
6 changes: 6 additions & 0 deletions .changeset/chilly-dryers-fail.md
Original file line number Diff line number Diff line change
@@ -0,0 +1,6 @@
---
"fingerprint-pro-server-api-java-sdk": major
---

Rename `Webhook` class to `WebhookValidation`.
Right now, `Webhook` class points to the actual data model.
4 changes: 2 additions & 2 deletions README.md
Original file line number Diff line number Diff line change
Expand Up @@ -240,7 +240,7 @@ This SDK provides utility method for verifying the HMAC signature of the incomin

Here is an example implementation using Spring Boot:
```java
import com.fingerprint.sdk.Webhook;
import com.fingerprint.sdk.WebhookValidation;

@RestController
class WebhookController {
Expand All @@ -257,7 +257,7 @@ class WebhookController {
return ResponseEntity.status(HttpStatus.BAD_REQUEST).body("Missing fpjs-event-signature header");
}

final boolean isValidSignature = Webhook.isValidWebhookSignature(signature, webhook, secret);
final boolean isValidSignature = WebhookValidation.isValidWebhookSignature(signature, webhook, secret);
if (!isValidSignature) {
return ResponseEntity.status(HttpStatus.BAD_REQUEST).body("Webhook signature is not valid");
}
Expand Down
Original file line number Diff line number Diff line change
@@ -1,6 +1,6 @@
package com.fingerprint.example;

import com.fingerprint.sdk.Webhook;
import com.fingerprint.sdk.WebhookValidation;

import java.nio.charset.StandardCharsets;
import java.security.NoSuchAlgorithmException;
Expand All @@ -13,7 +13,7 @@ public static void main(String... args) {
final byte[] data = "data".getBytes(StandardCharsets.UTF_8);

try {
boolean isSignatureValid = Webhook.isValidWebhookSignature(header, data, secret);
boolean isSignatureValid = WebhookValidation.isValidWebhookSignature(header, data, secret);
if (isSignatureValid) {
System.out.println("Webhook signature is valid");
} else {
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -8,7 +8,7 @@
import java.security.InvalidKeyException;
import java.security.NoSuchAlgorithmException;

public class Webhook {
public class WebhookValidation {

/**
* Verifies the HMAC signature extracted from the "fpjs-event-signature" header of the incoming request.
Expand Down
Original file line number Diff line number Diff line change
@@ -1,6 +1,6 @@
package com.fingerprint;

import com.fingerprint.sdk.Webhook;
import com.fingerprint.sdk.WebhookValidation;
import org.junit.jupiter.api.Assertions;
import org.junit.jupiter.api.Test;
import org.junit.jupiter.api.TestInstance;
Expand All @@ -9,40 +9,40 @@
import java.security.NoSuchAlgorithmException;

@TestInstance(TestInstance.Lifecycle.PER_CLASS)
public class WebhookTest {
public class WebhookValidationTest {

private static final String validHeader = "v1=1b2c16b75bd2a870c114153ccda5bcfca63314bc722fa160d690de133ccbb9db";
private static final String secret = "secret";
private static final byte[] data = "data".getBytes(StandardCharsets.UTF_8);

@Test
public void validHeaderTest() throws NoSuchAlgorithmException {
boolean result = Webhook.isValidWebhookSignature(validHeader, data, secret);
boolean result = WebhookValidation.isValidWebhookSignature(validHeader, data, secret);
Assertions.assertTrue(result);
}

@Test
public void invalidHeaderTest() throws NoSuchAlgorithmException {
boolean result = Webhook.isValidWebhookSignature("v2=wrong", data, secret);
boolean result = WebhookValidation.isValidWebhookSignature("v2=wrong", data, secret);
assert !result;
}

@Test
public void headerWithoutVersionTest() throws NoSuchAlgorithmException {
boolean result = Webhook.isValidWebhookSignature("secretonly", data, secret);
boolean result = WebhookValidation.isValidWebhookSignature("secretonly", data, secret);
assert !result;
}

@Test
public void emptySecretTest() throws NoSuchAlgorithmException {
Assertions.assertThrows(IllegalArgumentException.class, () -> {
Webhook.isValidWebhookSignature("v1=value", data, "");
WebhookValidation.isValidWebhookSignature("v1=value", data, "");
});
}

@Test
public void emptyDataTest() throws NoSuchAlgorithmException {
boolean result = Webhook.isValidWebhookSignature(validHeader, "".getBytes(), secret);
boolean result = WebhookValidation.isValidWebhookSignature(validHeader, "".getBytes(), secret);
assert !result;
}

Expand Down
4 changes: 2 additions & 2 deletions template/README.mustache
Original file line number Diff line number Diff line change
Expand Up @@ -267,7 +267,7 @@ This SDK provides utility method for verifying the HMAC signature of the incomin
Here is an example implementation using Spring Boot:
```java
import com.fingerprint.sdk.Webhook;
import com.fingerprint.sdk.WebhookValidation;
@RestController
class WebhookController {
Expand All @@ -284,7 +284,7 @@ class WebhookController {
return ResponseEntity.status(HttpStatus.BAD_REQUEST).body("Missing fpjs-event-signature header");
}
final boolean isValidSignature = Webhook.isValidWebhookSignature(signature, webhook, secret);
final boolean isValidSignature = WebhookValidation.isValidWebhookSignature(signature, webhook, secret);
if (!isValidSignature) {
return ResponseEntity.status(HttpStatus.BAD_REQUEST).body("Webhook signature is not valid");
}
Expand Down

0 comments on commit 817b444

Please sign in to comment.