Rest.php
2.19 KB
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
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
<?php
namespace WP_Rocket\Engine\Support;
use WP_Rocket\Admin\Options_Data;
class Rest {
const ROUTE_NAMESPACE = 'wp-rocket/v1';
/**
* Data instance
*
* @var Data
*/
private $data;
/**
* Options instance
*
* @var Options_Data
*/
private $options;
/**
* Instantiate the class
*
* @param Data $data Data instance.
* @param Options_Data $options Options instance.
*/
public function __construct( Data $data, Options_Data $options ) {
$this->data = $data;
$this->options = $options;
}
/**
* Registers the REST route to get the support data
*
* @since 3.7.5
*
* @return void
*/
public function register_route() {
register_rest_route(
self::ROUTE_NAMESPACE,
'support',
[
'methods' => 'POST',
'callback' => [ $this, 'get_support_data' ],
'args' => [
'email' => [
'required' => true,
'validate_callback' => [ $this, 'validate_email' ],
],
'key' => [
'required' => true,
'validate_callback' => [ $this, 'validate_key' ],
],
],
'permission_callback' => '__return_true',
]
);
}
/**
* Returns the support data if the referer is correct
*
* @since 3.7.5
*
* @return WP_REST_Response
*/
public function get_support_data() {
return rest_ensure_response(
[
'code' => 'rest_support_data_success',
'message' => 'Support data request successful',
'data' => [
'status' => 200,
'content' => $this->data->get_support_data(),
],
]
);
}
/**
* Checks that the email sent along the request corresponds to the one saved in the DB
*
* @since 3.7.5
*
* @param string $param Parameter value to validate.
*
* @return bool
*/
public function validate_email( $param ) {
return ! empty( $param ) && $param === $this->options->get( 'consumer_email', '' );
}
/**
* Checks that the key sent along the request corresponds to the one saved in the DB
*
* @since 3.7.5
*
* @param string $param Parameter value to validate.
*
* @return bool
*/
public function validate_key( $param ) {
return ! empty( $param ) && $param === $this->options->get( 'consumer_key', '' );
}
}