HEX
Server: Apache/2
System: Linux server-80-13-140-150.da.direct 5.14.0-362.24.1.el9_3.0.1.x86_64 #1 SMP PREEMPT_DYNAMIC Thu Apr 4 22:31:43 UTC 2024 x86_64
User: cpt (1004)
PHP: 8.1.24
Disabled: exec,system,passthru,shell_exec,proc_close,proc_open,dl,popen,show_source,posix_kill,posix_mkfifo,posix_getpwuid,posix_setpgid,posix_setsid,posix_setuid,posix_setgid,posix_seteuid,posix_setegid,posix_uname
Upload Files
File: /home/cpt/public_html/wp-content/plugins/wpforms-lite/src/Integrations/Square/Api/WebhookEvent.php
<?php

namespace WPForms\Integrations\Square\Api;

use RuntimeException;
use WPForms\Integrations\Square\Helpers;
use WPForms\Vendor\Square\Utils\WebhooksHelper;

/**
 * Webhook event handler.
 *
 * @since 1.9.5
 */
class WebhookEvent {

	/**
	 * Construct and validate the Square webhook event.
	 *
	 * @since 1.9.5
	 *
	 * @param string $payload        The raw JSON payload from Square.
	 * @param string $signature      The Square webhook signature from headers.
	 * @param string $webhook_secret The webhook signing secret from Square Developer Dashboard.
	 *
	 * @return object The decoded event data.
	 *
	 * @throws RuntimeException If the webhook payload structure is invalid.
	 */
	public static function construct_event( string $payload, string $signature, string $webhook_secret ) {

		// Validate the webhook signature.
		if ( ! WebhooksHelper::isValidWebhookEventSignature( $payload, $signature, $webhook_secret, Helpers::get_webhook_url() ) ) {
			throw new RuntimeException( 'Invalid webhook signature. Possible unauthorized request.' );
		}

		// Decode JSON payload.
		$event = json_decode( $payload, false );

		// Check for JSON decoding errors.
		if ( json_last_error() !== JSON_ERROR_NONE ) {
			throw new RuntimeException( 'Invalid JSON payload' );
		}

		if ( ! $event || ! isset( $event->type, $event->data ) ) {
			throw new RuntimeException( 'Invalid webhook payload structure.' );
		}

		return $event;
	}
}