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
|
<?php /** * WPSEO plugin file. * * @package WPSEO\Admin */
/** * Represents the class that contains the list of possible extensions for Yoast SEO. */ class WPSEO_Extensions {
/** * Array with the Yoast extensions. * * @var array */ protected $extensions = array( 'Yoast SEO Premium' => array( 'slug' => 'yoast-seo-premium', 'identifier' => 'wordpress-seo-premium', 'classname' => 'WPSEO_Premium', 'my-yoast-slug' => WPSEO_Addon_Manager::PREMIUM_SLUG, ), 'News SEO' => array( 'slug' => 'news-seo', 'identifier' => 'wpseo-news', 'classname' => 'WPSEO_News', 'my-yoast-slug' => WPSEO_Addon_Manager::NEWS_SLUG, ), 'Yoast WooCommerce SEO' => array( 'slug' => 'woocommerce-yoast-seo', 'identifier' => 'wpseo-woocommerce', 'classname' => 'Yoast_WooCommerce_SEO', 'my-yoast-slug' => WPSEO_Addon_Manager::WOOCOMMERCE_SLUG, ), 'Video SEO' => array( 'slug' => 'video-seo-for-wordpress', 'identifier' => 'wpseo-video', 'classname' => 'WPSEO_Video_Sitemap', 'my-yoast-slug' => WPSEO_Addon_Manager::VIDEO_SLUG, ), 'Local SEO' => array( 'slug' => 'local-seo-for-wordpress', 'identifier' => 'wpseo-local', 'classname' => 'WPSEO_Local_Core', 'my-yoast-slug' => WPSEO_Addon_Manager::LOCAL_SLUG, ), );
/** * Returns the set extensions. * * @return array All the extension names. */ public function get() { return array_keys( $this->extensions ); }
/** * Checks if the extension is valid. * * @param string $extension The extension to get the name for. * * @return bool Returns true when valid. */ public function is_valid( $extension ) { $addon_manager = new WPSEO_Addon_Manager(); return $addon_manager->has_valid_subscription( $this->extensions[ $extension ]['my-yoast-slug'] ); }
/** * Invalidates the extension by removing its option. * * @param string $extension The extension to invalidate. */ public function invalidate( $extension ) { /* * Make sure we clear the current site and multisite options. * * Because plugins can be site-activated or multi-site activated we need to clear * all possible options. * * If we knew here that the extension in question was network activated * we could do this a lot more easily. */ delete_option( $this->get_option_name( $extension ) ); delete_site_option( $this->get_option_name( $extension ) ); }
/** * Checks if the plugin has been installed. * * @param string $extension The name of the plugin to check. * * @return bool Returns true when installed. */ public function is_installed( $extension ) { return class_exists( $this->extensions[ $extension ]['classname'] ); }
/** * Converts the extension to the required option name. * * @param string $extension The extension name to convert. * * @return string Returns the option name. */ protected function get_option_name( $extension ) { return sanitize_title_with_dashes( $this->extensions[ $extension ]['slug'] . '_', null, 'save' ) . 'license'; } }
|