updates package er in
This commit is contained in:
parent
91ad91473c
commit
4e8270e882
@ -26,3 +26,4 @@ add_action('wp_enqueue_scripts', function(){
|
|||||||
|
|
||||||
\CampingCareWidget\Widget::init();
|
\CampingCareWidget\Widget::init();
|
||||||
\CampingCareWidget\Admin::init();
|
\CampingCareWidget\Admin::init();
|
||||||
|
\CampingCareWidget\Updates::init();
|
||||||
|
|||||||
90
src/Updates.php
Normal file
90
src/Updates.php
Normal file
@ -0,0 +1,90 @@
|
|||||||
|
<?php
|
||||||
|
|
||||||
|
namespace CampingCareWidget;
|
||||||
|
|
||||||
|
class Updates
|
||||||
|
{
|
||||||
|
|
||||||
|
public static function init()
|
||||||
|
{
|
||||||
|
|
||||||
|
add_filter('plugins_api', [static::class, 'get_plugin_info'], 20, 3);
|
||||||
|
}
|
||||||
|
|
||||||
|
/*
|
||||||
|
* $res empty at this step
|
||||||
|
* $action 'plugin_information'
|
||||||
|
* $args stdClass Object ( [slug] => woocommerce [is_ssl] => [fields] => Array ( [banners] => 1 [reviews] => 1 [downloaded] => [active_installs] => 1 ) [per_page] => 24 [locale] => en_US )
|
||||||
|
*/
|
||||||
|
function get_plugin_info($res, $action, $args)
|
||||||
|
{
|
||||||
|
|
||||||
|
// do nothing if this is not about getting plugin information
|
||||||
|
if ('plugin_information' !== $action) {
|
||||||
|
return $res;
|
||||||
|
}
|
||||||
|
|
||||||
|
$pluginName = plugin_basename(__DIR__);
|
||||||
|
|
||||||
|
// do nothing if it is not our plugin
|
||||||
|
if ($pluginName !== $args->slug) {
|
||||||
|
return $res;
|
||||||
|
}
|
||||||
|
|
||||||
|
// info.json is the file with the actual plugin information on your server
|
||||||
|
$remote = wp_remote_get(
|
||||||
|
'https://wordpress-plugin-repository.exp.sforum.nl/plugins/' . urlencode($pluginName) . '/info.json',
|
||||||
|
array(
|
||||||
|
'timeout' => 10,
|
||||||
|
'headers' => array(
|
||||||
|
'Accept' => 'application/json'
|
||||||
|
)
|
||||||
|
)
|
||||||
|
);
|
||||||
|
|
||||||
|
// do nothing if we don't get the correct response from the server
|
||||||
|
if (
|
||||||
|
is_wp_error($remote)
|
||||||
|
|| 200 !== wp_remote_retrieve_response_code($remote)
|
||||||
|
|| empty(wp_remote_retrieve_body($remote))
|
||||||
|
) {
|
||||||
|
return $res;
|
||||||
|
}
|
||||||
|
|
||||||
|
$res = json_decode(wp_remote_retrieve_body($remote));
|
||||||
|
return $res;
|
||||||
|
//
|
||||||
|
// $res = (object)[];
|
||||||
|
// $res->name = $remote->name;
|
||||||
|
// $res->slug = $remote->slug;
|
||||||
|
// $res->author = $remote->author;
|
||||||
|
// $res->author_profile = $remote->author_profile;
|
||||||
|
// $res->version = $remote->version;
|
||||||
|
// $res->tested = $remote->tested;
|
||||||
|
// $res->requires = $remote->requires;
|
||||||
|
// $res->requires_php = $remote->requires_php;
|
||||||
|
// $res->download_link = $remote->download_url;
|
||||||
|
// $res->trunk = $remote->download_url;
|
||||||
|
// $res->last_updated = $remote->last_updated;
|
||||||
|
// $res->sections = array(
|
||||||
|
// 'description' => $remote->sections->description,
|
||||||
|
// 'installation' => $remote->sections->installation,
|
||||||
|
// 'changelog' => $remote->sections->changelog
|
||||||
|
// // you can add your custom sections (tabs) here
|
||||||
|
// );
|
||||||
|
// // in case you want the screenshots tab, use the following HTML format for its content:
|
||||||
|
// // <ol><li><a href="IMG_URL" target="_blank"><img src="IMG_URL" alt="CAPTION" /></a><p>CAPTION</p></li></ol>
|
||||||
|
// if (!empty($remote->sections->screenshots)) {
|
||||||
|
// $res->sections['screenshots'] = $remote->sections->screenshots;
|
||||||
|
// }
|
||||||
|
//
|
||||||
|
// $res->banners = array(
|
||||||
|
// 'low' => $remote->banners->low,
|
||||||
|
// 'high' => $remote->banners->high
|
||||||
|
// );
|
||||||
|
//
|
||||||
|
// return $res;
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
}
|
||||||
Loading…
x
Reference in New Issue
Block a user