/var/www/html_fr/wp-content/plugins/yaymail/src/Abstracts/BaseController.php


1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
<?php
namespace YayMail\Abstracts;

/**
 * Base Rest API Controller
 */
abstract class BaseController {

    
/**
     * Check if a user has permission to access a router
     *
     * @return bool
     */
    
public function permission_callback() {
        return 
current_user_can'manage_woocommerce' );
    }

    
/**
     * Returns response when verify nonce failed
     *
     * @return \WP_REST_Response
     */
    
public function nonce_failure_response() {
        return new 
\WP_REST_Response(
            [
                
'success' => false,
                
'code'    => 'nonce_failure',
                
'message' => __'Verify nonce failed''yaymail' ),
            ]
        );
    }

    
/**
     * Verify nonce
     *
     * @return int|false
     */
    
public function verify_nonce$request ) {
        
$nonce $request->get_header'x_wp_nonce' );
        return 
wp_verify_nonce$nonce'wp_rest' );
    }

    
/**
     * Function API exec
     *
     * @param  callable $callable
     * @param  \WP_REST_Request $request
     * @return \WP_REST_Response|\WP_Error
     */
    
public function exec$callable\WP_REST_Request $request ) {

        if ( ! 
$this->verify_nonce$request ) ) {
            return 
rest_ensure_request$this->nonce_failure_response() );
        }

        try {
            if ( 
is_callable$callable ) ) {
                
$response $callable$request );
            }
        } catch ( 
\Throwable $ex ) {
            return 
rest_ensure_response(
                [
                    
'isError' => true,
                    
'code'    => $ex->getCode(),
                    
'message' => $ex->getMessage(),
                ]
            );
        }

        return 
rest_ensure_response$response );
    }

}