index of
/
home
/
thefkyzp
/
easyloanly.com
/
wp-content
/
plugins
/
forminator
/
admin
/
classes
/
File: /home/thefkyzp/easyloanly.com/wp-content/plugins/forminator/admin/classes/class-admin-ajax.php
<?php if ( ! defined( 'ABSPATH' ) ) { die(); } /** * Class Forminator_Admin_AJAX * * @since 1.0 */ class Forminator_Admin_AJAX { /** * Forminator_Admin_AJAX constructor. * * @since 1.0 */ public function __construct() { // Handle close welcome box add_action( 'wp_ajax_forminator_dismiss_welcome', array( $this, 'dismiss_welcome' ) ); add_action( 'wp_ajax_nopriv_forminator_dismiss_welcome', array( $this, 'dismiss_welcome' ) ); // Handle load google fonts add_action( 'wp_ajax_forminator_load_google_fonts', array( $this, 'load_google_fonts' ) ); // Handle load reCaptcha preview add_action( 'wp_ajax_forminator_load_recaptcha_preview', array( $this, 'load_recaptcha_preview' ) ); add_action( 'wp_ajax_forminator_load_hcaptcha_preview', array( $this, 'load_hcaptcha_preview' ) ); // Handle save settings add_action( 'wp_ajax_forminator_save_builder', array( $this, 'save_builder' ) ); add_action( 'wp_ajax_forminator_save_poll', array( $this, 'save_poll_form' ) ); add_action( 'wp_ajax_forminator_save_quiz_nowrong', array( $this, 'save_quiz' ) ); add_action( 'wp_ajax_forminator_save_quiz_knowledge', array( $this, 'save_quiz' ) ); add_action( 'wp_ajax_forminator_save_login', array( $this, 'save_login' ) ); add_action( 'wp_ajax_forminator_save_register', array( $this, 'save_register' ) ); // Handle settings popups. add_action( 'wp_ajax_forminator_load_captcha_popup', array( $this, 'load_captcha' ) ); add_action( 'wp_ajax_forminator_save_captcha_popup', array( $this, 'save_captcha' ) ); add_action( 'wp_ajax_forminator_load_currency_popup', array( $this, 'load_currency' ) ); add_action( 'wp_ajax_forminator_save_currency_popup', array( $this, 'save_currency' ) ); add_action( 'wp_ajax_forminator_load_pagination_entries_popup', array( $this, 'load_pagination_entries' ) ); add_action( 'wp_ajax_forminator_save_pagination_entries_popup', array( $this, 'save_pagination_entries' ) ); add_action( 'wp_ajax_forminator_load_pagination_listings_popup', array( $this, 'load_pagination_listings' ) ); add_action( 'wp_ajax_forminator_save_pagination_listings_popup', array( $this, 'save_pagination_listings' ) ); add_action( 'wp_ajax_forminator_load_email_settings_popup', array( $this, 'load_email_form' ) ); add_action( 'wp_ajax_forminator_load_uninstall_settings_popup', array( $this, 'load_uninstall_form' ) ); add_action( 'wp_ajax_forminator_save_uninstall_settings_popup', array( $this, 'save_uninstall_form' ) ); add_action( 'wp_ajax_forminator_load_preview_cforms_popup', array( $this, 'preview_module' ) ); add_action( 'wp_ajax_forminator_load_preview_polls_popup', array( $this, 'preview_module' ) ); add_action( 'wp_ajax_forminator_load_preview_quizzes_popup', array( $this, 'preview_module' ) ); // Handle exports popup add_action( 'wp_ajax_forminator_load_exports_popup', array( $this, 'load_exports' ) ); add_action( 'wp_ajax_forminator_clear_exports_popup', array( $this, 'clear_exports' ) ); // Handle search user email add_action( 'wp_ajax_forminator_builder_search_emails', array( $this, 'search_emails' ) ); add_action( 'wp_ajax_forminator_load_privacy_settings_popup', array( $this, 'load_privacy_settings' ) ); add_action( 'wp_ajax_forminator_save_privacy_settings_popup', array( $this, 'save_privacy_settings' ) ); add_action( 'wp_ajax_forminator_load_export_form_popup', array( $this, 'load_export' ) ); add_action( 'wp_ajax_forminator_load_import_form_popup', array( $this, 'load_import' ) ); add_action( 'wp_ajax_forminator_save_import_form_popup', array( $this, 'save_import' ) ); add_action( 'wp_ajax_forminator_load_import_form_cf7_popup', array( $this, 'load_import_form_cf7' ) ); add_action( 'wp_ajax_forminator_save_import_form_cf7_popup', array( $this, 'save_import_form_cf7' ) ); add_action( 'wp_ajax_forminator_load_import_form_ninja_popup', array( $this, 'load_import_form_ninja' ) ); add_action( 'wp_ajax_forminator_save_import_form_ninja_popup', array( $this, 'save_import_form_ninja' ) ); add_action( 'wp_ajax_forminator_load_import_form_gravity_popup', array( $this, 'load_import_form_gravity' ) ); add_action( 'wp_ajax_forminator_save_import_form_gravity_popup', array( $this, 'save_import_form_gravity' ) ); add_action( 'wp_ajax_forminator_load_export_poll_popup', array( $this, 'load_export' ) ); add_action( 'wp_ajax_forminator_load_import_poll_popup', array( $this, 'load_import' ) ); add_action( 'wp_ajax_forminator_save_import_poll_popup', array( $this, 'save_import' ) ); add_action( 'wp_ajax_forminator_delete_poll_submissions', array( $this, 'delete_poll_submissions' ) ); add_action( 'wp_ajax_forminator_load_export_quiz_popup', array( $this, 'load_export' ) ); add_action( 'wp_ajax_forminator_load_import_quiz_popup', array( $this, 'load_import' ) ); add_action( 'wp_ajax_forminator_save_import_quiz_popup', array( $this, 'save_import' ) ); // Handle PDFs. add_action( 'wp_ajax_forminator_save_pdf', array( $this, 'save_pdf' ) ); add_action( 'wp_ajax_forminator_fetch_pdfs', array( $this, 'fetch_pdfs' ) ); add_action( 'wp_ajax_forminator_delete_pdf', array( $this, 'delete_pdf' ) ); add_action( 'wp_ajax_forminator_save_accessibility_settings_popup', array( $this, 'save_accessibility_settings', ) ); add_action( 'wp_ajax_forminator_save_dashboard_settings_popup', array( $this, 'save_dashboard_settings' ) ); add_action( 'wp_ajax_forminator_stripe_settings_modal', array( $this, 'stripe_settings_modal' ) ); add_action( 'wp_ajax_forminator_stripe_update_page', array( $this, 'stripe_update_page' ) ); add_action( 'wp_ajax_forminator_disconnect_stripe', array( $this, 'stripe_disconnect' ) ); add_action( 'wp_ajax_forminator_paypal_settings_modal', array( $this, 'paypal_settings_modal' ) ); add_action( 'wp_ajax_forminator_paypal_update_page', array( $this, 'paypal_update_page' ) ); add_action( 'wp_ajax_forminator_disconnect_paypal', array( $this, 'paypal_disconnect' ) ); add_action( 'wp_ajax_forminator_save_payments_settings_popup', array( $this, 'save_payments' ) ); add_action( 'wp_ajax_forminator_dismiss_notification', array( $this, 'dismiss_notice' ) ); add_action( 'wp_ajax_forminator_dismiss_notice', array( $this, 'dismiss_admin_notice' ) ); add_action( 'wp_ajax_forminator_promote_remind_later', array( $this, 'promote_remind_later' ) ); add_action( 'wp_ajax_forminator_later_notification', array( $this, 'later_notice' ) ); add_action( 'wp_ajax_forminator_reset_tracking_data', array( $this, 'reset_tracking_data' ) ); add_action( 'wp_ajax_forminator_save_appearance_preset', array( $this, 'save_appearance_preset' ) ); add_action( 'wp_ajax_forminator_create_appearance_preset', array( $this, 'create_appearance_preset' ) ); add_action( 'wp_ajax_forminator_apply_appearance_preset', array( $this, 'apply_appearance_preset' ) ); add_action( 'wp_ajax_forminator_delete_appearance_preset', array( $this, 'delete_appearance_preset' ) ); add_action( 'wp_ajax_forminator_module_search', array( $this, 'module_search' ) ); // Process ajax actions. $ajax_actions = array( 'forminator_addons-install', 'forminator_addons-activate', 'forminator_addons-deactivate', 'forminator_addons-delete', 'forminator_addons-update', ); foreach ( $ajax_actions as $action ) { add_action( "wp_ajax_$action", array( $this, 'addons_page_actions' ) ); } add_action( 'wp_ajax_forminator_filter_report_data', array( $this, 'filter_report_data' ) ); add_action( 'wp_ajax_forminator_search_users', array( $this, 'search_users' ) ); add_action( 'wp_ajax_forminator_get_avatar', array( $this, 'get_avatar' ) ); add_action( 'wp_ajax_forminator_save_report', array( $this, 'save_report' ) ); add_action( 'wp_ajax_forminator_fetch_report', array( $this, 'fetch_report' ) ); add_action( 'wp_ajax_forminator_report_update_status', array( $this, 'update_report_status' ) ); // Process Permission settings. add_action( 'wp_ajax_forminator_save_permissions', array( $this, 'save_permissions' ) ); } /** * Save quizzes * * @since 1.0 * @since 1.1 change superglobal POST to `get_post_data` */ public function save_quiz() { if ( ! forminator_is_user_allowed( 'forminator-quiz' ) ) { wp_send_json_error( esc_html__( 'Invalid request, you are not allowed to do that action.', 'forminator' ) ); } forminator_validate_ajax( 'forminator_save_quiz', false, 'forminator-quiz' ); $submitted_data = $this->get_post_data(); $quiz_data = array(); if ( ! empty( $_POST['data'] ) ) { $quiz_data = Forminator_Core::sanitize_array( json_decode( wp_unslash( $_POST['data'] ), true ) ); } $id = isset( $submitted_data['form_id'] ) ? intval( $submitted_data['form_id'] ) : 0; $settings = isset( $quiz_data['settings'] ) ? $quiz_data['settings'] : array(); $title = isset( $submitted_data['quiz_title'] ) ? $submitted_data['quiz_title'] : $submitted_data['formName']; $status = isset( $submitted_data['status'] ) ? $submitted_data['status'] : ''; $version = isset( $submitted_data['version'] ) ? $submitted_data['version'] : '1.0'; $template = new stdClass(); $template->type = isset( $submitted_data['action'] ) ? $submitted_data['action'] : ''; // Check if results exist if ( isset( $quiz_data['results'] ) && is_array( $quiz_data['results'] ) ) { $template->results = $quiz_data['results']; } // Check if answers exist if ( isset( $quiz_data['questions'] ) ) { $template->questions = $quiz_data['questions']; } if ( isset( $quiz_data['settings'] ) ) { $settings = $quiz_data['settings']; } $settings['version'] = $version; $template->settings = $settings; if ( isset( $quiz_data['notifications'] ) ) { $template->notifications = $quiz_data['notifications']; } $id = Forminator_Quiz_Admin::update( $id, $title, $status, $template ); if ( is_wp_error( $id ) ) { wp_send_json_error( $id->get_error_message() ); } else { wp_send_json_success( $id ); } } /** * Save poll * * @since 1.0 * @since 1.1 change superglobal POST to `get_post_data` */ public function save_poll_form() { if ( ! forminator_is_user_allowed( 'forminator-poll' ) ) { wp_send_json_error( esc_html__( 'Invalid request, you are not allowed to do that action.', 'forminator' ) ); } forminator_validate_ajax( 'forminator_save_poll', false, 'forminator-poll' ); $submitted_data = $this->get_post_data(); $poll_data = array(); if ( ! empty( $_POST['data'] ) ) { $poll_data = Forminator_Core::sanitize_array( json_decode( wp_unslash( $_POST['data'] ), true ) ); } $settings = isset( $poll_data['settings'] ) ? $poll_data['settings'] : array(); $id = isset( $submitted_data['form_id'] ) ? intval( $submitted_data['form_id'] ) : 0; $title = $submitted_data['formName']; $status = isset( $submitted_data['status'] ) ? $submitted_data['status'] : ''; $version = isset( $submitted_data['version'] ) ? $submitted_data['version'] : '1.0'; $template = new stdClass(); if ( isset( $poll_data['answers'] ) ) { $template->answers = $poll_data['answers']; } $settings['version'] = $version; $template->settings = $settings; $id = Forminator_Poll_Admin::update( $id, $title, $status, $template ); if ( is_wp_error( $id ) ) { wp_send_json_error( $id->get_error_message() ); } else { wp_send_json_success( $id ); } } /** * Save custom form fields * * @since 1.2 */ public function save_builder() { if ( ! forminator_is_user_allowed( 'forminator-cform' ) ) { wp_send_json_error( esc_html__( 'Invalid request, you are not allowed to do that action.', 'forminator' ) ); } forminator_validate_ajax( 'forminator_save_builder_fields', false, 'forminator-cform' ); $submitted_data = $this->get_post_data(); $form_data = array(); $fields = array(); $id = isset( $submitted_data['form_id'] ) ? intval( $submitted_data['form_id'] ) : 0; $title = $submitted_data['formName']; $status = isset( $submitted_data['status'] ) ? $submitted_data['status'] : ''; $version = isset( $submitted_data['version'] ) ? $submitted_data['version'] : '1.0'; $template = new stdClass(); $action = ''; if ( ! empty( $_POST['data'] ) ) { $form_data = Forminator_Core::sanitize_array( json_decode( wp_unslash( $_POST['data'] ), true ) ); } if ( is_null( $id ) || $id <= 0 ) { $form_model = new Forminator_Form_Model(); $action = 'create'; if ( empty( $status ) ) { $status = Forminator_Form_Model::STATUS_PUBLISH; } } else { $form_model = Forminator_Base_Form_Model::get_model( $id ); $action = 'update'; if ( ! is_object( $form_model ) ) { wp_send_json_error( esc_html__( 'Form model doesn\'t exist', 'forminator' ) ); } if ( empty( $status ) ) { $status = $form_model->status; } // we need to empty fields cause we will send new data $form_model->clear_fields(); } // Build the fields. if ( isset( $form_data ) ) { $fields = $form_data['wrappers']; unset( $form_data['wrappers'] ); } $template->fields = $fields; if ( isset( $form_data['integrationConditions'] ) ) { $template->integration_conditions = $form_data['integrationConditions']; } if ( isset( $form_data['behaviorArray'] ) ) { $template->behaviors = $form_data['behaviorArray']; } if ( isset( $form_data['notifications'] ) ) { $template->notifications = $form_data['notifications']; } // Sanitize settings $settings = $form_data['settings']; $activation_method = ! empty( $settings['activation-method'] ) ? $settings['activation-method'] : ''; if ( 'manual' == $activation_method ) { $settings['automatic-login'] = ''; } $settings['version'] = $version; $template->settings = $settings; $id = Forminator_Custom_Form_Admin::update( $id, $title, $status, $template ); if ( is_wp_error( $id ) ) { wp_send_json_error( $id->get_error_message() ); } else { wp_send_json_success( $id ); } } /** * Save PDF * * @since 2.0 */ public function save_pdf() { if ( ! forminator_is_user_allowed( 'forminator-cform' ) ) { wp_send_json_error( esc_html__( 'Invalid request, you are not allowed to do that action.', 'forminator' ) ); } forminator_validate_ajax( 'forminator_save_builder_fields', false, 'forminator-cform' ); try { $submitted_data = $this->get_post_data(); if ( ! class_exists( 'Forminator_PDF_Form_Actions' ) ) { throw new Exception( esc_html__( 'PDF add-on is not installed.', 'forminator' ) ); } $pdf_data['pdf_id'] = Forminator_PDF_Form_Actions::create_new_pdf_form( $submitted_data ); if ( empty( $pdf_data['pdf_id'] ) || ! is_numeric( $pdf_data['pdf_id'] ) ) { throw new Exception( esc_html__( 'Failed to create PDF. Please try again.', 'forminator' ) ); } wp_send_json_success( $pdf_data ); } catch ( Exception $e ) { wp_send_json_error( $e->getMessage() ); } } /** * Deleta a PDF * * @since 2.0 */ public function delete_pdf() { if ( ! forminator_is_user_allowed( 'forminator-cform' ) ) { wp_send_json_error( esc_html__( 'Invalid request, you are not allowed to do that action.', 'forminator' ) ); } forminator_validate_ajax( 'forminator_save_builder_fields', false, 'forminator-cform' ); try { $pdf_data = $this->get_post_data(); if ( ! isset( $pdf_data['pdfId'] ) || empty( $pdf_data['pdfId'] ) ) { throw new Exception( esc_html__( 'PDF not found.', 'forminator' ) ); } Forminator_API::delete_form( $pdf_data['pdfId'] ); wp_send_json_success( $pdf_data['pdfId'] ); } catch ( Exception $e ) { wp_send_json_error( $e->getMessage() ); } } /** * Fetch PDF files * * @since 2.0 */ public function fetch_pdfs() { if ( ! forminator_is_user_allowed( 'forminator-cform' ) ) { wp_send_json_error( esc_html__( 'Invalid request, you are not allowed to do that action.', 'forminator' ) ); } forminator_validate_ajax( 'forminator_save_builder_fields', false, 'forminator-cform' ); try { $submitted_data = $this->get_post_data(); $pdfs = Forminator_API::get_forms( null, 1, 999, 'pdf_form', $submitted_data['parent_form_id'] ); if ( is_wp_error( $pdfs ) || ! is_array( $pdfs ) ) { throw new Exception( esc_html__( 'Forminator encountered an error while fetching the PDF files.', 'forminator' ) ); } wp_send_json_success( $pdfs ); } catch ( Exception $e ) { wp_send_json_error( $e->getMessage() ); } } /** * Save custom form settings * * @since 1.2 */ public function save_builder_settings() { _deprecated_function( 'save_builder_settings', '1.6', 'save_builder' ); if ( ! current_user_can( forminator_get_permission( 'forminator-cform' ) ) ) { return; } forminator_validate_ajax( 'forminator_save_builder_fields', false, 'forminator-cform' ); $submitted_data = $this->get_post_data(); $id = isset( $submitted_data['form_id'] ) ? intval( $submitted_data['form_id'] ) : 0; $title = $submitted_data['formName']; $status = isset( $submitted_data['status'] ) ? $submitted_data['status'] : ''; $version = isset( $submitted_data['version'] ) ? $submitted_data['version'] : '1.0'; if ( is_null( $id ) || $id <= 0 ) { $form_model = new Forminator_Form_Model(); if ( empty( $status ) ) { $status = Forminator_Form_Model::STATUS_PUBLISH; } } else { $form_model = Forminator_Base_Form_Model::get_model( $id ); if ( ! is_object( $form_model ) ) { wp_send_json_error( esc_html__( "Form model doesn't exist", 'forminator' ) ); } if ( empty( $status ) ) { $status = $form_model->status; } } $form_model->set_var_in_array( 'name', 'formName', $submitted_data, 'forminator_sanitize_field' ); $settings = $submitted_data['data']; $settings['formName'] = $title; $settings['version'] = $version; $form_model->settings = $settings; // status. $form_model->status = $status; // Save data $id = $form_model->save(); // add privacy settings to global option $override_privacy = false; if ( isset( $settings['enable-submissions-retention'] ) ) { $override_privacy = filter_var( $settings['enable-submissions-retention'], FILTER_VALIDATE_BOOLEAN ); } $retention_number = null; $retention_unit = null; if ( $override_privacy ) { $retention_number = 0; $retention_unit = 'days'; if ( isset( $settings['submissions-retention-number'] ) ) { $retention_number = (int) $settings['submissions-retention-number']; } if ( isset( $settings['submissions-retention-unit'] ) ) { $retention_unit = $settings['submissions-retention-unit']; } } forminator_update_form_submissions_retention( $id, $retention_number, $retention_unit ); wp_send_json_success( $id ); } /** * Apply Appearance Preset ajax. */ public function apply_appearance_preset() { forminator_validate_ajax( 'forminator_apply_preset', false, 'forminator-cform' ); $preset_id = Forminator_Core::sanitize_text_field( 'preset_id' ); $ids = filter_input( INPUT_POST, 'ids', FILTER_VALIDATE_INT, FILTER_REQUIRE_ARRAY ); $edit_form = filter_input( INPUT_POST, 'edit_form', FILTER_VALIDATE_BOOLEAN ); $count = 0; $new_settings = Forminator_Settings_Page::get_preset( $preset_id ); if ( $ids ) { foreach ( $ids as $form_id ) { $form_model = Forminator_Base_Form_Model::get_model( $form_id ); if ( ! $form_model ) { continue; } $form_model->settings = self::merge_appearance_settings( $form_model->settings, $new_settings ); if ( $edit_form ) { $settings = isset( $_POST['settings'] ) ? Forminator_Core::sanitize_array( $_POST['settings'] ) : array(); $old_settings = json_decode( wp_unslash( $settings ), true ); if ( $old_settings ) { $form_model->settings = self::merge_appearance_settings( $old_settings, $new_settings ); } wp_send_json_success( $form_model->settings ); } // Save data. $form_model->save(); // Regenerare module css file. Forminator_Render_Form::regenerate_css_file( $form_id ); $count ++; } } if ( $edit_form ) { wp_send_json_error( esc_html__( 'Something went wrong.', 'forminator' ) ); } /* translators: %s: Form count */ $success = sprintf( esc_html__( 'Preset successfully applied to %d form(s).', 'forminator' ), $count ); wp_send_json_success( $success ); } /** * Merge Appearance settings * * @param array $settings Current Settings. * @param array $new_settings New Appearance settings. * * @return array */ private function merge_appearance_settings( $settings, $new_settings ) { $appearance_settings = Forminator_Settings_Page::only_appearance_settings( $settings ); $rest_settings = array(); foreach ( $settings as $key => $val ) { if ( ! array_key_exists( $key, $appearance_settings ) ) { $rest_settings[ $key ] = $val; } } $new_settings = array_merge( $rest_settings, $new_settings ); return $new_settings; } /** * Create Appearance Preset ajax. */ public function create_appearance_preset() { forminator_validate_ajax( 'forminator_create_preset', false, 'forminator-settings' ); $id = uniqid(); $settings = array(); $form_id = filter_input( INPUT_POST, 'form_id', FILTER_VALIDATE_INT ); $name = Forminator_Core::sanitize_text_field( 'name' ); if ( empty( $name ) ) { wp_send_json_error( esc_html__( 'Preset Name is empty.', 'forminator' ) ); } if ( ! empty( $form_id ) ) { $form = Forminator_Base_Form_Model::get_model( $form_id ); $settings = $form->settings; } // Update preset list. Forminator_Settings_Page::save_preset_list( $id, $name ); // Save preset. self::save_preset( $id, $settings ); wp_send_json_success( $id ); } /** * Delete Appearance Preset ajax. */ public function delete_appearance_preset() { forminator_validate_ajax( 'forminator_appearance_preset', false, 'forminator-settings' ); $id = Forminator_Core::sanitize_text_field( 'preset_id' ); if ( empty( $id ) ) { wp_send_json_error( esc_html__( 'Preset ID is empty.', 'forminator' ) ); } if ( 'default' === $id ) { wp_send_json_error( esc_html__( 'Preset ID is incorrect.', 'forminator' ) ); } // Delete preset from list. $key = 'forminator_appearance_presets'; $preset_names = get_option( $key, array() ); unset( $preset_names[ $id ] ); update_option( $key, $preset_names ); // Delete preset. delete_option( 'forminator_appearance_preset_' . $id ); wp_send_json_success(); } /** * Save Appearance Preset ajax. */ public function save_appearance_preset() { forminator_validate_ajax( 'forminator_appearance_preset', false, 'forminator-settings' ); $id = Forminator_Core::sanitize_text_field( 'presetId' ); if ( ! $id ) { wp_send_json_error( esc_html__( 'Appearance preset id doesn\'t exist', 'forminator' ) ); } $settings = array(); if ( ! empty( $_POST['settings'] ) ) { $settings = Forminator_Core::sanitize_array( json_decode( wp_unslash( $_POST['settings'] ), true ) ); } self::save_preset( $id, $settings ); wp_send_json_success( esc_html__( 'The preset has been successfully updated.', 'forminator' ) ); } /** * Save Appearance Preset * * @param string $id ID. * @param array $settings Settings. */ private static function save_preset( $id, $settings ) { update_option( 'forminator_appearance_preset_' . $id, $settings ); } /** * Dismiss welcome message * * @since 1.0 */ public function dismiss_welcome() { forminator_validate_ajax( 'forminator_dismiss_welcome' ); update_option( 'forminator_welcome_dismissed', true ); wp_send_json_success(); } /** * Load google fonts * * @since 1.0.5 */ public function load_google_fonts() { forminator_validate_ajax( 'forminator_load_google_fonts', false, 'forminator' ); $is_object = isset( $_POST['data']['isObject'] ) ? sanitize_text_field( $_POST['data']['isObject'] ) : false; $fonts = forminator_get_font_families( $is_object ); wp_send_json_success( $fonts ); } /** * Load reCaptcha settings * * @since 1.0 */ public function load_captcha() { // Validate nonce forminator_validate_ajax( 'forminator_popup_captcha', false, 'forminator-settings' ); $html = forminator_template( 'settings/popup/edit-captcha-content' ); wp_send_json_success( $html ); } /** * Save reCaptcha popup data * * @since 1.0 */ public function save_captcha() { // Validate nonce forminator_validate_ajax( 'forminator_save_popup_captcha', false, 'forminator-settings' ); update_option( 'forminator_captcha_key', Forminator_Core::sanitize_text_field( 'v2_captcha_key' ) ); update_option( 'forminator_captcha_secret', Forminator_Core::sanitize_text_field( 'v2_captcha_secret' ) ); update_option( 'forminator_v2_invisible_captcha_key', Forminator_Core::sanitize_text_field( 'v2_invisible_captcha_key' ) ); update_option( 'forminator_v2_invisible_captcha_secret', Forminator_Core::sanitize_text_field( 'v2_invisible_captcha_secret' ) ); update_option( 'forminator_v3_captcha_key', Forminator_Core::sanitize_text_field( 'v3_captcha_key' ) ); update_option( 'forminator_v3_captcha_secret', Forminator_Core::sanitize_text_field( 'v3_captcha_secret' ) ); update_option( 'forminator_hcaptcha_key', sanitize_text_field( $_POST['hcaptcha_key'] ) ); update_option( 'forminator_hcaptcha_secret', sanitize_text_field( $_POST['hcaptcha_secret'] ) ); update_option( 'forminator_captcha_tab_saved', sanitize_text_field( $_POST['captcha_tab_saved'] ) ); // update_option( "forminator_hcaptcha_noconflict", sanitize_text_field( $_POST['hcaptcha_noconflict'] ) ); update_option( 'forminator_captcha_language', Forminator_Core::sanitize_text_field( 'captcha_language' ) ); wp_send_json_success(); } /** * Load currency modal * * @since 1.0 */ public function load_currency() { forminator_validate_ajax( 'forminator_popup_currency', false, 'forminator-settings' ); $html = forminator_template( 'settings/popup/edit-currency-content' ); wp_send_json_success( $html ); } /** * Save reCaptcha popup data * * @since 1.0 */ public function save_currency() { // Validate nonce forminator_validate_ajax( 'forminator_save_popup_currency', false, 'forminator-settings' ); update_option( 'forminator_currency', Forminator_Core::sanitize_text_field( 'currency' ) ); wp_send_json_success(); } /** * Load entries pagination modal * * @since 1.0.2 */ public function load_pagination_entries() { // Validate nonce forminator_validate_ajax( 'forminator_popup_pagination_entries', false, 'forminator-settings' ); $html = forminator_template( 'settings/popup/edit-pagination-entries-content' ); wp_send_json_success( $html ); } /* * Load reCaptcha preview * * @since 1.5.4 */ public function load_recaptcha_preview() { forminator_validate_ajax( 'forminator_load_captcha_settings', false, 'forminator-settings' ); $site_language = get_locale(); $language = get_option( 'forminator_captcha_language', '' ); $language = ! empty( $language ) ? $language : $site_language; $captcha = Forminator_Core::sanitize_text_field( 'captcha' ); if ( 'v2-invisible' === $captcha ) { $captcha_key = get_option( 'forminator_v2_invisible_captcha_key', '' ); $captcha_size = 'invisible'; $onload = 'forminator_render_admin_captcha_v2_invisible'; } elseif ( 'v3' === $captcha ) { $captcha_key = get_option( 'forminator_v3_captcha_key', '' ); $captcha_size = 'invisible'; $onload = 'forminator_render_admin_captcha_v3'; } else { $captcha_key = get_option( 'forminator_captcha_key', '' ); $captcha_size = 'normal'; $onload = 'forminator_render_admin_captcha_v2'; } $html = ''; if ( ! empty( $captcha_key ) ) { // phpcs:ignore WordPress.WP.EnqueuedResources.NonEnqueuedScript $html .= '<script src="' . esc_url( 'https://www.google.com/recaptcha/api.js?hl=' . $language ) . '&render=explicit&onload=' . $onload . '" async defer></script>'; $html .= '<div class="forminator-g-recaptcha-' . esc_attr( $captcha ) . '" data-sitekey="' . esc_attr( $captcha_key ) . '" data-theme="light" data-size="' . $captcha_size . '"></div>'; } else { $html .= '<div role="alert" class="sui-notice sui-active" style="display: block; text-align: left;" aria-live="assertive">'; $html .= '<div class="sui-notice-content">'; $html .= '<div class="sui-notice-message">'; $html .= '<span class="sui-notice-icon sui-icon-info" aria-hidden="true"></span>'; $html .= '<p>' . esc_html__( 'You have to first save your credentials to load the reCAPTCHA . ', 'forminator' ) . '</p>'; $html .= '</div>'; $html .= '</div>'; $html .= '</div>'; } wp_send_json_success( $html ); } /* * Load hCaptcha preview * * @since 1.15.? */ public function load_hcaptcha_preview() { forminator_validate_ajax( 'forminator_load_captcha_settings', false, 'forminator-settings' ); $site_language = get_locale(); $language = get_option( 'forminator_captcha_language', '' ); $language = ! empty( $language ) ? $language : $site_language; // $captcha = sanitize_text_field( $_POST['captcha'] );// phpcs:ignore -- data without nonce verification $hcaptcha_key = get_option( 'forminator_hcaptcha_key', '' ); $hcaptcha_secret = get_option( 'forminator_hcaptcha_secret', '' ); $onload = 'forminator_render_admin_hcaptcha'; if ( ! empty( $hcaptcha_key ) && ! empty( $hcaptcha_secret ) ) { // phpcs:ignore WordPress.WP.EnqueuedResources.NonEnqueuedScript // recaptchacompat=off seems to fix problems with hcaptcha container loading recaptcha instead of hcaptcha in the admin $html = '<script src="https://js.hcaptcha.com/1/api.js?hl=' . $language . '&onload=' . $onload . '&render=explicit&recaptchacompat=off" async defer></script>'; $html .= '<div class="forminator-hcaptcha h-captcha" data-sitekey="' . esc_attr( $hcaptcha_key ) . '"></div>'; } else { $html = '<div class="sui-notice" style="margin: 10px 0;"><p>' . esc_html__( 'Save your API keys to load the hCAPTCHA preview.', 'forminator' ) . '</p></div>'; } wp_send_json_success( $html ); } /** * Load listings pagination modal * * @since 1.0.2 */ public function load_pagination_listings() { // Validate nonce forminator_validate_ajax( 'forminator_popup_pagination_listings', false, 'forminator-settings' ); $html = forminator_template( 'settings/popup/edit-pagination-listings-content' ); wp_send_json_success( $html ); } /** * Save listings pagination popup data * * @since 1.0.2 */ public function save_pagination_listings() { // Validate nonce forminator_validate_ajax( 'forminator_save_popup_pagination_listings', false, 'forminator-settings' ); $pagination = filter_input( INPUT_POST, 'pagination_listings', FILTER_VALIDATE_INT ); if ( 0 < $pagination ) { update_option( 'forminator_pagination_listings', $pagination ); wp_send_json_success(); } else { wp_send_json_error( esc_html__( 'Limit per page can not be less than one.', 'forminator' ) ); } } /** * Load the email settings form * * @since 1.1 */ public function load_email_form() { // Validate nonce forminator_validate_ajax( 'forminator_load_popup_email_settings', false, 'forminator-settings' ); $html = forminator_template( 'settings/popup/edit-email-content' ); wp_send_json_success( $html ); } /** * Load the uninstall form * * @since 1.0.2 */ public function load_uninstall_form() { // Validate nonce forminator_validate_ajax( 'forminator_popup_uninstall_form', false, 'forminator-settings' ); $html = forminator_template( 'settings/popup/edit-uninstall-content' ); wp_send_json_success( $html ); } /** * Save listings pagination popup data * * @since 1.0.2 */ public function save_uninstall_form() { // Validate nonce forminator_validate_ajax( 'forminator_save_popup_uninstall_settings', false, 'forminator-settings' ); $delete_uninstall = Forminator_Core::sanitize_text_field( 'delete_uninstall', false ); $delete_uninstall = filter_var( $delete_uninstall, FILTER_VALIDATE_BOOLEAN ); $custom_upload = Forminator_Core::sanitize_text_field( 'custom_upload', false ); $custom_upload = filter_var( $custom_upload, FILTER_VALIDATE_BOOLEAN ); $custom_upload_root = Forminator_Core::sanitize_text_field( 'custom_upload_root' ); $custom_upload_root = ! empty( $custom_upload_root ) ? $custom_upload_root : 'forminator'; update_option( 'forminator_uninstall_clear_data', $delete_uninstall ); // Custom upload update_option( 'forminator_custom_upload', $custom_upload ); update_option( 'forminator_custom_upload_root', $custom_upload_root ); wp_send_json_success(); } /** * Preview module * * @since 1.0 */ public function preview_module() { $current_action = current_action(); $slug = str_replace( array( 'wp_ajax_forminator_load_preview_', '_popup' ), '', $current_action ); if ( 'cforms' === $slug ) { $slug = 'form'; } elseif ( 'polls' === $slug ) { $slug = 'poll'; } elseif ( 'quizzes' === $slug ) { $slug = 'quiz'; } // Validate nonce forminator_validate_ajax( 'forminator_popup_preview_' . $slug, false, 'forminator' ); $preview_data = false; // force -1 for preview. $form_id = filter_input( INPUT_POST, 'id', FILTER_VALIDATE_INT ); $form_id = $form_id ? $form_id : - 1; // Check if preview data set if ( ! empty( $_POST['data'] ) ) { $data = Forminator_Core::sanitize_array( $_POST['data'], 'data' ); if ( ! is_array( $data ) ) { $data = json_decode( $data, true ); } $function = 'forminator_data_to_model_' . $slug; $preview_data = $function( $data ); } $html = forminator_preview( $form_id, $slug, true, $preview_data ); wp_send_json_success( $html ); } /** * Load list of exports * * @since 1.0 */ public function load_exports() { // Validate nonce forminator_validate_ajax( 'forminator_load_exports', false, 'forminator-settings' ); $form_id = filter_input( INPUT_POST, 'id', FILTER_VALIDATE_INT ); if ( $form_id ) { $args = array( 'form_id' => $form_id, ); $html = forminator_template( 'settings/popup/exports-content', $args ); wp_send_json_success( $html ); } else { wp_send_json_error( esc_html__( 'Not valid module ID provided.', 'forminator' ) ); } } /** * Clear list of exports * * @since 1.0 */ public function clear_exports() { // Validate nonce. forminator_validate_ajax( 'forminator_clear_exports', false, 'forminator-settings' ); $form_id = filter_input( INPUT_POST, 'id', FILTER_VALIDATE_INT ); if ( ! $form_id ) { wp_send_json_error( esc_html__( 'No ID was provided.', 'forminator' ) ); } $was_cleared = delete_export_logs( $form_id ); if ( $was_cleared ) { wp_send_json_success( esc_html__( 'Exports cleared.', 'forminator' ) ); } else { wp_send_json_error( esc_html__( 'Exports couldn\'t be cleared.', 'forminator' ) ); } } /** * Search Emails * * @since 1.0.3 * @since 1.1 change superglobal POST to `get_post_data` */ public function search_emails() { $submitted_data = $this->get_post_data(); $property = isset( $submitted_data['property'] ) ? $submitted_data['property'] : ''; $permission_slug = isset( $submitted_data['permission'] ) ? $submitted_data['permission'] : ''; forminator_validate_ajax( 'forminator_search_emails', false, $permission_slug ); // TODO : add ajax validate here and js admin too. $admin_email = ! empty( $submitted_data['admin_email'] ) ? true : false; $search_email = ! empty( $submitted_data['q'] ) ? $submitted_data['q'] : false; $exclude_admins = ! empty( $submitted_data['exclude_admins'] ) ? $submitted_data['exclude_admins'] : false; $is_permission = ! empty( $submitted_data['is_permission'] ) ? $submitted_data['is_permission'] : false; // return admin_email when requested. if ( $admin_email ) { wp_send_json_success( get_option( 'admin_email' ) ); } if ( ! $search_email ) { wp_send_json_success( array() ); } $args = array( 'search' => '*' . $search_email . '*', 'number' => 10, 'orderby' => 'user_login', 'order' => 'ASC', ); if ( $exclude_admins ) { $args['role__not_in'] = 'Administrator'; } $role = isset( $submitted_data['role'] ) ? $submitted_data['role'] : []; if ( ! empty( $role ) ) { $args['role__in'] = $role; } /** * Filter args to be passed on to get_users * * @param array $args * @param string $search_email string to search. * * @see get_users() * * @since 1.2 */ $args = apply_filters( 'forminator_builder_search_emails_args', $args, $search_email ); // Create a single array of users in permissions. if ( 'specific_user' === $property ) { $permitted_users = []; $permissions = get_option( 'forminator_permissions', [] ); $pid = isset( $submitted_data['pid'] ) ? $submitted_data['pid'] : ''; foreach ( $permissions as $permission ) { if ( (string) $pid !== (string) $permission['pid'] && isset( $permission['specific_user'] ) ) { $permitted_users = array_merge( $permitted_users, $permission['specific_user'] ); } } } $users = get_users( $args ); $data = array(); if ( ! empty( $users ) ) { foreach ( $users as $user ) { // Check if user has already been added to other permissions. if ( 'specific_user' === $property ) { if ( in_array( $user->ID, $permitted_users ) ) { continue; } } if ( $is_permission ) { $data[] = array( 'id' => $user->ID, 'text' => $user->user_email, 'display_name' => $user->display_name, ); } else { $data[] = array( 'id' => $user->user_email, 'text' => $user->user_email, 'display_name' => $user->display_name, ); } } } /** * Filter returned data when builder search emails * * @param array $data * @param array $users search result of get_users. * @param array $args current query args passed to get_users. * @param string $search_email string to search. * * @since 1.2 */ $data = apply_filters( 'forminator_builder_search_emails_data', $data, $users, $args, $search_email ); wp_send_json_success( $data ); } /** * Get superglobal POST data * * @param string $nonce_action action to validate. * @param array $sanitize_callbacks { * custom sanitize options, its assoc array * 'field_name_1' => 'function_to_call_1' function will called with `call_user_func_array`, * 'field_name_2' => 'function_to_call_2', * } * @param string $permission_slug The slug that will be used to get the capability for checking. * * @return array * @since 1.1 */ protected function get_post_data( $nonce_action = '', $sanitize_callbacks = array(), $permission_slug = '' ) { // do nonce / caps check when requested. if ( ! empty( $nonce_action ) ) { // it will wp_send_json_error. forminator_validate_ajax( $nonce_action, false, $permission_slug ); } $post_data = Forminator_Core::sanitize_array( $_POST ); // do some additional sanitize. foreach ( $sanitize_callbacks as $field => $sanitize_func ) { if ( isset( $post_data[ $field ] ) ) { if ( is_callable( $sanitize_func ) ) { $post_data[ $field ] = call_user_func_array( array( $sanitize_func ), array( $post_data[ $field ] ) ); } } } // do some validation return $post_data; } /* * Load Privacy Settings * * @since 1.0.6 */ public function load_privacy_settings() { // Validate nonce forminator_validate_ajax( 'forminator_popup_privacy_settings', false, 'forminator-settings' ); $html = forminator_template( 'settings/popup/edit-privacy-settings' ); wp_send_json_success( $html ); } /** * Save Privacy Settings * * @since 1.0.6 */ public function save_privacy_settings() { // Validate nonce forminator_validate_ajax( 'forminator_save_privacy_settings', false, 'forminator-settings' ); $post_data = Forminator_Core::sanitize_array( $_POST ); /** * CUSTOM FORMS */ // Account Erasure Requests if ( isset( $post_data['erase_form_submissions'] ) ) { $enable_erasure_request_erase_form_submissions = filter_var( $post_data['erase_form_submissions'], FILTER_VALIDATE_BOOLEAN ); update_option( 'forminator_enable_erasure_request_erase_form_submissions', $enable_erasure_request_erase_form_submissions ); } // Account Erasure Requests. // Submissions Retention. $cform_retain_forever = filter_var( $post_data['form_retain_submission_forever'], FILTER_VALIDATE_BOOLEAN ); update_option( 'retain_submission_forever', (string) $cform_retain_forever ); if ( $cform_retain_forever ) { $post_data['form_retain_submission_number'] = 0; } if ( isset( $post_data['form_retain_submission_number'] ) ) { $submissions_retention_number = intval( $post_data['form_retain_submission_number'] ); if ( $submissions_retention_number < 0 ) { $submissions_retention_number = 0; } update_option( 'forminator_retain_submissions_interval_number', $submissions_retention_number ); } update_option( 'forminator_retain_submissions_interval_unit', $post_data['form_retain_submission_unit'] ); // Submissions Retention // IP Retention $cform_retain_ip_forever = filter_var( $post_data['form_retain_ip_forever'], FILTER_VALIDATE_BOOLEAN ); update_option( 'retain_ip_forever', (string) $cform_retain_ip_forever ); if ( $cform_retain_ip_forever ) { $post_data['form_retain_ip_number'] = 0; } if ( isset( $post_data['form_retain_ip_number'] ) ) { $cform_ip_retention_number = intval( $post_data['form_retain_ip_number'] ); if ( $cform_ip_retention_number < 0 ) { $cform_ip_retention_number = 0; } update_option( 'forminator_retain_ip_interval_number', $cform_ip_retention_number ); } update_option( 'forminator_retain_ip_interval_unit', $post_data['form_retain_ip_unit'] ); // IP Retention. // Geolocation Retention. $cform_retain_geolocation_forever = filter_var( $post_data['form_retain_geolocation_forever'], FILTER_VALIDATE_BOOLEAN ); update_option( 'retain_geolocation_forever', (string) $cform_retain_geolocation_forever ); if ( $cform_retain_geolocation_forever ) { $post_data['form_retain_geolocation_number'] = 0; } if ( isset( $post_data['form_retain_geolocation_number'] ) ) { $cform_geolocation_retention_number = intval( $post_data['form_retain_geolocation_number'] ); if ( $cform_geolocation_retention_number < 0 ) { $cform_geolocation_retention_number = 0; } update_option( 'forminator_retain_geolocation_interval_number', $cform_geolocation_retention_number ); } update_option( 'forminator_retain_geolocation_interval_unit', $post_data['form_retain_geolocation_unit'] ); /** * POLLS */ // Submissions Retention $poll_retain_submissions_forever = filter_var( $post_data['poll_retain_submission_forever'], FILTER_VALIDATE_BOOLEAN ); update_option( 'poll_retain_submission_forever', (string) $poll_retain_submissions_forever ); if ( $poll_retain_submissions_forever ) { $post_data['poll_retain_submission_number'] = 0; } // Polls if ( isset( $post_data['poll_retain_submission_number'] ) ) { $poll_submissions_retention_number = intval( $post_data['poll_retain_submission_number'] ); if ( $poll_submissions_retention_number < 0 ) { $poll_submissions_retention_number = 0; } update_option( 'forminator_retain_poll_submissions_interval_number', $poll_submissions_retention_number ); } update_option( 'forminator_retain_poll_submissions_interval_unit', $post_data['poll_retain_submission_unit'] ); // Submissions Retention // IP Retention $poll_retain_ip_forever = filter_var( $post_data['poll_retain_ip_forever'], FILTER_VALIDATE_BOOLEAN ); update_option( 'retain_poll_forever', (string) $poll_retain_ip_forever ); if ( $poll_retain_ip_forever ) { $post_data['poll_retain_ip_number'] = 0; } if ( isset( $post_data['poll_retain_ip_number'] ) ) { $votes_retention_number = intval( $post_data['poll_retain_ip_number'] ); if ( $votes_retention_number < 0 ) { $votes_retention_number = 0; } update_option( 'forminator_retain_votes_interval_number', $votes_retention_number ); } update_option( 'forminator_retain_votes_interval_unit', $post_data['poll_retain_ip_unit'] ); // IP Retention /** * QUIZ */ // Submissions Retention $quiz_retain_submissions_forever = filter_var( $post_data['quiz_retain_submission_forever'], FILTER_VALIDATE_BOOLEAN ); update_option( 'quiz_retain_submission_forever', (string) $quiz_retain_submissions_forever ); if ( $quiz_retain_submissions_forever ) { $post_data['quiz_retain_submission_number'] = 0; } if ( isset( $post_data['quiz_retain_submission_number'] ) ) { $quiz_submissions_retention_number = intval( $post_data['quiz_retain_submission_number'] ); if ( $quiz_submissions_retention_number < 0 ) { $quiz_submissions_retention_number = 0; } update_option( 'forminator_retain_quiz_submissions_interval_number', $quiz_submissions_retention_number ); } update_option( 'forminator_retain_quiz_submissions_interval_unit', $post_data['quiz_retain_submission_unit'] ); // Submissions Retention wp_send_json_success(); } /** * AJAX Reset tracking data */ public function reset_tracking_data() { // Validate nonce. forminator_validate_ajax( 'forminator_reset_tracking_data', false, 'forminator' ); $id = filter_input( INPUT_POST, 'id', FILTER_VALIDATE_INT ); if ( ! $id ) { wp_send_json_error( esc_html__( 'Required id parameter is not set.', 'forminator' ) ); } Forminator_Admin_Module_Edit_Page::reset_module_views( $id ); wp_send_json_success( esc_html__( 'Tracking Data has been reset successfully.', 'forminator' ) ); } /** * Execute Import Form * * @since 1.5 */ public function save_import() { if ( ! Forminator::is_import_export_feature_enabled() ) { wp_send_json_error( esc_html__( 'Import Export Feature disabled.', 'forminator' ) ); } $current_action = current_action(); $slug = str_replace( array( 'wp_ajax_forminator_save_import_', '_popup' ), '', $current_action ); // Validate nonce forminator_validate_ajax( 'forminator_save_import_' . $slug, false, 'forminator-settings' ); $importable = json_decode( html_entity_decode( wp_unslash( $_POST['importable'] ) ), true ); $import_data = Forminator_Core::sanitize_array( $importable ); // Modify recipients if replace all recipients checkbox has been checked. $change_recipients = Forminator_Core::sanitize_text_field( 'change_recipients' ); if ( 'checked' === $change_recipients ) { $import_data = $this->change_recipients( $import_data ); } // hook custom data here. $import_data = apply_filters( 'forminator_' . $slug . '_import_data', $import_data ); try { if ( empty( $_POST['importable'] ) ) { throw new Exception( esc_html__( 'Import text can not be empty.', 'forminator' ) ); } if ( empty( $import_data ) || ! is_array( $import_data ) ) { throw new Exception( esc_html__( 'Oops, looks like we found an issue. Import text can not include whitespace or special characters.', 'forminator' ) ); } if ( ! isset( $import_data['type'] ) || $slug !== $import_data['type'] ) { throw new Exception( esc_html__( 'Oops, wrong module type. You can only import a module of the same type that you\'re currently viewing.', 'forminator' ) ); } $class = 'Forminator_' . forminator_get_prefix( $slug, '', true ) . '_Model'; $model = $class::create_from_import_data( $import_data ); if ( is_wp_error( $model ) ) { throw new Exception( $model->get_error_message() ); } if ( ! $model instanceof Forminator_Base_Form_Model ) { throw new Exception( esc_html__( 'Failed to import module, please make sure import text is valid, and try again.', 'forminator' ) ); } $return_url = admin_url( 'admin.php?page=forminator-' . forminator_get_prefix( $slug, 'c' ) ); /** * Fires after form import * * @since 1.27.0 * * @param int $slug Module type. */ do_action( 'forminator_after_form_import', $slug ); wp_send_json_success( array( 'id' => $model->id, 'url' => $return_url, ) ); } catch ( Exception $e ) { wp_send_json_error( $e->getMessage() ); } } /** * Change the recipients * * @since 1.18.0 * * @param mixed $data imported module data. * * @return array $data */ public function change_recipients( $data ) { if ( ! empty( $data ) ) { $current_user_email = wp_get_current_user()->user_email; if ( 'poll' === $data['type'] ) { if ( ! empty( $data['data']['settings']['admin-email-recipients'] ) ) { $data['data']['settings']['admin-email-recipients'] = $this->apply_user_email( $data['data']['settings']['admin-email-recipients'], $current_user_email ); } if ( ! empty( $data['data']['settings']['admin-email-cc-address'] ) ) { $data['data']['settings']['admin-email-cc-address'] = $this->apply_user_email( $data['data']['settings']['admin-email-cc-address'], $current_user_email ); } if ( ! empty( $data['data']['settings']['admin-email-bcc-address'] ) ) { $data['data']['settings']['admin-email-bcc-address'] = $this->apply_user_email( $data['data']['settings']['admin-email-bcc-address'], $current_user_email ); } } else { if ( ! empty( $data['data']['notifications'] ) ) { foreach ( $data['data']['notifications'] as $notif_key => $notif ) { // Modify the recipients. if ( ! empty( $notif['recipients'] ) ) { $recipients = $this->apply_user_email( $notif['recipients'], $current_user_email ); $data['data']['notifications'][ $notif_key ]['recipients'] = $recipients; } // Modify the routing recipients. if ( ! empty( $notif['routing'] ) ) { foreach ( $notif['routing'] as $routing_key => $route ) { if ( ! empty( $route['email'] ) ) { $route_emails = $this->apply_user_email( $route['email'], $current_user_email ); $data['data']['notifications'][ $notif_key ]['routing'][ $routing_key ]['email'] = $route_emails; } } } } } } } return $data; } /** * Apply user emails * * @since 1.18.0 * * @param string $data - Email recipients * @param string $current_user_email * * @return array $recipients */ public function apply_user_email( $data, $current_user_email ) { $recipients = ! is_array( $data ) ? explode( ',', $data ) : $data; foreach ( $recipients as $key => $recipient ) { $recipient = trim( $recipient ); // Will not change recipients that use field tags like {email-1}. if ( false === strpos( $recipient, '{' ) ) { $recipients[ $key ] = $current_user_email; } } $recipients = array_unique( $recipients ); return ! is_array( $data ) ? implode( ',', $recipients ) : $recipients; } /** * Get instance of thirdparty importer class * * @since 1.5 */ public function importers( $type ) { $class = ''; switch ( $type ) { case 'cf7': if ( class_exists( 'Forminator_Admin_Import_CF7' ) ) { $class = new Forminator_Admin_Import_CF7(); } break; case 'ninja': if ( class_exists( 'Forminator_Admin_Import_Ninja' ) ) { $class = new Forminator_Admin_Import_Ninja(); } break; case 'gravity': if ( class_exists( 'Forminator_Admin_Import_Gravity' ) ) { return new Forminator_Admin_Import_Gravity(); } break; default: break; } return $class; } /** * Load Import Custom Form Popup * * @since 1.5 */ public function load_import_form_cf7() { if ( ! Forminator::is_import_export_feature_enabled() || ! forminator_is_import_plugin_enabled( 'cf7' ) ) { wp_send_json_success( '' ); } // Validate nonce. forminator_validate_ajax( 'forminator_popup_import_form_cf7', false, 'forminator-settings' ); $html = forminator_template( 'custom-form/popup/import-cf7' ); wp_send_json_success( $html ); } /** * Execute Contact Form 7 Import Form * * @since 1.5 */ public function save_import_form_cf7() { if ( ! Forminator::is_import_export_feature_enabled() || ! forminator_is_import_plugin_enabled( 'cf7' ) ) { wp_send_json_error( esc_html__( 'Import Export Feature disabled.', 'forminator' ) ); } // Validate nonce. forminator_validate_ajax( 'forminator_save_import_form_cf7', false, 'forminator-settings' ); $post_data = $this->get_post_data(); $importable = ( isset( $post_data['cf7_forms'] ) ? $post_data['cf7_forms'] : '' ); $importer = $this->importers( 'cf7' ); if ( ! empty( $importer ) ) : if ( ! empty( $importable ) ) { if ( 'specific' === $importable ) { $forms = isset( $post_data['cf7-form-id'] ) ? $post_data['cf7-form-id'] : array(); } else { $forms = forminator_list_thirdparty_contact_forms( 'cf7' ); } if ( ! empty( $forms ) ) { foreach ( $forms as $key => $value ) { $values = 'specific' === $importable ? intval( $value ) : $value->ID; $imported = $importer->import_form( $values, $post_data ); if ( 'fail' === $imported['type'] ) { $error = $imported['message']; } } if ( ! empty( $error ) ) { wp_send_json_error( $error ); } wp_send_json_success( $imported ); } } else { wp_send_json_error( esc_html__( 'Can\'t find form to import', 'forminator' ) ); } endif; wp_send_json_error( esc_html__( 'Could not import the forms. Check if the selected form plugin is active', 'forminator' ) ); } /** * Load Import Custom Form Popup * * @since 1.5 */ public function load_import_form_ninja() { if ( ! Forminator::is_import_export_feature_enabled() || ! forminator_is_import_plugin_enabled( 'ninjaforms' ) ) { wp_send_json_success( '' ); } // Validate nonce. forminator_validate_ajax( 'forminator_popup_import_form_ninjaforms', false, 'forminator-settings' ); $html = forminator_template( 'custom-form/popup/import-ninjaforms' ); wp_send_json_success( $html ); } /** * Execute Ninjaforms Import Form Save * * @since 1.5 */ public function save_import_form_ninja() { if ( ! Forminator::is_import_export_feature_enabled() || ! forminator_is_import_plugin_enabled( 'ninjaforms' ) ) { wp_send_json_error( esc_html__( 'Import Export Feature disabled.', 'forminator' ) ); } // Validate nonce. forminator_validate_ajax( 'forminator_save_import_form_ninja', false, 'forminator-settings' ); $importable = Forminator_Core::sanitize_text_field( 'ninjaforms' ); $importer = ( ! empty( $this->importers( 'ninja' ) ) ? $this->importers( 'ninja' ) : '' ); if ( ! empty( $importer ) ) : if ( 'all' !== $importable && '' !== $importable ) { $importable = absint( $importable ); $imported = $importer->import_form( $importable ); if ( 'fail' === $imported['type'] ) { wp_send_json_error( $imported['message'] ); } wp_send_json_success( $imported ); } elseif ( '' !== $importable ) { $forms = forminator_list_thirdparty_contact_forms( 'ninjaforms' ); foreach ( $forms as $key => $value ) { $imported = $importer->import_form( $value->get_id() ); if ( 'fail' === $imported['type'] ) { $error = $imported['message']; } } if ( ! empty( $error ) ) { wp_send_json_error( $error ); } wp_send_json_success( $imported ); } endif; wp_send_json_error( esc_html__( 'Could not import the forms. Check if the selected form plugin is active', 'forminator' ) ); } /** * Load Import Custom Form Popup * * @since 1.5 */ public function load_import_form_gravity() { if ( ! Forminator::is_import_export_feature_enabled() || ! forminator_is_import_plugin_enabled( 'gravityforms' ) ) { wp_send_json_success( '' ); } // Validate nonce. forminator_validate_ajax( 'forminator_popup_import_form_gravityforms', false, 'forminator-settings' ); $html = forminator_template( 'custom-form/popup/import-gravityforms' ); wp_send_json_success( $html ); } /** * Execute Ninjaforms Import Form Save * * @since 1.5 */ public function save_import_form_gravity() { if ( ! Forminator::is_import_export_feature_enabled() || ! forminator_is_import_plugin_enabled( 'gravityforms' ) ) { wp_send_json_error( esc_html__( 'Import Export Feature disabled.', 'forminator' ) ); } // Validate nonce. forminator_validate_ajax( 'forminator_save_import_form_gravity', false, 'forminator-settings' ); $importable = Forminator_Core::sanitize_text_field( 'gravityforms' ); $importer = ( ! empty( $this->importers( 'gravity' ) ) ? $this->importers( 'gravity' ) : '' ); if ( ! empty( $importer ) ) : if ( 'all' !== $importable && '' !== $importable ) { $importable = absint( $importable ); $imported = $importer->import_form( $importable ); if ( 'fail' === $imported['type'] ) { wp_send_json_error( $imported['message'] ); } wp_send_json_success( $imported ); } elseif ( '' !== $importable ) { $forms = forminator_list_thirdparty_contact_forms( 'gravityforms' ); foreach ( $forms as $key => $value ) { $imported = $importer->import_form( $value['id'] ); if ( 'fail' === $imported['type'] ) { $error = $imported['message']; } } if ( ! empty( $error ) ) { wp_send_json_error( $error ); } wp_send_json_success( $imported ); } endif; } /** * Load Export Module Popup * * @since 1.5 */ public function load_export() { if ( ! Forminator::is_import_export_feature_enabled() ) { wp_send_json_success( '' ); } $current_action = current_action(); $slug = str_replace( array( 'wp_ajax_forminator_load_export_', '_popup' ), '', $current_action ); // Validate nonce forminator_validate_ajax( 'forminator_popup_export_' . $slug, false, 'forminator' ); $html = forminator_template( 'common/popup/export', array( 'slug' => $slug ) ); /** * Fires after form export * * @since 1.27.0 * * @param int $slug Module type. */ do_action( 'forminator_after_form_export', $slug ); wp_send_json_success( $html ); } /** * Load Import Popup * * @since 1.5 */ public function load_import() { if ( ! Forminator::is_import_export_feature_enabled() ) { wp_send_json_success( '' ); } $current_action = current_action(); $slug = str_replace( array( 'wp_ajax_forminator_load_import_', '_popup' ), '', $current_action ); // Validate nonce forminator_validate_ajax( 'forminator_popup_import_' . $slug, false, 'forminator' ); $html = forminator_template( 'common/popup/import', array( 'slug' => $slug ) ); wp_send_json_success( $html ); } /** * Save pagination data * * @since 1.6 */ public function save_pagination() { // Validate nonce forminator_validate_ajax( 'forminator_save_popup_pagination', false, 'forminator' ); $pagination = filter_input( INPUT_POST, 'pagination_entries', FILTER_VALIDATE_INT ); $pagination_listing = filter_input( INPUT_POST, 'pagination_listings', FILTER_VALIDATE_INT ); if ( 1 > $pagination || 1 > $pagination_listing ) { wp_send_json_error( esc_html__( 'Limit per page can not be less than one.', 'forminator' ) ); } update_option( 'forminator_pagination_entries', $pagination ); update_option( 'forminator_pagination_listings', $pagination_listing ); wp_send_json_success(); } /** * Save accessibility_settings * * @since 1.6.1 */ public function save_accessibility_settings() { // Validate nonce forminator_validate_ajax( 'forminator_save_accessibility_settings', false, 'forminator-settings' ); $enable_accessibility = filter_input( INPUT_POST, 'enable_accessibility', FILTER_VALIDATE_BOOLEAN ); update_option( 'forminator_enable_accessibility', $enable_accessibility ); wp_send_json_success(); } /** * Save dashboard * * @since 1.6.3 */ public function save_dashboard_settings() { // Validate nonce forminator_validate_ajax( 'forminator_save_dashboard_settings', false, 'forminator-settings' ); $dashboard_settings = forminator_get_dashboard_settings(); $widgets = array( 'forms', 'polls', 'quizzes' ); $num_recents = filter_input( INPUT_POST, 'num_recent', FILTER_VALIDATE_INT, FILTER_REQUIRE_ARRAY ); $num_recents = is_array( $num_recents ) ? $num_recents : array(); $publisheds = filter_input( INPUT_POST, 'published', FILTER_VALIDATE_BOOLEAN, FILTER_REQUIRE_ARRAY ); $publisheds = is_array( $publisheds ) ? $publisheds : array(); $drafts = filter_input( INPUT_POST, 'draft', FILTER_VALIDATE_BOOLEAN, FILTER_REQUIRE_ARRAY ); $drafts = is_array( $drafts ) ? $drafts : array(); // value based settings foreach ( $num_recents as $widget => $value ) { if ( ! isset( $dashboard_settings[ $widget ] ) ) { $dashboard_settings[ $widget ] = array(); } // at least 0. if ( $value >= 0 ) { $dashboard_settings[ $widget ]['num_recent'] = $value; } } // bool based settings aka checkboxes. foreach ( $widgets as $widget ) { if ( ! isset( $dashboard_settings[ $widget ] ) ) { $dashboard_settings[ $widget ] = array(); } // default enabled, handle when not exist = false. if ( ! isset( $publisheds[ $widget ] ) ) { $dashboard_settings[ $widget ]['published'] = false; } if ( ! isset( $drafts[ $widget ] ) ) { $dashboard_settings[ $widget ]['draft'] = false; } } update_option( 'forminator_dashboard_settings', $dashboard_settings ); $sender_email = filter_input( INPUT_POST, 'sender_email', FILTER_SANITIZE_EMAIL ); if ( $sender_email ) { update_option( 'forminator_sender_email_address', $sender_email ); } $sender_name = Forminator_Core::sanitize_text_field( 'sender_name' ); if ( $sender_name ) { update_option( 'forminator_sender_name', $sender_name ); } $pagination = filter_input( INPUT_POST, 'pagination_entries', FILTER_VALIDATE_INT ); $pagination_listing = filter_input( INPUT_POST, 'pagination_listings', FILTER_VALIDATE_INT ); if ( 1 > $pagination || 1 > $pagination_listing ) { wp_send_json_error( esc_html__( 'Limit per page can not be less than one.', 'forminator' ) ); } update_option( 'forminator_pagination_entries', $pagination ); update_option( 'forminator_pagination_listings', $pagination_listing ); $editor_settings = Forminator_Core::sanitize_text_field( 'editor_settings', false ); update_option( 'forminator_editor_settings', $editor_settings ); $old_usage_tracking = get_option( 'forminator_usage_tracking' ); $usage_tracking = filter_input( INPUT_POST, 'usage_tracking', FILTER_VALIDATE_BOOLEAN ); update_option( 'forminator_usage_tracking', $usage_tracking ); /** * Triggered after save dashboard settings * * @param boolean $old_usage_tracking Old usage tracking value. * * @since 1.27.0 */ do_action( 'forminator_after_dashboard_settings', $old_usage_tracking ); wp_send_json_success(); } /** * Disconnect stripe * * @since 1.7 */ public function stripe_disconnect() { // Validate nonce forminator_validate_ajax( 'forminatorSettingsRequest', false, 'forminator-settings' ); if ( class_exists( 'Forminator_Gateway_Stripe' ) ) { Forminator_Gateway_Stripe::store_settings( array() ); } $data['notification'] = array( 'type' => 'success', 'text' => esc_html__( 'Stripe account disconnected successfully.', 'forminator' ), 'duration' => '4000', ); $file = forminator_plugin_dir() . 'admin/views/settings/payments/section-stripe.php'; ob_start(); /** @noinspection PhpIncludeInspection */ include $file; $data['html'] = ob_get_clean(); wp_send_json_success( $data ); } /** * Disconnect PayPal * * @since 1.7 */ public function paypal_disconnect() { // Validate nonce. forminator_validate_ajax( 'forminatorSettingsRequest', false, 'forminator-settings' ); if ( class_exists( 'Forminator_PayPal_Express' ) ) { Forminator_PayPal_Express::store_settings( array() ); } $data['notification'] = array( 'type' => 'success', 'text' => esc_html__( 'PayPal account disconnected successfully.', 'forminator' ), 'duration' => '4000', ); $file = forminator_plugin_dir() . 'admin/views/settings/payments/section-paypal.php'; ob_start(); /** @noinspection PhpIncludeInspection */ include $file; $data['html'] = ob_get_clean(); wp_send_json_success( $data ); } /** * Handle stripe settings * * @since 1.7 */ public function stripe_update_page() { // Validate nonce forminator_validate_ajax( 'forminator_stripe_settings_modal', false, 'forminator-settings' ); $file = forminator_plugin_dir() . 'admin/views/settings/payments/section-stripe.php'; ob_start(); /** @noinspection PhpIncludeInspection */ include $file; $html = ob_get_clean(); wp_send_json_success( $html ); } /** * Handle PayPal settings * * @since 1.7 */ public function paypal_update_page() { // Validate nonce forminator_validate_ajax( 'forminator_paypal_settings_modal', false, 'forminator-settings' ); $file = forminator_plugin_dir() . 'admin/views/settings/payments/section-paypal.php'; ob_start(); /** @noinspection PhpIncludeInspection */ include $file; $html = ob_get_clean(); wp_send_json_success( $html ); } /** * Handle stripe settings * * @since 1.7 */ public function stripe_settings_modal() { if ( ! class_exists( 'Forminator_Gateway_Stripe' ) ) { return false; } $post_data = Forminator_Core::sanitize_array( $_POST ); // Validate nonce forminator_validate_ajax( 'forminator_stripe_settings_modal', false, $post_data['page_slug'] ); $data = array(); $is_connect_request = isset( $post_data['connect'] ) ? $post_data['connect'] : false; $template_vars = array(); try { $stripe = new Forminator_Gateway_Stripe(); $test_key = isset( $post_data['test_key'] ) ? $post_data['test_key'] : $stripe->get_test_key(); $test_secret = isset( $post_data['test_secret'] ) ? $post_data['test_secret'] : $stripe->get_test_secret(); $live_key = isset( $post_data['live_key'] ) ? $post_data['live_key'] : $stripe->get_live_key(); $live_secret = isset( $post_data['live_secret'] ) ? $post_data['live_secret'] : $stripe->get_live_secret(); $default_currency = $stripe->get_default_currency(); $template_vars['test_key'] = $test_key; $template_vars['test_secret'] = $test_secret; $template_vars['live_key'] = $live_key; $template_vars['live_secret'] = $live_secret; if ( ! empty( $is_connect_request ) ) { if ( empty( $test_key ) ) { throw new Forminator_Gateway_Exception( '', Forminator_Gateway_Stripe::EMPTY_TEST_KEY_EXCEPTION ); } if ( empty( $test_secret ) ) { throw new Forminator_Gateway_Exception( '', Forminator_Gateway_Stripe::EMPTY_TEST_SECRET_EXCEPTION ); } Forminator_Gateway_Stripe::validate_keys( $test_key, $test_secret, Forminator_Gateway_Stripe::INVALID_TEST_SECRET_EXCEPTION ); if ( empty( $live_key ) ) { throw new Forminator_Gateway_Exception( '', Forminator_Gateway_Stripe::EMPTY_LIVE_KEY_EXCEPTION ); } if ( empty( $live_secret ) ) { throw new Forminator_Gateway_Exception( '', Forminator_Gateway_Stripe::EMPTY_LIVE_SECRET_EXCEPTION ); } Forminator_Gateway_Stripe::validate_keys( $live_key, $live_secret, Forminator_Gateway_Stripe::INVALID_LIVE_SECRET_EXCEPTION ); Forminator_Gateway_Stripe::store_settings( array( 'test_key' => $test_key, 'test_secret' => $test_secret, 'live_key' => $live_key, 'live_secret' => $live_secret, 'default_currency' => $default_currency, ) ); $data['notification'] = array( 'type' => 'success', 'text' => esc_html__( 'Stripe account connected successfully. You can now add the Stripe field to your forms and start collecting payments.', 'forminator' ), 'duration' => '4000', ); } } catch ( Forminator_Gateway_Exception $e ) { forminator_maybe_log( __METHOD__, $e->getMessage(), $e->getTrace() ); $template_vars['error_message'] = $e->getMessage(); if ( Forminator_Gateway_Stripe::EMPTY_TEST_KEY_EXCEPTION === $e->getCode() ) { $template_vars['test_key_error'] = esc_html__( 'Please input test publishable key', 'forminator' ); } if ( Forminator_Gateway_Stripe::EMPTY_TEST_SECRET_EXCEPTION === $e->getCode() ) { $template_vars['test_secret_error'] = esc_html__( 'Please input test secret key', 'forminator' ); } if ( Forminator_Gateway_Stripe::EMPTY_LIVE_KEY_EXCEPTION === $e->getCode() ) { $template_vars['live_key_error'] = esc_html__( 'Please input live publishable key', 'forminator' ); } if ( Forminator_Gateway_Stripe::EMPTY_LIVE_SECRET_EXCEPTION === $e->getCode() ) { $template_vars['live_secret_error'] = esc_html__( 'Please input live secret key', 'forminator' ); } if ( Forminator_Gateway_Stripe::INVALID_TEST_SECRET_EXCEPTION === $e->getCode() ) { $template_vars['test_secret_error'] = esc_html__( 'You\'ve entered an invalid test secret key', 'forminator' ); } if ( Forminator_Gateway_Stripe::INVALID_LIVE_SECRET_EXCEPTION === $e->getCode() ) { $template_vars['live_secret_error'] = esc_html__( 'You\'ve entered an invalid live secret key', 'forminator' ); } if ( Forminator_Gateway_Stripe::INVALID_TEST_KEY_EXCEPTION === $e->getCode() ) { $template_vars['test_key_error'] = esc_html__( 'You\'ve entered an invalid test publishable key', 'forminator' ); } if ( Forminator_Gateway_Stripe::INVALID_LIVE_KEY_EXCEPTION === $e->getCode() ) { $template_vars['live_key_error'] = esc_html__( 'You\'ve entered an invalid live publishable key', 'forminator' ); } } ob_start(); /** @noinspection PhpIncludeInspection */ include forminator_plugin_dir() . 'admin/views/settings/payments/stripe.php'; $html = ob_get_clean(); $data['html'] = $html; $data['buttons'] = array(); $data['buttons']['connect']['markup'] = '<div class="sui-actions-right">' . '<button class="sui-button forminator-stripe-connect" type="button" data-nonce="' . wp_create_nonce( 'forminator_stripe_settings_modal' ) . '">' . '<span class="sui-loading-text">' . esc_html__( 'Connect', 'forminator' ) . '</span>' . '<i class="sui-icon-loader sui-loading" aria-hidden="true"></i>' . '</button>' . '</div>'; wp_send_json_success( $data ); } /** * Handle PayPal settings * * @since 1.7.1 */ public function paypal_settings_modal() { // Validate nonce forminator_validate_ajax( 'forminator_paypal_settings_modal', false, 'forminator-settings' ); $data = array(); $post_data = Forminator_Core::sanitize_array( $_POST ); $is_connect_request = isset( $post_data['connect'] ) ? $post_data['connect'] : false; $template_vars = array(); try { $paypal = new Forminator_PayPal_Express(); $sandbox_id = isset( $post_data['sandbox_id'] ) ? $post_data['sandbox_id'] : $paypal->get_sandbox_id(); $sandbox_secret = isset( $post_data['sandbox_secret'] ) ? $post_data['sandbox_secret'] : $paypal->get_sandbox_secret(); $live_id = isset( $post_data['live_id'] ) ? $post_data['live_id'] : $paypal->get_live_id(); $live_secret = isset( $post_data['live_secret'] ) ? $post_data['live_secret'] : $paypal->get_live_secret(); $default_currency = $paypal->get_default_currency(); $template_vars['sandbox_id'] = $sandbox_id; $template_vars['sandbox_secret'] = $sandbox_secret; $template_vars['live_id'] = $live_id; $template_vars['live_secret'] = $live_secret; if ( ! empty( $is_connect_request ) ) { if ( empty( $sandbox_id ) ) { throw new Forminator_Gateway_Exception( '', Forminator_PayPal_Express::EMPTY_SANDBOX_ID_EXCEPTION ); } if ( empty( $sandbox_secret ) ) { throw new Forminator_Gateway_Exception( '', Forminator_PayPal_Express::EMPTY_SANDBOX_SECRET_EXCEPTION ); } $paypal->validate_id( 'sandbox', $sandbox_id, $sandbox_secret, Forminator_PayPal_Express::INVALID_SANDBOX_SECRET_EXCEPTION ); if ( empty( $live_id ) ) { throw new Forminator_Gateway_Exception( '', Forminator_PayPal_Express::EMPTY_LIVE_ID_EXCEPTION ); } if ( empty( $live_secret ) ) { throw new Forminator_Gateway_Exception( '', Forminator_PayPal_Express::EMPTY_LIVE_SECRET_EXCEPTION ); } $paypal->validate_id( 'live', $live_id, $live_secret, Forminator_PayPal_Express::INVALID_LIVE_SECRET_EXCEPTION ); Forminator_PayPal_Express::store_settings( array( 'sandbox_id' => $sandbox_id, 'sandbox_secret' => $sandbox_secret, 'live_id' => $live_id, 'live_secret' => $live_secret, 'currency' => $default_currency, ) ); $data['notification'] = array( 'type' => 'success', 'text' => esc_html__( 'PayPal account connected successfully. You can now add the PayPal field to your forms and start collecting payments.', 'forminator' ), 'duration' => '4000', ); } } catch ( Forminator_Gateway_Exception $e ) { forminator_maybe_log( __METHOD__, $e->getMessage(), $e->getTrace() ); $template_vars['error_message'] = $e->getMessage(); if ( Forminator_PayPal_Express::EMPTY_SANDBOX_ID_EXCEPTION === $e->getCode() ) { $template_vars['sandbox_id_error'] = esc_html__( 'Please input sandbox client id', 'forminator' ); } if ( Forminator_PayPal_Express::EMPTY_SANDBOX_SECRET_EXCEPTION === $e->getCode() ) { $template_vars['sandbox_secret_error'] = esc_html__( 'Please input sandbox secret key', 'forminator' ); } if ( Forminator_PayPal_Express::EMPTY_LIVE_ID_EXCEPTION === $e->getCode() ) { $template_vars['live_id_error'] = esc_html__( 'Please input live client id', 'forminator' ); } if ( Forminator_PayPal_Express::EMPTY_LIVE_SECRET_EXCEPTION === $e->getCode() ) { $template_vars['live_secret_error'] = esc_html__( 'Please input live secret key', 'forminator' ); } if ( Forminator_PayPal_Express::INVALID_SANDBOX_SECRET_EXCEPTION === $e->getCode() ) { $template_vars['sandbox_secret_error'] = esc_html__( 'You\'ve entered an invalid sandbox secret key', 'forminator' ); } if ( Forminator_PayPal_Express::INVALID_LIVE_SECRET_EXCEPTION === $e->getCode() ) { $template_vars['live_secret_error'] = esc_html__( 'You\'ve entered an invalid live secret key', 'forminator' ); } if ( Forminator_PayPal_Express::INVALID_SANDBOX_ID_EXCEPTION === $e->getCode() ) { $template_vars['sandbox_id_error'] = esc_html__( 'You\'ve entered an invalid sandbox client id', 'forminator' ); } if ( Forminator_PayPal_Express::INVALID_LIVE_ID_EXCEPTION === $e->getCode() ) { $template_vars['live_id_error'] = esc_html__( 'You\'ve entered an invalid live client id', 'forminator' ); } } ob_start(); /** @noinspection PhpIncludeInspection */ include forminator_plugin_dir() . 'admin/views/settings/payments/paypal.php'; $html = ob_get_clean(); $data['html'] = $html; $data['buttons'] = array(); $data['buttons']['connect']['markup'] = '<div class="sui-actions-right">' . '<button class="sui-button forminator-paypal-connect" type="button" data-nonce="' . wp_create_nonce( 'forminator_paypal_settings_modal' ) . '">' . '<span class="sui-loading-text">' . esc_html__( 'Connect', 'forminator' ) . '</span>' . '<i class="sui-icon-loader sui-loading" aria-hidden="true"></i>' . '</button>' . '</div>'; wp_send_json_success( $data ); } /** * Dismiss notice. Use dismiss_admin_notice method instead * * @since 1.9 */ public function dismiss_notice() { forminator_validate_ajax( 'forminator_dismiss_notification' ); $notification_name = Forminator_Core::sanitize_text_field( 'prop' ); $input_value = Forminator_Core::sanitize_text_field( 'value' ); $allowed_options = array( 'forminator_skip_pro_notice', 'forminator_cf7_notice_dismissed', 'forminator_stripe_notice_dismissed', 'forminator_rating_success', 'forminator_rating_dismissed', 'forminator_publish_rating_later', 'forminator_publish_rating_later_dismiss', 'forminator_days_rating_later_dismiss', 'forminator_submission_rating_later', 'forminator_submission_rating_later_dismiss', 'forminator_hosting_banner_dismiss', 'forminator_hosting_banner_later', 'forminator_hosting_offer_dismiss', 'forminator_hosting_offer_later' ); if ( ! in_array( $notification_name, $allowed_options, true ) && 0 !== strpos( $notification_name, 'forminator_addons_update_' ) && 0 !== strpos( $notification_name, 'forminator_dismiss_feature_' ) ) { wp_send_json_error( esc_html__( 'Invalid option name', 'forminator' ) ); } if ( ! empty( $input_value ) ) { update_option( $notification_name, $input_value ); } else { update_option( $notification_name, true ); } $version_upgraded = get_option( 'forminator_version_upgraded', false ); if ( $version_upgraded ) { update_option( 'forminator_version_upgraded', false ); } // Remove this code once the next feature is released, as it is a data tracking option if ( ! empty( $_POST['usage_value'] ) ) { $old_usage_tracking = get_option( 'forminator_usage_tracking' ); $usage_value = filter_input( INPUT_POST, 'usage_value', FILTER_VALIDATE_BOOLEAN ); update_option( 'forminator_usage_tracking', $usage_value ); /** * Triggered after Feature model Usage settings save * * @param boolean $old_usage_tracking Old usage tracking value. * * @since 1.27.0 */ do_action( 'forminator_feature_usage_settings', $old_usage_tracking ); } wp_send_json_success(); } /** * Dismiss admin notice. */ public function dismiss_admin_notice() { forminator_validate_ajax( 'forminator_dismiss_notice' ); $slug = Forminator_Core::sanitize_text_field( 'slug' ); $user_id = get_current_user_id(); $dismissed = get_user_meta( $user_id, 'frmt_dismissed_messages', true ); if ( ! $dismissed || ! is_array( $dismissed ) ) { $dismissed = array(); } $dismissed[] = $slug; update_user_meta( $user_id, 'frmt_dismissed_messages', $dismissed ); wp_send_json_success(); } /** * Dismiss notice * * @since 1.9 */ public function later_notice() { forminator_validate_ajax( 'forminator_dismiss_notification' ); $notification_name = Forminator_Core::sanitize_text_field( 'prop' ); $form_id = filter_input( INPUT_POST, 'form_id', FILTER_VALIDATE_INT ); $allowed_keys = array( 'forminator_publish_rating_later', 'forminator_publish_rating_later_dismiss', 'forminator_days_rating_later_dismiss', 'forminator_submission_rating_later', 'forminator_submission_rating_later_dismiss', ); if ( ! in_array( $notification_name, $allowed_keys, true ) ) { wp_send_json_error( esc_html__( 'Invalid notification name', 'forminator' ) ); } update_post_meta( $form_id, $notification_name, true ); wp_send_json_success(); } /** * Promote free plan - Remind me later */ public function promote_remind_later() { forminator_validate_ajax( 'forminator_promote_remind_later' ); set_transient( 'forminator_free_plan_remind_later_' . get_current_user_id(), true, WEEK_IN_SECONDS ); wp_send_json_success(); } /** * Save general payments settings * * @since 1.7 */ public function save_payments() { forminator_validate_ajax( 'forminator_save_payments_settings', false, 'forminator-settings' ); // stripe. $default_currency = Forminator_Core::sanitize_text_field( 'stripe-default-currency' ); if ( $default_currency ) { try { $stripe = new Forminator_Gateway_Stripe(); $test_key = $stripe->get_test_key(); $test_secret = $stripe->get_test_secret(); $live_key = $stripe->get_live_key(); $live_secret = $stripe->get_live_secret(); Forminator_Gateway_Stripe::store_settings( array( 'test_key' => $test_key, 'test_secret' => $test_secret, 'live_key' => $live_key, 'live_secret' => $live_secret, 'default_currency' => $default_currency, ) ); } catch ( Forminator_Gateway_Exception $e ) { wp_send_json_error( $e->getMessage() ); } } // paypal. $pp_default_currency = Forminator_Core::sanitize_text_field( 'paypal-default-currency' ); if ( $pp_default_currency ) { $default_currency = $pp_default_currency; try { $paypal = new Forminator_PayPal_Express(); $sandbox_id = $paypal->get_sandbox_id(); $sandbox_secret = $paypal->get_sandbox_secret(); $live_id = $paypal->get_live_id(); $live_secret = $paypal->get_live_secret(); Forminator_PayPal_Express::store_settings( array( 'sandbox_id' => $sandbox_id, 'sandbox_secret' => $sandbox_secret, 'live_id' => $live_id, 'live_secret' => $live_secret, 'currency' => $default_currency, ) ); } catch ( Forminator_Gateway_Exception $e ) { wp_send_json_error( $e->getMessage() ); } } wp_send_json_success(); } /** * Delete all poll submission * * @since 1.7.2 */ public function delete_poll_submissions() { forminator_validate_ajax( 'forminatorPollEntries', false, 'forminator-entries' ); $form_id = filter_input( INPUT_POST, 'id', FILTER_VALIDATE_INT ); if ( $form_id ) { Forminator_Form_Entry_Model::delete_by_form( $form_id ); $file = forminator_plugin_dir() . 'admin/views/common/entries/content-none.php'; ob_start(); /** @noinspection PhpIncludeInspection */ include $file; $html = ob_get_clean(); $data['html'] = $html; $data['notification'] = array( 'type' => 'success', 'text' => esc_html__( 'All the submissions deleted successfully.', 'forminator' ), 'duration' => '4000', ); wp_send_json_success( $data ); } else { $data['notification'] = array( 'type' => 'error', 'text' => esc_html__( 'Submission delete failed.', 'forminator' ), 'duration' => '4000', ); wp_send_json_error( $data ); } } /** * Module search for all types * * @since 1.14.12 */ public function module_search() { forminator_validate_ajax( 'forminator-nonce-search-module', false, 'forminator' ); $html = ''; $keyword = Forminator_Core::sanitize_text_field( 'search_keyword' ); $modules = Forminator_Admin_Module_Edit_Page::get_searched_modules( $keyword ); ob_start(); Forminator_Admin_Module_Edit_Page::show_modules( $modules, Forminator_Core::sanitize_text_field( 'module_slug' ), Forminator_Core::sanitize_text_field( 'preview_dialog' ), Forminator_Core::sanitize_text_field( 'preview_title' ), Forminator_Core::sanitize_text_field( 'export_dialog' ), Forminator_Core::sanitize_text_field( 'post_type' ), Forminator_Core::sanitize_text_field( 'soon' ), Forminator_Core::sanitize_text_field( 'sql_month_start_date' ), Forminator_Core::sanitize_text_field( 'wizard_page' ), $keyword ); $html = ob_get_clean(); wp_send_json_success( $html ); } public function addons_page_actions() { // Validate nonce. forminator_validate_ajax( 'forminator_popup_addons_actions', false, 'forminator-addons' ); $action = Forminator_Core::sanitize_text_field( 'action' ); if ( ! $action ) { wp_send_json_error( array( 'message' => esc_html__( 'Required field missing', 'forminator' ) ) ); } $action = str_replace( 'forminator_', '', $action ); Forminator_Admin_Addons_page::get_instance()->addons_action_ajax( $action ); // When the addons_action_ajax function did not send a response assume error. wp_send_json_error( array( 'message' => esc_html__( 'Unexpected action, we could not handle it.', 'forminator' ) ) ); } /** * Filter report data * * @return void */ public function filter_report_data() { // Validate nonce. forminator_validate_ajax( 'forminator_filter_report_data', false, 'forminator-reports' ); $form_id = filter_input( INPUT_POST, 'form_id', FILTER_VALIDATE_INT ); $form_type = Forminator_Core::sanitize_text_field( 'form_type' ); $start_date = Forminator_Core::sanitize_text_field( 'start_date' ); $end_date = Forminator_Core::sanitize_text_field( 'end_date' ); $range_time = Forminator_Core::sanitize_text_field( 'range_time' ); $range_text = ! empty( $range_time ) ? $range_time : 'Custom'; if ( ! empty( $form_id ) && ! empty( $start_date ) && ! empty( $end_date ) ) { $admin_report_instance = Forminator_Admin_Report_Page::get_instance(); $reports = $admin_report_instance->forminator_report_data( $form_id, $form_type, $start_date, $end_date, $range_text ); $report_data = $admin_report_instance->forminator_report_array( $reports, $form_id ); $chart_data = $admin_report_instance->forminator_report_chart_data( $form_id, $start_date, $end_date ); if ( isset( $chart_data['submissions'] ) ) { $chart_data['submissions'] = array_values( $chart_data['submissions'] ); } if ( ! empty( $report_data ) ) { $response = array( 'reports' => $report_data, 'chart_data' => $chart_data, ); $response = apply_filters( 'forminator_report_data', $response, $form_id, $form_type, $start_date, $end_date ); wp_send_json_success( $response ); } } wp_send_json_error( array( 'message' => esc_html__( 'Required field missing', 'forminator' ) ) ); } /** * Search users from the add recipients modal. * * @since 1.20.0 */ public function search_users() { forminator_validate_ajax( 'forminator-fetch', 'nonce', 'forminator-reports' ); $query = Forminator_Core::sanitize_text_field( 'query' ); $query = "*$query*"; $exclude = filter_input( INPUT_POST, 'exclude', FILTER_VALIDATE_INT, FILTER_REQUIRE_ARRAY ); $users = forminator_get_users_by_query( $query, $exclude ); wp_send_json_success( $users ); } /** * Get avatar for the recipients modal. * * @since 1.20.0 */ public function get_avatar() { forminator_validate_ajax( 'forminator-fetch', 'nonce', 'forminator-reports' ); if ( ! current_user_can( forminator_get_permission( 'forminator-reports' ) ) ) { wp_send_json_error( array( 'message' => esc_html__( 'Current user cannot add recipient.', 'forminator' ), ) ); } $email = filter_input( INPUT_POST, 'email', FILTER_VALIDATE_EMAIL ); if ( false === $email ) { wp_send_json_error( array( 'message' => esc_html__( 'Invalid email.', 'forminator' ), ) ); } wp_send_json_success( get_avatar_url( $email ) ); } /** * Fetch reports by id * * @since 1.20.0 */ public function fetch_report() { forminator_validate_ajax( 'forminator-fetch', 'nonce', 'forminator-reports' ); $report_id = Forminator_Core::sanitize_text_field( 'report_id' ); $report_value = array(); if ( empty( $report_id ) ) { wp_send_json_error( array( 'message' => esc_html__( 'Something went wrong.', 'forminator' ), ) ); } $report_data = Forminator_Form_Reports_Model::get_instance()->fetch_report_by_id( $report_id ); if ( ! empty( $report_data ) ) { $report_value = ! empty( $report_data->report_value ) ? Forminator_Core::sanitize_html_array( maybe_unserialize( $report_data->report_value ) ) : array(); if ( isset( $report_data->status ) ) { $report_value['report_status'] = esc_html( $report_data->status ); } $report_value['report_id'] = intval( $report_data->report_id ); } wp_send_json_success( $report_value ); } /** * Save Report. * * @since 1.20.0 */ public function save_report() { forminator_validate_ajax( 'forminator-save', 'nonce', 'forminator-reports' ); if ( empty( $_POST['reports'] ) ) { wp_send_json_error( array( 'message' => esc_html__( 'Something went wrong.', 'forminator' ), ) ); } $report_id = Forminator_Core::sanitize_text_field( 'report_id' ); $status = Forminator_Core::sanitize_text_field( 'status' ); $reports_data = Forminator_Core::sanitize_array( $_POST['reports'] ); $reports_data['report_status'] = $status; if ( 0 !== (int) $report_id ) { $result = Forminator_Form_Reports_Model::get_instance()->report_update( $report_id, $reports_data, $status ); } else { $result = Forminator_Form_Reports_Model::get_instance()->report_save( $reports_data, $status ); $reports_data['report_id'] = $result; } if ( is_wp_error( $result ) ) { wp_send_json_error(); } /** * Fires after report save * * @since 1.27.0 * * @param array $reports_data Report data. */ do_action( 'forminator_after_notification_update', $reports_data ); wp_send_json_success( $result ); } /* * Update report status */ public function update_report_status() { forminator_validate_ajax( 'forminator-save', 'nonce', 'forminator-reports' ); $report_id = Forminator_Core::sanitize_text_field( 'report_id' ); $status = Forminator_Core::sanitize_text_field( 'status' ); if ( empty( $status ) ) { wp_send_json_error( array( 'message' => esc_html__( 'Something went wrong.', 'forminator' ), ) ); } $result = Forminator_Form_Reports_Model::get_instance()->report_update_status( $report_id, $status ); if ( is_wp_error( $result ) ) { wp_send_json_error(); } wp_send_json_success( $result ); } /* * Save permission. */ public function save_permissions() { forminator_validate_ajax( 'forminator_permission_nonce' ); $old_permissions = get_option( 'forminator_permissions', array() ); $post_data = Forminator_Core::sanitize_array( $_POST ); $permissions = json_decode( wp_unslash( $post_data[ 'permissions' ] ), true ); $caps = forminator_get_capabilities(); // Perform changes during save mode. if ( 'new' === $post_data['mode'] ) { foreach ( $permissions as $key => $permission ) { /** * For specific users. * - Add caps to the users * - Check each permission for get_avatar then retrieve it. */ if ( 'specific' === $permission['permission_type'] ) { // $permissions[ $key ]['user_info'] = []; foreach( $permission['specific_user'] as $user_index => $user_id ) { $user = get_user_by( 'ID', $user_id ); if ( false !== $user ) { // Add caps to the user. forminator_apply_capabilities( $user, $permission ); // Set user info. $permissions[ $key ]['user_info'][ $user_id ]['name'] = $user->display_name; $permissions[ $key ]['user_info'][ $user_id ]['email'] = $user->user_email; // We only need avatar for first user. if ( 0 === $user_index ) { $permissions[ $key ]['avatar'] = get_avatar_url( $user->user_email, array( 'size' => 30 ) ); } } } /** * For roles. * - Add caps to users under these roles. */ } else { $role = get_role( $permission['user_role'] ); // Add caps to the role. forminator_apply_capabilities( $role, $permission ); if ( empty( $permission['exclude_users'] ) ) { continue; } // Set user info for excluded users. foreach( $permission['exclude_users'] as $user_id ) { $user = get_user_by( 'ID', $user_id ); if ( false !== $user ) { $permissions[ $key ]['user_info'][ $user_id ]['name'] = $user->display_name; $permissions[ $key ]['user_info'][ $user_id ]['email'] = $user->user_email; } } } } /** * EDIT mode. * * If specific users, get the missing users from new permission state then revoke their caps. * Add new caps if new ones are added. * * If role, add or remove caps as per new state. */ } else { $pid = $post_data['pid']; $old_permission = $old_permissions[ array_search( $pid, array_column( $old_permissions, 'pid' ) ) ]; if ( 'edit' === $post_data['mode'] ) { foreach ( $permissions as $key => $permission ) { if ( $old_permission['pid'] === $permission['pid'] ) { // If specific user. if ( 'specific' === $permission['permission_type'] ) { // Remove caps from deleted users. $deleted_users = array_diff( $old_permission['specific_user'], $permission['specific_user'] ); foreach ( $deleted_users as $user_id ) { $graduate = get_user_by( 'ID', $user_id ); if ( false !== $graduate ) { foreach( $caps as $cap ) { $graduate->remove_cap( $cap ); } } } // Add/remove caps to the current users. foreach( $permission['specific_user'] as $user_index => $user_id ) { $user = get_user_by( 'ID', $user_id ); forminator_apply_capabilities( $user, $permission ); // Set user info. $permissions[ $key ]['user_info'][ $user_id ]['name'] = $user->display_name; $permissions[ $key ]['user_info'][ $user_id ]['email'] = $user->user_email; // We only need avatar for first user. if ( 0 === $user_index ) { $permissions[ $key ]['avatar'] = get_avatar_url( $user->user_email, array( 'size' => 30 ) ); } } // If role. } else { $role = get_role( $permission['user_role'] ); // Add/remove caps to the role. forminator_apply_capabilities( $role, $permission ); if ( empty( $permission['exclude_users'] ) ) { continue; } // Set user info for excluded users. foreach( $permission['exclude_users'] as $user_id ) { $user = get_user_by( 'ID', $user_id ); if ( false !== $user ) { $permissions[ $key ]['user_info'][ $user_id ]['name'] = $user->display_name; $permissions[ $key ]['user_info'][ $user_id ]['email'] = $user->user_email; } } } } } /** * Delete mode. * * If specific users, get the missing users from new permission state then revoke their caps. * Add new caps if new ones are added. * * If role, add or remove caps as per new state. */ } elseif ( 'delete' === $post_data['mode'] ) { // If specific user. if ( 'specific' === $old_permission['permission_type'] ) { // Remove caps from users. foreach ( $old_permission['specific_user'] as $user_id ) { $graduate = get_user_by( 'ID', $user_id ); if ( false !== $graduate ) { foreach( $caps as $cap ) { $graduate->remove_cap( $cap ); } } } // If role. } else { $role = get_role( $old_permission['user_role'] ); // Remove caps from the role. if ( ! is_null( $role ) ) { foreach( $caps as $cap ) { $role->remove_cap( $cap ); } } } } } if ( update_option( 'forminator_permissions', $permissions ) ) { wp_send_json_success( $permissions ); } else { wp_send_json_error(); } } }