wordproof-helper.php
3.01 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
110
111
112
113
114
115
116
<?php
namespace Yoast\WP\SEO\Helpers;
use ReflectionClass;
use Yoast\WP\SEO\Conditionals\Non_Multisite_Conditional;
use Yoast\WP\SEO\Conditionals\Third_Party\Wordproof_Plugin_Inactive_Conditional;
use Yoast\WP\SEO\Conditionals\User_Can_Publish_Posts_And_Pages_Conditional;
/**
* A helper object for WordProof integration.
*/
class Wordproof_Helper {
/**
* Holds the Current Page helper instance.
*
* @var Current_Page_Helper
*/
protected $current_page;
/**
* Holds the WooCommerce helper instance.
*
* @var Woocommerce_Helper
*/
protected $woocommerce;
/**
* Holds the Options Page helper instance.
*
* @var Options_Helper
*/
protected $options;
/**
* WordProof_Helper constructor.
*
* @param Current_Page_Helper $current_page The current page helper.
* @param Woocommerce_Helper $woocommerce The woocommerce helper.
* @param Options_Helper $options The options helper.
*/
public function __construct( Current_Page_Helper $current_page, Woocommerce_Helper $woocommerce, Options_Helper $options ) {
$this->current_page = $current_page;
$this->woocommerce = $woocommerce;
$this->options = $options;
}
/**
* Remove site options after disabling the integration.
*
* @return bool Returns if the options are deleted
*/
public function remove_site_options() {
return \delete_site_option( 'wordproof_access_token' )
&& \delete_site_option( 'wordproof_source_id' );
}
/**
* Returns if conditionals are met. If not, the integration should be disabled.
*
* @param bool $return_conditional If the conditional class name that was unmet should be returned.
*
* @return bool|string Returns if the integration should be disabled.
*/
public function integration_is_disabled( $return_conditional = false ) {
$conditionals = [ new Non_Multisite_Conditional(), new Wordproof_Plugin_Inactive_Conditional() ];
foreach ( $conditionals as $conditional ) {
if ( ! $conditional->is_met() ) {
if ( $return_conditional === true ) {
return ( new ReflectionClass( $conditional ) )->getShortName();
}
return true;
}
}
return false;
}
/**
* Returns if the WordProof integration toggle is turned on.
*
* @return bool Returns if the integration toggle is set to true if conditionals are met.
*/
public function integration_is_active() {
if ( $this->integration_is_disabled() ) {
return false;
}
return $this->options->get( 'wordproof_integration_active', true );
}
/**
* Return if WordProof should be active for this post editor page.
*
* @return bool Returns if WordProof should be active for this page.
*/
public function is_active() {
$is_wordproof_active = $this->integration_is_active();
if ( ! $is_wordproof_active ) {
return false;
}
$user_can_publish = ( new User_Can_Publish_Posts_And_Pages_Conditional() )->is_met();
if ( ! $user_can_publish ) {
return false;
}
return ( $this->current_page->current_post_is_privacy_policy() || $this->woocommerce->current_post_is_terms_and_conditions_page() );
}
}