File "wp_autoupdate.php"
Full Path: /www/wwwroot/shphe-en.com/wp-content/plugins/modern-admin/wp_autoupdate.php
File size: 3.96 KB
MIME-type: --
Charset: utf-8
<?php
class modern_admin_auto_update
{
/**
* The plugin current version
* @var string
*/
public $current_version;
/**
* The plugin remote update path
* @var string
*/
public $update_path;
/**
* Plugin Slug (plugin_directory/plugin_file.php)
* @var string
*/
public $plugin_slug;
/**
* Plugin name (plugin_file)
* @var string
*/
public $slug;
public $license;
/**
* Initialize a new instance of the WordPress Auto-Update class
* @param string $current_version
* @param string $update_path
* @param string $plugin_slug
*/
function __construct($license,$current_version, $update_path, $plugin_slug)
{
// Set the class public variables
$this->license = $license;
$this->current_version = $current_version;
$this->update_path = $update_path;
$this->plugin_slug = $plugin_slug;
list ($t1, $t2) = explode('/', $plugin_slug);
$this->slug = str_replace('.php', '', $t2);
// define the alternative API for updating checking
add_filter('pre_set_site_transient_update_plugins', array(&$this, 'check_update'));
// Define the alternative response for information checking
add_filter('plugins_api', array(&$this, 'check_info'), 10, 3);
}
/**
* Add our self-hosted autoupdate plugin to the filter transient
*
* @param $transient
* @return object $ transient
*/
public function check_update($transient)
{
if (empty($transient->checked)) {
return $transient;
}
// Get the remote version
$remote_version = $this->getRemote_version();
// If a newer version is available, add the update
if (version_compare($this->current_version, $remote_version['version'], '<')) {
$obj = new stdClass();
$obj->slug = $this->slug;
$obj->new_version = $remote_version['version'];
$obj->url = $this->update_path;
$obj->package = $remote_version['link'];
$transient->response[$this->plugin_slug] = $obj;
}
return $transient;
}
/**
* Add our self-hosted description to the filter
*
* @param boolean $false
* @param array $action
* @param object $arg
* @return bool|object
*/
public function check_info($false, $action, $arg)
{
if (isset($arg->slug) && $arg->slug === $this->slug) {
$information = $this->getRemote_information();
return $information;
}
return false;
}
/**
* Return the remote version
* @return string $remote_version
*/
public function getRemote_version()
{
global $wp_version;
$args = array(
'slug' => $this->slug,
'key'=>$this->license,
'url' =>home_url()
);
$request = wp_remote_post($this->update_path, array('body' => array('action' => 'version','request' => serialize($args)),'user-agent' => 'WordPress/' . $wp_version . '; ' . home_url()));
if (!is_wp_error($request) || wp_remote_retrieve_response_code($request) === 200) {
return unserialize($request['body']);
}
return false;
}
/**
* Get information about the remote version
* @return bool|object
*/
public function getRemote_information()
{
global $wp_version;
$args = array(
'slug' => $this->slug,
'key'=>$this->license,
'url' =>home_url()
);
$request = wp_remote_post($this->update_path, array('body' => array('action' => 'info','request' => serialize($args)),'user-agent' => 'WordPress/' . $wp_version . '; ' . home_url()));
if (!is_wp_error($request) || wp_remote_retrieve_response_code($request) === 200) {
return unserialize($request['body']);
}
return false;
}
}