<?php
namespace ElementorPro\Modules\Forms\Actions;
use Elementor\Controls_Manager;
use ElementorPro\Modules\Forms\Classes\Action_Base;
if ( ! defined( 'ABSPATH' ) ) {
exit; // Exit if accessed directly
}
class Webhook extends Action_Base {
public function get_name() {
return 'webhook';
}
public function get_label() {
return esc_html__( 'Webhook', 'elementor-pro' );
}
public function register_settings_section( $widget ) {
$widget->start_controls_section(
'section_webhook',
[
'label' => esc_html__( 'Webhook', 'elementor-pro' ),
'condition' => [
'submit_actions' => $this->get_name(),
],
]
);
$widget->add_control(
'webhooks',
[
'label' => esc_html__( 'Webhook URL', 'elementor-pro' ),
'type' => Controls_Manager::TEXT,
'placeholder' => esc_html__( 'https://your-webhook-url.com', 'elementor-pro' ),
'ai' => [
'active' => false,
],
'label_block' => true,
'separator' => 'before',
'description' => esc_html__( 'Enter the integration URL (like Zapier) that will receive the form\'s submitted data.', 'elementor-pro' ),
'render_type' => 'none',
'dynamic' => [
'active' => true,
],
]
);
$widget->add_control(
'webhooks_advanced_data',
[
'label' => esc_html__( 'Advanced Data', 'elementor-pro' ),
'type' => Controls_Manager::SWITCHER,
'default' => 'no',
'render_type' => 'none',
]
);
$widget->end_controls_section();
}
public function on_export( $element ) {}
public function run( $record, $ajax_handler ) {
$settings = $record->get( 'form_settings' );
if ( empty( $settings['webhooks'] ) ) {
return;
}
if ( isset( $settings['webhooks_advanced_data'] ) && 'yes' === $settings['webhooks_advanced_data'] ) {
$body['form'] = [
'id' => $settings['id'],
'name' => $settings['form_name'],
];
$body['fields'] = $record->get( 'fields' );
$body['meta'] = $record->get( 'meta' );
} else {
$body = $record->get_formatted_data( true );
$body['form_id'] = $settings['id'];
$body['form_name'] = $settings['form_name'];
}
$args = [
'body' => $body,
];
/**
* Forms webhook request arguments.
*
* Filters the request arguments delivered by the form webhook when executing
* an ajax request.
*
* @since 1.0.0
*
* @param array $args Webhook request arguments.
* @param Form_Record $record An instance of the form record.
*/
$args = apply_filters( 'elementor_pro/forms/webhooks/request_args', $args, $record );
$response = wp_remote_post( $settings['webhooks'], $args );
/**
* Elementor form webhook response.
*
* Fires when the webhook response is retrieved by Elementor forms. This hook
* allows developers to add functionality after recieving webhook responses.
*
* @since 1.0.0
*
* @param \WP_Error|array $response The response or WP_Error on failure.
* @param Form_Record $record An instance of the form record.
*/
do_action( 'elementor_pro/forms/webhooks/response', $response, $record );
if ( 200 !== (int) wp_remote_retrieve_response_code( $response ) ) {
throw new \Exception( 'Webhook error.' );
}
}
}