HEX
Server: Apache/2.4.65 (Ubuntu)
System: Linux ielts-store-v2 6.8.0-1036-gcp #38~22.04.1-Ubuntu SMP Thu Aug 14 01:19:18 UTC 2025 x86_64
User: root (0)
PHP: 7.2.34-54+ubuntu20.04.1+deb.sury.org+1
Disabled: pcntl_alarm,pcntl_fork,pcntl_waitpid,pcntl_wait,pcntl_wifexited,pcntl_wifstopped,pcntl_wifsignaled,pcntl_wifcontinued,pcntl_wexitstatus,pcntl_wtermsig,pcntl_wstopsig,pcntl_signal,pcntl_signal_get_handler,pcntl_signal_dispatch,pcntl_get_last_error,pcntl_strerror,pcntl_sigprocmask,pcntl_sigwaitinfo,pcntl_sigtimedwait,pcntl_exec,pcntl_getpriority,pcntl_setpriority,pcntl_async_signals,
Upload Files
File: //proc/self/cwd/wp-content/plugins/woocommerce-zapier/src/API/Controller/WebhookController.php
<?php

namespace OM4\WooCommerceZapier\API\Controller;

use OM4\WooCommerceZapier\API\API;
use OM4\WooCommerceZapier\WooCommerceResource\Manager as ResourceManager;
use WC_REST_Webhooks_Controller;
use WP_Error;
use WP_REST_Request;
use WP_REST_Response;

defined( 'ABSPATH' ) || exit;

/**
 * Exposes WooCommerce's REST API v3 Webhooks endpoint via the WooCommerce Zapier endpoint namespace.
 *
 * @since 2.0.0
 */
class WebhookController extends WC_REST_Webhooks_Controller {

	/**
	 * Endpoint namespace.
	 *
	 * @var string
	 */
	protected $namespace = API::REST_NAMESPACE;

	/**
	 * ResourceManager instance.
	 *
	 * @var ResourceManager
	 */
	protected $resource_manager;

	/**
	 * Target resource.
	 *
	 * @var string
	 */
	protected $resource;

	/**
	 * WebhookController constructor.
	 *
	 * @param ResourceManager $resource_manager ResourceManager instance.
	 *
	 * @since 2.1.0
	 */
	public function __construct( ResourceManager $resource_manager ) {
		$this->resource_manager = $resource_manager;
	}

	/**
	 * Handler for whenever a webhook is created via this controller.
	 *
	 * Allows us to filter/override the newly created webhook.
	 *
	 * @param WP_REST_Request $request Full details about the request.
	 * @return WP_Error|WP_REST_Response
	 *
	 * @since 2.1.0
	 */
	public function create_item( $request ) {
		// Validate webhook topic as it's required in order to determine the resource.
		// Topic validation is the same as `WC_REST_Webhooks_V1_Controller::create_item()`.
		if ( empty( $request['topic'] ) || ! wc_is_webhook_valid_topic( strtolower( $request['topic'] ) ) ) {
			return new WP_Error( "woocommerce_rest_{$this->post_type}_invalid_topic", __( 'Webhook topic is required and must be valid.', 'woocommerce-zapier' ), array( 'status' => 400 ) );
		}
		$key_parts      = explode( '.', $request['topic'] );
		$this->resource = $key_parts[0];
		return parent::create_item( $request );
	}

	/**
	 * Get the corresponding REST API version.
	 *
	 * @since 2.1.0
	 * @return string
	 */
	protected function get_default_api_version() {
		$resource = $this->resource_manager->get_resource( $this->resource );
		if ( ! $resource ) {
			// Not one of our resources.
			return parent::get_default_api_version();
		}
		$version = (string) $resource->get_controller_rest_api_version();
		return "wp_api_v$version";
	}
}