123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188 |
- <?php
- namespace YahnisElsts\PluginUpdateChecker\v5p0\Plugin;
- use YahnisElsts\PluginUpdateChecker\v5p0\InstalledPackage;
- use YahnisElsts\PluginUpdateChecker\v5p0\PucFactory;
- if ( !class_exists(Package::class, false) ):
- class Package extends InstalledPackage {
- /**
- * @var UpdateChecker
- */
- protected $updateChecker;
- /**
- * @var string Full path of the main plugin file.
- */
- protected $pluginAbsolutePath = '';
- /**
- * @var string Plugin basename.
- */
- private $pluginFile;
- /**
- * @var string|null
- */
- private $cachedInstalledVersion = null;
- public function __construct($pluginAbsolutePath, $updateChecker) {
- $this->pluginAbsolutePath = $pluginAbsolutePath;
- $this->pluginFile = plugin_basename($this->pluginAbsolutePath);
- parent::__construct($updateChecker);
- //Clear the version number cache when something - anything - is upgraded or WP clears the update cache.
- add_filter('upgrader_post_install', array($this, 'clearCachedVersion'));
- add_action('delete_site_transient_update_plugins', array($this, 'clearCachedVersion'));
- }
- public function getInstalledVersion() {
- if ( isset($this->cachedInstalledVersion) ) {
- return $this->cachedInstalledVersion;
- }
- $pluginHeader = $this->getPluginHeader();
- if ( isset($pluginHeader['Version']) ) {
- $this->cachedInstalledVersion = $pluginHeader['Version'];
- return $pluginHeader['Version'];
- } else {
- //This can happen if the filename points to something that is not a plugin.
- $this->updateChecker->triggerError(
- sprintf(
- "Can't to read the Version header for '%s'. The filename is incorrect or is not a plugin.",
- $this->updateChecker->pluginFile
- ),
- E_USER_WARNING
- );
- return null;
- }
- }
- /**
- * Clear the cached plugin version. This method can be set up as a filter (hook) and will
- * return the filter argument unmodified.
- *
- * @param mixed $filterArgument
- * @return mixed
- */
- public function clearCachedVersion($filterArgument = null) {
- $this->cachedInstalledVersion = null;
- return $filterArgument;
- }
- public function getAbsoluteDirectoryPath() {
- return dirname($this->pluginAbsolutePath);
- }
- /**
- * Get the value of a specific plugin or theme header.
- *
- * @param string $headerName
- * @param string $defaultValue
- * @return string Either the value of the header, or $defaultValue if the header doesn't exist or is empty.
- */
- public function getHeaderValue($headerName, $defaultValue = '') {
- $headers = $this->getPluginHeader();
- if ( isset($headers[$headerName]) && ($headers[$headerName] !== '') ) {
- return $headers[$headerName];
- }
- return $defaultValue;
- }
- protected function getHeaderNames() {
- return array(
- 'Name' => 'Plugin Name',
- 'PluginURI' => 'Plugin URI',
- 'Version' => 'Version',
- 'Description' => 'Description',
- 'Author' => 'Author',
- 'AuthorURI' => 'Author URI',
- 'TextDomain' => 'Text Domain',
- 'DomainPath' => 'Domain Path',
- 'Network' => 'Network',
- //The newest WordPress version that this plugin requires or has been tested with.
- //We support several different formats for compatibility with other libraries.
- 'Tested WP' => 'Tested WP',
- 'Requires WP' => 'Requires WP',
- 'Tested up to' => 'Tested up to',
- 'Requires at least' => 'Requires at least',
- );
- }
- /**
- * Get the translated plugin title.
- *
- * @return string
- */
- public function getPluginTitle() {
- $title = '';
- $header = $this->getPluginHeader();
- if ( $header && !empty($header['Name']) && isset($header['TextDomain']) ) {
- $title = translate($header['Name'], $header['TextDomain']);
- }
- return $title;
- }
- /**
- * Get plugin's metadata from its file header.
- *
- * @return array
- */
- public function getPluginHeader() {
- if ( !is_file($this->pluginAbsolutePath) ) {
- //This can happen if the plugin filename is wrong.
- $this->updateChecker->triggerError(
- sprintf(
- "Can't to read the plugin header for '%s'. The file does not exist.",
- $this->updateChecker->pluginFile
- ),
- E_USER_WARNING
- );
- return array();
- }
- if ( !function_exists('get_plugin_data') ) {
- require_once(ABSPATH . '/wp-admin/includes/plugin.php');
- }
- return get_plugin_data($this->pluginAbsolutePath, false, false);
- }
- public function removeHooks() {
- remove_filter('upgrader_post_install', array($this, 'clearCachedVersion'));
- remove_action('delete_site_transient_update_plugins', array($this, 'clearCachedVersion'));
- }
- /**
- * Check if the plugin file is inside the mu-plugins directory.
- *
- * @return bool
- */
- public function isMuPlugin() {
- static $cachedResult = null;
- if ( $cachedResult === null ) {
- if ( !defined('WPMU_PLUGIN_DIR') || !is_string(WPMU_PLUGIN_DIR) ) {
- $cachedResult = false;
- return $cachedResult;
- }
- //Convert both paths to the canonical form before comparison.
- $muPluginDir = realpath(WPMU_PLUGIN_DIR);
- $pluginPath = realpath($this->pluginAbsolutePath);
- //If realpath() fails, just normalize the syntax instead.
- if (($muPluginDir === false) || ($pluginPath === false)) {
- $muPluginDir = PucFactory::normalizePath(WPMU_PLUGIN_DIR);
- $pluginPath = PucFactory::normalizePath($this->pluginAbsolutePath);
- }
- $cachedResult = (strpos($pluginPath, $muPluginDir) === 0);
- }
- return $cachedResult;
- }
- }
- endif;
|