class-wpml-tm-options-ajax.php
1.76 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
<?php
class WPML_TM_Options_Ajax {
const NONCE_TRANSLATED_DOCUMENT = 'wpml-translated-document-options-nonce';
private $sitepress;
public function __construct( SitePress $sitepress ) {
$this->sitepress = $sitepress;
}
public function ajax_hooks() {
add_action( 'wp_ajax_wpml_translated_document_options', array( $this, 'wpml_translated_document_options' ) );
}
public function wpml_translated_document_options() {
if ( ! $this->is_valid_request() ) {
wp_send_json_error();
} else {
$settings = $this->sitepress->get_settings();
if ( array_key_exists( 'document_status', $_POST ) ) {
$settings['translated_document_status'] = filter_var( $_POST['document_status'], FILTER_SANITIZE_NUMBER_INT, FILTER_NULL_ON_FAILURE );
}
// phpcs:ignore WordPress.Security.NonceVerification.Missing
if ( array_key_exists( 'document_status_sync', $_POST ) ) {
// phpcs:ignore WordPress.Security.NonceVerification.Missing
$settings['translated_document_status_sync'] = filter_var( $_POST['document_status_sync'], FILTER_SANITIZE_NUMBER_INT, FILTER_NULL_ON_FAILURE );
}
if ( array_key_exists( 'page_url', $_POST ) ) {
$settings['translated_document_page_url'] = filter_var( $_POST['page_url'], FILTER_SANITIZE_FULL_SPECIAL_CHARS, FILTER_NULL_ON_FAILURE );
}
if ( $settings ) {
$this->sitepress->save_settings( $settings );
}
wp_send_json_success();
}
}
private function is_valid_request() {
$valid_request = true;
if ( ! array_key_exists( 'nonce', $_POST ) ) {
$valid_request = false;
}
if ( $valid_request ) {
$nonce = $_POST['nonce'];
$nonce_is_valid = wp_verify_nonce( $nonce, self::NONCE_TRANSLATED_DOCUMENT );
if ( ! $nonce_is_valid ) {
$valid_request = false;
}
}
return $valid_request;
}
}