status_code != 200) { debug_event('autoupdate', 'Github API request ' . $url . ' failed with http code ' . $request->status_code, '1'); return null; } return json_decode($request->body); } catch (Exception $e) { debug_event('autoupdate', 'Request error: ' . $e->getMessage(), '1'); return null; } } /** * Check if last github check expired. * @return boolean */ protected static function lastcheck_expired() { $lastcheck = AmpConfig::get('autoupdate_lastcheck'); if (!$lastcheck) { Preference::update('autoupdate_lastcheck', $GLOBALS['user']->id, '1'); AmpConfig::set('autoupdate_lastcheck', '1', true); } return ((time() - (3600 * 3)) > $lastcheck); } /** * Get latest available version from GitHub. * @param boolean $force * @return string */ public static function get_latest_version($force = false) { $lastversion = ''; // Forced or last check expired, check latest version from Github if ($force || (self::lastcheck_expired() && AmpConfig::get('autoupdate'))) { // Always update last check time to avoid infinite check on permanent errors (proxy, firewall, ...) $time = time(); Preference::update('autoupdate_lastcheck', $GLOBALS['user']->id, $time); AmpConfig::set('autoupdate_lastcheck', $time, true); // Development version, get latest commit on develop branch if (self::is_develop()) { $commits = self::github_request('/commits/develop'); if (!empty($commits)) { $lastversion = $commits->sha; Preference::update('autoupdate_lastversion', $GLOBALS['user']->id, $lastversion); AmpConfig::set('autoupdate_lastversion', $lastversion, true); $available = self::is_update_available(true); Preference::update('autoupdate_lastversion_new', $GLOBALS['user']->id, $available); AmpConfig::set('autoupdate_lastversion_new', $available, true); } } // Otherwise it is stable version, get latest tag else { $tags = self::github_request('/tags'); if (!empty($tags)) { $lastversion = $tags[0]->name; Preference::update('autoupdate_lastversion', $GLOBALS['user']->id, $lastversion); AmpConfig::set('autoupdate_lastversion', $lastversion, true); $available = self::is_update_available(true); Preference::update('autoupdate_lastversion_new', $GLOBALS['user']->id, $available); AmpConfig::set('autoupdate_lastversion_new', $available, true); } } } // Otherwise retrieve the cached version number else { $lastversion = AmpConfig::get('autoupdate_lastversion'); } return $lastversion; } /** * Get current local version. * @return string */ public static function get_current_version() { if (self::is_develop()) { return self::get_current_commit(); } else { return AmpConfig::get('version'); } } /** * Get current local git commit. * @return string */ public static function get_current_commit() { if (self::is_branch_develop_exists()) { return trim(file_get_contents(AmpConfig::get('prefix') . '/.git/refs/heads/develop')); } return ''; } /** * Check if an update is available. * @param boolean $force * @return boolean */ public static function is_update_available($force = false) { if (!$force && (!self::lastcheck_expired() || !AmpConfig::get('autoupdate'))) { return AmpConfig::get('autoupdate_lastversion_new'); } debug_event('autoupdate', 'Checking latest version online...', '5'); $available = false; $current = self::get_current_version(); $latest = self::get_latest_version(); if ($current != $latest && !empty($current)) { if (self::is_develop()) { $ccommit = self::github_request('/commits/' . $current); $lcommit = self::github_request('/commits/' . $latest); if (!empty($ccommit) && !empty($lcommit)) { // Comparison based on commit date $ctime = strtotime($ccommit->commit->author->date); $ltime = strtotime($lcommit->commit->author->date); $available = ($ctime < $ltime); } } else { $cpart = explode('-', $current); $lpart = explode('-', $latest); $available = (version_compare($cpart[0], $lpart[0]) < 0); } } return $available; } /** * Display new version information and update link if possible. */ public static function show_new_version() { echo '