Feedback.php
1.33 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
<?php
namespace ACP\RequestHandler\Ajax;
use AC\Capabilities;
use AC\Nonce;
use AC\Plugin\Version;
use AC\Request;
use ACP\RequestAjaxHandler;
class Feedback implements RequestAjaxHandler {
/**
* @var Version
*/
private $version;
public function __construct( Version $version ) {
$this->version = $version;
}
public function handle(): void {
if ( ! current_user_can( Capabilities::MANAGE ) ) {
return;
}
$request = new Request();
if ( ! ( new Nonce\Ajax() )->verify( $request ) ) {
wp_send_json_error( __( 'Invalid request', 'codepress-admin-columns' ) );
}
$email = $request->filter( 'email', null, FILTER_SANITIZE_EMAIL );
if ( ! is_email( $email ) ) {
wp_send_json_error( __( 'Please insert a valid email so we can reply to your feedback.', 'codepress-admin-columns' ) );
}
$feedback = $request->filter( 'feedback', null, FILTER_SANITIZE_STRING );
if ( empty( $feedback ) ) {
wp_send_json_error( __( 'Your feedback form is empty.', 'codepress-admin-columns' ) );
}
$headers = [
sprintf( 'From: <%s>', trim( $email ) ),
'Content-Type: text/html',
];
wp_mail(
acp_support_email(),
sprintf( 'Beta Feedback on Admin Columns Pro %s', $this->version->get_value() ),
nl2br( $feedback ),
$headers
);
wp_send_json_success( __( 'Thank you very much for your feedback!' ) );
}
}