HEX
Server: Apache/2.4.6 (CentOS) OpenSSL/1.0.2k-fips PHP/7.4.30
System: Linux iZj6c1151k3ad370bosnmsZ 3.10.0-1160.76.1.el7.x86_64 #1 SMP Wed Aug 10 16:21:17 UTC 2022 x86_64
User: root (0)
PHP: 7.4.30
Disabled: NONE
Upload Files
File: /var/www/html/www.winghung.com/wp-content/plugins/conversational-forms/classes/api/settings.php
<?php

/**
 * REST API route for settings
 *
 * @package Caldera_Forms Modified by QuantumCloud
 * @author    Josh Pollock <Josh@CalderaWP.com>
 * @license   GPL-2.0+
 * @link
 * @copyright 2016 CalderaWP LLC
 */
class Qcformbuilder_Forms_API_Settings implements  Qcformbuilder_Forms_API_Route{

	/**
	 * @since 1.5.0
	 * @inheritdoc
	 */
	public function add_routes( $namespace ) {
		register_rest_route( $namespace, '/settings/entries',
			array(
				'methods'         => array( 'POST' ),
				'callback'        => array( $this, 'update_entry_settings' ),
				'permission_callback' => array( $this, 'create_item_permissions_check' ),
				'args'            => array(
					'per_page' => array(
						'required'          => 'false',
						'type'              => 'integer',
					)
				)
			)
		);
        register_rest_route( $namespace, '/settings',
            array(
                'methods'         => array( 'POST' ),
                'callback'        => array( $this, 'update_settings' ),
                'permission_callback' => array( $this, 'create_item_permissions_check' ),
                'args'            => array(
                    'styleIncludes' => array(
                        'required'          => 'false',
                        'type'              => 'array',
                    ),
                    'cdnEnable' => array(
                        'required'          => 'false',
                        'type'              => 'boolean',
                    ),
                )
            )
        );
        register_rest_route( $namespace, '/settings',
            array(
                'methods'         => array( 'GET' ),
                'callback'        => array( $this, 'get_settings' ),
                'permission_callback' => array( $this, 'get_items_permissions_check' ),
            )
        );

	}

	/**
	 * Update entry settings
	 *
	 * @since 1.5.0
	 *
	 * @param WP_REST_Request $request
	 *
	 * @return Qcformbuilder_Forms_API_Response
	 */
	public function update_entry_settings( WP_REST_Request $request ){
		Qcformbuilder_Forms_Entry_Viewer::update_entries_per_page( $request[ 'per_page' ] );
		$response = new Qcformbuilder_Forms_API_Response( array(
			'per_page' => Qcformbuilder_Forms_Entry_Viewer::entries_per_page()
		));
		return $response;
	}

    /**
     * Update general settings
     *
     * @since 1.7.3
     *
     * @param WP_REST_Request $request
     * @return Qcformbuilder_Forms_API_Response
     */
	public function update_settings( \WP_REST_Request $request ){
        $style_includes = Qcformbuilder_Forms_Render_Assets::get_style_includes();
        $new_values = [];
        foreach ( $style_includes as $key => $saved ){
			$request[$key] = !is_bool($request[$key]) && $request[$key] === "false" ? false : $request[$key];
            $new_values[ $key ] = isset($request[$key]) ? boolval($request[$key]) : $saved;
        }

        update_option( '_qcformbuilder_forms_styleincludes', $new_values);

        if( $request['cdnEnable'] === true ){
            Qcformbuilder_Forms::settings()->get_cdn()->enable();
        }else if( $request['cdnEnable'] === false ) {
            Qcformbuilder_Forms::settings()->get_cdn()->disable();
        }

        return Qcformbuilder_Forms_API_Response_Factory::general_settings_response(
            $new_values,
            Qcformbuilder_Forms::settings()->get_cdn()->enabled(),
            201
        );

    }

    /**
     * Get general settings
     *
     * @since 1.7.3
     *
     * @return Qcformbuilder_Forms_API_Response
     */
    public function get_settings(){
        return Qcformbuilder_Forms_API_Response_Factory::general_settings_response(
            Qcformbuilder_Forms_Render_Assets::get_style_includes(),
            Qcformbuilder_Forms::settings()->get_cdn()->enabled(),
            201
        );
    }


	/**
	* Permissions for settings read
	*
	* @since 1.8.0
	*
	* @param WP_REST_Request $request
	*
	* @return bool
	*/
	public function get_items_permissions_check( WP_REST_Request $request ){

		$allowed = current_user_can( Qcformbuilder_Forms::get_manage_cap( 'entry-view' ) );

		/**
		 * Filter permissions for viewing settings config via Qcformbuilder Forms REST API
		 *
		 * @since 1.8.0
		 *
		 * @param bool $allowed Is request authorized?
		 * @param WP_REST_Request $request The current request
		 */
		return apply_filters( 'qcformbuilder_forms_api_allow_settings_view', $allowed, $request );

	}

	/**
	 * Permissions for settings create/update/delete
	 *
	 * @since 1.8.0
	 *
	 * @param WP_REST_Request $request
	 *
	 * @return bool
	 */
	public function create_item_permissions_check( WP_REST_Request $request ){

		$allowed = current_user_can( Qcformbuilder_Forms::get_manage_cap( 'entry-edit' ) );

		/**
		 * Filter permissions for updating  settings via Qcformbuilder Forms REST API
		 *
		 * @since 1.8.0
		 *
		 * @param bool $allowed Is request authorized?
		 * @param WP_REST_Request $request The current request
		 */
		return apply_filters( 'qcformbuilder_forms_api_allow_settings_edit', $allowed, $request );

	}

}